i.MX31: Add a debug menu to play around with DVFS/DPTC settings for fun, testing...
[kugel-rb.git] / firmware / target / arm / usb-drv-arc.c
blobfc74ce5bf0e0ece350d352c2ef21d37d8eb1649e
1 /***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
10 * Driver for ARC USBOTG Device Controller
12 * Copyright (C) 2007 by Björn Stenberg
14 * This program is free software; you can redistribute it and/or
15 * modify it under the terms of the GNU General Public License
16 * as published by the Free Software Foundation; either version 2
17 * of the License, or (at your option) any later version.
19 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
20 * KIND, either express or implied.
22 ****************************************************************************/
24 #include "system.h"
25 #include "config.h"
26 #include "string.h"
27 #include "usb_ch9.h"
28 #include "usb_core.h"
29 #include "kernel.h"
30 #include "panic.h"
31 #include "usb_drv.h"
33 /*#define LOGF_ENABLE*/
34 #include "logf.h"
36 /* USB device mode registers (Little Endian) */
38 #define REG_ID (*(volatile unsigned int *)(USB_BASE+0x000))
39 #define REG_HWGENERAL (*(volatile unsigned int *)(USB_BASE+0x004))
40 #define REG_HWHOST (*(volatile unsigned int *)(USB_BASE+0x008))
41 #define REG_HWDEVICE (*(volatile unsigned int *)(USB_BASE+0x00c))
42 #define REG_TXBUF (*(volatile unsigned int *)(USB_BASE+0x010))
43 #define REG_RXBUF (*(volatile unsigned int *)(USB_BASE+0x014))
44 #define REG_CAPLENGTH (*(volatile unsigned char*)(USB_BASE+0x100))
45 #define REG_DCIVERSION (*(volatile unsigned int *)(USB_BASE+0x120))
46 #define REG_DCCPARAMS (*(volatile unsigned int *)(USB_BASE+0x124))
47 #define REG_USBCMD (*(volatile unsigned int *)(USB_BASE+0x140))
48 #define REG_USBSTS (*(volatile unsigned int *)(USB_BASE+0x144))
49 #define REG_USBINTR (*(volatile unsigned int *)(USB_BASE+0x148))
50 #define REG_FRINDEX (*(volatile unsigned int *)(USB_BASE+0x14c))
51 #define REG_DEVICEADDR (*(volatile unsigned int *)(USB_BASE+0x154))
52 #define REG_ENDPOINTLISTADDR (*(volatile unsigned int *)(USB_BASE+0x158))
53 #define REG_BURSTSIZE (*(volatile unsigned int *)(USB_BASE+0x160))
54 #define REG_ULPI (*(volatile unsigned int *)(USB_BASE+0x170))
55 #define REG_CONFIGFLAG (*(volatile unsigned int *)(USB_BASE+0x180))
56 #define REG_PORTSC1 (*(volatile unsigned int *)(USB_BASE+0x184))
57 #define REG_OTGSC (*(volatile unsigned int *)(USB_BASE+0x1a4))
58 #define REG_USBMODE (*(volatile unsigned int *)(USB_BASE+0x1a8))
59 #define REG_ENDPTSETUPSTAT (*(volatile unsigned int *)(USB_BASE+0x1ac))
60 #define REG_ENDPTPRIME (*(volatile unsigned int *)(USB_BASE+0x1b0))
61 #define REG_ENDPTFLUSH (*(volatile unsigned int *)(USB_BASE+0x1b4))
62 #define REG_ENDPTSTATUS (*(volatile unsigned int *)(USB_BASE+0x1b8))
63 #define REG_ENDPTCOMPLETE (*(volatile unsigned int *)(USB_BASE+0x1bc))
64 #define REG_ENDPTCTRL0 (*(volatile unsigned int *)(USB_BASE+0x1c0))
65 #define REG_ENDPTCTRL1 (*(volatile unsigned int *)(USB_BASE+0x1c4))
66 #define REG_ENDPTCTRL2 (*(volatile unsigned int *)(USB_BASE+0x1c8))
67 #define REG_ENDPTCTRL(_x_) (*(volatile unsigned int *)(USB_BASE+0x1c0+4*(_x_)))
69 /* Frame Index Register Bit Masks */
70 #define USB_FRINDEX_MASKS (0x3fff)
72 /* USB CMD Register Bit Masks */
73 #define USBCMD_RUN (0x00000001)
74 #define USBCMD_CTRL_RESET (0x00000002)
75 #define USBCMD_PERIODIC_SCHEDULE_EN (0x00000010)
76 #define USBCMD_ASYNC_SCHEDULE_EN (0x00000020)
77 #define USBCMD_INT_AA_DOORBELL (0x00000040)
78 #define USBCMD_ASP (0x00000300)
79 #define USBCMD_ASYNC_SCH_PARK_EN (0x00000800)
80 #define USBCMD_SUTW (0x00002000)
81 #define USBCMD_ATDTW (0x00004000)
82 #define USBCMD_ITC (0x00FF0000)
84 /* bit 15,3,2 are frame list size */
85 #define USBCMD_FRAME_SIZE_1024 (0x00000000)
86 #define USBCMD_FRAME_SIZE_512 (0x00000004)
87 #define USBCMD_FRAME_SIZE_256 (0x00000008)
88 #define USBCMD_FRAME_SIZE_128 (0x0000000C)
89 #define USBCMD_FRAME_SIZE_64 (0x00008000)
90 #define USBCMD_FRAME_SIZE_32 (0x00008004)
91 #define USBCMD_FRAME_SIZE_16 (0x00008008)
92 #define USBCMD_FRAME_SIZE_8 (0x0000800C)
94 /* bit 9-8 are async schedule park mode count */
95 #define USBCMD_ASP_00 (0x00000000)
96 #define USBCMD_ASP_01 (0x00000100)
97 #define USBCMD_ASP_10 (0x00000200)
98 #define USBCMD_ASP_11 (0x00000300)
99 #define USBCMD_ASP_BIT_POS (8)
101 /* bit 23-16 are interrupt threshold control */
102 #define USBCMD_ITC_NO_THRESHOLD (0x00000000)
103 #define USBCMD_ITC_1_MICRO_FRM (0x00010000)
104 #define USBCMD_ITC_2_MICRO_FRM (0x00020000)
105 #define USBCMD_ITC_4_MICRO_FRM (0x00040000)
106 #define USBCMD_ITC_8_MICRO_FRM (0x00080000)
107 #define USBCMD_ITC_16_MICRO_FRM (0x00100000)
108 #define USBCMD_ITC_32_MICRO_FRM (0x00200000)
109 #define USBCMD_ITC_64_MICRO_FRM (0x00400000)
110 #define USBCMD_ITC_BIT_POS (16)
112 /* USB STS Register Bit Masks */
113 #define USBSTS_INT (0x00000001)
114 #define USBSTS_ERR (0x00000002)
115 #define USBSTS_PORT_CHANGE (0x00000004)
116 #define USBSTS_FRM_LST_ROLL (0x00000008)
117 #define USBSTS_SYS_ERR (0x00000010) /* not used */
118 #define USBSTS_IAA (0x00000020)
119 #define USBSTS_RESET (0x00000040)
120 #define USBSTS_SOF (0x00000080)
121 #define USBSTS_SUSPEND (0x00000100)
122 #define USBSTS_HC_HALTED (0x00001000)
123 #define USBSTS_RCL (0x00002000)
124 #define USBSTS_PERIODIC_SCHEDULE (0x00004000)
125 #define USBSTS_ASYNC_SCHEDULE (0x00008000)
127 /* USB INTR Register Bit Masks */
128 #define USBINTR_INT_EN (0x00000001)
129 #define USBINTR_ERR_INT_EN (0x00000002)
130 #define USBINTR_PTC_DETECT_EN (0x00000004)
131 #define USBINTR_FRM_LST_ROLL_EN (0x00000008)
132 #define USBINTR_SYS_ERR_EN (0x00000010)
133 #define USBINTR_ASYN_ADV_EN (0x00000020)
134 #define USBINTR_RESET_EN (0x00000040)
135 #define USBINTR_SOF_EN (0x00000080)
136 #define USBINTR_DEVICE_SUSPEND (0x00000100)
138 /* ULPI Register Bit Masks */
139 #define ULPI_ULPIWU (0x80000000)
140 #define ULPI_ULPIRUN (0x40000000)
141 #define ULPI_ULPIRW (0x20000000)
142 #define ULPI_ULPISS (0x08000000)
143 #define ULPI_ULPIPORT (0x07000000)
144 #define ULPI_ULPIADDR (0x00FF0000)
145 #define ULPI_ULPIDATRD (0x0000FF00)
146 #define ULPI_ULPIDATWR (0x000000FF)
148 /* Device Address bit masks */
149 #define USBDEVICEADDRESS_MASK (0xFE000000)
150 #define USBDEVICEADDRESS_BIT_POS (25)
152 /* endpoint list address bit masks */
153 #define USB_EP_LIST_ADDRESS_MASK (0xfffff800)
155 /* PORTSCX Register Bit Masks */
156 #define PORTSCX_CURRENT_CONNECT_STATUS (0x00000001)
157 #define PORTSCX_CONNECT_STATUS_CHANGE (0x00000002)
158 #define PORTSCX_PORT_ENABLE (0x00000004)
159 #define PORTSCX_PORT_EN_DIS_CHANGE (0x00000008)
160 #define PORTSCX_OVER_CURRENT_ACT (0x00000010)
161 #define PORTSCX_OVER_CURRENT_CHG (0x00000020)
162 #define PORTSCX_PORT_FORCE_RESUME (0x00000040)
163 #define PORTSCX_PORT_SUSPEND (0x00000080)
164 #define PORTSCX_PORT_RESET (0x00000100)
165 #define PORTSCX_LINE_STATUS_BITS (0x00000C00)
166 #define PORTSCX_PORT_POWER (0x00001000)
167 #define PORTSCX_PORT_INDICTOR_CTRL (0x0000C000)
168 #define PORTSCX_PORT_TEST_CTRL (0x000F0000)
169 #define PORTSCX_WAKE_ON_CONNECT_EN (0x00100000)
170 #define PORTSCX_WAKE_ON_CONNECT_DIS (0x00200000)
171 #define PORTSCX_WAKE_ON_OVER_CURRENT (0x00400000)
172 #define PORTSCX_PHY_LOW_POWER_SPD (0x00800000)
173 #define PORTSCX_PORT_FORCE_FULL_SPEED (0x01000000)
174 #define PORTSCX_PORT_SPEED_MASK (0x0C000000)
175 #define PORTSCX_PORT_WIDTH (0x10000000)
176 #define PORTSCX_PHY_TYPE_SEL (0xC0000000)
178 /* bit 11-10 are line status */
179 #define PORTSCX_LINE_STATUS_SE0 (0x00000000)
180 #define PORTSCX_LINE_STATUS_JSTATE (0x00000400)
181 #define PORTSCX_LINE_STATUS_KSTATE (0x00000800)
182 #define PORTSCX_LINE_STATUS_UNDEF (0x00000C00)
183 #define PORTSCX_LINE_STATUS_BIT_POS (10)
185 /* bit 15-14 are port indicator control */
186 #define PORTSCX_PIC_OFF (0x00000000)
187 #define PORTSCX_PIC_AMBER (0x00004000)
188 #define PORTSCX_PIC_GREEN (0x00008000)
189 #define PORTSCX_PIC_UNDEF (0x0000C000)
190 #define PORTSCX_PIC_BIT_POS (14)
192 /* bit 19-16 are port test control */
193 #define PORTSCX_PTC_DISABLE (0x00000000)
194 #define PORTSCX_PTC_JSTATE (0x00010000)
195 #define PORTSCX_PTC_KSTATE (0x00020000)
196 #define PORTSCX_PTC_SE0NAK (0x00030000)
197 #define PORTSCX_PTC_PACKET (0x00040000)
198 #define PORTSCX_PTC_FORCE_EN (0x00050000)
199 #define PORTSCX_PTC_BIT_POS (16)
201 /* bit 27-26 are port speed */
202 #define PORTSCX_PORT_SPEED_FULL (0x00000000)
203 #define PORTSCX_PORT_SPEED_LOW (0x04000000)
204 #define PORTSCX_PORT_SPEED_HIGH (0x08000000)
205 #define PORTSCX_PORT_SPEED_UNDEF (0x0C000000)
206 #define PORTSCX_SPEED_BIT_POS (26)
208 /* bit 28 is parallel transceiver width for UTMI interface */
209 #define PORTSCX_PTW (0x10000000)
210 #define PORTSCX_PTW_8BIT (0x00000000)
211 #define PORTSCX_PTW_16BIT (0x10000000)
213 /* bit 31-30 are port transceiver select */
214 #define PORTSCX_PTS_UTMI (0x00000000)
215 #define PORTSCX_PTS_CLASSIC (0x40000000)
216 #define PORTSCX_PTS_ULPI (0x80000000)
217 #define PORTSCX_PTS_FSLS (0xC0000000)
218 #define PORTSCX_PTS_BIT_POS (30)
220 /* USB MODE Register Bit Masks */
221 #define USBMODE_CTRL_MODE_IDLE (0x00000000)
222 #define USBMODE_CTRL_MODE_DEVICE (0x00000002)
223 #define USBMODE_CTRL_MODE_HOST (0x00000003)
224 #define USBMODE_CTRL_MODE_RSV (0x00000001)
225 #define USBMODE_SETUP_LOCK_OFF (0x00000008)
226 #define USBMODE_STREAM_DISABLE (0x00000010)
228 /* Endpoint Flush Register */
229 #define EPFLUSH_TX_OFFSET (0x00010000)
230 #define EPFLUSH_RX_OFFSET (0x00000000)
232 /* Endpoint Setup Status bit masks */
233 #define EPSETUP_STATUS_MASK (0x0000003F)
234 #define EPSETUP_STATUS_EP0 (0x00000001)
236 /* ENDPOINTCTRLx Register Bit Masks */
237 #define EPCTRL_TX_ENABLE (0x00800000)
238 #define EPCTRL_TX_DATA_TOGGLE_RST (0x00400000) /* Not EP0 */
239 #define EPCTRL_TX_DATA_TOGGLE_INH (0x00200000) /* Not EP0 */
240 #define EPCTRL_TX_TYPE (0x000C0000)
241 #define EPCTRL_TX_DATA_SOURCE (0x00020000) /* Not EP0 */
242 #define EPCTRL_TX_EP_STALL (0x00010000)
243 #define EPCTRL_RX_ENABLE (0x00000080)
244 #define EPCTRL_RX_DATA_TOGGLE_RST (0x00000040) /* Not EP0 */
245 #define EPCTRL_RX_DATA_TOGGLE_INH (0x00000020) /* Not EP0 */
246 #define EPCTRL_RX_TYPE (0x0000000C)
247 #define EPCTRL_RX_DATA_SINK (0x00000002) /* Not EP0 */
248 #define EPCTRL_RX_EP_STALL (0x00000001)
250 /* bit 19-18 and 3-2 are endpoint type */
251 #define EPCTRL_TX_EP_TYPE_SHIFT (18)
252 #define EPCTRL_RX_EP_TYPE_SHIFT (2)
254 /* pri_ctrl Register Bit Masks */
255 #define PRI_CTRL_PRI_LVL1 (0x0000000C)
256 #define PRI_CTRL_PRI_LVL0 (0x00000003)
258 /* si_ctrl Register Bit Masks */
259 #define SI_CTRL_ERR_DISABLE (0x00000010)
260 #define SI_CTRL_IDRC_DISABLE (0x00000008)
261 #define SI_CTRL_RD_SAFE_EN (0x00000004)
262 #define SI_CTRL_RD_PREFETCH_DISABLE (0x00000002)
263 #define SI_CTRL_RD_PREFEFETCH_VAL (0x00000001)
265 /* control Register Bit Masks */
266 #define USB_CTRL_IOENB (0x00000004)
267 #define USB_CTRL_ULPI_INT0EN (0x00000001)
269 /* OTGSC Register Bit Masks */
270 #define OTGSC_B_SESSION_VALID (0x00000800)
271 #define OTGSC_A_VBUS_VALID (0x00000200)
273 #define QH_MULT_POS (30)
274 #define QH_ZLT_SEL (0x20000000)
275 #define QH_MAX_PKT_LEN_POS (16)
276 #define QH_IOS (0x00008000)
277 #define QH_NEXT_TERMINATE (0x00000001)
278 #define QH_IOC (0x00008000)
279 #define QH_MULTO (0x00000C00)
280 #define QH_STATUS_HALT (0x00000040)
281 #define QH_STATUS_ACTIVE (0x00000080)
282 #define EP_QUEUE_CURRENT_OFFSET_MASK (0x00000FFF)
283 #define EP_QUEUE_HEAD_NEXT_POINTER_MASK (0xFFFFFFE0)
284 #define EP_QUEUE_FRINDEX_MASK (0x000007FF)
285 #define EP_MAX_LENGTH_TRANSFER (0x4000)
287 #define DTD_NEXT_TERMINATE (0x00000001)
288 #define DTD_IOC (0x00008000)
289 #define DTD_STATUS_ACTIVE (0x00000080)
290 #define DTD_STATUS_HALTED (0x00000040)
291 #define DTD_STATUS_DATA_BUFF_ERR (0x00000020)
292 #define DTD_STATUS_TRANSACTION_ERR (0x00000008)
293 #define DTD_RESERVED_FIELDS (0x80007300)
294 #define DTD_ADDR_MASK (0xFFFFFFE0)
295 #define DTD_PACKET_SIZE (0x7FFF0000)
296 #define DTD_LENGTH_BIT_POS (16)
297 #define DTD_ERROR_MASK (DTD_STATUS_HALTED | \
298 DTD_STATUS_DATA_BUFF_ERR | \
299 DTD_STATUS_TRANSACTION_ERR)
301 #define DTD_RESERVED_LENGTH_MASK 0x0001ffff
302 #define DTD_RESERVED_IN_USE 0x80000000
303 #define DTD_RESERVED_PIPE_MASK 0x0ff00000
304 #define DTD_RESERVED_PIPE_OFFSET 20
305 /*-------------------------------------------------------------------------*/
307 /* 4 transfer descriptors per endpoint allow 64k transfers, which is the usual MSC
308 transfer size, so it seems like a good size */
309 #define NUM_TDS_PER_EP 4
311 typedef struct usb_endpoint
313 bool allocated[2];
314 short type[2];
315 short max_pkt_size[2];
316 } usb_endpoint_t;
317 static usb_endpoint_t endpoints[USB_NUM_ENDPOINTS];
319 /* manual: 32.13.2 Endpoint Transfer Descriptor (dTD) */
320 struct transfer_descriptor {
321 unsigned int next_td_ptr; /* Next TD pointer(31-5), T(0) set
322 indicate invalid */
323 unsigned int size_ioc_sts; /* Total bytes (30-16), IOC (15),
324 MultO(11-10), STS (7-0) */
325 unsigned int buff_ptr0; /* Buffer pointer Page 0 */
326 unsigned int buff_ptr1; /* Buffer pointer Page 1 */
327 unsigned int buff_ptr2; /* Buffer pointer Page 2 */
328 unsigned int buff_ptr3; /* Buffer pointer Page 3 */
329 unsigned int buff_ptr4; /* Buffer pointer Page 4 */
330 unsigned int reserved;
331 } __attribute__ ((packed));
333 static struct transfer_descriptor td_array[USB_NUM_ENDPOINTS*2*NUM_TDS_PER_EP]
334 USB_DEVBSS_ATTR __attribute__((aligned(32)));
336 /* manual: 32.13.1 Endpoint Queue Head (dQH) */
337 struct queue_head {
338 unsigned int max_pkt_length; /* Mult(31-30) , Zlt(29) , Max Pkt len
339 and IOS(15) */
340 unsigned int curr_dtd_ptr; /* Current dTD Pointer(31-5) */
341 struct transfer_descriptor dtd; /* dTD overlay */
342 unsigned int setup_buffer[2]; /* Setup data 8 bytes */
343 unsigned int reserved; /* for software use, pointer to the first TD */
344 unsigned int status; /* for software use, status of chain in progress */
345 unsigned int length; /* for software use, transfered bytes of chain in progress */
346 unsigned int wait; /* for softwate use, indicates if the transfer is blocking */
347 } __attribute__((packed));
349 static struct queue_head qh_array[USB_NUM_ENDPOINTS*2]
350 USB_QHARRAY_ATTR;
352 static struct wakeup transfer_completion_signal[USB_NUM_ENDPOINTS*2]
353 SHAREDBSS_ATTR;
355 static const unsigned int pipe2mask[] = {
356 0x01, 0x010000,
357 0x02, 0x020000,
358 0x04, 0x040000,
359 0x08, 0x080000,
360 0x10, 0x100000,
363 /*-------------------------------------------------------------------------*/
364 static void transfer_completed(void);
365 static void control_received(void);
366 static int prime_transfer(int ep_num, void* ptr, int len, bool send, bool wait);
367 static void prepare_td(struct transfer_descriptor* td,
368 struct transfer_descriptor* previous_td, void *ptr, int len,int pipe);
369 static void bus_reset(void);
370 static void init_control_queue_heads(void);
371 static void init_queue_heads(void);
372 static void init_endpoints(void);
373 /*-------------------------------------------------------------------------*/
374 static void usb_drv_stop(void)
376 /* disable interrupts */
377 REG_USBINTR = 0;
378 /* stop usb controller (disconnect) */
379 REG_USBCMD &= ~USBCMD_RUN;
382 static void usb_drv_reset(void)
384 int oldlevel = disable_irq_save();
385 REG_USBCMD &= ~USBCMD_RUN;
386 restore_irq(oldlevel);
388 #ifdef USB_PORTSCX_PHY_TYPE
389 /* If a PHY type is specified, set it now */
390 REG_PORTSC1 = (REG_PORTSC1 & ~PORTSCX_PHY_TYPE_SEL) | USB_PORTSCX_PHY_TYPE;
391 #endif
392 sleep(HZ/20);
393 REG_USBCMD |= USBCMD_CTRL_RESET;
394 while (REG_USBCMD & USBCMD_CTRL_RESET);
396 #if CONFIG_CPU == PP5022 || CONFIG_CPU == PP5024
397 /* On a CPU which identifies as a PP5022, this
398 initialization must be done after USB is reset.
400 outl(inl(0x70000060) | 0xF, 0x70000060);
401 outl(inl(0x70000028) | 0x10000, 0x70000028);
402 outl(inl(0x70000028) & ~0x10000, 0x70000028);
403 outl(inl(0x70000060) & ~0x20, 0x70000060);
404 udelay(10);
405 outl(inl(0x70000060) | 0x20, 0x70000060);
406 udelay(10);
407 outl((inl(0x70000060) & ~0xF) | 4, 0x70000060);
408 udelay(10);
409 outl(inl(0x70000060) & ~0x20, 0x70000060);
410 udelay(10);
411 outl(inl(0x70000060) & ~0xF, 0x70000060);
412 udelay(10);
413 outl(inl(0x70000060) | 0x20, 0x70000060);
414 udelay(10);
415 outl(inl(0x70000028) | 0x800, 0x70000028);
416 outl(inl(0x70000028) & ~0x800, 0x70000028);
417 while ((inl(0x70000028) & 0x80) == 0);
418 #endif
421 /* One-time driver startup init */
422 void usb_drv_startup(void)
424 /* Initialize all the signal objects once */
425 int i;
426 for(i=0;i<USB_NUM_ENDPOINTS*2;i++) {
427 wakeup_init(&transfer_completion_signal[i]);
431 /* manual: 32.14.1 Device Controller Initialization */
432 static void _usb_drv_init(bool attach)
434 usb_drv_reset();
436 REG_USBMODE = USBMODE_CTRL_MODE_DEVICE;
438 #ifdef USB_NO_HIGH_SPEED
439 /* Force device to full speed */
440 /* See 32.9.5.9.2 */
441 REG_PORTSC1 |= PORTSCX_PORT_FORCE_FULL_SPEED;
442 #endif
444 init_control_queue_heads();
445 memset(td_array, 0, sizeof td_array);
447 REG_ENDPOINTLISTADDR = (unsigned int)qh_array;
448 REG_DEVICEADDR = 0;
450 if (!attach) {
451 /* enable RESET interrupt */
452 REG_USBINTR = USBINTR_RESET_EN;
454 else
456 /* enable USB interrupts */
457 REG_USBINTR =
458 USBINTR_INT_EN |
459 USBINTR_ERR_INT_EN |
460 USBINTR_PTC_DETECT_EN |
461 USBINTR_RESET_EN;
464 usb_drv_int_enable(true);
466 /* go go go */
467 REG_USBCMD |= USBCMD_RUN;
469 logf("usb_drv_init() finished");
470 logf("usb id %x", REG_ID);
471 logf("usb dciversion %x", REG_DCIVERSION);
472 logf("usb dccparams %x", REG_DCCPARAMS);
474 /* now a bus reset will occur. see bus_reset() */
475 (void)attach;
478 #ifdef LOGF_ENABLE
479 #define XFER_DIR_STR(dir) ((dir) ? "IN" : "OUT")
480 #define XFER_TYPE_STR(type) \
481 ((type) == USB_ENDPOINT_XFER_CONTROL ? "CTRL" : \
482 ((type) == USB_ENDPOINT_XFER_ISOC ? "ISOC" : \
483 ((type) == USB_ENDPOINT_XFER_BULK ? "BULK" : \
484 ((type) == USB_ENDPOINT_XFER_INT ? "INTR" : "INVL"))))
486 static void log_ep(int ep_num, int ep_dir, char* prefix)
488 usb_endpoint_t* endpoint = &endpoints[ep_num];
490 logf("%s: ep%d %s %s %d", prefix, ep_num, XFER_DIR_STR(ep_dir),
491 XFER_TYPE_STR(endpoint->type[ep_dir]),
492 endpoint->max_pkt_size[ep_dir]);
494 #else
495 #undef log_ep
496 #define log_ep(...)
497 #endif
499 void usb_drv_init(void)
501 #ifdef USB_DETECT_BY_CORE
502 /* USB core decides */
503 _usb_drv_init(true);
504 #else
505 /* Use bus reset condition */
506 _usb_drv_init(false);
507 #endif
510 /* fully enable driver */
511 void usb_drv_attach(void)
513 logf("usb_drv_attach");
514 #ifndef USB_DETECT_BY_CORE
515 sleep(HZ/10);
516 _usb_drv_init(true);
517 #endif
520 void usb_drv_exit(void)
522 usb_drv_stop();
524 /* TODO : is one of these needed to save power ?
525 REG_PORTSC1 |= PORTSCX_PHY_LOW_POWER_SPD;
526 REG_USBCMD |= USBCMD_CTRL_RESET;
529 usb_drv_int_enable(false);
532 void usb_drv_int(void)
534 unsigned int usbintr = REG_USBINTR; /* Only watch enabled ints */
535 unsigned int status = REG_USBSTS & usbintr;
537 #if 0
538 if (status & USBSTS_INT) logf("int: usb ioc");
539 if (status & USBSTS_ERR) logf("int: usb err");
540 if (status & USBSTS_PORT_CHANGE) logf("int: portchange");
541 if (status & USBSTS_RESET) logf("int: reset");
542 #endif
544 /* usb transaction interrupt */
545 if (status & USBSTS_INT) {
546 REG_USBSTS = USBSTS_INT;
548 /* a control packet? */
549 if (REG_ENDPTSETUPSTAT & EPSETUP_STATUS_EP0) {
550 control_received();
553 if (REG_ENDPTCOMPLETE)
554 transfer_completed();
557 /* error interrupt */
558 if (status & USBSTS_ERR) {
559 REG_USBSTS = USBSTS_ERR;
560 logf("usb error int");
563 /* reset interrupt */
564 if (status & USBSTS_RESET) {
565 REG_USBSTS = USBSTS_RESET;
567 if (UNLIKELY(usbintr == USBINTR_RESET_EN)) {
568 /* USB detected - detach and inform */
569 usb_drv_stop();
570 usb_drv_usb_detect_event();
572 else
574 bus_reset();
575 usb_core_bus_reset(); /* tell mom */
579 /* port change */
580 if (status & USBSTS_PORT_CHANGE) {
581 REG_USBSTS = USBSTS_PORT_CHANGE;
585 bool usb_drv_stalled(int endpoint,bool in)
587 if(in) {
588 return ((REG_ENDPTCTRL(EP_NUM(endpoint)) & EPCTRL_TX_EP_STALL)!=0);
590 else {
591 return ((REG_ENDPTCTRL(EP_NUM(endpoint)) & EPCTRL_RX_EP_STALL)!=0);
595 void usb_drv_stall(int endpoint, bool stall, bool in)
597 int ep_num = EP_NUM(endpoint);
599 logf("%sstall %d", stall ? "" : "un", ep_num);
601 if(in) {
602 if (stall) {
603 REG_ENDPTCTRL(ep_num) |= EPCTRL_TX_EP_STALL;
605 else {
606 REG_ENDPTCTRL(ep_num) &= ~EPCTRL_TX_EP_STALL;
609 else {
610 if (stall) {
611 REG_ENDPTCTRL(ep_num) |= EPCTRL_RX_EP_STALL;
613 else {
614 REG_ENDPTCTRL(ep_num) &= ~EPCTRL_RX_EP_STALL;
619 int usb_drv_send_nonblocking(int endpoint, void* ptr, int length)
621 return prime_transfer(EP_NUM(endpoint), ptr, length, true, false);
624 int usb_drv_send(int endpoint, void* ptr, int length)
626 return prime_transfer(EP_NUM(endpoint), ptr, length, true, true);
629 int usb_drv_recv(int endpoint, void* ptr, int length)
631 //logf("usbrecv(%x, %d)", ptr, length);
632 return prime_transfer(EP_NUM(endpoint), ptr, length, false, false);
635 int usb_drv_port_speed(void)
637 return (REG_PORTSC1 & 0x08000000) ? 1 : 0;
640 bool usb_drv_connected(void)
642 return (REG_PORTSC1 &
643 (PORTSCX_PORT_SUSPEND | PORTSCX_CURRENT_CONNECT_STATUS))
644 == PORTSCX_CURRENT_CONNECT_STATUS;
647 bool usb_drv_powered(void)
649 /* true = bus 4V4 ok */
650 return (REG_OTGSC & OTGSC_A_VBUS_VALID) ? true : false;
653 void usb_drv_set_address(int address)
655 REG_DEVICEADDR = address << USBDEVICEADDRESS_BIT_POS;
656 init_queue_heads();
657 init_endpoints();
660 void usb_drv_reset_endpoint(int endpoint, bool send)
662 int pipe = EP_NUM(endpoint) * 2 + (send ? 1 : 0);
663 unsigned int mask = pipe2mask[pipe];
664 REG_ENDPTFLUSH = mask;
665 while (REG_ENDPTFLUSH & mask);
668 void usb_drv_set_test_mode(int mode)
670 switch(mode){
671 case 0:
672 REG_PORTSC1 &= ~PORTSCX_PORT_TEST_CTRL;
673 break;
674 case 1:
675 REG_PORTSC1 |= PORTSCX_PTC_JSTATE;
676 break;
677 case 2:
678 REG_PORTSC1 |= PORTSCX_PTC_KSTATE;
679 break;
680 case 3:
681 REG_PORTSC1 |= PORTSCX_PTC_SE0NAK;
682 break;
683 case 4:
684 REG_PORTSC1 |= PORTSCX_PTC_PACKET;
685 break;
686 case 5:
687 REG_PORTSC1 |= PORTSCX_PTC_FORCE_EN;
688 break;
690 usb_drv_reset();
691 REG_USBCMD |= USBCMD_RUN;
694 /*-------------------------------------------------------------------------*/
696 /* manual: 32.14.5.2 */
697 static int prime_transfer(int ep_num, void* ptr, int len, bool send, bool wait)
699 int rc = 0;
700 int pipe = ep_num * 2 + (send ? 1 : 0);
701 unsigned int mask = pipe2mask[pipe];
702 struct queue_head* qh = &qh_array[pipe];
703 static long last_tick;
704 struct transfer_descriptor *new_td, *cur_td, *prev_td;
706 int oldlevel = disable_irq_save();
708 if (send && ep_num > EP_CONTROL) {
709 logf("usb: sent %d bytes", len);
712 qh->status = 0;
713 qh->wait = wait;
715 new_td=&td_array[pipe*NUM_TDS_PER_EP];
716 cur_td=new_td;
717 prev_td=0;
718 int tdlen;
722 tdlen=MIN(len,16384);
723 prepare_td(cur_td, prev_td, ptr, tdlen,pipe);
724 ptr+=tdlen;
725 prev_td=cur_td;
726 cur_td++;
727 len-=tdlen;
729 while(len>0);
730 //logf("starting ep %d %s",ep_num,send?"send":"receive");
732 qh->dtd.next_td_ptr = (unsigned int)new_td;
733 qh->dtd.size_ioc_sts &= ~(QH_STATUS_HALT | QH_STATUS_ACTIVE);
735 REG_ENDPTPRIME |= mask;
737 if(ep_num == EP_CONTROL && (REG_ENDPTSETUPSTAT & EPSETUP_STATUS_EP0)) {
738 /* 32.14.3.2.2 */
739 logf("new setup arrived");
740 rc = -4;
741 goto pt_error;
744 last_tick = current_tick;
745 while ((REG_ENDPTPRIME & mask)) {
746 if (REG_USBSTS & USBSTS_RESET) {
747 rc = -1;
748 goto pt_error;
751 if (TIME_AFTER(current_tick, last_tick + HZ/4)) {
752 logf("prime timeout");
753 rc = -2;
754 goto pt_error;
758 if (!(REG_ENDPTSTATUS & mask)) {
759 if(REG_ENDPTCOMPLETE & mask)
761 logf("endpoint completed fast! %d %d %x", ep_num, pipe, qh->dtd.size_ioc_sts & 0xff);
763 else
765 logf("no prime! %d %d %x", ep_num, pipe, qh->dtd.size_ioc_sts & 0xff);
766 rc = -3;
767 goto pt_error;
770 if(ep_num == EP_CONTROL && (REG_ENDPTSETUPSTAT & EPSETUP_STATUS_EP0)) {
771 /* 32.14.3.2.2 */
772 logf("new setup arrived");
773 rc = -4;
774 goto pt_error;
777 restore_irq(oldlevel);
779 if (wait) {
780 /* wait for transfer to finish */
781 wakeup_wait(&transfer_completion_signal[pipe], TIMEOUT_BLOCK);
782 if(qh->status!=0) {
783 /* No need to cancel wait here since it was done and the signal
784 * came. */
785 return -5;
787 //logf("all tds done");
790 pt_error:
791 if(rc<0)
792 restore_irq(oldlevel);
794 /* Error status must make sure an abandoned wakeup signal isn't left */
795 if (rc < 0 && wait) {
796 /* Cancel wait */
797 qh->wait = 0;
798 /* Make sure to remove any signal if interrupt fired before we zeroed
799 * qh->wait. Could happen during a bus reset for example. */
800 wakeup_wait(&transfer_completion_signal[pipe], TIMEOUT_NOBLOCK);
803 return rc;
806 void usb_drv_cancel_all_transfers(void)
808 int i;
809 REG_ENDPTFLUSH = ~0;
810 while (REG_ENDPTFLUSH);
812 memset(td_array, 0, sizeof td_array);
813 for(i=0;i<USB_NUM_ENDPOINTS*2;i++) {
814 if(qh_array[i].wait) {
815 qh_array[i].wait=0;
816 qh_array[i].status=DTD_STATUS_HALTED;
817 wakeup_signal(&transfer_completion_signal[i]);
822 int usb_drv_request_endpoint(int type, int dir)
824 int ep_num, ep_dir;
825 short ep_type;
827 /* Safety */
828 ep_dir = EP_DIR(dir);
829 ep_type = type & USB_ENDPOINT_XFERTYPE_MASK;
831 logf("req: %s %s", XFER_DIR_STR(ep_dir), XFER_TYPE_STR(ep_type));
833 /* Find an available ep/dir pair */
834 for (ep_num=1;ep_num<USB_NUM_ENDPOINTS;ep_num++) {
835 usb_endpoint_t* endpoint=&endpoints[ep_num];
836 int other_dir=(ep_dir ? 0:1);
838 if (endpoint->allocated[ep_dir])
839 continue;
841 if (endpoint->allocated[other_dir] &&
842 endpoint->type[other_dir] != ep_type) {
843 logf("ep of different type!");
844 continue;
848 endpoint->allocated[ep_dir] = 1;
849 endpoint->type[ep_dir] = ep_type;
851 log_ep(ep_num, ep_dir, "add");
852 return (ep_num | (dir & USB_ENDPOINT_DIR_MASK));
855 return -1;
858 void usb_drv_release_endpoint(int ep)
860 int ep_num = EP_NUM(ep);
861 int ep_dir = EP_DIR(ep);
863 log_ep(ep_num, ep_dir, "rel");
864 endpoints[ep_num].allocated[ep_dir] = 0;
868 static void prepare_td(struct transfer_descriptor* td,
869 struct transfer_descriptor* previous_td,
870 void *ptr, int len,int pipe)
872 //logf("adding a td : %d",len);
873 /* FIXME td allow iso packets per frame override but we don't use it here */
874 memset(td, 0, sizeof(struct transfer_descriptor));
875 td->next_td_ptr = DTD_NEXT_TERMINATE;
876 td->size_ioc_sts = (len<< DTD_LENGTH_BIT_POS) |
877 DTD_STATUS_ACTIVE | DTD_IOC;
878 td->buff_ptr0 = (unsigned int)ptr;
879 td->buff_ptr1 = ((unsigned int)ptr & 0xfffff000) + 0x1000;
880 td->buff_ptr2 = ((unsigned int)ptr & 0xfffff000) + 0x2000;
881 td->buff_ptr3 = ((unsigned int)ptr & 0xfffff000) + 0x3000;
882 td->buff_ptr4 = ((unsigned int)ptr & 0xfffff000) + 0x4000;
883 td->reserved |= DTD_RESERVED_LENGTH_MASK & len;
884 td->reserved |= DTD_RESERVED_IN_USE;
885 td->reserved |= (pipe << DTD_RESERVED_PIPE_OFFSET);
887 if (previous_td != 0) {
888 previous_td->next_td_ptr=(unsigned int)td;
889 previous_td->size_ioc_sts&=~DTD_IOC;
893 static void control_received(void)
895 int i;
896 /* copy setup data from packet */
897 static unsigned int tmp[2];
898 tmp[0] = qh_array[0].setup_buffer[0];
899 tmp[1] = qh_array[0].setup_buffer[1];
901 /* acknowledge packet recieved */
902 REG_ENDPTSETUPSTAT = EPSETUP_STATUS_EP0;
904 /* Stop pending control transfers */
905 for(i=0;i<2;i++) {
906 if(qh_array[i].wait) {
907 qh_array[i].wait=0;
908 qh_array[i].status=DTD_STATUS_HALTED;
909 wakeup_signal(&transfer_completion_signal[i]);
913 usb_core_control_request((struct usb_ctrlrequest*)tmp);
916 static void transfer_completed(void)
918 int ep;
919 unsigned int mask = REG_ENDPTCOMPLETE;
920 REG_ENDPTCOMPLETE = mask;
922 for (ep=0; ep<USB_NUM_ENDPOINTS; ep++) {
923 int dir;
924 for (dir=0; dir<2; dir++) {
925 int pipe = ep * 2 + dir;
926 if (mask & pipe2mask[pipe]) {
927 struct queue_head* qh = &qh_array[pipe];
929 int length=0;
930 struct transfer_descriptor* td=&td_array[pipe*NUM_TDS_PER_EP];
931 while(td!=(struct transfer_descriptor*)DTD_NEXT_TERMINATE && td!=0)
933 /* It seems that the controller sets the pipe bit to one even if the TD
934 * dosn't have the IOC bit set. So we have the rely the active status bit
935 * to check that all the TDs of the transfer are really finished and let
936 * the transfer continue if it's no the case */
937 if(td->size_ioc_sts & DTD_STATUS_ACTIVE)
939 logf("skip half finished transfer");
940 goto Lskip;
942 length += ((td->reserved & DTD_RESERVED_LENGTH_MASK) -
943 ((td->size_ioc_sts & DTD_PACKET_SIZE) >> DTD_LENGTH_BIT_POS));
944 td=(struct transfer_descriptor*) td->next_td_ptr;
946 if(qh->wait) {
947 qh->wait=0;
948 wakeup_signal(&transfer_completion_signal[pipe]);
951 usb_core_transfer_complete(ep, dir?USB_DIR_IN:USB_DIR_OUT,
952 qh->status, length);
953 Lskip:
954 continue;
960 /* manual: 32.14.2.1 Bus Reset */
961 static void bus_reset(void)
963 int i;
964 logf("usb bus_reset");
966 REG_DEVICEADDR = 0;
967 REG_ENDPTSETUPSTAT = REG_ENDPTSETUPSTAT;
968 REG_ENDPTCOMPLETE = REG_ENDPTCOMPLETE;
970 for (i=0; i<100; i++) {
971 if (!REG_ENDPTPRIME)
972 break;
974 if (REG_USBSTS & USBSTS_RESET) {
975 logf("usb: double reset");
976 return;
979 udelay(100);
981 if (REG_ENDPTPRIME) {
982 logf("usb: short reset timeout");
985 usb_drv_cancel_all_transfers();
987 if (!(REG_PORTSC1 & PORTSCX_PORT_RESET)) {
988 logf("usb: slow reset!");
992 /* manual: 32.14.4.1 Queue Head Initialization */
993 static void init_control_queue_heads(void)
995 memset(qh_array, 0, sizeof qh_array);
997 /*** control ***/
998 qh_array[EP_CONTROL].max_pkt_length = 64 << QH_MAX_PKT_LEN_POS | QH_IOS;
999 qh_array[EP_CONTROL].dtd.next_td_ptr = QH_NEXT_TERMINATE;
1000 qh_array[EP_CONTROL+1].max_pkt_length = 64 << QH_MAX_PKT_LEN_POS;
1001 qh_array[EP_CONTROL+1].dtd.next_td_ptr = QH_NEXT_TERMINATE;
1003 /* manual: 32.14.4.1 Queue Head Initialization */
1004 static void init_queue_heads(void)
1006 /* FIXME the packetsize for isochronous transfers is 1023 : 1024 but
1007 * the current code only support one type of packet size so we restrict
1008 * isochronous packet size for now also */
1009 int packetsize = (usb_drv_port_speed() ? 512 : 64);
1010 int i;
1012 /* TODO: this should take ep_allocation into account */
1013 for (i=1;i<USB_NUM_ENDPOINTS;i++) {
1015 /* OUT */
1016 if(endpoints[i].type[DIR_OUT] == USB_ENDPOINT_XFER_ISOC)
1017 /* FIXME: we can adjust the number of packets per frame, currently use one */
1018 qh_array[i*2].max_pkt_length = packetsize << QH_MAX_PKT_LEN_POS | QH_ZLT_SEL | 1 << QH_MULT_POS;
1019 else
1020 qh_array[i*2].max_pkt_length = packetsize << QH_MAX_PKT_LEN_POS | QH_ZLT_SEL;
1022 qh_array[i*2].dtd.next_td_ptr = QH_NEXT_TERMINATE;
1024 /* IN */
1025 if(endpoints[i].type[DIR_IN] == USB_ENDPOINT_XFER_ISOC)
1026 /* FIXME: we can adjust the number of packets per frame, currently use one */
1027 qh_array[i*2+1].max_pkt_length = packetsize << QH_MAX_PKT_LEN_POS | QH_ZLT_SEL | 1 << QH_MULT_POS;
1028 else
1029 qh_array[i*2+1].max_pkt_length = packetsize << QH_MAX_PKT_LEN_POS | QH_ZLT_SEL;
1031 qh_array[i*2+1].dtd.next_td_ptr = QH_NEXT_TERMINATE;
1035 static void init_endpoints(void)
1037 int ep_num;
1039 logf("init_endpoints");
1040 /* RX/TX from the device POV: OUT/IN, respectively */
1041 for(ep_num=1;ep_num<USB_NUM_ENDPOINTS;ep_num++) {
1042 usb_endpoint_t *endpoint = &endpoints[ep_num];
1044 /* manual: 32.9.5.18 (Caution): Leaving an unconfigured endpoint control
1045 * will cause undefined behavior for the data pid tracking on the active
1046 * endpoint/direction. */
1047 if (!endpoint->allocated[DIR_OUT])
1048 endpoint->type[DIR_OUT] = USB_ENDPOINT_XFER_BULK;
1049 if (!endpoint->allocated[DIR_IN])
1050 endpoint->type[DIR_IN] = USB_ENDPOINT_XFER_BULK;
1052 REG_ENDPTCTRL(ep_num) =
1053 EPCTRL_RX_DATA_TOGGLE_RST | EPCTRL_RX_ENABLE |
1054 EPCTRL_TX_DATA_TOGGLE_RST | EPCTRL_TX_ENABLE |
1055 (endpoint->type[DIR_OUT] << EPCTRL_RX_EP_TYPE_SHIFT) |
1056 (endpoint->type[DIR_IN] << EPCTRL_TX_EP_TYPE_SHIFT);