Commit f70a68bc authored by Jani Nikula's avatar Jani Nikula

drm/i915: convert vlv_dpio_read()/write() from pipe to phy

vlv_dpio_read() and vlv_dpio_write() really operate on the phy, not
pipe. Passing the pipe instead of the phy as parameter is supposed to be
a convenience, but when the caller has the phy, it becomes an
inconvenience. See e.g. chv_dpio_cmn_power_well_enable() and
assert_chv_phy_powergate().

Figure out the phy in the callers, and pass phy to the dpio functions.

v2: retract one overzealous pipe->phy change (Ville)
Reviewed-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231114104534.4180144-3-jani.nikula@intel.com
parent 9fda18c2
...@@ -1400,20 +1400,16 @@ static void chv_dpio_cmn_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -1400,20 +1400,16 @@ static void chv_dpio_cmn_power_well_enable(struct drm_i915_private *dev_priv,
{ {
enum i915_power_well_id id = i915_power_well_instance(power_well)->id; enum i915_power_well_id id = i915_power_well_instance(power_well)->id;
enum dpio_phy phy; enum dpio_phy phy;
enum pipe pipe;
u32 tmp; u32 tmp;
drm_WARN_ON_ONCE(&dev_priv->drm, drm_WARN_ON_ONCE(&dev_priv->drm,
id != VLV_DISP_PW_DPIO_CMN_BC && id != VLV_DISP_PW_DPIO_CMN_BC &&
id != CHV_DISP_PW_DPIO_CMN_D); id != CHV_DISP_PW_DPIO_CMN_D);
if (id == VLV_DISP_PW_DPIO_CMN_BC) { if (id == VLV_DISP_PW_DPIO_CMN_BC)
pipe = PIPE_A;
phy = DPIO_PHY0; phy = DPIO_PHY0;
} else { else
pipe = PIPE_C;
phy = DPIO_PHY1; phy = DPIO_PHY1;
}
/* since ref/cri clock was enabled */ /* since ref/cri clock was enabled */
udelay(1); /* >10ns for cmnreset, >0ns for sidereset */ udelay(1); /* >10ns for cmnreset, >0ns for sidereset */
...@@ -1428,24 +1424,24 @@ static void chv_dpio_cmn_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -1428,24 +1424,24 @@ static void chv_dpio_cmn_power_well_enable(struct drm_i915_private *dev_priv,
vlv_dpio_get(dev_priv); vlv_dpio_get(dev_priv);
/* Enable dynamic power down */ /* Enable dynamic power down */
tmp = vlv_dpio_read(dev_priv, pipe, CHV_CMN_DW28); tmp = vlv_dpio_read(dev_priv, phy, CHV_CMN_DW28);
tmp |= DPIO_DYNPWRDOWNEN_CH0 | DPIO_CL1POWERDOWNEN | tmp |= DPIO_DYNPWRDOWNEN_CH0 | DPIO_CL1POWERDOWNEN |
DPIO_SUS_CLK_CONFIG_GATE_CLKREQ; DPIO_SUS_CLK_CONFIG_GATE_CLKREQ;
vlv_dpio_write(dev_priv, pipe, CHV_CMN_DW28, tmp); vlv_dpio_write(dev_priv, phy, CHV_CMN_DW28, tmp);
if (id == VLV_DISP_PW_DPIO_CMN_BC) { if (id == VLV_DISP_PW_DPIO_CMN_BC) {
tmp = vlv_dpio_read(dev_priv, pipe, _CHV_CMN_DW6_CH1); tmp = vlv_dpio_read(dev_priv, phy, _CHV_CMN_DW6_CH1);
tmp |= DPIO_DYNPWRDOWNEN_CH1; tmp |= DPIO_DYNPWRDOWNEN_CH1;
vlv_dpio_write(dev_priv, pipe, _CHV_CMN_DW6_CH1, tmp); vlv_dpio_write(dev_priv, phy, _CHV_CMN_DW6_CH1, tmp);
} else { } else {
/* /*
* Force the non-existing CL2 off. BXT does this * Force the non-existing CL2 off. BXT does this
* too, so maybe it saves some power even though * too, so maybe it saves some power even though
* CL2 doesn't exist? * CL2 doesn't exist?
*/ */
tmp = vlv_dpio_read(dev_priv, pipe, CHV_CMN_DW30); tmp = vlv_dpio_read(dev_priv, phy, CHV_CMN_DW30);
tmp |= DPIO_CL2_LDOFUSE_PWRENB; tmp |= DPIO_CL2_LDOFUSE_PWRENB;
vlv_dpio_write(dev_priv, pipe, CHV_CMN_DW30, tmp); vlv_dpio_write(dev_priv, phy, CHV_CMN_DW30, tmp);
} }
vlv_dpio_put(dev_priv); vlv_dpio_put(dev_priv);
...@@ -1499,7 +1495,6 @@ static void chv_dpio_cmn_power_well_disable(struct drm_i915_private *dev_priv, ...@@ -1499,7 +1495,6 @@ static void chv_dpio_cmn_power_well_disable(struct drm_i915_private *dev_priv,
static void assert_chv_phy_powergate(struct drm_i915_private *dev_priv, enum dpio_phy phy, static void assert_chv_phy_powergate(struct drm_i915_private *dev_priv, enum dpio_phy phy,
enum dpio_channel ch, bool override, unsigned int mask) enum dpio_channel ch, bool override, unsigned int mask)
{ {
enum pipe pipe = phy == DPIO_PHY0 ? PIPE_A : PIPE_C;
u32 reg, val, expected, actual; u32 reg, val, expected, actual;
/* /*
...@@ -1518,7 +1513,7 @@ static void assert_chv_phy_powergate(struct drm_i915_private *dev_priv, enum dpi ...@@ -1518,7 +1513,7 @@ static void assert_chv_phy_powergate(struct drm_i915_private *dev_priv, enum dpi
reg = _CHV_CMN_DW6_CH1; reg = _CHV_CMN_DW6_CH1;
vlv_dpio_get(dev_priv); vlv_dpio_get(dev_priv);
val = vlv_dpio_read(dev_priv, pipe, reg); val = vlv_dpio_read(dev_priv, phy, reg);
vlv_dpio_put(dev_priv); vlv_dpio_put(dev_priv);
/* /*
......
This diff is collapsed.
...@@ -227,9 +227,8 @@ static u32 vlv_dpio_phy_iosf_port(struct drm_i915_private *i915, enum dpio_phy p ...@@ -227,9 +227,8 @@ static u32 vlv_dpio_phy_iosf_port(struct drm_i915_private *i915, enum dpio_phy p
return IOSF_PORT_DPIO; return IOSF_PORT_DPIO;
} }
u32 vlv_dpio_read(struct drm_i915_private *i915, enum pipe pipe, int reg) u32 vlv_dpio_read(struct drm_i915_private *i915, enum dpio_phy phy, int reg)
{ {
enum dpio_phy phy = vlv_pipe_to_phy(pipe);
u32 port = vlv_dpio_phy_iosf_port(i915, phy); u32 port = vlv_dpio_phy_iosf_port(i915, phy);
u32 val = 0; u32 val = 0;
...@@ -240,16 +239,15 @@ u32 vlv_dpio_read(struct drm_i915_private *i915, enum pipe pipe, int reg) ...@@ -240,16 +239,15 @@ u32 vlv_dpio_read(struct drm_i915_private *i915, enum pipe pipe, int reg)
* so ideally we should check the register offset instead... * so ideally we should check the register offset instead...
*/ */
drm_WARN(&i915->drm, val == 0xffffffff, drm_WARN(&i915->drm, val == 0xffffffff,
"DPIO read pipe %c reg 0x%x == 0x%x\n", "DPIO PHY%d read reg 0x%x == 0x%x\n",
pipe_name(pipe), reg, val); phy, reg, val);
return val; return val;
} }
void vlv_dpio_write(struct drm_i915_private *i915, void vlv_dpio_write(struct drm_i915_private *i915,
enum pipe pipe, int reg, u32 val) enum dpio_phy phy, int reg, u32 val)
{ {
enum dpio_phy phy = vlv_pipe_to_phy(pipe);
u32 port = vlv_dpio_phy_iosf_port(i915, phy); u32 port = vlv_dpio_phy_iosf_port(i915, phy);
vlv_sideband_rw(i915, DPIO_DEVFN, port, SB_MWR_NP, reg, &val); vlv_sideband_rw(i915, DPIO_DEVFN, port, SB_MWR_NP, reg, &val);
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
#include "vlv_sideband_reg.h" #include "vlv_sideband_reg.h"
enum pipe; enum dpio_phy;
struct drm_i915_private; struct drm_i915_private;
enum { enum {
...@@ -75,9 +75,9 @@ static inline void vlv_dpio_get(struct drm_i915_private *i915) ...@@ -75,9 +75,9 @@ static inline void vlv_dpio_get(struct drm_i915_private *i915)
vlv_iosf_sb_get(i915, BIT(VLV_IOSF_SB_DPIO)); vlv_iosf_sb_get(i915, BIT(VLV_IOSF_SB_DPIO));
} }
u32 vlv_dpio_read(struct drm_i915_private *i915, enum pipe pipe, int reg); u32 vlv_dpio_read(struct drm_i915_private *i915, enum dpio_phy phy, int reg);
void vlv_dpio_write(struct drm_i915_private *i915, void vlv_dpio_write(struct drm_i915_private *i915,
enum pipe pipe, int reg, u32 val); enum dpio_phy phy, int reg, u32 val);
static inline void vlv_dpio_put(struct drm_i915_private *i915) static inline void vlv_dpio_put(struct drm_i915_private *i915)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment