2  * ISP116x HCD (Host Controller Driver) for USB.
 
   4  * Derived from the SL811 HCD, rewritten for ISP116x.
 
   5  * Copyright (C) 2005 Olav Kongas <ok@artecdesign.ee>
 
   8  * Copyright (C) 2004 Psion Teklogix (for NetBook PRO)
 
   9  * Copyright (C) 2004 David Brownell
 
  11  * Periodic scheduling is based on Roman's OHCI code
 
  12  * Copyright (C) 1999 Roman Weissgaerber
 
  17  * The driver basically works. A number of people have used it with a range
 
  20  * The driver passes all usbtests 1-14.
 
  22  * Suspending/resuming of root hub via sysfs works. Remote wakeup works too.
 
  23  * And suspending/resuming of platform device works too. Suspend/resume
 
  24  * via HCD operations vector is not implemented.
 
  26  * Iso transfer support is not implemented. Adding this would include
 
  27  * implementing recovery from the failure to service the processed ITL
 
  28  * fifo ram in time, which will involve chip reset.
 
  31  + More testing of suspend/resume.
 
  35   ISP116x chips require certain delays between accesses to its
 
  36   registers. The following timing options exist.
 
  38   1. Configure your memory controller (the best)
 
  39   2. Implement platform-specific delay function possibly
 
  40   combined with configuring the memory controller; see
 
  41   include/linux/usb-isp116x.h for more info. Some broken
 
  42   memory controllers line LH7A400 SMC need this. Also,
 
  43   uncomment for that to work the following
 
  44   USE_PLATFORM_DELAY macro.
 
  45   3. Use ndelay (easiest, poorest). For that, uncomment
 
  46   the following USE_NDELAY macro.
 
  48 #define USE_PLATFORM_DELAY
 
  53 /* Transfer descriptors. See dump_ptd() for printout format  */
 
  55 /* enqueuing/finishing log of urbs */
 
  58 #include <linux/module.h>
 
  59 #include <linux/delay.h>
 
  60 #include <linux/debugfs.h>
 
  61 #include <linux/seq_file.h>
 
  62 #include <linux/errno.h>
 
  63 #include <linux/init.h>
 
  64 #include <linux/list.h>
 
  65 #include <linux/usb.h>
 
  66 #include <linux/usb_isp116x.h>
 
  67 #include <linux/platform_device.h>
 
  71 #include <asm/system.h>
 
  72 #include <asm/byteorder.h>
 
  74 #include "../core/hcd.h"
 
  77 #define DRIVER_VERSION  "03 Nov 2005"
 
  78 #define DRIVER_DESC     "ISP116x USB Host Controller Driver"
 
  80 MODULE_DESCRIPTION(DRIVER_DESC);
 
  81 MODULE_LICENSE("GPL");
 
  83 static const char hcd_name[] = "isp116x-hcd";
 
  85 /*-----------------------------------------------------------------*/
 
  88   Write len bytes to fifo, pad till 32-bit boundary
 
  90 static void write_ptddata_to_fifo(struct isp116x *isp116x, void *buf, int len)
 
  93         u16 *dp2 = (u16 *) buf;
 
  97         if ((unsigned long)dp2 & 1) {
 
  99                 for (; len > 1; len -= 2) {
 
 102                         isp116x_raw_write_data16(isp116x, w);
 
 105                         isp116x_write_data16(isp116x, (u16) * dp);
 
 108                 for (; len > 1; len -= 2)
 
 109                         isp116x_raw_write_data16(isp116x, *dp2++);
 
 111                         isp116x_write_data16(isp116x, 0xff & *((u8 *) dp2));
 
 113         if (quot == 1 || quot == 2)
 
 114                 isp116x_raw_write_data16(isp116x, 0);
 
 118   Read len bytes from fifo and then read till 32-bit boundary.
 
 120 static void read_ptddata_from_fifo(struct isp116x *isp116x, void *buf, int len)
 
 123         u16 *dp2 = (u16 *) buf;
 
 127         if ((unsigned long)dp2 & 1) {
 
 129                 for (; len > 1; len -= 2) {
 
 130                         w = isp116x_raw_read_data16(isp116x);
 
 132                         *dp++ = (w >> 8) & 0xff;
 
 135                         *dp = 0xff & isp116x_read_data16(isp116x);
 
 138                 for (; len > 1; len -= 2)
 
 139                         *dp2++ = isp116x_raw_read_data16(isp116x);
 
 141                         *(u8 *) dp2 = 0xff & isp116x_read_data16(isp116x);
 
 143         if (quot == 1 || quot == 2)
 
 144                 isp116x_raw_read_data16(isp116x);
 
 148   Write ptd's and data for scheduled transfers into
 
 149   the fifo ram. Fifo must be empty and ready.
 
 151 static void pack_fifo(struct isp116x *isp116x)
 
 153         struct isp116x_ep *ep;
 
 155         int buflen = isp116x->atl_last_dir == PTD_DIR_IN
 
 156             ? isp116x->atl_bufshrt : isp116x->atl_buflen;
 
 158         isp116x_write_reg16(isp116x, HCuPINT, HCuPINT_AIIEOT);
 
 159         isp116x_write_reg16(isp116x, HCXFERCTR, buflen);
 
 160         isp116x_write_addr(isp116x, HCATLPORT | ISP116x_WRITE_OFFSET);
 
 161         for (ep = isp116x->atl_active; ep; ep = ep->active) {
 
 164                 dump_ptd_out_data(ptd, ep->data);
 
 165                 isp116x_write_data16(isp116x, ptd->count);
 
 166                 isp116x_write_data16(isp116x, ptd->mps);
 
 167                 isp116x_write_data16(isp116x, ptd->len);
 
 168                 isp116x_write_data16(isp116x, ptd->faddr);
 
 169                 buflen -= sizeof(struct ptd);
 
 170                 /* Skip writing data for last IN PTD */
 
 171                 if (ep->active || (isp116x->atl_last_dir != PTD_DIR_IN)) {
 
 172                         write_ptddata_to_fifo(isp116x, ep->data, ep->length);
 
 173                         buflen -= ALIGN(ep->length, 4);
 
 180   Read the processed ptd's and data from fifo ram back to
 
 181   URBs' buffers. Fifo must be full and done
 
 183 static void unpack_fifo(struct isp116x *isp116x)
 
 185         struct isp116x_ep *ep;
 
 187         int buflen = isp116x->atl_last_dir == PTD_DIR_IN
 
 188             ? isp116x->atl_buflen : isp116x->atl_bufshrt;
 
 190         isp116x_write_reg16(isp116x, HCuPINT, HCuPINT_AIIEOT);
 
 191         isp116x_write_reg16(isp116x, HCXFERCTR, buflen);
 
 192         isp116x_write_addr(isp116x, HCATLPORT);
 
 193         for (ep = isp116x->atl_active; ep; ep = ep->active) {
 
 195                 ptd->count = isp116x_read_data16(isp116x);
 
 196                 ptd->mps = isp116x_read_data16(isp116x);
 
 197                 ptd->len = isp116x_read_data16(isp116x);
 
 198                 ptd->faddr = isp116x_read_data16(isp116x);
 
 199                 buflen -= sizeof(struct ptd);
 
 200                 /* Skip reading data for last Setup or Out PTD */
 
 201                 if (ep->active || (isp116x->atl_last_dir == PTD_DIR_IN)) {
 
 202                         read_ptddata_from_fifo(isp116x, ep->data, ep->length);
 
 203                         buflen -= ALIGN(ep->length, 4);
 
 206                 dump_ptd_in_data(ptd, ep->data);
 
 211 /*---------------------------------------------------------------*/
 
 216 static void preproc_atl_queue(struct isp116x *isp116x)
 
 218         struct isp116x_ep *ep;
 
 223         for (ep = isp116x->atl_active; ep; ep = ep->active) {
 
 224                 u16 toggle = 0, dir = PTD_DIR_SETUP;
 
 226                 BUG_ON(list_empty(&ep->hep->urb_list));
 
 227                 urb = container_of(ep->hep->urb_list.next,
 
 228                                    struct urb, urb_list);
 
 231                 spin_lock(&urb->lock);
 
 232                 ep->data = (unsigned char *)urb->transfer_buffer
 
 233                     + urb->actual_length;
 
 235                 switch (ep->nextpid) {
 
 237                         toggle = usb_gettoggle(urb->dev, ep->epnum, 0);
 
 241                         toggle = usb_gettoggle(urb->dev, ep->epnum, 1);
 
 245                         len = sizeof(struct usb_ctrlrequest);
 
 246                         ep->data = urb->setup_packet;
 
 251                         dir = (urb->transfer_buffer_length
 
 252                                && usb_pipein(urb->pipe))
 
 253                             ? PTD_DIR_OUT : PTD_DIR_IN;
 
 256                         ERR("%s %d: ep->nextpid %d\n", __func__, __LINE__,
 
 261                 ptd->count = PTD_CC_MSK | PTD_ACTIVE_MSK | PTD_TOGGLE(toggle);
 
 262                 ptd->mps = PTD_MPS(ep->maxpacket)
 
 263                     | PTD_SPD(urb->dev->speed == USB_SPEED_LOW)
 
 265                 ptd->len = PTD_LEN(len) | PTD_DIR(dir);
 
 266                 ptd->faddr = PTD_FA(usb_pipedevice(urb->pipe));
 
 267                 spin_unlock(&urb->lock);
 
 269                         ptd->mps |= PTD_LAST_MSK;
 
 270                         isp116x->atl_last_dir = dir;
 
 272                 isp116x->atl_bufshrt = sizeof(struct ptd) + isp116x->atl_buflen;
 
 273                 isp116x->atl_buflen = isp116x->atl_bufshrt + ALIGN(len, 4);
 
 278   Analyze transfer results, handle partial transfers and errors
 
 280 static void postproc_atl_queue(struct isp116x *isp116x)
 
 282         struct isp116x_ep *ep;
 
 284         struct usb_device *udev;
 
 289         for (ep = isp116x->atl_active; ep; ep = ep->active) {
 
 290                 BUG_ON(list_empty(&ep->hep->urb_list));
 
 292                     container_of(ep->hep->urb_list.next, struct urb, urb_list);
 
 295                 cc = PTD_GET_CC(ptd);
 
 297                 spin_lock(&urb->lock);
 
 299                 /* Data underrun is special. For allowed underrun
 
 300                    we clear the error and continue as normal. For
 
 301                    forbidden underrun we finish the DATA stage
 
 302                    immediately while for control transfer,
 
 303                    we do a STATUS stage. */
 
 304                 if (cc == TD_DATAUNDERRUN) {
 
 305                         if (!(urb->transfer_flags & URB_SHORT_NOT_OK)) {
 
 306                                 DBG("Allowed data underrun\n");
 
 311                                 if (usb_pipecontrol(urb->pipe))
 
 312                                         ep->nextpid = USB_PID_ACK;
 
 314                                         usb_settoggle(udev, ep->epnum,
 
 317                                                       PTD_GET_TOGGLE(ptd));
 
 318                                 urb->actual_length += PTD_GET_COUNT(ptd);
 
 319                                 urb->status = cc_to_error[TD_DATAUNDERRUN];
 
 320                                 spin_unlock(&urb->lock);
 
 324                 /* Keep underrun error through the STATUS stage */
 
 325                 if (urb->status == cc_to_error[TD_DATAUNDERRUN])
 
 326                         cc = TD_DATAUNDERRUN;
 
 328                 if (cc != TD_CC_NOERROR && cc != TD_NOTACCESSED
 
 329                     && (++ep->error_count >= 3 || cc == TD_CC_STALL
 
 330                         || cc == TD_DATAOVERRUN)) {
 
 331                         if (urb->status == -EINPROGRESS)
 
 332                                 urb->status = cc_to_error[cc];
 
 333                         if (ep->nextpid == USB_PID_ACK)
 
 335                         spin_unlock(&urb->lock);
 
 338                 /* According to usb spec, zero-length Int transfer signals
 
 339                    finishing of the urb. Hey, does this apply only
 
 341                 if (usb_pipeint(urb->pipe) && !PTD_GET_LEN(ptd)) {
 
 342                         if (urb->status == -EINPROGRESS)
 
 344                         spin_unlock(&urb->lock);
 
 348                 /* Relax after previously failed, but later succeeded
 
 349                    or correctly NAK'ed retransmission attempt */
 
 351                     && (cc == TD_CC_NOERROR || cc == TD_NOTACCESSED))
 
 354                 /* Take into account idiosyncracies of the isp116x chip
 
 355                    regarding toggle bit for failed transfers */
 
 356                 if (ep->nextpid == USB_PID_OUT)
 
 357                         usb_settoggle(udev, ep->epnum, 1, PTD_GET_TOGGLE(ptd)
 
 358                                       ^ (ep->error_count > 0));
 
 359                 else if (ep->nextpid == USB_PID_IN)
 
 360                         usb_settoggle(udev, ep->epnum, 0, PTD_GET_TOGGLE(ptd)
 
 361                                       ^ (ep->error_count > 0));
 
 363                 switch (ep->nextpid) {
 
 366                         urb->actual_length += PTD_GET_COUNT(ptd);
 
 367                         if (PTD_GET_ACTIVE(ptd)
 
 368                             || (cc != TD_CC_NOERROR && cc < 0x0E))
 
 370                         if (urb->transfer_buffer_length != urb->actual_length) {
 
 374                                 if (urb->transfer_flags & URB_ZERO_PACKET
 
 375                                     && ep->nextpid == USB_PID_OUT
 
 376                                     && !(PTD_GET_COUNT(ptd) % ep->maxpacket)) {
 
 377                                         DBG("Zero packet requested\n");
 
 381                         /* All data for this URB is transferred, let's finish */
 
 382                         if (usb_pipecontrol(urb->pipe))
 
 383                                 ep->nextpid = USB_PID_ACK;
 
 384                         else if (urb->status == -EINPROGRESS)
 
 388                         if (PTD_GET_ACTIVE(ptd)
 
 389                             || (cc != TD_CC_NOERROR && cc < 0x0E))
 
 391                         if (urb->transfer_buffer_length == urb->actual_length)
 
 392                                 ep->nextpid = USB_PID_ACK;
 
 393                         else if (usb_pipeout(urb->pipe)) {
 
 394                                 usb_settoggle(udev, 0, 1, 1);
 
 395                                 ep->nextpid = USB_PID_OUT;
 
 397                                 usb_settoggle(udev, 0, 0, 1);
 
 398                                 ep->nextpid = USB_PID_IN;
 
 402                         if (PTD_GET_ACTIVE(ptd)
 
 403                             || (cc != TD_CC_NOERROR && cc < 0x0E))
 
 405                         if (urb->status == -EINPROGRESS)
 
 412                 spin_unlock(&urb->lock);
 
 417   Take done or failed requests out of schedule. Give back
 
 420 static void finish_request(struct isp116x *isp116x, struct isp116x_ep *ep,
 
 421                            struct urb *urb, struct pt_regs *regs)
 
 422 __releases(isp116x->lock) __acquires(isp116x->lock)
 
 429         if (usb_pipecontrol(urb->pipe))
 
 430                 ep->nextpid = USB_PID_SETUP;
 
 432         urb_dbg(urb, "Finish");
 
 434         spin_unlock(&isp116x->lock);
 
 435         usb_hcd_giveback_urb(isp116x_to_hcd(isp116x), urb, regs);
 
 436         spin_lock(&isp116x->lock);
 
 438         /* take idle endpoints out of the schedule */
 
 439         if (!list_empty(&ep->hep->urb_list))
 
 442         /* async deschedule */
 
 443         if (!list_empty(&ep->schedule)) {
 
 444                 list_del_init(&ep->schedule);
 
 448         /* periodic deschedule */
 
 449         DBG("deschedule qh%d/%p branch %d\n", ep->period, ep, ep->branch);
 
 450         for (i = ep->branch; i < PERIODIC_SIZE; i += ep->period) {
 
 451                 struct isp116x_ep *temp;
 
 452                 struct isp116x_ep **prev = &isp116x->periodic[i];
 
 454                 while (*prev && ((temp = *prev) != ep))
 
 458                 isp116x->load[i] -= ep->load;
 
 460         ep->branch = PERIODIC_SIZE;
 
 461         isp116x_to_hcd(isp116x)->self.bandwidth_allocated -=
 
 462             ep->load / ep->period;
 
 464         /* switch irq type? */
 
 465         if (!--isp116x->periodic_count) {
 
 466                 isp116x->irqenb &= ~HCuPINT_SOF;
 
 467                 isp116x->irqenb |= HCuPINT_ATL;
 
 472   Scan transfer lists, schedule transfers, send data off
 
 475 static void start_atl_transfers(struct isp116x *isp116x)
 
 477         struct isp116x_ep *last_ep = NULL, *ep;
 
 480         int len, index, speed, byte_time;
 
 482         if (atomic_read(&isp116x->atl_finishing))
 
 485         if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x)->state))
 
 488         /* FIFO not empty? */
 
 489         if (isp116x_read_reg16(isp116x, HCBUFSTAT) & HCBUFSTAT_ATL_FULL)
 
 492         isp116x->atl_active = NULL;
 
 493         isp116x->atl_buflen = isp116x->atl_bufshrt = 0;
 
 495         /* Schedule int transfers */
 
 496         if (isp116x->periodic_count) {
 
 497                 isp116x->fmindex = index =
 
 498                     (isp116x->fmindex + 1) & (PERIODIC_SIZE - 1);
 
 499                 if ((load = isp116x->load[index])) {
 
 500                         /* Bring all int transfers for this frame
 
 501                            into the active queue */
 
 502                         isp116x->atl_active = last_ep =
 
 503                             isp116x->periodic[index];
 
 504                         while (last_ep->next)
 
 505                                 last_ep = (last_ep->active = last_ep->next);
 
 506                         last_ep->active = NULL;
 
 510         /* Schedule control/bulk transfers */
 
 511         list_for_each_entry(ep, &isp116x->async, schedule) {
 
 512                 urb = container_of(ep->hep->urb_list.next,
 
 513                                    struct urb, urb_list);
 
 514                 speed = urb->dev->speed;
 
 515                 byte_time = speed == USB_SPEED_LOW
 
 516                     ? BYTE_TIME_LOWSPEED : BYTE_TIME_FULLSPEED;
 
 518                 if (ep->nextpid == USB_PID_SETUP) {
 
 519                         len = sizeof(struct usb_ctrlrequest);
 
 520                 } else if (ep->nextpid == USB_PID_ACK) {
 
 523                         /* Find current free length ... */
 
 524                         len = (MAX_LOAD_LIMIT - load) / byte_time;
 
 526                         /* ... then limit it to configured max size ... */
 
 527                         len = min(len, speed == USB_SPEED_LOW ?
 
 528                                   MAX_TRANSFER_SIZE_LOWSPEED :
 
 529                                   MAX_TRANSFER_SIZE_FULLSPEED);
 
 531                         /* ... and finally cut to the multiple of MaxPacketSize,
 
 532                            or to the real length if there's enough room. */
 
 534                             (urb->transfer_buffer_length -
 
 535                              urb->actual_length)) {
 
 536                                 len -= len % ep->maxpacket;
 
 540                                 len = urb->transfer_buffer_length -
 
 545                 load += len * byte_time;
 
 546                 if (load > MAX_LOAD_LIMIT)
 
 552                         last_ep->active = ep;
 
 554                         isp116x->atl_active = ep;
 
 558         /* Avoid starving of endpoints */
 
 559         if ((&isp116x->async)->next != (&isp116x->async)->prev)
 
 560                 list_move(&isp116x->async, (&isp116x->async)->next);
 
 562         if (isp116x->atl_active) {
 
 563                 preproc_atl_queue(isp116x);
 
 569   Finish the processed transfers
 
 571 static void finish_atl_transfers(struct isp116x *isp116x, struct pt_regs *regs)
 
 573         struct isp116x_ep *ep;
 
 576         if (!isp116x->atl_active)
 
 578         /* Fifo not ready? */
 
 579         if (!(isp116x_read_reg16(isp116x, HCBUFSTAT) & HCBUFSTAT_ATL_DONE))
 
 582         atomic_inc(&isp116x->atl_finishing);
 
 583         unpack_fifo(isp116x);
 
 584         postproc_atl_queue(isp116x);
 
 585         for (ep = isp116x->atl_active; ep; ep = ep->active) {
 
 587                     container_of(ep->hep->urb_list.next, struct urb, urb_list);
 
 588                 /* USB_PID_ACK check here avoids finishing of
 
 589                    control transfers, for which TD_DATAUNDERRUN
 
 590                    occured, while URB_SHORT_NOT_OK was set */
 
 591                 if (urb && urb->status != -EINPROGRESS
 
 592                     && ep->nextpid != USB_PID_ACK)
 
 593                         finish_request(isp116x, ep, urb, regs);
 
 595         atomic_dec(&isp116x->atl_finishing);
 
 598 static irqreturn_t isp116x_irq(struct usb_hcd *hcd, struct pt_regs *regs)
 
 600         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
 602         irqreturn_t ret = IRQ_NONE;
 
 604         spin_lock(&isp116x->lock);
 
 605         isp116x_write_reg16(isp116x, HCuPINTENB, 0);
 
 606         irqstat = isp116x_read_reg16(isp116x, HCuPINT);
 
 607         isp116x_write_reg16(isp116x, HCuPINT, irqstat);
 
 609         if (irqstat & (HCuPINT_ATL | HCuPINT_SOF)) {
 
 611                 finish_atl_transfers(isp116x, regs);
 
 614         if (irqstat & HCuPINT_OPR) {
 
 615                 u32 intstat = isp116x_read_reg32(isp116x, HCINTSTAT);
 
 616                 isp116x_write_reg32(isp116x, HCINTSTAT, intstat);
 
 617                 if (intstat & HCINT_UE) {
 
 618                         ERR("Unrecoverable error, HC is dead!\n");
 
 619                         /* IRQ's are off, we do no DMA,
 
 620                            perfectly ready to die ... */
 
 621                         hcd->state = HC_STATE_HALT;
 
 625                 if (intstat & HCINT_RHSC)
 
 626                         /* When root hub or any of its ports is going
 
 627                            to come out of suspend, it may take more
 
 628                            than 10ms for status bits to stabilize. */
 
 629                         mod_timer(&hcd->rh_timer, jiffies
 
 630                                   + msecs_to_jiffies(20) + 1);
 
 631                 if (intstat & HCINT_RD) {
 
 632                         DBG("---- remote wakeup\n");
 
 633                         usb_hcd_resume_root_hub(hcd);
 
 635                 irqstat &= ~HCuPINT_OPR;
 
 639         if (irqstat & (HCuPINT_ATL | HCuPINT_SOF)) {
 
 640                 start_atl_transfers(isp116x);
 
 643         isp116x_write_reg16(isp116x, HCuPINTENB, isp116x->irqenb);
 
 645         spin_unlock(&isp116x->lock);
 
 649 /*-----------------------------------------------------------------*/
 
 651 /* usb 1.1 says max 90% of a frame is available for periodic transfers.
 
 652  * this driver doesn't promise that much since it's got to handle an
 
 653  * IRQ per packet; irq handling latencies also use up that time.
 
 657 #define MAX_PERIODIC_LOAD       600
 
 658 static int balance(struct isp116x *isp116x, u16 period, u16 load)
 
 660         int i, branch = -ENOSPC;
 
 662         /* search for the least loaded schedule branch of that period
 
 663            which has enough bandwidth left unreserved. */
 
 664         for (i = 0; i < period; i++) {
 
 665                 if (branch < 0 || isp116x->load[branch] > isp116x->load[i]) {
 
 668                         for (j = i; j < PERIODIC_SIZE; j += period) {
 
 669                                 if ((isp116x->load[j] + load)
 
 673                         if (j < PERIODIC_SIZE)
 
 681 /* NB! ALL the code above this point runs with isp116x->lock
 
 685 /*-----------------------------------------------------------------*/
 
 687 static int isp116x_urb_enqueue(struct usb_hcd *hcd,
 
 688                                struct usb_host_endpoint *hep, struct urb *urb,
 
 691         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
 692         struct usb_device *udev = urb->dev;
 
 693         unsigned int pipe = urb->pipe;
 
 694         int is_out = !usb_pipein(pipe);
 
 695         int type = usb_pipetype(pipe);
 
 696         int epnum = usb_pipeendpoint(pipe);
 
 697         struct isp116x_ep *ep = NULL;
 
 702         urb_dbg(urb, "Enqueue");
 
 704         if (type == PIPE_ISOCHRONOUS) {
 
 705                 ERR("Isochronous transfers not supported\n");
 
 706                 urb_dbg(urb, "Refused to enqueue");
 
 709         /* avoid all allocations within spinlocks: request or endpoint */
 
 711                 ep = kzalloc(sizeof *ep, mem_flags);
 
 716         spin_lock_irqsave(&isp116x->lock, flags);
 
 717         if (!HC_IS_RUNNING(hcd->state)) {
 
 726                 INIT_LIST_HEAD(&ep->schedule);
 
 727                 ep->udev = usb_get_dev(udev);
 
 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((int)ep->maxpacket,
 
 778                                  urb->transfer_buffer_length);
 
 780                 /* urb submitted for already existing endpoint */
 
 781                 if (ep->branch < PERIODIC_SIZE)
 
 784                 ret = ep->branch = 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,
 
 823         /* in case of unlink-during-submit */
 
 824         spin_lock(&urb->lock);
 
 825         if (urb->status != -EINPROGRESS) {
 
 826                 spin_unlock(&urb->lock);
 
 827                 finish_request(isp116x, ep, urb, NULL);
 
 832         spin_unlock(&urb->lock);
 
 833         start_atl_transfers(isp116x);
 
 836         spin_unlock_irqrestore(&isp116x->lock, flags);
 
 843 static int isp116x_urb_dequeue(struct usb_hcd *hcd, struct urb *urb)
 
 845         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
 846         struct usb_host_endpoint *hep;
 
 847         struct isp116x_ep *ep, *ep_act;
 
 850         spin_lock_irqsave(&isp116x->lock, flags);
 
 852         /* URB already unlinked (or never linked)? */
 
 854                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
 858         WARN_ON(hep != ep->hep);
 
 860         /* In front of queue? */
 
 861         if (ep->hep->urb_list.next == &urb->urb_list)
 
 863                 for (ep_act = isp116x->atl_active; ep_act;
 
 864                      ep_act = ep_act->active)
 
 866                                 VDBG("dequeue, urb %p active; wait for irq\n",
 
 873                 finish_request(isp116x, ep, urb, NULL);
 
 875         spin_unlock_irqrestore(&isp116x->lock, flags);
 
 879 static void isp116x_endpoint_disable(struct usb_hcd *hcd,
 
 880                                      struct usb_host_endpoint *hep)
 
 883         struct isp116x_ep *ep = hep->hcpriv;
 
 888         /* assume we'd just wait for the irq */
 
 889         for (i = 0; i < 100 && !list_empty(&hep->urb_list); i++)
 
 891         if (!list_empty(&hep->urb_list))
 
 892                 WARN("ep %p not empty?\n", ep);
 
 894         usb_put_dev(ep->udev);
 
 899 static int isp116x_get_frame(struct usb_hcd *hcd)
 
 901         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
 905         spin_lock_irqsave(&isp116x->lock, flags);
 
 906         fmnum = isp116x_read_reg32(isp116x, HCFMNUM);
 
 907         spin_unlock_irqrestore(&isp116x->lock, flags);
 
 912   Adapted from ohci-hub.c. Currently we don't support autosuspend.
 
 914 static int isp116x_hub_status_data(struct usb_hcd *hcd, char *buf)
 
 916         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
 917         int ports, i, changed = 0;
 
 920         if (!HC_IS_RUNNING(hcd->state))
 
 923         /* Report no status change now, if we are scheduled to be
 
 925         if (timer_pending(&hcd->rh_timer))
 
 928         ports = isp116x->rhdesca & RH_A_NDP;
 
 929         spin_lock_irqsave(&isp116x->lock, flags);
 
 930         isp116x->rhstatus = isp116x_read_reg32(isp116x, HCRHSTATUS);
 
 931         if (isp116x->rhstatus & (RH_HS_LPSC | RH_HS_OCIC))
 
 932                 buf[0] = changed = 1;
 
 936         for (i = 0; i < ports; i++) {
 
 937                 u32 status = isp116x->rhport[i] =
 
 938                     isp116x_read_reg32(isp116x, i ? HCRHPORT2 : HCRHPORT1);
 
 940                 if (status & (RH_PS_CSC | RH_PS_PESC | RH_PS_PSSC
 
 941                               | RH_PS_OCIC | RH_PS_PRSC)) {
 
 943                         buf[0] |= 1 << (i + 1);
 
 947         spin_unlock_irqrestore(&isp116x->lock, flags);
 
 951 static void isp116x_hub_descriptor(struct isp116x *isp116x,
 
 952                                    struct usb_hub_descriptor *desc)
 
 954         u32 reg = isp116x->rhdesca;
 
 956         desc->bDescriptorType = 0x29;
 
 957         desc->bDescLength = 9;
 
 958         desc->bHubContrCurrent = 0;
 
 959         desc->bNbrPorts = (u8) (reg & 0x3);
 
 960         /* Power switching, device type, overcurrent. */
 
 961         desc->wHubCharacteristics = cpu_to_le16((u16) ((reg >> 8) & 0x1f));
 
 962         desc->bPwrOn2PwrGood = (u8) ((reg >> 24) & 0xff);
 
 963         /* two bitmaps:  ports removable, and legacy PortPwrCtrlMask */
 
 965         desc->bitmap[1] = ~0;
 
 968 /* Perform reset of a given port.
 
 969    It would be great to just start the reset and let the
 
 970    USB core to clear the reset in due time. However,
 
 971    root hub ports should be reset for at least 50 ms, while
 
 972    our chip stays in reset for about 10 ms. I.e., we must
 
 973    repeatedly reset it ourself here.
 
 975 static inline void root_port_reset(struct isp116x *isp116x, unsigned port)
 
 978         unsigned long flags, t;
 
 980         /* Root hub reset should be 50 ms, but some devices
 
 981            want it even longer. */
 
 982         t = jiffies + msecs_to_jiffies(100);
 
 984         while (time_before(jiffies, t)) {
 
 985                 spin_lock_irqsave(&isp116x->lock, flags);
 
 986                 /* spin until any current reset finishes */
 
 988                         tmp = isp116x_read_reg32(isp116x, port ?
 
 989                                                  HCRHPORT2 : HCRHPORT1);
 
 990                         if (!(tmp & RH_PS_PRS))
 
 994                 /* Don't reset a disconnected port */
 
 995                 if (!(tmp & RH_PS_CCS)) {
 
 996                         spin_unlock_irqrestore(&isp116x->lock, flags);
 
 999                 /* Reset lasts 10ms (claims datasheet) */
 
1000                 isp116x_write_reg32(isp116x, port ? HCRHPORT2 :
 
1001                                     HCRHPORT1, (RH_PS_PRS));
 
1002                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1007 /* Adapted from ohci-hub.c */
 
1008 static int isp116x_hub_control(struct usb_hcd *hcd,
 
1010                                u16 wValue, u16 wIndex, char *buf, u16 wLength)
 
1012         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1014         unsigned long flags;
 
1015         int ports = isp116x->rhdesca & RH_A_NDP;
 
1019         case ClearHubFeature:
 
1020                 DBG("ClearHubFeature: ");
 
1022                 case C_HUB_OVER_CURRENT:
 
1023                         DBG("C_HUB_OVER_CURRENT\n");
 
1024                         spin_lock_irqsave(&isp116x->lock, flags);
 
1025                         isp116x_write_reg32(isp116x, HCRHSTATUS, RH_HS_OCIC);
 
1026                         spin_unlock_irqrestore(&isp116x->lock, flags);
 
1027                 case C_HUB_LOCAL_POWER:
 
1028                         DBG("C_HUB_LOCAL_POWER\n");
 
1035                 DBG("SetHubFeature: ");
 
1037                 case C_HUB_OVER_CURRENT:
 
1038                 case C_HUB_LOCAL_POWER:
 
1039                         DBG("C_HUB_OVER_CURRENT or C_HUB_LOCAL_POWER\n");
 
1045         case GetHubDescriptor:
 
1046                 DBG("GetHubDescriptor\n");
 
1047                 isp116x_hub_descriptor(isp116x,
 
1048                                        (struct usb_hub_descriptor *)buf);
 
1051                 DBG("GetHubStatus\n");
 
1052                 *(__le32 *) buf = 0;
 
1055                 DBG("GetPortStatus\n");
 
1056                 if (!wIndex || wIndex > ports)
 
1058                 tmp = isp116x->rhport[--wIndex];
 
1059                 *(__le32 *) buf = cpu_to_le32(tmp);
 
1060                 DBG("GetPortStatus: port[%d]  %08x\n", wIndex + 1, tmp);
 
1062         case ClearPortFeature:
 
1063                 DBG("ClearPortFeature: ");
 
1064                 if (!wIndex || wIndex > ports)
 
1069                 case USB_PORT_FEAT_ENABLE:
 
1070                         DBG("USB_PORT_FEAT_ENABLE\n");
 
1073                 case USB_PORT_FEAT_C_ENABLE:
 
1074                         DBG("USB_PORT_FEAT_C_ENABLE\n");
 
1077                 case USB_PORT_FEAT_SUSPEND:
 
1078                         DBG("USB_PORT_FEAT_SUSPEND\n");
 
1081                 case USB_PORT_FEAT_C_SUSPEND:
 
1082                         DBG("USB_PORT_FEAT_C_SUSPEND\n");
 
1085                 case USB_PORT_FEAT_POWER:
 
1086                         DBG("USB_PORT_FEAT_POWER\n");
 
1089                 case USB_PORT_FEAT_C_CONNECTION:
 
1090                         DBG("USB_PORT_FEAT_C_CONNECTION\n");
 
1093                 case USB_PORT_FEAT_C_OVER_CURRENT:
 
1094                         DBG("USB_PORT_FEAT_C_OVER_CURRENT\n");
 
1097                 case USB_PORT_FEAT_C_RESET:
 
1098                         DBG("USB_PORT_FEAT_C_RESET\n");
 
1104                 spin_lock_irqsave(&isp116x->lock, flags);
 
1105                 isp116x_write_reg32(isp116x, wIndex
 
1106                                     ? HCRHPORT2 : HCRHPORT1, tmp);
 
1107                 isp116x->rhport[wIndex] =
 
1108                     isp116x_read_reg32(isp116x, wIndex ? HCRHPORT2 : HCRHPORT1);
 
1109                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1111         case SetPortFeature:
 
1112                 DBG("SetPortFeature: ");
 
1113                 if (!wIndex || wIndex > ports)
 
1117                 case USB_PORT_FEAT_SUSPEND:
 
1118                         DBG("USB_PORT_FEAT_SUSPEND\n");
 
1119                         spin_lock_irqsave(&isp116x->lock, flags);
 
1120                         isp116x_write_reg32(isp116x, wIndex
 
1121                                             ? HCRHPORT2 : HCRHPORT1, RH_PS_PSS);
 
1123                 case USB_PORT_FEAT_POWER:
 
1124                         DBG("USB_PORT_FEAT_POWER\n");
 
1125                         spin_lock_irqsave(&isp116x->lock, flags);
 
1126                         isp116x_write_reg32(isp116x, wIndex
 
1127                                             ? HCRHPORT2 : HCRHPORT1, RH_PS_PPS);
 
1129                 case USB_PORT_FEAT_RESET:
 
1130                         DBG("USB_PORT_FEAT_RESET\n");
 
1131                         root_port_reset(isp116x, wIndex);
 
1132                         spin_lock_irqsave(&isp116x->lock, flags);
 
1137                 isp116x->rhport[wIndex] =
 
1138                     isp116x_read_reg32(isp116x, wIndex ? HCRHPORT2 : HCRHPORT1);
 
1139                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1144                 /* "protocol stall" on error */
 
1145                 DBG("PROTOCOL STALL\n");
 
1151 /*-----------------------------------------------------------------*/
 
1153 #ifdef CONFIG_DEBUG_FS
 
1155 static void dump_irq(struct seq_file *s, char *label, u16 mask)
 
1157         seq_printf(s, "%s %04x%s%s%s%s%s%s\n", label, mask,
 
1158                    mask & HCuPINT_CLKRDY ? " clkrdy" : "",
 
1159                    mask & HCuPINT_SUSP ? " susp" : "",
 
1160                    mask & HCuPINT_OPR ? " opr" : "",
 
1161                    mask & HCuPINT_AIIEOT ? " eot" : "",
 
1162                    mask & HCuPINT_ATL ? " atl" : "",
 
1163                    mask & HCuPINT_SOF ? " sof" : "");
 
1166 static void dump_int(struct seq_file *s, char *label, u32 mask)
 
1168         seq_printf(s, "%s %08x%s%s%s%s%s%s%s\n", label, mask,
 
1169                    mask & HCINT_MIE ? " MIE" : "",
 
1170                    mask & HCINT_RHSC ? " rhsc" : "",
 
1171                    mask & HCINT_FNO ? " fno" : "",
 
1172                    mask & HCINT_UE ? " ue" : "",
 
1173                    mask & HCINT_RD ? " rd" : "",
 
1174                    mask & HCINT_SF ? " sof" : "", mask & HCINT_SO ? " so" : "");
 
1177 static int isp116x_show_dbg(struct seq_file *s, void *unused)
 
1179         struct isp116x *isp116x = s->private;
 
1181         seq_printf(s, "%s\n%s version %s\n",
 
1182                    isp116x_to_hcd(isp116x)->product_desc, hcd_name,
 
1185         if (HC_IS_SUSPENDED(isp116x_to_hcd(isp116x)->state)) {
 
1186                 seq_printf(s, "HCD is suspended\n");
 
1189         if (!HC_IS_RUNNING(isp116x_to_hcd(isp116x)->state)) {
 
1190                 seq_printf(s, "HCD not running\n");
 
1194         spin_lock_irq(&isp116x->lock);
 
1195         dump_irq(s, "hc_irq_enable", isp116x_read_reg16(isp116x, HCuPINTENB));
 
1196         dump_irq(s, "hc_irq_status", isp116x_read_reg16(isp116x, HCuPINT));
 
1197         dump_int(s, "hc_int_enable", isp116x_read_reg32(isp116x, HCINTENB));
 
1198         dump_int(s, "hc_int_status", isp116x_read_reg32(isp116x, HCINTSTAT));
 
1199         isp116x_show_regs_seq(isp116x, s);
 
1200         spin_unlock_irq(&isp116x->lock);
 
1201         seq_printf(s, "\n");
 
1206 static int isp116x_open_seq(struct inode *inode, struct file *file)
 
1208         return single_open(file, isp116x_show_dbg, inode->u.generic_ip);
 
1211 static struct file_operations isp116x_debug_fops = {
 
1212         .open = isp116x_open_seq,
 
1214         .llseek = seq_lseek,
 
1215         .release = single_release,
 
1218 static int create_debug_file(struct isp116x *isp116x)
 
1220         isp116x->dentry = debugfs_create_file(hcd_name,
 
1221                                               S_IRUGO, NULL, isp116x,
 
1222                                               &isp116x_debug_fops);
 
1223         if (!isp116x->dentry)
 
1228 static void remove_debug_file(struct isp116x *isp116x)
 
1230         debugfs_remove(isp116x->dentry);
 
1235 #define create_debug_file(d)    0
 
1236 #define remove_debug_file(d)    do{}while(0)
 
1238 #endif                          /* CONFIG_DEBUG_FS */
 
1240 /*-----------------------------------------------------------------*/
 
1243   Software reset - can be called from any contect.
 
1245 static int isp116x_sw_reset(struct isp116x *isp116x)
 
1248         unsigned long flags;
 
1251         spin_lock_irqsave(&isp116x->lock, flags);
 
1252         isp116x_write_reg16(isp116x, HCSWRES, HCSWRES_MAGIC);
 
1253         isp116x_write_reg32(isp116x, HCCMDSTAT, HCCMDSTAT_HCR);
 
1255                 /* It usually resets within 1 ms */
 
1257                 if (!(isp116x_read_reg32(isp116x, HCCMDSTAT) & HCCMDSTAT_HCR))
 
1261                 ERR("Software reset timeout\n");
 
1264         spin_unlock_irqrestore(&isp116x->lock, flags);
 
1268 static int isp116x_reset(struct usb_hcd *hcd)
 
1270         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1273         int ret, timeout = 15 /* ms */ ;
 
1275         ret = isp116x_sw_reset(isp116x);
 
1279         t = jiffies + msecs_to_jiffies(timeout);
 
1280         while (time_before_eq(jiffies, t)) {
 
1282                 spin_lock_irq(&isp116x->lock);
 
1283                 clkrdy = isp116x_read_reg16(isp116x, HCuPINT) & HCuPINT_CLKRDY;
 
1284                 spin_unlock_irq(&isp116x->lock);
 
1289                 ERR("Clock not ready after %dms\n", timeout);
 
1290                 /* After sw_reset the clock won't report to be ready, if
 
1291                    H_WAKEUP pin is high. */
 
1292                 ERR("Please make sure that the H_WAKEUP pin is pulled low!\n");
 
1298 static void isp116x_stop(struct usb_hcd *hcd)
 
1300         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1301         unsigned long flags;
 
1304         spin_lock_irqsave(&isp116x->lock, flags);
 
1305         isp116x_write_reg16(isp116x, HCuPINTENB, 0);
 
1307         /* Switch off ports' power, some devices don't come up
 
1308            after next 'insmod' without this */
 
1309         val = isp116x_read_reg32(isp116x, HCRHDESCA);
 
1310         val &= ~(RH_A_NPS | RH_A_PSM);
 
1311         isp116x_write_reg32(isp116x, HCRHDESCA, val);
 
1312         isp116x_write_reg32(isp116x, HCRHSTATUS, RH_HS_LPS);
 
1313         spin_unlock_irqrestore(&isp116x->lock, flags);
 
1315         isp116x_sw_reset(isp116x);
 
1319   Configure the chip. The chip must be successfully reset by now.
 
1321 static int isp116x_start(struct usb_hcd *hcd)
 
1323         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1324         struct isp116x_platform_data *board = isp116x->board;
 
1326         unsigned long flags;
 
1328         spin_lock_irqsave(&isp116x->lock, flags);
 
1330         /* clear interrupt status and disable all interrupt sources */
 
1331         isp116x_write_reg16(isp116x, HCuPINT, 0xff);
 
1332         isp116x_write_reg16(isp116x, HCuPINTENB, 0);
 
1334         val = isp116x_read_reg16(isp116x, HCCHIPID);
 
1335         if ((val & HCCHIPID_MASK) != HCCHIPID_MAGIC) {
 
1336                 ERR("Invalid chip ID %04x\n", val);
 
1337                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1341         /* To be removed in future */
 
1342         hcd->uses_new_polling = 1;
 
1344         isp116x_write_reg16(isp116x, HCITLBUFLEN, ISP116x_ITL_BUFSIZE);
 
1345         isp116x_write_reg16(isp116x, HCATLBUFLEN, ISP116x_ATL_BUFSIZE);
 
1348         val = HCHWCFG_INT_ENABLE | HCHWCFG_DBWIDTH(1);
 
1349         if (board->sel15Kres)
 
1350                 val |= HCHWCFG_15KRSEL;
 
1351         /* Remote wakeup won't work without working clock */
 
1352         if (board->remote_wakeup_enable)
 
1353                 val |= HCHWCFG_CLKNOTSTOP;
 
1354         if (board->oc_enable)
 
1355                 val |= HCHWCFG_ANALOG_OC;
 
1356         if (board->int_act_high)
 
1357                 val |= HCHWCFG_INT_POL;
 
1358         if (board->int_edge_triggered)
 
1359                 val |= HCHWCFG_INT_TRIGGER;
 
1360         isp116x_write_reg16(isp116x, HCHWCFG, val);
 
1362         /* ----- Root hub conf */
 
1363         val = (25 << 24) & RH_A_POTPGT;
 
1364         /* AN10003_1.pdf recommends RH_A_NPS (no power switching) to
 
1365            be always set. Yet, instead, we request individual port
 
1368         /* Report overcurrent per port */
 
1370         isp116x_write_reg32(isp116x, HCRHDESCA, val);
 
1371         isp116x->rhdesca = isp116x_read_reg32(isp116x, HCRHDESCA);
 
1374         isp116x_write_reg32(isp116x, HCRHDESCB, val);
 
1375         isp116x->rhdescb = isp116x_read_reg32(isp116x, HCRHDESCB);
 
1378         if (board->remote_wakeup_enable) {
 
1379                 if (!device_can_wakeup(hcd->self.controller))
 
1380                         device_init_wakeup(hcd->self.controller, 1);
 
1383         isp116x_write_reg32(isp116x, HCRHSTATUS, val);
 
1384         isp116x->rhstatus = isp116x_read_reg32(isp116x, HCRHSTATUS);
 
1386         isp116x_write_reg32(isp116x, HCFMINTVL, 0x27782edf);
 
1388         hcd->state = HC_STATE_RUNNING;
 
1390         /* Set up interrupts */
 
1391         isp116x->intenb = HCINT_MIE | HCINT_RHSC | HCINT_UE;
 
1392         if (board->remote_wakeup_enable)
 
1393                 isp116x->intenb |= HCINT_RD;
 
1394         isp116x->irqenb = HCuPINT_ATL | HCuPINT_OPR;    /* | HCuPINT_SUSP; */
 
1395         isp116x_write_reg32(isp116x, HCINTENB, isp116x->intenb);
 
1396         isp116x_write_reg16(isp116x, HCuPINTENB, isp116x->irqenb);
 
1398         /* Go operational */
 
1399         val = HCCONTROL_USB_OPER;
 
1400         if (board->remote_wakeup_enable)
 
1401                 val |= HCCONTROL_RWE;
 
1402         isp116x_write_reg32(isp116x, HCCONTROL, val);
 
1404         /* Disable ports to avoid race in device enumeration */
 
1405         isp116x_write_reg32(isp116x, HCRHPORT1, RH_PS_CCS);
 
1406         isp116x_write_reg32(isp116x, HCRHPORT2, RH_PS_CCS);
 
1408         isp116x_show_regs_log(isp116x);
 
1409         spin_unlock_irqrestore(&isp116x->lock, flags);
 
1415 static int isp116x_bus_suspend(struct usb_hcd *hcd)
 
1417         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1418         unsigned long flags;
 
1422         spin_lock_irqsave(&isp116x->lock, flags);
 
1423         val = isp116x_read_reg32(isp116x, HCCONTROL);
 
1425         switch (val & HCCONTROL_HCFS) {
 
1426         case HCCONTROL_USB_OPER:
 
1427                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1428                 val &= (~HCCONTROL_HCFS & ~HCCONTROL_RWE);
 
1429                 val |= HCCONTROL_USB_SUSPEND;
 
1430                 if (device_may_wakeup(&hcd->self.root_hub->dev))
 
1431                         val |= HCCONTROL_RWE;
 
1432                 /* Wait for usb transfers to finish */
 
1434                 spin_lock_irqsave(&isp116x->lock, flags);
 
1435                 isp116x_write_reg32(isp116x, HCCONTROL, val);
 
1436                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1437                 /* Wait for devices to suspend */
 
1440         case HCCONTROL_USB_RESUME:
 
1441                 isp116x_write_reg32(isp116x, HCCONTROL,
 
1442                                     (val & ~HCCONTROL_HCFS) |
 
1443                                     HCCONTROL_USB_RESET);
 
1444         case HCCONTROL_USB_RESET:
 
1446         default:                /* HCCONTROL_USB_SUSPEND */
 
1447                 spin_unlock_irqrestore(&isp116x->lock, flags);
 
1454 static int isp116x_bus_resume(struct usb_hcd *hcd)
 
1456         struct isp116x *isp116x = hcd_to_isp116x(hcd);
 
1460         spin_lock_irq(&isp116x->lock);
 
1462         val = isp116x_read_reg32(isp116x, HCCONTROL);
 
1463         switch (val & HCCONTROL_HCFS) {
 
1464         case HCCONTROL_USB_SUSPEND:
 
1465                 val &= ~HCCONTROL_HCFS;
 
1466                 val |= HCCONTROL_USB_RESUME;
 
1467                 isp116x_write_reg32(isp116x, HCCONTROL, val);
 
1468         case HCCONTROL_USB_RESUME:
 
1470         case HCCONTROL_USB_OPER:
 
1471                 spin_unlock_irq(&isp116x->lock);
 
1472                 /* Without setting power_state here the
 
1473                    SUSPENDED state won't be removed from
 
1474                    sysfs/usbN/power.state as a response to remote
 
1475                    wakeup. Maybe in the future. */
 
1476                 hcd->self.root_hub->dev.power.power_state = PMSG_ON;
 
1479                 /* HCCONTROL_USB_RESET: this may happen, when during
 
1480                    suspension the HC lost power. Reinitialize completely */
 
1481                 spin_unlock_irq(&isp116x->lock);
 
1482                 DBG("Chip has been reset while suspended. Reinit from scratch.\n");
 
1485                 isp116x_hub_control(hcd, SetPortFeature,
 
1486                                     USB_PORT_FEAT_POWER, 1, NULL, 0);
 
1487                 if ((isp116x->rhdesca & RH_A_NDP) == 2)
 
1488                         isp116x_hub_control(hcd, SetPortFeature,
 
1489                                             USB_PORT_FEAT_POWER, 2, NULL, 0);
 
1490                 hcd->self.root_hub->dev.power.power_state = PMSG_ON;
 
1494         val = isp116x->rhdesca & RH_A_NDP;
 
1497                     isp116x_read_reg32(isp116x, val ? HCRHPORT2 : HCRHPORT1);
 
1498                 /* force global, not selective, resume */
 
1499                 if (!(stat & RH_PS_PSS))
 
1501                 DBG("%s: Resuming port %d\n", __func__, val);
 
1502                 isp116x_write_reg32(isp116x, RH_PS_POCI, val
 
1503                                     ? HCRHPORT2 : HCRHPORT1);
 
1505         spin_unlock_irq(&isp116x->lock);
 
1507         hcd->state = HC_STATE_RESUMING;
 
1510         /* Go operational */
 
1511         spin_lock_irq(&isp116x->lock);
 
1512         val = isp116x_read_reg32(isp116x, HCCONTROL);
 
1513         isp116x_write_reg32(isp116x, HCCONTROL,
 
1514                             (val & ~HCCONTROL_HCFS) | HCCONTROL_USB_OPER);
 
1515         spin_unlock_irq(&isp116x->lock);
 
1516         /* see analogous comment above */
 
1517         hcd->self.root_hub->dev.power.power_state = PMSG_ON;
 
1518         hcd->state = HC_STATE_RUNNING;
 
1525 #define isp116x_bus_suspend     NULL
 
1526 #define isp116x_bus_resume      NULL
 
1530 static struct hc_driver isp116x_hc_driver = {
 
1531         .description = hcd_name,
 
1532         .product_desc = "ISP116x Host Controller",
 
1533         .hcd_priv_size = sizeof(struct isp116x),
 
1538         .reset = isp116x_reset,
 
1539         .start = isp116x_start,
 
1540         .stop = isp116x_stop,
 
1542         .urb_enqueue = isp116x_urb_enqueue,
 
1543         .urb_dequeue = isp116x_urb_dequeue,
 
1544         .endpoint_disable = isp116x_endpoint_disable,
 
1546         .get_frame_number = isp116x_get_frame,
 
1548         .hub_status_data = isp116x_hub_status_data,
 
1549         .hub_control = isp116x_hub_control,
 
1550         .bus_suspend = isp116x_bus_suspend,
 
1551         .bus_resume = isp116x_bus_resume,
 
1554 /*----------------------------------------------------------------*/
 
1556 static int __init_or_module isp116x_remove(struct platform_device *pdev)
 
1558         struct usb_hcd *hcd = platform_get_drvdata(pdev);
 
1559         struct isp116x *isp116x;
 
1560         struct resource *res;
 
1564         isp116x = hcd_to_isp116x(hcd);
 
1565         remove_debug_file(isp116x);
 
1566         usb_remove_hcd(hcd);
 
1568         iounmap(isp116x->data_reg);
 
1569         res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
 
1570         release_mem_region(res->start, 2);
 
1571         iounmap(isp116x->addr_reg);
 
1572         res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
 
1573         release_mem_region(res->start, 2);
 
1579 #define resource_len(r) (((r)->end - (r)->start) + 1)
 
1581 static int __init isp116x_probe(struct platform_device *pdev)
 
1583         struct usb_hcd *hcd;
 
1584         struct isp116x *isp116x;
 
1585         struct resource *addr, *data;
 
1586         void __iomem *addr_reg;
 
1587         void __iomem *data_reg;
 
1591         if (pdev->num_resources < 3) {
 
1596         data = platform_get_resource(pdev, IORESOURCE_MEM, 0);
 
1597         addr = platform_get_resource(pdev, IORESOURCE_MEM, 1);
 
1598         irq = platform_get_irq(pdev, 0);
 
1599         if (!addr || !data || irq < 0) {
 
1604         if (pdev->dev.dma_mask) {
 
1605                 DBG("DMA not supported\n");
 
1610         if (!request_mem_region(addr->start, 2, hcd_name)) {
 
1614         addr_reg = ioremap(addr->start, resource_len(addr));
 
1615         if (addr_reg == NULL) {
 
1619         if (!request_mem_region(data->start, 2, hcd_name)) {
 
1623         data_reg = ioremap(data->start, resource_len(data));
 
1624         if (data_reg == NULL) {
 
1629         /* allocate and initialize hcd */
 
1630         hcd = usb_create_hcd(&isp116x_hc_driver, &pdev->dev, pdev->dev.bus_id);
 
1635         /* this rsrc_start is bogus */
 
1636         hcd->rsrc_start = addr->start;
 
1637         isp116x = hcd_to_isp116x(hcd);
 
1638         isp116x->data_reg = data_reg;
 
1639         isp116x->addr_reg = addr_reg;
 
1640         spin_lock_init(&isp116x->lock);
 
1641         INIT_LIST_HEAD(&isp116x->async);
 
1642         isp116x->board = pdev->dev.platform_data;
 
1644         if (!isp116x->board) {
 
1645                 ERR("Platform data structure not initialized\n");
 
1649         if (isp116x_check_platform_delay(isp116x)) {
 
1650                 ERR("USE_PLATFORM_DELAY defined, but delay function not "
 
1652                 ERR("See comments in drivers/usb/host/isp116x-hcd.c\n");
 
1657         ret = usb_add_hcd(hcd, irq, SA_INTERRUPT);
 
1661         ret = create_debug_file(isp116x);
 
1663                 ERR("Couldn't create debugfs entry\n");
 
1670         usb_remove_hcd(hcd);
 
1676         release_mem_region(data->start, 2);
 
1680         release_mem_region(addr->start, 2);
 
1682         ERR("init error, %d\n", ret);
 
1688   Suspend of platform device
 
1690 static int isp116x_suspend(struct platform_device *dev, pm_message_t state)
 
1692         VDBG("%s: state %x\n", __func__, state.event);
 
1693         dev->dev.power.power_state = state;
 
1698   Resume platform device
 
1700 static int isp116x_resume(struct platform_device *dev)
 
1702         VDBG("%s:  state %x\n", __func__, dev->power.power_state.event);
 
1703         dev->dev.power.power_state = PMSG_ON;
 
1709 #define isp116x_suspend    NULL
 
1710 #define isp116x_resume     NULL
 
1714 static struct platform_driver isp116x_driver = {
 
1715         .probe = isp116x_probe,
 
1716         .remove = isp116x_remove,
 
1717         .suspend = isp116x_suspend,
 
1718         .resume = isp116x_resume,
 
1720                    .name = (char *)hcd_name,
 
1724 /*-----------------------------------------------------------------*/
 
1726 static int __init isp116x_init(void)
 
1731         INFO("driver %s, %s\n", hcd_name, DRIVER_VERSION);
 
1732         return platform_driver_register(&isp116x_driver);
 
1735 module_init(isp116x_init);
 
1737 static void __exit isp116x_cleanup(void)
 
1739         platform_driver_unregister(&isp116x_driver);
 
1742 module_exit(isp116x_cleanup);