提交 2b58417f 编写于 作者: V Ville Syrjälä

drm/i915: Clean up some cdclk switch statements

Redo some switch statements in the cdclk code to use a common
fall through for the default case. Makes everything look a bit
more uniform

Cc: Mika Kahola <mika.kahola@intel.com>
Cc: Manasi Navare <manasi.d.navare@intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: NMika Kahola <mika.kahola@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171024095216.1638-2-ville.syrjala@linux.intel.com
上级 b40c88fd
...@@ -681,6 +681,13 @@ static void bdw_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -681,6 +681,13 @@ static void bdw_set_cdclk(struct drm_i915_private *dev_priv,
val &= ~LCPLL_CLK_FREQ_MASK; val &= ~LCPLL_CLK_FREQ_MASK;
switch (cdclk) { switch (cdclk) {
default:
MISSING_CASE(cdclk);
/* fall through */
case 337500:
val |= LCPLL_CLK_FREQ_337_5_BDW;
data = 2;
break;
case 450000: case 450000:
val |= LCPLL_CLK_FREQ_450; val |= LCPLL_CLK_FREQ_450;
data = 0; data = 0;
...@@ -689,17 +696,10 @@ static void bdw_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -689,17 +696,10 @@ static void bdw_set_cdclk(struct drm_i915_private *dev_priv,
val |= LCPLL_CLK_FREQ_54O_BDW; val |= LCPLL_CLK_FREQ_54O_BDW;
data = 1; data = 1;
break; break;
case 337500:
val |= LCPLL_CLK_FREQ_337_5_BDW;
data = 2;
break;
case 675000: case 675000:
val |= LCPLL_CLK_FREQ_675_BDW; val |= LCPLL_CLK_FREQ_675_BDW;
data = 3; data = 3;
break; break;
default:
WARN(1, "invalid cdclk frequency\n");
return;
} }
I915_WRITE(LCPLL_CTL, val); I915_WRITE(LCPLL_CTL, val);
...@@ -926,8 +926,6 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -926,8 +926,6 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv,
u32 freq_select, pcu_ack; u32 freq_select, pcu_ack;
int ret; int ret;
WARN_ON((cdclk == 24000) != (vco == 0));
mutex_lock(&dev_priv->pcu_lock); mutex_lock(&dev_priv->pcu_lock);
ret = skl_pcode_request(dev_priv, SKL_PCODE_CDCLK_CONTROL, ret = skl_pcode_request(dev_priv, SKL_PCODE_CDCLK_CONTROL,
SKL_CDCLK_PREPARE_FOR_CHANGE, SKL_CDCLK_PREPARE_FOR_CHANGE,
...@@ -942,6 +940,15 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -942,6 +940,15 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv,
/* set CDCLK_CTL */ /* set CDCLK_CTL */
switch (cdclk) { switch (cdclk) {
default:
WARN_ON(cdclk != dev_priv->cdclk.hw.ref);
WARN_ON(vco != 0);
/* fall through */
case 308571:
case 337500:
freq_select = CDCLK_FREQ_337_308;
pcu_ack = 0;
break;
case 450000: case 450000:
case 432000: case 432000:
freq_select = CDCLK_FREQ_450_432; freq_select = CDCLK_FREQ_450_432;
...@@ -951,12 +958,6 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -951,12 +958,6 @@ static void skl_set_cdclk(struct drm_i915_private *dev_priv,
freq_select = CDCLK_FREQ_540; freq_select = CDCLK_FREQ_540;
pcu_ack = 2; pcu_ack = 2;
break; break;
case 308571:
case 337500:
default:
freq_select = CDCLK_FREQ_337_308;
pcu_ack = 0;
break;
case 617143: case 617143:
case 675000: case 675000:
freq_select = CDCLK_FREQ_675_617; freq_select = CDCLK_FREQ_675_617;
...@@ -1110,6 +1111,7 @@ static int bxt_de_pll_vco(struct drm_i915_private *dev_priv, int cdclk) ...@@ -1110,6 +1111,7 @@ static int bxt_de_pll_vco(struct drm_i915_private *dev_priv, int cdclk)
switch (cdclk) { switch (cdclk) {
default: default:
MISSING_CASE(cdclk); MISSING_CASE(cdclk);
/* fall through */
case 144000: case 144000:
case 288000: case 288000:
case 384000: case 384000:
...@@ -1134,6 +1136,7 @@ static int glk_de_pll_vco(struct drm_i915_private *dev_priv, int cdclk) ...@@ -1134,6 +1136,7 @@ static int glk_de_pll_vco(struct drm_i915_private *dev_priv, int cdclk)
switch (cdclk) { switch (cdclk) {
default: default:
MISSING_CASE(cdclk); MISSING_CASE(cdclk);
/* fall through */
case 79200: case 79200:
case 158400: case 158400:
case 316800: case 316800:
...@@ -1246,24 +1249,22 @@ static void bxt_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -1246,24 +1249,22 @@ static void bxt_set_cdclk(struct drm_i915_private *dev_priv,
/* cdclk = vco / 2 / div{1,1.5,2,4} */ /* cdclk = vco / 2 / div{1,1.5,2,4} */
switch (DIV_ROUND_CLOSEST(vco, cdclk)) { switch (DIV_ROUND_CLOSEST(vco, cdclk)) {
case 8: default:
divider = BXT_CDCLK_CD2X_DIV_SEL_4; WARN_ON(cdclk != dev_priv->cdclk.hw.ref);
break; WARN_ON(vco != 0);
case 4: /* fall through */
divider = BXT_CDCLK_CD2X_DIV_SEL_2; case 2:
divider = BXT_CDCLK_CD2X_DIV_SEL_1;
break; break;
case 3: case 3:
WARN(IS_GEMINILAKE(dev_priv), "Unsupported divider\n"); WARN(IS_GEMINILAKE(dev_priv), "Unsupported divider\n");
divider = BXT_CDCLK_CD2X_DIV_SEL_1_5; divider = BXT_CDCLK_CD2X_DIV_SEL_1_5;
break; break;
case 2: case 4:
divider = BXT_CDCLK_CD2X_DIV_SEL_1; divider = BXT_CDCLK_CD2X_DIV_SEL_2;
break; break;
default: case 8:
WARN_ON(cdclk != dev_priv->cdclk.hw.ref); divider = BXT_CDCLK_CD2X_DIV_SEL_4;
WARN_ON(vco != 0);
divider = BXT_CDCLK_CD2X_DIV_SEL_1;
break; break;
} }
...@@ -1532,18 +1533,16 @@ static void cnl_set_cdclk(struct drm_i915_private *dev_priv, ...@@ -1532,18 +1533,16 @@ static void cnl_set_cdclk(struct drm_i915_private *dev_priv,
/* cdclk = vco / 2 / div{1,2} */ /* cdclk = vco / 2 / div{1,2} */
switch (DIV_ROUND_CLOSEST(vco, cdclk)) { switch (DIV_ROUND_CLOSEST(vco, cdclk)) {
case 4:
divider = BXT_CDCLK_CD2X_DIV_SEL_2;
break;
case 2:
divider = BXT_CDCLK_CD2X_DIV_SEL_1;
break;
default: default:
WARN_ON(cdclk != dev_priv->cdclk.hw.ref); WARN_ON(cdclk != dev_priv->cdclk.hw.ref);
WARN_ON(vco != 0); WARN_ON(vco != 0);
/* fall through */
case 2:
divider = BXT_CDCLK_CD2X_DIV_SEL_1; divider = BXT_CDCLK_CD2X_DIV_SEL_1;
break; break;
case 4:
divider = BXT_CDCLK_CD2X_DIV_SEL_2;
break;
} }
switch (cdclk) { switch (cdclk) {
...@@ -1592,6 +1591,7 @@ static int cnl_cdclk_pll_vco(struct drm_i915_private *dev_priv, int cdclk) ...@@ -1592,6 +1591,7 @@ static int cnl_cdclk_pll_vco(struct drm_i915_private *dev_priv, int cdclk)
switch (cdclk) { switch (cdclk) {
default: default:
MISSING_CASE(cdclk); MISSING_CASE(cdclk);
/* fall through */
case 168000: case 168000:
case 336000: case 336000:
ratio = dev_priv->cdclk.hw.ref == 19200 ? 35 : 28; ratio = dev_priv->cdclk.hw.ref == 19200 ? 35 : 28;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册