2 * omap-usb-host.c - The USBHS core driver for OMAP EHCI & OHCI
4 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com
5 * Author: Keshava Munegowda <keshava_mgowda@ti.com>
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 of
9 * the License as published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #include <linux/kernel.h>
20 #include <linux/module.h>
21 #include <linux/types.h>
22 #include <linux/slab.h>
23 #include <linux/delay.h>
24 #include <linux/clk.h>
25 #include <linux/dma-mapping.h>
26 #include <linux/gpio.h>
27 #include <linux/platform_device.h>
28 #include <linux/platform_data/usb-omap.h>
29 #include <linux/pm_runtime.h>
33 #define USBHS_DRIVER_NAME "usbhs_omap"
34 #define OMAP_EHCI_DEVICE "ehci-omap"
35 #define OMAP_OHCI_DEVICE "ohci-omap3"
37 /* OMAP USBHOST Register addresses */
39 /* UHH Register Set */
40 #define OMAP_UHH_REVISION (0x00)
41 #define OMAP_UHH_SYSCONFIG (0x10)
42 #define OMAP_UHH_SYSCONFIG_MIDLEMODE (1 << 12)
43 #define OMAP_UHH_SYSCONFIG_CACTIVITY (1 << 8)
44 #define OMAP_UHH_SYSCONFIG_SIDLEMODE (1 << 3)
45 #define OMAP_UHH_SYSCONFIG_ENAWAKEUP (1 << 2)
46 #define OMAP_UHH_SYSCONFIG_SOFTRESET (1 << 1)
47 #define OMAP_UHH_SYSCONFIG_AUTOIDLE (1 << 0)
49 #define OMAP_UHH_SYSSTATUS (0x14)
50 #define OMAP_UHH_HOSTCONFIG (0x40)
51 #define OMAP_UHH_HOSTCONFIG_ULPI_BYPASS (1 << 0)
52 #define OMAP_UHH_HOSTCONFIG_ULPI_P1_BYPASS (1 << 0)
53 #define OMAP_UHH_HOSTCONFIG_ULPI_P2_BYPASS (1 << 11)
54 #define OMAP_UHH_HOSTCONFIG_ULPI_P3_BYPASS (1 << 12)
55 #define OMAP_UHH_HOSTCONFIG_INCR4_BURST_EN (1 << 2)
56 #define OMAP_UHH_HOSTCONFIG_INCR8_BURST_EN (1 << 3)
57 #define OMAP_UHH_HOSTCONFIG_INCR16_BURST_EN (1 << 4)
58 #define OMAP_UHH_HOSTCONFIG_INCRX_ALIGN_EN (1 << 5)
59 #define OMAP_UHH_HOSTCONFIG_P1_CONNECT_STATUS (1 << 8)
60 #define OMAP_UHH_HOSTCONFIG_P2_CONNECT_STATUS (1 << 9)
61 #define OMAP_UHH_HOSTCONFIG_P3_CONNECT_STATUS (1 << 10)
62 #define OMAP4_UHH_HOSTCONFIG_APP_START_CLK (1 << 31)
64 /* OMAP4-specific defines */
65 #define OMAP4_UHH_SYSCONFIG_IDLEMODE_CLEAR (3 << 2)
66 #define OMAP4_UHH_SYSCONFIG_NOIDLE (1 << 2)
67 #define OMAP4_UHH_SYSCONFIG_STDBYMODE_CLEAR (3 << 4)
68 #define OMAP4_UHH_SYSCONFIG_NOSTDBY (1 << 4)
69 #define OMAP4_UHH_SYSCONFIG_SOFTRESET (1 << 0)
71 #define OMAP4_P1_MODE_CLEAR (3 << 16)
72 #define OMAP4_P1_MODE_TLL (1 << 16)
73 #define OMAP4_P1_MODE_HSIC (3 << 16)
74 #define OMAP4_P2_MODE_CLEAR (3 << 18)
75 #define OMAP4_P2_MODE_TLL (1 << 18)
76 #define OMAP4_P2_MODE_HSIC (3 << 18)
78 #define OMAP_UHH_DEBUG_CSR (0x44)
80 /* Values of UHH_REVISION - Note: these are not given in the TRM */
81 #define OMAP_USBHS_REV1 0x00000010 /* OMAP3 */
82 #define OMAP_USBHS_REV2 0x50700100 /* OMAP4 */
84 #define is_omap_usbhs_rev1(x) (x->usbhs_rev == OMAP_USBHS_REV1)
85 #define is_omap_usbhs_rev2(x) (x->usbhs_rev == OMAP_USBHS_REV2)
87 #define is_ehci_phy_mode(x) (x == OMAP_EHCI_PORT_MODE_PHY)
88 #define is_ehci_tll_mode(x) (x == OMAP_EHCI_PORT_MODE_TLL)
89 #define is_ehci_hsic_mode(x) (x == OMAP_EHCI_PORT_MODE_HSIC)
92 struct usbhs_hcd_omap
{
94 struct clk
**utmi_clk
;
95 struct clk
**hsic60m_clk
;
96 struct clk
**hsic480m_clk
;
98 struct clk
*xclk60mhsp1_ck
;
99 struct clk
*xclk60mhsp2_ck
;
100 struct clk
*utmi_p1_gfclk
;
101 struct clk
*utmi_p2_gfclk
;
102 struct clk
*init_60m_fclk
;
103 struct clk
*ehci_logic_fck
;
105 void __iomem
*uhh_base
;
107 struct usbhs_omap_platform_data
*pdata
;
111 /*-------------------------------------------------------------------------*/
113 const char usbhs_driver_name
[] = USBHS_DRIVER_NAME
;
114 static u64 usbhs_dmamask
= DMA_BIT_MASK(32);
116 /*-------------------------------------------------------------------------*/
118 static inline void usbhs_write(void __iomem
*base
, u32 reg
, u32 val
)
120 __raw_writel(val
, base
+ reg
);
123 static inline u32
usbhs_read(void __iomem
*base
, u32 reg
)
125 return __raw_readl(base
+ reg
);
128 static inline void usbhs_writeb(void __iomem
*base
, u8 reg
, u8 val
)
130 __raw_writeb(val
, base
+ reg
);
133 static inline u8
usbhs_readb(void __iomem
*base
, u8 reg
)
135 return __raw_readb(base
+ reg
);
138 /*-------------------------------------------------------------------------*/
140 static struct platform_device
*omap_usbhs_alloc_child(const char *name
,
141 struct resource
*res
, int num_resources
, void *pdata
,
142 size_t pdata_size
, struct device
*dev
)
144 struct platform_device
*child
;
147 child
= platform_device_alloc(name
, 0);
150 dev_err(dev
, "platform_device_alloc %s failed\n", name
);
154 ret
= platform_device_add_resources(child
, res
, num_resources
);
156 dev_err(dev
, "platform_device_add_resources failed\n");
160 ret
= platform_device_add_data(child
, pdata
, pdata_size
);
162 dev_err(dev
, "platform_device_add_data failed\n");
166 child
->dev
.dma_mask
= &usbhs_dmamask
;
167 dma_set_coherent_mask(&child
->dev
, DMA_BIT_MASK(32));
168 child
->dev
.parent
= dev
;
170 ret
= platform_device_add(child
);
172 dev_err(dev
, "platform_device_add failed\n");
179 platform_device_put(child
);
185 static int omap_usbhs_alloc_children(struct platform_device
*pdev
)
187 struct device
*dev
= &pdev
->dev
;
188 struct usbhs_omap_platform_data
*pdata
= dev
->platform_data
;
189 struct platform_device
*ehci
;
190 struct platform_device
*ohci
;
191 struct resource
*res
;
192 struct resource resources
[2];
195 res
= platform_get_resource_byname(pdev
, IORESOURCE_MEM
, "ehci");
197 dev_err(dev
, "EHCI get resource IORESOURCE_MEM failed\n");
203 res
= platform_get_resource_byname(pdev
, IORESOURCE_IRQ
, "ehci-irq");
205 dev_err(dev
, " EHCI get resource IORESOURCE_IRQ failed\n");
211 ehci
= omap_usbhs_alloc_child(OMAP_EHCI_DEVICE
, resources
, 2, pdata
,
212 sizeof(*pdata
), dev
);
215 dev_err(dev
, "omap_usbhs_alloc_child failed\n");
220 res
= platform_get_resource_byname(pdev
, IORESOURCE_MEM
, "ohci");
222 dev_err(dev
, "OHCI get resource IORESOURCE_MEM failed\n");
228 res
= platform_get_resource_byname(pdev
, IORESOURCE_IRQ
, "ohci-irq");
230 dev_err(dev
, "OHCI get resource IORESOURCE_IRQ failed\n");
236 ohci
= omap_usbhs_alloc_child(OMAP_OHCI_DEVICE
, resources
, 2, pdata
,
237 sizeof(*pdata
), dev
);
239 dev_err(dev
, "omap_usbhs_alloc_child failed\n");
247 platform_device_unregister(ehci
);
253 static bool is_ohci_port(enum usbhs_omap_port_mode pmode
)
256 case OMAP_OHCI_PORT_MODE_PHY_6PIN_DATSE0
:
257 case OMAP_OHCI_PORT_MODE_PHY_6PIN_DPDM
:
258 case OMAP_OHCI_PORT_MODE_PHY_3PIN_DATSE0
:
259 case OMAP_OHCI_PORT_MODE_PHY_4PIN_DPDM
:
260 case OMAP_OHCI_PORT_MODE_TLL_6PIN_DATSE0
:
261 case OMAP_OHCI_PORT_MODE_TLL_6PIN_DPDM
:
262 case OMAP_OHCI_PORT_MODE_TLL_3PIN_DATSE0
:
263 case OMAP_OHCI_PORT_MODE_TLL_4PIN_DPDM
:
264 case OMAP_OHCI_PORT_MODE_TLL_2PIN_DATSE0
:
265 case OMAP_OHCI_PORT_MODE_TLL_2PIN_DPDM
:
273 static int usbhs_runtime_resume(struct device
*dev
)
275 struct usbhs_hcd_omap
*omap
= dev_get_drvdata(dev
);
276 struct usbhs_omap_platform_data
*pdata
= omap
->pdata
;
279 dev_dbg(dev
, "usbhs_runtime_resume\n");
283 if (!IS_ERR(omap
->ehci_logic_fck
))
284 clk_enable(omap
->ehci_logic_fck
);
286 for (i
= 0; i
< omap
->nports
; i
++) {
287 switch (pdata
->port_mode
[i
]) {
288 case OMAP_EHCI_PORT_MODE_HSIC
:
289 if (!IS_ERR(omap
->hsic60m_clk
[i
])) {
290 r
= clk_enable(omap
->hsic60m_clk
[i
]);
293 "Can't enable port %d hsic60m clk:%d\n",
298 if (!IS_ERR(omap
->hsic480m_clk
[i
])) {
299 r
= clk_enable(omap
->hsic480m_clk
[i
]);
302 "Can't enable port %d hsic480m clk:%d\n",
306 /* Fall through as HSIC mode needs utmi_clk */
308 case OMAP_EHCI_PORT_MODE_TLL
:
309 if (!IS_ERR(omap
->utmi_clk
[i
])) {
310 r
= clk_enable(omap
->utmi_clk
[i
]);
313 "Can't enable port %d clk : %d\n",
326 static int usbhs_runtime_suspend(struct device
*dev
)
328 struct usbhs_hcd_omap
*omap
= dev_get_drvdata(dev
);
329 struct usbhs_omap_platform_data
*pdata
= omap
->pdata
;
332 dev_dbg(dev
, "usbhs_runtime_suspend\n");
334 for (i
= 0; i
< omap
->nports
; i
++) {
335 switch (pdata
->port_mode
[i
]) {
336 case OMAP_EHCI_PORT_MODE_HSIC
:
337 if (!IS_ERR(omap
->hsic60m_clk
[i
]))
338 clk_disable(omap
->hsic60m_clk
[i
]);
340 if (!IS_ERR(omap
->hsic480m_clk
[i
]))
341 clk_disable(omap
->hsic480m_clk
[i
]);
342 /* Fall through as utmi_clks were used in HSIC mode */
344 case OMAP_EHCI_PORT_MODE_TLL
:
345 if (!IS_ERR(omap
->utmi_clk
[i
]))
346 clk_disable(omap
->utmi_clk
[i
]);
353 if (!IS_ERR(omap
->ehci_logic_fck
))
354 clk_disable(omap
->ehci_logic_fck
);
361 static unsigned omap_usbhs_rev1_hostconfig(struct usbhs_hcd_omap
*omap
,
364 struct usbhs_omap_platform_data
*pdata
= omap
->pdata
;
367 for (i
= 0; i
< omap
->nports
; i
++) {
368 switch (pdata
->port_mode
[i
]) {
369 case OMAP_USBHS_PORT_MODE_UNUSED
:
370 reg
&= ~(OMAP_UHH_HOSTCONFIG_P1_CONNECT_STATUS
<< i
);
372 case OMAP_EHCI_PORT_MODE_PHY
:
373 if (pdata
->single_ulpi_bypass
)
377 reg
&= ~OMAP_UHH_HOSTCONFIG_ULPI_P1_BYPASS
;
379 reg
&= ~(OMAP_UHH_HOSTCONFIG_ULPI_P2_BYPASS
383 if (pdata
->single_ulpi_bypass
)
387 reg
|= OMAP_UHH_HOSTCONFIG_ULPI_P1_BYPASS
;
389 reg
|= OMAP_UHH_HOSTCONFIG_ULPI_P2_BYPASS
395 if (pdata
->single_ulpi_bypass
) {
396 /* bypass ULPI only if none of the ports use PHY mode */
397 reg
|= OMAP_UHH_HOSTCONFIG_ULPI_BYPASS
;
399 for (i
= 0; i
< omap
->nports
; i
++) {
400 if (is_ehci_phy_mode(pdata
->port_mode
[i
])) {
401 reg
&= OMAP_UHH_HOSTCONFIG_ULPI_BYPASS
;
410 static unsigned omap_usbhs_rev2_hostconfig(struct usbhs_hcd_omap
*omap
,
413 struct usbhs_omap_platform_data
*pdata
= omap
->pdata
;
416 for (i
= 0; i
< omap
->nports
; i
++) {
417 /* Clear port mode fields for PHY mode */
418 reg
&= ~(OMAP4_P1_MODE_CLEAR
<< 2 * i
);
420 if (is_ehci_tll_mode(pdata
->port_mode
[i
]) ||
421 (is_ohci_port(pdata
->port_mode
[i
])))
422 reg
|= OMAP4_P1_MODE_TLL
<< 2 * i
;
423 else if (is_ehci_hsic_mode(pdata
->port_mode
[i
]))
424 reg
|= OMAP4_P1_MODE_HSIC
<< 2 * i
;
430 static void omap_usbhs_init(struct device
*dev
)
432 struct usbhs_hcd_omap
*omap
= dev_get_drvdata(dev
);
433 struct usbhs_omap_platform_data
*pdata
= omap
->pdata
;
436 dev_dbg(dev
, "starting TI HSUSB Controller\n");
438 if (pdata
->phy_reset
) {
439 if (gpio_is_valid(pdata
->reset_gpio_port
[0]))
440 devm_gpio_request_one(dev
, pdata
->reset_gpio_port
[0],
441 GPIOF_OUT_INIT_LOW
, "USB1 PHY reset");
443 if (gpio_is_valid(pdata
->reset_gpio_port
[1]))
444 devm_gpio_request_one(dev
, pdata
->reset_gpio_port
[1],
445 GPIOF_OUT_INIT_LOW
, "USB2 PHY reset");
447 /* Hold the PHY in RESET for enough time till DIR is high */
451 pm_runtime_get_sync(dev
);
453 reg
= usbhs_read(omap
->uhh_base
, OMAP_UHH_HOSTCONFIG
);
454 /* setup ULPI bypass and burst configurations */
455 reg
|= (OMAP_UHH_HOSTCONFIG_INCR4_BURST_EN
456 | OMAP_UHH_HOSTCONFIG_INCR8_BURST_EN
457 | OMAP_UHH_HOSTCONFIG_INCR16_BURST_EN
);
458 reg
|= OMAP4_UHH_HOSTCONFIG_APP_START_CLK
;
459 reg
&= ~OMAP_UHH_HOSTCONFIG_INCRX_ALIGN_EN
;
461 switch (omap
->usbhs_rev
) {
462 case OMAP_USBHS_REV1
:
463 reg
= omap_usbhs_rev1_hostconfig(omap
, reg
);
466 case OMAP_USBHS_REV2
:
467 reg
= omap_usbhs_rev2_hostconfig(omap
, reg
);
470 default: /* newer revisions */
471 reg
= omap_usbhs_rev2_hostconfig(omap
, reg
);
475 usbhs_write(omap
->uhh_base
, OMAP_UHH_HOSTCONFIG
, reg
);
476 dev_dbg(dev
, "UHH setup done, uhh_hostconfig=%x\n", reg
);
478 pm_runtime_put_sync(dev
);
479 if (pdata
->phy_reset
) {
480 /* Hold the PHY in RESET for enough time till
481 * PHY is settled and ready
485 if (gpio_is_valid(pdata
->reset_gpio_port
[0]))
486 gpio_set_value_cansleep
487 (pdata
->reset_gpio_port
[0], 1);
489 if (gpio_is_valid(pdata
->reset_gpio_port
[1]))
490 gpio_set_value_cansleep
491 (pdata
->reset_gpio_port
[1], 1);
496 * usbhs_omap_probe - initialize TI-based HCDs
498 * Allocates basic resources for this USB host controller.
500 static int usbhs_omap_probe(struct platform_device
*pdev
)
502 struct device
*dev
= &pdev
->dev
;
503 struct usbhs_omap_platform_data
*pdata
= dev
->platform_data
;
504 struct usbhs_hcd_omap
*omap
;
505 struct resource
*res
;
511 dev_err(dev
, "Missing platform data\n");
515 omap
= devm_kzalloc(dev
, sizeof(*omap
), GFP_KERNEL
);
517 dev_err(dev
, "Memory allocation failed\n");
521 res
= platform_get_resource_byname(pdev
, IORESOURCE_MEM
, "uhh");
522 omap
->uhh_base
= devm_request_and_ioremap(dev
, res
);
523 if (!omap
->uhh_base
) {
524 dev_err(dev
, "Resource request/ioremap failed\n");
525 return -EADDRNOTAVAIL
;
530 pm_runtime_enable(dev
);
532 platform_set_drvdata(pdev
, omap
);
533 pm_runtime_get_sync(dev
);
535 omap
->usbhs_rev
= usbhs_read(omap
->uhh_base
, OMAP_UHH_REVISION
);
537 /* we need to call runtime suspend before we update omap->nports
538 * to prevent unbalanced clk_disable()
540 pm_runtime_put_sync(dev
);
543 * If platform data contains nports then use that
544 * else make out number of ports from USBHS revision
547 omap
->nports
= pdata
->nports
;
549 switch (omap
->usbhs_rev
) {
550 case OMAP_USBHS_REV1
:
553 case OMAP_USBHS_REV2
:
557 omap
->nports
= OMAP3_HS_USB_PORTS
;
559 "USB HOST Rev:0x%d not recognized, assuming %d ports\n",
560 omap
->usbhs_rev
, omap
->nports
);
565 i
= sizeof(struct clk
*) * omap
->nports
;
566 omap
->utmi_clk
= devm_kzalloc(dev
, i
, GFP_KERNEL
);
567 omap
->hsic480m_clk
= devm_kzalloc(dev
, i
, GFP_KERNEL
);
568 omap
->hsic60m_clk
= devm_kzalloc(dev
, i
, GFP_KERNEL
);
570 if (!omap
->utmi_clk
|| !omap
->hsic480m_clk
|| !omap
->hsic60m_clk
) {
571 dev_err(dev
, "Memory allocation failed\n");
576 need_logic_fck
= false;
577 for (i
= 0; i
< omap
->nports
; i
++) {
578 if (is_ehci_phy_mode(i
) || is_ehci_tll_mode(i
) ||
579 is_ehci_hsic_mode(i
))
580 need_logic_fck
|= true;
583 omap
->ehci_logic_fck
= ERR_PTR(-EINVAL
);
584 if (need_logic_fck
) {
585 omap
->ehci_logic_fck
= clk_get(dev
, "ehci_logic_fck");
586 if (IS_ERR(omap
->ehci_logic_fck
)) {
587 ret
= PTR_ERR(omap
->ehci_logic_fck
);
588 dev_dbg(dev
, "ehci_logic_fck failed:%d\n", ret
);
592 omap
->utmi_p1_gfclk
= clk_get(dev
, "utmi_p1_gfclk");
593 if (IS_ERR(omap
->utmi_p1_gfclk
)) {
594 ret
= PTR_ERR(omap
->utmi_p1_gfclk
);
595 dev_err(dev
, "utmi_p1_gfclk failed error:%d\n", ret
);
599 omap
->utmi_p2_gfclk
= clk_get(dev
, "utmi_p2_gfclk");
600 if (IS_ERR(omap
->utmi_p2_gfclk
)) {
601 ret
= PTR_ERR(omap
->utmi_p2_gfclk
);
602 dev_err(dev
, "utmi_p2_gfclk failed error:%d\n", ret
);
606 omap
->xclk60mhsp1_ck
= clk_get(dev
, "xclk60mhsp1_ck");
607 if (IS_ERR(omap
->xclk60mhsp1_ck
)) {
608 ret
= PTR_ERR(omap
->xclk60mhsp1_ck
);
609 dev_err(dev
, "xclk60mhsp1_ck failed error:%d\n", ret
);
610 goto err_xclk60mhsp1
;
613 omap
->xclk60mhsp2_ck
= clk_get(dev
, "xclk60mhsp2_ck");
614 if (IS_ERR(omap
->xclk60mhsp2_ck
)) {
615 ret
= PTR_ERR(omap
->xclk60mhsp2_ck
);
616 dev_err(dev
, "xclk60mhsp2_ck failed error:%d\n", ret
);
617 goto err_xclk60mhsp2
;
620 omap
->init_60m_fclk
= clk_get(dev
, "init_60m_fclk");
621 if (IS_ERR(omap
->init_60m_fclk
)) {
622 ret
= PTR_ERR(omap
->init_60m_fclk
);
623 dev_err(dev
, "init_60m_fclk failed error:%d\n", ret
);
627 for (i
= 0; i
< omap
->nports
; i
++) {
630 /* clock names are indexed from 1*/
631 snprintf(clkname
, sizeof(clkname
),
632 "usb_host_hs_utmi_p%d_clk", i
+ 1);
634 /* If a clock is not found we won't bail out as not all
635 * platforms have all clocks and we can function without
638 omap
->utmi_clk
[i
] = clk_get(dev
, clkname
);
639 if (IS_ERR(omap
->utmi_clk
[i
]))
640 dev_dbg(dev
, "Failed to get clock : %s : %ld\n",
641 clkname
, PTR_ERR(omap
->utmi_clk
[i
]));
643 snprintf(clkname
, sizeof(clkname
),
644 "usb_host_hs_hsic480m_p%d_clk", i
+ 1);
645 omap
->hsic480m_clk
[i
] = clk_get(dev
, clkname
);
646 if (IS_ERR(omap
->hsic480m_clk
[i
]))
647 dev_dbg(dev
, "Failed to get clock : %s : %ld\n",
648 clkname
, PTR_ERR(omap
->hsic480m_clk
[i
]));
650 snprintf(clkname
, sizeof(clkname
),
651 "usb_host_hs_hsic60m_p%d_clk", i
+ 1);
652 omap
->hsic60m_clk
[i
] = clk_get(dev
, clkname
);
653 if (IS_ERR(omap
->hsic60m_clk
[i
]))
654 dev_dbg(dev
, "Failed to get clock : %s : %ld\n",
655 clkname
, PTR_ERR(omap
->hsic60m_clk
[i
]));
658 if (is_ehci_phy_mode(pdata
->port_mode
[0])) {
659 /* for OMAP3, clk_set_parent fails */
660 ret
= clk_set_parent(omap
->utmi_p1_gfclk
,
661 omap
->xclk60mhsp1_ck
);
663 dev_dbg(dev
, "xclk60mhsp1_ck set parent failed: %d\n",
665 } else if (is_ehci_tll_mode(pdata
->port_mode
[0])) {
666 ret
= clk_set_parent(omap
->utmi_p1_gfclk
,
667 omap
->init_60m_fclk
);
669 dev_dbg(dev
, "P0 init_60m_fclk set parent failed: %d\n",
673 if (is_ehci_phy_mode(pdata
->port_mode
[1])) {
674 ret
= clk_set_parent(omap
->utmi_p2_gfclk
,
675 omap
->xclk60mhsp2_ck
);
677 dev_dbg(dev
, "xclk60mhsp2_ck set parent failed: %d\n",
679 } else if (is_ehci_tll_mode(pdata
->port_mode
[1])) {
680 ret
= clk_set_parent(omap
->utmi_p2_gfclk
,
681 omap
->init_60m_fclk
);
683 dev_dbg(dev
, "P1 init_60m_fclk set parent failed: %d\n",
687 omap_usbhs_init(dev
);
688 ret
= omap_usbhs_alloc_children(pdev
);
690 dev_err(dev
, "omap_usbhs_alloc_children failed\n");
697 for (i
= 0; i
< omap
->nports
; i
++) {
698 if (!IS_ERR(omap
->utmi_clk
[i
]))
699 clk_put(omap
->utmi_clk
[i
]);
700 if (!IS_ERR(omap
->hsic60m_clk
[i
]))
701 clk_put(omap
->hsic60m_clk
[i
]);
702 if (!IS_ERR(omap
->hsic480m_clk
[i
]))
703 clk_put(omap
->hsic480m_clk
[i
]);
706 clk_put(omap
->init_60m_fclk
);
709 clk_put(omap
->xclk60mhsp2_ck
);
712 clk_put(omap
->xclk60mhsp1_ck
);
715 clk_put(omap
->utmi_p2_gfclk
);
718 clk_put(omap
->utmi_p1_gfclk
);
721 if (!IS_ERR(omap
->ehci_logic_fck
))
722 clk_put(omap
->ehci_logic_fck
);
725 pm_runtime_disable(dev
);
731 * usbhs_omap_remove - shutdown processing for UHH & TLL HCDs
732 * @pdev: USB Host Controller being removed
734 * Reverses the effect of usbhs_omap_probe().
736 static int usbhs_omap_remove(struct platform_device
*pdev
)
738 struct usbhs_hcd_omap
*omap
= platform_get_drvdata(pdev
);
741 for (i
= 0; i
< omap
->nports
; i
++) {
742 if (!IS_ERR(omap
->utmi_clk
[i
]))
743 clk_put(omap
->utmi_clk
[i
]);
744 if (!IS_ERR(omap
->hsic60m_clk
[i
]))
745 clk_put(omap
->hsic60m_clk
[i
]);
746 if (!IS_ERR(omap
->hsic480m_clk
[i
]))
747 clk_put(omap
->hsic480m_clk
[i
]);
750 clk_put(omap
->init_60m_fclk
);
751 clk_put(omap
->utmi_p1_gfclk
);
752 clk_put(omap
->utmi_p2_gfclk
);
753 clk_put(omap
->xclk60mhsp2_ck
);
754 clk_put(omap
->xclk60mhsp1_ck
);
756 if (!IS_ERR(omap
->ehci_logic_fck
))
757 clk_put(omap
->ehci_logic_fck
);
759 pm_runtime_disable(&pdev
->dev
);
764 static const struct dev_pm_ops usbhsomap_dev_pm_ops
= {
765 .runtime_suspend
= usbhs_runtime_suspend
,
766 .runtime_resume
= usbhs_runtime_resume
,
769 static struct platform_driver usbhs_omap_driver
= {
771 .name
= (char *)usbhs_driver_name
,
772 .owner
= THIS_MODULE
,
773 .pm
= &usbhsomap_dev_pm_ops
,
775 .remove
= usbhs_omap_remove
,
778 MODULE_AUTHOR("Keshava Munegowda <keshava_mgowda@ti.com>");
779 MODULE_ALIAS("platform:" USBHS_DRIVER_NAME
);
780 MODULE_LICENSE("GPL v2");
781 MODULE_DESCRIPTION("usb host common core driver for omap EHCI and OHCI");
783 static int __init
omap_usbhs_drvinit(void)
785 return platform_driver_probe(&usbhs_omap_driver
, usbhs_omap_probe
);
789 * init before ehci and ohci drivers;
790 * The usbhs core driver should be initialized much before
791 * the omap ehci and ohci probe functions are called.
792 * This usbhs core driver should be initialized after
795 fs_initcall_sync(omap_usbhs_drvinit
);
797 static void __exit
omap_usbhs_drvexit(void)
799 platform_driver_unregister(&usbhs_omap_driver
);
801 module_exit(omap_usbhs_drvexit
);