ohci-hcd.c 35.9 KB
Newer Older
L
Linus Torvalds 已提交
1
/*
2 3 4
 * Open Host Controller Interface (OHCI) driver for USB.
 *
 * Maintainer: Alan Stern <stern@rowland.harvard.edu>
L
Linus Torvalds 已提交
5 6 7
 *
 * (C) Copyright 1999 Roman Weissgaerber <weissg@vienna.at>
 * (C) Copyright 2000-2004 David Brownell <dbrownell@users.sourceforge.net>
8
 *
L
Linus Torvalds 已提交
9 10 11 12
 * [ Initialisation is based on Linus'  ]
 * [ uhci code and gregs ohci fragments ]
 * [ (C) Copyright 1999 Linus Torvalds  ]
 * [ (C) Copyright 1999 Gregory P. Smith]
13 14
 *
 *
L
Linus Torvalds 已提交
15 16 17 18 19 20 21
 * OHCI is the main "non-Intel/VIA" standard for USB 1.1 host controller
 * interfaces (though some non-x86 Intel chips use it).  It supports
 * smarter hardware than UHCI.  A download link for the spec available
 * through the http://www.usb.org website.
 *
 * This file is licenced under the GPL.
 */
22

L
Linus Torvalds 已提交
23 24 25 26 27 28 29 30 31 32 33 34 35
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/pci.h>
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/ioport.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/timer.h>
#include <linux/list.h>
#include <linux/usb.h>
36
#include <linux/usb/otg.h>
37
#include <linux/usb/hcd.h>
38
#include <linux/dma-mapping.h>
39
#include <linux/dmapool.h>
40
#include <linux/workqueue.h>
41
#include <linux/debugfs.h>
L
Linus Torvalds 已提交
42 43 44 45 46 47 48 49 50 51 52 53

#include <asm/io.h>
#include <asm/irq.h>
#include <asm/unaligned.h>
#include <asm/byteorder.h>


#define DRIVER_AUTHOR "Roman Weissgaerber, David Brownell"
#define DRIVER_DESC "USB 1.1 'Open' Host Controller (OHCI) Driver"

/*-------------------------------------------------------------------------*/

54
#undef OHCI_VERBOSE_DEBUG	/* not always helpful */
L
Linus Torvalds 已提交
55 56

/* For initializing controller (mask in an HCFS mode too) */
57
#define	OHCI_CONTROL_INIT	OHCI_CTRL_CBSR
L
Linus Torvalds 已提交
58
#define	OHCI_INTR_INIT \
59 60
		(OHCI_INTR_MIE | OHCI_INTR_RHSC | OHCI_INTR_UE \
		| OHCI_INTR_RD | OHCI_INTR_WDH)
L
Linus Torvalds 已提交
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75

#ifdef __hppa__
/* On PA-RISC, PDC can leave IR set incorrectly; ignore it there. */
#define	IR_DISABLE
#endif

#ifdef CONFIG_ARCH_OMAP
/* OMAP doesn't support IR (no SMM; not needed) */
#define	IR_DISABLE
#endif

/*-------------------------------------------------------------------------*/

static const char	hcd_name [] = "ohci_hcd";

76 77
#define	STATECHANGE_DELAY	msecs_to_jiffies(300)

L
Linus Torvalds 已提交
78
#include "ohci.h"
79
#include "pci-quirks.h"
L
Linus Torvalds 已提交
80 81 82

static void ohci_dump (struct ohci_hcd *ohci, int verbose);
static void ohci_stop (struct usb_hcd *hcd);
L
Libin Yang 已提交
83

L
Linus Torvalds 已提交
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
#include "ohci-hub.c"
#include "ohci-dbg.c"
#include "ohci-mem.c"
#include "ohci-q.c"


/*
 * On architectures with edge-triggered interrupts we must never return
 * IRQ_NONE.
 */
#if defined(CONFIG_SA1111)  /* ... or other edge-triggered systems */
#define IRQ_NOTMINE	IRQ_HANDLED
#else
#define IRQ_NOTMINE	IRQ_NONE
#endif


/* Some boards misreport power switching/overcurrent */
102
static bool distrust_firmware = 1;
L
Linus Torvalds 已提交
103 104 105 106 107
module_param (distrust_firmware, bool, 0);
MODULE_PARM_DESC (distrust_firmware,
	"true to distrust firmware power/overcurrent setup");

/* Some boards leave IR set wrongly, since they fail BIOS/SMM handshakes */
108
static bool no_handshake = 0;
L
Linus Torvalds 已提交
109 110 111 112 113 114 115 116 117 118 119
module_param (no_handshake, bool, 0);
MODULE_PARM_DESC (no_handshake, "true (not default) disables BIOS handshake");

/*-------------------------------------------------------------------------*/

/*
 * queue up an urb for anything except the root hub
 */
static int ohci_urb_enqueue (
	struct usb_hcd	*hcd,
	struct urb	*urb,
A
Al Viro 已提交
120
	gfp_t		mem_flags
L
Linus Torvalds 已提交
121 122 123 124 125 126 127 128
) {
	struct ohci_hcd	*ohci = hcd_to_ohci (hcd);
	struct ed	*ed;
	urb_priv_t	*urb_priv;
	unsigned int	pipe = urb->pipe;
	int		i, size = 0;
	unsigned long	flags;
	int		retval = 0;
129

L
Linus Torvalds 已提交
130
#ifdef OHCI_VERBOSE_DEBUG
131
	urb_print(urb, "SUB", usb_pipein(pipe), -EINPROGRESS);
L
Linus Torvalds 已提交
132
#endif
133

L
Linus Torvalds 已提交
134
	/* every endpoint has a ed, locate and maybe (re)initialize it */
135
	if (! (ed = ed_get (ohci, urb->ep, urb->dev, pipe, urb->interval)))
L
Linus Torvalds 已提交
136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
		return -ENOMEM;

	/* for the private part of the URB we need the number of TDs (size) */
	switch (ed->type) {
		case PIPE_CONTROL:
			/* td_submit_urb() doesn't yet handle these */
			if (urb->transfer_buffer_length > 4096)
				return -EMSGSIZE;

			/* 1 TD for setup, 1 for ACK, plus ... */
			size = 2;
			/* FALLTHROUGH */
		// case PIPE_INTERRUPT:
		// case PIPE_BULK:
		default:
L
Lucas De Marchi 已提交
151
			/* one TD for every 4096 Bytes (can be up to 8K) */
L
Linus Torvalds 已提交
152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
			size += urb->transfer_buffer_length / 4096;
			/* ... and for any remaining bytes ... */
			if ((urb->transfer_buffer_length % 4096) != 0)
				size++;
			/* ... and maybe a zero length packet to wrap it up */
			if (size == 0)
				size++;
			else if ((urb->transfer_flags & URB_ZERO_PACKET) != 0
				&& (urb->transfer_buffer_length
					% usb_maxpacket (urb->dev, pipe,
						usb_pipeout (pipe))) == 0)
				size++;
			break;
		case PIPE_ISOCHRONOUS: /* number of packets from URB */
			size = urb->number_of_packets;
			break;
	}

	/* allocate the private part of the URB */
171
	urb_priv = kzalloc (sizeof (urb_priv_t) + size * sizeof (struct td *),
L
Linus Torvalds 已提交
172 173 174 175 176
			mem_flags);
	if (!urb_priv)
		return -ENOMEM;
	INIT_LIST_HEAD (&urb_priv->pending);
	urb_priv->length = size;
177
	urb_priv->ed = ed;
L
Linus Torvalds 已提交
178 179 180 181 182 183 184 185 186

	/* allocate the TDs (deferring hash chain updates) */
	for (i = 0; i < size; i++) {
		urb_priv->td [i] = td_alloc (ohci, mem_flags);
		if (!urb_priv->td [i]) {
			urb_priv->length = i;
			urb_free_priv (ohci, urb_priv);
			return -ENOMEM;
		}
187
	}
L
Linus Torvalds 已提交
188 189 190 191

	spin_lock_irqsave (&ohci->lock, flags);

	/* don't submit to a dead HC */
192
	if (!HCD_HW_ACCESSIBLE(hcd)) {
193 194 195
		retval = -ENODEV;
		goto fail;
	}
A
Alan Stern 已提交
196
	if (ohci->rh_state != OHCI_RH_RUNNING) {
L
Linus Torvalds 已提交
197 198 199
		retval = -ENODEV;
		goto fail;
	}
200 201
	retval = usb_hcd_link_urb_to_ep(hcd, urb);
	if (retval)
L
Linus Torvalds 已提交
202 203 204 205 206
		goto fail;

	/* schedule the ed if needed */
	if (ed->state == ED_IDLE) {
		retval = ed_schedule (ohci, ed);
207 208 209 210
		if (retval < 0) {
			usb_hcd_unlink_urb_from_ep(hcd, urb);
			goto fail;
		}
L
Linus Torvalds 已提交
211 212 213 214 215 216 217 218
		if (ed->type == PIPE_ISOCHRONOUS) {
			u16	frame = ohci_frame_no(ohci);

			/* delay a few frames before the first TD */
			frame += max_t (u16, 8, ed->interval);
			frame &= ~(ed->interval - 1);
			frame |= ed->branch;
			urb->start_frame = frame;
219 220
		}
	} else if (ed->type == PIPE_ISOCHRONOUS) {
221
		u16	next = ohci_frame_no(ohci) + 1;
222 223 224 225 226 227
		u16	frame = ed->last_iso + ed->interval;

		/* Behind the scheduling threshold? */
		if (unlikely(tick_before(frame, next))) {

			/* USB_ISO_ASAP: Round up to the first available slot */
228
			if (urb->transfer_flags & URB_ISO_ASAP) {
229 230
				frame += (next - frame + ed->interval - 1) &
						-ed->interval;
L
Linus Torvalds 已提交
231

232 233 234
			/*
			 * Not ASAP: Use the next slot in the stream.  If
			 * the entire URB falls before the threshold, fail.
L
Linus Torvalds 已提交
235
			 */
236 237
			} else {
				if (tick_before(frame + ed->interval *
238
					(urb->number_of_packets - 1), next)) {
239 240 241 242 243 244 245 246 247 248 249 250 251 252 253
					retval = -EXDEV;
					usb_hcd_unlink_urb_from_ep(hcd, urb);
					goto fail;
				}

				/*
				 * Some OHCI hardware doesn't handle late TDs
				 * correctly.  After retiring them it proceeds
				 * to the next ED instead of the next TD.
				 * Therefore we have to omit the late TDs
				 * entirely.
				 */
				urb_priv->td_cnt = DIV_ROUND_UP(
						(u16) (next - frame),
						ed->interval);
254
			}
L
Linus Torvalds 已提交
255
		}
256 257
		urb->start_frame = frame;
	}
L
Linus Torvalds 已提交
258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273

	/* fill the TDs and link them to the ed; and
	 * enable that part of the schedule, if needed
	 * and update count of queued periodic urbs
	 */
	urb->hcpriv = urb_priv;
	td_submit_urb (ohci, urb);

fail:
	if (retval)
		urb_free_priv (ohci, urb_priv);
	spin_unlock_irqrestore (&ohci->lock, flags);
	return retval;
}

/*
274 275
 * decouple the URB from the HC queues (TDs, urb_priv).
 * reporting is always done
L
Linus Torvalds 已提交
276 277 278
 * asynchronously, and we might be dealing with an urb that's
 * partially transferred, or an ED with other urbs being unlinked.
 */
279
static int ohci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status)
L
Linus Torvalds 已提交
280 281 282
{
	struct ohci_hcd		*ohci = hcd_to_ohci (hcd);
	unsigned long		flags;
283
	int			rc;
284

L
Linus Torvalds 已提交
285
#ifdef OHCI_VERBOSE_DEBUG
286
	urb_print(urb, "UNLINK", 1, status);
287
#endif
L
Linus Torvalds 已提交
288 289

	spin_lock_irqsave (&ohci->lock, flags);
290 291 292
	rc = usb_hcd_check_unlink_urb(hcd, urb, status);
	if (rc) {
		;	/* Do nothing */
A
Alan Stern 已提交
293
	} else if (ohci->rh_state == OHCI_RH_RUNNING) {
L
Linus Torvalds 已提交
294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310
		urb_priv_t  *urb_priv;

		/* Unless an IRQ completed the unlink while it was being
		 * handed to us, flag it for unlink and giveback, and force
		 * some upcoming INTR_SF to call finish_unlinks()
		 */
		urb_priv = urb->hcpriv;
		if (urb_priv) {
			if (urb_priv->ed->state == ED_OPER)
				start_ed_unlink (ohci, urb_priv->ed);
		}
	} else {
		/*
		 * with HC dead, we won't respect hc queue pointers
		 * any more ... just clean up every urb's memory.
		 */
		if (urb->hcpriv)
311
			finish_urb(ohci, urb, status);
L
Linus Torvalds 已提交
312 313
	}
	spin_unlock_irqrestore (&ohci->lock, flags);
314
	return rc;
L
Linus Torvalds 已提交
315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339
}

/*-------------------------------------------------------------------------*/

/* frees config/altsetting state for endpoints,
 * including ED memory, dummy TD, and bulk/intr data toggle
 */

static void
ohci_endpoint_disable (struct usb_hcd *hcd, struct usb_host_endpoint *ep)
{
	struct ohci_hcd		*ohci = hcd_to_ohci (hcd);
	unsigned long		flags;
	struct ed		*ed = ep->hcpriv;
	unsigned		limit = 1000;

	/* ASSERT:  any requests/urbs are being unlinked */
	/* ASSERT:  nobody can be submitting urbs for this any more */

	if (!ed)
		return;

rescan:
	spin_lock_irqsave (&ohci->lock, flags);

A
Alan Stern 已提交
340
	if (ohci->rh_state != OHCI_RH_RUNNING) {
L
Linus Torvalds 已提交
341 342
sanitize:
		ed->state = ED_IDLE;
M
Mike Nuss 已提交
343 344
		if (quirk_zfmicro(ohci) && ed->type == PIPE_INTERRUPT)
			ohci->eds_scheduled--;
345
		finish_unlinks (ohci, 0);
L
Linus Torvalds 已提交
346 347 348 349 350 351
	}

	switch (ed->state) {
	case ED_UNLINK:		/* wait for hw to finish? */
		/* major IRQ delivery trouble loses INTR_SF too... */
		if (limit-- == 0) {
M
Mike Nuss 已提交
352 353 354 355 356 357
			ohci_warn(ohci, "ED unlink timeout\n");
			if (quirk_zfmicro(ohci)) {
				ohci_warn(ohci, "Attempting ZF TD recovery\n");
				ohci->ed_to_check = ed;
				ohci->zf_delay = 2;
			}
L
Linus Torvalds 已提交
358 359 360
			goto sanitize;
		}
		spin_unlock_irqrestore (&ohci->lock, flags);
361
		schedule_timeout_uninterruptible(1);
L
Linus Torvalds 已提交
362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395
		goto rescan;
	case ED_IDLE:		/* fully unlinked */
		if (list_empty (&ed->td_list)) {
			td_free (ohci, ed->dummy);
			ed_free (ohci, ed);
			break;
		}
		/* else FALL THROUGH */
	default:
		/* caller was supposed to have unlinked any requests;
		 * that's not our job.  can't recover; must leak ed.
		 */
		ohci_err (ohci, "leak ed %p (#%02x) state %d%s\n",
			ed, ep->desc.bEndpointAddress, ed->state,
			list_empty (&ed->td_list) ? "" : " (has tds)");
		td_free (ohci, ed->dummy);
		break;
	}
	ep->hcpriv = NULL;
	spin_unlock_irqrestore (&ohci->lock, flags);
}

static int ohci_get_frame (struct usb_hcd *hcd)
{
	struct ohci_hcd		*ohci = hcd_to_ohci (hcd);

	return ohci_frame_no(ohci);
}

static void ohci_usb_reset (struct ohci_hcd *ohci)
{
	ohci->hc_control = ohci_readl (ohci, &ohci->regs->control);
	ohci->hc_control &= OHCI_CTRL_RWC;
	ohci_writel (ohci, ohci->hc_control, &ohci->regs->control);
A
Alan Stern 已提交
396
	ohci->rh_state = OHCI_RH_HALTED;
L
Linus Torvalds 已提交
397 398
}

399
/* ohci_shutdown forcibly disables IRQs and DMA, helping kexec and
400 401 402
 * other cases where the next software may expect clean state from the
 * "firmware".  this is bus-neutral, unlike shutdown() methods.
 */
403 404
static void
ohci_shutdown (struct usb_hcd *hcd)
405 406 407
{
	struct ohci_hcd *ohci;

408
	ohci = hcd_to_ohci (hcd);
409
	ohci_writel(ohci, (u32) ~0, &ohci->regs->intrdisable);
410

411 412 413 414
	/* Software reset, after which the controller goes into SUSPEND */
	ohci_writel(ohci, OHCI_HCR, &ohci->regs->cmdstatus);
	ohci_readl(ohci, &ohci->regs->cmdstatus);	/* flush the writes */
	udelay(10);
415

416
	ohci_writel(ohci, ohci->fminterval, &ohci->regs->fminterval);
417 418
}

M
Mike Nuss 已提交
419 420 421 422 423 424 425 426 427 428 429 430 431 432 433
static int check_ed(struct ohci_hcd *ohci, struct ed *ed)
{
	return (hc32_to_cpu(ohci, ed->hwINFO) & ED_IN) != 0
		&& (hc32_to_cpu(ohci, ed->hwHeadP) & TD_MASK)
			== (hc32_to_cpu(ohci, ed->hwTailP) & TD_MASK)
		&& !list_empty(&ed->td_list);
}

/* ZF Micro watchdog timer callback. The ZF Micro chipset sometimes completes
 * an interrupt TD but neglects to add it to the donelist.  On systems with
 * this chipset, we need to periodically check the state of the queues to look
 * for such "lost" TDs.
 */
static void unlink_watchdog_func(unsigned long _ohci)
{
434
	unsigned long	flags;
M
Mike Nuss 已提交
435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500
	unsigned	max;
	unsigned	seen_count = 0;
	unsigned	i;
	struct ed	**seen = NULL;
	struct ohci_hcd	*ohci = (struct ohci_hcd *) _ohci;

	spin_lock_irqsave(&ohci->lock, flags);
	max = ohci->eds_scheduled;
	if (!max)
		goto done;

	if (ohci->ed_to_check)
		goto out;

	seen = kcalloc(max, sizeof *seen, GFP_ATOMIC);
	if (!seen)
		goto out;

	for (i = 0; i < NUM_INTS; i++) {
		struct ed	*ed = ohci->periodic[i];

		while (ed) {
			unsigned	temp;

			/* scan this branch of the periodic schedule tree */
			for (temp = 0; temp < seen_count; temp++) {
				if (seen[temp] == ed) {
					/* we've checked it and what's after */
					ed = NULL;
					break;
				}
			}
			if (!ed)
				break;
			seen[seen_count++] = ed;
			if (!check_ed(ohci, ed)) {
				ed = ed->ed_next;
				continue;
			}

			/* HC's TD list is empty, but HCD sees at least one
			 * TD that's not been sent through the donelist.
			 */
			ohci->ed_to_check = ed;
			ohci->zf_delay = 2;

			/* The HC may wait until the next frame to report the
			 * TD as done through the donelist and INTR_WDH.  (We
			 * just *assume* it's not a multi-TD interrupt URB;
			 * those could defer the IRQ more than one frame, using
			 * DI...)  Check again after the next INTR_SF.
			 */
			ohci_writel(ohci, OHCI_INTR_SF,
					&ohci->regs->intrstatus);
			ohci_writel(ohci, OHCI_INTR_SF,
					&ohci->regs->intrenable);

			/* flush those writes */
			(void) ohci_readl(ohci, &ohci->regs->control);

			goto out;
		}
	}
out:
	kfree(seen);
	if (ohci->eds_scheduled)
501
		mod_timer(&ohci->unlink_watchdog, round_jiffies(jiffies + HZ));
M
Mike Nuss 已提交
502 503 504 505
done:
	spin_unlock_irqrestore(&ohci->lock, flags);
}

L
Linus Torvalds 已提交
506 507 508 509 510 511 512 513 514
/*-------------------------------------------------------------------------*
 * HC functions
 *-------------------------------------------------------------------------*/

/* init memory, and kick BIOS/SMM off */

static int ohci_init (struct ohci_hcd *ohci)
{
	int ret;
515
	struct usb_hcd *hcd = ohci_to_hcd(ohci);
L
Linus Torvalds 已提交
516

517 518 519
	if (distrust_firmware)
		ohci->flags |= OHCI_QUIRK_HUB_POWER;

A
Alan Stern 已提交
520
	ohci->rh_state = OHCI_RH_HALTED;
521
	ohci->regs = hcd->regs;
L
Linus Torvalds 已提交
522

523 524 525 526
	/* REVISIT this BIOS handshake is now moved into PCI "quirks", and
	 * was never needed for most non-PCI systems ... remove the code?
	 */

L
Linus Torvalds 已提交
527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556
#ifndef IR_DISABLE
	/* SMM owns the HC?  not for long! */
	if (!no_handshake && ohci_readl (ohci,
					&ohci->regs->control) & OHCI_CTRL_IR) {
		u32 temp;

		ohci_dbg (ohci, "USB HC TakeOver from BIOS/SMM\n");

		/* this timeout is arbitrary.  we make it long, so systems
		 * depending on usb keyboards may be usable even if the
		 * BIOS/SMM code seems pretty broken.
		 */
		temp = 500;	/* arbitrary: five seconds */

		ohci_writel (ohci, OHCI_INTR_OC, &ohci->regs->intrenable);
		ohci_writel (ohci, OHCI_OCR, &ohci->regs->cmdstatus);
		while (ohci_readl (ohci, &ohci->regs->control) & OHCI_CTRL_IR) {
			msleep (10);
			if (--temp == 0) {
				ohci_err (ohci, "USB HC takeover failed!"
					"  (BIOS/SMM bug)\n");
				return -EBUSY;
			}
		}
		ohci_usb_reset (ohci);
	}
#endif

	/* Disable HC interrupts */
	ohci_writel (ohci, OHCI_INTR_MIE, &ohci->regs->intrdisable);
557 558 559 560

	/* flush the writes, and save key bits like RWC */
	if (ohci_readl (ohci, &ohci->regs->control) & OHCI_CTRL_RWC)
		ohci->hc_control |= OHCI_CTRL_RWC;
L
Linus Torvalds 已提交
561

562 563 564 565
	/* Read the number of ports unless overridden */
	if (ohci->num_ports == 0)
		ohci->num_ports = roothub_a(ohci) & RH_A_NDP;

L
Linus Torvalds 已提交
566 567 568
	if (ohci->hcca)
		return 0;

569
	ohci->hcca = dma_alloc_coherent (hcd->self.controller,
L
Linus Torvalds 已提交
570 571 572 573 574
			sizeof *ohci->hcca, &ohci->hcca_dma, 0);
	if (!ohci->hcca)
		return -ENOMEM;

	if ((ret = ohci_mem_init (ohci)) < 0)
575 576 577 578
		ohci_stop (hcd);
	else {
		create_debug_files (ohci);
	}
L
Linus Torvalds 已提交
579 580 581 582 583 584 585 586

	return ret;
}

/*-------------------------------------------------------------------------*/

/* Start an OHCI controller, set the BUS operational
 * resets USB and controller
587
 * enable interrupts
L
Linus Torvalds 已提交
588 589 590
 */
static int ohci_run (struct ohci_hcd *ohci)
{
591
	u32			mask, val;
L
Linus Torvalds 已提交
592
	int			first = ohci->fminterval == 0;
593
	struct usb_hcd		*hcd = ohci_to_hcd(ohci);
L
Linus Torvalds 已提交
594

A
Alan Stern 已提交
595
	ohci->rh_state = OHCI_RH_HALTED;
L
Linus Torvalds 已提交
596 597 598 599

	/* boot firmware should have set this up (5.1.1.3.1) */
	if (first) {

600 601
		val = ohci_readl (ohci, &ohci->regs->fminterval);
		ohci->fminterval = val & 0x3fff;
L
Linus Torvalds 已提交
602 603 604 605 606 607 608
		if (ohci->fminterval != FI)
			ohci_dbg (ohci, "fminterval delta %d\n",
				ohci->fminterval - FI);
		ohci->fminterval |= FSMP (ohci->fminterval) << 16;
		/* also: power/overcurrent flags in roothub.a */
	}

609 610 611 612
	/* Reset USB nearly "by the book".  RemoteWakeupConnected has
	 * to be checked in case boot firmware (BIOS/SMM/...) has set up
	 * wakeup in a way the bus isn't aware of (e.g., legacy PCI PM).
	 * If the bus glue detected wakeup capability then it should
613
	 * already be enabled; if so we'll just enable it again.
L
Linus Torvalds 已提交
614
	 */
615 616
	if ((ohci->hc_control & OHCI_CTRL_RWC) != 0)
		device_set_wakeup_capable(hcd->self.controller, 1);
L
Linus Torvalds 已提交
617 618 619

	switch (ohci->hc_control & OHCI_CTRL_HCFS) {
	case OHCI_USB_OPER:
620
		val = 0;
L
Linus Torvalds 已提交
621 622 623 624 625
		break;
	case OHCI_USB_SUSPEND:
	case OHCI_USB_RESUME:
		ohci->hc_control &= OHCI_CTRL_RWC;
		ohci->hc_control |= OHCI_USB_RESUME;
626
		val = 10 /* msec wait */;
L
Linus Torvalds 已提交
627 628 629 630 631
		break;
	// case OHCI_USB_RESET:
	default:
		ohci->hc_control &= OHCI_CTRL_RWC;
		ohci->hc_control |= OHCI_USB_RESET;
632
		val = 50 /* msec wait */;
L
Linus Torvalds 已提交
633 634 635 636 637
		break;
	}
	ohci_writel (ohci, ohci->hc_control, &ohci->regs->control);
	// flush the writes
	(void) ohci_readl (ohci, &ohci->regs->control);
638
	msleep(val);
A
Alan Stern 已提交
639

L
Linus Torvalds 已提交
640 641 642 643 644 645 646 647
	memset (ohci->hcca, 0, sizeof (struct ohci_hcca));

	/* 2msec timelimit here means no irqs/preempt */
	spin_lock_irq (&ohci->lock);

retry:
	/* HC Reset requires max 10 us delay */
	ohci_writel (ohci, OHCI_HCR,  &ohci->regs->cmdstatus);
648
	val = 30;	/* ... allow extra time */
L
Linus Torvalds 已提交
649
	while ((ohci_readl (ohci, &ohci->regs->cmdstatus) & OHCI_HCR) != 0) {
650
		if (--val == 0) {
L
Linus Torvalds 已提交
651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699
			spin_unlock_irq (&ohci->lock);
			ohci_err (ohci, "USB HC reset timed out!\n");
			return -1;
		}
		udelay (1);
	}

	/* now we're in the SUSPEND state ... must go OPERATIONAL
	 * within 2msec else HC enters RESUME
	 *
	 * ... but some hardware won't init fmInterval "by the book"
	 * (SiS, OPTi ...), so reset again instead.  SiS doesn't need
	 * this if we write fmInterval after we're OPERATIONAL.
	 * Unclear about ALi, ServerWorks, and others ... this could
	 * easily be a longstanding bug in chip init on Linux.
	 */
	if (ohci->flags & OHCI_QUIRK_INITRESET) {
		ohci_writel (ohci, ohci->hc_control, &ohci->regs->control);
		// flush those writes
		(void) ohci_readl (ohci, &ohci->regs->control);
	}

	/* Tell the controller where the control and bulk lists are
	 * The lists are empty now. */
	ohci_writel (ohci, 0, &ohci->regs->ed_controlhead);
	ohci_writel (ohci, 0, &ohci->regs->ed_bulkhead);

	/* a reset clears this */
	ohci_writel (ohci, (u32) ohci->hcca_dma, &ohci->regs->hcca);

	periodic_reinit (ohci);

	/* some OHCI implementations are finicky about how they init.
	 * bogus values here mean not even enumeration could work.
	 */
	if ((ohci_readl (ohci, &ohci->regs->fminterval) & 0x3fff0000) == 0
			|| !ohci_readl (ohci, &ohci->regs->periodicstart)) {
		if (!(ohci->flags & OHCI_QUIRK_INITRESET)) {
			ohci->flags |= OHCI_QUIRK_INITRESET;
			ohci_dbg (ohci, "enabling initreset quirk\n");
			goto retry;
		}
		spin_unlock_irq (&ohci->lock);
		ohci_err (ohci, "init err (%08x %04x)\n",
			ohci_readl (ohci, &ohci->regs->fminterval),
			ohci_readl (ohci, &ohci->regs->periodicstart));
		return -EOVERFLOW;
	}

700
	/* use rhsc irqs after khubd is fully initialized */
701
	set_bit(HCD_FLAG_POLL_RH, &hcd->flags);
702 703 704
	hcd->uses_new_polling = 1;

	/* start controller operations */
L
Linus Torvalds 已提交
705
	ohci->hc_control &= OHCI_CTRL_RWC;
706 707
	ohci->hc_control |= OHCI_CONTROL_INIT | OHCI_USB_OPER;
	ohci_writel (ohci, ohci->hc_control, &ohci->regs->control);
A
Alan Stern 已提交
708
	ohci->rh_state = OHCI_RH_RUNNING;
L
Linus Torvalds 已提交
709 710 711 712 713 714

	/* wake on ConnectStatusChange, matching external hubs */
	ohci_writel (ohci, RH_HS_DRWE, &ohci->regs->roothub.status);

	/* Choose the interrupts we care about now, others later on demand */
	mask = OHCI_INTR_INIT;
715
	ohci_writel (ohci, ~0, &ohci->regs->intrstatus);
L
Linus Torvalds 已提交
716 717 718
	ohci_writel (ohci, mask, &ohci->regs->intrenable);

	/* handle root hub init quirks ... */
719 720
	val = roothub_a (ohci);
	val &= ~(RH_A_PSM | RH_A_OCPM);
L
Linus Torvalds 已提交
721 722
	if (ohci->flags & OHCI_QUIRK_SUPERIO) {
		/* NSC 87560 and maybe others */
723 724 725
		val |= RH_A_NOCP;
		val &= ~(RH_A_POTPGT | RH_A_NPS);
		ohci_writel (ohci, val, &ohci->regs->roothub.a);
726 727
	} else if ((ohci->flags & OHCI_QUIRK_AMD756) ||
			(ohci->flags & OHCI_QUIRK_HUB_POWER)) {
L
Linus Torvalds 已提交
728 729 730
		/* hub power always on; required for AMD-756 and some
		 * Mac platforms.  ganged overcurrent reporting, if any.
		 */
731 732
		val |= RH_A_NPS;
		ohci_writel (ohci, val, &ohci->regs->roothub.a);
L
Linus Torvalds 已提交
733 734
	}
	ohci_writel (ohci, RH_HS_LPSC, &ohci->regs->roothub.status);
735
	ohci_writel (ohci, (val & RH_A_NPS) ? 0 : RH_B_PPCM,
L
Linus Torvalds 已提交
736 737 738 739
						&ohci->regs->roothub.b);
	// flush those writes
	(void) ohci_readl (ohci, &ohci->regs->control);

740
	ohci->next_statechange = jiffies + STATECHANGE_DELAY;
L
Linus Torvalds 已提交
741 742 743
	spin_unlock_irq (&ohci->lock);

	// POTPGT delay is bits 24-31, in 2 ms units.
744
	mdelay ((val >> 23) & 0x1fe);
L
Linus Torvalds 已提交
745

M
Mike Nuss 已提交
746 747 748 749 750 751 752 753 754
	if (quirk_zfmicro(ohci)) {
		/* Create timer to watch for bad queue state on ZF Micro */
		setup_timer(&ohci->unlink_watchdog, unlink_watchdog_func,
				(unsigned long) ohci);

		ohci->eds_scheduled = 0;
		ohci->ed_to_check = NULL;
	}

L
Linus Torvalds 已提交
755 756 757 758 759
	ohci_dump (ohci, 1);

	return 0;
}

760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785
/* ohci_setup routine for generic controller initialization */

int ohci_setup(struct usb_hcd *hcd)
{
	struct ohci_hcd		*ohci = hcd_to_ohci(hcd);

	ohci_hcd_init(ohci);
	
	return ohci_init(ohci);
}
EXPORT_SYMBOL_GPL(ohci_setup);

/* ohci_start routine for generic controller start of all OHCI bus glue */
static int ohci_start(struct usb_hcd *hcd)
{
	struct ohci_hcd		*ohci = hcd_to_ohci(hcd);
	int	ret;

	ret = ohci_run(ohci);
	if (ret < 0) {
		ohci_err(ohci, "can't start\n");
		ohci_stop(hcd);
	}
	return ret;
}

L
Linus Torvalds 已提交
786 787 788 789
/*-------------------------------------------------------------------------*/

/* an interrupt happens */

790
static irqreturn_t ohci_irq (struct usb_hcd *hcd)
L
Linus Torvalds 已提交
791 792 793
{
	struct ohci_hcd		*ohci = hcd_to_ohci (hcd);
	struct ohci_regs __iomem *regs = ohci->regs;
M
Mike Nuss 已提交
794
	int			ints;
L
Linus Torvalds 已提交
795

796 797 798
	/* Read interrupt status (and flush pending writes).  We ignore the
	 * optimization of checking the LSB of hcca->done_head; it doesn't
	 * work on all systems (edge triggering for OHCI can be a factor).
M
Mike Nuss 已提交
799
	 */
800
	ints = ohci_readl(ohci, &regs->intrstatus);
L
Linus Torvalds 已提交
801

802 803 804 805
	/* Check for an all 1's result which is a typical consequence
	 * of dead, unclocked, or unplugged (CardBus...) devices
	 */
	if (ints == ~(u32)0) {
A
Alan Stern 已提交
806
		ohci->rh_state = OHCI_RH_HALTED;
L
Linus Torvalds 已提交
807
		ohci_dbg (ohci, "device removed!\n");
808
		usb_hc_died(hcd);
L
Linus Torvalds 已提交
809
		return IRQ_HANDLED;
810 811 812 813
	}

	/* We only care about interrupts that are enabled */
	ints &= ohci_readl(ohci, &regs->intrenable);
L
Linus Torvalds 已提交
814 815

	/* interrupt for some other device? */
A
Alan Stern 已提交
816
	if (ints == 0 || unlikely(ohci->rh_state == OHCI_RH_HALTED))
L
Linus Torvalds 已提交
817
		return IRQ_NOTMINE;
818

L
Linus Torvalds 已提交
819 820
	if (ints & OHCI_INTR_UE) {
		// e.g. due to PCI Master/Target Abort
M
Mike Nuss 已提交
821
		if (quirk_nec(ohci)) {
822 823 824 825 826 827 828 829 830 831
			/* Workaround for a silicon bug in some NEC chips used
			 * in Apple's PowerBooks. Adapted from Darwin code.
			 */
			ohci_err (ohci, "OHCI Unrecoverable Error, scheduling NEC chip restart\n");

			ohci_writel (ohci, OHCI_INTR_UE, &regs->intrdisable);

			schedule_work (&ohci->nec_work);
		} else {
			ohci_err (ohci, "OHCI Unrecoverable Error, disabled\n");
A
Alan Stern 已提交
832
			ohci->rh_state = OHCI_RH_HALTED;
833
			usb_hc_died(hcd);
834
		}
L
Linus Torvalds 已提交
835 836 837 838 839

		ohci_dump (ohci, 1);
		ohci_usb_reset (ohci);
	}

A
Alan Stern 已提交
840 841 842 843 844
	if (ints & OHCI_INTR_RHSC) {
		ohci_vdbg(ohci, "rhsc\n");
		ohci->next_statechange = jiffies + STATECHANGE_DELAY;
		ohci_writel(ohci, OHCI_INTR_RD | OHCI_INTR_RHSC,
				&regs->intrstatus);
845 846 847 848 849 850 851 852 853 854

		/* NOTE: Vendors didn't always make the same implementation
		 * choices for RHSC.  Many followed the spec; RHSC triggers
		 * on an edge, like setting and maybe clearing a port status
		 * change bit.  With others it's level-triggered, active
		 * until khubd clears all the port status change bits.  We'll
		 * always disable it here and rely on polling until khubd
		 * re-enables it.
		 */
		ohci_writel(ohci, OHCI_INTR_RHSC, &regs->intrdisable);
A
Alan Stern 已提交
855 856 857 858 859 860 861 862 863 864
		usb_hcd_poll_rh_status(hcd);
	}

	/* For connect and disconnect events, we expect the controller
	 * to turn on RHSC along with RD.  But for remote wakeup events
	 * this might not happen.
	 */
	else if (ints & OHCI_INTR_RD) {
		ohci_vdbg(ohci, "resume detect\n");
		ohci_writel(ohci, OHCI_INTR_RD, &regs->intrstatus);
865
		set_bit(HCD_FLAG_POLL_RH, &hcd->flags);
A
Alan Stern 已提交
866 867 868 869 870
		if (ohci->autostop) {
			spin_lock (&ohci->lock);
			ohci_rh_resume (ohci);
			spin_unlock (&ohci->lock);
		} else
D
David Brownell 已提交
871
			usb_hcd_resume_root_hub(hcd);
L
Linus Torvalds 已提交
872 873 874 875
	}

	if (ints & OHCI_INTR_WDH) {
		spin_lock (&ohci->lock);
876
		dl_done_list (ohci);
L
Linus Torvalds 已提交
877 878
		spin_unlock (&ohci->lock);
	}
879

M
Mike Nuss 已提交
880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904
	if (quirk_zfmicro(ohci) && (ints & OHCI_INTR_SF)) {
		spin_lock(&ohci->lock);
		if (ohci->ed_to_check) {
			struct ed *ed = ohci->ed_to_check;

			if (check_ed(ohci, ed)) {
				/* HC thinks the TD list is empty; HCD knows
				 * at least one TD is outstanding
				 */
				if (--ohci->zf_delay == 0) {
					struct td *td = list_entry(
						ed->td_list.next,
						struct td, td_list);
					ohci_warn(ohci,
						  "Reclaiming orphan TD %p\n",
						  td);
					takeback_td(ohci, td);
					ohci->ed_to_check = NULL;
				}
			} else
				ohci->ed_to_check = NULL;
		}
		spin_unlock(&ohci->lock);
	}

L
Linus Torvalds 已提交
905 906 907 908 909 910 911
	/* could track INTR_SO to reduce available PCI/... bandwidth */

	/* handle any pending URB/ED unlinks, leaving INTR_SF enabled
	 * when there's still unlinking to be done (next frame).
	 */
	spin_lock (&ohci->lock);
	if (ohci->ed_rm_list)
912
		finish_unlinks (ohci, ohci_frame_no(ohci));
M
Mike Nuss 已提交
913 914 915
	if ((ints & OHCI_INTR_SF) != 0
			&& !ohci->ed_rm_list
			&& !ohci->ed_to_check
A
Alan Stern 已提交
916
			&& ohci->rh_state == OHCI_RH_RUNNING)
917
		ohci_writel (ohci, OHCI_INTR_SF, &regs->intrdisable);
L
Linus Torvalds 已提交
918 919
	spin_unlock (&ohci->lock);

A
Alan Stern 已提交
920
	if (ohci->rh_state == OHCI_RH_RUNNING) {
L
Linus Torvalds 已提交
921
		ohci_writel (ohci, ints, &regs->intrstatus);
922
		ohci_writel (ohci, OHCI_INTR_MIE, &regs->intrenable);
L
Linus Torvalds 已提交
923 924 925 926 927 928 929 930 931 932
		// flush those writes
		(void) ohci_readl (ohci, &ohci->regs->control);
	}

	return IRQ_HANDLED;
}

/*-------------------------------------------------------------------------*/

static void ohci_stop (struct usb_hcd *hcd)
933
{
L
Linus Torvalds 已提交
934 935 936 937
	struct ohci_hcd		*ohci = hcd_to_ohci (hcd);

	ohci_dump (ohci, 1);

T
Tejun Heo 已提交
938
	if (quirk_nec(ohci))
939
		flush_work(&ohci->nec_work);
L
Linus Torvalds 已提交
940 941

	ohci_writel (ohci, OHCI_INTR_MIE, &ohci->regs->intrdisable);
942
	ohci_usb_reset(ohci);
943
	free_irq(hcd->irq, hcd);
944
	hcd->irq = 0;
945

M
Mike Nuss 已提交
946 947
	if (quirk_zfmicro(ohci))
		del_timer(&ohci->unlink_watchdog);
L
Libin Yang 已提交
948
	if (quirk_amdiso(ohci))
949
		usb_amd_dev_put();
M
Mike Nuss 已提交
950

L
Linus Torvalds 已提交
951 952 953
	remove_debug_files (ohci);
	ohci_mem_cleanup (ohci);
	if (ohci->hcca) {
954 955
		dma_free_coherent (hcd->self.controller,
				sizeof *ohci->hcca,
L
Linus Torvalds 已提交
956 957 958 959 960 961 962 963
				ohci->hcca, ohci->hcca_dma);
		ohci->hcca = NULL;
		ohci->hcca_dma = 0;
	}
}

/*-------------------------------------------------------------------------*/

964 965
#if defined(CONFIG_PM) || defined(CONFIG_PCI)

L
Linus Torvalds 已提交
966
/* must not be called from interrupt context */
967
int ohci_restart(struct ohci_hcd *ohci)
L
Linus Torvalds 已提交
968 969 970 971 972
{
	int temp;
	int i;
	struct urb_priv *priv;

973
	ohci_init(ohci);
L
Linus Torvalds 已提交
974
	spin_lock_irq(&ohci->lock);
A
Alan Stern 已提交
975
	ohci->rh_state = OHCI_RH_HALTED;
976 977

	/* Recycle any "live" eds/tds (and urbs). */
L
Linus Torvalds 已提交
978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000
	if (!list_empty (&ohci->pending))
		ohci_dbg(ohci, "abort schedule...\n");
	list_for_each_entry (priv, &ohci->pending, pending) {
		struct urb	*urb = priv->td[0]->urb;
		struct ed	*ed = priv->ed;

		switch (ed->state) {
		case ED_OPER:
			ed->state = ED_UNLINK;
			ed->hwINFO |= cpu_to_hc32(ohci, ED_DEQUEUE);
			ed_deschedule (ohci, ed);

			ed->ed_next = ohci->ed_rm_list;
			ed->ed_prev = NULL;
			ohci->ed_rm_list = ed;
			/* FALLTHROUGH */
		case ED_UNLINK:
			break;
		default:
			ohci_dbg(ohci, "bogus ed %p state %d\n",
					ed, ed->state);
		}

1001 1002
		if (!urb->unlinked)
			urb->unlinked = -ESHUTDOWN;
L
Linus Torvalds 已提交
1003
	}
1004
	finish_unlinks (ohci, 0);
L
Linus Torvalds 已提交
1005 1006 1007 1008 1009 1010 1011
	spin_unlock_irq(&ohci->lock);

	/* paranoia, in case that didn't work: */

	/* empty the interrupt branches */
	for (i = 0; i < NUM_INTS; i++) ohci->load [i] = 0;
	for (i = 0; i < NUM_INTS; i++) ohci->hcca->int_table [i] = 0;
1012

L
Linus Torvalds 已提交
1013 1014 1015
	/* no EDs to remove */
	ohci->ed_rm_list = NULL;

1016
	/* empty control and bulk lists */
L
Linus Torvalds 已提交
1017 1018 1019 1020 1021 1022 1023
	ohci->ed_controltail = NULL;
	ohci->ed_bulktail    = NULL;

	if ((temp = ohci_run (ohci)) < 0) {
		ohci_err (ohci, "can't restart, %d\n", temp);
		return temp;
	}
A
Alan Stern 已提交
1024
	ohci_dbg(ohci, "restart complete\n");
L
Linus Torvalds 已提交
1025 1026
	return 0;
}
1027
EXPORT_SYMBOL_GPL(ohci_restart);
1028

1029 1030
#endif

1031 1032
#ifdef CONFIG_PM

1033
int ohci_suspend(struct usb_hcd *hcd, bool do_wakeup)
1034 1035 1036 1037
{
	struct ohci_hcd	*ohci = hcd_to_ohci (hcd);
	unsigned long	flags;

1038
	/* Disable irq emission and mark HW unaccessible. Use
1039 1040 1041 1042 1043 1044 1045 1046 1047 1048
	 * the spinlock to properly synchronize with possible pending
	 * RH suspend or resume activity.
	 */
	spin_lock_irqsave (&ohci->lock, flags);
	ohci_writel(ohci, OHCI_INTR_MIE, &ohci->regs->intrdisable);
	(void)ohci_readl(ohci, &ohci->regs->intrdisable);

	clear_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags);
	spin_unlock_irqrestore (&ohci->lock, flags);

1049
	return 0;
1050
}
1051
EXPORT_SYMBOL_GPL(ohci_suspend);
1052 1053


1054
int ohci_resume(struct usb_hcd *hcd, bool hibernated)
1055
{
1056 1057 1058 1059
	struct ohci_hcd		*ohci = hcd_to_ohci(hcd);
	int			port;
	bool			need_reinit = false;

1060 1061 1062 1063
	set_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags);

	/* Make sure resume from hibernation re-enumerates everything */
	if (hibernated)
1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098
		ohci_usb_reset(ohci);

	/* See if the controller is already running or has been reset */
	ohci->hc_control = ohci_readl(ohci, &ohci->regs->control);
	if (ohci->hc_control & (OHCI_CTRL_IR | OHCI_SCHED_ENABLES)) {
		need_reinit = true;
	} else {
		switch (ohci->hc_control & OHCI_CTRL_HCFS) {
		case OHCI_USB_OPER:
		case OHCI_USB_RESET:
			need_reinit = true;
		}
	}

	/* If needed, reinitialize and suspend the root hub */
	if (need_reinit) {
		spin_lock_irq(&ohci->lock);
		ohci_rh_resume(ohci);
		ohci_rh_suspend(ohci, 0);
		spin_unlock_irq(&ohci->lock);
	}

	/* Normally just turn on port power and enable interrupts */
	else {
		ohci_dbg(ohci, "powerup ports\n");
		for (port = 0; port < ohci->num_ports; port++)
			ohci_writel(ohci, RH_PS_PPS,
					&ohci->regs->roothub.portstatus[port]);

		ohci_writel(ohci, OHCI_INTR_MIE, &ohci->regs->intrenable);
		ohci_readl(ohci, &ohci->regs->intrenable);
		msleep(20);
	}

	usb_hcd_resume_root_hub(hcd);
1099 1100 1101

	return 0;
}
1102 1103 1104 1105 1106 1107 1108 1109 1110 1111
EXPORT_SYMBOL_GPL(ohci_resume);

#endif

/*-------------------------------------------------------------------------*/

/*
 * Generic structure: This gets copied for platform drivers so that
 * individual entries can be overridden as needed.
 */
1112

1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151
static const struct hc_driver ohci_hc_driver = {
	.description =          hcd_name,
	.product_desc =         "OHCI Host Controller",
	.hcd_priv_size =        sizeof(struct ohci_hcd),

	/*
	 * generic hardware linkage
	*/
	.irq =                  ohci_irq,
	.flags =                HCD_MEMORY | HCD_USB11,

	/*
	* basic lifecycle operations
	*/
	.reset =                ohci_setup,
	.start =                ohci_start,
	.stop =                 ohci_stop,
	.shutdown =             ohci_shutdown,

	/*
	 * managing i/o requests and associated device resources
	*/
	.urb_enqueue =          ohci_urb_enqueue,
	.urb_dequeue =          ohci_urb_dequeue,
	.endpoint_disable =     ohci_endpoint_disable,

	/*
	* scheduling support
	*/
	.get_frame_number =     ohci_get_frame,

	/*
	* root hub support
	*/
	.hub_status_data =      ohci_hub_status_data,
	.hub_control =          ohci_hub_control,
#ifdef CONFIG_PM
	.bus_suspend =          ohci_bus_suspend,
	.bus_resume =           ohci_bus_resume,
1152
#endif
1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167
	.start_port_reset =	ohci_start_port_reset,
};

void ohci_init_driver(struct hc_driver *drv,
		const struct ohci_driver_overrides *over)
{
	/* Copy the generic table to drv and then apply the overrides */
	*drv = ohci_hc_driver;

	drv->product_desc = over->product_desc;
	drv->hcd_priv_size += over->extra_priv_size;
	if (over->reset)
		drv->reset = over->reset;
}
EXPORT_SYMBOL_GPL(ohci_init_driver);
1168

1169 1170
/*-------------------------------------------------------------------------*/

L
Linus Torvalds 已提交
1171
MODULE_AUTHOR (DRIVER_AUTHOR);
1172
MODULE_DESCRIPTION(DRIVER_DESC);
L
Linus Torvalds 已提交
1173 1174
MODULE_LICENSE ("GPL");

1175
#if defined(CONFIG_ARCH_SA1100) && defined(CONFIG_SA1111)
L
Linus Torvalds 已提交
1176
#include "ohci-sa1111.c"
1177
#define SA1111_DRIVER		ohci_hcd_sa1111_driver
L
Linus Torvalds 已提交
1178 1179
#endif

1180
#if defined(CONFIG_PXA27x) || defined(CONFIG_PXA3xx)
L
Linus Torvalds 已提交
1181
#include "ohci-pxa27x.c"
1182
#define PLATFORM_DRIVER		ohci_hcd_pxa27x_driver
L
Linus Torvalds 已提交
1183 1184
#endif

1185 1186
#ifdef CONFIG_ARCH_EP93XX
#include "ohci-ep93xx.c"
1187
#define EP93XX_PLATFORM_DRIVER	ohci_hcd_ep93xx_driver
1188 1189
#endif

1190
#ifdef CONFIG_ARCH_LPC32XX
1191
#include "ohci-nxp.c"
1192
#define NXP_PLATFORM_DRIVER	usb_hcd_nxp_driver
1193 1194
#endif

1195 1196
#ifdef CONFIG_ARCH_DAVINCI_DA8XX
#include "ohci-da8xx.c"
1197
#define DAVINCI_PLATFORM_DRIVER	ohci_hcd_da8xx_driver
1198 1199
#endif

1200 1201 1202 1203 1204
#ifdef CONFIG_USB_OHCI_HCD_PPC_OF
#include "ohci-ppc-of.c"
#define OF_PLATFORM_DRIVER	ohci_hcd_ppc_of_driver
#endif

G
Geoff Levand 已提交
1205 1206
#ifdef CONFIG_PPC_PS3
#include "ohci-ps3.c"
G
Geoff Levand 已提交
1207
#define PS3_SYSTEM_BUS_DRIVER	ps3_ohci_driver
G
Geoff Levand 已提交
1208 1209
#endif

M
Magnus Damm 已提交
1210 1211
#ifdef CONFIG_MFD_SM501
#include "ohci-sm501.c"
1212
#define SM501_OHCI_DRIVER	ohci_hcd_sm501_driver
M
Magnus Damm 已提交
1213 1214
#endif

1215 1216 1217
#ifdef CONFIG_MFD_TC6393XB
#include "ohci-tmio.c"
#define TMIO_OHCI_DRIVER	ohci_hcd_tmio_driver
1218 1219 1220 1221 1222
#endif

#ifdef CONFIG_MACH_JZ4740
#include "ohci-jz4740.c"
#define PLATFORM_DRIVER	ohci_hcd_jz4740_driver
1223 1224
#endif

1225 1226 1227 1228 1229
#ifdef CONFIG_USB_OCTEON_OHCI
#include "ohci-octeon.c"
#define PLATFORM_DRIVER		ohci_octeon_driver
#endif

1230 1231 1232 1233 1234
#ifdef CONFIG_TILE_USB
#include "ohci-tilegx.c"
#define PLATFORM_DRIVER		ohci_hcd_tilegx_driver
#endif

1235 1236 1237 1238 1239 1240 1241
static int __init ohci_hcd_mod_init(void)
{
	int retval = 0;

	if (usb_disabled())
		return -ENODEV;

1242
	printk(KERN_INFO "%s: " DRIVER_DESC "\n", hcd_name);
1243 1244
	pr_debug ("%s: block sizes: ed %Zd td %Zd\n", hcd_name,
		sizeof (struct ed), sizeof (struct td));
1245
	set_bit(USB_OHCI_LOADED, &usb_hcds_loaded);
1246

1247
#ifdef DEBUG
1248
	ohci_debug_root = debugfs_create_dir("ohci", usb_debug_root);
1249 1250 1251 1252 1253 1254
	if (!ohci_debug_root) {
		retval = -ENOENT;
		goto error_debug;
	}
#endif

G
Geoff Levand 已提交
1255
#ifdef PS3_SYSTEM_BUS_DRIVER
G
Geoff Levand 已提交
1256 1257 1258
	retval = ps3_ohci_driver_register(&PS3_SYSTEM_BUS_DRIVER);
	if (retval < 0)
		goto error_ps3;
G
Geoff Levand 已提交
1259 1260
#endif

1261 1262 1263
#ifdef PLATFORM_DRIVER
	retval = platform_driver_register(&PLATFORM_DRIVER);
	if (retval < 0)
1264
		goto error_platform;
1265 1266
#endif

1267
#ifdef OF_PLATFORM_DRIVER
1268
	retval = platform_driver_register(&OF_PLATFORM_DRIVER);
1269
	if (retval < 0)
1270
		goto error_of_platform;
1271 1272
#endif

1273 1274 1275
#ifdef SA1111_DRIVER
	retval = sa1111_driver_register(&SA1111_DRIVER);
	if (retval < 0)
1276
		goto error_sa1111;
1277 1278
#endif

1279 1280 1281 1282 1283 1284
#ifdef SM501_OHCI_DRIVER
	retval = platform_driver_register(&SM501_OHCI_DRIVER);
	if (retval < 0)
		goto error_sm501;
#endif

1285 1286 1287 1288 1289 1290
#ifdef TMIO_OHCI_DRIVER
	retval = platform_driver_register(&TMIO_OHCI_DRIVER);
	if (retval < 0)
		goto error_tmio;
#endif

1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308
#ifdef EP93XX_PLATFORM_DRIVER
	retval = platform_driver_register(&EP93XX_PLATFORM_DRIVER);
	if (retval < 0)
		goto error_ep93xx;
#endif

#ifdef NXP_PLATFORM_DRIVER
	retval = platform_driver_register(&NXP_PLATFORM_DRIVER);
	if (retval < 0)
		goto error_nxp;
#endif

#ifdef DAVINCI_PLATFORM_DRIVER
	retval = platform_driver_register(&DAVINCI_PLATFORM_DRIVER);
	if (retval < 0)
		goto error_davinci;
#endif

1309 1310 1311
	return retval;

	/* Error path */
1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323
#ifdef DAVINCI_PLATFORM_DRIVER
	platform_driver_unregister(&DAVINCI_PLATFORM_DRIVER);
 error_davinci:
#endif
#ifdef NXP_PLATFORM_DRIVER
	platform_driver_unregister(&NXP_PLATFORM_DRIVER);
 error_nxp:
#endif
#ifdef EP93XX_PLATFORM_DRIVER
	platform_driver_unregister(&EP93XX_PLATFORM_DRIVER);
 error_ep93xx:
#endif
1324 1325 1326 1327
#ifdef TMIO_OHCI_DRIVER
	platform_driver_unregister(&TMIO_OHCI_DRIVER);
 error_tmio:
#endif
1328
#ifdef SM501_OHCI_DRIVER
1329
	platform_driver_unregister(&SM501_OHCI_DRIVER);
1330 1331
 error_sm501:
#endif
1332 1333 1334
#ifdef SA1111_DRIVER
	sa1111_driver_unregister(&SA1111_DRIVER);
 error_sa1111:
1335
#endif
1336
#ifdef OF_PLATFORM_DRIVER
1337
	platform_driver_unregister(&OF_PLATFORM_DRIVER);
1338
 error_of_platform:
1339
#endif
1340 1341 1342
#ifdef PLATFORM_DRIVER
	platform_driver_unregister(&PLATFORM_DRIVER);
 error_platform:
1343
#endif
G
Geoff Levand 已提交
1344
#ifdef PS3_SYSTEM_BUS_DRIVER
G
Geoff Levand 已提交
1345
	ps3_ohci_driver_unregister(&PS3_SYSTEM_BUS_DRIVER);
G
Geoff Levand 已提交
1346
 error_ps3:
1347
#endif
1348 1349 1350 1351 1352 1353
#ifdef DEBUG
	debugfs_remove(ohci_debug_root);
	ohci_debug_root = NULL;
 error_debug:
#endif

1354
	clear_bit(USB_OHCI_LOADED, &usb_hcds_loaded);
1355 1356 1357 1358 1359 1360
	return retval;
}
module_init(ohci_hcd_mod_init);

static void __exit ohci_hcd_mod_exit(void)
{
1361 1362 1363 1364 1365 1366 1367 1368 1369
#ifdef DAVINCI_PLATFORM_DRIVER
	platform_driver_unregister(&DAVINCI_PLATFORM_DRIVER);
#endif
#ifdef NXP_PLATFORM_DRIVER
	platform_driver_unregister(&NXP_PLATFORM_DRIVER);
#endif
#ifdef EP93XX_PLATFORM_DRIVER
	platform_driver_unregister(&EP93XX_PLATFORM_DRIVER);
#endif
1370 1371 1372
#ifdef TMIO_OHCI_DRIVER
	platform_driver_unregister(&TMIO_OHCI_DRIVER);
#endif
1373 1374 1375
#ifdef SM501_OHCI_DRIVER
	platform_driver_unregister(&SM501_OHCI_DRIVER);
#endif
1376 1377 1378
#ifdef SA1111_DRIVER
	sa1111_driver_unregister(&SA1111_DRIVER);
#endif
1379
#ifdef OF_PLATFORM_DRIVER
1380
	platform_driver_unregister(&OF_PLATFORM_DRIVER);
1381
#endif
1382 1383 1384
#ifdef PLATFORM_DRIVER
	platform_driver_unregister(&PLATFORM_DRIVER);
#endif
G
Geoff Levand 已提交
1385
#ifdef PS3_SYSTEM_BUS_DRIVER
G
Geoff Levand 已提交
1386
	ps3_ohci_driver_unregister(&PS3_SYSTEM_BUS_DRIVER);
G
Geoff Levand 已提交
1387
#endif
1388 1389 1390
#ifdef DEBUG
	debugfs_remove(ohci_debug_root);
#endif
1391
	clear_bit(USB_OHCI_LOADED, &usb_hcds_loaded);
1392 1393 1394
}
module_exit(ohci_hcd_mod_exit);