Commit 133dce06 authored by Dmitry Eremin-Solenikov's avatar Dmitry Eremin-Solenikov Committed by Eric Miao

ARM: pxa/eseries: switch to using gpio-vbus transceiver

Switch from handling gpio-vbus in pxa25x_udc to using standard gpio-vbus
tranceiver.
Signed-off-by: default avatarDmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Cc: Ian Molton <spyro@f2s.com>
Signed-off-by: default avatarEric Miao <eric.y.miao@gmail.com>
parent ccc46e29
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include <linux/mfd/t7l66xb.h> #include <linux/mfd/t7l66xb.h>
#include <linux/mtd/nand.h> #include <linux/mtd/nand.h>
#include <linux/mtd/partitions.h> #include <linux/mtd/partitions.h>
#include <linux/usb/gpio_vbus.h>
#include <video/w100fb.h> #include <video/w100fb.h>
...@@ -51,12 +52,20 @@ void __init eseries_fixup(struct machine_desc *desc, ...@@ -51,12 +52,20 @@ void __init eseries_fixup(struct machine_desc *desc,
mi->bank[0].size = (64*1024*1024); mi->bank[0].size = (64*1024*1024);
} }
struct pxa2xx_udc_mach_info e7xx_udc_mach_info = { struct gpio_vbus_mach_info e7xx_udc_info = {
.gpio_vbus = GPIO_E7XX_USB_DISC, .gpio_vbus = GPIO_E7XX_USB_DISC,
.gpio_pullup = GPIO_E7XX_USB_PULLUP, .gpio_pullup = GPIO_E7XX_USB_PULLUP,
.gpio_pullup_inverted = 1 .gpio_pullup_inverted = 1
}; };
static struct platform_device e7xx_gpio_vbus = {
.name = "gpio-vbus",
.id = -1,
.dev = {
.platform_data = &e7xx_udc_info,
},
};
struct pxaficp_platform_data e7xx_ficp_platform_data = { struct pxaficp_platform_data e7xx_ficp_platform_data = {
.gpio_pwdown = GPIO_E7XX_IR_OFF, .gpio_pwdown = GPIO_E7XX_IR_OFF,
.transceiver_cap = IR_SIRMODE | IR_OFF, .transceiver_cap = IR_SIRMODE | IR_OFF,
...@@ -165,6 +174,7 @@ static struct platform_device e330_tc6387xb_device = { ...@@ -165,6 +174,7 @@ static struct platform_device e330_tc6387xb_device = {
static struct platform_device *e330_devices[] __initdata = { static struct platform_device *e330_devices[] __initdata = {
&e330_tc6387xb_device, &e330_tc6387xb_device,
&e7xx_gpio_vbus,
}; };
static void __init e330_init(void) static void __init e330_init(void)
...@@ -175,7 +185,6 @@ static void __init e330_init(void) ...@@ -175,7 +185,6 @@ static void __init e330_init(void)
eseries_register_clks(); eseries_register_clks();
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
platform_add_devices(ARRAY_AND_SIZE(e330_devices)); platform_add_devices(ARRAY_AND_SIZE(e330_devices));
pxa_set_udc_info(&e7xx_udc_mach_info);
} }
MACHINE_START(E330, "Toshiba e330") MACHINE_START(E330, "Toshiba e330")
...@@ -214,6 +223,7 @@ static struct platform_device e350_t7l66xb_device = { ...@@ -214,6 +223,7 @@ static struct platform_device e350_t7l66xb_device = {
static struct platform_device *e350_devices[] __initdata = { static struct platform_device *e350_devices[] __initdata = {
&e350_t7l66xb_device, &e350_t7l66xb_device,
&e7xx_gpio_vbus,
}; };
static void __init e350_init(void) static void __init e350_init(void)
...@@ -224,7 +234,6 @@ static void __init e350_init(void) ...@@ -224,7 +234,6 @@ static void __init e350_init(void)
eseries_register_clks(); eseries_register_clks();
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
platform_add_devices(ARRAY_AND_SIZE(e350_devices)); platform_add_devices(ARRAY_AND_SIZE(e350_devices));
pxa_set_udc_info(&e7xx_udc_mach_info);
} }
MACHINE_START(E350, "Toshiba e350") MACHINE_START(E350, "Toshiba e350")
...@@ -333,6 +342,7 @@ static struct platform_device e400_t7l66xb_device = { ...@@ -333,6 +342,7 @@ static struct platform_device e400_t7l66xb_device = {
static struct platform_device *e400_devices[] __initdata = { static struct platform_device *e400_devices[] __initdata = {
&e400_t7l66xb_device, &e400_t7l66xb_device,
&e7xx_gpio_vbus,
}; };
static void __init e400_init(void) static void __init e400_init(void)
...@@ -346,7 +356,6 @@ static void __init e400_init(void) ...@@ -346,7 +356,6 @@ static void __init e400_init(void)
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
pxa_set_fb_info(NULL, &e400_pxafb_mach_info); pxa_set_fb_info(NULL, &e400_pxafb_mach_info);
platform_add_devices(ARRAY_AND_SIZE(e400_devices)); platform_add_devices(ARRAY_AND_SIZE(e400_devices));
pxa_set_udc_info(&e7xx_udc_mach_info);
} }
MACHINE_START(E400, "Toshiba e400") MACHINE_START(E400, "Toshiba e400")
...@@ -519,6 +528,7 @@ static struct platform_device e740_t7l66xb_device = { ...@@ -519,6 +528,7 @@ static struct platform_device e740_t7l66xb_device = {
static struct platform_device *e740_devices[] __initdata = { static struct platform_device *e740_devices[] __initdata = {
&e740_fb_device, &e740_fb_device,
&e740_t7l66xb_device, &e740_t7l66xb_device,
&e7xx_gpio_vbus,
}; };
static void __init e740_init(void) static void __init e740_init(void)
...@@ -532,7 +542,6 @@ static void __init e740_init(void) ...@@ -532,7 +542,6 @@ static void __init e740_init(void)
"UDCCLK", &pxa25x_device_udc.dev), "UDCCLK", &pxa25x_device_udc.dev),
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
platform_add_devices(ARRAY_AND_SIZE(e740_devices)); platform_add_devices(ARRAY_AND_SIZE(e740_devices));
pxa_set_udc_info(&e7xx_udc_mach_info);
pxa_set_ac97_info(NULL); pxa_set_ac97_info(NULL);
pxa_set_ficp_info(&e7xx_ficp_platform_data); pxa_set_ficp_info(&e7xx_ficp_platform_data);
} }
...@@ -711,6 +720,7 @@ static struct platform_device e750_tc6393xb_device = { ...@@ -711,6 +720,7 @@ static struct platform_device e750_tc6393xb_device = {
static struct platform_device *e750_devices[] __initdata = { static struct platform_device *e750_devices[] __initdata = {
&e750_fb_device, &e750_fb_device,
&e750_tc6393xb_device, &e750_tc6393xb_device,
&e7xx_gpio_vbus,
}; };
static void __init e750_init(void) static void __init e750_init(void)
...@@ -723,7 +733,6 @@ static void __init e750_init(void) ...@@ -723,7 +733,6 @@ static void __init e750_init(void)
"GPIO11_CLK", NULL), "GPIO11_CLK", NULL),
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
platform_add_devices(ARRAY_AND_SIZE(e750_devices)); platform_add_devices(ARRAY_AND_SIZE(e750_devices));
pxa_set_udc_info(&e7xx_udc_mach_info);
pxa_set_ac97_info(NULL); pxa_set_ac97_info(NULL);
pxa_set_ficp_info(&e7xx_ficp_platform_data); pxa_set_ficp_info(&e7xx_ficp_platform_data);
} }
...@@ -873,12 +882,21 @@ static struct platform_device e800_fb_device = { ...@@ -873,12 +882,21 @@ static struct platform_device e800_fb_device = {
/* --------------------------- UDC definitions --------------------------- */ /* --------------------------- UDC definitions --------------------------- */
static struct pxa2xx_udc_mach_info e800_udc_mach_info = { static struct gpio_vbus_mach_info e800_udc_info = {
.gpio_vbus = GPIO_E800_USB_DISC, .gpio_vbus = GPIO_E800_USB_DISC,
.gpio_pullup = GPIO_E800_USB_PULLUP, .gpio_pullup = GPIO_E800_USB_PULLUP,
.gpio_pullup_inverted = 1 .gpio_pullup_inverted = 1
}; };
static struct platform_device e800_gpio_vbus = {
.name = "gpio-vbus",
.id = -1,
.dev = {
.platform_data = &e800_udc_info,
},
};
/* ----------------- e800 tc6393xb parameters ------------------ */ /* ----------------- e800 tc6393xb parameters ------------------ */
static struct tc6393xb_platform_data e800_tc6393xb_info = { static struct tc6393xb_platform_data e800_tc6393xb_info = {
...@@ -907,6 +925,7 @@ static struct platform_device e800_tc6393xb_device = { ...@@ -907,6 +925,7 @@ static struct platform_device e800_tc6393xb_device = {
static struct platform_device *e800_devices[] __initdata = { static struct platform_device *e800_devices[] __initdata = {
&e800_fb_device, &e800_fb_device,
&e800_tc6393xb_device, &e800_tc6393xb_device,
&e800_gpio_vbus,
}; };
static void __init e800_init(void) static void __init e800_init(void)
...@@ -919,7 +938,6 @@ static void __init e800_init(void) ...@@ -919,7 +938,6 @@ static void __init e800_init(void)
"GPIO11_CLK", NULL), "GPIO11_CLK", NULL),
eseries_get_tmio_gpios(); eseries_get_tmio_gpios();
platform_add_devices(ARRAY_AND_SIZE(e800_devices)); platform_add_devices(ARRAY_AND_SIZE(e800_devices));
pxa_set_udc_info(&e800_udc_mach_info);
pxa_set_ac97_info(NULL); pxa_set_ac97_info(NULL);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment