pinctrl: aspeed: Allow disabling Port D and Port E loopback mode
authorRick Altherr <raltherr@google.com>
Wed, 15 Feb 2017 06:09:14 +0000 (22:09 -0800)
committerLinus Walleij <linus.walleij@linaro.org>
Tue, 14 Mar 2017 13:42:22 +0000 (14:42 +0100)
commitc825676b0823fd43a4d08bf865f81bb188b51db1
treeb4f2efe40ccaa2ba6c41374d8e463d437cce596a
parent3818e4a7678ea70508b6b6e72a4cbf445e1e7dfa
pinctrl: aspeed: Allow disabling Port D and Port E loopback mode

Port D and port E GPIO loopback modes are commonly enabled via hardware
straps for use with front-panel buttons.  When the BMC is powered
off or fails to boot, the front-panel buttons are directly connected to
the host chipset via the loopback to allow direct power-on and reset
control. Once the BMC has booted, the loopback mode must be disabled for
the BMC to take over control of host power-on and reset.

Disabling these loopback modes requires writing to the hardware strap
register which violates the current design of assuming the system
designer chose the strap settings for a specific reason and they should
be treated as read-only. Only the two bits of the strap register related
to these loopback modes are allowed to be written and comments have been
added to explain why.

Signed-off-by: Rick Altherr <raltherr@google.com>
Acked-by: Joel Stanley <joel@jms.id.au>
Reviewed-by: Andrew Jeffery <andrew@aj.id.au>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/aspeed/pinctrl-aspeed.c