Re: [Intel-gfx] [PATCH v7 5/5] drm/i915/rkl: Add Wa_14011224835 for PHY B initialization
On Tue, 2020-06-16 at 20:31 -0700, Matt Roper wrote: > After doing normal PHY-B initialization on Rocket Lake, we need to > manually copy some additional PHY-A register values into PHY-B > registers. > > Note that the bspec's combo phy page doesn't specify that this > workaround is restricted to specific platform steppings (and doesn't > even do a very good job of specifying that RKL is the only platform this > is needed on), but the RKL workaround page lists this as relevant only > for A and B steppings, so I'm trusting that information for now. > > v2: Make rkl_combo_phy_b_init_wa() static > > Bspec: 49291 > Bspec: 53273 > Signed-off-by: Matt Roper > --- > .../gpu/drm/i915/display/intel_combo_phy.c| 26 +++ > drivers/gpu/drm/i915/i915_reg.h | 13 +- > 2 files changed, 38 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/i915/display/intel_combo_phy.c > b/drivers/gpu/drm/i915/display/intel_combo_phy.c > index 77b04bb3ec62..d5d95e2746c2 100644 > --- a/drivers/gpu/drm/i915/display/intel_combo_phy.c > +++ b/drivers/gpu/drm/i915/display/intel_combo_phy.c > @@ -338,6 +338,27 @@ void intel_combo_phy_power_up_lanes(struct > drm_i915_private *dev_priv, > intel_de_write(dev_priv, ICL_PORT_CL_DW10(phy), val); > } > > +static void rkl_combo_phy_b_init_wa(struct drm_i915_private *i915) > +{ > + u32 grccode, grccode_ldo; > + u32 iref_rcal_ord, rcompcode_ld_cap_ov; Nitpick: you could do all the bellow with just 2 u32(val and grccode). > + > + intel_de_wait_for_register(i915, ICL_PORT_COMP_DW3(PHY_A), > +FIRST_COMP_DONE, FIRST_COMP_DONE, 100); The timeout parameter here is in ms not usec > + > + grccode = REG_FIELD_GET(GRCCODE, > + intel_de_read(i915, ICL_PORT_COMP_DW6(PHY_A))); > + iref_rcal_ord = REG_FIELD_PREP(IREF_RCAL_ORD, grccode); > + intel_de_rmw(i915, ICL_PORT_COMP_DW2(PHY_B), IREF_RCAL_ORD, > + iref_rcal_ord | IREF_RCAL_ORD_EN); > + > + grccode_ldo = REG_FIELD_GET(GRCCODE_LDO, > + intel_de_read(i915, > ICL_PORT_COMP_DW0(PHY_A))); > + rcompcode_ld_cap_ov = REG_FIELD_PREP(RCOMPCODE_LD_CAP_OV, grccode_ldo); > + intel_de_rmw(i915, ICL_PORT_COMP_DW6(PHY_B), RCOMPCODE_LD_CAP_OV, > + rcompcode_ld_cap_ov | RCOMPCODEOVEN_LDO_SYNC); > +} > + > static void icl_combo_phys_init(struct drm_i915_private *dev_priv) > { > enum phy phy; > @@ -390,6 +411,11 @@ static void icl_combo_phys_init(struct drm_i915_private > *dev_priv) > val = intel_de_read(dev_priv, ICL_PORT_CL_DW5(phy)); > val |= CL_POWER_DOWN_ENABLE; > intel_de_write(dev_priv, ICL_PORT_CL_DW5(phy), val); > + > + if (IS_RKL_REVID(dev_priv, RKL_REVID_A0, RKL_REVID_B0) && > + phy == PHY_B) > + /* Wa_14011224835:rkl[a0..c0] */ > + rkl_combo_phy_b_init_wa(dev_priv); Missing the icl_combo_phy_verify_state() counter part. > } > } > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h > index 34b2ec04ccd8..10f6e46523b6 100644 > --- a/drivers/gpu/drm/i915/i915_reg.h > +++ b/drivers/gpu/drm/i915/i915_reg.h > @@ -1908,11 +1908,16 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) > > #define CNL_PORT_COMP_DW0_MMIO(0x162100) > #define ICL_PORT_COMP_DW0(phy) _MMIO(_ICL_PORT_COMP_DW(0, phy)) > -#define COMP_INIT (1 << 31) > +#define COMP_INIT REG_BIT(31) > +#define GRCCODE_LDOREG_GENMASK(7, 0) > > #define CNL_PORT_COMP_DW1_MMIO(0x162104) > #define ICL_PORT_COMP_DW1(phy) _MMIO(_ICL_PORT_COMP_DW(1, phy)) > > +#define ICL_PORT_COMP_DW2(phy) _MMIO(_ICL_PORT_COMP_DW(2, phy)) > +#define IREF_RCAL_ORD_EN REG_BIT(7) > +#define IREF_RCAL_ORD REG_GENMASK(6, 0) > + > #define CNL_PORT_COMP_DW3_MMIO(0x16210c) > #define ICL_PORT_COMP_DW3(phy) _MMIO(_ICL_PORT_COMP_DW(3, phy)) > #define PROCESS_INFO_DOT_0 (0 << 26) > @@ -1925,6 +1930,12 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) > #define VOLTAGE_INFO_1_05V (2 << 24) > #define VOLTAGE_INFO_MASK (3 << 24) > #define VOLTAGE_INFO_SHIFT 24 > +#define FIRST_COMP_DONEREG_BIT(22) > + > +#define ICL_PORT_COMP_DW6(phy) _MMIO(_ICL_PORT_COMP_DW(6, phy)) > +#define GRCCODEREG_GENMASK(30, 24) > +#define RCOMPCODEOVEN_LDO_SYNC REG_BIT(23) > +#define RCOMPCODE_LD_CAP_OVREG_GENMASK(22, 16) > Register definition matches. > #define ICL_PORT_COMP_DW8(phy) _MMIO(_ICL_PORT_COMP_DW(8, phy)) > #define IREFGEN(1 << 24) ___ Intel-gfx mailing list Intel-gfx@lis
Re: [Intel-gfx] [PATCH v7 5/5] drm/i915/rkl: Add Wa_14011224835 for PHY B initialization
On Tue, 2020-06-16 at 20:31 -0700, Matt Roper wrote: > After doing normal PHY-B initialization on Rocket Lake, we need to > manually copy some additional PHY-A register values into PHY-B > registers. > > Note that the bspec's combo phy page doesn't specify that this > workaround is restricted to specific platform steppings (and doesn't > even do a very good job of specifying that RKL is the only platform this > is needed on), but the RKL workaround page lists this as relevant only > for A and B steppings, so I'm trusting that information for now. > > v2: Make rkl_combo_phy_b_init_wa() static > > Bspec: 49291 > Bspec: 53273 > Signed-off-by: Matt Roper > --- > .../gpu/drm/i915/display/intel_combo_phy.c| 26 +++ > drivers/gpu/drm/i915/i915_reg.h | 13 +- > 2 files changed, 38 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/i915/display/intel_combo_phy.c > b/drivers/gpu/drm/i915/display/intel_combo_phy.c > index 77b04bb3ec62..d5d95e2746c2 100644 > --- a/drivers/gpu/drm/i915/display/intel_combo_phy.c > +++ b/drivers/gpu/drm/i915/display/intel_combo_phy.c > @@ -338,6 +338,27 @@ void intel_combo_phy_power_up_lanes(struct > drm_i915_private *dev_priv, > intel_de_write(dev_priv, ICL_PORT_CL_DW10(phy), val); > } > > +static void rkl_combo_phy_b_init_wa(struct drm_i915_private *i915) > +{ > + u32 grccode, grccode_ldo; > + u32 iref_rcal_ord, rcompcode_ld_cap_ov; > + > + intel_de_wait_for_register(i915, ICL_PORT_COMP_DW3(PHY_A), > +FIRST_COMP_DONE, FIRST_COMP_DONE, 100); > + > + grccode = REG_FIELD_GET(GRCCODE, > + intel_de_read(i915, ICL_PORT_COMP_DW6(PHY_A))); > + iref_rcal_ord = REG_FIELD_PREP(IREF_RCAL_ORD, grccode); > + intel_de_rmw(i915, ICL_PORT_COMP_DW2(PHY_B), IREF_RCAL_ORD, > + iref_rcal_ord | IREF_RCAL_ORD_EN); > + > + grccode_ldo = REG_FIELD_GET(GRCCODE_LDO, > + intel_de_read(i915, > ICL_PORT_COMP_DW0(PHY_A))); > + rcompcode_ld_cap_ov = REG_FIELD_PREP(RCOMPCODE_LD_CAP_OV, grccode_ldo); > + intel_de_rmw(i915, ICL_PORT_COMP_DW6(PHY_B), RCOMPCODE_LD_CAP_OV, > + rcompcode_ld_cap_ov | RCOMPCODEOVEN_LDO_SYNC); > +} > + > static void icl_combo_phys_init(struct drm_i915_private *dev_priv) > { > enum phy phy; > @@ -390,6 +411,11 @@ static void icl_combo_phys_init(struct drm_i915_private > *dev_priv) > val = intel_de_read(dev_priv, ICL_PORT_CL_DW5(phy)); > val |= CL_POWER_DOWN_ENABLE; > intel_de_write(dev_priv, ICL_PORT_CL_DW5(phy), val); > + > + if (IS_RKL_REVID(dev_priv, RKL_REVID_A0, RKL_REVID_B0) && > + phy == PHY_B) > + /* Wa_14011224835:rkl[a0..c0] */ > + rkl_combo_phy_b_init_wa(dev_priv); > } > } > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h > index 34b2ec04ccd8..10f6e46523b6 100644 > --- a/drivers/gpu/drm/i915/i915_reg.h > +++ b/drivers/gpu/drm/i915/i915_reg.h > @@ -1908,11 +1908,16 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) > > #define CNL_PORT_COMP_DW0_MMIO(0x162100) > #define ICL_PORT_COMP_DW0(phy) _MMIO(_ICL_PORT_COMP_DW(0, phy)) > -#define COMP_INIT (1 << 31) > +#define COMP_INIT REG_BIT(31) > +#define GRCCODE_LDOREG_GENMASK(7, 0) > > #define CNL_PORT_COMP_DW1_MMIO(0x162104) > #define ICL_PORT_COMP_DW1(phy) _MMIO(_ICL_PORT_COMP_DW(1, phy)) > > +#define ICL_PORT_COMP_DW2(phy) _MMIO(_ICL_PORT_COMP_DW(2, phy)) > +#define IREF_RCAL_ORD_EN REG_BIT(7) > +#define IREF_RCAL_ORD REG_GENMASK(6, 0) > + > #define CNL_PORT_COMP_DW3_MMIO(0x16210c) > #define ICL_PORT_COMP_DW3(phy) _MMIO(_ICL_PORT_COMP_DW(3, phy)) > #define PROCESS_INFO_DOT_0 (0 << 26) > @@ -1925,6 +1930,12 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) > #define VOLTAGE_INFO_1_05V (2 << 24) > #define VOLTAGE_INFO_MASK (3 << 24) > #define VOLTAGE_INFO_SHIFT 24 > +#define FIRST_COMP_DONEREG_BIT(22) > + > +#define ICL_PORT_COMP_DW6(phy) _MMIO(_ICL_PORT_COMP_DW(6, phy)) > +#define GRCCODEREG_GENMASK(30, 24) > +#define RCOMPCODEOVEN_LDO_SYNC REG_BIT(23) > +#define RCOMPCODE_LD_CAP_OVREG_GENMASK(22, 16) > > #define ICL_PORT_COMP_DW8(phy) _MMIO(_ICL_PORT_COMP_DW(8, phy)) > #define IREFGEN(1 << 24) ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
[Intel-gfx] [PATCH v7 5/5] drm/i915/rkl: Add Wa_14011224835 for PHY B initialization
After doing normal PHY-B initialization on Rocket Lake, we need to manually copy some additional PHY-A register values into PHY-B registers. Note that the bspec's combo phy page doesn't specify that this workaround is restricted to specific platform steppings (and doesn't even do a very good job of specifying that RKL is the only platform this is needed on), but the RKL workaround page lists this as relevant only for A and B steppings, so I'm trusting that information for now. v2: Make rkl_combo_phy_b_init_wa() static Bspec: 49291 Bspec: 53273 Signed-off-by: Matt Roper --- .../gpu/drm/i915/display/intel_combo_phy.c| 26 +++ drivers/gpu/drm/i915/i915_reg.h | 13 +- 2 files changed, 38 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/i915/display/intel_combo_phy.c b/drivers/gpu/drm/i915/display/intel_combo_phy.c index 77b04bb3ec62..d5d95e2746c2 100644 --- a/drivers/gpu/drm/i915/display/intel_combo_phy.c +++ b/drivers/gpu/drm/i915/display/intel_combo_phy.c @@ -338,6 +338,27 @@ void intel_combo_phy_power_up_lanes(struct drm_i915_private *dev_priv, intel_de_write(dev_priv, ICL_PORT_CL_DW10(phy), val); } +static void rkl_combo_phy_b_init_wa(struct drm_i915_private *i915) +{ + u32 grccode, grccode_ldo; + u32 iref_rcal_ord, rcompcode_ld_cap_ov; + + intel_de_wait_for_register(i915, ICL_PORT_COMP_DW3(PHY_A), + FIRST_COMP_DONE, FIRST_COMP_DONE, 100); + + grccode = REG_FIELD_GET(GRCCODE, + intel_de_read(i915, ICL_PORT_COMP_DW6(PHY_A))); + iref_rcal_ord = REG_FIELD_PREP(IREF_RCAL_ORD, grccode); + intel_de_rmw(i915, ICL_PORT_COMP_DW2(PHY_B), IREF_RCAL_ORD, +iref_rcal_ord | IREF_RCAL_ORD_EN); + + grccode_ldo = REG_FIELD_GET(GRCCODE_LDO, + intel_de_read(i915, ICL_PORT_COMP_DW0(PHY_A))); + rcompcode_ld_cap_ov = REG_FIELD_PREP(RCOMPCODE_LD_CAP_OV, grccode_ldo); + intel_de_rmw(i915, ICL_PORT_COMP_DW6(PHY_B), RCOMPCODE_LD_CAP_OV, +rcompcode_ld_cap_ov | RCOMPCODEOVEN_LDO_SYNC); +} + static void icl_combo_phys_init(struct drm_i915_private *dev_priv) { enum phy phy; @@ -390,6 +411,11 @@ static void icl_combo_phys_init(struct drm_i915_private *dev_priv) val = intel_de_read(dev_priv, ICL_PORT_CL_DW5(phy)); val |= CL_POWER_DOWN_ENABLE; intel_de_write(dev_priv, ICL_PORT_CL_DW5(phy), val); + + if (IS_RKL_REVID(dev_priv, RKL_REVID_A0, RKL_REVID_B0) && + phy == PHY_B) + /* Wa_14011224835:rkl[a0..c0] */ + rkl_combo_phy_b_init_wa(dev_priv); } } diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 34b2ec04ccd8..10f6e46523b6 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h @@ -1908,11 +1908,16 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) #define CNL_PORT_COMP_DW0 _MMIO(0x162100) #define ICL_PORT_COMP_DW0(phy) _MMIO(_ICL_PORT_COMP_DW(0, phy)) -#define COMP_INIT(1 << 31) +#define COMP_INITREG_BIT(31) +#define GRCCODE_LDO REG_GENMASK(7, 0) #define CNL_PORT_COMP_DW1 _MMIO(0x162104) #define ICL_PORT_COMP_DW1(phy) _MMIO(_ICL_PORT_COMP_DW(1, phy)) +#define ICL_PORT_COMP_DW2(phy) _MMIO(_ICL_PORT_COMP_DW(2, phy)) +#define IREF_RCAL_ORD_EN REG_BIT(7) +#define IREF_RCAL_ORDREG_GENMASK(6, 0) + #define CNL_PORT_COMP_DW3 _MMIO(0x16210c) #define ICL_PORT_COMP_DW3(phy) _MMIO(_ICL_PORT_COMP_DW(3, phy)) #define PROCESS_INFO_DOT_0 (0 << 26) @@ -1925,6 +1930,12 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg) #define VOLTAGE_INFO_1_05V (2 << 24) #define VOLTAGE_INFO_MASK(3 << 24) #define VOLTAGE_INFO_SHIFT 24 +#define FIRST_COMP_DONE REG_BIT(22) + +#define ICL_PORT_COMP_DW6(phy) _MMIO(_ICL_PORT_COMP_DW(6, phy)) +#define GRCCODE REG_GENMASK(30, 24) +#define RCOMPCODEOVEN_LDO_SYNC REG_BIT(23) +#define RCOMPCODE_LD_CAP_OV REG_GENMASK(22, 16) #define ICL_PORT_COMP_DW8(phy) _MMIO(_ICL_PORT_COMP_DW(8, phy)) #define IREFGEN (1 << 24) -- 2.24.1 ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx