On Tue, 2017-05-09 at 12:16 -0700, Anusha Srivatsa wrote: > From: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> > > On CNP PCH based platforms the gmbus is on the south display that > is on PCH. The existing implementation for previous platforms > already covers the need for CNP expect for the pin pair configuration > that follows similar definitions that we had on BXT. > > v2: Don't drop "_BXT" as the indicator of the first platform > supporting this pin numbers. Suggested by Daniel. > v3: Add missing else and fix register table since CNP GPIO_CTL > starts on 0xC5014. > v4: Fix pin number and map according to the current available VBT. > Re-add pin 4 for port D. Lost during some rebase. > v5: rebased. > > Cc: Daniel Vetter <daniel.vetter@xxxxxxxxx> > Cc: Jani Nikula <jani.nikula@xxxxxxxxx> > Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> > Reviewed-by: Anusha Srivatsa <anusha.srivatsa@xxxxxxxxx> Thank you a lot for all the work on these patches. > --- > drivers/gpu/drm/i915/i915_reg.h | 3 ++- > drivers/gpu/drm/i915/intel_hdmi.c | 8 +++++--- > drivers/gpu/drm/i915/intel_i2c.c | 20 ++++++++++++++++++-- > 3 files changed, 25 insertions(+), 6 deletions(-) > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h > index 9310d43..18fc7d3 100644 > --- a/drivers/gpu/drm/i915/i915_reg.h > +++ b/drivers/gpu/drm/i915/i915_reg.h > @@ -2626,9 +2626,10 @@ enum skl_disp_power_wells { > #define GMBUS_PIN_DPB 5 /* SDVO, HDMIB */ > #define GMBUS_PIN_DPD 6 /* HDMID */ > #define GMBUS_PIN_RESERVED 7 /* 7 reserved */ > -#define GMBUS_PIN_1_BXT 1 > +#define GMBUS_PIN_1_BXT 1 /* BXT+ (atom) and CNP+ (big core) */ > #define GMBUS_PIN_2_BXT 2 > #define GMBUS_PIN_3_BXT 3 > +#define GMBUS_PIN_4_CNP 4 > #define GMBUS_NUM_PINS 7 /* including 0 */ > #define GMBUS1 _MMIO(dev_priv->gpio_mmio_base + 0x5104) /* command/status */ > #define GMBUS_SW_CLR_INT (1<<31) > diff --git a/drivers/gpu/drm/i915/intel_hdmi.c b/drivers/gpu/drm/i915/intel_hdmi.c > index 58d6903..2789681 100644 > --- a/drivers/gpu/drm/i915/intel_hdmi.c > +++ b/drivers/gpu/drm/i915/intel_hdmi.c > @@ -1885,19 +1885,21 @@ static u8 intel_hdmi_ddc_pin(struct drm_i915_private *dev_priv, > > switch (port) { > case PORT_B: > - if (IS_GEN9_LP(dev_priv)) > + if (IS_GEN9_LP(dev_priv) || HAS_PCH_CNP(dev_priv)) > ddc_pin = GMBUS_PIN_1_BXT; > else > ddc_pin = GMBUS_PIN_DPB; > break; > case PORT_C: > - if (IS_GEN9_LP(dev_priv)) > + if (IS_GEN9_LP(dev_priv) || HAS_PCH_CNP(dev_priv)) > ddc_pin = GMBUS_PIN_2_BXT; > else > ddc_pin = GMBUS_PIN_DPC; > break; > case PORT_D: > - if (IS_CHERRYVIEW(dev_priv)) > + if (HAS_PCH_CNP(dev_priv)) > + ddc_pin = GMBUS_PIN_4_CNP; > + else if (IS_CHERRYVIEW(dev_priv)) > ddc_pin = GMBUS_PIN_DPD_CHV; > else > ddc_pin = GMBUS_PIN_DPD; > diff --git a/drivers/gpu/drm/i915/intel_i2c.c b/drivers/gpu/drm/i915/intel_i2c.c > index b6401e8..3eb4a91 100644 > --- a/drivers/gpu/drm/i915/intel_i2c.c > +++ b/drivers/gpu/drm/i915/intel_i2c.c > @@ -68,11 +68,25 @@ static const struct gmbus_pin gmbus_pins_bxt[] = { > [GMBUS_PIN_3_BXT] = { "misc", GPIOD }, > }; > > +/* > + * FIXME: Spec maps 3-misc-0xc541c and 4-portd-0xc5420. > + * However, current available pre-prod VBT maps: > + * portD to pin 3 using 0xc5420. > + */ We cannot use this patch since it would break CFL. We need to add the spec table and workaround the vbt parsing on cnl for now. I will send new version soon. > +static const struct gmbus_pin gmbus_pins_cnp[] = { > + [GMBUS_PIN_1_BXT] = { "dpb", GPIOB }, > + [GMBUS_PIN_2_BXT] = { "dpc", GPIOC }, > + [GMBUS_PIN_3_BXT] = { "misc", GPIOE }, > + [GMBUS_PIN_4_CNP] = { "dpd", GPIOD }, > +}; > + > /* pin is expected to be valid */ > static const struct gmbus_pin *get_gmbus_pin(struct drm_i915_private *dev_priv, > unsigned int pin) > { > - if (IS_GEN9_LP(dev_priv)) > + if (HAS_PCH_CNP(dev_priv)) > + return &gmbus_pins_cnp[pin]; > + else if (IS_GEN9_LP(dev_priv)) > return &gmbus_pins_bxt[pin]; > else if (IS_GEN9_BC(dev_priv)) > return &gmbus_pins_skl[pin]; > @@ -87,7 +101,9 @@ bool intel_gmbus_is_valid_pin(struct drm_i915_private *dev_priv, > { > unsigned int size; > > - if (IS_GEN9_LP(dev_priv)) > + if (HAS_PCH_CNP(dev_priv)) > + size = ARRAY_SIZE(gmbus_pins_cnp); > + else if (IS_GEN9_LP(dev_priv)) > size = ARRAY_SIZE(gmbus_pins_bxt); > else if (IS_GEN9_BC(dev_priv)) > size = ARRAY_SIZE(gmbus_pins_skl); _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx