2 * ISP116x HCD (Host Controller Driver) for USB.
4 * Derived from the SL811 HCD, rewritten for ISP116x.
5 * Copyright (C) 2005 Olav Kongas <ok@artecdesign.ee>
8 * Copyright (C) 2004 Psion Teklogix (for NetBook PRO)
9 * Copyright (C) 2004 David Brownell
11 * Periodic scheduling is based on Roman's OHCI code
12 * Copyright (C) 1999 Roman Weissgaerber
17 * The driver basically works. A number of people have used it with a range
20 * The driver passes all usbtests 1-14.
22 * Suspending/resuming of root hub via sysfs works. Remote wakeup works too.
23 * And suspending/resuming of platform device works too. Suspend/resume
24 * via HCD operations vector is not implemented.
26 * Iso transfer support is not implemented. Adding this would include
27 * implementing recovery from the failure to service the processed ITL
28 * fifo ram in time, which will involve chip reset.
31 + More testing of suspend/resume.
35 ISP116x chips require certain delays between accesses to its
36 registers. The following timing options exist.
38 1. Configure your memory controller (the best)
39 2. Implement platform-specific delay function possibly
40 combined with configuring the memory controller; see
41 include/linux/usb-isp116x.h for more info. Some broken
42 memory controllers line LH7A400 SMC need this. Also,
43 uncomment for that to work the following
44 USE_PLATFORM_DELAY macro.
45 3. Use ndelay (easiest, poorest). For that, uncomment
46 the following USE_NDELAY macro.
48 #define USE_PLATFORM_DELAY
53 /* Transfer descriptors. See dump_ptd() for printout format */
55 /* enqueuing/finishing log of urbs */
58 #include <linux/module.h>
59 #include <linux/delay.h>
60 #include <linux/debugfs.h>
61 #include <linux/seq_file.h>
62 #include <linux/errno.h>
63 #include <linux/init.h>
64 #include <linux/list.h>
65 #include <linux/usb.h>
66 #include <linux/usb/isp116x.h>
67 #include <linux/platform_device.h>
71 #include <asm/system.h>
72 #include <asm/byteorder.h>
74 #include "../core/hcd.h"
77 #define DRIVER_VERSION "03 Nov 2005"
78 #define DRIVER_DESC "ISP116x USB Host Controller Driver"
80 MODULE_DESCRIPTION(DRIVER_DESC);
81 MODULE_LICENSE("GPL");
83 static const char hcd_name[] = "isp116x-hcd";
85 /*-----------------------------------------------------------------*/
88 Write len bytes to fifo, pad till 32-bit boundary
90 static void write_ptddata_to_fifo(struct isp116x *isp116x, void *buf, int len)
93 u16 *dp2 = (u16 *) buf;
97 if ((unsigned long)dp2 & 1) {
99 for (; len > 1; len -= 2) {
102 isp116x_raw_write_data16(isp116x, w);
105 isp116x_write_data16(isp116x, (u16) * dp);
108 for (; len > 1; len -= 2)
109 isp116x_raw_write_data16(isp116x, *dp2++);
111 isp116x_write_data16(isp116x, 0xff & *((u8 *) dp2));
113 if (quot == 1 || quot == 2)
114 isp116x_raw_write_data16(isp116x, 0);
118 Read len bytes from fifo and then read till 32-bit boundary.
120 static void read_ptddata_from_fifo(struct isp116x *isp116x, void *buf, int len)
123 u16 *dp2 = (u16 *) buf;
127 if ((unsigned long)dp2 & 1) {
129 for (; len > 1; len -= 2) {
130 w = isp116x_raw_read_data16(isp116x);
132 *dp++ = (w >> 8) & 0xff;
135 *dp = 0xff & isp116x_read_data16(isp116x);
138 for (; len > 1; len -= 2)
139 *dp2++ = isp116x_raw_read_data16(isp116x);
141 *(u8 *) dp2 = 0xff & isp116x_read_data16(isp116x);
143 if (quot == 1 || quot == 2)
144 isp116x_raw_read_data16(isp116x);
148 Write ptd's and data for scheduled transfers into
149 the fifo ram. Fifo must be empty and ready.
151 static void pack_fifo(struct isp116x *isp116x)
153 struct isp116x_ep *ep;
155 int buflen = isp116x->atl_last_dir == PTD_DIR_IN
156 ? isp116x->atl_bufshrt : isp116x->atl_buflen;
158 isp116x_write_reg16(isp116x, HCuPINT, HCuPINT_AIIEOT);
159 isp116x_write_reg16(isp116x, HCXFERCTR, buflen);
160 isp116x_write_addr(isp116x, HCATLPORT | ISP116x_WRITE_OFFSET);
161 for (ep = isp116x->atl_active; ep; ep = ep->active) {
164 dump_ptd_out_data(ptd, ep->data);
165 isp116x_write_data16(isp116x, ptd->count);
166 isp116x_write_data16(isp116x, ptd->mps);
167 isp116x_write_data16(isp116x, ptd->len);
168 isp116x_write_data16(isp116x, ptd->faddr);
169 buflen -= sizeof(struct ptd);
170 /* Skip writing data for last IN PTD */
171 if (ep->active || (isp116x->atl_last_dir != PTD_DIR_IN)) {
172 write_ptddata_to_fifo(isp116x, ep->data, ep->length);
173 buflen -= ALIGN(ep->length, 4);
180 Read the processed ptd's and data from fifo ram back to
181 URBs' buffers. Fifo must be full and done
183 static void unpack_fifo(struct isp116x *isp116x)
185 struct isp116x_ep *ep;
187 int buflen = isp116x->atl_last_dir == PTD_DIR_IN
188 ? isp116x->atl_buflen : isp116x->atl_bufshrt;
190 isp116x_write_reg16(isp116x, HCuPINT, HCuPINT_AIIEOT);
191 isp116x_write_reg16(isp116x, HCXFERCTR, buflen);
192 isp116x_write_addr(isp116x, HCATLPORT);
193 for (ep = isp116x->atl_active; ep; ep = ep->active) {
195 ptd->count = isp116x_read_data16(isp116x);
196 ptd->mps = isp116x_read_data16(isp116x);
197 ptd->len = isp116x_read_data16(isp116x);
198 ptd->faddr = isp116x_read_data16(isp116x);
199 buflen -= sizeof(struct ptd);
200 /* Skip reading data for last Setup or Out PTD */
201 if (ep->active || (isp116x->atl_last_dir == PTD_DIR_IN)) {
202 read_ptddata_from_fifo(isp116x, ep->data, ep->length);
203 buflen -= ALIGN(ep->length, 4);
206 dump_ptd_in_data(ptd, ep->data);
211 /*---------------------------------------------------------------*/
216 static void preproc_atl_queue(struct isp116x *isp116x)
218 struct isp116x_ep *ep;
223 for (ep = isp116x->atl_active; ep; ep = ep->active) {
224 u16 toggle = 0, dir = PTD_DIR_SETUP;
226 BUG_ON(list_empty(&ep->hep->urb_list));
227 urb = container_of(ep->hep->urb_list.next,
228 struct urb, urb_list);
231 ep->data = (unsigned char *)urb->transfer_buffer
232 + urb->actual_length;
234 switch (ep->nextpid) {
236 toggle = usb_gettoggle(urb->dev, ep->epnum, 0);
240 toggle = usb_gettoggle(urb->dev, ep->epnum, 1);
244 len = sizeof(struct usb_ctrlrequest);
245 ep->data = urb->setup_packet;
250 dir = (urb->transfer_buffer_length
251 && usb_pipein(urb->pipe))
252 ? PTD_DIR_OUT : PTD_DIR_IN;
255 ERR("%s %d: ep->nextpid %d\n", __func__, __LINE__,
260 ptd->count = PTD_CC_MSK | PTD_ACTIVE_MSK | PTD_TOGGLE(toggle);
261 ptd->mps = PTD_MPS(ep->maxpacket)
262 | PTD_SPD(urb->dev->speed == USB_SPEED_LOW)
264 ptd->len = PTD_LEN(len) | PTD_DIR(dir);
265 ptd->faddr = PTD_FA(usb_pipedevice(urb->pipe));
267 ptd->mps |= PTD_LAST_MSK;
268 isp116x->atl_last_dir = dir;
270 isp116x->atl_bufshrt = sizeof(struct ptd) + isp116x->atl_buflen;
271 isp116x->atl_buflen = isp116x->atl_bufshrt + ALIGN(len, 4);
276 Take done or failed requests out of schedule. Give back
279 static void finish_request(struct isp116x *isp116x, struct isp116x_ep *ep,
280 struct urb *urb, int status)
281 __releases(isp116x->lock) __acquires(isp116x->lock)
287 if (usb_pipecontrol(urb->pipe))
288 ep->nextpid = USB_PID_SETUP;
290 urb_dbg(urb, "Finish");
292 usb_hcd_unlink_urb_from_ep(isp116x_to_hcd(isp116x), urb);
293 spin_unlock(&isp116x->lock);
294 usb_hcd_giveback_urb(isp116x_to_hcd(isp116x), urb, status);
295 spin_lock(&isp116x->lock);
297 /* take idle endpoints out of the schedule */
298 if (!list_empty(&ep->hep->urb_list))
301 /* async deschedule */
302 if (!list_empty(&ep->schedule)) {
303 list_del_init(&ep->schedule);
307 /* periodic deschedule */
308 DBG("deschedule qh%d/%p branch %d\n", ep->period, ep, ep->branch);
309 for (i = ep->branch; i < PERIODIC_SIZE; i += ep->period) {
310 struct isp116x_ep *temp;
311 struct isp116x_ep **prev = &isp116x->periodic[i];
313 while (*prev && ((temp = *prev) != ep))
317 isp116x->load[i] -= ep->load;
319 ep->branch = PERIODIC_SIZE;
320 isp116x_to_hcd(isp116x)->self.bandwidth_allocated -=
321 ep->load / ep->period;
323 /* switch irq type? */
324 if (!--isp116x->periodic_count) {
325 isp116x->irqenb &= ~HCuPINT_SOF;
326 isp116x->irqenb |= HCuPINT_ATL;
331 Analyze transfer results, handle partial transfers and errors
333 static void postproc_atl_queue(struct isp116x *isp116x)
335 struct isp116x_ep *ep;
337 struct usb_device *udev;
343 for (ep = isp116x->atl_active; ep; ep = ep->active) {
344 BUG_ON(list_empty(&ep->hep->urb_list));
346 container_of(ep->hep->urb_list.next, struct urb, urb_list);
349 cc = PTD_GET_CC(ptd);
351 status = -EINPROGRESS;
353 /* Data underrun is special. For allowed underrun
354 we clear the error and continue as normal. For
355 forbidden underrun we finish the DATA stage
356 immediately while for control transfer,
357 we do a STATUS stage. */
358 if (cc == TD_DATAUNDERRUN) {
359 if (!(urb->transfer_flags & URB_SHORT_NOT_OK) ||
360 usb_pipecontrol(urb->pipe)) {
361 DBG("Allowed or control data underrun\n");
366 usb_settoggle(udev, ep->epnum,
367 ep->nextpid == USB_PID_OUT,
368 PTD_GET_TOGGLE(ptd));
369 urb->actual_length += PTD_GET_COUNT(ptd);
370 status = cc_to_error[TD_DATAUNDERRUN];
375 if (cc != TD_CC_NOERROR && cc != TD_NOTACCESSED
376 && (++ep->error_count >= 3 || cc == TD_CC_STALL
377 || cc == TD_DATAOVERRUN)) {
378 status = cc_to_error[cc];
379 if (ep->nextpid == USB_PID_ACK)
383 /* According to usb spec, zero-length Int transfer signals
384 finishing of the urb. Hey, does this apply only
386 if (usb_pipeint(urb->pipe) && !PTD_GET_LEN(ptd)) {
391 /* Relax after previously failed, but later succeeded
392 or correctly NAK'ed retransmission attempt */
394 && (cc == TD_CC_NOERROR || cc == TD_NOTACCESSED))
397 /* Take into account idiosyncracies of the isp116x chip
398 regarding toggle bit for failed transfers */
399 if (ep->nextpid == USB_PID_OUT)
400 usb_settoggle(udev, ep->epnum, 1, PTD_GET_TOGGLE(ptd)
401 ^ (ep->error_count > 0));
402 else if (ep->nextpid == USB_PID_IN)
403 usb_settoggle(udev, ep->epnum, 0, PTD_GET_TOGGLE(ptd)
404 ^ (ep->error_count > 0));
406 switch (ep->nextpid) {
409 urb->actual_length += PTD_GET_COUNT(ptd);
410 if (PTD_GET_ACTIVE(ptd)
411 || (cc != TD_CC_NOERROR && cc < 0x0E))
413 if (urb->transfer_buffer_length != urb->actual_length) {
417 if (urb->transfer_flags & URB_ZERO_PACKET
418 && ep->nextpid == USB_PID_OUT
419 && !(PTD_GET_COUNT(ptd) % ep->maxpacket)) {
420 DBG("Zero packet requested\n");
424 /* All data for this URB is transferred, let's finish */
425 if (usb_pipecontrol(urb->pipe))
426 ep->nextpid = USB_PID_ACK;
431 if (PTD_GET_ACTIVE(ptd)
432 || (cc != TD_CC_NOERROR && cc < 0x0E))
434 if (urb->transfer_buffer_length == urb->actual_length)
435 ep->nextpid = USB_PID_ACK;
436 else if (usb_pipeout(urb->pipe)) {
437 usb_settoggle(udev, 0, 1, 1);
438 ep->nextpid = USB_PID_OUT;
440 usb_settoggle(udev, 0, 0, 1);
441 ep->nextpid = USB_PID_IN;
445 if (PTD_GET_ACTIVE(ptd)
446 || (cc != TD_CC_NOERROR && cc < 0x0E))
456 if (status != -EINPROGRESS || urb->unlinked)
457 finish_request(isp116x, ep, urb, status);
462 Scan transfer lists, schedule transfers, send data off
465 static void start_atl_transfers(struct isp116x *isp116x)
467 struct isp116x_ep *last_ep = NULL, *ep;
470 int len, index, speed, byte_time;
472 if (atomic_read(&isp116x->atl_finishing))
475 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x)->state))
478 /* FIFO not empty? */
479 if (isp116x_read_reg16(isp116x, HCBUFSTAT) & HCBUFSTAT_ATL_FULL)
482 isp116x->atl_active = NULL;
483 isp116x->atl_buflen = isp116x->atl_bufshrt = 0;
485 /* Schedule int transfers */
486 if (isp116x->periodic_count) {
487 isp116x->fmindex = index =
488 (isp116x->fmindex + 1) & (PERIODIC_SIZE - 1);
489 if ((load = isp116x->load[index])) {
490 /* Bring all int transfers for this frame
491 into the active queue */
492 isp116x->atl_active = last_ep =
493 isp116x->periodic[index];
494 while (last_ep->next)
495 last_ep = (last_ep->active = last_ep->next);
496 last_ep->active = NULL;
500 /* Schedule control/bulk transfers */
501 list_for_each_entry(ep, &isp116x->async, schedule) {
502 urb = container_of(ep->hep->urb_list.next,
503 struct urb, urb_list);
504 speed = urb->dev->speed;
505 byte_time = speed == USB_SPEED_LOW
506 ? BYTE_TIME_LOWSPEED : BYTE_TIME_FULLSPEED;
508 if (ep->nextpid == USB_PID_SETUP) {
509 len = sizeof(struct usb_ctrlrequest);
510 } else if (ep->nextpid == USB_PID_ACK) {
513 /* Find current free length ... */
514 len = (MAX_LOAD_LIMIT - load) / byte_time;
516 /* ... then limit it to configured max size ... */
517 len = min(len, speed == USB_SPEED_LOW ?
518 MAX_TRANSFER_SIZE_LOWSPEED :
519 MAX_TRANSFER_SIZE_FULLSPEED);
521 /* ... and finally cut to the multiple of MaxPacketSize,
522 or to the real length if there's enough room. */
524 (urb->transfer_buffer_length -
525 urb->actual_length)) {
526 len -= len % ep->maxpacket;
530 len = urb->transfer_buffer_length -
535 load += len * byte_time;
536 if (load > MAX_LOAD_LIMIT)
542 last_ep->active = ep;
544 isp116x->atl_active = ep;
548 /* Avoid starving of endpoints */
549 if ((&isp116x->async)->next != (&isp116x->async)->prev)
550 list_move(&isp116x->async, (&isp116x->async)->next);
552 if (isp116x->atl_active) {
553 preproc_atl_queue(isp116x);
559 Finish the processed transfers
561 static void finish_atl_transfers(struct isp116x *isp116x)
563 if (!isp116x->atl_active)
565 /* Fifo not ready? */
566 if (!(isp116x_read_reg16(isp116x, HCBUFSTAT) & HCBUFSTAT_ATL_DONE))
569 atomic_inc(&isp116x->atl_finishing);
570 unpack_fifo(isp116x);
571 postproc_atl_queue(isp116x);
572 atomic_dec(&isp116x->atl_finishing);
575 static irqreturn_t isp116x_irq(struct usb_hcd *hcd)
577 struct isp116x *isp116x = hcd_to_isp116x(hcd);
579 irqreturn_t ret = IRQ_NONE;
581 spin_lock(&isp116x->lock);
582 isp116x_write_reg16(isp116x, HCuPINTENB, 0);
583 irqstat = isp116x_read_reg16(isp116x, HCuPINT);
584 isp116x_write_reg16(isp116x, HCuPINT, irqstat);
586 if (irqstat & (HCuPINT_ATL | HCuPINT_SOF)) {
588 finish_atl_transfers(isp116x);
591 if (irqstat & HCuPINT_OPR) {
592 u32 intstat = isp116x_read_reg32(isp116x, HCINTSTAT);
593 isp116x_write_reg32(isp116x, HCINTSTAT, intstat);
594 if (intstat & HCINT_UE) {
595 ERR("Unrecoverable error, HC is dead!\n");
596 /* IRQ's are off, we do no DMA,
597 perfectly ready to die ... */
598 hcd->state = HC_STATE_HALT;
602 if (intstat & HCINT_RHSC)
603 /* When root hub or any of its ports is going
604 to come out of suspend, it may take more
605 than 10ms for status bits to stabilize. */
606 mod_timer(&hcd->rh_timer, jiffies
607 + msecs_to_jiffies(20) + 1);
608 if (intstat & HCINT_RD) {
609 DBG("---- remote wakeup\n");
610 usb_hcd_resume_root_hub(hcd);
612 irqstat &= ~HCuPINT_OPR;
616 if (irqstat & (HCuPINT_ATL | HCuPINT_SOF)) {
617 start_atl_transfers(isp116x);
620 isp116x_write_reg16(isp116x, HCuPINTENB, isp116x->irqenb);
622 spin_unlock(&isp116x->lock);
626 /*-----------------------------------------------------------------*/
628 /* usb 1.1 says max 90% of a frame is available for periodic transfers.
629 * this driver doesn't promise that much since it's got to handle an
630 * IRQ per packet; irq handling latencies also use up that time.
634 #define MAX_PERIODIC_LOAD 600
635 static int balance(struct isp116x *isp116x, u16 period, u16 load)
637 int i, branch = -ENOSPC;
639 /* search for the least loaded schedule branch of that period
640 which has enough bandwidth left unreserved. */
641 for (i = 0; i < period; i++) {
642 if (branch < 0 || isp116x->load[branch] > isp116x->load[i]) {
645 for (j = i; j < PERIODIC_SIZE; j += period) {
646 if ((isp116x->load[j] + load)
650 if (j < PERIODIC_SIZE)
658 /* NB! ALL the code above this point runs with isp116x->lock
662 /*-----------------------------------------------------------------*/
664 static int isp116x_urb_enqueue(struct usb_hcd *hcd,
668 struct isp116x *isp116x = hcd_to_isp116x(hcd);
669 struct usb_device *udev = urb->dev;
670 unsigned int pipe = urb->pipe;
671 int is_out = !usb_pipein(pipe);
672 int type = usb_pipetype(pipe);
673 int epnum = usb_pipeendpoint(pipe);
674 struct usb_host_endpoint *hep = urb->ep;
675 struct isp116x_ep *ep = NULL;
680 urb_dbg(urb, "Enqueue");
682 if (type == PIPE_ISOCHRONOUS) {
683 ERR("Isochronous transfers not supported\n");
684 urb_dbg(urb, "Refused to enqueue");
687 /* avoid all allocations within spinlocks: request or endpoint */
689 ep = kzalloc(sizeof *ep, mem_flags);
694 spin_lock_irqsave(&isp116x->lock, flags);
695 if (!HC_IS_RUNNING(hcd->state)) {
698 goto fail_not_linked;
700 ret = usb_hcd_link_urb_to_ep(hcd, urb);
703 goto fail_not_linked;
709 INIT_LIST_HEAD(&ep->schedule);
712 ep->maxpacket = usb_maxpacket(udev, urb->pipe, is_out);
713 usb_settoggle(udev, epnum, is_out, 0);
715 if (type == PIPE_CONTROL) {
716 ep->nextpid = USB_PID_SETUP;
718 ep->nextpid = USB_PID_OUT;
720 ep->nextpid = USB_PID_IN;
725 With INT URBs submitted, the driver works with SOF
726 interrupt enabled and ATL interrupt disabled. After
727 the PTDs are written to fifo ram, the chip starts
728 fifo processing and usb transfers after the next
729 SOF and continues until the transfers are finished
730 (succeeded or failed) or the frame ends. Therefore,
731 the transfers occur only in every second frame,
732 while fifo reading/writing and data processing
733 occur in every other second frame. */
734 if (urb->interval < 2)
736 if (urb->interval > 2 * PERIODIC_SIZE)
737 urb->interval = 2 * PERIODIC_SIZE;
738 ep->period = urb->interval >> 1;
739 ep->branch = PERIODIC_SIZE;
740 ep->load = usb_calc_bus_time(udev->speed,
742 (type == PIPE_ISOCHRONOUS),
743 usb_maxpacket(udev, pipe,
751 /* maybe put endpoint into schedule */
755 if (list_empty(&ep->schedule))
756 list_add_tail(&ep->schedule, &isp116x->async);
759 urb->interval = ep->period;
760 ep->length = min((int)ep->maxpacket,
761 urb->transfer_buffer_length);
763 /* urb submitted for already existing endpoint */
764 if (ep->branch < PERIODIC_SIZE)
767 ep->branch = ret = balance(isp116x, ep->period, ep->load);
772 urb->start_frame = (isp116x->fmindex & (PERIODIC_SIZE - 1))
775 /* sort each schedule branch by period (slow before fast)
776 to share the faster parts of the tree without needing
777 dummy/placeholder nodes */
778 DBG("schedule qh%d/%p branch %d\n", ep->period, ep, ep->branch);
779 for (i = ep->branch; i < PERIODIC_SIZE; i += ep->period) {
780 struct isp116x_ep **prev = &isp116x->periodic[i];
781 struct isp116x_ep *here = *prev;
783 while (here && ep != here) {
784 if (ep->period > here->period)
793 isp116x->load[i] += ep->load;
795 hcd->self.bandwidth_allocated += ep->load / ep->period;
797 /* switch over to SOFint */
798 if (!isp116x->periodic_count++) {
799 isp116x->irqenb &= ~HCuPINT_ATL;
800 isp116x->irqenb |= HCuPINT_SOF;
801 isp116x_write_reg16(isp116x, HCuPINTENB,
807 start_atl_transfers(isp116x);
811 usb_hcd_unlink_urb_from_ep(hcd, urb);
813 spin_unlock_irqrestore(&isp116x->lock, flags);
820 static int isp116x_urb_dequeue(struct usb_hcd *hcd, struct urb *urb,
823 struct isp116x *isp116x = hcd_to_isp116x(hcd);
824 struct usb_host_endpoint *hep;
825 struct isp116x_ep *ep, *ep_act;
829 spin_lock_irqsave(&isp116x->lock, flags);
830 rc = usb_hcd_check_unlink_urb(hcd, urb, status);
836 WARN_ON(hep != ep->hep);
838 /* In front of queue? */
839 if (ep->hep->urb_list.next == &urb->urb_list)
841 for (ep_act = isp116x->atl_active; ep_act;
842 ep_act = ep_act->active)
844 VDBG("dequeue, urb %p active; wait for irq\n",
851 finish_request(isp116x, ep, urb, status);
853 spin_unlock_irqrestore(&isp116x->lock, flags);
857 static void isp116x_endpoint_disable(struct usb_hcd *hcd,
858 struct usb_host_endpoint *hep)
861 struct isp116x_ep *ep = hep->hcpriv;
866 /* assume we'd just wait for the irq */
867 for (i = 0; i < 100 && !list_empty(&hep->urb_list); i++)
869 if (!list_empty(&hep->urb_list))
870 WARN("ep %p not empty?\n", ep);
876 static int isp116x_get_frame(struct usb_hcd *hcd)
878 struct isp116x *isp116x = hcd_to_isp116x(hcd);
882 spin_lock_irqsave(&isp116x->lock, flags);
883 fmnum = isp116x_read_reg32(isp116x, HCFMNUM);
884 spin_unlock_irqrestore(&isp116x->lock, flags);
889 Adapted from ohci-hub.c. Currently we don't support autosuspend.
891 static int isp116x_hub_status_data(struct usb_hcd *hcd, char *buf)
893 struct isp116x *isp116x = hcd_to_isp116x(hcd);
894 int ports, i, changed = 0;
897 if (!HC_IS_RUNNING(hcd->state))
900 /* Report no status change now, if we are scheduled to be
902 if (timer_pending(&hcd->rh_timer))
905 ports = isp116x->rhdesca & RH_A_NDP;
906 spin_lock_irqsave(&isp116x->lock, flags);
907 isp116x->rhstatus = isp116x_read_reg32(isp116x, HCRHSTATUS);
908 if (isp116x->rhstatus & (RH_HS_LPSC | RH_HS_OCIC))
909 buf[0] = changed = 1;
913 for (i = 0; i < ports; i++) {
914 u32 status = isp116x_read_reg32(isp116x, i ? HCRHPORT2 : HCRHPORT1);
916 if (status & (RH_PS_CSC | RH_PS_PESC | RH_PS_PSSC
917 | RH_PS_OCIC | RH_PS_PRSC)) {
919 buf[0] |= 1 << (i + 1);
922 spin_unlock_irqrestore(&isp116x->lock, flags);
926 static void isp116x_hub_descriptor(struct isp116x *isp116x,
927 struct usb_hub_descriptor *desc)
929 u32 reg = isp116x->rhdesca;
931 desc->bDescriptorType = 0x29;
932 desc->bDescLength = 9;
933 desc->bHubContrCurrent = 0;
934 desc->bNbrPorts = (u8) (reg & 0x3);
935 /* Power switching, device type, overcurrent. */
936 desc->wHubCharacteristics = cpu_to_le16((u16) ((reg >> 8) & 0x1f));
937 desc->bPwrOn2PwrGood = (u8) ((reg >> 24) & 0xff);
938 /* two bitmaps: ports removable, and legacy PortPwrCtrlMask */
940 desc->bitmap[1] = ~0;
943 /* Perform reset of a given port.
944 It would be great to just start the reset and let the
945 USB core to clear the reset in due time. However,
946 root hub ports should be reset for at least 50 ms, while
947 our chip stays in reset for about 10 ms. I.e., we must
948 repeatedly reset it ourself here.
950 static inline void root_port_reset(struct isp116x *isp116x, unsigned port)
953 unsigned long flags, t;
955 /* Root hub reset should be 50 ms, but some devices
956 want it even longer. */
957 t = jiffies + msecs_to_jiffies(100);
959 while (time_before(jiffies, t)) {
960 spin_lock_irqsave(&isp116x->lock, flags);
961 /* spin until any current reset finishes */
963 tmp = isp116x_read_reg32(isp116x, port ?
964 HCRHPORT2 : HCRHPORT1);
965 if (!(tmp & RH_PS_PRS))
969 /* Don't reset a disconnected port */
970 if (!(tmp & RH_PS_CCS)) {
971 spin_unlock_irqrestore(&isp116x->lock, flags);
974 /* Reset lasts 10ms (claims datasheet) */
975 isp116x_write_reg32(isp116x, port ? HCRHPORT2 :
976 HCRHPORT1, (RH_PS_PRS));
977 spin_unlock_irqrestore(&isp116x->lock, flags);
982 /* Adapted from ohci-hub.c */
983 static int isp116x_hub_control(struct usb_hcd *hcd,
985 u16 wValue, u16 wIndex, char *buf, u16 wLength)
987 struct isp116x *isp116x = hcd_to_isp116x(hcd);
990 int ports = isp116x->rhdesca & RH_A_NDP;
994 case ClearHubFeature:
995 DBG("ClearHubFeature: ");
997 case C_HUB_OVER_CURRENT:
998 DBG("C_HUB_OVER_CURRENT\n");
999 spin_lock_irqsave(&isp116x->lock, flags);
1000 isp116x_write_reg32(isp116x, HCRHSTATUS, RH_HS_OCIC);
1001 spin_unlock_irqrestore(&isp116x->lock, flags);
1002 case C_HUB_LOCAL_POWER:
1003 DBG("C_HUB_LOCAL_POWER\n");
1010 DBG("SetHubFeature: ");
1012 case C_HUB_OVER_CURRENT:
1013 case C_HUB_LOCAL_POWER:
1014 DBG("C_HUB_OVER_CURRENT or C_HUB_LOCAL_POWER\n");
1020 case GetHubDescriptor:
1021 DBG("GetHubDescriptor\n");
1022 isp116x_hub_descriptor(isp116x,
1023 (struct usb_hub_descriptor *)buf);
1026 DBG("GetHubStatus\n");
1027 *(__le32 *) buf = 0;
1030 DBG("GetPortStatus\n");
1031 if (!wIndex || wIndex > ports)
1033 spin_lock_irqsave(&isp116x->lock, flags);
1034 tmp = isp116x_read_reg32(isp116x, (--wIndex) ? HCRHPORT2 : HCRHPORT1);
1035 spin_unlock_irqrestore(&isp116x->lock, flags);
1036 *(__le32 *) buf = cpu_to_le32(tmp);
1037 DBG("GetPortStatus: port[%d] %08x\n", wIndex + 1, tmp);
1039 case ClearPortFeature:
1040 DBG("ClearPortFeature: ");
1041 if (!wIndex || wIndex > ports)
1046 case USB_PORT_FEAT_ENABLE:
1047 DBG("USB_PORT_FEAT_ENABLE\n");
1050 case USB_PORT_FEAT_C_ENABLE:
1051 DBG("USB_PORT_FEAT_C_ENABLE\n");
1054 case USB_PORT_FEAT_SUSPEND:
1055 DBG("USB_PORT_FEAT_SUSPEND\n");
1058 case USB_PORT_FEAT_C_SUSPEND:
1059 DBG("USB_PORT_FEAT_C_SUSPEND\n");
1062 case USB_PORT_FEAT_POWER:
1063 DBG("USB_PORT_FEAT_POWER\n");
1066 case USB_PORT_FEAT_C_CONNECTION:
1067 DBG("USB_PORT_FEAT_C_CONNECTION\n");
1070 case USB_PORT_FEAT_C_OVER_CURRENT:
1071 DBG("USB_PORT_FEAT_C_OVER_CURRENT\n");
1074 case USB_PORT_FEAT_C_RESET:
1075 DBG("USB_PORT_FEAT_C_RESET\n");
1081 spin_lock_irqsave(&isp116x->lock, flags);
1082 isp116x_write_reg32(isp116x, wIndex
1083 ? HCRHPORT2 : HCRHPORT1, tmp);
1084 spin_unlock_irqrestore(&isp116x->lock, flags);
1086 case SetPortFeature:
1087 DBG("SetPortFeature: ");
1088 if (!wIndex || wIndex > ports)
1092 case USB_PORT_FEAT_SUSPEND:
1093 DBG("USB_PORT_FEAT_SUSPEND\n");
1094 spin_lock_irqsave(&isp116x->lock, flags);
1095 isp116x_write_reg32(isp116x, wIndex
1096 ? HCRHPORT2 : HCRHPORT1, RH_PS_PSS);
1097 spin_unlock_irqrestore(&isp116x->lock, flags);
1099 case USB_PORT_FEAT_POWER:
1100 DBG("USB_PORT_FEAT_POWER\n");
1101 spin_lock_irqsave(&isp116x->lock, flags);
1102 isp116x_write_reg32(isp116x, wIndex
1103 ? HCRHPORT2 : HCRHPORT1, RH_PS_PPS);
1104 spin_unlock_irqrestore(&isp116x->lock, flags);
1106 case USB_PORT_FEAT_RESET:
1107 DBG("USB_PORT_FEAT_RESET\n");
1108 root_port_reset(isp116x, wIndex);
1117 /* "protocol stall" on error */
1118 DBG("PROTOCOL STALL\n");
1124 /*-----------------------------------------------------------------*/
1126 #ifdef CONFIG_DEBUG_FS
1128 static void dump_irq(struct seq_file *s, char *label, u16 mask)
1130 seq_printf(s, "%s %04x%s%s%s%s%s%s\n", label, mask,
1131 mask & HCuPINT_CLKRDY ? " clkrdy" : "",
1132 mask & HCuPINT_SUSP ? " susp" : "",
1133 mask & HCuPINT_OPR ? " opr" : "",
1134 mask & HCuPINT_AIIEOT ? " eot" : "",
1135 mask & HCuPINT_ATL ? " atl" : "",
1136 mask & HCuPINT_SOF ? " sof" : "");
1139 static void dump_int(struct seq_file *s, char *label, u32 mask)
1141 seq_printf(s, "%s %08x%s%s%s%s%s%s%s\n", label, mask,
1142 mask & HCINT_MIE ? " MIE" : "",
1143 mask & HCINT_RHSC ? " rhsc" : "",
1144 mask & HCINT_FNO ? " fno" : "",
1145 mask & HCINT_UE ? " ue" : "",
1146 mask & HCINT_RD ? " rd" : "",
1147 mask & HCINT_SF ? " sof" : "", mask & HCINT_SO ? " so" : "");
1150 static int isp116x_show_dbg(struct seq_file *s, void *unused)
1152 struct isp116x *isp116x = s->private;
1154 seq_printf(s, "%s\n%s version %s\n",
1155 isp116x_to_hcd(isp116x)->product_desc, hcd_name,
1158 if (HC_IS_SUSPENDED(isp116x_to_hcd(isp116x)->state)) {
1159 seq_printf(s, "HCD is suspended\n");
1162 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x)->state)) {
1163 seq_printf(s, "HCD not running\n");
1167 spin_lock_irq(&isp116x->lock);
1168 dump_irq(s, "hc_irq_enable", isp116x_read_reg16(isp116x, HCuPINTENB));
1169 dump_irq(s, "hc_irq_status", isp116x_read_reg16(isp116x, HCuPINT));
1170 dump_int(s, "hc_int_enable", isp116x_read_reg32(isp116x, HCINTENB));
1171 dump_int(s, "hc_int_status", isp116x_read_reg32(isp116x, HCINTSTAT));
1172 isp116x_show_regs_seq(isp116x, s);
1173 spin_unlock_irq(&isp116x->lock);
1174 seq_printf(s, "\n");
1179 static int isp116x_open_seq(struct inode *inode, struct file *file)
1181 return single_open(file, isp116x_show_dbg, inode->i_private);
1184 static const struct file_operations isp116x_debug_fops = {
1185 .open = isp116x_open_seq,
1187 .llseek = seq_lseek,
1188 .release = single_release,
1191 static int create_debug_file(struct isp116x *isp116x)
1193 isp116x->dentry = debugfs_create_file(hcd_name,
1194 S_IRUGO, NULL, isp116x,
1195 &isp116x_debug_fops);
1196 if (!isp116x->dentry)
1201 static void remove_debug_file(struct isp116x *isp116x)
1203 debugfs_remove(isp116x->dentry);
1208 #define create_debug_file(d) 0
1209 #define remove_debug_file(d) do{}while(0)
1211 #endif /* CONFIG_DEBUG_FS */
1213 /*-----------------------------------------------------------------*/
1216 Software reset - can be called from any contect.
1218 static int isp116x_sw_reset(struct isp116x *isp116x)
1221 unsigned long flags;
1224 spin_lock_irqsave(&isp116x->lock, flags);
1225 isp116x_write_reg16(isp116x, HCSWRES, HCSWRES_MAGIC);
1226 isp116x_write_reg32(isp116x, HCCMDSTAT, HCCMDSTAT_HCR);
1228 /* It usually resets within 1 ms */
1230 if (!(isp116x_read_reg32(isp116x, HCCMDSTAT) & HCCMDSTAT_HCR))
1234 ERR("Software reset timeout\n");
1237 spin_unlock_irqrestore(&isp116x->lock, flags);
1241 static int isp116x_reset(struct usb_hcd *hcd)
1243 struct isp116x *isp116x = hcd_to_isp116x(hcd);
1246 int ret, timeout = 15 /* ms */ ;
1248 ret = isp116x_sw_reset(isp116x);
1252 t = jiffies + msecs_to_jiffies(timeout);
1253 while (time_before_eq(jiffies, t)) {
1255 spin_lock_irq(&isp116x->lock);
1256 clkrdy = isp116x_read_reg16(isp116x, HCuPINT) & HCuPINT_CLKRDY;
1257 spin_unlock_irq(&isp116x->lock);
1262 ERR("Clock not ready after %dms\n", timeout);
1263 /* After sw_reset the clock won't report to be ready, if
1264 H_WAKEUP pin is high. */
1265 ERR("Please make sure that the H_WAKEUP pin is pulled low!\n");
1271 static void isp116x_stop(struct usb_hcd *hcd)
1273 struct isp116x *isp116x = hcd_to_isp116x(hcd);
1274 unsigned long flags;
1277 spin_lock_irqsave(&isp116x->lock, flags);
1278 isp116x_write_reg16(isp116x, HCuPINTENB, 0);
1280 /* Switch off ports' power, some devices don't come up
1281 after next 'insmod' without this */
1282 val = isp116x_read_reg32(isp116x, HCRHDESCA);
1283 val &= ~(RH_A_NPS | RH_A_PSM);
1284 isp116x_write_reg32(isp116x, HCRHDESCA, val);
1285 isp116x_write_reg32(isp116x, HCRHSTATUS, RH_HS_LPS);
1286 spin_unlock_irqrestore(&isp116x->lock, flags);
1288 isp116x_sw_reset(isp116x);
1292 Configure the chip. The chip must be successfully reset by now.
1294 static int isp116x_start(struct usb_hcd *hcd)
1296 struct isp116x *isp116x = hcd_to_isp116x(hcd);
1297 struct isp116x_platform_data *board = isp116x->board;
1299 unsigned long flags;
1301 spin_lock_irqsave(&isp116x->lock, flags);
1303 /* clear interrupt status and disable all interrupt sources */
1304 isp116x_write_reg16(isp116x, HCuPINT, 0xff);
1305 isp116x_write_reg16(isp116x, HCuPINTENB, 0);
1307 val = isp116x_read_reg16(isp116x, HCCHIPID);
1308 if ((val & HCCHIPID_MASK) != HCCHIPID_MAGIC) {
1309 ERR("Invalid chip ID %04x\n", val);
1310 spin_unlock_irqrestore(&isp116x->lock, flags);
1314 /* To be removed in future */
1315 hcd->uses_new_polling = 1;
1317 isp116x_write_reg16(isp116x, HCITLBUFLEN, ISP116x_ITL_BUFSIZE);
1318 isp116x_write_reg16(isp116x, HCATLBUFLEN, ISP116x_ATL_BUFSIZE);
1321 val = HCHWCFG_INT_ENABLE | HCHWCFG_DBWIDTH(1);
1322 if (board->sel15Kres)
1323 val |= HCHWCFG_15KRSEL;
1324 /* Remote wakeup won't work without working clock */
1325 if (board->remote_wakeup_enable)
1326 val |= HCHWCFG_CLKNOTSTOP;
1327 if (board->oc_enable)
1328 val |= HCHWCFG_ANALOG_OC;
1329 if (board->int_act_high)
1330 val |= HCHWCFG_INT_POL;
1331 if (board->int_edge_triggered)
1332 val |= HCHWCFG_INT_TRIGGER;
1333 isp116x_write_reg16(isp116x, HCHWCFG, val);
1335 /* ----- Root hub conf */
1336 val = (25 << 24) & RH_A_POTPGT;
1337 /* AN10003_1.pdf recommends RH_A_NPS (no power switching) to
1338 be always set. Yet, instead, we request individual port
1341 /* Report overcurrent per port */
1343 isp116x_write_reg32(isp116x, HCRHDESCA, val);
1344 isp116x->rhdesca = isp116x_read_reg32(isp116x, HCRHDESCA);
1347 isp116x_write_reg32(isp116x, HCRHDESCB, val);
1348 isp116x->rhdescb = isp116x_read_reg32(isp116x, HCRHDESCB);
1351 if (board->remote_wakeup_enable) {
1352 if (!device_can_wakeup(hcd->self.controller))
1353 device_init_wakeup(hcd->self.controller, 1);
1356 isp116x_write_reg32(isp116x, HCRHSTATUS, val);
1357 isp116x->rhstatus = isp116x_read_reg32(isp116x, HCRHSTATUS);
1359 isp116x_write_reg32(isp116x, HCFMINTVL, 0x27782edf);
1361 hcd->state = HC_STATE_RUNNING;
1363 /* Set up interrupts */
1364 isp116x->intenb = HCINT_MIE | HCINT_RHSC | HCINT_UE;
1365 if (board->remote_wakeup_enable)
1366 isp116x->intenb |= HCINT_RD;
1367 isp116x->irqenb = HCuPINT_ATL | HCuPINT_OPR; /* | HCuPINT_SUSP; */
1368 isp116x_write_reg32(isp116x, HCINTENB, isp116x->intenb);
1369 isp116x_write_reg16(isp116x, HCuPINTENB, isp116x->irqenb);
1371 /* Go operational */
1372 val = HCCONTROL_USB_OPER;
1373 if (board->remote_wakeup_enable)
1374 val |= HCCONTROL_RWE;
1375 isp116x_write_reg32(isp116x, HCCONTROL, val);
1377 /* Disable ports to avoid race in device enumeration */
1378 isp116x_write_reg32(isp116x, HCRHPORT1, RH_PS_CCS);
1379 isp116x_write_reg32(isp116x, HCRHPORT2, RH_PS_CCS);
1381 isp116x_show_regs_log(isp116x);
1382 spin_unlock_irqrestore(&isp116x->lock, flags);
1388 static int isp116x_bus_suspend(struct usb_hcd *hcd)
1390 struct isp116x *isp116x = hcd_to_isp116x(hcd);
1391 unsigned long flags;
1395 spin_lock_irqsave(&isp116x->lock, flags);
1396 val = isp116x_read_reg32(isp116x, HCCONTROL);
1398 switch (val & HCCONTROL_HCFS) {
1399 case HCCONTROL_USB_OPER:
1400 spin_unlock_irqrestore(&isp116x->lock, flags);
1401 val &= (~HCCONTROL_HCFS & ~HCCONTROL_RWE);
1402 val |= HCCONTROL_USB_SUSPEND;
1403 if (hcd->self.root_hub->do_remote_wakeup)
1404 val |= HCCONTROL_RWE;
1405 /* Wait for usb transfers to finish */
1407 spin_lock_irqsave(&isp116x->lock, flags);
1408 isp116x_write_reg32(isp116x, HCCONTROL, val);
1409 spin_unlock_irqrestore(&isp116x->lock, flags);
1410 /* Wait for devices to suspend */
1413 case HCCONTROL_USB_RESUME:
1414 isp116x_write_reg32(isp116x, HCCONTROL,
1415 (val & ~HCCONTROL_HCFS) |
1416 HCCONTROL_USB_RESET);
1417 case HCCONTROL_USB_RESET:
1419 default: /* HCCONTROL_USB_SUSPEND */
1420 spin_unlock_irqrestore(&isp116x->lock, flags);
1427 static int isp116x_bus_resume(struct usb_hcd *hcd)
1429 struct isp116x *isp116x = hcd_to_isp116x(hcd);
1433 spin_lock_irq(&isp116x->lock);
1435 val = isp116x_read_reg32(isp116x, HCCONTROL);
1436 switch (val & HCCONTROL_HCFS) {
1437 case HCCONTROL_USB_SUSPEND:
1438 val &= ~HCCONTROL_HCFS;
1439 val |= HCCONTROL_USB_RESUME;
1440 isp116x_write_reg32(isp116x, HCCONTROL, val);
1441 case HCCONTROL_USB_RESUME:
1443 case HCCONTROL_USB_OPER:
1444 spin_unlock_irq(&isp116x->lock);
1447 /* HCCONTROL_USB_RESET: this may happen, when during
1448 suspension the HC lost power. Reinitialize completely */
1449 spin_unlock_irq(&isp116x->lock);
1450 DBG("Chip has been reset while suspended. Reinit from scratch.\n");
1453 isp116x_hub_control(hcd, SetPortFeature,
1454 USB_PORT_FEAT_POWER, 1, NULL, 0);
1455 if ((isp116x->rhdesca & RH_A_NDP) == 2)
1456 isp116x_hub_control(hcd, SetPortFeature,
1457 USB_PORT_FEAT_POWER, 2, NULL, 0);
1461 val = isp116x->rhdesca & RH_A_NDP;
1464 isp116x_read_reg32(isp116x, val ? HCRHPORT2 : HCRHPORT1);
1465 /* force global, not selective, resume */
1466 if (!(stat & RH_PS_PSS))
1468 DBG("%s: Resuming port %d\n", __func__, val);
1469 isp116x_write_reg32(isp116x, RH_PS_POCI, val
1470 ? HCRHPORT2 : HCRHPORT1);
1472 spin_unlock_irq(&isp116x->lock);
1474 hcd->state = HC_STATE_RESUMING;
1477 /* Go operational */
1478 spin_lock_irq(&isp116x->lock);
1479 val = isp116x_read_reg32(isp116x, HCCONTROL);
1480 isp116x_write_reg32(isp116x, HCCONTROL,
1481 (val & ~HCCONTROL_HCFS) | HCCONTROL_USB_OPER);
1482 spin_unlock_irq(&isp116x->lock);
1483 hcd->state = HC_STATE_RUNNING;
1490 #define isp116x_bus_suspend NULL
1491 #define isp116x_bus_resume NULL
1495 static struct hc_driver isp116x_hc_driver = {
1496 .description = hcd_name,
1497 .product_desc = "ISP116x Host Controller",
1498 .hcd_priv_size = sizeof(struct isp116x),
1503 .reset = isp116x_reset,
1504 .start = isp116x_start,
1505 .stop = isp116x_stop,
1507 .urb_enqueue = isp116x_urb_enqueue,
1508 .urb_dequeue = isp116x_urb_dequeue,
1509 .endpoint_disable = isp116x_endpoint_disable,
1511 .get_frame_number = isp116x_get_frame,
1513 .hub_status_data = isp116x_hub_status_data,
1514 .hub_control = isp116x_hub_control,
1515 .bus_suspend = isp116x_bus_suspend,
1516 .bus_resume = isp116x_bus_resume,
1519 /*----------------------------------------------------------------*/
1521 static int isp116x_remove(struct platform_device *pdev)
1523 struct usb_hcd *hcd = platform_get_drvdata(pdev);
1524 struct isp116x *isp116x;
1525 struct resource *res;
1529 isp116x = hcd_to_isp116x(hcd);
1530 remove_debug_file(isp116x);
1531 usb_remove_hcd(hcd);
1533 iounmap(isp116x->data_reg);
1534 res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
1535 release_mem_region(res->start, 2);
1536 iounmap(isp116x->addr_reg);
1537 res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1538 release_mem_region(res->start, 2);
1544 #define resource_len(r) (((r)->end - (r)->start) + 1)
1546 static int __devinit isp116x_probe(struct platform_device *pdev)
1548 struct usb_hcd *hcd;
1549 struct isp116x *isp116x;
1550 struct resource *addr, *data;
1551 void __iomem *addr_reg;
1552 void __iomem *data_reg;
1556 if (pdev->num_resources < 3) {
1561 data = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1562 addr = platform_get_resource(pdev, IORESOURCE_MEM, 1);
1563 irq = platform_get_irq(pdev, 0);
1564 if (!addr || !data || irq < 0) {
1569 if (pdev->dev.dma_mask) {
1570 DBG("DMA not supported\n");
1575 if (!request_mem_region(addr->start, 2, hcd_name)) {
1579 addr_reg = ioremap(addr->start, resource_len(addr));
1580 if (addr_reg == NULL) {
1584 if (!request_mem_region(data->start, 2, hcd_name)) {
1588 data_reg = ioremap(data->start, resource_len(data));
1589 if (data_reg == NULL) {
1594 /* allocate and initialize hcd */
1595 hcd = usb_create_hcd(&isp116x_hc_driver, &pdev->dev, pdev->dev.bus_id);
1600 /* this rsrc_start is bogus */
1601 hcd->rsrc_start = addr->start;
1602 isp116x = hcd_to_isp116x(hcd);
1603 isp116x->data_reg = data_reg;
1604 isp116x->addr_reg = addr_reg;
1605 spin_lock_init(&isp116x->lock);
1606 INIT_LIST_HEAD(&isp116x->async);
1607 isp116x->board = pdev->dev.platform_data;
1609 if (!isp116x->board) {
1610 ERR("Platform data structure not initialized\n");
1614 if (isp116x_check_platform_delay(isp116x)) {
1615 ERR("USE_PLATFORM_DELAY defined, but delay function not "
1617 ERR("See comments in drivers/usb/host/isp116x-hcd.c\n");
1622 ret = usb_add_hcd(hcd, irq, IRQF_DISABLED);
1626 ret = create_debug_file(isp116x);
1628 ERR("Couldn't create debugfs entry\n");
1635 usb_remove_hcd(hcd);
1641 release_mem_region(data->start, 2);
1645 release_mem_region(addr->start, 2);
1647 ERR("init error, %d\n", ret);
1653 Suspend of platform device
1655 static int isp116x_suspend(struct platform_device *dev, pm_message_t state)
1657 VDBG("%s: state %x\n", __func__, state.event);
1662 Resume platform device
1664 static int isp116x_resume(struct platform_device *dev)
1666 VDBG("%s\n", __func__);
1672 #define isp116x_suspend NULL
1673 #define isp116x_resume NULL
1677 /* work with hotplug and coldplug */
1678 MODULE_ALIAS("platform:isp116x-hcd");
1680 static struct platform_driver isp116x_driver = {
1681 .probe = isp116x_probe,
1682 .remove = isp116x_remove,
1683 .suspend = isp116x_suspend,
1684 .resume = isp116x_resume,
1686 .name = (char *)hcd_name,
1687 .owner = THIS_MODULE,
1691 /*-----------------------------------------------------------------*/
1693 static int __init isp116x_init(void)
1698 INFO("driver %s, %s\n", hcd_name, DRIVER_VERSION);
1699 return platform_driver_register(&isp116x_driver);
1702 module_init(isp116x_init);
1704 static void __exit isp116x_cleanup(void)
1706 platform_driver_unregister(&isp116x_driver);
1709 module_exit(isp116x_cleanup);