Message ID | 20181113105536.6459-1-jbrunet@baylibre.com |
---|---|
State | Accepted |
Commit | 614b1868a125a0ba24be08f3a7fa832ddcde6bca |
Headers | show |
Series | pinctrl: meson: fix pull enable register calculation | expand |
On 13/11/2018 11:55, Jerome Brunet wrote: > We just changed the code so we apply bias disable on the correct > register but forgot to align the register calculation. The result > is that we apply the change on the correct register, but possibly > at the incorrect offset/bit > > This went undetected because offsets tends to be the same between > REG_PULL and REG_PULLEN for a given pin the EE controller. This > is not true for the AO controller. > > Fixes: e39f9dd8206a ("pinctrl: meson: fix pinconf bias disable") > Signed-off-by: Jerome Brunet <jbrunet@baylibre.com> > --- > drivers/pinctrl/meson/pinctrl-meson.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/pinctrl/meson/pinctrl-meson.c b/drivers/pinctrl/meson/pinctrl-meson.c > index 53d449076dee..ea87d739f534 100644 > --- a/drivers/pinctrl/meson/pinctrl-meson.c > +++ b/drivers/pinctrl/meson/pinctrl-meson.c > @@ -191,7 +191,8 @@ static int meson_pinconf_set(struct pinctrl_dev *pcdev, unsigned int pin, > case PIN_CONFIG_BIAS_DISABLE: > dev_dbg(pc->dev, "pin %u: disable bias\n", pin); > > - meson_calc_reg_and_bit(bank, pin, REG_PULL, ®, &bit); > + meson_calc_reg_and_bit(bank, pin, REG_PULLEN, ®, > + &bit); > ret = regmap_update_bits(pc->reg_pullen, reg, > BIT(bit), 0); > if (ret) > I saw it aswell, Acked-by: Neil Armstrong <narmstrong@baylibre.com>
On Tue, Nov 13, 2018 at 11:55 AM Jerome Brunet <jbrunet@baylibre.com> wrote: > We just changed the code so we apply bias disable on the correct > register but forgot to align the register calculation. The result > is that we apply the change on the correct register, but possibly > at the incorrect offset/bit > > This went undetected because offsets tends to be the same between > REG_PULL and REG_PULLEN for a given pin the EE controller. This > is not true for the AO controller. > > Fixes: e39f9dd8206a ("pinctrl: meson: fix pinconf bias disable") > Signed-off-by: Jerome Brunet <jbrunet@baylibre.com> Patch applied for fixes. Yours, Linus Walleij
diff --git a/drivers/pinctrl/meson/pinctrl-meson.c b/drivers/pinctrl/meson/pinctrl-meson.c index 53d449076dee..ea87d739f534 100644 --- a/drivers/pinctrl/meson/pinctrl-meson.c +++ b/drivers/pinctrl/meson/pinctrl-meson.c @@ -191,7 +191,8 @@ static int meson_pinconf_set(struct pinctrl_dev *pcdev, unsigned int pin, case PIN_CONFIG_BIAS_DISABLE: dev_dbg(pc->dev, "pin %u: disable bias\n", pin); - meson_calc_reg_and_bit(bank, pin, REG_PULL, ®, &bit); + meson_calc_reg_and_bit(bank, pin, REG_PULLEN, ®, + &bit); ret = regmap_update_bits(pc->reg_pullen, reg, BIT(bit), 0); if (ret)
We just changed the code so we apply bias disable on the correct register but forgot to align the register calculation. The result is that we apply the change on the correct register, but possibly at the incorrect offset/bit This went undetected because offsets tends to be the same between REG_PULL and REG_PULLEN for a given pin the EE controller. This is not true for the AO controller. Fixes: e39f9dd8206a ("pinctrl: meson: fix pinconf bias disable") Signed-off-by: Jerome Brunet <jbrunet@baylibre.com> --- drivers/pinctrl/meson/pinctrl-meson.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) -- 2.19.1