diff options
author | attilio <attilio@FreeBSD.org> | 2013-02-27 18:17:34 +0000 |
---|---|---|
committer | attilio <attilio@FreeBSD.org> | 2013-02-27 18:17:34 +0000 |
commit | 52c57fbbdb554a7ce0cdbb6bf27051ef70834bdf (patch) | |
tree | d0908474209a17865e044675940a2f62f9ff2493 /sys/arm | |
parent | c74a3afc6a5d7d1ced989c36d4ba0a7d2bbc43b9 (diff) | |
download | FreeBSD-src-52c57fbbdb554a7ce0cdbb6bf27051ef70834bdf.zip FreeBSD-src-52c57fbbdb554a7ce0cdbb6bf27051ef70834bdf.tar.gz |
MFC
Diffstat (limited to 'sys/arm')
-rw-r--r-- | sys/arm/ti/ti_gpio.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/sys/arm/ti/ti_gpio.c b/sys/arm/ti/ti_gpio.c index 58de516..4edb10e 100644 --- a/sys/arm/ti/ti_gpio.c +++ b/sys/arm/ti/ti_gpio.c @@ -653,6 +653,9 @@ ti_gpio_attach(device_t dev) struct ti_gpio_softc *sc = device_get_softc(dev); unsigned int i; int err = 0; + int pin; + uint32_t flags; + uint32_t reg_oe; sc->sc_dev = dev; @@ -720,6 +723,17 @@ ti_gpio_attach(device_t dev) /* Disable interrupts for all pins */ ti_gpio_write_4(sc, i, TI_GPIO_CLEARIRQENABLE1, 0xffffffff); ti_gpio_write_4(sc, i, TI_GPIO_CLEARIRQENABLE2, 0xffffffff); + + /* Init OE register based on pads configuration */ + reg_oe = 0xffffffff; + for (pin = 0; pin < 32; pin++) { + ti_scm_padconf_get_gpioflags( + PINS_PER_BANK*i + pin, &flags); + if (flags & GPIO_PIN_OUTPUT) + reg_oe &= ~(1U << pin); + } + + ti_gpio_write_4(sc, i, TI_GPIO_OE, reg_oe); } } |