]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/commitdiff
twl4030-gpio: beagle pull up/down init
authorDavid Brownell <dbrownell@users.sourceforge.net>
Tue, 30 Sep 2008 18:43:09 +0000 (21:43 +0300)
committerTony Lindgren <tony@atomide.com>
Wed, 1 Oct 2008 10:37:40 +0000 (13:37 +0300)
Better TWL init on Beagle:  use the setup() callback to
learn IRQ assignments; and configure pullups/pulldowns.

Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/mach-omap2/board-omap3beagle.c

index aa5e9a60bb63baa252f7fe7f6a95e90f8e59e226..98bdaf29f5403b486197c8275dd43de845fee98f 100644 (file)
@@ -114,15 +114,31 @@ static struct twl4030_usb_data beagle_usb_data = {
        .usb_mode       = T2_USB_MODE_ULPI,
 };
 
+static int beagle_twl_gpio_setup(struct device *dev,
+               unsigned gpio, unsigned ngpio)
+{
+       /* request_gpio(gpio + 0, "mmc0_cd");
+        * gpio_direction_input(gpio + 0);
+        */
+
+       gpio_request(gpio + 1, "EHCI_nOC");
+       gpio_direction_input(gpio + 1);
+
+       /* gpio + 18 + 0 == ledA, nEN_USB_PWR (out)
+        * gpio + 18 + 1 == ledB, PMU_STAT (out, a LED)
+        */
+
+       return 0;
+}
+
 static struct twl4030_gpio_platform_data beagle_gpio_data = {
        .gpio_base      = OMAP_MAX_GPIO_LINES,
        .irq_base       = TWL4030_GPIO_IRQ_BASE,
        .irq_end        = TWL4030_GPIO_IRQ_END,
-
-       /* REVISIT:  setup() should use twl gpio index
-        *  - 0 as MMC card detect,
-        *  - 1 as EHCI port overcurrent (active low)
-        */
+       .pullups        = BIT(1),
+       .pulldowns      = BIT(2) | BIT(6) | BIT(7) | BIT(8) | BIT(13)
+                               | BIT(15) | BIT(16) | BIT(17),
+       .setup          = beagle_twl_gpio_setup,
 };
 
 static struct twl4030_platform_data beagle_twldata = {