aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/usb/host/ehci-fsl.c21
-rw-r--r--drivers/usb/host/ehci-hub.c2
-rw-r--r--drivers/usb/host/ehci.h4
-rw-r--r--drivers/usb/host/ohci-omap.c27
-rw-r--r--drivers/usb/host/ohci.h5
5 files changed, 25 insertions, 34 deletions
diff --git a/drivers/usb/host/ehci-fsl.c b/drivers/usb/host/ehci-fsl.c
index 43362577b54a..3379945b095e 100644
--- a/drivers/usb/host/ehci-fsl.c
+++ b/drivers/usb/host/ehci-fsl.c
@@ -142,19 +142,19 @@ static int usb_hcd_fsl_probe(const struct hc_driver *driver,
142 if (pdata->operating_mode == FSL_USB2_DR_OTG) { 142 if (pdata->operating_mode == FSL_USB2_DR_OTG) {
143 struct ehci_hcd *ehci = hcd_to_ehci(hcd); 143 struct ehci_hcd *ehci = hcd_to_ehci(hcd);
144 144
145 ehci->transceiver = usb_get_transceiver(); 145 hcd->phy = usb_get_transceiver();
146 dev_dbg(&pdev->dev, "hcd=0x%p ehci=0x%p, transceiver=0x%p\n", 146 dev_dbg(&pdev->dev, "hcd=0x%p ehci=0x%p, phy=0x%p\n",
147 hcd, ehci, ehci->transceiver); 147 hcd, ehci, hcd->phy);
148 148
149 if (ehci->transceiver) { 149 if (hcd->phy) {
150 retval = otg_set_host(ehci->transceiver->otg, 150 retval = otg_set_host(hcd->phy->otg,
151 &ehci_to_hcd(ehci)->self); 151 &ehci_to_hcd(ehci)->self);
152 if (retval) { 152 if (retval) {
153 usb_put_transceiver(ehci->transceiver); 153 usb_put_transceiver(hcd->phy);
154 goto err4; 154 goto err4;
155 } 155 }
156 } else { 156 } else {
157 dev_err(&pdev->dev, "can't find transceiver\n"); 157 dev_err(&pdev->dev, "can't find phy\n");
158 retval = -ENODEV; 158 retval = -ENODEV;
159 goto err4; 159 goto err4;
160 } 160 }
@@ -190,11 +190,10 @@ static void usb_hcd_fsl_remove(struct usb_hcd *hcd,
190 struct platform_device *pdev) 190 struct platform_device *pdev)
191{ 191{
192 struct fsl_usb2_platform_data *pdata = pdev->dev.platform_data; 192 struct fsl_usb2_platform_data *pdata = pdev->dev.platform_data;
193 struct ehci_hcd *ehci = hcd_to_ehci(hcd);
194 193
195 if (ehci->transceiver) { 194 if (hcd->phy) {
196 otg_set_host(ehci->transceiver->otg, NULL); 195 otg_set_host(hcd->phy->otg, NULL);
197 usb_put_transceiver(ehci->transceiver); 196 usb_put_transceiver(hcd->phy);
198 } 197 }
199 198
200 usb_remove_hcd(hcd); 199 usb_remove_hcd(hcd);
diff --git a/drivers/usb/host/ehci-hub.c b/drivers/usb/host/ehci-hub.c
index fc9e7cc6ac9b..dd5eef6af6df 100644
--- a/drivers/usb/host/ehci-hub.c
+++ b/drivers/usb/host/ehci-hub.c
@@ -724,7 +724,7 @@ static int ehci_hub_control (
724#ifdef CONFIG_USB_OTG 724#ifdef CONFIG_USB_OTG
725 if ((hcd->self.otg_port == (wIndex + 1)) 725 if ((hcd->self.otg_port == (wIndex + 1))
726 && hcd->self.b_hnp_enable) { 726 && hcd->self.b_hnp_enable) {
727 otg_start_hnp(ehci->transceiver->otg); 727 otg_start_hnp(hcd->phy->otg);
728 break; 728 break;
729 } 729 }
730#endif 730#endif
diff --git a/drivers/usb/host/ehci.h b/drivers/usb/host/ehci.h
index 2694ed6558d2..85c3572155d1 100644
--- a/drivers/usb/host/ehci.h
+++ b/drivers/usb/host/ehci.h
@@ -175,10 +175,6 @@ struct ehci_hcd { /* one per controller */
175#ifdef DEBUG 175#ifdef DEBUG
176 struct dentry *debug_dir; 176 struct dentry *debug_dir;
177#endif 177#endif
178 /*
179 * OTG controllers and transceivers need software interaction
180 */
181 struct usb_phy *transceiver;
182}; 178};
183 179
184/* convert between an HCD pointer and the corresponding EHCI_HCD */ 180/* convert between an HCD pointer and the corresponding EHCI_HCD */
diff --git a/drivers/usb/host/ohci-omap.c b/drivers/usb/host/ohci-omap.c
index 9ce35d0d9d5d..eccddb461396 100644
--- a/drivers/usb/host/ohci-omap.c
+++ b/drivers/usb/host/ohci-omap.c
@@ -167,14 +167,15 @@ static int omap_1510_local_bus_init(void)
167 167
168static void start_hnp(struct ohci_hcd *ohci) 168static void start_hnp(struct ohci_hcd *ohci)
169{ 169{
170 const unsigned port = ohci_to_hcd(ohci)->self.otg_port - 1; 170 struct usb_hcd *hcd = ohci_to_hcd(ohci);
171 const unsigned port = hcd->self.otg_port - 1;
171 unsigned long flags; 172 unsigned long flags;
172 u32 l; 173 u32 l;
173 174
174 otg_start_hnp(ohci->transceiver->otg); 175 otg_start_hnp(hcd->phy->otg);
175 176
176 local_irq_save(flags); 177 local_irq_save(flags);
177 ohci->transceiver->state = OTG_STATE_A_SUSPEND; 178 hcd->phy->state = OTG_STATE_A_SUSPEND;
178 writel (RH_PS_PSS, &ohci->regs->roothub.portstatus [port]); 179 writel (RH_PS_PSS, &ohci->regs->roothub.portstatus [port]);
179 l = omap_readl(OTG_CTRL); 180 l = omap_readl(OTG_CTRL);
180 l &= ~OTG_A_BUSREQ; 181 l &= ~OTG_A_BUSREQ;
@@ -211,18 +212,18 @@ static int ohci_omap_init(struct usb_hcd *hcd)
211 212
212#ifdef CONFIG_USB_OTG 213#ifdef CONFIG_USB_OTG
213 if (need_transceiver) { 214 if (need_transceiver) {
214 ohci->transceiver = usb_get_transceiver(); 215 hcd->phy = usb_get_transceiver();
215 if (ohci->transceiver) { 216 if (hcd->phy) {
216 int status = otg_set_host(ohci->transceiver->otg, 217 int status = otg_set_host(hcd->phy->otg,
217 &ohci_to_hcd(ohci)->self); 218 &ohci_to_hcd(ohci)->self);
218 dev_dbg(hcd->self.controller, "init %s transceiver, status %d\n", 219 dev_dbg(hcd->self.controller, "init %s phy, status %d\n",
219 ohci->transceiver->label, status); 220 hcd->phy->label, status);
220 if (status) { 221 if (status) {
221 usb_put_transceiver(ohci->transceiver); 222 usb_put_transceiver(hcd->phy);
222 return status; 223 return status;
223 } 224 }
224 } else { 225 } else {
225 dev_err(hcd->self.controller, "can't find transceiver\n"); 226 dev_err(hcd->self.controller, "can't find phy\n");
226 return -ENODEV; 227 return -ENODEV;
227 } 228 }
228 ohci->start_hnp = start_hnp; 229 ohci->start_hnp = start_hnp;
@@ -403,9 +404,9 @@ usb_hcd_omap_remove (struct usb_hcd *hcd, struct platform_device *pdev)
403 struct ohci_hcd *ohci = hcd_to_ohci (hcd); 404 struct ohci_hcd *ohci = hcd_to_ohci (hcd);
404 405
405 usb_remove_hcd(hcd); 406 usb_remove_hcd(hcd);
406 if (ohci->transceiver) { 407 if (hcd->phy) {
407 (void) otg_set_host(ohci->transceiver->otg, 0); 408 (void) otg_set_host(hcd->phy->otg, 0);
408 usb_put_transceiver(ohci->transceiver); 409 usb_put_transceiver(hcd->phy);
409 } 410 }
410 if (machine_is_omap_osk()) 411 if (machine_is_omap_osk())
411 gpio_free(9); 412 gpio_free(9);
diff --git a/drivers/usb/host/ohci.h b/drivers/usb/host/ohci.h
index 1b19aea25a2b..d3299143d9e2 100644
--- a/drivers/usb/host/ohci.h
+++ b/drivers/usb/host/ohci.h
@@ -372,11 +372,6 @@ struct ohci_hcd {
372 struct ed *ed_controltail; /* last in ctrl list */ 372 struct ed *ed_controltail; /* last in ctrl list */
373 struct ed *periodic [NUM_INTS]; /* shadow int_table */ 373 struct ed *periodic [NUM_INTS]; /* shadow int_table */
374 374
375 /*
376 * OTG controllers and transceivers need software interaction;
377 * other external transceivers should be software-transparent
378 */
379 struct usb_phy *transceiver;
380 void (*start_hnp)(struct ohci_hcd *ohci); 375 void (*start_hnp)(struct ohci_hcd *ohci);
381 376
382 /* 377 /*