On Sat, Nov 02, 2013 at 09:07:42PM -0700, Ben Widawsky wrote: > From: Paulo Zanoni <paulo.r.zanoni@xxxxxxxxx> > > Broadwell has different DDI buffer translations for eDP and DP, so add > support for the missing eDP and keep Haswell the same. > > A future patch addresses the suggestion from Art to check for eDP on > port D and use the eDP values there, too. > > Reviewed-by: Art Runyan <arthur.j.runyan@xxxxxxxxx> > Signed-off-by: Paulo Zanoni <paulo.r.zanoni@xxxxxxxxx> > --- > drivers/gpu/drm/i915/intel_ddi.c | 38 +++++++++++++++++++++++++++++++++----- > 1 file changed, 33 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_ddi.c b/drivers/gpu/drm/i915/intel_ddi.c > index 4baf3cd..3868ed9 100644 > --- a/drivers/gpu/drm/i915/intel_ddi.c > +++ b/drivers/gpu/drm/i915/intel_ddi.c > @@ -72,6 +72,19 @@ static const u32 hsw_ddi_translations_hdmi[] = { > 0x80FFFFFF, 0x00030002, /* 11: 1000 1000 0 */ > }; > > +static const u32 bdw_ddi_translations_edp[] = { > + 0x00FFFFFF, 0x00000012, /* DP parameters */ > + 0x00EBAFFF, 0x00020011, > + 0x00C71FFF, 0x0006000F, > + 0x00FFFFFF, 0x00020011, > + 0x00DB6FFF, 0x0005000F, > + 0x00BEEFFF, 0x000A000C, > + 0x00FFFFFF, 0x0005000F, > + 0x00DB6FFF, 0x000A000C, > + 0x00FFFFFF, 0x000A000C, > + 0x00FFFFFF, 0x00140006 /* HDMI parameters 800mV 0dB*/ > +}; > + > static const u32 bdw_ddi_translations_dp[] = { > 0x00FFFFFF, 0x0007000E, /* DP parameters */ > 0x00D75FFF, 0x000E000A, > @@ -132,26 +145,41 @@ static void intel_prepare_ddi_buffers(struct drm_device *dev, enum port port) > int hdmi_level = dev_priv->vbt.ddi_port_info[port].hdmi_level_shift; > const u32 *ddi_translations_fdi; > const u32 *ddi_translations_dp; > + const u32 *ddi_translations_edp; > const u32 *ddi_translations; > > if (IS_BROADWELL(dev)) { > ddi_translations_fdi = bdw_ddi_translations_fdi; > ddi_translations_dp = bdw_ddi_translations_dp; > + ddi_translations_edp = bdw_ddi_translations_edp; > } else if (IS_HASWELL(dev)) { > ddi_translations_fdi = hsw_ddi_translations_fdi; > ddi_translations_dp = hsw_ddi_translations_dp; > + ddi_translations_edp = hsw_ddi_translations_dp; > } else { > WARN(1, "ddi translation table missing\n"); > + ddi_translations_edp = bdw_ddi_translations_dp; > ddi_translations_fdi = bdw_ddi_translations_fdi; > ddi_translations_dp = bdw_ddi_translations_dp; > } > > - ddi_translations = ((port == PORT_E) ? > - ddi_translations_fdi : > - ddi_translations_dp); > + switch (port) { > + case PORT_A: > + ddi_translations = ddi_translations_edp; > + break; > + case PORT_B: > + case PORT_C: > + case PORT_D: > + ddi_translations = ddi_translations_dp; > + break; > + case PORT_E: > + ddi_translations = ddi_translations_fdi; > + break; > + default: > + BUG(); > + } > > - for (i = 0, reg = DDI_BUF_TRANS(port); > - i < ARRAY_SIZE(hsw_ddi_translations_fdi); i++) { > + for (i=0, reg=DDI_BUF_TRANS(port); i < ARRAY_SIZE(hsw_ddi_translations_fdi); i++) { Daniel, maybe fix up this for checkpatch in merge? I don't care either way. > I915_WRITE(reg, ddi_translations[i]); > reg += 4; > } Reviewed-by: Ben Widawsky <ben@xxxxxxxxxxxx> -- Ben Widawsky, Intel Open Source Technology Center _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx