diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-01-07 16:16:28 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-01-07 16:16:28 -0500 |
commit | 3e5b08cbbf78bedd316904ab0cf3b27119433ee5 (patch) | |
tree | 0365745c1b7441c1868551c024410c829c3accc6 /arch/arm/mach-omap2/board-4430sdp.c | |
parent | da40d036fd716f0efb2917076220814b1e927ae1 (diff) | |
parent | 2af10844eb6ed104f9505bf3a7ba3ceb02264f31 (diff) |
Merge branch 'usb-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb-2.6
* 'usb-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb-2.6: (144 commits)
USB: add support for Dream Cheeky DL100B Webmail Notifier (1d34:0004)
USB: serial: ftdi_sio: add support for TIOCSERGETLSR
USB: ehci-mxc: Setup portsc register prior to accessing OTG viewport
USB: atmel_usba_udc: fix freeing irq in usba_udc_remove()
usb: ehci-omap: fix tll channel enable mask
usb: ohci-omap3: fix trivial typo
USB: gadget: ci13xxx: don't assume that PAGE_SIZE is 4096
USB: gadget: ci13xxx: fix complete() callback for no_interrupt rq's
USB: gadget: update ci13xxx to work with g_ether
USB: gadgets: ci13xxx: fix probing of compiled-in gadget drivers
Revert "USB: musb: pm: don't rely fully on clock support"
Revert "USB: musb: blackfin: pm: make it work"
USB: uas: Use GFP_NOIO instead of GFP_KERNEL in I/O submission path
USB: uas: Ensure we only bind to a UAS interface
USB: uas: Rename sense pipe and sense urb to status pipe and status urb
USB: uas: Use kzalloc instead of kmalloc
USB: uas: Fix up the Sense IU
usb: musb: core: kill unneeded #include's
DA8xx: assign name to MUSB IRQ resource
usb: gadget: g_ncm added
...
Manually fix up trivial conflicts in USB Kconfig changes in:
arch/arm/mach-omap2/Kconfig
arch/sh/Kconfig
drivers/usb/Kconfig
drivers/usb/host/ehci-hcd.c
and annoying chip clock data conflicts in:
arch/arm/mach-omap2/clock3xxx_data.c
arch/arm/mach-omap2/clock44xx_data.c
Diffstat (limited to 'arch/arm/mach-omap2/board-4430sdp.c')
-rw-r--r-- | arch/arm/mach-omap2/board-4430sdp.c | 35 |
1 files changed, 29 insertions, 6 deletions
diff --git a/arch/arm/mach-omap2/board-4430sdp.c b/arch/arm/mach-omap2/board-4430sdp.c index 1cb208b6e626..a70bdf28e2bc 100644 --- a/arch/arm/mach-omap2/board-4430sdp.c +++ b/arch/arm/mach-omap2/board-4430sdp.c | |||
@@ -44,6 +44,7 @@ | |||
44 | #define ETH_KS8851_IRQ 34 | 44 | #define ETH_KS8851_IRQ 34 |
45 | #define ETH_KS8851_POWER_ON 48 | 45 | #define ETH_KS8851_POWER_ON 48 |
46 | #define ETH_KS8851_QUART 138 | 46 | #define ETH_KS8851_QUART 138 |
47 | #define OMAP4SDP_MDM_PWR_EN_GPIO 157 | ||
47 | #define OMAP4_SFH7741_SENSOR_OUTPUT_GPIO 184 | 48 | #define OMAP4_SFH7741_SENSOR_OUTPUT_GPIO 184 |
48 | #define OMAP4_SFH7741_ENABLE_GPIO 188 | 49 | #define OMAP4_SFH7741_ENABLE_GPIO 188 |
49 | 50 | ||
@@ -250,12 +251,29 @@ static void __init omap_4430sdp_init_irq(void) | |||
250 | gic_init_irq(); | 251 | gic_init_irq(); |
251 | } | 252 | } |
252 | 253 | ||
254 | static const struct ehci_hcd_omap_platform_data ehci_pdata __initconst = { | ||
255 | .port_mode[0] = EHCI_HCD_OMAP_MODE_PHY, | ||
256 | .port_mode[1] = EHCI_HCD_OMAP_MODE_UNKNOWN, | ||
257 | .port_mode[2] = EHCI_HCD_OMAP_MODE_UNKNOWN, | ||
258 | .phy_reset = false, | ||
259 | .reset_gpio_port[0] = -EINVAL, | ||
260 | .reset_gpio_port[1] = -EINVAL, | ||
261 | .reset_gpio_port[2] = -EINVAL, | ||
262 | }; | ||
263 | |||
253 | static struct omap_musb_board_data musb_board_data = { | 264 | static struct omap_musb_board_data musb_board_data = { |
254 | .interface_type = MUSB_INTERFACE_UTMI, | 265 | .interface_type = MUSB_INTERFACE_UTMI, |
255 | .mode = MUSB_PERIPHERAL, | 266 | .mode = MUSB_OTG, |
256 | .power = 100, | 267 | .power = 100, |
257 | }; | 268 | }; |
258 | 269 | ||
270 | static struct twl4030_usb_data omap4_usbphy_data = { | ||
271 | .phy_init = omap4430_phy_init, | ||
272 | .phy_exit = omap4430_phy_exit, | ||
273 | .phy_power = omap4430_phy_power, | ||
274 | .phy_set_clock = omap4430_phy_set_clk, | ||
275 | }; | ||
276 | |||
259 | static struct omap2_hsmmc_info mmc[] = { | 277 | static struct omap2_hsmmc_info mmc[] = { |
260 | { | 278 | { |
261 | .mmc = 1, | 279 | .mmc = 1, |
@@ -475,6 +493,7 @@ static struct twl4030_platform_data sdp4430_twldata = { | |||
475 | .vaux1 = &sdp4430_vaux1, | 493 | .vaux1 = &sdp4430_vaux1, |
476 | .vaux2 = &sdp4430_vaux2, | 494 | .vaux2 = &sdp4430_vaux2, |
477 | .vaux3 = &sdp4430_vaux3, | 495 | .vaux3 = &sdp4430_vaux3, |
496 | .usb = &omap4_usbphy_data | ||
478 | }; | 497 | }; |
479 | 498 | ||
480 | static struct i2c_board_info __initdata sdp4430_i2c_boardinfo[] = { | 499 | static struct i2c_board_info __initdata sdp4430_i2c_boardinfo[] = { |
@@ -555,11 +574,15 @@ static void __init omap_4430sdp_init(void) | |||
555 | platform_add_devices(sdp4430_devices, ARRAY_SIZE(sdp4430_devices)); | 574 | platform_add_devices(sdp4430_devices, ARRAY_SIZE(sdp4430_devices)); |
556 | omap_serial_init(); | 575 | omap_serial_init(); |
557 | omap4_twl6030_hsmmc_init(mmc); | 576 | omap4_twl6030_hsmmc_init(mmc); |
558 | /* OMAP4 SDP uses internal transceiver so register nop transceiver */ | 577 | |
559 | usb_nop_xceiv_register(); | 578 | /* Power on the ULPI PHY */ |
560 | /* FIXME: allow multi-omap to boot until musb is updated for omap4 */ | 579 | if (gpio_is_valid(OMAP4SDP_MDM_PWR_EN_GPIO)) { |
561 | if (!cpu_is_omap44xx()) | 580 | /* FIXME: Assumes pad is already muxed for GPIO mode */ |
562 | usb_musb_init(&musb_board_data); | 581 | gpio_request(OMAP4SDP_MDM_PWR_EN_GPIO, "USBB1 PHY VMDM_3V3"); |
582 | gpio_direction_output(OMAP4SDP_MDM_PWR_EN_GPIO, 1); | ||
583 | } | ||
584 | usb_ehci_init(&ehci_pdata); | ||
585 | usb_musb_init(&musb_board_data); | ||
563 | 586 | ||
564 | status = omap_ethernet_init(); | 587 | status = omap_ethernet_init(); |
565 | if (status) { | 588 | if (status) { |