@@ -512,6 +512,7 @@ void vlv_crtc_clock_get(struct intel_crtc_state *crtc_state)
512
512
{
513
513
struct intel_crtc * crtc = to_intel_crtc (crtc_state -> uapi .crtc );
514
514
struct drm_i915_private * dev_priv = to_i915 (crtc -> base .dev );
515
+ enum dpio_channel ch = vlv_pipe_to_channel (crtc -> pipe );
515
516
enum dpio_phy phy = vlv_pipe_to_phy (crtc -> pipe );
516
517
const struct i9xx_dpll_hw_state * hw_state = & crtc_state -> dpll_hw_state .i9xx ;
517
518
int refclk = 100000 ;
@@ -523,7 +524,7 @@ void vlv_crtc_clock_get(struct intel_crtc_state *crtc_state)
523
524
return ;
524
525
525
526
vlv_dpio_get (dev_priv );
526
- tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW3 (crtc -> pipe ));
527
+ tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW3 (ch ));
527
528
vlv_dpio_put (dev_priv );
528
529
529
530
clock .m1 = (tmp >> DPIO_M1DIV_SHIFT ) & 7 ;
@@ -1867,27 +1868,27 @@ void i9xx_enable_pll(const struct intel_crtc_state *crtc_state)
1867
1868
}
1868
1869
1869
1870
static void vlv_pllb_recal_opamp (struct drm_i915_private * dev_priv ,
1870
- enum dpio_phy phy )
1871
+ enum dpio_phy phy , enum dpio_channel ch )
1871
1872
{
1872
1873
u32 tmp ;
1873
1874
1874
1875
/*
1875
1876
* PLLB opamp always calibrates to max value of 0x3f, force enable it
1876
1877
* and set it to a reasonable value instead.
1877
1878
*/
1878
- tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW17 (1 ));
1879
+ tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW17 (ch ));
1879
1880
tmp &= 0xffffff00 ;
1880
1881
tmp |= 0x00000030 ;
1881
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW17 (1 ), tmp );
1882
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW17 (ch ), tmp );
1882
1883
1883
1884
tmp = vlv_dpio_read (dev_priv , phy , VLV_REF_DW11 );
1884
1885
tmp &= 0x00ffffff ;
1885
1886
tmp |= 0x8c000000 ;
1886
1887
vlv_dpio_write (dev_priv , phy , VLV_REF_DW11 , tmp );
1887
1888
1888
- tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW17 (1 ));
1889
+ tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW17 (ch ));
1889
1890
tmp &= 0xffffff00 ;
1890
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW17 (1 ), tmp );
1891
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW17 (ch ), tmp );
1891
1892
1892
1893
tmp = vlv_dpio_read (dev_priv , phy , VLV_REF_DW11 );
1893
1894
tmp &= 0x00ffffff ;
@@ -1900,6 +1901,7 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
1900
1901
struct intel_crtc * crtc = to_intel_crtc (crtc_state -> uapi .crtc );
1901
1902
struct drm_i915_private * dev_priv = to_i915 (crtc -> base .dev );
1902
1903
const struct dpll * clock = & crtc_state -> dpll ;
1904
+ enum dpio_channel ch = vlv_pipe_to_channel (crtc -> pipe );
1903
1905
enum dpio_phy phy = vlv_pipe_to_phy (crtc -> pipe );
1904
1906
enum pipe pipe = crtc -> pipe ;
1905
1907
u32 tmp , coreclk ;
@@ -1910,15 +1912,15 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
1910
1912
1911
1913
/* PLL B needs special handling */
1912
1914
if (pipe == PIPE_B )
1913
- vlv_pllb_recal_opamp (dev_priv , phy );
1915
+ vlv_pllb_recal_opamp (dev_priv , phy , ch );
1914
1916
1915
1917
/* Set up Tx target for periodic Rcomp update */
1916
1918
vlv_dpio_write (dev_priv , phy , VLV_PCS_DW17_BCAST , 0x0100000f );
1917
1919
1918
1920
/* Disable target IRef on PLL */
1919
- tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW16 (pipe ));
1921
+ tmp = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW16 (ch ));
1920
1922
tmp &= 0x00ffffff ;
1921
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW16 (pipe ), tmp );
1923
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW16 (ch ), tmp );
1922
1924
1923
1925
/* Disable fast lock */
1924
1926
vlv_dpio_write (dev_priv , phy , VLV_CMN_DW0 , 0x610 );
@@ -1937,46 +1939,46 @@ static void vlv_prepare_pll(const struct intel_crtc_state *crtc_state)
1937
1939
* Note: don't use the DAC post divider as it seems unstable.
1938
1940
*/
1939
1941
tmp |= (DPIO_POST_DIV_HDMIDP << DPIO_POST_DIV_SHIFT );
1940
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW3 (pipe ), tmp );
1942
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW3 (ch ), tmp );
1941
1943
1942
1944
tmp |= DPIO_ENABLE_CALIBRATION ;
1943
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW3 (pipe ), tmp );
1945
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW3 (ch ), tmp );
1944
1946
1945
1947
/* Set HBR and RBR LPF coefficients */
1946
1948
if (crtc_state -> port_clock == 162000 ||
1947
1949
intel_crtc_has_type (crtc_state , INTEL_OUTPUT_ANALOG ) ||
1948
1950
intel_crtc_has_type (crtc_state , INTEL_OUTPUT_HDMI ))
1949
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW18 (pipe ),
1951
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW18 (ch ),
1950
1952
0x009f0003 );
1951
1953
else
1952
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW18 (pipe ),
1954
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW18 (ch ),
1953
1955
0x00d0000f );
1954
1956
1955
1957
if (intel_crtc_has_dp_encoder (crtc_state )) {
1956
1958
/* Use SSC source */
1957
1959
if (pipe == PIPE_A )
1958
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (pipe ),
1960
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (ch ),
1959
1961
0x0df40000 );
1960
1962
else
1961
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (pipe ),
1963
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (ch ),
1962
1964
0x0df70000 );
1963
1965
} else { /* HDMI or VGA */
1964
1966
/* Use bend source */
1965
1967
if (pipe == PIPE_A )
1966
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (pipe ),
1968
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (ch ),
1967
1969
0x0df70000 );
1968
1970
else
1969
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (pipe ),
1971
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW5 (ch ),
1970
1972
0x0df40000 );
1971
1973
}
1972
1974
1973
- coreclk = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW7 (pipe ));
1975
+ coreclk = vlv_dpio_read (dev_priv , phy , VLV_PLL_DW7 (ch ));
1974
1976
coreclk = (coreclk & 0x0000ff00 ) | 0x01c00000 ;
1975
1977
if (intel_crtc_has_dp_encoder (crtc_state ))
1976
1978
coreclk |= 0x01000000 ;
1977
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW7 (pipe ), coreclk );
1979
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW7 (ch ), coreclk );
1978
1980
1979
- vlv_dpio_write (dev_priv , phy , VLV_PLL_DW19 (pipe ), 0x87871000 );
1981
+ vlv_dpio_write (dev_priv , phy , VLV_PLL_DW19 (ch ), 0x87871000 );
1980
1982
1981
1983
vlv_dpio_put (dev_priv );
1982
1984
}
@@ -2026,8 +2028,7 @@ static void chv_prepare_pll(const struct intel_crtc_state *crtc_state)
2026
2028
struct intel_crtc * crtc = to_intel_crtc (crtc_state -> uapi .crtc );
2027
2029
struct drm_i915_private * dev_priv = to_i915 (crtc -> base .dev );
2028
2030
const struct dpll * clock = & crtc_state -> dpll ;
2029
- enum pipe pipe = crtc -> pipe ;
2030
- enum dpio_channel ch = vlv_pipe_to_channel (pipe );
2031
+ enum dpio_channel ch = vlv_pipe_to_channel (crtc -> pipe );
2031
2032
enum dpio_phy phy = vlv_pipe_to_phy (crtc -> pipe );
2032
2033
u32 tmp , loopfilter , tribuf_calcntr ;
2033
2034
u32 m2_frac ;
@@ -2117,9 +2118,9 @@ static void _chv_enable_pll(const struct intel_crtc_state *crtc_state)
2117
2118
struct intel_crtc * crtc = to_intel_crtc (crtc_state -> uapi .crtc );
2118
2119
struct drm_i915_private * dev_priv = to_i915 (crtc -> base .dev );
2119
2120
const struct i9xx_dpll_hw_state * hw_state = & crtc_state -> dpll_hw_state .i9xx ;
2120
- enum pipe pipe = crtc -> pipe ;
2121
- enum dpio_channel ch = vlv_pipe_to_channel (pipe );
2121
+ enum dpio_channel ch = vlv_pipe_to_channel (crtc -> pipe );
2122
2122
enum dpio_phy phy = vlv_pipe_to_phy (crtc -> pipe );
2123
+ enum pipe pipe = crtc -> pipe ;
2123
2124
u32 tmp ;
2124
2125
2125
2126
vlv_dpio_get (dev_priv );
0 commit comments