}
}
+static enum drm_mode_status
+intel_hdmi_mode_valid_format(struct intel_connector *connector,
+ const struct drm_display_mode *mode,
+ int clock, bool has_hdmi_sink,
+ enum intel_output_format sink_format)
+{
+ struct intel_display *display = to_intel_display(connector);
+ enum drm_mode_status status;
+
+ status = intel_hdmi_sink_format_valid(connector, mode,
+ has_hdmi_sink, sink_format);
+ if (status != MODE_OK)
+ return status;
+
+ status = intel_pfit_mode_valid(display, mode, sink_format, 0);
+ if (status != MODE_OK)
+ return status;
+
+ return intel_hdmi_mode_clock_valid(&connector->base, clock, has_hdmi_sink, sink_format);
+}
+
static enum drm_mode_status
intel_hdmi_mode_valid(struct drm_connector *_connector,
const struct drm_display_mode *mode)
struct intel_connector *connector = to_intel_connector(_connector);
struct intel_display *display = to_intel_display(connector);
struct intel_hdmi *hdmi = intel_attached_hdmi(connector);
+ const struct drm_display_info *info = &connector->base.display_info;
enum drm_mode_status status;
int clock = mode->clock;
int max_dotclk = display->cdclk.max_dotclk_freq;
bool has_hdmi_sink = intel_has_hdmi_sink(hdmi, connector->base.state);
- bool ycbcr_420_only;
- enum intel_output_format sink_format;
status = intel_cpu_transcoder_mode_valid(display, mode);
if (status != MODE_OK)
if (clock > 600000)
return MODE_CLOCK_HIGH;
- ycbcr_420_only = drm_mode_is_420_only(&connector->base.display_info, mode);
-
- if (ycbcr_420_only)
- sink_format = INTEL_OUTPUT_FORMAT_YCBCR420;
- else
- sink_format = INTEL_OUTPUT_FORMAT_RGB;
+ if (drm_mode_is_420_only(info, mode)) {
+ status = intel_hdmi_mode_valid_format(connector, mode, clock, has_hdmi_sink,
+ INTEL_OUTPUT_FORMAT_YCBCR420);
+ } else {
+ status = intel_hdmi_mode_valid_format(connector, mode, clock, has_hdmi_sink,
+ INTEL_OUTPUT_FORMAT_RGB);
- status = intel_pfit_mode_valid(display, mode, sink_format, 0);
+ if (status != MODE_OK && drm_mode_is_420_also(info, mode))
+ status = intel_hdmi_mode_valid_format(connector, mode, clock, has_hdmi_sink,
+ INTEL_OUTPUT_FORMAT_YCBCR420);
+ }
if (status != MODE_OK)
return status;
- status = intel_hdmi_mode_clock_valid(&connector->base, clock, has_hdmi_sink, sink_format);
- if (status != MODE_OK) {
- if (ycbcr_420_only ||
- !connector->base.ycbcr_420_allowed ||
- !drm_mode_is_420_also(&connector->base.display_info, mode))
- return status;
-
- sink_format = INTEL_OUTPUT_FORMAT_YCBCR420;
-
- status = intel_pfit_mode_valid(display, mode, sink_format, 0);
- if (status != MODE_OK)
- return status;
-
- status = intel_hdmi_mode_clock_valid(&connector->base, clock, has_hdmi_sink,
- sink_format);
- if (status != MODE_OK)
- return status;
- }
-
return intel_mode_valid_max_plane_size(display, mode, 1);
}