pinctrl: pinctrl-single: Make sure we do not change bits outside of mask
authorPeter Ujfalusi <peter.ujfalusi@ti.com>
Wed, 5 Sep 2012 09:01:57 +0000 (12:01 +0300)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 10 Sep 2012 07:14:03 +0000 (09:14 +0200)
Use the pcs->fmask to make sure that the value is not changing (setting)
bits in areas where it should not.
To avoid situations like this:

pmx_dummy: pinmux@4a100040 {
compatible = "pinctrl-single";
reg = <0x4a100040 0x0196>;
#address-cells = <1>;
#size-cells = <0>;
pinctrl-single,register-width = <16>;
pinctrl-single,function-mask = <0x00ff>;
};

&pmx_dummy {
pinctrl-names = "default";
pinctrl-0 = <&board_pins>;

board_pins: pinmux_board_pins {
pinctrl-single,pins = <
0x6c 0xf0f
0x6e 0x10f
0x70 0x23f
0x72 0xa5f
>;
};
};

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Acked-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/pinctrl-single.c

index 76a4260f20f3dc458b3aa77b71f0d468728d9833..35086310b81d9482b815a3b690879e96ca2308ad 100644 (file)
@@ -337,7 +337,7 @@ static int pcs_enable(struct pinctrl_dev *pctldev, unsigned fselector,
                vals = &func->vals[i];
                val = pcs->read(vals->reg);
                val &= ~pcs->fmask;
-               val |= vals->val;
+               val |= (vals->val & pcs->fmask);
                pcs->write(val, vals->reg);
        }