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/list.h>
64 #include <linux/slab.h>
65 #include <linux/usb.h>
66 #include <linux/usb/isp116x.h>
67 #include <linux/usb/hcd.h>
68 #include <linux/platform_device.h>
72 #include <asm/byteorder.h>
76 #define DRIVER_VERSION "03 Nov 2005"
77 #define DRIVER_DESC "ISP116x USB Host Controller Driver"
79 MODULE_DESCRIPTION(DRIVER_DESC
);
80 MODULE_LICENSE("GPL");
82 static const char hcd_name
[] = "isp116x-hcd";
84 /*-----------------------------------------------------------------*/
87 Write len bytes to fifo, pad till 32-bit boundary
89 static void write_ptddata_to_fifo(struct isp116x
*isp116x
, void *buf
, int len
)
92 u16
*dp2
= (u16
*) buf
;
96 /* buffer is already in 'usb data order', which is LE. */
97 /* When reading buffer as u16, we have to take care byte order */
98 /* doesn't get mixed up */
100 if ((unsigned long)dp2
& 1) {
102 for (; len
> 1; len
-= 2) {
105 isp116x_raw_write_data16(isp116x
, w
);
108 isp116x_write_data16(isp116x
, (u16
) * dp
);
111 for (; len
> 1; len
-= 2) {
112 /* Keep byte order ! */
113 isp116x_raw_write_data16(isp116x
, cpu_to_le16(*dp2
++));
117 isp116x_write_data16(isp116x
, 0xff & *((u8
*) dp2
));
119 if (quot
== 1 || quot
== 2)
120 isp116x_raw_write_data16(isp116x
, 0);
124 Read len bytes from fifo and then read till 32-bit boundary.
126 static void read_ptddata_from_fifo(struct isp116x
*isp116x
, void *buf
, int len
)
129 u16
*dp2
= (u16
*) buf
;
133 /* buffer is already in 'usb data order', which is LE. */
134 /* When reading buffer as u16, we have to take care byte order */
135 /* doesn't get mixed up */
137 if ((unsigned long)dp2
& 1) {
139 for (; len
> 1; len
-= 2) {
140 w
= isp116x_raw_read_data16(isp116x
);
142 *dp
++ = (w
>> 8) & 0xff;
146 *dp
= 0xff & isp116x_read_data16(isp116x
);
149 for (; len
> 1; len
-= 2) {
150 /* Keep byte order! */
151 *dp2
++ = le16_to_cpu(isp116x_raw_read_data16(isp116x
));
155 *(u8
*) dp2
= 0xff & isp116x_read_data16(isp116x
);
157 if (quot
== 1 || quot
== 2)
158 isp116x_raw_read_data16(isp116x
);
162 Write ptd's and data for scheduled transfers into
163 the fifo ram. Fifo must be empty and ready.
165 static void pack_fifo(struct isp116x
*isp116x
)
167 struct isp116x_ep
*ep
;
169 int buflen
= isp116x
->atl_last_dir
== PTD_DIR_IN
170 ? isp116x
->atl_bufshrt
: isp116x
->atl_buflen
;
172 isp116x_write_reg16(isp116x
, HCuPINT
, HCuPINT_AIIEOT
);
173 isp116x_write_reg16(isp116x
, HCXFERCTR
, buflen
);
174 isp116x_write_addr(isp116x
, HCATLPORT
| ISP116x_WRITE_OFFSET
);
175 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
178 dump_ptd_out_data(ptd
, ep
->data
);
179 isp116x_write_data16(isp116x
, ptd
->count
);
180 isp116x_write_data16(isp116x
, ptd
->mps
);
181 isp116x_write_data16(isp116x
, ptd
->len
);
182 isp116x_write_data16(isp116x
, ptd
->faddr
);
183 buflen
-= sizeof(struct ptd
);
184 /* Skip writing data for last IN PTD */
185 if (ep
->active
|| (isp116x
->atl_last_dir
!= PTD_DIR_IN
)) {
186 write_ptddata_to_fifo(isp116x
, ep
->data
, ep
->length
);
187 buflen
-= ALIGN(ep
->length
, 4);
194 Read the processed ptd's and data from fifo ram back to
195 URBs' buffers. Fifo must be full and done
197 static void unpack_fifo(struct isp116x
*isp116x
)
199 struct isp116x_ep
*ep
;
201 int buflen
= isp116x
->atl_last_dir
== PTD_DIR_IN
202 ? isp116x
->atl_buflen
: isp116x
->atl_bufshrt
;
204 isp116x_write_reg16(isp116x
, HCuPINT
, HCuPINT_AIIEOT
);
205 isp116x_write_reg16(isp116x
, HCXFERCTR
, buflen
);
206 isp116x_write_addr(isp116x
, HCATLPORT
);
207 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
209 ptd
->count
= isp116x_read_data16(isp116x
);
210 ptd
->mps
= isp116x_read_data16(isp116x
);
211 ptd
->len
= isp116x_read_data16(isp116x
);
212 ptd
->faddr
= isp116x_read_data16(isp116x
);
213 buflen
-= sizeof(struct ptd
);
214 /* Skip reading data for last Setup or Out PTD */
215 if (ep
->active
|| (isp116x
->atl_last_dir
== PTD_DIR_IN
)) {
216 read_ptddata_from_fifo(isp116x
, ep
->data
, ep
->length
);
217 buflen
-= ALIGN(ep
->length
, 4);
220 dump_ptd_in_data(ptd
, ep
->data
);
225 /*---------------------------------------------------------------*/
230 static void preproc_atl_queue(struct isp116x
*isp116x
)
232 struct isp116x_ep
*ep
;
237 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
238 u16 toggle
= 0, dir
= PTD_DIR_SETUP
;
240 BUG_ON(list_empty(&ep
->hep
->urb_list
));
241 urb
= container_of(ep
->hep
->urb_list
.next
,
242 struct urb
, urb_list
);
245 ep
->data
= (unsigned char *)urb
->transfer_buffer
246 + urb
->actual_length
;
248 switch (ep
->nextpid
) {
250 toggle
= usb_gettoggle(urb
->dev
, ep
->epnum
, 0);
254 toggle
= usb_gettoggle(urb
->dev
, ep
->epnum
, 1);
258 len
= sizeof(struct usb_ctrlrequest
);
259 ep
->data
= urb
->setup_packet
;
264 dir
= (urb
->transfer_buffer_length
265 && usb_pipein(urb
->pipe
))
266 ? PTD_DIR_OUT
: PTD_DIR_IN
;
269 ERR("%s %d: ep->nextpid %d\n", __func__
, __LINE__
,
274 ptd
->count
= PTD_CC_MSK
| PTD_ACTIVE_MSK
| PTD_TOGGLE(toggle
);
275 ptd
->mps
= PTD_MPS(ep
->maxpacket
)
276 | PTD_SPD(urb
->dev
->speed
== USB_SPEED_LOW
)
278 ptd
->len
= PTD_LEN(len
) | PTD_DIR(dir
);
279 ptd
->faddr
= PTD_FA(usb_pipedevice(urb
->pipe
));
281 ptd
->mps
|= PTD_LAST_MSK
;
282 isp116x
->atl_last_dir
= dir
;
284 isp116x
->atl_bufshrt
= sizeof(struct ptd
) + isp116x
->atl_buflen
;
285 isp116x
->atl_buflen
= isp116x
->atl_bufshrt
+ ALIGN(len
, 4);
290 Take done or failed requests out of schedule. Give back
293 static void finish_request(struct isp116x
*isp116x
, struct isp116x_ep
*ep
,
294 struct urb
*urb
, int status
)
295 __releases(isp116x
->lock
) __acquires(isp116x
->lock
)
301 if (usb_pipecontrol(urb
->pipe
))
302 ep
->nextpid
= USB_PID_SETUP
;
304 urb_dbg(urb
, "Finish");
306 usb_hcd_unlink_urb_from_ep(isp116x_to_hcd(isp116x
), urb
);
307 spin_unlock(&isp116x
->lock
);
308 usb_hcd_giveback_urb(isp116x_to_hcd(isp116x
), urb
, status
);
309 spin_lock(&isp116x
->lock
);
311 /* take idle endpoints out of the schedule */
312 if (!list_empty(&ep
->hep
->urb_list
))
315 /* async deschedule */
316 if (!list_empty(&ep
->schedule
)) {
317 list_del_init(&ep
->schedule
);
321 /* periodic deschedule */
322 DBG("deschedule qh%d/%p branch %d\n", ep
->period
, ep
, ep
->branch
);
323 for (i
= ep
->branch
; i
< PERIODIC_SIZE
; i
+= ep
->period
) {
324 struct isp116x_ep
*temp
;
325 struct isp116x_ep
**prev
= &isp116x
->periodic
[i
];
327 while (*prev
&& ((temp
= *prev
) != ep
))
331 isp116x
->load
[i
] -= ep
->load
;
333 ep
->branch
= PERIODIC_SIZE
;
334 isp116x_to_hcd(isp116x
)->self
.bandwidth_allocated
-=
335 ep
->load
/ ep
->period
;
337 /* switch irq type? */
338 if (!--isp116x
->periodic_count
) {
339 isp116x
->irqenb
&= ~HCuPINT_SOF
;
340 isp116x
->irqenb
|= HCuPINT_ATL
;
345 Analyze transfer results, handle partial transfers and errors
347 static void postproc_atl_queue(struct isp116x
*isp116x
)
349 struct isp116x_ep
*ep
;
351 struct usb_device
*udev
;
357 for (ep
= isp116x
->atl_active
; ep
; ep
= ep
->active
) {
358 BUG_ON(list_empty(&ep
->hep
->urb_list
));
360 container_of(ep
->hep
->urb_list
.next
, struct urb
, urb_list
);
363 cc
= PTD_GET_CC(ptd
);
365 status
= -EINPROGRESS
;
367 /* Data underrun is special. For allowed underrun
368 we clear the error and continue as normal. For
369 forbidden underrun we finish the DATA stage
370 immediately while for control transfer,
371 we do a STATUS stage. */
372 if (cc
== TD_DATAUNDERRUN
) {
373 if (!(urb
->transfer_flags
& URB_SHORT_NOT_OK
) ||
374 usb_pipecontrol(urb
->pipe
)) {
375 DBG("Allowed or control data underrun\n");
380 usb_settoggle(udev
, ep
->epnum
,
381 ep
->nextpid
== USB_PID_OUT
,
382 PTD_GET_TOGGLE(ptd
));
383 urb
->actual_length
+= PTD_GET_COUNT(ptd
);
384 status
= cc_to_error
[TD_DATAUNDERRUN
];
389 if (cc
!= TD_CC_NOERROR
&& cc
!= TD_NOTACCESSED
390 && (++ep
->error_count
>= 3 || cc
== TD_CC_STALL
391 || cc
== TD_DATAOVERRUN
)) {
392 status
= cc_to_error
[cc
];
393 if (ep
->nextpid
== USB_PID_ACK
)
397 /* According to usb spec, zero-length Int transfer signals
398 finishing of the urb. Hey, does this apply only
400 if (usb_pipeint(urb
->pipe
) && !PTD_GET_LEN(ptd
)) {
405 /* Relax after previously failed, but later succeeded
406 or correctly NAK'ed retransmission attempt */
408 && (cc
== TD_CC_NOERROR
|| cc
== TD_NOTACCESSED
))
411 /* Take into account idiosyncracies of the isp116x chip
412 regarding toggle bit for failed transfers */
413 if (ep
->nextpid
== USB_PID_OUT
)
414 usb_settoggle(udev
, ep
->epnum
, 1, PTD_GET_TOGGLE(ptd
)
415 ^ (ep
->error_count
> 0));
416 else if (ep
->nextpid
== USB_PID_IN
)
417 usb_settoggle(udev
, ep
->epnum
, 0, PTD_GET_TOGGLE(ptd
)
418 ^ (ep
->error_count
> 0));
420 switch (ep
->nextpid
) {
423 urb
->actual_length
+= PTD_GET_COUNT(ptd
);
424 if (PTD_GET_ACTIVE(ptd
)
425 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
427 if (urb
->transfer_buffer_length
!= urb
->actual_length
) {
431 if (urb
->transfer_flags
& URB_ZERO_PACKET
432 && ep
->nextpid
== USB_PID_OUT
433 && !(PTD_GET_COUNT(ptd
) % ep
->maxpacket
)) {
434 DBG("Zero packet requested\n");
438 /* All data for this URB is transferred, let's finish */
439 if (usb_pipecontrol(urb
->pipe
))
440 ep
->nextpid
= USB_PID_ACK
;
445 if (PTD_GET_ACTIVE(ptd
)
446 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
448 if (urb
->transfer_buffer_length
== urb
->actual_length
)
449 ep
->nextpid
= USB_PID_ACK
;
450 else if (usb_pipeout(urb
->pipe
)) {
451 usb_settoggle(udev
, 0, 1, 1);
452 ep
->nextpid
= USB_PID_OUT
;
454 usb_settoggle(udev
, 0, 0, 1);
455 ep
->nextpid
= USB_PID_IN
;
459 if (PTD_GET_ACTIVE(ptd
)
460 || (cc
!= TD_CC_NOERROR
&& cc
< 0x0E))
470 if (status
!= -EINPROGRESS
|| urb
->unlinked
)
471 finish_request(isp116x
, ep
, urb
, status
);
476 Scan transfer lists, schedule transfers, send data off
479 static void start_atl_transfers(struct isp116x
*isp116x
)
481 struct isp116x_ep
*last_ep
= NULL
, *ep
;
484 int len
, index
, speed
, byte_time
;
486 if (atomic_read(&isp116x
->atl_finishing
))
489 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x
)->state
))
492 /* FIFO not empty? */
493 if (isp116x_read_reg16(isp116x
, HCBUFSTAT
) & HCBUFSTAT_ATL_FULL
)
496 isp116x
->atl_active
= NULL
;
497 isp116x
->atl_buflen
= isp116x
->atl_bufshrt
= 0;
499 /* Schedule int transfers */
500 if (isp116x
->periodic_count
) {
501 isp116x
->fmindex
= index
=
502 (isp116x
->fmindex
+ 1) & (PERIODIC_SIZE
- 1);
503 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
= USB_DT_HUB
;
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) &
956 desc
->bPwrOn2PwrGood
= (u8
) ((reg
>> 24) & 0xff);
957 /* ports removable, and legacy PortPwrCtrlMask */
958 desc
->u
.hs
.DeviceRemovable
[0] = 0;
959 desc
->u
.hs
.DeviceRemovable
[1] = ~0;
962 /* Perform reset of a given port.
963 It would be great to just start the reset and let the
964 USB core to clear the reset in due time. However,
965 root hub ports should be reset for at least 50 ms, while
966 our chip stays in reset for about 10 ms. I.e., we must
967 repeatedly reset it ourself here.
969 static inline void root_port_reset(struct isp116x
*isp116x
, unsigned port
)
972 unsigned long flags
, t
;
974 /* Root hub reset should be 50 ms, but some devices
975 want it even longer. */
976 t
= jiffies
+ msecs_to_jiffies(100);
978 while (time_before(jiffies
, t
)) {
979 spin_lock_irqsave(&isp116x
->lock
, flags
);
980 /* spin until any current reset finishes */
982 tmp
= isp116x_read_reg32(isp116x
, port
?
983 HCRHPORT2
: HCRHPORT1
);
984 if (!(tmp
& RH_PS_PRS
))
988 /* Don't reset a disconnected port */
989 if (!(tmp
& RH_PS_CCS
)) {
990 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
993 /* Reset lasts 10ms (claims datasheet) */
994 isp116x_write_reg32(isp116x
, port
? HCRHPORT2
:
995 HCRHPORT1
, (RH_PS_PRS
));
996 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1001 /* Adapted from ohci-hub.c */
1002 static int isp116x_hub_control(struct usb_hcd
*hcd
,
1004 u16 wValue
, u16 wIndex
, char *buf
, u16 wLength
)
1006 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1008 unsigned long flags
;
1009 int ports
= isp116x
->rhdesca
& RH_A_NDP
;
1013 case ClearHubFeature
:
1014 DBG("ClearHubFeature: ");
1016 case C_HUB_OVER_CURRENT
:
1017 DBG("C_HUB_OVER_CURRENT\n");
1018 spin_lock_irqsave(&isp116x
->lock
, flags
);
1019 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_OCIC
);
1020 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1021 case C_HUB_LOCAL_POWER
:
1022 DBG("C_HUB_LOCAL_POWER\n");
1029 DBG("SetHubFeature: ");
1031 case C_HUB_OVER_CURRENT
:
1032 case C_HUB_LOCAL_POWER
:
1033 DBG("C_HUB_OVER_CURRENT or C_HUB_LOCAL_POWER\n");
1039 case GetHubDescriptor
:
1040 DBG("GetHubDescriptor\n");
1041 isp116x_hub_descriptor(isp116x
,
1042 (struct usb_hub_descriptor
*)buf
);
1045 DBG("GetHubStatus\n");
1046 *(__le32
*) buf
= 0;
1049 DBG("GetPortStatus\n");
1050 if (!wIndex
|| wIndex
> ports
)
1052 spin_lock_irqsave(&isp116x
->lock
, flags
);
1053 tmp
= isp116x_read_reg32(isp116x
, (--wIndex
) ? HCRHPORT2
: HCRHPORT1
);
1054 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1055 *(__le32
*) buf
= cpu_to_le32(tmp
);
1056 DBG("GetPortStatus: port[%d] %08x\n", wIndex
+ 1, tmp
);
1058 case ClearPortFeature
:
1059 DBG("ClearPortFeature: ");
1060 if (!wIndex
|| wIndex
> ports
)
1065 case USB_PORT_FEAT_ENABLE
:
1066 DBG("USB_PORT_FEAT_ENABLE\n");
1069 case USB_PORT_FEAT_C_ENABLE
:
1070 DBG("USB_PORT_FEAT_C_ENABLE\n");
1073 case USB_PORT_FEAT_SUSPEND
:
1074 DBG("USB_PORT_FEAT_SUSPEND\n");
1077 case USB_PORT_FEAT_C_SUSPEND
:
1078 DBG("USB_PORT_FEAT_C_SUSPEND\n");
1081 case USB_PORT_FEAT_POWER
:
1082 DBG("USB_PORT_FEAT_POWER\n");
1085 case USB_PORT_FEAT_C_CONNECTION
:
1086 DBG("USB_PORT_FEAT_C_CONNECTION\n");
1089 case USB_PORT_FEAT_C_OVER_CURRENT
:
1090 DBG("USB_PORT_FEAT_C_OVER_CURRENT\n");
1093 case USB_PORT_FEAT_C_RESET
:
1094 DBG("USB_PORT_FEAT_C_RESET\n");
1100 spin_lock_irqsave(&isp116x
->lock
, flags
);
1101 isp116x_write_reg32(isp116x
, wIndex
1102 ? HCRHPORT2
: HCRHPORT1
, tmp
);
1103 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1105 case SetPortFeature
:
1106 DBG("SetPortFeature: ");
1107 if (!wIndex
|| wIndex
> ports
)
1111 case USB_PORT_FEAT_SUSPEND
:
1112 DBG("USB_PORT_FEAT_SUSPEND\n");
1113 spin_lock_irqsave(&isp116x
->lock
, flags
);
1114 isp116x_write_reg32(isp116x
, wIndex
1115 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PSS
);
1116 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1118 case USB_PORT_FEAT_POWER
:
1119 DBG("USB_PORT_FEAT_POWER\n");
1120 spin_lock_irqsave(&isp116x
->lock
, flags
);
1121 isp116x_write_reg32(isp116x
, wIndex
1122 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PPS
);
1123 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1125 case USB_PORT_FEAT_RESET
:
1126 DBG("USB_PORT_FEAT_RESET\n");
1127 root_port_reset(isp116x
, wIndex
);
1136 /* "protocol stall" on error */
1137 DBG("PROTOCOL STALL\n");
1143 /*-----------------------------------------------------------------*/
1145 #ifdef CONFIG_DEBUG_FS
1147 static void dump_irq(struct seq_file
*s
, char *label
, u16 mask
)
1149 seq_printf(s
, "%s %04x%s%s%s%s%s%s\n", label
, mask
,
1150 mask
& HCuPINT_CLKRDY
? " clkrdy" : "",
1151 mask
& HCuPINT_SUSP
? " susp" : "",
1152 mask
& HCuPINT_OPR
? " opr" : "",
1153 mask
& HCuPINT_AIIEOT
? " eot" : "",
1154 mask
& HCuPINT_ATL
? " atl" : "",
1155 mask
& HCuPINT_SOF
? " sof" : "");
1158 static void dump_int(struct seq_file
*s
, char *label
, u32 mask
)
1160 seq_printf(s
, "%s %08x%s%s%s%s%s%s%s\n", label
, mask
,
1161 mask
& HCINT_MIE
? " MIE" : "",
1162 mask
& HCINT_RHSC
? " rhsc" : "",
1163 mask
& HCINT_FNO
? " fno" : "",
1164 mask
& HCINT_UE
? " ue" : "",
1165 mask
& HCINT_RD
? " rd" : "",
1166 mask
& HCINT_SF
? " sof" : "", mask
& HCINT_SO
? " so" : "");
1169 static int isp116x_show_dbg(struct seq_file
*s
, void *unused
)
1171 struct isp116x
*isp116x
= s
->private;
1173 seq_printf(s
, "%s\n%s version %s\n",
1174 isp116x_to_hcd(isp116x
)->product_desc
, hcd_name
,
1177 if (HC_IS_SUSPENDED(isp116x_to_hcd(isp116x
)->state
)) {
1178 seq_printf(s
, "HCD is suspended\n");
1181 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x
)->state
)) {
1182 seq_printf(s
, "HCD not running\n");
1186 spin_lock_irq(&isp116x
->lock
);
1187 dump_irq(s
, "hc_irq_enable", isp116x_read_reg16(isp116x
, HCuPINTENB
));
1188 dump_irq(s
, "hc_irq_status", isp116x_read_reg16(isp116x
, HCuPINT
));
1189 dump_int(s
, "hc_int_enable", isp116x_read_reg32(isp116x
, HCINTENB
));
1190 dump_int(s
, "hc_int_status", isp116x_read_reg32(isp116x
, HCINTSTAT
));
1191 isp116x_show_regs_seq(isp116x
, s
);
1192 spin_unlock_irq(&isp116x
->lock
);
1193 seq_printf(s
, "\n");
1198 static int isp116x_open_seq(struct inode
*inode
, struct file
*file
)
1200 return single_open(file
, isp116x_show_dbg
, inode
->i_private
);
1203 static const struct file_operations isp116x_debug_fops
= {
1204 .open
= isp116x_open_seq
,
1206 .llseek
= seq_lseek
,
1207 .release
= single_release
,
1210 static int create_debug_file(struct isp116x
*isp116x
)
1212 isp116x
->dentry
= debugfs_create_file(hcd_name
,
1213 S_IRUGO
, NULL
, isp116x
,
1214 &isp116x_debug_fops
);
1215 if (!isp116x
->dentry
)
1220 static void remove_debug_file(struct isp116x
*isp116x
)
1222 debugfs_remove(isp116x
->dentry
);
1227 #define create_debug_file(d) 0
1228 #define remove_debug_file(d) do{}while(0)
1230 #endif /* CONFIG_DEBUG_FS */
1232 /*-----------------------------------------------------------------*/
1235 Software reset - can be called from any contect.
1237 static int isp116x_sw_reset(struct isp116x
*isp116x
)
1240 unsigned long flags
;
1243 spin_lock_irqsave(&isp116x
->lock
, flags
);
1244 isp116x_write_reg16(isp116x
, HCSWRES
, HCSWRES_MAGIC
);
1245 isp116x_write_reg32(isp116x
, HCCMDSTAT
, HCCMDSTAT_HCR
);
1247 /* It usually resets within 1 ms */
1249 if (!(isp116x_read_reg32(isp116x
, HCCMDSTAT
) & HCCMDSTAT_HCR
))
1253 ERR("Software reset timeout\n");
1256 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1260 static int isp116x_reset(struct usb_hcd
*hcd
)
1262 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1265 int ret
, timeout
= 15 /* ms */ ;
1267 ret
= isp116x_sw_reset(isp116x
);
1271 t
= jiffies
+ msecs_to_jiffies(timeout
);
1272 while (time_before_eq(jiffies
, t
)) {
1274 spin_lock_irq(&isp116x
->lock
);
1275 clkrdy
= isp116x_read_reg16(isp116x
, HCuPINT
) & HCuPINT_CLKRDY
;
1276 spin_unlock_irq(&isp116x
->lock
);
1281 ERR("Clock not ready after %dms\n", timeout
);
1282 /* After sw_reset the clock won't report to be ready, if
1283 H_WAKEUP pin is high. */
1284 ERR("Please make sure that the H_WAKEUP pin is pulled low!\n");
1290 static void isp116x_stop(struct usb_hcd
*hcd
)
1292 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1293 unsigned long flags
;
1296 spin_lock_irqsave(&isp116x
->lock
, flags
);
1297 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1299 /* Switch off ports' power, some devices don't come up
1300 after next 'insmod' without this */
1301 val
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1302 val
&= ~(RH_A_NPS
| RH_A_PSM
);
1303 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1304 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_LPS
);
1305 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1307 isp116x_sw_reset(isp116x
);
1311 Configure the chip. The chip must be successfully reset by now.
1313 static int isp116x_start(struct usb_hcd
*hcd
)
1315 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1316 struct isp116x_platform_data
*board
= isp116x
->board
;
1318 unsigned long flags
;
1320 spin_lock_irqsave(&isp116x
->lock
, flags
);
1322 /* clear interrupt status and disable all interrupt sources */
1323 isp116x_write_reg16(isp116x
, HCuPINT
, 0xff);
1324 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1326 val
= isp116x_read_reg16(isp116x
, HCCHIPID
);
1327 if ((val
& HCCHIPID_MASK
) != HCCHIPID_MAGIC
) {
1328 ERR("Invalid chip ID %04x\n", val
);
1329 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1333 /* To be removed in future */
1334 hcd
->uses_new_polling
= 1;
1336 isp116x_write_reg16(isp116x
, HCITLBUFLEN
, ISP116x_ITL_BUFSIZE
);
1337 isp116x_write_reg16(isp116x
, HCATLBUFLEN
, ISP116x_ATL_BUFSIZE
);
1340 val
= HCHWCFG_INT_ENABLE
| HCHWCFG_DBWIDTH(1);
1341 if (board
->sel15Kres
)
1342 val
|= HCHWCFG_15KRSEL
;
1343 /* Remote wakeup won't work without working clock */
1344 if (board
->remote_wakeup_enable
)
1345 val
|= HCHWCFG_CLKNOTSTOP
;
1346 if (board
->oc_enable
)
1347 val
|= HCHWCFG_ANALOG_OC
;
1348 if (board
->int_act_high
)
1349 val
|= HCHWCFG_INT_POL
;
1350 if (board
->int_edge_triggered
)
1351 val
|= HCHWCFG_INT_TRIGGER
;
1352 isp116x_write_reg16(isp116x
, HCHWCFG
, val
);
1354 /* ----- Root hub conf */
1355 val
= (25 << 24) & RH_A_POTPGT
;
1356 /* AN10003_1.pdf recommends RH_A_NPS (no power switching) to
1357 be always set. Yet, instead, we request individual port
1360 /* Report overcurrent per port */
1362 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1363 isp116x
->rhdesca
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1366 isp116x_write_reg32(isp116x
, HCRHDESCB
, val
);
1367 isp116x
->rhdescb
= isp116x_read_reg32(isp116x
, HCRHDESCB
);
1370 if (board
->remote_wakeup_enable
) {
1371 if (!device_can_wakeup(hcd
->self
.controller
))
1372 device_init_wakeup(hcd
->self
.controller
, 1);
1375 isp116x_write_reg32(isp116x
, HCRHSTATUS
, val
);
1376 isp116x
->rhstatus
= isp116x_read_reg32(isp116x
, HCRHSTATUS
);
1378 isp116x_write_reg32(isp116x
, HCFMINTVL
, 0x27782edf);
1380 hcd
->state
= HC_STATE_RUNNING
;
1382 /* Set up interrupts */
1383 isp116x
->intenb
= HCINT_MIE
| HCINT_RHSC
| HCINT_UE
;
1384 if (board
->remote_wakeup_enable
)
1385 isp116x
->intenb
|= HCINT_RD
;
1386 isp116x
->irqenb
= HCuPINT_ATL
| HCuPINT_OPR
; /* | HCuPINT_SUSP; */
1387 isp116x_write_reg32(isp116x
, HCINTENB
, isp116x
->intenb
);
1388 isp116x_write_reg16(isp116x
, HCuPINTENB
, isp116x
->irqenb
);
1390 /* Go operational */
1391 val
= HCCONTROL_USB_OPER
;
1392 if (board
->remote_wakeup_enable
)
1393 val
|= HCCONTROL_RWE
;
1394 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1396 /* Disable ports to avoid race in device enumeration */
1397 isp116x_write_reg32(isp116x
, HCRHPORT1
, RH_PS_CCS
);
1398 isp116x_write_reg32(isp116x
, HCRHPORT2
, RH_PS_CCS
);
1400 isp116x_show_regs_log(isp116x
);
1401 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1407 static int isp116x_bus_suspend(struct usb_hcd
*hcd
)
1409 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1410 unsigned long flags
;
1414 spin_lock_irqsave(&isp116x
->lock
, flags
);
1415 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1417 switch (val
& HCCONTROL_HCFS
) {
1418 case HCCONTROL_USB_OPER
:
1419 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1420 val
&= (~HCCONTROL_HCFS
& ~HCCONTROL_RWE
);
1421 val
|= HCCONTROL_USB_SUSPEND
;
1422 if (hcd
->self
.root_hub
->do_remote_wakeup
)
1423 val
|= HCCONTROL_RWE
;
1424 /* Wait for usb transfers to finish */
1426 spin_lock_irqsave(&isp116x
->lock
, flags
);
1427 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1428 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1429 /* Wait for devices to suspend */
1432 case HCCONTROL_USB_RESUME
:
1433 isp116x_write_reg32(isp116x
, HCCONTROL
,
1434 (val
& ~HCCONTROL_HCFS
) |
1435 HCCONTROL_USB_RESET
);
1436 case HCCONTROL_USB_RESET
:
1438 default: /* HCCONTROL_USB_SUSPEND */
1439 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1446 static int isp116x_bus_resume(struct usb_hcd
*hcd
)
1448 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1452 spin_lock_irq(&isp116x
->lock
);
1454 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1455 switch (val
& HCCONTROL_HCFS
) {
1456 case HCCONTROL_USB_SUSPEND
:
1457 val
&= ~HCCONTROL_HCFS
;
1458 val
|= HCCONTROL_USB_RESUME
;
1459 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1460 case HCCONTROL_USB_RESUME
:
1462 case HCCONTROL_USB_OPER
:
1463 spin_unlock_irq(&isp116x
->lock
);
1466 /* HCCONTROL_USB_RESET: this may happen, when during
1467 suspension the HC lost power. Reinitialize completely */
1468 spin_unlock_irq(&isp116x
->lock
);
1469 DBG("Chip has been reset while suspended. Reinit from scratch.\n");
1472 isp116x_hub_control(hcd
, SetPortFeature
,
1473 USB_PORT_FEAT_POWER
, 1, NULL
, 0);
1474 if ((isp116x
->rhdesca
& RH_A_NDP
) == 2)
1475 isp116x_hub_control(hcd
, SetPortFeature
,
1476 USB_PORT_FEAT_POWER
, 2, NULL
, 0);
1480 val
= isp116x
->rhdesca
& RH_A_NDP
;
1483 isp116x_read_reg32(isp116x
, val
? HCRHPORT2
: HCRHPORT1
);
1484 /* force global, not selective, resume */
1485 if (!(stat
& RH_PS_PSS
))
1487 DBG("%s: Resuming port %d\n", __func__
, val
);
1488 isp116x_write_reg32(isp116x
, RH_PS_POCI
, val
1489 ? HCRHPORT2
: HCRHPORT1
);
1491 spin_unlock_irq(&isp116x
->lock
);
1493 hcd
->state
= HC_STATE_RESUMING
;
1494 msleep(USB_RESUME_TIMEOUT
);
1496 /* Go operational */
1497 spin_lock_irq(&isp116x
->lock
);
1498 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1499 isp116x_write_reg32(isp116x
, HCCONTROL
,
1500 (val
& ~HCCONTROL_HCFS
) | HCCONTROL_USB_OPER
);
1501 spin_unlock_irq(&isp116x
->lock
);
1502 hcd
->state
= HC_STATE_RUNNING
;
1509 #define isp116x_bus_suspend NULL
1510 #define isp116x_bus_resume NULL
1514 static struct hc_driver isp116x_hc_driver
= {
1515 .description
= hcd_name
,
1516 .product_desc
= "ISP116x Host Controller",
1517 .hcd_priv_size
= sizeof(struct isp116x
),
1522 .reset
= isp116x_reset
,
1523 .start
= isp116x_start
,
1524 .stop
= isp116x_stop
,
1526 .urb_enqueue
= isp116x_urb_enqueue
,
1527 .urb_dequeue
= isp116x_urb_dequeue
,
1528 .endpoint_disable
= isp116x_endpoint_disable
,
1530 .get_frame_number
= isp116x_get_frame
,
1532 .hub_status_data
= isp116x_hub_status_data
,
1533 .hub_control
= isp116x_hub_control
,
1534 .bus_suspend
= isp116x_bus_suspend
,
1535 .bus_resume
= isp116x_bus_resume
,
1538 /*----------------------------------------------------------------*/
1540 static int isp116x_remove(struct platform_device
*pdev
)
1542 struct usb_hcd
*hcd
= platform_get_drvdata(pdev
);
1543 struct isp116x
*isp116x
;
1544 struct resource
*res
;
1548 isp116x
= hcd_to_isp116x(hcd
);
1549 remove_debug_file(isp116x
);
1550 usb_remove_hcd(hcd
);
1552 iounmap(isp116x
->data_reg
);
1553 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1554 release_mem_region(res
->start
, 2);
1555 iounmap(isp116x
->addr_reg
);
1556 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1557 release_mem_region(res
->start
, 2);
1563 static int isp116x_probe(struct platform_device
*pdev
)
1565 struct usb_hcd
*hcd
;
1566 struct isp116x
*isp116x
;
1567 struct resource
*addr
, *data
, *ires
;
1568 void __iomem
*addr_reg
;
1569 void __iomem
*data_reg
;
1572 unsigned long irqflags
;
1577 if (pdev
->num_resources
< 3) {
1582 data
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1583 addr
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1584 ires
= platform_get_resource(pdev
, IORESOURCE_IRQ
, 0);
1586 if (!addr
|| !data
|| !ires
) {
1592 irqflags
= ires
->flags
& IRQF_TRIGGER_MASK
;
1594 if (pdev
->dev
.dma_mask
) {
1595 DBG("DMA not supported\n");
1600 if (!request_mem_region(addr
->start
, 2, hcd_name
)) {
1604 addr_reg
= ioremap(addr
->start
, resource_size(addr
));
1605 if (addr_reg
== NULL
) {
1609 if (!request_mem_region(data
->start
, 2, hcd_name
)) {
1613 data_reg
= ioremap(data
->start
, resource_size(data
));
1614 if (data_reg
== NULL
) {
1619 /* allocate and initialize hcd */
1620 hcd
= usb_create_hcd(&isp116x_hc_driver
, &pdev
->dev
, dev_name(&pdev
->dev
));
1625 /* this rsrc_start is bogus */
1626 hcd
->rsrc_start
= addr
->start
;
1627 isp116x
= hcd_to_isp116x(hcd
);
1628 isp116x
->data_reg
= data_reg
;
1629 isp116x
->addr_reg
= addr_reg
;
1630 spin_lock_init(&isp116x
->lock
);
1631 INIT_LIST_HEAD(&isp116x
->async
);
1632 isp116x
->board
= dev_get_platdata(&pdev
->dev
);
1634 if (!isp116x
->board
) {
1635 ERR("Platform data structure not initialized\n");
1639 if (isp116x_check_platform_delay(isp116x
)) {
1640 ERR("USE_PLATFORM_DELAY defined, but delay function not "
1642 ERR("See comments in drivers/usb/host/isp116x-hcd.c\n");
1647 ret
= usb_add_hcd(hcd
, irq
, irqflags
);
1651 device_wakeup_enable(hcd
->self
.controller
);
1653 ret
= create_debug_file(isp116x
);
1655 ERR("Couldn't create debugfs entry\n");
1662 usb_remove_hcd(hcd
);
1668 release_mem_region(data
->start
, 2);
1672 release_mem_region(addr
->start
, 2);
1674 ERR("init error, %d\n", ret
);
1680 Suspend of platform device
1682 static int isp116x_suspend(struct platform_device
*dev
, pm_message_t state
)
1684 VDBG("%s: state %x\n", __func__
, state
.event
);
1689 Resume platform device
1691 static int isp116x_resume(struct platform_device
*dev
)
1693 VDBG("%s\n", __func__
);
1699 #define isp116x_suspend NULL
1700 #define isp116x_resume NULL
1704 /* work with hotplug and coldplug */
1705 MODULE_ALIAS("platform:isp116x-hcd");
1707 static struct platform_driver isp116x_driver
= {
1708 .probe
= isp116x_probe
,
1709 .remove
= isp116x_remove
,
1710 .suspend
= isp116x_suspend
,
1711 .resume
= isp116x_resume
,
1717 module_platform_driver(isp116x_driver
);