Commit 1bea6afb authored by Light Hsieh's avatar Light Hsieh Committed by Linus Walleij

pinctrl: mediatek: Refine mtk_pinconf_get()

Correct cases for PIN_CONFIG_SLEW_RATE, PIN_CONFIG_INPUT_SCHMITT_ENABLE,
and PIN_CONFIG_OUTPUT_ENABLE -
Use variable ret to receive value in mtk_hw_get_value() (instead of
variable val) since pinconf_to_config_packed() at end of this function
use variable ret to pack config value.
Signed-off-by: default avatarLight Hsieh <light.hsieh@mediatek.com>
Link: https://lore.kernel.org/r/1579675994-7001-4-git-send-email-light.hsieh@mediatek.comAcked-by: default avatarSean Wang <sean.wang@kernel.org>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 3599cc52
...@@ -78,7 +78,7 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev, ...@@ -78,7 +78,7 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev,
{ {
struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev); struct mtk_pinctrl *hw = pinctrl_dev_get_drvdata(pctldev);
u32 param = pinconf_to_config_param(*config); u32 param = pinconf_to_config_param(*config);
int val, val2, err, reg, ret = 1; int err, reg, ret = 1;
const struct mtk_pin_desc *desc; const struct mtk_pin_desc *desc;
if (pin >= hw->soc->npins) { if (pin >= hw->soc->npins) {
...@@ -107,17 +107,11 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev, ...@@ -107,17 +107,11 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev,
err = -ENOTSUPP; err = -ENOTSUPP;
break; break;
case PIN_CONFIG_SLEW_RATE: case PIN_CONFIG_SLEW_RATE:
err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SR, &val); err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SR, &ret);
if (err)
return err;
if (!val)
return -EINVAL;
break; break;
case PIN_CONFIG_INPUT_ENABLE: case PIN_CONFIG_INPUT_ENABLE:
case PIN_CONFIG_OUTPUT_ENABLE: case PIN_CONFIG_OUTPUT_ENABLE:
err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &val); err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &ret);
if (err) if (err)
goto out; goto out;
/* CONFIG Current direction return value /* CONFIG Current direction return value
...@@ -128,20 +122,22 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev, ...@@ -128,20 +122,22 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev,
* input 1 (= reverse HW value) * input 1 (= reverse HW value)
*/ */
if (param == PIN_CONFIG_INPUT_ENABLE) if (param == PIN_CONFIG_INPUT_ENABLE)
val = !val; ret = !ret;
break; break;
case PIN_CONFIG_INPUT_SCHMITT_ENABLE: case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &val); err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_DIR, &ret);
if (err) if (err)
return err; goto out;
/* return error when in output mode
err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SMT, &val2); * because schmitt trigger only work in input mode
if (err) */
return err; if (ret) {
err = -EINVAL;
goto out;
}
if (val || !val2) err = mtk_hw_get_value(hw, desc, PINCTRL_PIN_REG_SMT, &ret);
return -EINVAL;
break; break;
case PIN_CONFIG_DRIVE_STRENGTH: case PIN_CONFIG_DRIVE_STRENGTH:
...@@ -154,13 +150,7 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev, ...@@ -154,13 +150,7 @@ static int mtk_pinconf_get(struct pinctrl_dev *pctldev,
case MTK_PIN_CONFIG_RDSEL: case MTK_PIN_CONFIG_RDSEL:
reg = (param == MTK_PIN_CONFIG_TDSEL) ? reg = (param == MTK_PIN_CONFIG_TDSEL) ?
PINCTRL_PIN_REG_TDSEL : PINCTRL_PIN_REG_RDSEL; PINCTRL_PIN_REG_TDSEL : PINCTRL_PIN_REG_RDSEL;
err = mtk_hw_get_value(hw, desc, reg, &ret);
err = mtk_hw_get_value(hw, desc, reg, &val);
if (err)
return err;
ret = val;
break; break;
case MTK_PIN_CONFIG_PU_ADV: case MTK_PIN_CONFIG_PU_ADV:
case MTK_PIN_CONFIG_PD_ADV: case MTK_PIN_CONFIG_PD_ADV:
......
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