On Thu, 05 Jun 2025, Imre Deak <imre.d...@intel.com> wrote:
> An enum list is better suited to define a quirk list, do that. This
> makes looking up a quirk more robust and also allows for separating
> quirks internal to the EDID parser and global quirks which can be
> queried outside of the EDID parser (added as a follow-up).
>
> Suggested-by: Jani Nikula <jani.nik...@linux.intel.com>
> Signed-off-by: Imre Deak <imre.d...@intel.com>

Reviewed-by: Jani Nikula <jani.nik...@intel.com>

> ---
>  drivers/gpu/drm/drm_edid.c | 218 +++++++++++++++++++------------------
>  1 file changed, 112 insertions(+), 106 deletions(-)
>
> diff --git a/drivers/gpu/drm/drm_edid.c b/drivers/gpu/drm/drm_edid.c
> index 74e77742b2bd4..857ae0c47a1c3 100644
> --- a/drivers/gpu/drm/drm_edid.c
> +++ b/drivers/gpu/drm/drm_edid.c
> @@ -66,34 +66,36 @@ static int oui(u8 first, u8 second, u8 third)
>   * on as many displays as possible).
>   */
>  
> -/* First detailed mode wrong, use largest 60Hz mode */
> -#define EDID_QUIRK_PREFER_LARGE_60           (1 << 0)
> -/* Reported 135MHz pixel clock is too high, needs adjustment */
> -#define EDID_QUIRK_135_CLOCK_TOO_HIGH                (1 << 1)
> -/* Prefer the largest mode at 75 Hz */
> -#define EDID_QUIRK_PREFER_LARGE_75           (1 << 2)
> -/* Detail timing is in cm not mm */
> -#define EDID_QUIRK_DETAILED_IN_CM            (1 << 3)
> -/* Detailed timing descriptors have bogus size values, so just take the
> - * maximum size and use that.
> - */
> -#define EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE (1 << 4)
> -/* use +hsync +vsync for detailed mode */
> -#define EDID_QUIRK_DETAILED_SYNC_PP          (1 << 6)
> -/* Force reduced-blanking timings for detailed modes */
> -#define EDID_QUIRK_FORCE_REDUCED_BLANKING    (1 << 7)
> -/* Force 8bpc */
> -#define EDID_QUIRK_FORCE_8BPC                        (1 << 8)
> -/* Force 12bpc */
> -#define EDID_QUIRK_FORCE_12BPC                       (1 << 9)
> -/* Force 6bpc */
> -#define EDID_QUIRK_FORCE_6BPC                        (1 << 10)
> -/* Force 10bpc */
> -#define EDID_QUIRK_FORCE_10BPC                       (1 << 11)
> -/* Non desktop display (i.e. HMD) */
> -#define EDID_QUIRK_NON_DESKTOP                       (1 << 12)
> -/* Cap the DSC target bitrate to 15bpp */
> -#define EDID_QUIRK_CAP_DSC_15BPP             (1 << 13)
> +enum drm_edid_internal_quirk {
> +     /* First detailed mode wrong, use largest 60Hz mode */
> +     EDID_QUIRK_PREFER_LARGE_60,
> +     /* Reported 135MHz pixel clock is too high, needs adjustment */
> +     EDID_QUIRK_135_CLOCK_TOO_HIGH,
> +     /* Prefer the largest mode at 75 Hz */
> +     EDID_QUIRK_PREFER_LARGE_75,
> +     /* Detail timing is in cm not mm */
> +     EDID_QUIRK_DETAILED_IN_CM,
> +     /* Detailed timing descriptors have bogus size values, so just take the
> +      * maximum size and use that.
> +      */
> +     EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE,
> +     /* use +hsync +vsync for detailed mode */
> +     EDID_QUIRK_DETAILED_SYNC_PP,
> +     /* Force reduced-blanking timings for detailed modes */
> +     EDID_QUIRK_FORCE_REDUCED_BLANKING,
> +     /* Force 8bpc */
> +     EDID_QUIRK_FORCE_8BPC,
> +     /* Force 12bpc */
> +     EDID_QUIRK_FORCE_12BPC,
> +     /* Force 6bpc */
> +     EDID_QUIRK_FORCE_6BPC,
> +     /* Force 10bpc */
> +     EDID_QUIRK_FORCE_10BPC,
> +     /* Non desktop display (i.e. HMD) */
> +     EDID_QUIRK_NON_DESKTOP,
> +     /* Cap the DSC target bitrate to 15bpp */
> +     EDID_QUIRK_CAP_DSC_15BPP,
> +};
>  
>  #define MICROSOFT_IEEE_OUI   0xca125c
>  
> @@ -128,124 +130,124 @@ static const struct edid_quirk {
>       u32 quirks;
>  } edid_quirk_list[] = {
>       /* Acer AL1706 */
> -     EDID_QUIRK('A', 'C', 'R', 44358, EDID_QUIRK_PREFER_LARGE_60),
> +     EDID_QUIRK('A', 'C', 'R', 44358, BIT(EDID_QUIRK_PREFER_LARGE_60)),
>       /* Acer F51 */
> -     EDID_QUIRK('A', 'P', 'I', 0x7602, EDID_QUIRK_PREFER_LARGE_60),
> +     EDID_QUIRK('A', 'P', 'I', 0x7602, BIT(EDID_QUIRK_PREFER_LARGE_60)),
>  
>       /* AEO model 0 reports 8 bpc, but is a 6 bpc panel */
> -     EDID_QUIRK('A', 'E', 'O', 0, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('A', 'E', 'O', 0, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* BenQ GW2765 */
> -     EDID_QUIRK('B', 'N', 'Q', 0x78d6, EDID_QUIRK_FORCE_8BPC),
> +     EDID_QUIRK('B', 'N', 'Q', 0x78d6, BIT(EDID_QUIRK_FORCE_8BPC)),
>  
>       /* BOE model on HP Pavilion 15-n233sl reports 8 bpc, but is a 6 bpc 
> panel */
> -     EDID_QUIRK('B', 'O', 'E', 0x78b, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('B', 'O', 'E', 0x78b, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* CPT panel of Asus UX303LA reports 8 bpc, but is a 6 bpc panel */
> -     EDID_QUIRK('C', 'P', 'T', 0x17df, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('C', 'P', 'T', 0x17df, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* SDC panel of Lenovo B50-80 reports 8 bpc, but is a 6 bpc panel */
> -     EDID_QUIRK('S', 'D', 'C', 0x3652, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('S', 'D', 'C', 0x3652, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* BOE model 0x0771 reports 8 bpc, but is a 6 bpc panel */
> -     EDID_QUIRK('B', 'O', 'E', 0x0771, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('B', 'O', 'E', 0x0771, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* Belinea 10 15 55 */
> -     EDID_QUIRK('M', 'A', 'X', 1516, EDID_QUIRK_PREFER_LARGE_60),
> -     EDID_QUIRK('M', 'A', 'X', 0x77e, EDID_QUIRK_PREFER_LARGE_60),
> +     EDID_QUIRK('M', 'A', 'X', 1516, BIT(EDID_QUIRK_PREFER_LARGE_60)),
> +     EDID_QUIRK('M', 'A', 'X', 0x77e, BIT(EDID_QUIRK_PREFER_LARGE_60)),
>  
>       /* Envision Peripherals, Inc. EN-7100e */
> -     EDID_QUIRK('E', 'P', 'I', 59264, EDID_QUIRK_135_CLOCK_TOO_HIGH),
> +     EDID_QUIRK('E', 'P', 'I', 59264, BIT(EDID_QUIRK_135_CLOCK_TOO_HIGH)),
>       /* Envision EN2028 */
> -     EDID_QUIRK('E', 'P', 'I', 8232, EDID_QUIRK_PREFER_LARGE_60),
> +     EDID_QUIRK('E', 'P', 'I', 8232, BIT(EDID_QUIRK_PREFER_LARGE_60)),
>  
>       /* Funai Electronics PM36B */
> -     EDID_QUIRK('F', 'C', 'M', 13600, EDID_QUIRK_PREFER_LARGE_75 |
> -                                    EDID_QUIRK_DETAILED_IN_CM),
> +     EDID_QUIRK('F', 'C', 'M', 13600, BIT(EDID_QUIRK_PREFER_LARGE_75) |
> +                                      BIT(EDID_QUIRK_DETAILED_IN_CM)),
>  
>       /* LG 27GP950 */
> -     EDID_QUIRK('G', 'S', 'M', 0x5bbf, EDID_QUIRK_CAP_DSC_15BPP),
> +     EDID_QUIRK('G', 'S', 'M', 0x5bbf, BIT(EDID_QUIRK_CAP_DSC_15BPP)),
>  
>       /* LG 27GN950 */
> -     EDID_QUIRK('G', 'S', 'M', 0x5b9a, EDID_QUIRK_CAP_DSC_15BPP),
> +     EDID_QUIRK('G', 'S', 'M', 0x5b9a, BIT(EDID_QUIRK_CAP_DSC_15BPP)),
>  
>       /* LGD panel of HP zBook 17 G2, eDP 10 bpc, but reports unknown bpc */
> -     EDID_QUIRK('L', 'G', 'D', 764, EDID_QUIRK_FORCE_10BPC),
> +     EDID_QUIRK('L', 'G', 'D', 764, BIT(EDID_QUIRK_FORCE_10BPC)),
>  
>       /* LG Philips LCD LP154W01-A5 */
> -     EDID_QUIRK('L', 'P', 'L', 0, EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE),
> -     EDID_QUIRK('L', 'P', 'L', 0x2a00, EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE),
> +     EDID_QUIRK('L', 'P', 'L', 0, BIT(EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE)),
> +     EDID_QUIRK('L', 'P', 'L', 0x2a00, 
> BIT(EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE)),
>  
>       /* Samsung SyncMaster 205BW.  Note: irony */
> -     EDID_QUIRK('S', 'A', 'M', 541, EDID_QUIRK_DETAILED_SYNC_PP),
> +     EDID_QUIRK('S', 'A', 'M', 541, BIT(EDID_QUIRK_DETAILED_SYNC_PP)),
>       /* Samsung SyncMaster 22[5-6]BW */
> -     EDID_QUIRK('S', 'A', 'M', 596, EDID_QUIRK_PREFER_LARGE_60),
> -     EDID_QUIRK('S', 'A', 'M', 638, EDID_QUIRK_PREFER_LARGE_60),
> +     EDID_QUIRK('S', 'A', 'M', 596, BIT(EDID_QUIRK_PREFER_LARGE_60)),
> +     EDID_QUIRK('S', 'A', 'M', 638, BIT(EDID_QUIRK_PREFER_LARGE_60)),
>  
>       /* Sony PVM-2541A does up to 12 bpc, but only reports max 8 bpc */
> -     EDID_QUIRK('S', 'N', 'Y', 0x2541, EDID_QUIRK_FORCE_12BPC),
> +     EDID_QUIRK('S', 'N', 'Y', 0x2541, BIT(EDID_QUIRK_FORCE_12BPC)),
>  
>       /* ViewSonic VA2026w */
> -     EDID_QUIRK('V', 'S', 'C', 5020, EDID_QUIRK_FORCE_REDUCED_BLANKING),
> +     EDID_QUIRK('V', 'S', 'C', 5020, BIT(EDID_QUIRK_FORCE_REDUCED_BLANKING)),
>  
>       /* Medion MD 30217 PG */
> -     EDID_QUIRK('M', 'E', 'D', 0x7b8, EDID_QUIRK_PREFER_LARGE_75),
> +     EDID_QUIRK('M', 'E', 'D', 0x7b8, BIT(EDID_QUIRK_PREFER_LARGE_75)),
>  
>       /* Lenovo G50 */
> -     EDID_QUIRK('S', 'D', 'C', 18514, EDID_QUIRK_FORCE_6BPC),
> +     EDID_QUIRK('S', 'D', 'C', 18514, BIT(EDID_QUIRK_FORCE_6BPC)),
>  
>       /* Panel in Samsung NP700G7A-S01PL notebook reports 6bpc */
> -     EDID_QUIRK('S', 'E', 'C', 0xd033, EDID_QUIRK_FORCE_8BPC),
> +     EDID_QUIRK('S', 'E', 'C', 0xd033, BIT(EDID_QUIRK_FORCE_8BPC)),
>  
>       /* Rotel RSX-1058 forwards sink's EDID but only does HDMI 1.1*/
> -     EDID_QUIRK('E', 'T', 'R', 13896, EDID_QUIRK_FORCE_8BPC),
> +     EDID_QUIRK('E', 'T', 'R', 13896, BIT(EDID_QUIRK_FORCE_8BPC)),
>  
>       /* Valve Index Headset */
> -     EDID_QUIRK('V', 'L', 'V', 0x91a8, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b0, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b1, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b2, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b3, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b4, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b5, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b6, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b7, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b8, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91b9, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91ba, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91bb, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91bc, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91bd, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91be, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('V', 'L', 'V', 0x91bf, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('V', 'L', 'V', 0x91a8, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b0, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b1, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b2, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b3, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b4, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b5, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b6, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b7, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b8, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91b9, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91ba, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91bb, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91bc, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91bd, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91be, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('V', 'L', 'V', 0x91bf, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* HTC Vive and Vive Pro VR Headsets */
> -     EDID_QUIRK('H', 'V', 'R', 0xaa01, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('H', 'V', 'R', 0xaa02, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('H', 'V', 'R', 0xaa01, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('H', 'V', 'R', 0xaa02, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* Oculus Rift DK1, DK2, CV1 and Rift S VR Headsets */
> -     EDID_QUIRK('O', 'V', 'R', 0x0001, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('O', 'V', 'R', 0x0003, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('O', 'V', 'R', 0x0004, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('O', 'V', 'R', 0x0012, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('O', 'V', 'R', 0x0001, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('O', 'V', 'R', 0x0003, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('O', 'V', 'R', 0x0004, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('O', 'V', 'R', 0x0012, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* Windows Mixed Reality Headsets */
> -     EDID_QUIRK('A', 'C', 'R', 0x7fce, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('L', 'E', 'N', 0x0408, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('F', 'U', 'J', 0x1970, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('D', 'E', 'L', 0x7fce, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('S', 'E', 'C', 0x144a, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('A', 'U', 'S', 0xc102, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('A', 'C', 'R', 0x7fce, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('L', 'E', 'N', 0x0408, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('F', 'U', 'J', 0x1970, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('D', 'E', 'L', 0x7fce, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('S', 'E', 'C', 0x144a, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('A', 'U', 'S', 0xc102, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* Sony PlayStation VR Headset */
> -     EDID_QUIRK('S', 'N', 'Y', 0x0704, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('S', 'N', 'Y', 0x0704, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* Sensics VR Headsets */
> -     EDID_QUIRK('S', 'E', 'N', 0x1019, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('S', 'E', 'N', 0x1019, BIT(EDID_QUIRK_NON_DESKTOP)),
>  
>       /* OSVR HDK and HDK2 VR Headsets */
> -     EDID_QUIRK('S', 'V', 'R', 0x1019, EDID_QUIRK_NON_DESKTOP),
> -     EDID_QUIRK('A', 'U', 'O', 0x1111, EDID_QUIRK_NON_DESKTOP),
> +     EDID_QUIRK('S', 'V', 'R', 0x1019, BIT(EDID_QUIRK_NON_DESKTOP)),
> +     EDID_QUIRK('A', 'U', 'O', 0x1111, BIT(EDID_QUIRK_NON_DESKTOP)),
>  };
>  
>  /*
> @@ -2951,6 +2953,12 @@ static u32 edid_get_quirks(const struct drm_edid 
> *drm_edid)
>       return 0;
>  }
>  
> +static bool drm_edid_has_internal_quirk(struct drm_connector *connector,
> +                                     enum drm_edid_internal_quirk quirk)
> +{
> +     return connector->display_info.quirks & BIT(quirk);
> +}
> +
>  #define MODE_SIZE(m) ((m)->hdisplay * (m)->vdisplay)
>  #define MODE_REFRESH_DIFF(c,t) (abs((c) - (t)))
>  
> @@ -2960,7 +2968,6 @@ static u32 edid_get_quirks(const struct drm_edid 
> *drm_edid)
>   */
>  static void edid_fixup_preferred(struct drm_connector *connector)
>  {
> -     const struct drm_display_info *info = &connector->display_info;
>       struct drm_display_mode *t, *cur_mode, *preferred_mode;
>       int target_refresh = 0;
>       int cur_vrefresh, preferred_vrefresh;
> @@ -2968,9 +2975,9 @@ static void edid_fixup_preferred(struct drm_connector 
> *connector)
>       if (list_empty(&connector->probed_modes))
>               return;
>  
> -     if (info->quirks & EDID_QUIRK_PREFER_LARGE_60)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_PREFER_LARGE_60))
>               target_refresh = 60;
> -     if (info->quirks & EDID_QUIRK_PREFER_LARGE_75)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_PREFER_LARGE_75))
>               target_refresh = 75;
>  
>       preferred_mode = list_first_entry(&connector->probed_modes,
> @@ -3474,7 +3481,6 @@ static struct drm_display_mode 
> *drm_mode_detailed(struct drm_connector *connecto
>                                                 const struct drm_edid 
> *drm_edid,
>                                                 const struct detailed_timing 
> *timing)
>  {
> -     const struct drm_display_info *info = &connector->display_info;
>       struct drm_device *dev = connector->dev;
>       struct drm_display_mode *mode;
>       const struct detailed_pixel_timing *pt = &timing->data.pixel_data;
> @@ -3508,7 +3514,7 @@ static struct drm_display_mode 
> *drm_mode_detailed(struct drm_connector *connecto
>               return NULL;
>       }
>  
> -     if (info->quirks & EDID_QUIRK_FORCE_REDUCED_BLANKING) {
> +     if (drm_edid_has_internal_quirk(connector, 
> EDID_QUIRK_FORCE_REDUCED_BLANKING)) {
>               mode = drm_cvt_mode(dev, hactive, vactive, 60, true, false, 
> false);
>               if (!mode)
>                       return NULL;
> @@ -3520,7 +3526,7 @@ static struct drm_display_mode 
> *drm_mode_detailed(struct drm_connector *connecto
>       if (!mode)
>               return NULL;
>  
> -     if (info->quirks & EDID_QUIRK_135_CLOCK_TOO_HIGH)
> +     if (drm_edid_has_internal_quirk(connector, 
> EDID_QUIRK_135_CLOCK_TOO_HIGH))
>               mode->clock = 1088 * 10;
>       else
>               mode->clock = le16_to_cpu(timing->pixel_clock) * 10;
> @@ -3551,7 +3557,7 @@ static struct drm_display_mode 
> *drm_mode_detailed(struct drm_connector *connecto
>  
>       drm_mode_do_interlace_quirk(mode, pt);
>  
> -     if (info->quirks & EDID_QUIRK_DETAILED_SYNC_PP) {
> +     if (drm_edid_has_internal_quirk(connector, 
> EDID_QUIRK_DETAILED_SYNC_PP)) {
>               mode->flags |= DRM_MODE_FLAG_PHSYNC | DRM_MODE_FLAG_PVSYNC;
>       } else {
>               mode->flags |= (pt->misc & DRM_EDID_PT_HSYNC_POSITIVE) ?
> @@ -3564,12 +3570,12 @@ static struct drm_display_mode 
> *drm_mode_detailed(struct drm_connector *connecto
>       mode->width_mm = pt->width_mm_lo | (pt->width_height_mm_hi & 0xf0) << 4;
>       mode->height_mm = pt->height_mm_lo | (pt->width_height_mm_hi & 0xf) << 
> 8;
>  
> -     if (info->quirks & EDID_QUIRK_DETAILED_IN_CM) {
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_DETAILED_IN_CM)) {
>               mode->width_mm *= 10;
>               mode->height_mm *= 10;
>       }
>  
> -     if (info->quirks & EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE) {
> +     if (drm_edid_has_internal_quirk(connector, 
> EDID_QUIRK_DETAILED_USE_MAXIMUM_SIZE)) {
>               mode->width_mm = drm_edid->edid->width_cm * 10;
>               mode->height_mm = drm_edid->edid->height_cm * 10;
>       }
> @@ -6734,26 +6740,26 @@ static void update_display_info(struct drm_connector 
> *connector,
>       drm_update_mso(connector, drm_edid);
>  
>  out:
> -     if (info->quirks & EDID_QUIRK_NON_DESKTOP) {
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_NON_DESKTOP)) {
>               drm_dbg_kms(connector->dev, "[CONNECTOR:%d:%s] Non-desktop 
> display%s\n",
>                           connector->base.id, connector->name,
>                           info->non_desktop ? " (redundant quirk)" : "");
>               info->non_desktop = true;
>       }
>  
> -     if (info->quirks & EDID_QUIRK_CAP_DSC_15BPP)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_CAP_DSC_15BPP))
>               info->max_dsc_bpp = 15;
>  
> -     if (info->quirks & EDID_QUIRK_FORCE_6BPC)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_FORCE_6BPC))
>               info->bpc = 6;
>  
> -     if (info->quirks & EDID_QUIRK_FORCE_8BPC)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_FORCE_8BPC))
>               info->bpc = 8;
>  
> -     if (info->quirks & EDID_QUIRK_FORCE_10BPC)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_FORCE_10BPC))
>               info->bpc = 10;
>  
> -     if (info->quirks & EDID_QUIRK_FORCE_12BPC)
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_FORCE_12BPC))
>               info->bpc = 12;
>  
>       /* Depends on info->cea_rev set by drm_parse_cea_ext() above */
> @@ -6918,7 +6924,6 @@ static int add_displayid_detailed_modes(struct 
> drm_connector *connector,
>  static int _drm_edid_connector_add_modes(struct drm_connector *connector,
>                                        const struct drm_edid *drm_edid)
>  {
> -     const struct drm_display_info *info = &connector->display_info;
>       int num_modes = 0;
>  
>       if (!drm_edid)
> @@ -6948,7 +6953,8 @@ static int _drm_edid_connector_add_modes(struct 
> drm_connector *connector,
>       if (drm_edid->edid->features & DRM_EDID_FEATURE_CONTINUOUS_FREQ)
>               num_modes += add_inferred_modes(connector, drm_edid);
>  
> -     if (info->quirks & (EDID_QUIRK_PREFER_LARGE_60 | 
> EDID_QUIRK_PREFER_LARGE_75))
> +     if (drm_edid_has_internal_quirk(connector, EDID_QUIRK_PREFER_LARGE_60) 
> ||
> +         drm_edid_has_internal_quirk(connector, EDID_QUIRK_PREFER_LARGE_75))
>               edid_fixup_preferred(connector);
>  
>       return num_modes;

-- 
Jani Nikula, Intel

Reply via email to