mirror of
https://github.com/torvalds/linux.git
synced 2026-05-29 17:43:52 +02:00
drm/bridge: synopsys: dw-hdmi: Convert to drm_output_color_format
Now that we introduced a new drm_output_color_format enum to represent what DRM_COLOR_FORMAT_* bits were representing, we can switch to the new enum. The main difference is that while DRM_COLOR_FORMAT_ was a bitmask, drm_output_color_format is a proper enum. However, the enum was done is such a way than DRM_COLOR_FORMAT_X = BIT(DRM_OUTPUT_COLOR_FORMAT_X) so the transitition is easier. The only thing we need to consider is if the original code meant to use that value as a bitmask, in which case we do need to keep the bit shift, or as a discriminant in which case we don't. Reviewed-by: Philipp Zabel <p.zabel@pengutronix.de> Acked-by: Jani Nikula <jani.nikula@intel.com> Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com> Link: https://lore.kernel.org/r/20260305-drm-rework-color-formats-v3-9-f3935f6db579@kernel.org Signed-off-by: Maxime Ripard <mripard@kernel.org>
This commit is contained in:
parent
04b4e39a14
commit
4bf05805b6
|
|
@ -2664,7 +2664,7 @@ static u32 *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge,
|
|||
struct drm_display_mode *mode = &crtc_state->mode;
|
||||
u8 max_bpc = conn_state->max_requested_bpc;
|
||||
bool is_hdmi2_sink = info->hdmi.scdc.supported ||
|
||||
(info->color_formats & DRM_COLOR_FORMAT_YCBCR420);
|
||||
(info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR420));
|
||||
u32 *output_fmts;
|
||||
unsigned int i = 0;
|
||||
|
||||
|
|
@ -2723,36 +2723,36 @@ static u32 *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge,
|
|||
output_fmts[i++] = MEDIA_BUS_FMT_RGB888_1X24;
|
||||
|
||||
if (max_bpc >= 16 && info->bpc == 16) {
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR444))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_YUV16_1X48;
|
||||
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_RGB161616_1X48;
|
||||
}
|
||||
|
||||
if (max_bpc >= 12 && info->bpc >= 12) {
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR422)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR422))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_UYVY12_1X24;
|
||||
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR444))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_YUV12_1X36;
|
||||
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_RGB121212_1X36;
|
||||
}
|
||||
|
||||
if (max_bpc >= 10 && info->bpc >= 10) {
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR422)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR422))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_UYVY10_1X20;
|
||||
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR444))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_YUV10_1X30;
|
||||
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_RGB101010_1X30;
|
||||
}
|
||||
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR422)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR422))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_UYVY8_1X16;
|
||||
|
||||
if (info->color_formats & DRM_COLOR_FORMAT_YCBCR444)
|
||||
if (info->color_formats & BIT(DRM_OUTPUT_COLOR_FORMAT_YCBCR444))
|
||||
output_fmts[i++] = MEDIA_BUS_FMT_YUV8_1X24;
|
||||
|
||||
*num_output_fmts = i;
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user