On Wed, 27 Mar 2013 00:44:56 +0100 Daniel Vetter <daniel.vetter at ffwll.ch> wrote: > Now that we have a useful struct for this, let's use it. Some neat > pointer-chasing required, but it's all there already. > > v2: Rebased on top of the added Haswell limited color range support. > > Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch> > --- > drivers/gpu/drm/i915/intel_display.c | 13 ++++++------- > drivers/gpu/drm/i915/intel_dp.c | 2 +- > drivers/gpu/drm/i915/intel_drv.h | 12 +++++++----- > drivers/gpu/drm/i915/intel_hdmi.c | 5 +++-- > drivers/gpu/drm/i915/intel_sdvo.c | 5 +++-- > 5 files changed, 20 insertions(+), 17 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c > index fda0754..bfed546 100644 > --- a/drivers/gpu/drm/i915/intel_display.c > +++ b/drivers/gpu/drm/i915/intel_display.c > @@ -5173,7 +5173,7 @@ static void ironlake_set_pipeconf(struct drm_crtc *crtc, > else > val |= PIPECONF_PROGRESSIVE; > > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > val |= PIPECONF_COLOR_RANGE_SELECT; > else > val &= ~PIPECONF_COLOR_RANGE_SELECT; > @@ -5189,8 +5189,7 @@ static void ironlake_set_pipeconf(struct drm_crtc *crtc, > * is supported, but eventually this should handle various > * RGB<->YCbCr scenarios as well. > */ > -static void intel_set_pipe_csc(struct drm_crtc *crtc, > - const struct drm_display_mode *adjusted_mode) > +static void intel_set_pipe_csc(struct drm_crtc *crtc) > { > struct drm_device *dev = crtc->dev; > struct drm_i915_private *dev_priv = dev->dev_private; > @@ -5205,7 +5204,7 @@ static void intel_set_pipe_csc(struct drm_crtc *crtc, > * consideration. > */ > > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > coeff = ((235 - 16) * (1 << 12) / 255) & 0xff8; /* 0.xxx... */ > > /* > @@ -5229,7 +5228,7 @@ static void intel_set_pipe_csc(struct drm_crtc *crtc, > if (INTEL_INFO(dev)->gen > 6) { > uint16_t postoff = 0; > > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > postoff = (16 * (1 << 13) / 255) & 0x1fff; > > I915_WRITE(PIPE_CSC_POSTOFF_HI(pipe), postoff); > @@ -5240,7 +5239,7 @@ static void intel_set_pipe_csc(struct drm_crtc *crtc, > } else { > uint32_t mode = CSC_MODE_YUV_TO_RGB; > > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > mode |= CSC_BLACK_SCREEN_OFFSET; > > I915_WRITE(PIPE_CSC_MODE(pipe), mode); > @@ -5841,7 +5840,7 @@ static int haswell_crtc_mode_set(struct drm_crtc *crtc, > > haswell_set_pipeconf(crtc, adjusted_mode, dither); > > - intel_set_pipe_csc(crtc, adjusted_mode); > + intel_set_pipe_csc(crtc); > > /* Set up the display plane register */ > I915_WRITE(DSPCNTR(plane), DISPPLANE_GAMMA_ENABLE | DISPPLANE_PIPE_CSC_ENABLE); > diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c > index bc73e5e..d7c1403 100644 > --- a/drivers/gpu/drm/i915/intel_dp.c > +++ b/drivers/gpu/drm/i915/intel_dp.c > @@ -739,7 +739,7 @@ intel_dp_compute_config(struct intel_encoder *encoder, > } > > if (intel_dp->color_range) > - adjusted_mode->private_flags |= INTEL_MODE_LIMITED_COLOR_RANGE; > + pipe_config->limited_color_range = true; > > mode_rate = intel_dp_link_required(adjusted_mode->clock, bpp); > > diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h > index 8de1855..63160c6 100644 > --- a/drivers/gpu/drm/i915/intel_drv.h > +++ b/drivers/gpu/drm/i915/intel_drv.h > @@ -103,11 +103,6 @@ > > /* drm_display_mode->private_flags */ > #define INTEL_MODE_DP_FORCE_6BPC (0x10) > -/* > - * Set when limited 16-235 (as opposed to full 0-255) RGB color range is > - * to be used. > - */ > -#define INTEL_MODE_LIMITED_COLOR_RANGE (0x40) > > struct intel_framebuffer { > struct drm_framebuffer base; > @@ -193,6 +188,13 @@ struct intel_crtc_config { > /* Whether to set up the PCH/FDI. Note that we never allow sharing > * between pch encoders and cpu encoders. */ > bool has_pch_encoder; > + > + /* > + * Use reduced/limited/broadcast rbg range, compressing from the full > + * range fed into the crtcs. > + */ > + bool limited_color_range; > + > /* Used by SDVO (and if we ever fix it, HDMI). */ > unsigned pixel_multiplier; > }; > diff --git a/drivers/gpu/drm/i915/intel_hdmi.c b/drivers/gpu/drm/i915/intel_hdmi.c > index b588e6c..5508687 100644 > --- a/drivers/gpu/drm/i915/intel_hdmi.c > +++ b/drivers/gpu/drm/i915/intel_hdmi.c > @@ -333,6 +333,7 @@ static void intel_hdmi_set_avi_infoframe(struct drm_encoder *encoder, > struct drm_display_mode *adjusted_mode) > { > struct intel_hdmi *intel_hdmi = enc_to_intel_hdmi(encoder); > + struct intel_crtc *intel_crtc = to_intel_crtc(encoder->crtc); > struct dip_infoframe avi_if = { > .type = DIP_TYPE_AVI, > .ver = DIP_VERSION_AVI, > @@ -343,7 +344,7 @@ static void intel_hdmi_set_avi_infoframe(struct drm_encoder *encoder, > avi_if.body.avi.YQ_CN_PR |= DIP_AVI_PR_2; > > if (intel_hdmi->rgb_quant_range_selectable) { > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > avi_if.body.avi.ITC_EC_Q_SC |= DIP_AVI_RGB_QUANT_RANGE_LIMITED; > else > avi_if.body.avi.ITC_EC_Q_SC |= DIP_AVI_RGB_QUANT_RANGE_FULL; > @@ -785,7 +786,7 @@ bool intel_hdmi_compute_config(struct intel_encoder *encoder, > } > > if (intel_hdmi->color_range) > - adjusted_mode->private_flags |= INTEL_MODE_LIMITED_COLOR_RANGE; > + pipe_config->limited_color_range = true; > > if (HAS_PCH_SPLIT(dev) && !HAS_DDI(dev)) > pipe_config->has_pch_encoder = true; > diff --git a/drivers/gpu/drm/i915/intel_sdvo.c b/drivers/gpu/drm/i915/intel_sdvo.c > index 5f3f9e9..c6fbfd1 100644 > --- a/drivers/gpu/drm/i915/intel_sdvo.c > +++ b/drivers/gpu/drm/i915/intel_sdvo.c > @@ -956,9 +956,10 @@ static bool intel_sdvo_set_avi_infoframe(struct intel_sdvo *intel_sdvo, > .len = DIP_LEN_AVI, > }; > uint8_t sdvo_data[4 + sizeof(avi_if.body.avi)]; > + struct intel_crtc *intel_crtc = to_intel_crtc(intel_sdvo->base.base.crtc); > > if (intel_sdvo->rgb_quant_range_selectable) { > - if (adjusted_mode->private_flags & INTEL_MODE_LIMITED_COLOR_RANGE) > + if (intel_crtc->config.limited_color_range) > avi_if.body.avi.ITC_EC_Q_SC |= DIP_AVI_RGB_QUANT_RANGE_LIMITED; > else > avi_if.body.avi.ITC_EC_Q_SC |= DIP_AVI_RGB_QUANT_RANGE_FULL; > @@ -1091,7 +1092,7 @@ static bool intel_sdvo_compute_config(struct intel_encoder *encoder, > } > > if (intel_sdvo->color_range) > - adjusted_mode->private_flags |= INTEL_MODE_LIMITED_COLOR_RANGE; > + pipe_config->limited_color_range = true; > > return true; > } Looks nice. Reviewed-by: Jesse Barnes <jbarnes at virtuousgeek.org> -- Jesse Barnes, Intel Open Source Technology Center