uhci-hcd.c 25.3 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Universal Host Controller Interface driver for USB.
 *
 * Maintainer: Alan Stern <stern@rowland.harvard.edu>
 *
 * (C) Copyright 1999 Linus Torvalds
 * (C) Copyright 1999-2002 Johannes Erdfelt, johannes@erdfelt.com
 * (C) Copyright 1999 Randy Dunlap
 * (C) Copyright 1999 Georg Acher, acher@in.tum.de
 * (C) Copyright 1999 Deti Fliegl, deti@fliegl.de
 * (C) Copyright 1999 Thomas Sailer, sailer@ife.ee.ethz.ch
 * (C) Copyright 1999 Roman Weissgaerber, weissg@vienna.at
 * (C) Copyright 2000 Yggdrasil Computing, Inc. (port of new PCI interface
 *               support from usb-ohci.c by Adam Richter, adam@yggdrasil.com).
 * (C) Copyright 1999 Gregory P. Smith (from usb-ohci.c)
16
 * (C) Copyright 2004-2007 Alan Stern, stern@rowland.harvard.edu
L
Linus Torvalds 已提交
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
 *
 * Intel documents this fairly well, and as far as I know there
 * are no royalties or anything like that, but even so there are
 * people who decided that they want to do the same thing in a
 * completely different way.
 *
 */

#include <linux/module.h>
#include <linux/pci.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/delay.h>
#include <linux/ioport.h>
#include <linux/slab.h>
#include <linux/errno.h>
#include <linux/unistd.h>
#include <linux/interrupt.h>
#include <linux/spinlock.h>
#include <linux/debugfs.h>
#include <linux/pm.h>
#include <linux/dmapool.h>
#include <linux/dma-mapping.h>
#include <linux/usb.h>
41
#include <linux/usb/hcd.h>
L
Linus Torvalds 已提交
42
#include <linux/bitops.h>
A
Alan Stern 已提交
43
#include <linux/dmi.h>
L
Linus Torvalds 已提交
44 45 46 47 48 49 50 51 52 53

#include <asm/uaccess.h>
#include <asm/io.h>
#include <asm/irq.h>

#include "uhci-hcd.h"

/*
 * Version Information
 */
54 55 56 57
#define DRIVER_AUTHOR							\
	"Linus 'Frodo Rabbit' Torvalds, Johannes Erdfelt, "		\
	"Randy Dunlap, Georg Acher, Deti Fliegl, Thomas Sailer, "	\
	"Roman Weissgaerber, Alan Stern"
L
Linus Torvalds 已提交
58 59
#define DRIVER_DESC "USB Universal Host Controller Interface driver"

60
/* for flakey hardware, ignore overcurrent indicators */
61
static bool ignore_oc;
62 63 64
module_param(ignore_oc, bool, S_IRUGO);
MODULE_PARM_DESC(ignore_oc, "ignore hardware overcurrent indications");

L
Linus Torvalds 已提交
65 66
/*
 * debug = 0, no debugging messages
67 68
 * debug = 1, dump failed URBs except for stalls
 * debug = 2, dump all failed URBs (including stalls)
69
 *            show all queues in /sys/kernel/debug/uhci/[pci_addr]
70
 * debug = 3, show all TDs in URBs when dumping
L
Linus Torvalds 已提交
71
 */
72 73
#if defined(DEBUG) || defined(CONFIG_DYNAMIC_DEBUG)

L
Linus Torvalds 已提交
74 75 76
static int debug = 1;
module_param(debug, int, S_IRUGO | S_IWUSR);
MODULE_PARM_DESC(debug, "Debug level");
77
static char *errbuf;
78 79

#else
80 81 82 83

#define debug 0
#define errbuf NULL

84 85
#endif

86

L
Linus Torvalds 已提交
87 88
#define ERRBUF_LEN    (32 * 1024)

89
static struct kmem_cache *uhci_up_cachep;	/* urb_priv */
L
Linus Torvalds 已提交
90

91 92
static void suspend_rh(struct uhci_hcd *uhci, enum uhci_rh_state new_state);
static void wakeup_rh(struct uhci_hcd *uhci);
L
Linus Torvalds 已提交
93 94
static void uhci_get_current_frame_number(struct uhci_hcd *uhci);

95 96 97
/*
 * Calculate the link pointer DMA value for the first Skeleton QH in a frame.
 */
98
static __hc32 uhci_frame_skel_link(struct uhci_hcd *uhci, int frame)
99 100 101 102 103 104 105 106 107 108 109 110
{
	int skelnum;

	/*
	 * The interrupt queues will be interleaved as evenly as possible.
	 * There's not much to be done about period-1 interrupts; they have
	 * to occur in every frame.  But we can schedule period-2 interrupts
	 * in odd-numbered frames, period-4 interrupts in frames congruent
	 * to 2 (mod 4), and so on.  This way each frame only has two
	 * interrupt QHs, which will help spread out bandwidth utilization.
	 *
	 * ffs (Find First bit Set) does exactly what we need:
111 112
	 * 1,3,5,...  => ffs = 0 => use period-2 QH = skelqh[8],
	 * 2,6,10,... => ffs = 1 => use period-4 QH = skelqh[7], etc.
113
	 * ffs >= 7 => not on any high-period queue, so use
114
	 *	period-1 QH = skelqh[9].
115 116 117 118 119
	 * Add in UHCI_NUMFRAMES to insure at least one bit is set.
	 */
	skelnum = 8 - (int) __ffs(frame | UHCI_NUMFRAMES);
	if (skelnum <= 1)
		skelnum = 9;
120
	return LINK_TO_QH(uhci, uhci->skelqh[skelnum]);
121 122
}

L
Linus Torvalds 已提交
123 124
#include "uhci-debug.c"
#include "uhci-q.c"
125
#include "uhci-hub.c"
L
Linus Torvalds 已提交
126

127
/*
128
 * Finish up a host controller reset and update the recorded state.
129
 */
130
static void finish_reset(struct uhci_hcd *uhci)
L
Linus Torvalds 已提交
131
{
132 133 134 135 136 137 138
	int port;

	/* HCRESET doesn't affect the Suspend, Reset, and Resume Detect
	 * bits in the port status and control registers.
	 * We have to clear them by hand.
	 */
	for (port = 0; port < uhci->rh_numports; ++port)
139
		uhci_writew(uhci, 0, USBPORTSC1 + (port * 2));
140

141
	uhci->port_c_suspend = uhci->resuming_ports = 0;
142
	uhci->rh_state = UHCI_RH_RESET;
143
	uhci->is_stopped = UHCI_IS_STOPPED;
144
	clear_bit(HCD_FLAG_POLL_RH, &uhci_to_hcd(uhci)->flags);
L
Linus Torvalds 已提交
145 146
}

A
Alan Stern 已提交
147 148
/*
 * Last rites for a defunct/nonfunctional controller
149
 * or one we don't want to use any more.
A
Alan Stern 已提交
150
 */
151
static void uhci_hc_died(struct uhci_hcd *uhci)
A
Alan Stern 已提交
152
{
153
	uhci_get_current_frame_number(uhci);
154
	uhci->reset_hc(uhci);
155
	finish_reset(uhci);
156 157 158 159
	uhci->dead = 1;

	/* The current frame may already be partway finished */
	++uhci->frame_number;
A
Alan Stern 已提交
160 161
}

162
/*
D
David Brownell 已提交
163 164 165
 * Initialize a controller that was newly discovered or has lost power
 * or otherwise been reset while it was suspended.  In none of these cases
 * can we be sure of its previous state.
166 167 168
 */
static void check_and_reset_hc(struct uhci_hcd *uhci)
{
169
	if (uhci->check_and_reset_hc(uhci))
170
		finish_reset(uhci);
171 172
}

173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245
#if defined(CONFIG_USB_UHCI_SUPPORT_NON_PCI_HC)
/*
 * The two functions below are generic reset functions that are used on systems
 * that do not have keyboard and mouse legacy support. We assume that we are
 * running on such a system if CONFIG_USB_UHCI_SUPPORT_NON_PCI_HC is defined.
 */

/*
 * Make sure the controller is completely inactive, unable to
 * generate interrupts or do DMA.
 */
static void uhci_generic_reset_hc(struct uhci_hcd *uhci)
{
	/* Reset the HC - this will force us to get a
	 * new notification of any already connected
	 * ports due to the virtual disconnect that it
	 * implies.
	 */
	uhci_writew(uhci, USBCMD_HCRESET, USBCMD);
	mb();
	udelay(5);
	if (uhci_readw(uhci, USBCMD) & USBCMD_HCRESET)
		dev_warn(uhci_dev(uhci), "HCRESET not completed yet!\n");

	/* Just to be safe, disable interrupt requests and
	 * make sure the controller is stopped.
	 */
	uhci_writew(uhci, 0, USBINTR);
	uhci_writew(uhci, 0, USBCMD);
}

/*
 * Initialize a controller that was newly discovered or has just been
 * resumed.  In either case we can't be sure of its previous state.
 *
 * Returns: 1 if the controller was reset, 0 otherwise.
 */
static int uhci_generic_check_and_reset_hc(struct uhci_hcd *uhci)
{
	unsigned int cmd, intr;

	/*
	 * When restarting a suspended controller, we expect all the
	 * settings to be the same as we left them:
	 *
	 *	Controller is stopped and configured with EGSM set;
	 *	No interrupts enabled except possibly Resume Detect.
	 *
	 * If any of these conditions are violated we do a complete reset.
	 */

	cmd = uhci_readw(uhci, USBCMD);
	if ((cmd & USBCMD_RS) || !(cmd & USBCMD_CF) || !(cmd & USBCMD_EGSM)) {
		dev_dbg(uhci_dev(uhci), "%s: cmd = 0x%04x\n",
				__func__, cmd);
		goto reset_needed;
	}

	intr = uhci_readw(uhci, USBINTR);
	if (intr & (~USBINTR_RESUME)) {
		dev_dbg(uhci_dev(uhci), "%s: intr = 0x%04x\n",
				__func__, intr);
		goto reset_needed;
	}
	return 0;

reset_needed:
	dev_dbg(uhci_dev(uhci), "Performing full reset\n");
	uhci_generic_reset_hc(uhci);
	return 1;
}
#endif /* CONFIG_USB_UHCI_SUPPORT_NON_PCI_HC */

246 247 248 249 250 251
/*
 * Store the basic register settings needed by the controller.
 */
static void configure_hc(struct uhci_hcd *uhci)
{
	/* Set the frame length to the default: 1 ms exactly */
252
	uhci_writeb(uhci, USBSOF_DEFAULT, USBSOF);
253 254

	/* Store the frame list base address */
255
	uhci_writel(uhci, uhci->frame_dma_handle, USBFLBASEADD);
256 257

	/* Set the current frame number */
258 259
	uhci_writew(uhci, uhci->frame_number & UHCI_MAX_SOF_NUMBER,
			USBFRNUM);
260

261 262 263
	/* perform any arch/bus specific configuration */
	if (uhci->configure_hc)
		uhci->configure_hc(uhci);
264 265
}

266
static int resume_detect_interrupts_are_broken(struct uhci_hcd *uhci)
L
Linus Torvalds 已提交
267
{
268 269 270 271 272
	/* If we have to ignore overcurrent events then almost by definition
	 * we can't depend on resume-detect interrupts. */
	if (ignore_oc)
		return 1;

273 274
	return uhci->resume_detect_interrupts_are_broken ?
		uhci->resume_detect_interrupts_are_broken(uhci) : 0;
275 276
}

277
static int global_suspend_mode_is_broken(struct uhci_hcd *uhci)
A
Alan Stern 已提交
278
{
279 280
	return uhci->global_suspend_mode_is_broken ?
		uhci->global_suspend_mode_is_broken(uhci) : 0;
A
Alan Stern 已提交
281 282
}

283
static void suspend_rh(struct uhci_hcd *uhci, enum uhci_rh_state new_state)
284 285 286 287
__releases(uhci->lock)
__acquires(uhci->lock)
{
	int auto_stop;
288
	int int_enable, egsm_enable, wakeup_enable;
289
	struct usb_device *rhdev = uhci_to_hcd(uhci)->self.root_hub;
290 291

	auto_stop = (new_state == UHCI_RH_AUTO_STOPPED);
292
	dev_dbg(&rhdev->dev, "%s%s\n", __func__,
293 294
			(auto_stop ? " (auto-stop)" : ""));

295 296
	/* Start off by assuming Resume-Detect interrupts and EGSM work
	 * and that remote wakeups should be enabled.
297
	 */
A
Alan Stern 已提交
298
	egsm_enable = USBCMD_EGSM;
299
	int_enable = USBINTR_RESUME;
300 301
	wakeup_enable = 1;

302 303 304 305
	/*
	 * In auto-stop mode, we must be able to detect new connections.
	 * The user can force us to poll by disabling remote wakeup;
	 * otherwise we will use the EGSM/RD mechanism.
306 307 308
	 */
	if (auto_stop) {
		if (!device_may_wakeup(&rhdev->dev))
309 310
			egsm_enable = int_enable = 0;
	}
311

312
#ifdef CONFIG_PM
313 314 315 316 317
	/*
	 * In bus-suspend mode, we use the wakeup setting specified
	 * for the root hub.
	 */
	else {
318 319 320
		if (!rhdev->do_remote_wakeup)
			wakeup_enable = 0;
	}
321
#endif
322

323 324 325 326 327 328 329 330 331 332
	/*
	 * UHCI doesn't distinguish between wakeup requests from downstream
	 * devices and local connect/disconnect events.  There's no way to
	 * enable one without the other; both are controlled by EGSM.  Thus
	 * if wakeups are disallowed then EGSM must be turned off -- in which
	 * case remote wakeup requests from downstream during system sleep
	 * will be lost.
	 *
	 * In addition, if EGSM is broken then we can't use it.  Likewise,
	 * if Resume-Detect interrupts are broken then we can't use them.
333
	 *
334 335 336
	 * Finally, neither EGSM nor RD is useful by itself.  Without EGSM,
	 * the RD status bit will never get set.  Without RD, the controller
	 * won't generate interrupts to tell the system about wakeup events.
337
	 */
338 339 340
	if (!wakeup_enable || global_suspend_mode_is_broken(uhci) ||
			resume_detect_interrupts_are_broken(uhci))
		egsm_enable = int_enable = 0;
A
Alan Stern 已提交
341

342
	uhci->RD_enable = !!int_enable;
343 344
	uhci_writew(uhci, int_enable, USBINTR);
	uhci_writew(uhci, egsm_enable | USBCMD_CF, USBCMD);
345
	mb();
346 347 348 349 350 351 352
	udelay(5);

	/* If we're auto-stopping then no devices have been attached
	 * for a while, so there shouldn't be any active URBs and the
	 * controller should stop after a few microseconds.  Otherwise
	 * we will give the controller one frame to stop.
	 */
353
	if (!auto_stop && !(uhci_readw(uhci, USBSTS) & USBSTS_HCH)) {
354 355 356 357
		uhci->rh_state = UHCI_RH_SUSPENDING;
		spin_unlock_irq(&uhci->lock);
		msleep(1);
		spin_lock_irq(&uhci->lock);
358
		if (uhci->dead)
A
Alan Stern 已提交
359
			return;
360
	}
361
	if (!(uhci_readw(uhci, USBSTS) & USBSTS_HCH))
362
		dev_warn(uhci_dev(uhci), "Controller not stopped yet!\n");
L
Linus Torvalds 已提交
363 364

	uhci_get_current_frame_number(uhci);
365 366

	uhci->rh_state = new_state;
L
Linus Torvalds 已提交
367
	uhci->is_stopped = UHCI_IS_STOPPED;
368

369 370 371 372
	/*
	 * If remote wakeup is enabled but either EGSM or RD interrupts
	 * doesn't work, then we won't get an interrupt when a wakeup event
	 * occurs.  Thus the suspended root hub needs to be polled.
373
	 */
374
	if (wakeup_enable && (!int_enable || !egsm_enable))
375 376 377
		set_bit(HCD_FLAG_POLL_RH, &uhci_to_hcd(uhci)->flags);
	else
		clear_bit(HCD_FLAG_POLL_RH, &uhci_to_hcd(uhci)->flags);
L
Linus Torvalds 已提交
378

379
	uhci_scan_schedule(uhci);
A
Alan Stern 已提交
380
	uhci_fsbr_off(uhci);
L
Linus Torvalds 已提交
381 382
}

383 384 385 386 387 388 389
static void start_rh(struct uhci_hcd *uhci)
{
	uhci->is_stopped = 0;

	/* Mark it configured and running with a 64-byte max packet.
	 * All interrupts are enabled, even though RESUME won't do anything.
	 */
390 391 392
	uhci_writew(uhci, USBCMD_RS | USBCMD_CF | USBCMD_MAXP, USBCMD);
	uhci_writew(uhci, USBINTR_TIMEOUT | USBINTR_RESUME |
		USBINTR_IOC | USBINTR_SP, USBINTR);
393
	mb();
394
	uhci->rh_state = UHCI_RH_RUNNING;
395
	set_bit(HCD_FLAG_POLL_RH, &uhci_to_hcd(uhci)->flags);
396 397 398
}

static void wakeup_rh(struct uhci_hcd *uhci)
399 400
__releases(uhci->lock)
__acquires(uhci->lock)
L
Linus Torvalds 已提交
401
{
D
David Brownell 已提交
402
	dev_dbg(&uhci_to_hcd(uhci)->self.root_hub->dev,
403
			"%s%s\n", __func__,
404 405
			uhci->rh_state == UHCI_RH_AUTO_STOPPED ?
				" (auto-start)" : "");
L
Linus Torvalds 已提交
406

407 408 409 410 411
	/* If we are auto-stopped then no devices are attached so there's
	 * no need for wakeup signals.  Otherwise we send Global Resume
	 * for 20 ms.
	 */
	if (uhci->rh_state == UHCI_RH_SUSPENDED) {
412 413 414
		unsigned egsm;

		/* Keep EGSM on if it was set before */
415
		egsm = uhci_readw(uhci, USBCMD) & USBCMD_EGSM;
416
		uhci->rh_state = UHCI_RH_RESUMING;
417
		uhci_writew(uhci, USBCMD_FGR | USBCMD_CF | egsm, USBCMD);
418 419 420
		spin_unlock_irq(&uhci->lock);
		msleep(20);
		spin_lock_irq(&uhci->lock);
421
		if (uhci->dead)
A
Alan Stern 已提交
422
			return;
L
Linus Torvalds 已提交
423

424
		/* End Global Resume and wait for EOP to be sent */
425
		uhci_writew(uhci, USBCMD_CF, USBCMD);
426
		mb();
427
		udelay(4);
428
		if (uhci_readw(uhci, USBCMD) & USBCMD_FGR)
429 430
			dev_warn(uhci_dev(uhci), "FGR not stopped yet!\n");
	}
L
Linus Torvalds 已提交
431

432
	start_rh(uhci);
433

434 435
	/* Restart root hub polling */
	mod_timer(&uhci_to_hcd(uhci)->rh_timer, jiffies);
L
Linus Torvalds 已提交
436 437
}

438
static irqreturn_t uhci_irq(struct usb_hcd *hcd)
439 440 441
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
	unsigned short status;
L
Linus Torvalds 已提交
442 443

	/*
444 445 446
	 * Read the interrupt status, and write it back to clear the
	 * interrupt cause.  Contrary to the UHCI specification, the
	 * "HC Halted" status bit is persistent: it is RO, not R/WC.
L
Linus Torvalds 已提交
447
	 */
448
	status = uhci_readw(uhci, USBSTS);
449 450
	if (!(status & ~USBSTS_HCH))	/* shared interrupt, not mine */
		return IRQ_NONE;
451
	uhci_writew(uhci, status, USBSTS);		/* Clear it */
452

453 454 455 456
	spin_lock(&uhci->lock);
	if (unlikely(!uhci->is_initialized))	/* not yet configured */
		goto done;

457 458
	if (status & ~(USBSTS_USBINT | USBSTS_ERROR | USBSTS_RD)) {
		if (status & USBSTS_HSE)
C
Chen Gang 已提交
459 460
			dev_err(uhci_dev(uhci),
				"host system error, PCI problems?\n");
461
		if (status & USBSTS_HCPE)
C
Chen Gang 已提交
462 463
			dev_err(uhci_dev(uhci),
				"host controller process error, something bad happened!\n");
A
Alan Stern 已提交
464 465 466
		if (status & USBSTS_HCH) {
			if (uhci->rh_state >= UHCI_RH_RUNNING) {
				dev_err(uhci_dev(uhci),
C
Chen Gang 已提交
467
					"host controller halted, very bad!\n");
468 469
				if (debug > 1 && errbuf) {
					/* Print the schedule for debugging */
470 471
					uhci_sprint_schedule(uhci, errbuf,
						ERRBUF_LEN - EXTRA_SPACE);
472 473
					lprintk(errbuf);
				}
474
				uhci_hc_died(uhci);
475
				usb_hc_died(hcd);
476 477 478 479

				/* Force a callback in case there are
				 * pending unlinks */
				mod_timer(&hcd->rh_timer, jiffies);
A
Alan Stern 已提交
480
			}
L
Linus Torvalds 已提交
481 482 483
		}
	}

484 485
	if (status & USBSTS_RD) {
		spin_unlock(&uhci->lock);
486
		usb_hcd_poll_rh_status(hcd);
487
	} else {
488
		uhci_scan_schedule(uhci);
489
 done:
490
		spin_unlock(&uhci->lock);
491
	}
L
Linus Torvalds 已提交
492

493 494
	return IRQ_HANDLED;
}
L
Linus Torvalds 已提交
495

496 497
/*
 * Store the current frame number in uhci->frame_number if the controller
498
 * is running.  Expand from 11 bits (of which we use only 10) to a
499 500 501 502
 * full-sized integer.
 *
 * Like many other parts of the driver, this code relies on being polled
 * more than once per second as long as the controller is running.
503 504 505
 */
static void uhci_get_current_frame_number(struct uhci_hcd *uhci)
{
506 507 508
	if (!uhci->is_stopped) {
		unsigned delta;

509
		delta = (uhci_readw(uhci, USBFRNUM) - uhci->frame_number) &
510 511 512
				(UHCI_NUMFRAMES - 1);
		uhci->frame_number += delta;
	}
L
Linus Torvalds 已提交
513 514 515 516 517 518 519 520 521
}

/*
 * De-allocate all resources
 */
static void release_uhci(struct uhci_hcd *uhci)
{
	int i;

522

523 524 525 526 527
	spin_lock_irq(&uhci->lock);
	uhci->is_initialized = 0;
	spin_unlock_irq(&uhci->lock);

	debugfs_remove(uhci->dentry);
528

L
Linus Torvalds 已提交
529
	for (i = 0; i < UHCI_NUM_SKELQH; i++)
530
		uhci_free_qh(uhci, uhci->skelqh[i]);
L
Linus Torvalds 已提交
531

532
	uhci_free_td(uhci, uhci->term_td);
L
Linus Torvalds 已提交
533

534
	dma_pool_destroy(uhci->qh_pool);
L
Linus Torvalds 已提交
535

536
	dma_pool_destroy(uhci->td_pool);
L
Linus Torvalds 已提交
537

538 539 540 541 542
	kfree(uhci->frame_cpu);

	dma_free_coherent(uhci_dev(uhci),
			UHCI_NUMFRAMES * sizeof(*uhci->frame),
			uhci->frame, uhci->frame_dma_handle);
L
Linus Torvalds 已提交
543 544 545 546 547 548 549
}

/*
 * Allocate a frame list, and then setup the skeleton
 *
 * The hardware doesn't really know any difference
 * in the queues, but the order does matter for the
550 551
 * protocols higher up.  The order in which the queues
 * are encountered by the hardware is:
L
Linus Torvalds 已提交
552
 *
553
 *  - All isochronous events are handled before any
L
Linus Torvalds 已提交
554 555
 *    of the queues. We don't do that here, because
 *    we'll create the actual TD entries on demand.
556 557 558 559 560 561
 *  - The first queue is the high-period interrupt queue.
 *  - The second queue is the period-1 interrupt and async
 *    (low-speed control, full-speed control, then bulk) queue.
 *  - The third queue is the terminating bandwidth reclamation queue,
 *    which contains no members, loops back to itself, and is present
 *    only when FSBR is on and there are no full-speed control or bulk QHs.
L
Linus Torvalds 已提交
562 563 564 565 566
 */
static int uhci_start(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
	int retval = -EBUSY;
567
	int i;
568
	struct dentry __maybe_unused *dentry;
L
Linus Torvalds 已提交
569

570
	hcd->uses_new_polling = 1;
571 572 573
	/* Accept arbitrarily long scatter-gather lists */
	if (!(hcd->driver->flags & HCD_LOCAL_MEM))
		hcd->self.sg_tablesize = ~0;
L
Linus Torvalds 已提交
574 575

	spin_lock_init(&uhci->lock);
576 577
	setup_timer(&uhci->fsbr_timer, uhci_fsbr_timeout,
			(unsigned long) uhci);
578
	INIT_LIST_HEAD(&uhci->idle_qh_list);
L
Linus Torvalds 已提交
579 580
	init_waitqueue_head(&uhci->waitqh);

581 582 583 584 585 586 587
#ifdef UHCI_DEBUG_OPS
	dentry = debugfs_create_file(hcd->self.bus_name,
			S_IFREG|S_IRUGO|S_IWUSR, uhci_debugfs_root,
			uhci, &uhci_debug_operations);
	if (!dentry) {
		dev_err(uhci_dev(uhci), "couldn't create uhci debugfs entry\n");
		return -ENOMEM;
588
	}
589 590
	uhci->dentry = dentry;
#endif
591

592 593 594 595
	uhci->frame = dma_alloc_coherent(uhci_dev(uhci),
			UHCI_NUMFRAMES * sizeof(*uhci->frame),
			&uhci->frame_dma_handle, 0);
	if (!uhci->frame) {
C
Chen Gang 已提交
596 597
		dev_err(uhci_dev(uhci),
			"unable to allocate consistent memory for frame list\n");
598
		goto err_alloc_frame;
L
Linus Torvalds 已提交
599
	}
600
	memset(uhci->frame, 0, UHCI_NUMFRAMES * sizeof(*uhci->frame));
L
Linus Torvalds 已提交
601

602 603 604
	uhci->frame_cpu = kcalloc(UHCI_NUMFRAMES, sizeof(*uhci->frame_cpu),
			GFP_KERNEL);
	if (!uhci->frame_cpu) {
C
Chen Gang 已提交
605 606
		dev_err(uhci_dev(uhci),
			"unable to allocate memory for frame pointers\n");
607 608
		goto err_alloc_frame_cpu;
	}
L
Linus Torvalds 已提交
609 610 611 612 613 614 615 616 617 618 619 620 621 622 623

	uhci->td_pool = dma_pool_create("uhci_td", uhci_dev(uhci),
			sizeof(struct uhci_td), 16, 0);
	if (!uhci->td_pool) {
		dev_err(uhci_dev(uhci), "unable to create td dma_pool\n");
		goto err_create_td_pool;
	}

	uhci->qh_pool = dma_pool_create("uhci_qh", uhci_dev(uhci),
			sizeof(struct uhci_qh), 16, 0);
	if (!uhci->qh_pool) {
		dev_err(uhci_dev(uhci), "unable to create qh dma_pool\n");
		goto err_create_qh_pool;
	}

624
	uhci->term_td = uhci_alloc_td(uhci);
L
Linus Torvalds 已提交
625 626 627 628 629 630
	if (!uhci->term_td) {
		dev_err(uhci_dev(uhci), "unable to allocate terminating TD\n");
		goto err_alloc_term_td;
	}

	for (i = 0; i < UHCI_NUM_SKELQH; i++) {
631
		uhci->skelqh[i] = uhci_alloc_qh(uhci, NULL, NULL);
L
Linus Torvalds 已提交
632 633 634 635 636 637 638
		if (!uhci->skelqh[i]) {
			dev_err(uhci_dev(uhci), "unable to allocate QH\n");
			goto err_alloc_skelqh;
		}
	}

	/*
639
	 * 8 Interrupt queues; link all higher int queues to int1 = async
L
Linus Torvalds 已提交
640
	 */
641
	for (i = SKEL_ISO + 1; i < SKEL_ASYNC; ++i)
642 643 644
		uhci->skelqh[i]->link = LINK_TO_QH(uhci, uhci->skel_async_qh);
	uhci->skel_async_qh->link = UHCI_PTR_TERM(uhci);
	uhci->skel_term_qh->link = LINK_TO_QH(uhci, uhci->skel_term_qh);
L
Linus Torvalds 已提交
645 646

	/* This dummy TD is to work around a bug in Intel PIIX controllers */
647
	uhci_fill_td(uhci, uhci->term_td, 0, uhci_explen(0) |
648
			(0x7f << TD_TOKEN_DEVADDR_SHIFT) | USB_PID_IN, 0);
649
	uhci->term_td->link = UHCI_PTR_TERM(uhci);
650
	uhci->skel_async_qh->element = uhci->skel_term_qh->element =
651
		LINK_TO_TD(uhci, uhci->term_td);
L
Linus Torvalds 已提交
652 653 654 655 656 657 658 659

	/*
	 * Fill the frame list: make all entries point to the proper
	 * interrupt queue.
	 */
	for (i = 0; i < UHCI_NUMFRAMES; i++) {

		/* Only place we don't use the frame list routines */
660
		uhci->frame[i] = uhci_frame_skel_link(uhci, i);
L
Linus Torvalds 已提交
661 662 663 664
	}

	/*
	 * Some architectures require a full mb() to enforce completion of
665
	 * the memory writes above before the I/O transfers in configure_hc().
L
Linus Torvalds 已提交
666 667
	 */
	mb();
668

669
	spin_lock_irq(&uhci->lock);
670
	configure_hc(uhci);
671
	uhci->is_initialized = 1;
672
	start_rh(uhci);
673
	spin_unlock_irq(&uhci->lock);
L
Linus Torvalds 已提交
674 675 676 677 678 679
	return 0;

/*
 * error exits:
 */
err_alloc_skelqh:
680 681
	for (i = 0; i < UHCI_NUM_SKELQH; i++) {
		if (uhci->skelqh[i])
L
Linus Torvalds 已提交
682
			uhci_free_qh(uhci, uhci->skelqh[i]);
683
	}
L
Linus Torvalds 已提交
684 685 686 687 688 689 690 691 692 693

	uhci_free_td(uhci, uhci->term_td);

err_alloc_term_td:
	dma_pool_destroy(uhci->qh_pool);

err_create_qh_pool:
	dma_pool_destroy(uhci->td_pool);

err_create_td_pool:
694 695 696 697 698 699
	kfree(uhci->frame_cpu);

err_alloc_frame_cpu:
	dma_free_coherent(uhci_dev(uhci),
			UHCI_NUMFRAMES * sizeof(*uhci->frame),
			uhci->frame, uhci->frame_dma_handle);
L
Linus Torvalds 已提交
700

701
err_alloc_frame:
L
Linus Torvalds 已提交
702 703 704 705 706 707 708 709 710 711
	debugfs_remove(uhci->dentry);

	return retval;
}

static void uhci_stop(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);

	spin_lock_irq(&uhci->lock);
712
	if (HCD_HW_ACCESSIBLE(hcd) && !uhci->dead)
713
		uhci_hc_died(uhci);
714
	uhci_scan_schedule(uhci);
L
Linus Torvalds 已提交
715
	spin_unlock_irq(&uhci->lock);
716
	synchronize_irq(hcd->irq);
717

718
	del_timer_sync(&uhci->fsbr_timer);
L
Linus Torvalds 已提交
719 720 721 722
	release_uhci(uhci);
}

#ifdef CONFIG_PM
723 724 725
static int uhci_rh_suspend(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
D
David Brownell 已提交
726
	int rc = 0;
727 728

	spin_lock_irq(&uhci->lock);
729
	if (!HCD_HW_ACCESSIBLE(hcd))
D
David Brownell 已提交
730
		rc = -ESHUTDOWN;
731 732 733 734 735 736 737 738 739 740
	else if (uhci->dead)
		;		/* Dead controllers tell no tales */

	/* Once the controller is stopped, port resumes that are already
	 * in progress won't complete.  Hence if remote wakeup is enabled
	 * for the root hub and any ports are in the middle of a resume or
	 * remote wakeup, we must fail the suspend.
	 */
	else if (hcd->self.root_hub->do_remote_wakeup &&
			uhci->resuming_ports) {
C
Chen Gang 已提交
741 742
		dev_dbg(uhci_dev(uhci),
			"suspend failed because a port is resuming\n");
743 744
		rc = -EBUSY;
	} else
A
Alan Stern 已提交
745
		suspend_rh(uhci, UHCI_RH_SUSPENDED);
746
	spin_unlock_irq(&uhci->lock);
D
David Brownell 已提交
747
	return rc;
748 749 750 751 752
}

static int uhci_rh_resume(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
A
Alan Stern 已提交
753
	int rc = 0;
754 755

	spin_lock_irq(&uhci->lock);
756
	if (!HCD_HW_ACCESSIBLE(hcd))
D
David Brownell 已提交
757
		rc = -ESHUTDOWN;
758
	else if (!uhci->dead)
A
Alan Stern 已提交
759
		wakeup_rh(uhci);
760
	spin_unlock_irq(&uhci->lock);
A
Alan Stern 已提交
761
	return rc;
762 763
}

L
Linus Torvalds 已提交
764 765
#endif

766
/* Wait until a particular device/endpoint's QH is idle, and free it */
L
Linus Torvalds 已提交
767
static void uhci_hcd_endpoint_disable(struct usb_hcd *hcd,
768
		struct usb_host_endpoint *hep)
L
Linus Torvalds 已提交
769 770
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
771 772 773 774 775 776
	struct uhci_qh *qh;

	spin_lock_irq(&uhci->lock);
	qh = (struct uhci_qh *) hep->hcpriv;
	if (qh == NULL)
		goto done;
L
Linus Torvalds 已提交
777

778 779 780 781 782 783 784 785 786 787 788 789
	while (qh->state != QH_STATE_IDLE) {
		++uhci->num_waiting;
		spin_unlock_irq(&uhci->lock);
		wait_event_interruptible(uhci->waitqh,
				qh->state == QH_STATE_IDLE);
		spin_lock_irq(&uhci->lock);
		--uhci->num_waiting;
	}

	uhci_free_qh(uhci, qh);
done:
	spin_unlock_irq(&uhci->lock);
L
Linus Torvalds 已提交
790 791 792 793 794
}

static int uhci_hcd_get_frame_number(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
795 796
	unsigned frame_number;
	unsigned delta;
L
Linus Torvalds 已提交
797 798

	/* Minimize latency by avoiding the spinlock */
799 800
	frame_number = uhci->frame_number;
	barrier();
801
	delta = (uhci_readw(uhci, USBFRNUM) - frame_number) &
802 803
			(UHCI_NUMFRAMES - 1);
	return frame_number + delta;
L
Linus Torvalds 已提交
804 805
}

806 807 808 809 810 811
/* Determines number of ports on controller */
static int uhci_count_ports(struct usb_hcd *hcd)
{
	struct uhci_hcd *uhci = hcd_to_uhci(hcd);
	unsigned io_size = (unsigned) hcd->rsrc_len;
	int port;
L
Linus Torvalds 已提交
812

813 814 815 816 817 818 819 820 821 822
	/* The UHCI spec says devices must have 2 ports, and goes on to say
	 * they may have more but gives no way to determine how many there
	 * are.  However according to the UHCI spec, Bit 7 of the port
	 * status and control register is always set to 1.  So we try to
	 * use this to our advantage.  Another common failure mode when
	 * a nonexistent register is addressed is to return all ones, so
	 * we test for that also.
	 */
	for (port = 0; port < (io_size - USBPORTSC1) / 2; port++) {
		unsigned int portstatus;
L
Linus Torvalds 已提交
823

824
		portstatus = uhci_readw(uhci, USBPORTSC1 + (port * 2));
825 826 827 828 829
		if (!(portstatus & 0x0080) || portstatus == 0xffff)
			break;
	}
	if (debug)
		dev_info(uhci_dev(uhci), "detected %d ports\n", port);
L
Linus Torvalds 已提交
830

831 832
	/* Anything greater than 7 is weird so we'll ignore it. */
	if (port > UHCI_RH_MAXCHILD) {
C
Chen Gang 已提交
833 834
		dev_info(uhci_dev(uhci),
			"port count misdetected? forcing to 2 ports\n");
835 836
		port = 2;
	}
L
Linus Torvalds 已提交
837

838 839
	return port;
}
L
Linus Torvalds 已提交
840

841
static const char hcd_name[] = "uhci_hcd";
L
Linus Torvalds 已提交
842

843
#ifdef CONFIG_PCI
844
#include "uhci-pci.c"
845 846
#define	PCI_DRIVER		uhci_pci_driver
#endif
L
Linus Torvalds 已提交
847

848 849 850 851
#ifdef CONFIG_SPARC_LEON
#include "uhci-grlib.c"
#define PLATFORM_DRIVER		uhci_grlib_driver
#endif
L
Linus Torvalds 已提交
852

853 854 855 856 857
#ifdef CONFIG_USB_UHCI_PLATFORM
#include "uhci-platform.c"
#define PLATFORM_DRIVER		uhci_platform_driver
#endif

858 859
#if !defined(PCI_DRIVER) && !defined(PLATFORM_DRIVER)
#error "missing bus glue for uhci-hcd"
860
#endif
L
Linus Torvalds 已提交
861 862 863 864 865 866 867 868

static int __init uhci_hcd_init(void)
{
	int retval = -ENOMEM;

	if (usb_disabled())
		return -ENODEV;

869 870
	printk(KERN_INFO "uhci_hcd: " DRIVER_DESC "%s\n",
			ignore_oc ? ", overcurrent ignored" : "");
871
	set_bit(USB_UHCI_LOADED, &usb_hcds_loaded);
872

873 874 875 876 877 878 879 880
#if defined(DEBUG) || defined(CONFIG_DYNAMIC_DEBUG)
	errbuf = kmalloc(ERRBUF_LEN, GFP_KERNEL);
	if (!errbuf)
		goto errbuf_failed;
	uhci_debugfs_root = debugfs_create_dir("uhci", usb_debug_root);
	if (!uhci_debugfs_root)
		goto debug_failed;
#endif
L
Linus Torvalds 已提交
881 882

	uhci_up_cachep = kmem_cache_create("uhci_urb_priv",
883
		sizeof(struct urb_priv), 0, 0, NULL);
L
Linus Torvalds 已提交
884 885 886
	if (!uhci_up_cachep)
		goto up_failed;

887 888 889 890 891 892 893 894 895 896 897
#ifdef PLATFORM_DRIVER
	retval = platform_driver_register(&PLATFORM_DRIVER);
	if (retval < 0)
		goto clean0;
#endif

#ifdef PCI_DRIVER
	retval = pci_register_driver(&PCI_DRIVER);
	if (retval < 0)
		goto clean1;
#endif
L
Linus Torvalds 已提交
898 899 900

	return 0;

901 902 903 904 905 906 907
#ifdef PCI_DRIVER
clean1:
#endif
#ifdef PLATFORM_DRIVER
	platform_driver_unregister(&PLATFORM_DRIVER);
clean0:
#endif
908
	kmem_cache_destroy(uhci_up_cachep);
L
Linus Torvalds 已提交
909 910

up_failed:
911
#if defined(DEBUG) || defined(CONFIG_DYNAMIC_DEBUG)
L
Linus Torvalds 已提交
912 913 914
	debugfs_remove(uhci_debugfs_root);

debug_failed:
915
	kfree(errbuf);
L
Linus Torvalds 已提交
916 917

errbuf_failed:
918
#endif
L
Linus Torvalds 已提交
919

920
	clear_bit(USB_UHCI_LOADED, &usb_hcds_loaded);
L
Linus Torvalds 已提交
921 922 923 924 925
	return retval;
}

static void __exit uhci_hcd_cleanup(void) 
{
926 927 928 929 930 931
#ifdef PLATFORM_DRIVER
	platform_driver_unregister(&PLATFORM_DRIVER);
#endif
#ifdef PCI_DRIVER
	pci_unregister_driver(&PCI_DRIVER);
#endif
932
	kmem_cache_destroy(uhci_up_cachep);
L
Linus Torvalds 已提交
933
	debugfs_remove(uhci_debugfs_root);
934
#if defined(DEBUG) || defined(CONFIG_DYNAMIC_DEBUG)
935
	kfree(errbuf);
936
#endif
937
	clear_bit(USB_UHCI_LOADED, &usb_hcds_loaded);
L
Linus Torvalds 已提交
938 939 940 941 942 943 944 945
}

module_init(uhci_hcd_init);
module_exit(uhci_hcd_cleanup);

MODULE_AUTHOR(DRIVER_AUTHOR);
MODULE_DESCRIPTION(DRIVER_DESC);
MODULE_LICENSE("GPL");