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/slab.h>
66 #include <linux/usb.h>
67 #include <linux/usb/isp116x.h>
68 #include <linux/usb/hcd.h>
69 #include <linux/platform_device.h>
73 #include <asm/byteorder.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 /* buffer is already in 'usb data order', which is LE. */
98 /* When reading buffer as u16, we have to take care byte order */
99 /* doesn't get mixed up */
101 if ((unsigned long)dp2
& 1) {
103 for (; len
> 1; len
-= 2) {
106 isp116x_raw_write_data16(isp116x
, w
);
109 isp116x_write_data16(isp116x
, (u16
) * dp
);
112 for (; len
> 1; len
-= 2) {
113 /* Keep byte order ! */
114 isp116x_raw_write_data16(isp116x
, cpu_to_le16(*dp2
++));
118 isp116x_write_data16(isp116x
, 0xff & *((u8
*) dp2
));
120 if (quot
== 1 || quot
== 2)
121 isp116x_raw_write_data16(isp116x
, 0);
125 Read len bytes from fifo and then read till 32-bit boundary.
127 static void read_ptddata_from_fifo(struct isp116x
*isp116x
, void *buf
, int len
)
130 u16
*dp2
= (u16
*) buf
;
134 /* buffer is already in 'usb data order', which is LE. */
135 /* When reading buffer as u16, we have to take care byte order */
136 /* doesn't get mixed up */
138 if ((unsigned long)dp2
& 1) {
140 for (; len
> 1; len
-= 2) {
141 w
= isp116x_raw_read_data16(isp116x
);
143 *dp
++ = (w
>> 8) & 0xff;
147 *dp
= 0xff & isp116x_read_data16(isp116x
);
150 for (; len
> 1; len
-= 2) {
151 /* Keep byte order! */
152 *dp2
++ = le16_to_cpu(isp116x_raw_read_data16(isp116x
));
156 *(u8
*) dp2
= 0xff & isp116x_read_data16(isp116x
);
158 if (quot
== 1 || quot
== 2)
159 isp116x_raw_read_data16(isp116x
);
163 Write ptd's and data for scheduled transfers into
164 the fifo ram. Fifo must be empty and ready.
166 static void pack_fifo(struct isp116x
*isp116x
)
168 struct isp116x_ep
*ep
;
170 int buflen
= isp116x
->atl_last_dir
== PTD_DIR_IN
171 ? isp116x
->atl_bufshrt
: isp116x
->atl_buflen
;
173 isp116x_write_reg16(isp116x
, HCuPINT
, HCuPINT_AIIEOT
);
174 isp116x_write_reg16(isp116x
, HCXFERCTR
, buflen
);
175 isp116x_write_addr(isp116x
, HCATLPORT
| ISP116x_WRITE_OFFSET
);
176 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
179 dump_ptd_out_data(ptd
, ep
->data
);
180 isp116x_write_data16(isp116x
, ptd
->count
);
181 isp116x_write_data16(isp116x
, ptd
->mps
);
182 isp116x_write_data16(isp116x
, ptd
->len
);
183 isp116x_write_data16(isp116x
, ptd
->faddr
);
184 buflen
-= sizeof(struct ptd
);
185 /* Skip writing data for last IN PTD */
186 if (ep
->active
|| (isp116x
->atl_last_dir
!= PTD_DIR_IN
)) {
187 write_ptddata_to_fifo(isp116x
, ep
->data
, ep
->length
);
188 buflen
-= ALIGN(ep
->length
, 4);
195 Read the processed ptd's and data from fifo ram back to
196 URBs' buffers. Fifo must be full and done
198 static void unpack_fifo(struct isp116x
*isp116x
)
200 struct isp116x_ep
*ep
;
202 int buflen
= isp116x
->atl_last_dir
== PTD_DIR_IN
203 ? isp116x
->atl_buflen
: isp116x
->atl_bufshrt
;
205 isp116x_write_reg16(isp116x
, HCuPINT
, HCuPINT_AIIEOT
);
206 isp116x_write_reg16(isp116x
, HCXFERCTR
, buflen
);
207 isp116x_write_addr(isp116x
, HCATLPORT
);
208 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
210 ptd
->count
= isp116x_read_data16(isp116x
);
211 ptd
->mps
= isp116x_read_data16(isp116x
);
212 ptd
->len
= isp116x_read_data16(isp116x
);
213 ptd
->faddr
= isp116x_read_data16(isp116x
);
214 buflen
-= sizeof(struct ptd
);
215 /* Skip reading data for last Setup or Out PTD */
216 if (ep
->active
|| (isp116x
->atl_last_dir
== PTD_DIR_IN
)) {
217 read_ptddata_from_fifo(isp116x
, ep
->data
, ep
->length
);
218 buflen
-= ALIGN(ep
->length
, 4);
221 dump_ptd_in_data(ptd
, ep
->data
);
226 /*---------------------------------------------------------------*/
231 static void preproc_atl_queue(struct isp116x
*isp116x
)
233 struct isp116x_ep
*ep
;
238 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
239 u16 toggle
= 0, dir
= PTD_DIR_SETUP
;
241 BUG_ON(list_empty(&ep
->hep
->urb_list
));
242 urb
= container_of(ep
->hep
->urb_list
.next
,
243 struct urb
, urb_list
);
246 ep
->data
= (unsigned char *)urb
->transfer_buffer
247 + urb
->actual_length
;
249 switch (ep
->nextpid
) {
251 toggle
= usb_gettoggle(urb
->dev
, ep
->epnum
, 0);
255 toggle
= usb_gettoggle(urb
->dev
, ep
->epnum
, 1);
259 len
= sizeof(struct usb_ctrlrequest
);
260 ep
->data
= urb
->setup_packet
;
265 dir
= (urb
->transfer_buffer_length
266 && usb_pipein(urb
->pipe
))
267 ? PTD_DIR_OUT
: PTD_DIR_IN
;
270 ERR("%s %d: ep->nextpid %d\n", __func__
, __LINE__
,
275 ptd
->count
= PTD_CC_MSK
| PTD_ACTIVE_MSK
| PTD_TOGGLE(toggle
);
276 ptd
->mps
= PTD_MPS(ep
->maxpacket
)
277 | PTD_SPD(urb
->dev
->speed
== USB_SPEED_LOW
)
279 ptd
->len
= PTD_LEN(len
) | PTD_DIR(dir
);
280 ptd
->faddr
= PTD_FA(usb_pipedevice(urb
->pipe
));
282 ptd
->mps
|= PTD_LAST_MSK
;
283 isp116x
->atl_last_dir
= dir
;
285 isp116x
->atl_bufshrt
= sizeof(struct ptd
) + isp116x
->atl_buflen
;
286 isp116x
->atl_buflen
= isp116x
->atl_bufshrt
+ ALIGN(len
, 4);
291 Take done or failed requests out of schedule. Give back
294 static void finish_request(struct isp116x
*isp116x
, struct isp116x_ep
*ep
,
295 struct urb
*urb
, int status
)
296 __releases(isp116x
->lock
) __acquires(isp116x
->lock
)
302 if (usb_pipecontrol(urb
->pipe
))
303 ep
->nextpid
= USB_PID_SETUP
;
305 urb_dbg(urb
, "Finish");
307 usb_hcd_unlink_urb_from_ep(isp116x_to_hcd(isp116x
), urb
);
308 spin_unlock(&isp116x
->lock
);
309 usb_hcd_giveback_urb(isp116x_to_hcd(isp116x
), urb
, status
);
310 spin_lock(&isp116x
->lock
);
312 /* take idle endpoints out of the schedule */
313 if (!list_empty(&ep
->hep
->urb_list
))
316 /* async deschedule */
317 if (!list_empty(&ep
->schedule
)) {
318 list_del_init(&ep
->schedule
);
322 /* periodic deschedule */
323 DBG("deschedule qh%d/%p branch %d\n", ep
->period
, ep
, ep
->branch
);
324 for (i
= ep
->branch
; i
< PERIODIC_SIZE
; i
+= ep
->period
) {
325 struct isp116x_ep
*temp
;
326 struct isp116x_ep
**prev
= &isp116x
->periodic
[i
];
328 while (*prev
&& ((temp
= *prev
) != ep
))
332 isp116x
->load
[i
] -= ep
->load
;
334 ep
->branch
= PERIODIC_SIZE
;
335 isp116x_to_hcd(isp116x
)->self
.bandwidth_allocated
-=
336 ep
->load
/ ep
->period
;
338 /* switch irq type? */
339 if (!--isp116x
->periodic_count
) {
340 isp116x
->irqenb
&= ~HCuPINT_SOF
;
341 isp116x
->irqenb
|= HCuPINT_ATL
;
346 Analyze transfer results, handle partial transfers and errors
348 static void postproc_atl_queue(struct isp116x
*isp116x
)
350 struct isp116x_ep
*ep
;
352 struct usb_device
*udev
;
358 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
359 BUG_ON(list_empty(&ep
->hep
->urb_list
));
361 container_of(ep
->hep
->urb_list
.next
, struct urb
, urb_list
);
364 cc
= PTD_GET_CC(ptd
);
366 status
= -EINPROGRESS
;
368 /* Data underrun is special. For allowed underrun
369 we clear the error and continue as normal. For
370 forbidden underrun we finish the DATA stage
371 immediately while for control transfer,
372 we do a STATUS stage. */
373 if (cc
== TD_DATAUNDERRUN
) {
374 if (!(urb
->transfer_flags
& URB_SHORT_NOT_OK
) ||
375 usb_pipecontrol(urb
->pipe
)) {
376 DBG("Allowed or control data underrun\n");
381 usb_settoggle(udev
, ep
->epnum
,
382 ep
->nextpid
== USB_PID_OUT
,
383 PTD_GET_TOGGLE(ptd
));
384 urb
->actual_length
+= PTD_GET_COUNT(ptd
);
385 status
= cc_to_error
[TD_DATAUNDERRUN
];
390 if (cc
!= TD_CC_NOERROR
&& cc
!= TD_NOTACCESSED
391 && (++ep
->error_count
>= 3 || cc
== TD_CC_STALL
392 || cc
== TD_DATAOVERRUN
)) {
393 status
= cc_to_error
[cc
];
394 if (ep
->nextpid
== USB_PID_ACK
)
398 /* According to usb spec, zero-length Int transfer signals
399 finishing of the urb. Hey, does this apply only
401 if (usb_pipeint(urb
->pipe
) && !PTD_GET_LEN(ptd
)) {
406 /* Relax after previously failed, but later succeeded
407 or correctly NAK'ed retransmission attempt */
409 && (cc
== TD_CC_NOERROR
|| cc
== TD_NOTACCESSED
))
412 /* Take into account idiosyncracies of the isp116x chip
413 regarding toggle bit for failed transfers */
414 if (ep
->nextpid
== USB_PID_OUT
)
415 usb_settoggle(udev
, ep
->epnum
, 1, PTD_GET_TOGGLE(ptd
)
416 ^ (ep
->error_count
> 0));
417 else if (ep
->nextpid
== USB_PID_IN
)
418 usb_settoggle(udev
, ep
->epnum
, 0, PTD_GET_TOGGLE(ptd
)
419 ^ (ep
->error_count
> 0));
421 switch (ep
->nextpid
) {
424 urb
->actual_length
+= PTD_GET_COUNT(ptd
);
425 if (PTD_GET_ACTIVE(ptd
)
426 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
428 if (urb
->transfer_buffer_length
!= urb
->actual_length
) {
432 if (urb
->transfer_flags
& URB_ZERO_PACKET
433 && ep
->nextpid
== USB_PID_OUT
434 && !(PTD_GET_COUNT(ptd
) % ep
->maxpacket
)) {
435 DBG("Zero packet requested\n");
439 /* All data for this URB is transferred, let's finish */
440 if (usb_pipecontrol(urb
->pipe
))
441 ep
->nextpid
= USB_PID_ACK
;
446 if (PTD_GET_ACTIVE(ptd
)
447 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
449 if (urb
->transfer_buffer_length
== urb
->actual_length
)
450 ep
->nextpid
= USB_PID_ACK
;
451 else if (usb_pipeout(urb
->pipe
)) {
452 usb_settoggle(udev
, 0, 1, 1);
453 ep
->nextpid
= USB_PID_OUT
;
455 usb_settoggle(udev
, 0, 0, 1);
456 ep
->nextpid
= USB_PID_IN
;
460 if (PTD_GET_ACTIVE(ptd
)
461 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
471 if (status
!= -EINPROGRESS
|| urb
->unlinked
)
472 finish_request(isp116x
, ep
, urb
, status
);
477 Scan transfer lists, schedule transfers, send data off
480 static void start_atl_transfers(struct isp116x
*isp116x
)
482 struct isp116x_ep
*last_ep
= NULL
, *ep
;
485 int len
, index
, speed
, byte_time
;
487 if (atomic_read(&isp116x
->atl_finishing
))
490 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x
)->state
))
493 /* FIFO not empty? */
494 if (isp116x_read_reg16(isp116x
, HCBUFSTAT
) & HCBUFSTAT_ATL_FULL
)
497 isp116x
->atl_active
= NULL
;
498 isp116x
->atl_buflen
= isp116x
->atl_bufshrt
= 0;
500 /* Schedule int transfers */
501 if (isp116x
->periodic_count
) {
502 isp116x
->fmindex
= index
=
503 (isp116x
->fmindex
+ 1) & (PERIODIC_SIZE
- 1);
504 if ((load
= isp116x
->load
[index
])) {
505 /* Bring all int transfers for this frame
506 into the active queue */
507 isp116x
->atl_active
= last_ep
=
508 isp116x
->periodic
[index
];
509 while (last_ep
->next
)
510 last_ep
= (last_ep
->active
= last_ep
->next
);
511 last_ep
->active
= NULL
;
515 /* Schedule control/bulk transfers */
516 list_for_each_entry(ep
, &isp116x
->async
, schedule
) {
517 urb
= container_of(ep
->hep
->urb_list
.next
,
518 struct urb
, urb_list
);
519 speed
= urb
->dev
->speed
;
520 byte_time
= speed
== USB_SPEED_LOW
521 ? BYTE_TIME_LOWSPEED
: BYTE_TIME_FULLSPEED
;
523 if (ep
->nextpid
== USB_PID_SETUP
) {
524 len
= sizeof(struct usb_ctrlrequest
);
525 } else if (ep
->nextpid
== USB_PID_ACK
) {
528 /* Find current free length ... */
529 len
= (MAX_LOAD_LIMIT
- load
) / byte_time
;
531 /* ... then limit it to configured max size ... */
532 len
= min(len
, speed
== USB_SPEED_LOW
?
533 MAX_TRANSFER_SIZE_LOWSPEED
:
534 MAX_TRANSFER_SIZE_FULLSPEED
);
536 /* ... and finally cut to the multiple of MaxPacketSize,
537 or to the real length if there's enough room. */
539 (urb
->transfer_buffer_length
-
540 urb
->actual_length
)) {
541 len
-= len
% ep
->maxpacket
;
545 len
= urb
->transfer_buffer_length
-
550 load
+= len
* byte_time
;
551 if (load
> MAX_LOAD_LIMIT
)
557 last_ep
->active
= ep
;
559 isp116x
->atl_active
= ep
;
563 /* Avoid starving of endpoints */
564 if ((&isp116x
->async
)->next
!= (&isp116x
->async
)->prev
)
565 list_move(&isp116x
->async
, (&isp116x
->async
)->next
);
567 if (isp116x
->atl_active
) {
568 preproc_atl_queue(isp116x
);
574 Finish the processed transfers
576 static void finish_atl_transfers(struct isp116x
*isp116x
)
578 if (!isp116x
->atl_active
)
580 /* Fifo not ready? */
581 if (!(isp116x_read_reg16(isp116x
, HCBUFSTAT
) & HCBUFSTAT_ATL_DONE
))
584 atomic_inc(&isp116x
->atl_finishing
);
585 unpack_fifo(isp116x
);
586 postproc_atl_queue(isp116x
);
587 atomic_dec(&isp116x
->atl_finishing
);
590 static irqreturn_t
isp116x_irq(struct usb_hcd
*hcd
)
592 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
594 irqreturn_t ret
= IRQ_NONE
;
596 spin_lock(&isp116x
->lock
);
597 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
598 irqstat
= isp116x_read_reg16(isp116x
, HCuPINT
);
599 isp116x_write_reg16(isp116x
, HCuPINT
, irqstat
);
601 if (irqstat
& (HCuPINT_ATL
| HCuPINT_SOF
)) {
603 finish_atl_transfers(isp116x
);
606 if (irqstat
& HCuPINT_OPR
) {
607 u32 intstat
= isp116x_read_reg32(isp116x
, HCINTSTAT
);
608 isp116x_write_reg32(isp116x
, HCINTSTAT
, intstat
);
609 if (intstat
& HCINT_UE
) {
610 ERR("Unrecoverable error, HC is dead!\n");
611 /* IRQ's are off, we do no DMA,
612 perfectly ready to die ... */
613 hcd
->state
= HC_STATE_HALT
;
618 if (intstat
& HCINT_RHSC
)
619 /* When root hub or any of its ports is going
620 to come out of suspend, it may take more
621 than 10ms for status bits to stabilize. */
622 mod_timer(&hcd
->rh_timer
, jiffies
623 + msecs_to_jiffies(20) + 1);
624 if (intstat
& HCINT_RD
) {
625 DBG("---- remote wakeup\n");
626 usb_hcd_resume_root_hub(hcd
);
628 irqstat
&= ~HCuPINT_OPR
;
632 if (irqstat
& (HCuPINT_ATL
| HCuPINT_SOF
)) {
633 start_atl_transfers(isp116x
);
636 isp116x_write_reg16(isp116x
, HCuPINTENB
, isp116x
->irqenb
);
638 spin_unlock(&isp116x
->lock
);
642 /*-----------------------------------------------------------------*/
644 /* usb 1.1 says max 90% of a frame is available for periodic transfers.
645 * this driver doesn't promise that much since it's got to handle an
646 * IRQ per packet; irq handling latencies also use up that time.
650 #define MAX_PERIODIC_LOAD 600
651 static int balance(struct isp116x
*isp116x
, u16 period
, u16 load
)
653 int i
, branch
= -ENOSPC
;
655 /* search for the least loaded schedule branch of that period
656 which has enough bandwidth left unreserved. */
657 for (i
= 0; i
< period
; i
++) {
658 if (branch
< 0 || isp116x
->load
[branch
] > isp116x
->load
[i
]) {
661 for (j
= i
; j
< PERIODIC_SIZE
; j
+= period
) {
662 if ((isp116x
->load
[j
] + load
)
666 if (j
< PERIODIC_SIZE
)
674 /* NB! ALL the code above this point runs with isp116x->lock
678 /*-----------------------------------------------------------------*/
680 static int isp116x_urb_enqueue(struct usb_hcd
*hcd
,
684 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
685 struct usb_device
*udev
= urb
->dev
;
686 unsigned int pipe
= urb
->pipe
;
687 int is_out
= !usb_pipein(pipe
);
688 int type
= usb_pipetype(pipe
);
689 int epnum
= usb_pipeendpoint(pipe
);
690 struct usb_host_endpoint
*hep
= urb
->ep
;
691 struct isp116x_ep
*ep
= NULL
;
696 urb_dbg(urb
, "Enqueue");
698 if (type
== PIPE_ISOCHRONOUS
) {
699 ERR("Isochronous transfers not supported\n");
700 urb_dbg(urb
, "Refused to enqueue");
703 /* avoid all allocations within spinlocks: request or endpoint */
705 ep
= kzalloc(sizeof *ep
, mem_flags
);
710 spin_lock_irqsave(&isp116x
->lock
, flags
);
711 if (!HC_IS_RUNNING(hcd
->state
)) {
714 goto fail_not_linked
;
716 ret
= usb_hcd_link_urb_to_ep(hcd
, urb
);
719 goto fail_not_linked
;
725 INIT_LIST_HEAD(&ep
->schedule
);
728 ep
->maxpacket
= usb_maxpacket(udev
, urb
->pipe
, is_out
);
729 usb_settoggle(udev
, epnum
, is_out
, 0);
731 if (type
== PIPE_CONTROL
) {
732 ep
->nextpid
= USB_PID_SETUP
;
734 ep
->nextpid
= USB_PID_OUT
;
736 ep
->nextpid
= USB_PID_IN
;
741 With INT URBs submitted, the driver works with SOF
742 interrupt enabled and ATL interrupt disabled. After
743 the PTDs are written to fifo ram, the chip starts
744 fifo processing and usb transfers after the next
745 SOF and continues until the transfers are finished
746 (succeeded or failed) or the frame ends. Therefore,
747 the transfers occur only in every second frame,
748 while fifo reading/writing and data processing
749 occur in every other second frame. */
750 if (urb
->interval
< 2)
752 if (urb
->interval
> 2 * PERIODIC_SIZE
)
753 urb
->interval
= 2 * PERIODIC_SIZE
;
754 ep
->period
= urb
->interval
>> 1;
755 ep
->branch
= PERIODIC_SIZE
;
756 ep
->load
= usb_calc_bus_time(udev
->speed
,
758 (type
== PIPE_ISOCHRONOUS
),
759 usb_maxpacket(udev
, pipe
,
767 /* maybe put endpoint into schedule */
771 if (list_empty(&ep
->schedule
))
772 list_add_tail(&ep
->schedule
, &isp116x
->async
);
775 urb
->interval
= ep
->period
;
776 ep
->length
= min_t(u32
, ep
->maxpacket
,
777 urb
->transfer_buffer_length
);
779 /* urb submitted for already existing endpoint */
780 if (ep
->branch
< PERIODIC_SIZE
)
783 ep
->branch
= ret
= balance(isp116x
, ep
->period
, ep
->load
);
788 urb
->start_frame
= (isp116x
->fmindex
& (PERIODIC_SIZE
- 1))
791 /* sort each schedule branch by period (slow before fast)
792 to share the faster parts of the tree without needing
793 dummy/placeholder nodes */
794 DBG("schedule qh%d/%p branch %d\n", ep
->period
, ep
, ep
->branch
);
795 for (i
= ep
->branch
; i
< PERIODIC_SIZE
; i
+= ep
->period
) {
796 struct isp116x_ep
**prev
= &isp116x
->periodic
[i
];
797 struct isp116x_ep
*here
= *prev
;
799 while (here
&& ep
!= here
) {
800 if (ep
->period
> here
->period
)
809 isp116x
->load
[i
] += ep
->load
;
811 hcd
->self
.bandwidth_allocated
+= ep
->load
/ ep
->period
;
813 /* switch over to SOFint */
814 if (!isp116x
->periodic_count
++) {
815 isp116x
->irqenb
&= ~HCuPINT_ATL
;
816 isp116x
->irqenb
|= HCuPINT_SOF
;
817 isp116x_write_reg16(isp116x
, HCuPINTENB
,
823 start_atl_transfers(isp116x
);
827 usb_hcd_unlink_urb_from_ep(hcd
, urb
);
829 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
836 static int isp116x_urb_dequeue(struct usb_hcd
*hcd
, struct urb
*urb
,
839 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
840 struct usb_host_endpoint
*hep
;
841 struct isp116x_ep
*ep
, *ep_act
;
845 spin_lock_irqsave(&isp116x
->lock
, flags
);
846 rc
= usb_hcd_check_unlink_urb(hcd
, urb
, status
);
852 WARN_ON(hep
!= ep
->hep
);
854 /* In front of queue? */
855 if (ep
->hep
->urb_list
.next
== &urb
->urb_list
)
857 for (ep_act
= isp116x
->atl_active
; ep_act
;
858 ep_act
= ep_act
->active
)
860 VDBG("dequeue, urb %p active; wait for irq\n",
867 finish_request(isp116x
, ep
, urb
, status
);
869 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
873 static void isp116x_endpoint_disable(struct usb_hcd
*hcd
,
874 struct usb_host_endpoint
*hep
)
877 struct isp116x_ep
*ep
= hep
->hcpriv
;
882 /* assume we'd just wait for the irq */
883 for (i
= 0; i
< 100 && !list_empty(&hep
->urb_list
); i
++)
885 if (!list_empty(&hep
->urb_list
))
886 WARNING("ep %p not empty?\n", ep
);
892 static int isp116x_get_frame(struct usb_hcd
*hcd
)
894 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
898 spin_lock_irqsave(&isp116x
->lock
, flags
);
899 fmnum
= isp116x_read_reg32(isp116x
, HCFMNUM
);
900 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
905 Adapted from ohci-hub.c. Currently we don't support autosuspend.
907 static int isp116x_hub_status_data(struct usb_hcd
*hcd
, char *buf
)
909 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
910 int ports
, i
, changed
= 0;
913 if (!HC_IS_RUNNING(hcd
->state
))
916 /* Report no status change now, if we are scheduled to be
918 if (timer_pending(&hcd
->rh_timer
))
921 ports
= isp116x
->rhdesca
& RH_A_NDP
;
922 spin_lock_irqsave(&isp116x
->lock
, flags
);
923 isp116x
->rhstatus
= isp116x_read_reg32(isp116x
, HCRHSTATUS
);
924 if (isp116x
->rhstatus
& (RH_HS_LPSC
| RH_HS_OCIC
))
925 buf
[0] = changed
= 1;
929 for (i
= 0; i
< ports
; i
++) {
930 u32 status
= isp116x_read_reg32(isp116x
, i
? HCRHPORT2
: HCRHPORT1
);
932 if (status
& (RH_PS_CSC
| RH_PS_PESC
| RH_PS_PSSC
933 | RH_PS_OCIC
| RH_PS_PRSC
)) {
935 buf
[0] |= 1 << (i
+ 1);
938 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
942 static void isp116x_hub_descriptor(struct isp116x
*isp116x
,
943 struct usb_hub_descriptor
*desc
)
945 u32 reg
= isp116x
->rhdesca
;
947 desc
->bDescriptorType
= 0x29;
948 desc
->bDescLength
= 9;
949 desc
->bHubContrCurrent
= 0;
950 desc
->bNbrPorts
= (u8
) (reg
& 0x3);
951 /* Power switching, device type, overcurrent. */
952 desc
->wHubCharacteristics
= cpu_to_le16((u16
) ((reg
>> 8) & 0x1f));
953 desc
->bPwrOn2PwrGood
= (u8
) ((reg
>> 24) & 0xff);
954 /* ports removable, and legacy PortPwrCtrlMask */
955 desc
->u
.hs
.DeviceRemovable
[0] = 0;
956 desc
->u
.hs
.DeviceRemovable
[1] = ~0;
959 /* Perform reset of a given port.
960 It would be great to just start the reset and let the
961 USB core to clear the reset in due time. However,
962 root hub ports should be reset for at least 50 ms, while
963 our chip stays in reset for about 10 ms. I.e., we must
964 repeatedly reset it ourself here.
966 static inline void root_port_reset(struct isp116x
*isp116x
, unsigned port
)
969 unsigned long flags
, t
;
971 /* Root hub reset should be 50 ms, but some devices
972 want it even longer. */
973 t
= jiffies
+ msecs_to_jiffies(100);
975 while (time_before(jiffies
, t
)) {
976 spin_lock_irqsave(&isp116x
->lock
, flags
);
977 /* spin until any current reset finishes */
979 tmp
= isp116x_read_reg32(isp116x
, port
?
980 HCRHPORT2
: HCRHPORT1
);
981 if (!(tmp
& RH_PS_PRS
))
985 /* Don't reset a disconnected port */
986 if (!(tmp
& RH_PS_CCS
)) {
987 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
990 /* Reset lasts 10ms (claims datasheet) */
991 isp116x_write_reg32(isp116x
, port
? HCRHPORT2
:
992 HCRHPORT1
, (RH_PS_PRS
));
993 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
998 /* Adapted from ohci-hub.c */
999 static int isp116x_hub_control(struct usb_hcd
*hcd
,
1001 u16 wValue
, u16 wIndex
, char *buf
, u16 wLength
)
1003 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1005 unsigned long flags
;
1006 int ports
= isp116x
->rhdesca
& RH_A_NDP
;
1010 case ClearHubFeature
:
1011 DBG("ClearHubFeature: ");
1013 case C_HUB_OVER_CURRENT
:
1014 DBG("C_HUB_OVER_CURRENT\n");
1015 spin_lock_irqsave(&isp116x
->lock
, flags
);
1016 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_OCIC
);
1017 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1018 case C_HUB_LOCAL_POWER
:
1019 DBG("C_HUB_LOCAL_POWER\n");
1026 DBG("SetHubFeature: ");
1028 case C_HUB_OVER_CURRENT
:
1029 case C_HUB_LOCAL_POWER
:
1030 DBG("C_HUB_OVER_CURRENT or C_HUB_LOCAL_POWER\n");
1036 case GetHubDescriptor
:
1037 DBG("GetHubDescriptor\n");
1038 isp116x_hub_descriptor(isp116x
,
1039 (struct usb_hub_descriptor
*)buf
);
1042 DBG("GetHubStatus\n");
1043 *(__le32
*) buf
= 0;
1046 DBG("GetPortStatus\n");
1047 if (!wIndex
|| wIndex
> ports
)
1049 spin_lock_irqsave(&isp116x
->lock
, flags
);
1050 tmp
= isp116x_read_reg32(isp116x
, (--wIndex
) ? HCRHPORT2
: HCRHPORT1
);
1051 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1052 *(__le32
*) buf
= cpu_to_le32(tmp
);
1053 DBG("GetPortStatus: port[%d] %08x\n", wIndex
+ 1, tmp
);
1055 case ClearPortFeature
:
1056 DBG("ClearPortFeature: ");
1057 if (!wIndex
|| wIndex
> ports
)
1062 case USB_PORT_FEAT_ENABLE
:
1063 DBG("USB_PORT_FEAT_ENABLE\n");
1066 case USB_PORT_FEAT_C_ENABLE
:
1067 DBG("USB_PORT_FEAT_C_ENABLE\n");
1070 case USB_PORT_FEAT_SUSPEND
:
1071 DBG("USB_PORT_FEAT_SUSPEND\n");
1074 case USB_PORT_FEAT_C_SUSPEND
:
1075 DBG("USB_PORT_FEAT_C_SUSPEND\n");
1078 case USB_PORT_FEAT_POWER
:
1079 DBG("USB_PORT_FEAT_POWER\n");
1082 case USB_PORT_FEAT_C_CONNECTION
:
1083 DBG("USB_PORT_FEAT_C_CONNECTION\n");
1086 case USB_PORT_FEAT_C_OVER_CURRENT
:
1087 DBG("USB_PORT_FEAT_C_OVER_CURRENT\n");
1090 case USB_PORT_FEAT_C_RESET
:
1091 DBG("USB_PORT_FEAT_C_RESET\n");
1097 spin_lock_irqsave(&isp116x
->lock
, flags
);
1098 isp116x_write_reg32(isp116x
, wIndex
1099 ? HCRHPORT2
: HCRHPORT1
, tmp
);
1100 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1102 case SetPortFeature
:
1103 DBG("SetPortFeature: ");
1104 if (!wIndex
|| wIndex
> ports
)
1108 case USB_PORT_FEAT_SUSPEND
:
1109 DBG("USB_PORT_FEAT_SUSPEND\n");
1110 spin_lock_irqsave(&isp116x
->lock
, flags
);
1111 isp116x_write_reg32(isp116x
, wIndex
1112 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PSS
);
1113 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1115 case USB_PORT_FEAT_POWER
:
1116 DBG("USB_PORT_FEAT_POWER\n");
1117 spin_lock_irqsave(&isp116x
->lock
, flags
);
1118 isp116x_write_reg32(isp116x
, wIndex
1119 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PPS
);
1120 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1122 case USB_PORT_FEAT_RESET
:
1123 DBG("USB_PORT_FEAT_RESET\n");
1124 root_port_reset(isp116x
, wIndex
);
1133 /* "protocol stall" on error */
1134 DBG("PROTOCOL STALL\n");
1140 /*-----------------------------------------------------------------*/
1142 #ifdef CONFIG_DEBUG_FS
1144 static void dump_irq(struct seq_file
*s
, char *label
, u16 mask
)
1146 seq_printf(s
, "%s %04x%s%s%s%s%s%s\n", label
, mask
,
1147 mask
& HCuPINT_CLKRDY
? " clkrdy" : "",
1148 mask
& HCuPINT_SUSP
? " susp" : "",
1149 mask
& HCuPINT_OPR
? " opr" : "",
1150 mask
& HCuPINT_AIIEOT
? " eot" : "",
1151 mask
& HCuPINT_ATL
? " atl" : "",
1152 mask
& HCuPINT_SOF
? " sof" : "");
1155 static void dump_int(struct seq_file
*s
, char *label
, u32 mask
)
1157 seq_printf(s
, "%s %08x%s%s%s%s%s%s%s\n", label
, mask
,
1158 mask
& HCINT_MIE
? " MIE" : "",
1159 mask
& HCINT_RHSC
? " rhsc" : "",
1160 mask
& HCINT_FNO
? " fno" : "",
1161 mask
& HCINT_UE
? " ue" : "",
1162 mask
& HCINT_RD
? " rd" : "",
1163 mask
& HCINT_SF
? " sof" : "", mask
& HCINT_SO
? " so" : "");
1166 static int isp116x_show_dbg(struct seq_file
*s
, void *unused
)
1168 struct isp116x
*isp116x
= s
->private;
1170 seq_printf(s
, "%s\n%s version %s\n",
1171 isp116x_to_hcd(isp116x
)->product_desc
, hcd_name
,
1174 if (HC_IS_SUSPENDED(isp116x_to_hcd(isp116x
)->state
)) {
1175 seq_printf(s
, "HCD is suspended\n");
1178 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x
)->state
)) {
1179 seq_printf(s
, "HCD not running\n");
1183 spin_lock_irq(&isp116x
->lock
);
1184 dump_irq(s
, "hc_irq_enable", isp116x_read_reg16(isp116x
, HCuPINTENB
));
1185 dump_irq(s
, "hc_irq_status", isp116x_read_reg16(isp116x
, HCuPINT
));
1186 dump_int(s
, "hc_int_enable", isp116x_read_reg32(isp116x
, HCINTENB
));
1187 dump_int(s
, "hc_int_status", isp116x_read_reg32(isp116x
, HCINTSTAT
));
1188 isp116x_show_regs_seq(isp116x
, s
);
1189 spin_unlock_irq(&isp116x
->lock
);
1190 seq_printf(s
, "\n");
1195 static int isp116x_open_seq(struct inode
*inode
, struct file
*file
)
1197 return single_open(file
, isp116x_show_dbg
, inode
->i_private
);
1200 static const struct file_operations isp116x_debug_fops
= {
1201 .open
= isp116x_open_seq
,
1203 .llseek
= seq_lseek
,
1204 .release
= single_release
,
1207 static int create_debug_file(struct isp116x
*isp116x
)
1209 isp116x
->dentry
= debugfs_create_file(hcd_name
,
1210 S_IRUGO
, NULL
, isp116x
,
1211 &isp116x_debug_fops
);
1212 if (!isp116x
->dentry
)
1217 static void remove_debug_file(struct isp116x
*isp116x
)
1219 debugfs_remove(isp116x
->dentry
);
1224 #define create_debug_file(d) 0
1225 #define remove_debug_file(d) do{}while(0)
1227 #endif /* CONFIG_DEBUG_FS */
1229 /*-----------------------------------------------------------------*/
1232 Software reset - can be called from any contect.
1234 static int isp116x_sw_reset(struct isp116x
*isp116x
)
1237 unsigned long flags
;
1240 spin_lock_irqsave(&isp116x
->lock
, flags
);
1241 isp116x_write_reg16(isp116x
, HCSWRES
, HCSWRES_MAGIC
);
1242 isp116x_write_reg32(isp116x
, HCCMDSTAT
, HCCMDSTAT_HCR
);
1244 /* It usually resets within 1 ms */
1246 if (!(isp116x_read_reg32(isp116x
, HCCMDSTAT
) & HCCMDSTAT_HCR
))
1250 ERR("Software reset timeout\n");
1253 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1257 static int isp116x_reset(struct usb_hcd
*hcd
)
1259 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1262 int ret
, timeout
= 15 /* ms */ ;
1264 ret
= isp116x_sw_reset(isp116x
);
1268 t
= jiffies
+ msecs_to_jiffies(timeout
);
1269 while (time_before_eq(jiffies
, t
)) {
1271 spin_lock_irq(&isp116x
->lock
);
1272 clkrdy
= isp116x_read_reg16(isp116x
, HCuPINT
) & HCuPINT_CLKRDY
;
1273 spin_unlock_irq(&isp116x
->lock
);
1278 ERR("Clock not ready after %dms\n", timeout
);
1279 /* After sw_reset the clock won't report to be ready, if
1280 H_WAKEUP pin is high. */
1281 ERR("Please make sure that the H_WAKEUP pin is pulled low!\n");
1287 static void isp116x_stop(struct usb_hcd
*hcd
)
1289 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1290 unsigned long flags
;
1293 spin_lock_irqsave(&isp116x
->lock
, flags
);
1294 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1296 /* Switch off ports' power, some devices don't come up
1297 after next 'insmod' without this */
1298 val
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1299 val
&= ~(RH_A_NPS
| RH_A_PSM
);
1300 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1301 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_LPS
);
1302 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1304 isp116x_sw_reset(isp116x
);
1308 Configure the chip. The chip must be successfully reset by now.
1310 static int isp116x_start(struct usb_hcd
*hcd
)
1312 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1313 struct isp116x_platform_data
*board
= isp116x
->board
;
1315 unsigned long flags
;
1317 spin_lock_irqsave(&isp116x
->lock
, flags
);
1319 /* clear interrupt status and disable all interrupt sources */
1320 isp116x_write_reg16(isp116x
, HCuPINT
, 0xff);
1321 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1323 val
= isp116x_read_reg16(isp116x
, HCCHIPID
);
1324 if ((val
& HCCHIPID_MASK
) != HCCHIPID_MAGIC
) {
1325 ERR("Invalid chip ID %04x\n", val
);
1326 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1330 /* To be removed in future */
1331 hcd
->uses_new_polling
= 1;
1333 isp116x_write_reg16(isp116x
, HCITLBUFLEN
, ISP116x_ITL_BUFSIZE
);
1334 isp116x_write_reg16(isp116x
, HCATLBUFLEN
, ISP116x_ATL_BUFSIZE
);
1337 val
= HCHWCFG_INT_ENABLE
| HCHWCFG_DBWIDTH(1);
1338 if (board
->sel15Kres
)
1339 val
|= HCHWCFG_15KRSEL
;
1340 /* Remote wakeup won't work without working clock */
1341 if (board
->remote_wakeup_enable
)
1342 val
|= HCHWCFG_CLKNOTSTOP
;
1343 if (board
->oc_enable
)
1344 val
|= HCHWCFG_ANALOG_OC
;
1345 if (board
->int_act_high
)
1346 val
|= HCHWCFG_INT_POL
;
1347 if (board
->int_edge_triggered
)
1348 val
|= HCHWCFG_INT_TRIGGER
;
1349 isp116x_write_reg16(isp116x
, HCHWCFG
, val
);
1351 /* ----- Root hub conf */
1352 val
= (25 << 24) & RH_A_POTPGT
;
1353 /* AN10003_1.pdf recommends RH_A_NPS (no power switching) to
1354 be always set. Yet, instead, we request individual port
1357 /* Report overcurrent per port */
1359 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1360 isp116x
->rhdesca
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1363 isp116x_write_reg32(isp116x
, HCRHDESCB
, val
);
1364 isp116x
->rhdescb
= isp116x_read_reg32(isp116x
, HCRHDESCB
);
1367 if (board
->remote_wakeup_enable
) {
1368 if (!device_can_wakeup(hcd
->self
.controller
))
1369 device_init_wakeup(hcd
->self
.controller
, 1);
1372 isp116x_write_reg32(isp116x
, HCRHSTATUS
, val
);
1373 isp116x
->rhstatus
= isp116x_read_reg32(isp116x
, HCRHSTATUS
);
1375 isp116x_write_reg32(isp116x
, HCFMINTVL
, 0x27782edf);
1377 hcd
->state
= HC_STATE_RUNNING
;
1379 /* Set up interrupts */
1380 isp116x
->intenb
= HCINT_MIE
| HCINT_RHSC
| HCINT_UE
;
1381 if (board
->remote_wakeup_enable
)
1382 isp116x
->intenb
|= HCINT_RD
;
1383 isp116x
->irqenb
= HCuPINT_ATL
| HCuPINT_OPR
; /* | HCuPINT_SUSP; */
1384 isp116x_write_reg32(isp116x
, HCINTENB
, isp116x
->intenb
);
1385 isp116x_write_reg16(isp116x
, HCuPINTENB
, isp116x
->irqenb
);
1387 /* Go operational */
1388 val
= HCCONTROL_USB_OPER
;
1389 if (board
->remote_wakeup_enable
)
1390 val
|= HCCONTROL_RWE
;
1391 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1393 /* Disable ports to avoid race in device enumeration */
1394 isp116x_write_reg32(isp116x
, HCRHPORT1
, RH_PS_CCS
);
1395 isp116x_write_reg32(isp116x
, HCRHPORT2
, RH_PS_CCS
);
1397 isp116x_show_regs_log(isp116x
);
1398 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1404 static int isp116x_bus_suspend(struct usb_hcd
*hcd
)
1406 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1407 unsigned long flags
;
1411 spin_lock_irqsave(&isp116x
->lock
, flags
);
1412 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1414 switch (val
& HCCONTROL_HCFS
) {
1415 case HCCONTROL_USB_OPER
:
1416 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1417 val
&= (~HCCONTROL_HCFS
& ~HCCONTROL_RWE
);
1418 val
|= HCCONTROL_USB_SUSPEND
;
1419 if (hcd
->self
.root_hub
->do_remote_wakeup
)
1420 val
|= HCCONTROL_RWE
;
1421 /* Wait for usb transfers to finish */
1423 spin_lock_irqsave(&isp116x
->lock
, flags
);
1424 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1425 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1426 /* Wait for devices to suspend */
1429 case HCCONTROL_USB_RESUME
:
1430 isp116x_write_reg32(isp116x
, HCCONTROL
,
1431 (val
& ~HCCONTROL_HCFS
) |
1432 HCCONTROL_USB_RESET
);
1433 case HCCONTROL_USB_RESET
:
1435 default: /* HCCONTROL_USB_SUSPEND */
1436 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1443 static int isp116x_bus_resume(struct usb_hcd
*hcd
)
1445 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1449 spin_lock_irq(&isp116x
->lock
);
1451 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1452 switch (val
& HCCONTROL_HCFS
) {
1453 case HCCONTROL_USB_SUSPEND
:
1454 val
&= ~HCCONTROL_HCFS
;
1455 val
|= HCCONTROL_USB_RESUME
;
1456 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1457 case HCCONTROL_USB_RESUME
:
1459 case HCCONTROL_USB_OPER
:
1460 spin_unlock_irq(&isp116x
->lock
);
1463 /* HCCONTROL_USB_RESET: this may happen, when during
1464 suspension the HC lost power. Reinitialize completely */
1465 spin_unlock_irq(&isp116x
->lock
);
1466 DBG("Chip has been reset while suspended. Reinit from scratch.\n");
1469 isp116x_hub_control(hcd
, SetPortFeature
,
1470 USB_PORT_FEAT_POWER
, 1, NULL
, 0);
1471 if ((isp116x
->rhdesca
& RH_A_NDP
) == 2)
1472 isp116x_hub_control(hcd
, SetPortFeature
,
1473 USB_PORT_FEAT_POWER
, 2, NULL
, 0);
1477 val
= isp116x
->rhdesca
& RH_A_NDP
;
1480 isp116x_read_reg32(isp116x
, val
? HCRHPORT2
: HCRHPORT1
);
1481 /* force global, not selective, resume */
1482 if (!(stat
& RH_PS_PSS
))
1484 DBG("%s: Resuming port %d\n", __func__
, val
);
1485 isp116x_write_reg32(isp116x
, RH_PS_POCI
, val
1486 ? HCRHPORT2
: HCRHPORT1
);
1488 spin_unlock_irq(&isp116x
->lock
);
1490 hcd
->state
= HC_STATE_RESUMING
;
1493 /* Go operational */
1494 spin_lock_irq(&isp116x
->lock
);
1495 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1496 isp116x_write_reg32(isp116x
, HCCONTROL
,
1497 (val
& ~HCCONTROL_HCFS
) | HCCONTROL_USB_OPER
);
1498 spin_unlock_irq(&isp116x
->lock
);
1499 hcd
->state
= HC_STATE_RUNNING
;
1506 #define isp116x_bus_suspend NULL
1507 #define isp116x_bus_resume NULL
1511 static struct hc_driver isp116x_hc_driver
= {
1512 .description
= hcd_name
,
1513 .product_desc
= "ISP116x Host Controller",
1514 .hcd_priv_size
= sizeof(struct isp116x
),
1519 .reset
= isp116x_reset
,
1520 .start
= isp116x_start
,
1521 .stop
= isp116x_stop
,
1523 .urb_enqueue
= isp116x_urb_enqueue
,
1524 .urb_dequeue
= isp116x_urb_dequeue
,
1525 .endpoint_disable
= isp116x_endpoint_disable
,
1527 .get_frame_number
= isp116x_get_frame
,
1529 .hub_status_data
= isp116x_hub_status_data
,
1530 .hub_control
= isp116x_hub_control
,
1531 .bus_suspend
= isp116x_bus_suspend
,
1532 .bus_resume
= isp116x_bus_resume
,
1535 /*----------------------------------------------------------------*/
1537 static int isp116x_remove(struct platform_device
*pdev
)
1539 struct usb_hcd
*hcd
= platform_get_drvdata(pdev
);
1540 struct isp116x
*isp116x
;
1541 struct resource
*res
;
1545 isp116x
= hcd_to_isp116x(hcd
);
1546 remove_debug_file(isp116x
);
1547 usb_remove_hcd(hcd
);
1549 iounmap(isp116x
->data_reg
);
1550 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1551 release_mem_region(res
->start
, 2);
1552 iounmap(isp116x
->addr_reg
);
1553 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1554 release_mem_region(res
->start
, 2);
1560 static int __devinit
isp116x_probe(struct platform_device
*pdev
)
1562 struct usb_hcd
*hcd
;
1563 struct isp116x
*isp116x
;
1564 struct resource
*addr
, *data
, *ires
;
1565 void __iomem
*addr_reg
;
1566 void __iomem
*data_reg
;
1569 unsigned long irqflags
;
1574 if (pdev
->num_resources
< 3) {
1579 data
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1580 addr
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1581 ires
= platform_get_resource(pdev
, IORESOURCE_IRQ
, 0);
1583 if (!addr
|| !data
|| !ires
) {
1589 irqflags
= ires
->flags
& IRQF_TRIGGER_MASK
;
1591 if (pdev
->dev
.dma_mask
) {
1592 DBG("DMA not supported\n");
1597 if (!request_mem_region(addr
->start
, 2, hcd_name
)) {
1601 addr_reg
= ioremap(addr
->start
, resource_size(addr
));
1602 if (addr_reg
== NULL
) {
1606 if (!request_mem_region(data
->start
, 2, hcd_name
)) {
1610 data_reg
= ioremap(data
->start
, resource_size(data
));
1611 if (data_reg
== NULL
) {
1616 /* allocate and initialize hcd */
1617 hcd
= usb_create_hcd(&isp116x_hc_driver
, &pdev
->dev
, dev_name(&pdev
->dev
));
1622 /* this rsrc_start is bogus */
1623 hcd
->rsrc_start
= addr
->start
;
1624 isp116x
= hcd_to_isp116x(hcd
);
1625 isp116x
->data_reg
= data_reg
;
1626 isp116x
->addr_reg
= addr_reg
;
1627 spin_lock_init(&isp116x
->lock
);
1628 INIT_LIST_HEAD(&isp116x
->async
);
1629 isp116x
->board
= pdev
->dev
.platform_data
;
1631 if (!isp116x
->board
) {
1632 ERR("Platform data structure not initialized\n");
1636 if (isp116x_check_platform_delay(isp116x
)) {
1637 ERR("USE_PLATFORM_DELAY defined, but delay function not "
1639 ERR("See comments in drivers/usb/host/isp116x-hcd.c\n");
1644 ret
= usb_add_hcd(hcd
, irq
, irqflags
);
1648 ret
= create_debug_file(isp116x
);
1650 ERR("Couldn't create debugfs entry\n");
1657 usb_remove_hcd(hcd
);
1663 release_mem_region(data
->start
, 2);
1667 release_mem_region(addr
->start
, 2);
1669 ERR("init error, %d\n", ret
);
1675 Suspend of platform device
1677 static int isp116x_suspend(struct platform_device
*dev
, pm_message_t state
)
1679 VDBG("%s: state %x\n", __func__
, state
.event
);
1684 Resume platform device
1686 static int isp116x_resume(struct platform_device
*dev
)
1688 VDBG("%s\n", __func__
);
1694 #define isp116x_suspend NULL
1695 #define isp116x_resume NULL
1699 /* work with hotplug and coldplug */
1700 MODULE_ALIAS("platform:isp116x-hcd");
1702 static struct platform_driver isp116x_driver
= {
1703 .probe
= isp116x_probe
,
1704 .remove
= isp116x_remove
,
1705 .suspend
= isp116x_suspend
,
1706 .resume
= isp116x_resume
,
1708 .name
= (char *)hcd_name
,
1709 .owner
= THIS_MODULE
,
1713 module_platform_driver(isp116x_driver
);