2 * Universal Host Controller Interface driver for USB.
4 * Maintainer: Alan Stern <stern@rowland.harvard.edu>
6 * (C) Copyright 1999 Linus Torvalds
7 * (C) Copyright 1999-2002 Johannes Erdfelt, johannes@erdfelt.com
8 * (C) Copyright 1999 Randy Dunlap
9 * (C) Copyright 1999 Georg Acher, acher@in.tum.de
10 * (C) Copyright 1999 Deti Fliegl, deti@fliegl.de
11 * (C) Copyright 1999 Thomas Sailer, sailer@ife.ee.ethz.ch
12 * (C) Copyright 2004 Alan Stern, stern@rowland.harvard.edu
15 static __u8 root_hub_hub_des[] =
17 0x09, /* __u8 bLength; */
18 0x29, /* __u8 bDescriptorType; Hub-descriptor */
19 0x02, /* __u8 bNbrPorts; */
20 0x0a, /* __u16 wHubCharacteristics; */
21 0x00, /* (per-port OC, no power switching) */
22 0x01, /* __u8 bPwrOn2pwrGood; 2ms */
23 0x00, /* __u8 bHubContrCurrent; 0 mA */
24 0x00, /* __u8 DeviceRemovable; *** 7 Ports max *** */
25 0xff /* __u8 PortPwrCtrlMask; *** 7 ports max *** */
28 #define UHCI_RH_MAXCHILD 7
30 /* must write as zeroes */
31 #define WZ_BITS (USBPORTSC_RES2 | USBPORTSC_RES3 | USBPORTSC_RES4)
33 /* status change bits: nonzero writes will clear */
34 #define RWC_BITS (USBPORTSC_OCC | USBPORTSC_PEC | USBPORTSC_CSC)
36 static int uhci_hub_status_data(struct usb_hcd *hcd, char *buf)
38 struct uhci_hcd *uhci = hcd_to_uhci(hcd);
42 for (port = 0; port < uhci->rh_numports; ++port) {
43 if ((inw(uhci->io_addr + USBPORTSC1 + port * 2) & RWC_BITS) ||
44 test_bit(port, &uhci->port_c_suspend))
45 *buf |= (1 << (port + 1));
47 if (*buf && uhci->state == UHCI_SUSPENDED)
48 uhci->resume_detect = 1;
52 #define OK(x) len = (x); break
54 #define CLR_RH_PORTSTAT(x) \
55 status = inw(port_addr); \
56 status &= ~(RWC_BITS|WZ_BITS); \
58 status |= RWC_BITS & (x); \
59 outw(status, port_addr)
61 #define SET_RH_PORTSTAT(x) \
62 status = inw(port_addr); \
64 status &= ~(RWC_BITS|WZ_BITS); \
65 outw(status, port_addr)
67 /* UHCI controllers don't automatically stop resume signalling after 20 msec,
68 * so we have to poll and check timeouts in order to take care of it.
70 static void uhci_finish_suspend(struct uhci_hcd *uhci, int port,
71 unsigned long port_addr)
75 if (test_bit(port, &uhci->suspended_ports)) {
76 CLR_RH_PORTSTAT(USBPORTSC_SUSP | USBPORTSC_RD);
77 clear_bit(port, &uhci->suspended_ports);
78 clear_bit(port, &uhci->resuming_ports);
79 set_bit(port, &uhci->port_c_suspend);
81 /* The controller won't actually turn off the RD bit until
82 * it has had a chance to send a low-speed EOP sequence,
83 * which takes 3 bit times (= 2 microseconds). We'll delay
84 * slightly longer for good luck. */
89 /* Wait for the UHCI controller in HP's iLO2 server management chip.
90 * It can take up to 250 us to finish a reset and set the CSC bit.
92 static void wait_for_HP(unsigned long port_addr)
96 for (i = 10; i < 250; i += 10) {
97 if (inw(port_addr) & USBPORTSC_CSC)
104 static void uhci_check_ports(struct uhci_hcd *uhci)
107 unsigned long port_addr;
110 for (port = 0; port < uhci->rh_numports; ++port) {
111 port_addr = uhci->io_addr + USBPORTSC1 + 2 * port;
112 status = inw(port_addr);
113 if (unlikely(status & USBPORTSC_PR)) {
114 if (time_after_eq(jiffies, uhci->ports_timeout)) {
115 CLR_RH_PORTSTAT(USBPORTSC_PR);
117 /* HP's server management chip requires
119 if (to_pci_dev(uhci_dev(uhci))->vendor ==
121 wait_for_HP(port_addr);
123 /* If the port was enabled before, turning
124 * reset on caused a port enable change.
125 * Turning reset off causes a port connect
126 * status change. Clear these changes. */
127 CLR_RH_PORTSTAT(USBPORTSC_CSC | USBPORTSC_PEC);
128 SET_RH_PORTSTAT(USBPORTSC_PE);
131 if (unlikely(status & USBPORTSC_RD)) {
132 if (!test_bit(port, &uhci->resuming_ports)) {
134 /* Port received a wakeup request */
135 set_bit(port, &uhci->resuming_ports);
136 uhci->ports_timeout = jiffies +
137 msecs_to_jiffies(20);
138 } else if (time_after_eq(jiffies,
139 uhci->ports_timeout)) {
140 uhci_finish_suspend(uhci, port, port_addr);
146 /* size of returned buffer is part of USB spec */
147 static int uhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue,
148 u16 wIndex, char *buf, u16 wLength)
150 struct uhci_hcd *uhci = hcd_to_uhci(hcd);
151 int status, lstatus, retval = 0, len = 0;
152 unsigned int port = wIndex - 1;
153 unsigned long port_addr = uhci->io_addr + USBPORTSC1 + 2 * port;
154 u16 wPortChange, wPortStatus;
157 spin_lock_irqsave(&uhci->lock, flags);
161 *(__le32 *)buf = cpu_to_le32(0);
162 OK(4); /* hub power */
164 if (port >= uhci->rh_numports)
167 uhci_check_ports(uhci);
168 status = inw(port_addr);
170 /* Intel controllers report the OverCurrent bit active on.
171 * VIA controllers report it active off, so we'll adjust the
172 * bit value. (It's not standardized in the UHCI spec.)
174 if (to_pci_dev(hcd->self.controller)->vendor ==
176 status ^= USBPORTSC_OC;
178 /* UHCI doesn't support C_RESET (always false) */
179 wPortChange = lstatus = 0;
180 if (status & USBPORTSC_CSC)
181 wPortChange |= USB_PORT_STAT_C_CONNECTION;
182 if (status & USBPORTSC_PEC)
183 wPortChange |= USB_PORT_STAT_C_ENABLE;
184 if (status & USBPORTSC_OCC)
185 wPortChange |= USB_PORT_STAT_C_OVERCURRENT;
187 if (test_bit(port, &uhci->port_c_suspend)) {
188 wPortChange |= USB_PORT_STAT_C_SUSPEND;
191 if (test_bit(port, &uhci->suspended_ports))
193 if (test_bit(port, &uhci->resuming_ports))
196 /* UHCI has no power switching (always on) */
197 wPortStatus = USB_PORT_STAT_POWER;
198 if (status & USBPORTSC_CCS)
199 wPortStatus |= USB_PORT_STAT_CONNECTION;
200 if (status & USBPORTSC_PE) {
201 wPortStatus |= USB_PORT_STAT_ENABLE;
202 if (status & (USBPORTSC_SUSP | USBPORTSC_RD))
203 wPortStatus |= USB_PORT_STAT_SUSPEND;
205 if (status & USBPORTSC_OC)
206 wPortStatus |= USB_PORT_STAT_OVERCURRENT;
207 if (status & USBPORTSC_PR)
208 wPortStatus |= USB_PORT_STAT_RESET;
209 if (status & USBPORTSC_LSDA)
210 wPortStatus |= USB_PORT_STAT_LOW_SPEED;
213 dev_dbg(uhci_dev(uhci), "port %d portsc %04x,%02x\n",
214 wIndex, status, lstatus);
216 *(__le16 *)buf = cpu_to_le16(wPortStatus);
217 *(__le16 *)(buf + 2) = cpu_to_le16(wPortChange);
219 case SetHubFeature: /* We don't implement these */
220 case ClearHubFeature:
222 case C_HUB_OVER_CURRENT:
223 case C_HUB_LOCAL_POWER:
230 if (port >= uhci->rh_numports)
234 case USB_PORT_FEAT_SUSPEND:
235 set_bit(port, &uhci->suspended_ports);
236 SET_RH_PORTSTAT(USBPORTSC_SUSP);
238 case USB_PORT_FEAT_RESET:
239 SET_RH_PORTSTAT(USBPORTSC_PR);
241 /* Reset terminates Resume signalling */
242 uhci_finish_suspend(uhci, port, port_addr);
244 /* USB v2.0 7.1.7.5 */
245 uhci->ports_timeout = jiffies + msecs_to_jiffies(50);
247 case USB_PORT_FEAT_POWER:
248 /* UHCI has no power switching */
254 case ClearPortFeature:
255 if (port >= uhci->rh_numports)
259 case USB_PORT_FEAT_ENABLE:
260 CLR_RH_PORTSTAT(USBPORTSC_PE);
262 /* Disable terminates Resume signalling */
263 uhci_finish_suspend(uhci, port, port_addr);
265 case USB_PORT_FEAT_C_ENABLE:
266 CLR_RH_PORTSTAT(USBPORTSC_PEC);
268 case USB_PORT_FEAT_SUSPEND:
269 if (test_bit(port, &uhci->suspended_ports) &&
270 !test_and_set_bit(port,
271 &uhci->resuming_ports)) {
272 SET_RH_PORTSTAT(USBPORTSC_RD);
274 /* The controller won't allow RD to be set
275 * if the port is disabled. When this happens
276 * just skip the Resume signalling.
278 if (!(inw(port_addr) & USBPORTSC_RD))
279 uhci_finish_suspend(uhci, port,
282 /* USB v2.0 7.1.7.7 */
283 uhci->ports_timeout = jiffies +
284 msecs_to_jiffies(20);
287 case USB_PORT_FEAT_C_SUSPEND:
288 clear_bit(port, &uhci->port_c_suspend);
290 case USB_PORT_FEAT_POWER:
291 /* UHCI has no power switching */
293 case USB_PORT_FEAT_C_CONNECTION:
294 CLR_RH_PORTSTAT(USBPORTSC_CSC);
296 case USB_PORT_FEAT_C_OVER_CURRENT:
297 CLR_RH_PORTSTAT(USBPORTSC_OCC);
299 case USB_PORT_FEAT_C_RESET:
300 /* this driver won't report these */
306 case GetHubDescriptor:
307 len = min_t(unsigned int, sizeof(root_hub_hub_des), wLength);
308 memcpy(buf, root_hub_hub_des, len);
310 buf[2] = uhci->rh_numports;
316 spin_unlock_irqrestore(&uhci->lock, flags);