]> git.baikalelectronics.ru Git - kernel.git/commit
pinctrl: sunxi: Support I/O bias voltage setting on A80
authorChen-Yu Tsai <wens@csie.org>
Wed, 6 Feb 2019 03:32:31 +0000 (11:32 +0800)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 11 Feb 2019 08:20:58 +0000 (09:20 +0100)
commit6d38e98937b1c58294254a12bfa719ca0f8a12a4
treea88beca2278e3c3c313af238af54aa9bd37b669b
parente34381318ab0e221818a8b9b3db6be0f4a27bdc7
pinctrl: sunxi: Support I/O bias voltage setting on A80

The A80 SoC has configuration registers for I/O bias voltage. Incorrect
settings would make the affected peripherals inoperable in some cases,
such as Ethernet RGMII signals biased at 2.5V with the settings still
at 3.3V. However low speed signals such as MDIO on the same group of
pins seem to be unaffected.

Previously there was no way to know what the actual voltage used was,
short of hard-coding a value in the device tree. With the new pin bank
regulator supply support in place, the driver can now query the
regulator for its voltage, and if it's valid (as opposed to being the
dummy regulator), set the bias voltage setting accordingly.

Add a quirk to denote the presence of the configuration registers, and
a function to set the correct setting based on the voltage read back
from the regulator.

This is only done when the regulator is first acquired and enabled.
While it would be nice to have a notifier on the regulator so that when
the voltage changes, the driver can update the setting, in practice no
board currently supports dynamic changing of the I/O voltages.

Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Acked-by: Maxime Ripard <maxime.ripard@bootlin.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/sunxi/pinctrl-sun9i-a80-r.c
drivers/pinctrl/sunxi/pinctrl-sun9i-a80.c
drivers/pinctrl/sunxi/pinctrl-sunxi.c
drivers/pinctrl/sunxi/pinctrl-sunxi.h