1 // SPDX-License-Identifier: GPL-2.0
3 * ISP116x HCD (Host Controller Driver) for USB.
5 * Derived from the SL811 HCD, rewritten for ISP116x.
6 * Copyright (C) 2005 Olav Kongas <ok@artecdesign.ee>
9 * Copyright (C) 2004 Psion Teklogix (for NetBook PRO)
10 * Copyright (C) 2004 David Brownell
12 * Periodic scheduling is based on Roman's OHCI code
13 * Copyright (C) 1999 Roman Weissgaerber
18 * The driver basically works. A number of people have used it with a range
21 * The driver passes all usbtests 1-14.
23 * Suspending/resuming of root hub via sysfs works. Remote wakeup works too.
24 * And suspending/resuming of platform device works too. Suspend/resume
25 * via HCD operations vector is not implemented.
27 * Iso transfer support is not implemented. Adding this would include
28 * implementing recovery from the failure to service the processed ITL
29 * fifo ram in time, which will involve chip reset.
32 + More testing of suspend/resume.
36 ISP116x chips require certain delays between accesses to its
37 registers. The following timing options exist.
39 1. Configure your memory controller (the best)
40 2. Implement platform-specific delay function possibly
41 combined with configuring the memory controller; see
42 include/linux/usb-isp116x.h for more info. Some broken
43 memory controllers line LH7A400 SMC need this. Also,
44 uncomment for that to work the following
45 USE_PLATFORM_DELAY macro.
46 3. Use ndelay (easiest, poorest). For that, uncomment
47 the following USE_NDELAY macro.
49 #define USE_PLATFORM_DELAY
54 /* Transfer descriptors. See dump_ptd() for printout format */
56 /* enqueuing/finishing log of urbs */
59 #include <linux/module.h>
60 #include <linux/delay.h>
61 #include <linux/debugfs.h>
62 #include <linux/seq_file.h>
63 #include <linux/errno.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 load
= isp116x
->load
[index
];
506 /* Bring all int transfers for this frame
507 into the active queue */
508 isp116x
->atl_active
= last_ep
=
509 isp116x
->periodic
[index
];
510 while (last_ep
->next
)
511 last_ep
= (last_ep
->active
= last_ep
->next
);
512 last_ep
->active
= NULL
;
516 /* Schedule control/bulk transfers */
517 list_for_each_entry(ep
, &isp116x
->async
, schedule
) {
518 urb
= container_of(ep
->hep
->urb_list
.next
,
519 struct urb
, urb_list
);
520 speed
= urb
->dev
->speed
;
521 byte_time
= speed
== USB_SPEED_LOW
522 ? BYTE_TIME_LOWSPEED
: BYTE_TIME_FULLSPEED
;
524 if (ep
->nextpid
== USB_PID_SETUP
) {
525 len
= sizeof(struct usb_ctrlrequest
);
526 } else if (ep
->nextpid
== USB_PID_ACK
) {
529 /* Find current free length ... */
530 len
= (MAX_LOAD_LIMIT
- load
) / byte_time
;
532 /* ... then limit it to configured max size ... */
533 len
= min(len
, speed
== USB_SPEED_LOW
?
534 MAX_TRANSFER_SIZE_LOWSPEED
:
535 MAX_TRANSFER_SIZE_FULLSPEED
);
537 /* ... and finally cut to the multiple of MaxPacketSize,
538 or to the real length if there's enough room. */
540 (urb
->transfer_buffer_length
-
541 urb
->actual_length
)) {
542 len
-= len
% ep
->maxpacket
;
546 len
= urb
->transfer_buffer_length
-
551 load
+= len
* byte_time
;
552 if (load
> MAX_LOAD_LIMIT
)
558 last_ep
->active
= ep
;
560 isp116x
->atl_active
= ep
;
564 /* Avoid starving of endpoints */
565 if ((&isp116x
->async
)->next
!= (&isp116x
->async
)->prev
)
566 list_move(&isp116x
->async
, (&isp116x
->async
)->next
);
568 if (isp116x
->atl_active
) {
569 preproc_atl_queue(isp116x
);
575 Finish the processed transfers
577 static void finish_atl_transfers(struct isp116x
*isp116x
)
579 if (!isp116x
->atl_active
)
581 /* Fifo not ready? */
582 if (!(isp116x_read_reg16(isp116x
, HCBUFSTAT
) & HCBUFSTAT_ATL_DONE
))
585 atomic_inc(&isp116x
->atl_finishing
);
586 unpack_fifo(isp116x
);
587 postproc_atl_queue(isp116x
);
588 atomic_dec(&isp116x
->atl_finishing
);
591 static irqreturn_t
isp116x_irq(struct usb_hcd
*hcd
)
593 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
595 irqreturn_t ret
= IRQ_NONE
;
597 spin_lock(&isp116x
->lock
);
598 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
599 irqstat
= isp116x_read_reg16(isp116x
, HCuPINT
);
600 isp116x_write_reg16(isp116x
, HCuPINT
, irqstat
);
602 if (irqstat
& (HCuPINT_ATL
| HCuPINT_SOF
)) {
604 finish_atl_transfers(isp116x
);
607 if (irqstat
& HCuPINT_OPR
) {
608 u32 intstat
= isp116x_read_reg32(isp116x
, HCINTSTAT
);
609 isp116x_write_reg32(isp116x
, HCINTSTAT
, intstat
);
610 if (intstat
& HCINT_UE
) {
611 ERR("Unrecoverable error, HC is dead!\n");
612 /* IRQ's are off, we do no DMA,
613 perfectly ready to die ... */
614 hcd
->state
= HC_STATE_HALT
;
619 if (intstat
& HCINT_RHSC
)
620 /* When root hub or any of its ports is going
621 to come out of suspend, it may take more
622 than 10ms for status bits to stabilize. */
623 mod_timer(&hcd
->rh_timer
, jiffies
624 + msecs_to_jiffies(20) + 1);
625 if (intstat
& HCINT_RD
) {
626 DBG("---- remote wakeup\n");
627 usb_hcd_resume_root_hub(hcd
);
629 irqstat
&= ~HCuPINT_OPR
;
633 if (irqstat
& (HCuPINT_ATL
| HCuPINT_SOF
)) {
634 start_atl_transfers(isp116x
);
637 isp116x_write_reg16(isp116x
, HCuPINTENB
, isp116x
->irqenb
);
639 spin_unlock(&isp116x
->lock
);
643 /*-----------------------------------------------------------------*/
645 /* usb 1.1 says max 90% of a frame is available for periodic transfers.
646 * this driver doesn't promise that much since it's got to handle an
647 * IRQ per packet; irq handling latencies also use up that time.
651 #define MAX_PERIODIC_LOAD 600
652 static int balance(struct isp116x
*isp116x
, u16 period
, u16 load
)
654 int i
, branch
= -ENOSPC
;
656 /* search for the least loaded schedule branch of that period
657 which has enough bandwidth left unreserved. */
658 for (i
= 0; i
< period
; i
++) {
659 if (branch
< 0 || isp116x
->load
[branch
] > isp116x
->load
[i
]) {
662 for (j
= i
; j
< PERIODIC_SIZE
; j
+= period
) {
663 if ((isp116x
->load
[j
] + load
)
667 if (j
< PERIODIC_SIZE
)
675 /* NB! ALL the code above this point runs with isp116x->lock
679 /*-----------------------------------------------------------------*/
681 static int isp116x_urb_enqueue(struct usb_hcd
*hcd
,
685 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
686 struct usb_device
*udev
= urb
->dev
;
687 unsigned int pipe
= urb
->pipe
;
688 int is_out
= !usb_pipein(pipe
);
689 int type
= usb_pipetype(pipe
);
690 int epnum
= usb_pipeendpoint(pipe
);
691 struct usb_host_endpoint
*hep
= urb
->ep
;
692 struct isp116x_ep
*ep
= NULL
;
697 urb_dbg(urb
, "Enqueue");
699 if (type
== PIPE_ISOCHRONOUS
) {
700 ERR("Isochronous transfers not supported\n");
701 urb_dbg(urb
, "Refused to enqueue");
704 /* avoid all allocations within spinlocks: request or endpoint */
706 ep
= kzalloc(sizeof *ep
, mem_flags
);
711 spin_lock_irqsave(&isp116x
->lock
, flags
);
712 if (!HC_IS_RUNNING(hcd
->state
)) {
715 goto fail_not_linked
;
717 ret
= usb_hcd_link_urb_to_ep(hcd
, urb
);
720 goto fail_not_linked
;
726 INIT_LIST_HEAD(&ep
->schedule
);
729 ep
->maxpacket
= usb_maxpacket(udev
, urb
->pipe
, is_out
);
730 usb_settoggle(udev
, epnum
, is_out
, 0);
732 if (type
== PIPE_CONTROL
) {
733 ep
->nextpid
= USB_PID_SETUP
;
735 ep
->nextpid
= USB_PID_OUT
;
737 ep
->nextpid
= USB_PID_IN
;
742 With INT URBs submitted, the driver works with SOF
743 interrupt enabled and ATL interrupt disabled. After
744 the PTDs are written to fifo ram, the chip starts
745 fifo processing and usb transfers after the next
746 SOF and continues until the transfers are finished
747 (succeeded or failed) or the frame ends. Therefore,
748 the transfers occur only in every second frame,
749 while fifo reading/writing and data processing
750 occur in every other second frame. */
751 if (urb
->interval
< 2)
753 if (urb
->interval
> 2 * PERIODIC_SIZE
)
754 urb
->interval
= 2 * PERIODIC_SIZE
;
755 ep
->period
= urb
->interval
>> 1;
756 ep
->branch
= PERIODIC_SIZE
;
757 ep
->load
= usb_calc_bus_time(udev
->speed
,
759 (type
== PIPE_ISOCHRONOUS
),
760 usb_maxpacket(udev
, pipe
,
768 /* maybe put endpoint into schedule */
772 if (list_empty(&ep
->schedule
))
773 list_add_tail(&ep
->schedule
, &isp116x
->async
);
776 urb
->interval
= ep
->period
;
777 ep
->length
= min_t(u32
, ep
->maxpacket
,
778 urb
->transfer_buffer_length
);
780 /* urb submitted for already existing endpoint */
781 if (ep
->branch
< PERIODIC_SIZE
)
784 ep
->branch
= ret
= balance(isp116x
, ep
->period
, ep
->load
);
789 urb
->start_frame
= (isp116x
->fmindex
& (PERIODIC_SIZE
- 1))
792 /* sort each schedule branch by period (slow before fast)
793 to share the faster parts of the tree without needing
794 dummy/placeholder nodes */
795 DBG("schedule qh%d/%p branch %d\n", ep
->period
, ep
, ep
->branch
);
796 for (i
= ep
->branch
; i
< PERIODIC_SIZE
; i
+= ep
->period
) {
797 struct isp116x_ep
**prev
= &isp116x
->periodic
[i
];
798 struct isp116x_ep
*here
= *prev
;
800 while (here
&& ep
!= here
) {
801 if (ep
->period
> here
->period
)
810 isp116x
->load
[i
] += ep
->load
;
812 hcd
->self
.bandwidth_allocated
+= ep
->load
/ ep
->period
;
814 /* switch over to SOFint */
815 if (!isp116x
->periodic_count
++) {
816 isp116x
->irqenb
&= ~HCuPINT_ATL
;
817 isp116x
->irqenb
|= HCuPINT_SOF
;
818 isp116x_write_reg16(isp116x
, HCuPINTENB
,
824 start_atl_transfers(isp116x
);
828 usb_hcd_unlink_urb_from_ep(hcd
, urb
);
830 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
837 static int isp116x_urb_dequeue(struct usb_hcd
*hcd
, struct urb
*urb
,
840 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
841 struct usb_host_endpoint
*hep
;
842 struct isp116x_ep
*ep
, *ep_act
;
846 spin_lock_irqsave(&isp116x
->lock
, flags
);
847 rc
= usb_hcd_check_unlink_urb(hcd
, urb
, status
);
853 WARN_ON(hep
!= ep
->hep
);
855 /* In front of queue? */
856 if (ep
->hep
->urb_list
.next
== &urb
->urb_list
)
858 for (ep_act
= isp116x
->atl_active
; ep_act
;
859 ep_act
= ep_act
->active
)
861 VDBG("dequeue, urb %p active; wait for irq\n",
868 finish_request(isp116x
, ep
, urb
, status
);
870 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
874 static void isp116x_endpoint_disable(struct usb_hcd
*hcd
,
875 struct usb_host_endpoint
*hep
)
878 struct isp116x_ep
*ep
= hep
->hcpriv
;
883 /* assume we'd just wait for the irq */
884 for (i
= 0; i
< 100 && !list_empty(&hep
->urb_list
); i
++)
886 if (!list_empty(&hep
->urb_list
))
887 WARNING("ep %p not empty?\n", ep
);
893 static int isp116x_get_frame(struct usb_hcd
*hcd
)
895 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
899 spin_lock_irqsave(&isp116x
->lock
, flags
);
900 fmnum
= isp116x_read_reg32(isp116x
, HCFMNUM
);
901 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
906 Adapted from ohci-hub.c. Currently we don't support autosuspend.
908 static int isp116x_hub_status_data(struct usb_hcd
*hcd
, char *buf
)
910 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
911 int ports
, i
, changed
= 0;
914 if (!HC_IS_RUNNING(hcd
->state
))
917 /* Report no status change now, if we are scheduled to be
919 if (timer_pending(&hcd
->rh_timer
))
922 ports
= isp116x
->rhdesca
& RH_A_NDP
;
923 spin_lock_irqsave(&isp116x
->lock
, flags
);
924 isp116x
->rhstatus
= isp116x_read_reg32(isp116x
, HCRHSTATUS
);
925 if (isp116x
->rhstatus
& (RH_HS_LPSC
| RH_HS_OCIC
))
926 buf
[0] = changed
= 1;
930 for (i
= 0; i
< ports
; i
++) {
931 u32 status
= isp116x_read_reg32(isp116x
, i
? HCRHPORT2
: HCRHPORT1
);
933 if (status
& (RH_PS_CSC
| RH_PS_PESC
| RH_PS_PSSC
934 | RH_PS_OCIC
| RH_PS_PRSC
)) {
936 buf
[0] |= 1 << (i
+ 1);
939 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
943 static void isp116x_hub_descriptor(struct isp116x
*isp116x
,
944 struct usb_hub_descriptor
*desc
)
946 u32 reg
= isp116x
->rhdesca
;
948 desc
->bDescriptorType
= USB_DT_HUB
;
949 desc
->bDescLength
= 9;
950 desc
->bHubContrCurrent
= 0;
951 desc
->bNbrPorts
= (u8
) (reg
& 0x3);
952 /* Power switching, device type, overcurrent. */
953 desc
->wHubCharacteristics
= cpu_to_le16((u16
) ((reg
>> 8) &
957 desc
->bPwrOn2PwrGood
= (u8
) ((reg
>> 24) & 0xff);
958 /* ports removable, and legacy PortPwrCtrlMask */
959 desc
->u
.hs
.DeviceRemovable
[0] = 0;
960 desc
->u
.hs
.DeviceRemovable
[1] = ~0;
963 /* Perform reset of a given port.
964 It would be great to just start the reset and let the
965 USB core to clear the reset in due time. However,
966 root hub ports should be reset for at least 50 ms, while
967 our chip stays in reset for about 10 ms. I.e., we must
968 repeatedly reset it ourself here.
970 static inline void root_port_reset(struct isp116x
*isp116x
, unsigned port
)
973 unsigned long flags
, t
;
975 /* Root hub reset should be 50 ms, but some devices
976 want it even longer. */
977 t
= jiffies
+ msecs_to_jiffies(100);
979 while (time_before(jiffies
, t
)) {
980 spin_lock_irqsave(&isp116x
->lock
, flags
);
981 /* spin until any current reset finishes */
983 tmp
= isp116x_read_reg32(isp116x
, port
?
984 HCRHPORT2
: HCRHPORT1
);
985 if (!(tmp
& RH_PS_PRS
))
989 /* Don't reset a disconnected port */
990 if (!(tmp
& RH_PS_CCS
)) {
991 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
994 /* Reset lasts 10ms (claims datasheet) */
995 isp116x_write_reg32(isp116x
, port
? HCRHPORT2
:
996 HCRHPORT1
, (RH_PS_PRS
));
997 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1002 /* Adapted from ohci-hub.c */
1003 static int isp116x_hub_control(struct usb_hcd
*hcd
,
1005 u16 wValue
, u16 wIndex
, char *buf
, u16 wLength
)
1007 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1009 unsigned long flags
;
1010 int ports
= isp116x
->rhdesca
& RH_A_NDP
;
1014 case ClearHubFeature
:
1015 DBG("ClearHubFeature: ");
1017 case C_HUB_OVER_CURRENT
:
1018 DBG("C_HUB_OVER_CURRENT\n");
1019 spin_lock_irqsave(&isp116x
->lock
, flags
);
1020 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_OCIC
);
1021 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1023 case C_HUB_LOCAL_POWER
:
1024 DBG("C_HUB_LOCAL_POWER\n");
1031 DBG("SetHubFeature: ");
1033 case C_HUB_OVER_CURRENT
:
1034 case C_HUB_LOCAL_POWER
:
1035 DBG("C_HUB_OVER_CURRENT or C_HUB_LOCAL_POWER\n");
1041 case GetHubDescriptor
:
1042 DBG("GetHubDescriptor\n");
1043 isp116x_hub_descriptor(isp116x
,
1044 (struct usb_hub_descriptor
*)buf
);
1047 DBG("GetHubStatus\n");
1048 *(__le32
*) buf
= 0;
1051 DBG("GetPortStatus\n");
1052 if (!wIndex
|| wIndex
> ports
)
1054 spin_lock_irqsave(&isp116x
->lock
, flags
);
1055 tmp
= isp116x_read_reg32(isp116x
, (--wIndex
) ? HCRHPORT2
: HCRHPORT1
);
1056 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1057 *(__le32
*) buf
= cpu_to_le32(tmp
);
1058 DBG("GetPortStatus: port[%d] %08x\n", wIndex
+ 1, tmp
);
1060 case ClearPortFeature
:
1061 DBG("ClearPortFeature: ");
1062 if (!wIndex
|| wIndex
> ports
)
1067 case USB_PORT_FEAT_ENABLE
:
1068 DBG("USB_PORT_FEAT_ENABLE\n");
1071 case USB_PORT_FEAT_C_ENABLE
:
1072 DBG("USB_PORT_FEAT_C_ENABLE\n");
1075 case USB_PORT_FEAT_SUSPEND
:
1076 DBG("USB_PORT_FEAT_SUSPEND\n");
1079 case USB_PORT_FEAT_C_SUSPEND
:
1080 DBG("USB_PORT_FEAT_C_SUSPEND\n");
1083 case USB_PORT_FEAT_POWER
:
1084 DBG("USB_PORT_FEAT_POWER\n");
1087 case USB_PORT_FEAT_C_CONNECTION
:
1088 DBG("USB_PORT_FEAT_C_CONNECTION\n");
1091 case USB_PORT_FEAT_C_OVER_CURRENT
:
1092 DBG("USB_PORT_FEAT_C_OVER_CURRENT\n");
1095 case USB_PORT_FEAT_C_RESET
:
1096 DBG("USB_PORT_FEAT_C_RESET\n");
1102 spin_lock_irqsave(&isp116x
->lock
, flags
);
1103 isp116x_write_reg32(isp116x
, wIndex
1104 ? HCRHPORT2
: HCRHPORT1
, tmp
);
1105 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1107 case SetPortFeature
:
1108 DBG("SetPortFeature: ");
1109 if (!wIndex
|| wIndex
> ports
)
1113 case USB_PORT_FEAT_SUSPEND
:
1114 DBG("USB_PORT_FEAT_SUSPEND\n");
1115 spin_lock_irqsave(&isp116x
->lock
, flags
);
1116 isp116x_write_reg32(isp116x
, wIndex
1117 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PSS
);
1118 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1120 case USB_PORT_FEAT_POWER
:
1121 DBG("USB_PORT_FEAT_POWER\n");
1122 spin_lock_irqsave(&isp116x
->lock
, flags
);
1123 isp116x_write_reg32(isp116x
, wIndex
1124 ? HCRHPORT2
: HCRHPORT1
, RH_PS_PPS
);
1125 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1127 case USB_PORT_FEAT_RESET
:
1128 DBG("USB_PORT_FEAT_RESET\n");
1129 root_port_reset(isp116x
, wIndex
);
1138 /* "protocol stall" on error */
1139 DBG("PROTOCOL STALL\n");
1145 /*-----------------------------------------------------------------*/
1147 #ifdef CONFIG_DEBUG_FS
1149 static void dump_irq(struct seq_file
*s
, char *label
, u16 mask
)
1151 seq_printf(s
, "%s %04x%s%s%s%s%s%s\n", label
, mask
,
1152 mask
& HCuPINT_CLKRDY
? " clkrdy" : "",
1153 mask
& HCuPINT_SUSP
? " susp" : "",
1154 mask
& HCuPINT_OPR
? " opr" : "",
1155 mask
& HCuPINT_AIIEOT
? " eot" : "",
1156 mask
& HCuPINT_ATL
? " atl" : "",
1157 mask
& HCuPINT_SOF
? " sof" : "");
1160 static void dump_int(struct seq_file
*s
, char *label
, u32 mask
)
1162 seq_printf(s
, "%s %08x%s%s%s%s%s%s%s\n", label
, mask
,
1163 mask
& HCINT_MIE
? " MIE" : "",
1164 mask
& HCINT_RHSC
? " rhsc" : "",
1165 mask
& HCINT_FNO
? " fno" : "",
1166 mask
& HCINT_UE
? " ue" : "",
1167 mask
& HCINT_RD
? " rd" : "",
1168 mask
& HCINT_SF
? " sof" : "", mask
& HCINT_SO
? " so" : "");
1171 static int isp116x_show_dbg(struct seq_file
*s
, void *unused
)
1173 struct isp116x
*isp116x
= s
->private;
1175 seq_printf(s
, "%s\n%s version %s\n",
1176 isp116x_to_hcd(isp116x
)->product_desc
, hcd_name
,
1179 if (HC_IS_SUSPENDED(isp116x_to_hcd(isp116x
)->state
)) {
1180 seq_printf(s
, "HCD is suspended\n");
1183 if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x
)->state
)) {
1184 seq_printf(s
, "HCD not running\n");
1188 spin_lock_irq(&isp116x
->lock
);
1189 dump_irq(s
, "hc_irq_enable", isp116x_read_reg16(isp116x
, HCuPINTENB
));
1190 dump_irq(s
, "hc_irq_status", isp116x_read_reg16(isp116x
, HCuPINT
));
1191 dump_int(s
, "hc_int_enable", isp116x_read_reg32(isp116x
, HCINTENB
));
1192 dump_int(s
, "hc_int_status", isp116x_read_reg32(isp116x
, HCINTSTAT
));
1193 isp116x_show_regs_seq(isp116x
, s
);
1194 spin_unlock_irq(&isp116x
->lock
);
1195 seq_printf(s
, "\n");
1200 static int isp116x_open_seq(struct inode
*inode
, struct file
*file
)
1202 return single_open(file
, isp116x_show_dbg
, inode
->i_private
);
1205 static const struct file_operations isp116x_debug_fops
= {
1206 .open
= isp116x_open_seq
,
1208 .llseek
= seq_lseek
,
1209 .release
= single_release
,
1212 static int create_debug_file(struct isp116x
*isp116x
)
1214 isp116x
->dentry
= debugfs_create_file(hcd_name
,
1215 S_IRUGO
, NULL
, isp116x
,
1216 &isp116x_debug_fops
);
1217 if (!isp116x
->dentry
)
1222 static void remove_debug_file(struct isp116x
*isp116x
)
1224 debugfs_remove(isp116x
->dentry
);
1229 #define create_debug_file(d) 0
1230 #define remove_debug_file(d) do{}while(0)
1232 #endif /* CONFIG_DEBUG_FS */
1234 /*-----------------------------------------------------------------*/
1237 Software reset - can be called from any contect.
1239 static int isp116x_sw_reset(struct isp116x
*isp116x
)
1242 unsigned long flags
;
1245 spin_lock_irqsave(&isp116x
->lock
, flags
);
1246 isp116x_write_reg16(isp116x
, HCSWRES
, HCSWRES_MAGIC
);
1247 isp116x_write_reg32(isp116x
, HCCMDSTAT
, HCCMDSTAT_HCR
);
1249 /* It usually resets within 1 ms */
1251 if (!(isp116x_read_reg32(isp116x
, HCCMDSTAT
) & HCCMDSTAT_HCR
))
1255 ERR("Software reset timeout\n");
1258 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1262 static int isp116x_reset(struct usb_hcd
*hcd
)
1264 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1267 int ret
, timeout
= 15 /* ms */ ;
1269 ret
= isp116x_sw_reset(isp116x
);
1273 t
= jiffies
+ msecs_to_jiffies(timeout
);
1274 while (time_before_eq(jiffies
, t
)) {
1276 spin_lock_irq(&isp116x
->lock
);
1277 clkrdy
= isp116x_read_reg16(isp116x
, HCuPINT
) & HCuPINT_CLKRDY
;
1278 spin_unlock_irq(&isp116x
->lock
);
1283 ERR("Clock not ready after %dms\n", timeout
);
1284 /* After sw_reset the clock won't report to be ready, if
1285 H_WAKEUP pin is high. */
1286 ERR("Please make sure that the H_WAKEUP pin is pulled low!\n");
1292 static void isp116x_stop(struct usb_hcd
*hcd
)
1294 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1295 unsigned long flags
;
1298 spin_lock_irqsave(&isp116x
->lock
, flags
);
1299 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1301 /* Switch off ports' power, some devices don't come up
1302 after next 'insmod' without this */
1303 val
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1304 val
&= ~(RH_A_NPS
| RH_A_PSM
);
1305 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1306 isp116x_write_reg32(isp116x
, HCRHSTATUS
, RH_HS_LPS
);
1307 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1309 isp116x_sw_reset(isp116x
);
1313 Configure the chip. The chip must be successfully reset by now.
1315 static int isp116x_start(struct usb_hcd
*hcd
)
1317 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1318 struct isp116x_platform_data
*board
= isp116x
->board
;
1320 unsigned long flags
;
1322 spin_lock_irqsave(&isp116x
->lock
, flags
);
1324 /* clear interrupt status and disable all interrupt sources */
1325 isp116x_write_reg16(isp116x
, HCuPINT
, 0xff);
1326 isp116x_write_reg16(isp116x
, HCuPINTENB
, 0);
1328 val
= isp116x_read_reg16(isp116x
, HCCHIPID
);
1329 if ((val
& HCCHIPID_MASK
) != HCCHIPID_MAGIC
) {
1330 ERR("Invalid chip ID %04x\n", val
);
1331 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1335 /* To be removed in future */
1336 hcd
->uses_new_polling
= 1;
1338 isp116x_write_reg16(isp116x
, HCITLBUFLEN
, ISP116x_ITL_BUFSIZE
);
1339 isp116x_write_reg16(isp116x
, HCATLBUFLEN
, ISP116x_ATL_BUFSIZE
);
1342 val
= HCHWCFG_INT_ENABLE
| HCHWCFG_DBWIDTH(1);
1343 if (board
->sel15Kres
)
1344 val
|= HCHWCFG_15KRSEL
;
1345 /* Remote wakeup won't work without working clock */
1346 if (board
->remote_wakeup_enable
)
1347 val
|= HCHWCFG_CLKNOTSTOP
;
1348 if (board
->oc_enable
)
1349 val
|= HCHWCFG_ANALOG_OC
;
1350 if (board
->int_act_high
)
1351 val
|= HCHWCFG_INT_POL
;
1352 if (board
->int_edge_triggered
)
1353 val
|= HCHWCFG_INT_TRIGGER
;
1354 isp116x_write_reg16(isp116x
, HCHWCFG
, val
);
1356 /* ----- Root hub conf */
1357 val
= (25 << 24) & RH_A_POTPGT
;
1358 /* AN10003_1.pdf recommends RH_A_NPS (no power switching) to
1359 be always set. Yet, instead, we request individual port
1362 /* Report overcurrent per port */
1364 isp116x_write_reg32(isp116x
, HCRHDESCA
, val
);
1365 isp116x
->rhdesca
= isp116x_read_reg32(isp116x
, HCRHDESCA
);
1368 isp116x_write_reg32(isp116x
, HCRHDESCB
, val
);
1369 isp116x
->rhdescb
= isp116x_read_reg32(isp116x
, HCRHDESCB
);
1372 if (board
->remote_wakeup_enable
) {
1373 if (!device_can_wakeup(hcd
->self
.controller
))
1374 device_init_wakeup(hcd
->self
.controller
, 1);
1377 isp116x_write_reg32(isp116x
, HCRHSTATUS
, val
);
1378 isp116x
->rhstatus
= isp116x_read_reg32(isp116x
, HCRHSTATUS
);
1380 isp116x_write_reg32(isp116x
, HCFMINTVL
, 0x27782edf);
1382 hcd
->state
= HC_STATE_RUNNING
;
1384 /* Set up interrupts */
1385 isp116x
->intenb
= HCINT_MIE
| HCINT_RHSC
| HCINT_UE
;
1386 if (board
->remote_wakeup_enable
)
1387 isp116x
->intenb
|= HCINT_RD
;
1388 isp116x
->irqenb
= HCuPINT_ATL
| HCuPINT_OPR
; /* | HCuPINT_SUSP; */
1389 isp116x_write_reg32(isp116x
, HCINTENB
, isp116x
->intenb
);
1390 isp116x_write_reg16(isp116x
, HCuPINTENB
, isp116x
->irqenb
);
1392 /* Go operational */
1393 val
= HCCONTROL_USB_OPER
;
1394 if (board
->remote_wakeup_enable
)
1395 val
|= HCCONTROL_RWE
;
1396 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1398 /* Disable ports to avoid race in device enumeration */
1399 isp116x_write_reg32(isp116x
, HCRHPORT1
, RH_PS_CCS
);
1400 isp116x_write_reg32(isp116x
, HCRHPORT2
, RH_PS_CCS
);
1402 isp116x_show_regs_log(isp116x
);
1403 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1409 static int isp116x_bus_suspend(struct usb_hcd
*hcd
)
1411 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1412 unsigned long flags
;
1416 spin_lock_irqsave(&isp116x
->lock
, flags
);
1417 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1419 switch (val
& HCCONTROL_HCFS
) {
1420 case HCCONTROL_USB_OPER
:
1421 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1422 val
&= (~HCCONTROL_HCFS
& ~HCCONTROL_RWE
);
1423 val
|= HCCONTROL_USB_SUSPEND
;
1424 if (hcd
->self
.root_hub
->do_remote_wakeup
)
1425 val
|= HCCONTROL_RWE
;
1426 /* Wait for usb transfers to finish */
1428 spin_lock_irqsave(&isp116x
->lock
, flags
);
1429 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1430 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1431 /* Wait for devices to suspend */
1434 case HCCONTROL_USB_RESUME
:
1435 isp116x_write_reg32(isp116x
, HCCONTROL
,
1436 (val
& ~HCCONTROL_HCFS
) |
1437 HCCONTROL_USB_RESET
);
1439 case HCCONTROL_USB_RESET
:
1442 default: /* HCCONTROL_USB_SUSPEND */
1443 spin_unlock_irqrestore(&isp116x
->lock
, flags
);
1450 static int isp116x_bus_resume(struct usb_hcd
*hcd
)
1452 struct isp116x
*isp116x
= hcd_to_isp116x(hcd
);
1456 spin_lock_irq(&isp116x
->lock
);
1458 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1459 switch (val
& HCCONTROL_HCFS
) {
1460 case HCCONTROL_USB_SUSPEND
:
1461 val
&= ~HCCONTROL_HCFS
;
1462 val
|= HCCONTROL_USB_RESUME
;
1463 isp116x_write_reg32(isp116x
, HCCONTROL
, val
);
1464 case HCCONTROL_USB_RESUME
:
1466 case HCCONTROL_USB_OPER
:
1467 spin_unlock_irq(&isp116x
->lock
);
1470 /* HCCONTROL_USB_RESET: this may happen, when during
1471 suspension the HC lost power. Reinitialize completely */
1472 spin_unlock_irq(&isp116x
->lock
);
1473 DBG("Chip has been reset while suspended. Reinit from scratch.\n");
1476 isp116x_hub_control(hcd
, SetPortFeature
,
1477 USB_PORT_FEAT_POWER
, 1, NULL
, 0);
1478 if ((isp116x
->rhdesca
& RH_A_NDP
) == 2)
1479 isp116x_hub_control(hcd
, SetPortFeature
,
1480 USB_PORT_FEAT_POWER
, 2, NULL
, 0);
1484 val
= isp116x
->rhdesca
& RH_A_NDP
;
1487 isp116x_read_reg32(isp116x
, val
? HCRHPORT2
: HCRHPORT1
);
1488 /* force global, not selective, resume */
1489 if (!(stat
& RH_PS_PSS
))
1491 DBG("%s: Resuming port %d\n", __func__
, val
);
1492 isp116x_write_reg32(isp116x
, RH_PS_POCI
, val
1493 ? HCRHPORT2
: HCRHPORT1
);
1495 spin_unlock_irq(&isp116x
->lock
);
1497 hcd
->state
= HC_STATE_RESUMING
;
1498 msleep(USB_RESUME_TIMEOUT
);
1500 /* Go operational */
1501 spin_lock_irq(&isp116x
->lock
);
1502 val
= isp116x_read_reg32(isp116x
, HCCONTROL
);
1503 isp116x_write_reg32(isp116x
, HCCONTROL
,
1504 (val
& ~HCCONTROL_HCFS
) | HCCONTROL_USB_OPER
);
1505 spin_unlock_irq(&isp116x
->lock
);
1506 hcd
->state
= HC_STATE_RUNNING
;
1513 #define isp116x_bus_suspend NULL
1514 #define isp116x_bus_resume NULL
1518 static const struct hc_driver isp116x_hc_driver
= {
1519 .description
= hcd_name
,
1520 .product_desc
= "ISP116x Host Controller",
1521 .hcd_priv_size
= sizeof(struct isp116x
),
1526 .reset
= isp116x_reset
,
1527 .start
= isp116x_start
,
1528 .stop
= isp116x_stop
,
1530 .urb_enqueue
= isp116x_urb_enqueue
,
1531 .urb_dequeue
= isp116x_urb_dequeue
,
1532 .endpoint_disable
= isp116x_endpoint_disable
,
1534 .get_frame_number
= isp116x_get_frame
,
1536 .hub_status_data
= isp116x_hub_status_data
,
1537 .hub_control
= isp116x_hub_control
,
1538 .bus_suspend
= isp116x_bus_suspend
,
1539 .bus_resume
= isp116x_bus_resume
,
1542 /*----------------------------------------------------------------*/
1544 static int isp116x_remove(struct platform_device
*pdev
)
1546 struct usb_hcd
*hcd
= platform_get_drvdata(pdev
);
1547 struct isp116x
*isp116x
;
1548 struct resource
*res
;
1552 isp116x
= hcd_to_isp116x(hcd
);
1553 remove_debug_file(isp116x
);
1554 usb_remove_hcd(hcd
);
1556 iounmap(isp116x
->data_reg
);
1557 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1558 release_mem_region(res
->start
, 2);
1559 iounmap(isp116x
->addr_reg
);
1560 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1561 release_mem_region(res
->start
, 2);
1567 static int isp116x_probe(struct platform_device
*pdev
)
1569 struct usb_hcd
*hcd
;
1570 struct isp116x
*isp116x
;
1571 struct resource
*addr
, *data
, *ires
;
1572 void __iomem
*addr_reg
;
1573 void __iomem
*data_reg
;
1576 unsigned long irqflags
;
1581 if (pdev
->num_resources
< 3) {
1586 data
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1587 addr
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
1588 ires
= platform_get_resource(pdev
, IORESOURCE_IRQ
, 0);
1590 if (!addr
|| !data
|| !ires
) {
1596 irqflags
= ires
->flags
& IRQF_TRIGGER_MASK
;
1598 if (pdev
->dev
.dma_mask
) {
1599 DBG("DMA not supported\n");
1604 if (!request_mem_region(addr
->start
, 2, hcd_name
)) {
1608 addr_reg
= ioremap(addr
->start
, resource_size(addr
));
1609 if (addr_reg
== NULL
) {
1613 if (!request_mem_region(data
->start
, 2, hcd_name
)) {
1617 data_reg
= ioremap(data
->start
, resource_size(data
));
1618 if (data_reg
== NULL
) {
1623 /* allocate and initialize hcd */
1624 hcd
= usb_create_hcd(&isp116x_hc_driver
, &pdev
->dev
, dev_name(&pdev
->dev
));
1629 /* this rsrc_start is bogus */
1630 hcd
->rsrc_start
= addr
->start
;
1631 isp116x
= hcd_to_isp116x(hcd
);
1632 isp116x
->data_reg
= data_reg
;
1633 isp116x
->addr_reg
= addr_reg
;
1634 spin_lock_init(&isp116x
->lock
);
1635 INIT_LIST_HEAD(&isp116x
->async
);
1636 isp116x
->board
= dev_get_platdata(&pdev
->dev
);
1638 if (!isp116x
->board
) {
1639 ERR("Platform data structure not initialized\n");
1643 if (isp116x_check_platform_delay(isp116x
)) {
1644 ERR("USE_PLATFORM_DELAY defined, but delay function not "
1646 ERR("See comments in drivers/usb/host/isp116x-hcd.c\n");
1651 ret
= usb_add_hcd(hcd
, irq
, irqflags
);
1655 device_wakeup_enable(hcd
->self
.controller
);
1657 ret
= create_debug_file(isp116x
);
1659 ERR("Couldn't create debugfs entry\n");
1666 usb_remove_hcd(hcd
);
1672 release_mem_region(data
->start
, 2);
1676 release_mem_region(addr
->start
, 2);
1678 ERR("init error, %d\n", ret
);
1684 Suspend of platform device
1686 static int isp116x_suspend(struct platform_device
*dev
, pm_message_t state
)
1688 VDBG("%s: state %x\n", __func__
, state
.event
);
1693 Resume platform device
1695 static int isp116x_resume(struct platform_device
*dev
)
1697 VDBG("%s\n", __func__
);
1703 #define isp116x_suspend NULL
1704 #define isp116x_resume NULL
1708 /* work with hotplug and coldplug */
1709 MODULE_ALIAS("platform:isp116x-hcd");
1711 static struct platform_driver isp116x_driver
= {
1712 .probe
= isp116x_probe
,
1713 .remove
= isp116x_remove
,
1714 .suspend
= isp116x_suspend
,
1715 .resume
= isp116x_resume
,
1721 module_platform_driver(isp116x_driver
);