[Intel-gfx] [PATCH] drm/i915: Allow panel fixed modes to have differing sync polarities
Jani Nikula
jani.nikula at linux.intel.com
Thu Oct 13 06:46:27 UTC 2022
On Fri, 07 Oct 2022, Ville Syrjala <ville.syrjala at linux.intel.com> wrote:
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Apparently some panels declare multiple modes with random
> sync polarities. Seems a bit weird, but looks like Windows/GOP
> doesn't care, so let follow suit and accept alternate fixed
> modes regardless of their sync polarities.
>
> Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/6968
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_panel.c | 10 +++++++---
> 1 file changed, 7 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_panel.c b/drivers/gpu/drm/i915/display/intel_panel.c
> index 2b4b359b8342..fdeb1cd608c3 100644
> --- a/drivers/gpu/drm/i915/display/intel_panel.c
> +++ b/drivers/gpu/drm/i915/display/intel_panel.c
> @@ -82,12 +82,16 @@ static bool is_alt_drrs_mode(const struct drm_display_mode *mode,
> mode->clock != preferred_mode->clock;
> }
>
> +#define DRM_MODE_FLAG_SYNC_MASK (DRM_MODE_FLAG_PHSYNC | \
> + DRM_MODE_FLAG_NHSYNC | \
> + DRM_MODE_FLAG_PVSYNC | \
> + DRM_MODE_FLAG_NVSYNC)
Maybe not the best to name the macro in the DRM_MODE_* "namespace"?
Other than that,
Acked-by: Jani Nikula <jani.nikula at intel.com>
> +
> static bool is_alt_fixed_mode(const struct drm_display_mode *mode,
> const struct drm_display_mode *preferred_mode)
> {
> - return drm_mode_match(mode, preferred_mode,
> - DRM_MODE_MATCH_FLAGS |
> - DRM_MODE_MATCH_3D_FLAGS) &&
> + return (mode->flags & ~DRM_MODE_FLAG_SYNC_MASK) ==
> + (preferred_mode->flags & ~DRM_MODE_FLAG_SYNC_MASK) &&
> mode->hdisplay == preferred_mode->hdisplay &&
> mode->vdisplay == preferred_mode->vdisplay;
> }
--
Jani Nikula, Intel Open Source Graphics Center
More information about the Intel-gfx
mailing list