ARM: dts: Add mask-tpm-reset node in exynos5800-peach-pi
authorVikas Sajjan <vikas.sajjan@samsung.com>
Tue, 15 Jul 2014 17:38:44 +0000 (02:38 +0900)
committerKukjin Kim <kgene.kim@samsung.com>
Tue, 15 Jul 2014 17:39:57 +0000 (02:39 +0900)
The mask-tpm-reset GPIO is used by the kernel to prevent the TPM from
being reset across sleep/wake.  If we don't set it to anything then
the TPM will be reset.  U-Boot will detect this as invalid
and will reset the system on resume time. This GPIO can always be low
and not hurt anything.  It will get pulled back high again during a
normal warm reset when it will default back to an input.

To properly preserve the TPM state across suspend/resume and to make
the chrome U-Boot happy, properly set the GPIO to mask the
reset to the TPM.

Signed-off-by: Vikas Sajjan <vikas.sajjan@samsung.com>
Reviewed-by: Doug Anderson <dianders@chromium.org>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
arch/arm/boot/dts/exynos5800-peach-pi.dts

index 28f2a251aee54b26e3968c6c593269dfe9f2500d..0bc97d94474c6f7a0fa23a4b5d354587b63a25ad 100644 (file)
 
 
 &pinctrl_0 {
+       pinctrl-names = "default";
+       pinctrl-0 = <&mask_tpm_reset>;
+
        max98091_irq: max98091-irq {
                samsung,pins = "gpx0-2";
                samsung,pin-function = <0>;
                samsung,pin-drv = <0>;
        };
 
+       /* We need GPX0_6 to be low at sleep time; just keep it low always */
+       mask_tpm_reset: mask-tpm-reset {
+               samsung,pins = "gpx0-6";
+               samsung,pin-function = <1>;
+               samsung,pin-pud = <0>;
+               samsung,pin-drv = <0>;
+               samsung,pin-val = <0>;
+       };
+
        tpm_irq: tpm-irq {
                samsung,pins = "gpx1-0";
                samsung,pin-function = <0>;