Skip to content

Commit e55f8df

Browse files
committed
drm/i915/dpio: Fix VLV DPIO PLL register dword numbering
The spreadsheet defines the PLL register block as having the dwords in the following order: block dwords offsets PLL1 0x0-0x7 0x00-0x1f PLL2 0x0-0x7 0x20-0x3f PLL1ext 0x10-0x1f 0x40-0x5f PLL2ext 0x10-0x1f 0x60-0x7f So dword indexes 0x8-0xf don't even exist. Renumber our register defines to match. Note that the spreadsheet used hex numbering whereas our defiens are in decimal. Perhaps we should change that? Signed-off-by: Ville Syrjälä <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected] Reviewed-by: Jani Nikula <[email protected]>
1 parent a39eec1 commit e55f8df

File tree

2 files changed

+21
-21
lines changed

2 files changed

+21
-21
lines changed

drivers/gpu/drm/i915/display/intel_dpll.c

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1875,19 +1875,19 @@ static void vlv_pllb_recal_opamp(struct drm_i915_private *dev_priv,
18751875
* PLLB opamp always calibrates to max value of 0x3f, force enable it
18761876
* and set it to a reasonable value instead.
18771877
*/
1878-
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW9(1));
1878+
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW17(1));
18791879
reg_val &= 0xffffff00;
18801880
reg_val |= 0x00000030;
1881-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW9(1), reg_val);
1881+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW17(1), reg_val);
18821882

18831883
reg_val = vlv_dpio_read(dev_priv, phy, VLV_REF_DW11);
18841884
reg_val &= 0x00ffffff;
18851885
reg_val |= 0x8c000000;
18861886
vlv_dpio_write(dev_priv, phy, VLV_REF_DW11, reg_val);
18871887

1888-
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW9(1));
1888+
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW17(1));
18891889
reg_val &= 0xffffff00;
1890-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW9(1), reg_val);
1890+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW17(1), reg_val);
18911891

18921892
reg_val = vlv_dpio_read(dev_priv, phy, VLV_REF_DW11);
18931893
reg_val &= 0x00ffffff;
@@ -1923,9 +1923,9 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
19231923
vlv_dpio_write(dev_priv, phy, VLV_PCS_DW17_BCAST, 0x0100000f);
19241924

19251925
/* Disable target IRef on PLL */
1926-
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW8(pipe));
1926+
reg_val = vlv_dpio_read(dev_priv, phy, VLV_PLL_DW16(pipe));
19271927
reg_val &= 0x00ffffff;
1928-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW8(pipe), reg_val);
1928+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW16(pipe), reg_val);
19291929

19301930
/* Disable fast lock */
19311931
vlv_dpio_write(dev_priv, phy, VLV_CMN_DW0, 0x610);
@@ -1951,10 +1951,10 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
19511951
if (crtc_state->port_clock == 162000 ||
19521952
intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG) ||
19531953
intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1954-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW10(pipe),
1954+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW18(pipe),
19551955
0x009f0003);
19561956
else
1957-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW10(pipe),
1957+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW18(pipe),
19581958
0x00d0000f);
19591959

19601960
if (intel_crtc_has_dp_encoder(crtc_state)) {
@@ -1981,7 +1981,7 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
19811981
coreclk |= 0x01000000;
19821982
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW7(pipe), coreclk);
19831983

1984-
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW11(pipe), 0x87871000);
1984+
vlv_dpio_write(dev_priv, phy, VLV_PLL_DW19(pipe), 0x87871000);
19851985

19861986
vlv_dpio_put(dev_priv);
19871987
}

drivers/gpu/drm/i915/i915_reg.h

Lines changed: 12 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -229,21 +229,21 @@
229229
#define _VLV_PLL_DW7_CH1 0x803c
230230
#define VLV_PLL_DW7(ch) _PIPE(ch, _VLV_PLL_DW7_CH0, _VLV_PLL_DW7_CH1)
231231

232-
#define _VLV_PLL_DW8_CH0 0x8040
233-
#define _VLV_PLL_DW8_CH1 0x8060
234-
#define VLV_PLL_DW8(ch) _PIPE(ch, _VLV_PLL_DW8_CH0, _VLV_PLL_DW8_CH1)
232+
#define _VLV_PLL_DW16_CH0 0x8040
233+
#define _VLV_PLL_DW16_CH1 0x8060
234+
#define VLV_PLL_DW16(ch) _PIPE(ch, _VLV_PLL_DW16_CH0, _VLV_PLL_DW16_CH1)
235235

236-
#define _VLV_PLL_DW9_CH0 0x8044
237-
#define _VLV_PLL_DW9_CH1 0x8064
238-
#define VLV_PLL_DW9(ch) _PIPE(ch, _VLV_PLL_DW9_CH0, _VLV_PLL_DW9_CH1)
236+
#define _VLV_PLL_DW17_CH0 0x8044
237+
#define _VLV_PLL_DW17_CH1 0x8064
238+
#define VLV_PLL_DW17(ch) _PIPE(ch, _VLV_PLL_DW17_CH0, _VLV_PLL_DW17_CH1)
239239

240-
#define _VLV_PLL_DW10_CH0 0x8048
241-
#define _VLV_PLL_DW10_CH1 0x8068
242-
#define VLV_PLL_DW10(ch) _PIPE(ch, _VLV_PLL_DW10_CH0, _VLV_PLL_DW10_CH1)
240+
#define _VLV_PLL_DW18_CH0 0x8048
241+
#define _VLV_PLL_DW18_CH1 0x8068
242+
#define VLV_PLL_DW18(ch) _PIPE(ch, _VLV_PLL_DW18_CH0, _VLV_PLL_DW18_CH1)
243243

244-
#define _VLV_PLL_DW11_CH0 0x804c
245-
#define _VLV_PLL_DW11_CH1 0x806c
246-
#define VLV_PLL_DW11(ch) _PIPE(ch, _VLV_PLL_DW11_CH0, _VLV_PLL_DW11_CH1)
244+
#define _VLV_PLL_DW19_CH0 0x804c
245+
#define _VLV_PLL_DW19_CH1 0x806c
246+
#define VLV_PLL_DW19(ch) _PIPE(ch, _VLV_PLL_DW19_CH0, _VLV_PLL_DW19_CH1)
247247

248248
/* Spec for ref block start counts at DW8 */
249249
#define VLV_REF_DW11 0x80ac

0 commit comments

Comments
 (0)