Message ID | 20190912113338.30796-4-gwan-gyeong.mun@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | drm/i915/dp: Support for DP HDR outputs | expand |
On Thu, Sep 12, 2019 at 02:33:34PM +0300, Gwan-gyeong Mun wrote: > Because between HDMI and DP have different colorspaces, it renames > drm_mode_create_colorspace_property() function to > drm_mode_create_hdmi_colorspace_property() function for HDMI connector. > And it adds drm_mode_create_dp_colorspace_property() function for creating > of DP colorspace property. > In order to apply changed and added drm api, i915 driver has channged. > > v3: Addressed review comments from Ville > - Add new colorimetry options for DP 1.4a spec. > - Separate set of colorimetry enum values for DP. > v4: Add additional comments to struct drm_prop_enum_list. > Polishing an enum string of struct drm_prop_enum_list > v5: Change definitions of DRM_MODE_COLORIMETRYs to follow HDMI prefix and > DP abbreviations. > Add missed variables on dp_colorspaces. > Fix typo. [Uma] > v6: Addressed review comments from Ilia and Ville > - Split drm_mode_create_colorspace_property() to DP and HDMI connector. > v7: Fix typo [Jani Saarinen] > Fix white space. > > Signed-off-by: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com> > Reviewed-by: Uma Shankar <uma.shankar@intel.com> > --- > drivers/gpu/drm/drm_connector.c | 110 +++++++++++++++--- > .../gpu/drm/i915/display/intel_connector.c | 21 +++- > include/drm/drm_connector.h | 11 +- > 3 files changed, 121 insertions(+), 21 deletions(-) > > diff --git a/drivers/gpu/drm/drm_connector.c b/drivers/gpu/drm/drm_connector.c > index 4c766624b20d..656f72c1b3d7 100644 > --- a/drivers/gpu/drm/drm_connector.c > +++ b/drivers/gpu/drm/drm_connector.c > @@ -882,6 +882,47 @@ static const struct drm_prop_enum_list hdmi_colorspaces[] = { > { DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER, "DCI-P3_RGB_Theater" }, > }; > > +/* > + * As per DP 1.4a spec, 2.2.5.7.5 VSC SDP Payload for Pixel Encoding/Colorimetry > + * Format Table 2-120 > + */ > +static const struct drm_prop_enum_list dp_colorspaces[] = { > + /* For Default case, driver will set the colorspace */ > + { DRM_MODE_COLORIMETRY_DEFAULT, "Default" }, > + /* Colorimetry based on sRGB (IEC 61966-2-1) */ > + { DRM_MODE_COLORIMETRY_CEA_RGB, "CEA_RGB" }, We already have other mechanism for the CEA vs. IT RGB. I don't think we want to add another one. So I'd drop this. > + { DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED, "RGB_Wide_Gamut_Fixed_Point" }, > + /* Colorimetry based on scRGB (IEC 61966-2-2) */ > + { DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT, "RGB_Wide_Gamut_Floating_Point" }, > + /* Colorimetry based on IEC 61966-2-5 */ > + { DRM_MODE_COLORIMETRY_OPRGB, "opRGB" }, > + /* Colorimetry based on SMPTE RP 431-2 */ > + { DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65, "DCI-P3_RGB_D65" }, > + { DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE, "RGB_Custom_Color_Profile" }, I'd also drop this since we have no way to supply the profile anyway. > + /* Colorimetry based on ITU-R BT.2020 */ > + { DRM_MODE_COLORIMETRY_BT2020_RGB, "BT2020_RGB" }, > + { DRM_MODE_COLORIMETRY_BT601_YCC, "BT601_YCC" }, > + { DRM_MODE_COLORIMETRY_BT709_YCC, "BT709_YCC" }, > + /* Standard Definition Colorimetry based on IEC 61966-2-4 */ > + { DRM_MODE_COLORIMETRY_XVYCC_601, "XVYCC_601" }, > + /* High Definition Colorimetry based on IEC 61966-2-4 */ > + { DRM_MODE_COLORIMETRY_XVYCC_709, "XVYCC_709" }, > + /* Colorimetry based on IEC 61966-2-1/Amendment 1 */ > + { DRM_MODE_COLORIMETRY_SYCC_601, "SYCC_601" }, > + /* Colorimetry based on IEC 61966-2-5 [33] */ > + { DRM_MODE_COLORIMETRY_OPYCC_601, "opYCC_601" }, > + /* Colorimetry based on ITU-R BT.2020 */ > + { DRM_MODE_COLORIMETRY_BT2020_CYCC, "BT2020_CYCC" }, > + /* Colorimetry based on ITU-R BT.2020 */ > + { DRM_MODE_COLORIMETRY_BT2020_YCC, "BT2020_YCC" }, > + /* > + * Colorimetry based on Digital Imaging and Communications in Medicine > + * (DICOM) Part 14: Grayscale Standard Display Function > + */ > + { DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE, "Y_ONLY_DICOM_Part_14_Grayscale" }, > + { DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE, "Raw_Custom_Color_Profile" }, And these last two seem rather esoteric as well. I don't think any driver supports RAW/Y stuff so I'd drop them too. > +}; > + > /** > * DOC: standard connector properties > * > @@ -1674,7 +1715,6 @@ EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); > * DOC: standard connector properties > * > * Colorspace: > - * drm_mode_create_colorspace_property - create colorspace property > * This property helps select a suitable colorspace based on the sink > * capability. Modern sink devices support wider gamut like BT2020. > * This helps switch to BT2020 mode if the BT2020 encoded video stream > @@ -1694,32 +1734,68 @@ EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); > * - This property is just to inform sink what colorspace > * source is trying to drive. > * > + * Because between HDMI and DP have different colorspaces, > + * drm_mode_create_hdmi_colorspace_property() is used for HDMI connector and > + * drm_mode_create_dp_colorspace_property() is used for DP connector. > + */ > + > +/** > + * drm_mode_create_hdmi_colorspace_property - create hdmi colorspace property > + * @connector: connector to create the Colorspace property on. > + * > * Called by a driver the first time it's needed, must be attached to desired > - * connectors. > + * HDMI connectors. > + * > + * Returns: > + * Zero on success, negative errono on failure. > */ > -int drm_mode_create_colorspace_property(struct drm_connector *connector) > +int drm_mode_create_hdmi_colorspace_property(struct drm_connector *connector) > { > struct drm_device *dev = connector->dev; > - struct drm_property *prop; > > - if (connector->connector_type == DRM_MODE_CONNECTOR_HDMIA || > - connector->connector_type == DRM_MODE_CONNECTOR_HDMIB) { > - prop = drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, > - "Colorspace", > - hdmi_colorspaces, > - ARRAY_SIZE(hdmi_colorspaces)); > - if (!prop) > - return -ENOMEM; > - } else { > - DRM_DEBUG_KMS("Colorspace property not supported\n"); > + if (connector->colorspace_property) > return 0; > - } > > - connector->colorspace_property = prop; > + connector->colorspace_property = > + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, "Colorspace", > + hdmi_colorspaces, > + ARRAY_SIZE(hdmi_colorspaces)); > + > + if (!connector->colorspace_property) > + return -ENOMEM; > + > + return 0; > +} > +EXPORT_SYMBOL(drm_mode_create_hdmi_colorspace_property); > + > +/** > + * drm_mode_create_dp_colorspace_property - create dp colorspace property > + * @connector: connector to create the Colorspace property on. > + * > + * Called by a driver the first time it's needed, must be attached to desired > + * DP connectors. > + * > + * Returns: > + * Zero on success, negative errono on failure. > + */ > +int drm_mode_create_dp_colorspace_property(struct drm_connector *connector) > +{ > + struct drm_device *dev = connector->dev; > + > + if (connector->colorspace_property) > + return 0; > + > + connector->colorspace_property = > + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, "Colorspace", > + dp_colorspaces, > + ARRAY_SIZE(dp_colorspaces)); > + > + if (!connector->colorspace_property) > + return -ENOMEM; > > return 0; > } > -EXPORT_SYMBOL(drm_mode_create_colorspace_property); > +EXPORT_SYMBOL(drm_mode_create_dp_colorspace_property); > > /** > * drm_mode_create_content_type_property - create content type property > diff --git a/drivers/gpu/drm/i915/display/intel_connector.c b/drivers/gpu/drm/i915/display/intel_connector.c > index 308ec63207ee..1133c4e97bb4 100644 > --- a/drivers/gpu/drm/i915/display/intel_connector.c > +++ b/drivers/gpu/drm/i915/display/intel_connector.c > @@ -277,7 +277,22 @@ intel_attach_aspect_ratio_property(struct drm_connector *connector) > void > intel_attach_colorspace_property(struct drm_connector *connector) > { > - if (!drm_mode_create_colorspace_property(connector)) > - drm_object_attach_property(&connector->base, > - connector->colorspace_property, 0); > + switch (connector->connector_type) { > + case DRM_MODE_CONNECTOR_HDMIA: > + case DRM_MODE_CONNECTOR_HDMIB: > + if (drm_mode_create_hdmi_colorspace_property(connector)) > + return; > + break; > + case DRM_MODE_CONNECTOR_DisplayPort: > + case DRM_MODE_CONNECTOR_eDP: > + if (drm_mode_create_dp_colorspace_property(connector)) > + return; > + break; > + default: > + DRM_DEBUG_KMS("Colorspace property not supported\n"); > + return; > + } > + > + drm_object_attach_property(&connector->base, > + connector->colorspace_property, 0); > } > diff --git a/include/drm/drm_connector.h b/include/drm/drm_connector.h > index 681cb590f952..48efe92effd7 100644 > --- a/include/drm/drm_connector.h > +++ b/include/drm/drm_connector.h > @@ -281,6 +281,14 @@ enum drm_panel_orientation { > /* Additional Colorimetry extension added as part of CTA 861.G */ > #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65 11 > #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER 12 > +/* Additional Colorimetry Options added for DP 1.4a VSC Colorimetry Format */ > +#define DRM_MODE_COLORIMETRY_CEA_RGB 13 > +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED 14 > +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT 15 > +#define DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE 16 > +#define DRM_MODE_COLORIMETRY_BT601_YCC 17 > +#define DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE 18 > +#define DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE 19 > > /** > * enum drm_bus_flags - bus_flags info for &drm_display_info > @@ -1523,7 +1531,8 @@ int drm_connector_attach_scaling_mode_property(struct drm_connector *connector, > int drm_connector_attach_vrr_capable_property( > struct drm_connector *connector); > int drm_mode_create_aspect_ratio_property(struct drm_device *dev); > -int drm_mode_create_colorspace_property(struct drm_connector *connector); > +int drm_mode_create_hdmi_colorspace_property(struct drm_connector *connector); > +int drm_mode_create_dp_colorspace_property(struct drm_connector *connector); > int drm_mode_create_content_type_property(struct drm_device *dev); > void drm_hdmi_avi_infoframe_content_type(struct hdmi_avi_infoframe *frame, > const struct drm_connector_state *conn_state); > -- > 2.23.0
On Fri, 2019-09-13 at 22:13 +0300, Ville Syrjälä wrote: > On Thu, Sep 12, 2019 at 02:33:34PM +0300, Gwan-gyeong Mun wrote: > > Because between HDMI and DP have different colorspaces, it renames > > drm_mode_create_colorspace_property() function to > > drm_mode_create_hdmi_colorspace_property() function for HDMI > > connector. > > And it adds drm_mode_create_dp_colorspace_property() function for > > creating > > of DP colorspace property. > > In order to apply changed and added drm api, i915 driver has > > channged. > > > > v3: Addressed review comments from Ville > > - Add new colorimetry options for DP 1.4a spec. > > - Separate set of colorimetry enum values for DP. > > v4: Add additional comments to struct drm_prop_enum_list. > > Polishing an enum string of struct drm_prop_enum_list > > v5: Change definitions of DRM_MODE_COLORIMETRYs to follow HDMI > > prefix and > > DP abbreviations. > > Add missed variables on dp_colorspaces. > > Fix typo. [Uma] > > v6: Addressed review comments from Ilia and Ville > > - Split drm_mode_create_colorspace_property() to DP and HDMI > > connector. > > v7: Fix typo [Jani Saarinen] > > Fix white space. > > > > Signed-off-by: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com> > > Reviewed-by: Uma Shankar <uma.shankar@intel.com> > > --- > > drivers/gpu/drm/drm_connector.c | 110 > > +++++++++++++++--- > > .../gpu/drm/i915/display/intel_connector.c | 21 +++- > > include/drm/drm_connector.h | 11 +- > > 3 files changed, 121 insertions(+), 21 deletions(-) > > > > diff --git a/drivers/gpu/drm/drm_connector.c > > b/drivers/gpu/drm/drm_connector.c > > index 4c766624b20d..656f72c1b3d7 100644 > > --- a/drivers/gpu/drm/drm_connector.c > > +++ b/drivers/gpu/drm/drm_connector.c > > @@ -882,6 +882,47 @@ static const struct drm_prop_enum_list > > hdmi_colorspaces[] = { > > { DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER, "DCI-P3_RGB_Theater" > > }, > > }; > > > > +/* > > + * As per DP 1.4a spec, 2.2.5.7.5 VSC SDP Payload for Pixel > > Encoding/Colorimetry > > + * Format Table 2-120 > > + */ > > +static const struct drm_prop_enum_list dp_colorspaces[] = { > > + /* For Default case, driver will set the colorspace */ > > + { DRM_MODE_COLORIMETRY_DEFAULT, "Default" }, > > + /* Colorimetry based on sRGB (IEC 61966-2-1) */ > > + { DRM_MODE_COLORIMETRY_CEA_RGB, "CEA_RGB" }, > > We already have other mechanism for the CEA vs. IT RGB. > I don't think we want to add another one. So I'd drop this. > > > + { DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED, > > "RGB_Wide_Gamut_Fixed_Point" }, > > + /* Colorimetry based on scRGB (IEC 61966-2-2) */ > > + { DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT, > > "RGB_Wide_Gamut_Floating_Point" }, > > + /* Colorimetry based on IEC 61966-2-5 */ > > + { DRM_MODE_COLORIMETRY_OPRGB, "opRGB" }, > > + /* Colorimetry based on SMPTE RP 431-2 */ > > + { DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65, "DCI-P3_RGB_D65" }, > > + { DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE, > > "RGB_Custom_Color_Profile" }, > > I'd also drop this since we have no way to supply the profile anyway. > > > + /* Colorimetry based on ITU-R BT.2020 */ > > + { DRM_MODE_COLORIMETRY_BT2020_RGB, "BT2020_RGB" }, > > + { DRM_MODE_COLORIMETRY_BT601_YCC, "BT601_YCC" }, > > + { DRM_MODE_COLORIMETRY_BT709_YCC, "BT709_YCC" }, > > + /* Standard Definition Colorimetry based on IEC 61966-2-4 */ > > + { DRM_MODE_COLORIMETRY_XVYCC_601, "XVYCC_601" }, > > + /* High Definition Colorimetry based on IEC 61966-2-4 */ > > + { DRM_MODE_COLORIMETRY_XVYCC_709, "XVYCC_709" }, > > + /* Colorimetry based on IEC 61966-2-1/Amendment 1 */ > > + { DRM_MODE_COLORIMETRY_SYCC_601, "SYCC_601" }, > > + /* Colorimetry based on IEC 61966-2-5 [33] */ > > + { DRM_MODE_COLORIMETRY_OPYCC_601, "opYCC_601" }, > > + /* Colorimetry based on ITU-R BT.2020 */ > > + { DRM_MODE_COLORIMETRY_BT2020_CYCC, "BT2020_CYCC" }, > > + /* Colorimetry based on ITU-R BT.2020 */ > > + { DRM_MODE_COLORIMETRY_BT2020_YCC, "BT2020_YCC" }, > > + /* > > + * Colorimetry based on Digital Imaging and Communications in > > Medicine > > + * (DICOM) Part 14: Grayscale Standard Display Function > > + */ > > + { DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE, > > "Y_ONLY_DICOM_Part_14_Grayscale" }, > > + { DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE, > > "Raw_Custom_Color_Profile" }, > > And these last two seem rather esoteric as well. I don't think any > driver supports RAW/Y stuff so I'd drop them too. > Ville, thank you for reviewing and check in detail. I'll drop them which you commented. > > +}; > > + > > /** > > * DOC: standard connector properties > > * > > @@ -1674,7 +1715,6 @@ > > EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); > > * DOC: standard connector properties > > * > > * Colorspace: > > - * drm_mode_create_colorspace_property - create colorspace > > property > > * This property helps select a suitable colorspace based on > > the sink > > * capability. Modern sink devices support wider gamut like > > BT2020. > > * This helps switch to BT2020 mode if the BT2020 encoded > > video stream > > @@ -1694,32 +1734,68 @@ > > EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); > > * - This property is just to inform sink what colorspace > > * source is trying to drive. > > * > > + * Because between HDMI and DP have different colorspaces, > > + * drm_mode_create_hdmi_colorspace_property() is used for HDMI > > connector and > > + * drm_mode_create_dp_colorspace_property() is used for DP > > connector. > > + */ > > + > > +/** > > + * drm_mode_create_hdmi_colorspace_property - create hdmi > > colorspace property > > + * @connector: connector to create the Colorspace property on. > > + * > > * Called by a driver the first time it's needed, must be attached > > to desired > > - * connectors. > > + * HDMI connectors. > > + * > > + * Returns: > > + * Zero on success, negative errono on failure. > > */ > > -int drm_mode_create_colorspace_property(struct drm_connector > > *connector) > > +int drm_mode_create_hdmi_colorspace_property(struct drm_connector > > *connector) > > { > > struct drm_device *dev = connector->dev; > > - struct drm_property *prop; > > > > - if (connector->connector_type == DRM_MODE_CONNECTOR_HDMIA || > > - connector->connector_type == DRM_MODE_CONNECTOR_HDMIB) { > > - prop = drm_property_create_enum(dev, > > DRM_MODE_PROP_ENUM, > > - "Colorspace", > > - hdmi_colorspaces, > > - ARRAY_SIZE(hdmi_colorsp > > aces)); > > - if (!prop) > > - return -ENOMEM; > > - } else { > > - DRM_DEBUG_KMS("Colorspace property not supported\n"); > > + if (connector->colorspace_property) > > return 0; > > - } > > > > - connector->colorspace_property = prop; > > + connector->colorspace_property = > > + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, > > "Colorspace", > > + hdmi_colorspaces, > > + ARRAY_SIZE(hdmi_colorspaces)); > > + > > + if (!connector->colorspace_property) > > + return -ENOMEM; > > + > > + return 0; > > +} > > +EXPORT_SYMBOL(drm_mode_create_hdmi_colorspace_property); > > + > > +/** > > + * drm_mode_create_dp_colorspace_property - create dp colorspace > > property > > + * @connector: connector to create the Colorspace property on. > > + * > > + * Called by a driver the first time it's needed, must be attached > > to desired > > + * DP connectors. > > + * > > + * Returns: > > + * Zero on success, negative errono on failure. > > + */ > > +int drm_mode_create_dp_colorspace_property(struct drm_connector > > *connector) > > +{ > > + struct drm_device *dev = connector->dev; > > + > > + if (connector->colorspace_property) > > + return 0; > > + > > + connector->colorspace_property = > > + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, > > "Colorspace", > > + dp_colorspaces, > > + ARRAY_SIZE(dp_colorspaces)); > > + > > + if (!connector->colorspace_property) > > + return -ENOMEM; > > > > return 0; > > } > > -EXPORT_SYMBOL(drm_mode_create_colorspace_property); > > +EXPORT_SYMBOL(drm_mode_create_dp_colorspace_property); > > > > /** > > * drm_mode_create_content_type_property - create content type > > property > > diff --git a/drivers/gpu/drm/i915/display/intel_connector.c > > b/drivers/gpu/drm/i915/display/intel_connector.c > > index 308ec63207ee..1133c4e97bb4 100644 > > --- a/drivers/gpu/drm/i915/display/intel_connector.c > > +++ b/drivers/gpu/drm/i915/display/intel_connector.c > > @@ -277,7 +277,22 @@ intel_attach_aspect_ratio_property(struct > > drm_connector *connector) > > void > > intel_attach_colorspace_property(struct drm_connector *connector) > > { > > - if (!drm_mode_create_colorspace_property(connector)) > > - drm_object_attach_property(&connector->base, > > - connector- > > >colorspace_property, 0); > > + switch (connector->connector_type) { > > + case DRM_MODE_CONNECTOR_HDMIA: > > + case DRM_MODE_CONNECTOR_HDMIB: > > + if > > (drm_mode_create_hdmi_colorspace_property(connector)) > > + return; > > + break; > > + case DRM_MODE_CONNECTOR_DisplayPort: > > + case DRM_MODE_CONNECTOR_eDP: > > + if (drm_mode_create_dp_colorspace_property(connector)) > > + return; > > + break; > > + default: > > + DRM_DEBUG_KMS("Colorspace property not supported\n"); > > + return; > > + } > > + > > + drm_object_attach_property(&connector->base, > > + connector->colorspace_property, 0); > > } > > diff --git a/include/drm/drm_connector.h > > b/include/drm/drm_connector.h > > index 681cb590f952..48efe92effd7 100644 > > --- a/include/drm/drm_connector.h > > +++ b/include/drm/drm_connector.h > > @@ -281,6 +281,14 @@ enum drm_panel_orientation { > > /* Additional Colorimetry extension added as part of CTA 861.G */ > > #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65 11 > > #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER 12 > > +/* Additional Colorimetry Options added for DP 1.4a VSC > > Colorimetry Format */ > > +#define DRM_MODE_COLORIMETRY_CEA_RGB 13 > > +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED 14 > > +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT 15 > > +#define DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE 16 > > +#define DRM_MODE_COLORIMETRY_BT601_YCC 17 > > +#define DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE 18 > > +#define DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE 19 > > > > /** > > * enum drm_bus_flags - bus_flags info for &drm_display_info > > @@ -1523,7 +1531,8 @@ int > > drm_connector_attach_scaling_mode_property(struct drm_connector > > *connector, > > int drm_connector_attach_vrr_capable_property( > > struct drm_connector *connector); > > int drm_mode_create_aspect_ratio_property(struct drm_device *dev); > > -int drm_mode_create_colorspace_property(struct drm_connector > > *connector); > > +int drm_mode_create_hdmi_colorspace_property(struct drm_connector > > *connector); > > +int drm_mode_create_dp_colorspace_property(struct drm_connector > > *connector); > > int drm_mode_create_content_type_property(struct drm_device *dev); > > void drm_hdmi_avi_infoframe_content_type(struct hdmi_avi_infoframe > > *frame, > > const struct > > drm_connector_state *conn_state); > > -- > > 2.23.0
diff --git a/drivers/gpu/drm/drm_connector.c b/drivers/gpu/drm/drm_connector.c index 4c766624b20d..656f72c1b3d7 100644 --- a/drivers/gpu/drm/drm_connector.c +++ b/drivers/gpu/drm/drm_connector.c @@ -882,6 +882,47 @@ static const struct drm_prop_enum_list hdmi_colorspaces[] = { { DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER, "DCI-P3_RGB_Theater" }, }; +/* + * As per DP 1.4a spec, 2.2.5.7.5 VSC SDP Payload for Pixel Encoding/Colorimetry + * Format Table 2-120 + */ +static const struct drm_prop_enum_list dp_colorspaces[] = { + /* For Default case, driver will set the colorspace */ + { DRM_MODE_COLORIMETRY_DEFAULT, "Default" }, + /* Colorimetry based on sRGB (IEC 61966-2-1) */ + { DRM_MODE_COLORIMETRY_CEA_RGB, "CEA_RGB" }, + { DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED, "RGB_Wide_Gamut_Fixed_Point" }, + /* Colorimetry based on scRGB (IEC 61966-2-2) */ + { DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT, "RGB_Wide_Gamut_Floating_Point" }, + /* Colorimetry based on IEC 61966-2-5 */ + { DRM_MODE_COLORIMETRY_OPRGB, "opRGB" }, + /* Colorimetry based on SMPTE RP 431-2 */ + { DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65, "DCI-P3_RGB_D65" }, + { DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE, "RGB_Custom_Color_Profile" }, + /* Colorimetry based on ITU-R BT.2020 */ + { DRM_MODE_COLORIMETRY_BT2020_RGB, "BT2020_RGB" }, + { DRM_MODE_COLORIMETRY_BT601_YCC, "BT601_YCC" }, + { DRM_MODE_COLORIMETRY_BT709_YCC, "BT709_YCC" }, + /* Standard Definition Colorimetry based on IEC 61966-2-4 */ + { DRM_MODE_COLORIMETRY_XVYCC_601, "XVYCC_601" }, + /* High Definition Colorimetry based on IEC 61966-2-4 */ + { DRM_MODE_COLORIMETRY_XVYCC_709, "XVYCC_709" }, + /* Colorimetry based on IEC 61966-2-1/Amendment 1 */ + { DRM_MODE_COLORIMETRY_SYCC_601, "SYCC_601" }, + /* Colorimetry based on IEC 61966-2-5 [33] */ + { DRM_MODE_COLORIMETRY_OPYCC_601, "opYCC_601" }, + /* Colorimetry based on ITU-R BT.2020 */ + { DRM_MODE_COLORIMETRY_BT2020_CYCC, "BT2020_CYCC" }, + /* Colorimetry based on ITU-R BT.2020 */ + { DRM_MODE_COLORIMETRY_BT2020_YCC, "BT2020_YCC" }, + /* + * Colorimetry based on Digital Imaging and Communications in Medicine + * (DICOM) Part 14: Grayscale Standard Display Function + */ + { DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE, "Y_ONLY_DICOM_Part_14_Grayscale" }, + { DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE, "Raw_Custom_Color_Profile" }, +}; + /** * DOC: standard connector properties * @@ -1674,7 +1715,6 @@ EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); * DOC: standard connector properties * * Colorspace: - * drm_mode_create_colorspace_property - create colorspace property * This property helps select a suitable colorspace based on the sink * capability. Modern sink devices support wider gamut like BT2020. * This helps switch to BT2020 mode if the BT2020 encoded video stream @@ -1694,32 +1734,68 @@ EXPORT_SYMBOL(drm_mode_create_aspect_ratio_property); * - This property is just to inform sink what colorspace * source is trying to drive. * + * Because between HDMI and DP have different colorspaces, + * drm_mode_create_hdmi_colorspace_property() is used for HDMI connector and + * drm_mode_create_dp_colorspace_property() is used for DP connector. + */ + +/** + * drm_mode_create_hdmi_colorspace_property - create hdmi colorspace property + * @connector: connector to create the Colorspace property on. + * * Called by a driver the first time it's needed, must be attached to desired - * connectors. + * HDMI connectors. + * + * Returns: + * Zero on success, negative errono on failure. */ -int drm_mode_create_colorspace_property(struct drm_connector *connector) +int drm_mode_create_hdmi_colorspace_property(struct drm_connector *connector) { struct drm_device *dev = connector->dev; - struct drm_property *prop; - if (connector->connector_type == DRM_MODE_CONNECTOR_HDMIA || - connector->connector_type == DRM_MODE_CONNECTOR_HDMIB) { - prop = drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, - "Colorspace", - hdmi_colorspaces, - ARRAY_SIZE(hdmi_colorspaces)); - if (!prop) - return -ENOMEM; - } else { - DRM_DEBUG_KMS("Colorspace property not supported\n"); + if (connector->colorspace_property) return 0; - } - connector->colorspace_property = prop; + connector->colorspace_property = + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, "Colorspace", + hdmi_colorspaces, + ARRAY_SIZE(hdmi_colorspaces)); + + if (!connector->colorspace_property) + return -ENOMEM; + + return 0; +} +EXPORT_SYMBOL(drm_mode_create_hdmi_colorspace_property); + +/** + * drm_mode_create_dp_colorspace_property - create dp colorspace property + * @connector: connector to create the Colorspace property on. + * + * Called by a driver the first time it's needed, must be attached to desired + * DP connectors. + * + * Returns: + * Zero on success, negative errono on failure. + */ +int drm_mode_create_dp_colorspace_property(struct drm_connector *connector) +{ + struct drm_device *dev = connector->dev; + + if (connector->colorspace_property) + return 0; + + connector->colorspace_property = + drm_property_create_enum(dev, DRM_MODE_PROP_ENUM, "Colorspace", + dp_colorspaces, + ARRAY_SIZE(dp_colorspaces)); + + if (!connector->colorspace_property) + return -ENOMEM; return 0; } -EXPORT_SYMBOL(drm_mode_create_colorspace_property); +EXPORT_SYMBOL(drm_mode_create_dp_colorspace_property); /** * drm_mode_create_content_type_property - create content type property diff --git a/drivers/gpu/drm/i915/display/intel_connector.c b/drivers/gpu/drm/i915/display/intel_connector.c index 308ec63207ee..1133c4e97bb4 100644 --- a/drivers/gpu/drm/i915/display/intel_connector.c +++ b/drivers/gpu/drm/i915/display/intel_connector.c @@ -277,7 +277,22 @@ intel_attach_aspect_ratio_property(struct drm_connector *connector) void intel_attach_colorspace_property(struct drm_connector *connector) { - if (!drm_mode_create_colorspace_property(connector)) - drm_object_attach_property(&connector->base, - connector->colorspace_property, 0); + switch (connector->connector_type) { + case DRM_MODE_CONNECTOR_HDMIA: + case DRM_MODE_CONNECTOR_HDMIB: + if (drm_mode_create_hdmi_colorspace_property(connector)) + return; + break; + case DRM_MODE_CONNECTOR_DisplayPort: + case DRM_MODE_CONNECTOR_eDP: + if (drm_mode_create_dp_colorspace_property(connector)) + return; + break; + default: + DRM_DEBUG_KMS("Colorspace property not supported\n"); + return; + } + + drm_object_attach_property(&connector->base, + connector->colorspace_property, 0); } diff --git a/include/drm/drm_connector.h b/include/drm/drm_connector.h index 681cb590f952..48efe92effd7 100644 --- a/include/drm/drm_connector.h +++ b/include/drm/drm_connector.h @@ -281,6 +281,14 @@ enum drm_panel_orientation { /* Additional Colorimetry extension added as part of CTA 861.G */ #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_D65 11 #define DRM_MODE_COLORIMETRY_DCI_P3_RGB_THEATER 12 +/* Additional Colorimetry Options added for DP 1.4a VSC Colorimetry Format */ +#define DRM_MODE_COLORIMETRY_CEA_RGB 13 +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FIXED 14 +#define DRM_MODE_COLORIMETRY_RGB_WIDE_FLOAT 15 +#define DRM_MODE_COLORIMETRY_RGB_CUSTOM_COLOR_PROFILE 16 +#define DRM_MODE_COLORIMETRY_BT601_YCC 17 +#define DRM_MODE_COLORIMETRY_Y_ONLY_DICOM_P14_GRAYSCALE 18 +#define DRM_MODE_COLORIMETRY_RAW_CUSTOM_COLOR_PROFILE 19 /** * enum drm_bus_flags - bus_flags info for &drm_display_info @@ -1523,7 +1531,8 @@ int drm_connector_attach_scaling_mode_property(struct drm_connector *connector, int drm_connector_attach_vrr_capable_property( struct drm_connector *connector); int drm_mode_create_aspect_ratio_property(struct drm_device *dev); -int drm_mode_create_colorspace_property(struct drm_connector *connector); +int drm_mode_create_hdmi_colorspace_property(struct drm_connector *connector); +int drm_mode_create_dp_colorspace_property(struct drm_connector *connector); int drm_mode_create_content_type_property(struct drm_device *dev); void drm_hdmi_avi_infoframe_content_type(struct hdmi_avi_infoframe *frame, const struct drm_connector_state *conn_state);