[ARM] tegra: add EHCI and UDC controllers to devices.c
authorGary King <gking@nvidia.com>
Wed, 28 Jul 2010 23:22:31 +0000 (16:22 -0700)
committerColin Cross <ccross@android.com>
Wed, 6 Oct 2010 23:27:19 +0000 (16:27 -0700)
update harmony and ventana to use the common UDC definition, rather
than using the current duplicated definitions

Change-Id: I2e3aca674ab35305a0c516bd22e044382280d05e
Signed-off-by: Gary King <gking@nvidia.com>
arch/arm/mach-tegra/board-harmony.c
arch/arm/mach-tegra/board-ventana.c
arch/arm/mach-tegra/devices.c
arch/arm/mach-tegra/devices.h

index ebf8362fd3a54f9ae3fbf8a6380f5800fb10af82..af66a67c848632de56c0d7ccff90bdd48d7ec072 100644 (file)
@@ -22,7 +22,6 @@
 #include <linux/mtd/mtd.h>
 #include <linux/mtd/partitions.h>
 #include <linux/dma-mapping.h>
-#include <linux/fsl_devices.h>
 #include <linux/pda_power.h>
 #include <linux/io.h>
 #include <linux/delay.h>
@@ -153,40 +152,6 @@ static struct platform_device debug_uart = {
        },
 };
 
-/* OTG gadget device */
-static u64 tegra_otg_dmamask = DMA_BIT_MASK(32);
-
-
-static struct resource tegra_otg_resources[] = {
-       [0] = {
-               .start  = TEGRA_USB_BASE,
-               .end    = TEGRA_USB_BASE + TEGRA_USB_SIZE - 1,
-               .flags  = IORESOURCE_MEM,
-       },
-       [1] = {
-               .start  = INT_USB,
-               .end    = INT_USB,
-               .flags  = IORESOURCE_IRQ,
-       },
-};
-
-static struct fsl_usb2_platform_data tegra_otg_pdata = {
-       .operating_mode = FSL_USB2_DR_DEVICE,
-       .phy_mode       = FSL_USB2_PHY_UTMI,
-};
-
-static struct platform_device tegra_otg = {
-       .name = "fsl-tegra-udc",
-       .id   = -1,
-       .dev  = {
-               .dma_mask               = &tegra_otg_dmamask,
-               .coherent_dma_mask      = 0xffffffff,
-               .platform_data = &tegra_otg_pdata,
-       },
-       .resource = tegra_otg_resources,
-       .num_resources = ARRAY_SIZE(tegra_otg_resources),
-};
-
 /* PDA power */
 static struct pda_power_pdata pda_power_pdata = {
 };
@@ -224,7 +189,7 @@ static struct platform_device tegra_gart_dev = {
 static struct platform_device *harmony_devices[] __initdata = {
        &debug_uart,
        &tegra_nand_device,
-       &tegra_otg,
+       &tegra_udc_device,
        &pda_power_device,
        &tegra_i2c_device1,
        &tegra_i2c_device2,
index eef18980947dd393bd8b0a51cc2a0d104533d0fe..d9440c6ac85de26958233f153b561d84fe9e5d96 100644 (file)
@@ -28,7 +28,6 @@
 #include <linux/i2c.h>
 #include <linux/pda_power.h>
 #include <linux/dma-mapping.h>
-#include <linux/fsl_devices.h>
 #include <linux/delay.h>
 
 #include <mach/iomap.h>
@@ -73,40 +72,6 @@ static __initdata struct tegra_clk_init_table ventana_clk_init_table[] = {
        { NULL,         NULL,           0,              0},
 };
 
-/* OTG gadget device */
-static u64 tegra_otg_dmamask = DMA_BIT_MASK(32);
-
-
-static struct resource tegra_otg_resources[] = {
-       [0] = {
-               .start  = TEGRA_USB_BASE,
-               .end    = TEGRA_USB_BASE + TEGRA_USB_SIZE - 1,
-               .flags  = IORESOURCE_MEM,
-       },
-       [1] = {
-               .start  = INT_USB,
-               .end    = INT_USB,
-               .flags  = IORESOURCE_IRQ,
-       },
-};
-
-static struct fsl_usb2_platform_data tegra_otg_pdata = {
-       .operating_mode = FSL_USB2_DR_DEVICE,
-       .phy_mode       = FSL_USB2_PHY_UTMI,
-};
-
-static struct platform_device tegra_otg = {
-       .name = "fsl-tegra-udc",
-       .id   = -1,
-       .dev  = {
-               .dma_mask               = &tegra_otg_dmamask,
-               .coherent_dma_mask      = 0xffffffff,
-               .platform_data = &tegra_otg_pdata,
-       },
-       .resource = tegra_otg_resources,
-       .num_resources = ARRAY_SIZE(tegra_otg_resources),
-};
-
 /* PDA power */
 static struct pda_power_pdata pda_power_pdata = {
 };
@@ -143,7 +108,7 @@ static struct platform_device tegra_gart_dev = {
 
 static struct platform_device *ventana_devices[] __initdata = {
        &debug_uart,
-       &tegra_otg,
+       &tegra_udc_device,
        &pda_power_device,
        &tegra_gart_dev,
 };
index 600b1b484efcf719e0420f3c6f54d6bef3d28d1f..3d17f0fc7de2593d58d3579404b09aa280ef8566 100644 (file)
@@ -21,6 +21,8 @@
 
 #include <linux/resource.h>
 #include <linux/platform_device.h>
+#include <linux/dma-mapping.h>
+#include <linux/fsl_devices.h>
 #include <mach/irqs.h>
 #include <mach/iomap.h>
 
@@ -311,3 +313,96 @@ struct platform_device tegra_w1_device = {
        .resource      = w1_resources,
        .num_resources = ARRAY_SIZE(w1_resources),
 };
+
+static struct resource tegra_usb1_resources[] = {
+       [0] = {
+               .start  = TEGRA_USB_BASE,
+               .end    = TEGRA_USB_BASE + TEGRA_USB_SIZE - 1,
+               .flags  = IORESOURCE_MEM,
+       },
+       [1] = {
+               .start  = INT_USB,
+               .end    = INT_USB,
+               .flags  = IORESOURCE_IRQ,
+       },
+};
+
+static struct resource tegra_usb2_resources[] = {
+       [0] = {
+               .start  = TEGRA_USB2_BASE,
+               .end    = TEGRA_USB2_BASE + TEGRA_USB2_SIZE - 1,
+               .flags  = IORESOURCE_MEM,
+       },
+       [1] = {
+               .start  = INT_USB2,
+               .end    = INT_USB2,
+               .flags  = IORESOURCE_IRQ,
+       },
+};
+
+static struct resource tegra_usb3_resources[] = {
+       [0] = {
+               .start  = TEGRA_USB3_BASE,
+               .end    = TEGRA_USB3_BASE + TEGRA_USB3_SIZE - 1,
+               .flags  = IORESOURCE_MEM,
+       },
+       [1] = {
+               .start  = INT_USB3,
+               .end    = INT_USB3,
+               .flags  = IORESOURCE_IRQ,
+       },
+};
+
+static u64 tegra_udc_dmamask = DMA_BIT_MASK(32);
+
+static struct fsl_usb2_platform_data tegra_udc_pdata = {
+       .operating_mode = FSL_USB2_DR_DEVICE,
+       .phy_mode       = FSL_USB2_PHY_UTMI,
+};
+
+struct platform_device tegra_udc_device = {
+       .name   = "fsl-tegra-udc",
+       .id     = -1,
+       .dev    = {
+               .dma_mask       = &tegra_udc_dmamask,
+               .coherent_dma_mask = DMA_BIT_MASK(32),
+               .platform_data  = &tegra_udc_pdata,
+       },
+       .resource = tegra_usb1_resources,
+       .num_resources = ARRAY_SIZE(tegra_usb1_resources),
+};
+
+static u64 tegra_ehci_dmamask = DMA_BIT_MASK(32);
+
+struct platform_device tegra_ehci1_device = {
+       .name   = "tegra-ehci",
+       .id     = 0,
+       .dev    = {
+               .dma_mask       = &tegra_ehci_dmamask,
+               .coherent_dma_mask = DMA_BIT_MASK(32),
+       },
+       .resource = tegra_usb1_resources,
+       .num_resources = ARRAY_SIZE(tegra_usb1_resources),
+};
+
+struct platform_device tegra_ehci2_device = {
+       .name   = "tegra-ehci",
+       .id     = 1,
+       .dev    = {
+               .dma_mask       = &tegra_ehci_dmamask,
+               .coherent_dma_mask = DMA_BIT_MASK(32),
+       },
+       .resource = tegra_usb2_resources,
+       .num_resources = ARRAY_SIZE(tegra_usb2_resources),
+};
+
+struct platform_device tegra_ehci3_device = {
+       .name   = "tegra-ehci",
+       .id     = 2,
+       .dev    = {
+               .dma_mask       = &tegra_ehci_dmamask,
+               .coherent_dma_mask = DMA_BIT_MASK(32),
+       },
+       .resource = tegra_usb3_resources,
+       .num_resources = ARRAY_SIZE(tegra_usb3_resources),
+};
index bbe95926842d3813ef9725ae3de7480984881937..b16042ce2c65accd192432798f35cfb9f33ed58b 100644 (file)
@@ -36,5 +36,9 @@ extern struct platform_device tegra_spi_device2;
 extern struct platform_device tegra_spi_device3;
 extern struct platform_device tegra_spi_device4;
 extern struct platform_device tegra_w1_device;
+extern struct platform_device tegra_udc_device;
+extern struct platform_device tegra_ehci1_device;
+extern struct platform_device tegra_ehci2_device;
+extern struct platform_device tegra_ehci3_device;
 
 #endif