A bit number was mistakenly used instead of a flag when setting notification
[AROS.git] / rom / usb / pciusbhc / ehci / pciehci_hci.h
blobfc347094df044467df878bb65527b0aef639a119
1 /*
2 Copyright © 2011, The AROS Development Team. All rights reserved
3 $Id$
4 */
6 #ifndef PCIEHCI_HC_H
7 #define PCIEHCI_HC_H
9 /*
10 *----------------------------------------------------------------------------
11 * Includes for EHCI USB Controller
12 *----------------------------------------------------------------------------
13 * By Chris Hodges <chrisly@platon42.de>
16 #undef SYNC
17 #ifdef __powerpc__
18 #define SYNC asm volatile("eieio");
19 #else
20 #define SYNC
21 #endif
23 #define READMEM16_LE(rb) AROS_WORD2LE(*((volatile UWORD *) (rb)))
24 #define READMEM32_LE(rb) AROS_LONG2LE(*((volatile ULONG *) (rb)))
25 #define WRITEMEM32_LE(adr, value) *((volatile ULONG *) (adr)) = AROS_LONG2LE(value)
26 #define CONSTWRITEMEM32_LE(adr, value) *((volatile ULONG *) (adr)) = AROS_LONG2LE(value)
28 #define CONSTWRITEREG16_LE(rb, offset, value) *((volatile UWORD *) (((UBYTE *) (rb)) + ((ULONG) (offset)))) = AROS_WORD2LE(value)
29 #define CONSTWRITEREG32_LE(rb, offset, value) *((volatile ULONG *) (((UBYTE *) (rb)) + ((ULONG) (offset)))) = AROS_LONG2LE(value)
30 #define WRITEREG16_LE(rb, offset, value) *((volatile UWORD *) (((UBYTE *) (rb)) + ((ULONG) (offset)))) = AROS_WORD2LE(value)
31 #define WRITEREG32_LE(rb, offset, value) *((volatile ULONG *) (((UBYTE *) (rb)) + ((ULONG) (offset)))) = AROS_LONG2LE(value)
32 #define WRITEREG64_LE(rb, offset, value) *((volatile UQUAD *) (((UBYTE *) (rb)) + ((ULONG) (offset)))) = AROS_QUAD2LE(value)
34 #define READREG16_LE(rb, offset) AROS_WORD2LE(*((volatile UWORD *) (((UBYTE *) (rb)) + ((ULONG) (offset)))))
35 #define READREG32_LE(rb, offset) AROS_LONG2LE(*((volatile ULONG *) (((UBYTE *) (rb)) + ((ULONG) (offset)))))
36 #define READREG64_LE(rb, offset) AROS_QUAD2LE(*((volatile UQUAD *) (((UBYTE *) (rb)) + ((ULONG) (offset)))))
38 #define READIO16_LE(rb, offset) AROS_WORD2LE(WORDIN((((UBYTE *) (rb)) + ((ULONG) (offset)))))
39 #define WRITEIO16_LE(rb, offset, value) WORDOUT((((UBYTE *) (rb)) + ((ULONG) (offset))), AROS_WORD2LE(value))
40 #define WRITEIO32_LE(rb, offset, value) LONGOUT((((UBYTE *) (rb)) + ((ULONG) (offset))), AROS_WORD2LE(value))
42 /* Macros to swap bit defines, constants & variables */
43 #define SWB(x) ((x+16) & 31)
44 #define SWC(x) ((x>>16)|((x & 0xffff)<<16))
45 #define SWW(x) ((x>>16)|(x<<16))
46 #define L2U(x) (x<<16)
47 #define U2L(x) (x>>16)
49 #define PID_IN 0x69
50 #define PID_OUT 0xe1
51 #define PID_SETUP 0x2d
54 * --------------------- EHCI registers ------------------------
55 * Warning: These are BYTE offsets!
58 #define EHCI_CAPLENGTH 0x000 /* Offset for operational registers */
59 #define EHCI_HCIVERSION 0x002 /* HC Version Number */
60 #define EHCI_HCSPARAMS 0x004 /* HC Structural Parameters */
61 #define EHCI_HCCPARAMS 0x008 /* HC Capability Parameters */
62 #define EHCI_HCSPPORTROUTE 0x00c /* HC Companion Port Route Description */
64 /* EHCI_HCSPARAMS defines */
65 #define EHSB_PORTPOWERCTRL 4 /* Support for Port Power Control */
66 #define EHSB_EXTPORTROUTING 7 /* Routing to companion ports via HCSSPORTROUTE array */
67 #define EHSB_PORTINDICATORS 16 /* Support for Port Indicators */
69 #define EHSS_NUM_PORTS 0 /* Number of ports */
70 #define EHSS_PORTS_PER_COMP 8 /* Ports per companion controller */
71 #define EHSS_NUM_COMPANIONS 12 /* Number of companion controllers */
73 #define EHSF_PORTPOWERCTRL (1UL<<EHSB_PORTPOWERCTRL)
74 #define EHSF_EXTPORTROUTING (1UL<<EHSB_EXTPORTROUTING)
75 #define EHSF_PORTINDICATORS (1UL<<EHSB_PORTINDICATORS)
77 #define EHSM_NUM_PORTS (((1UL<<4)-1)<<EHSS_NUM_PORTS)
78 #define EHSM_PORTS_PER_COMP (((1UL<<4)-1)<<EHSS_PORTS_PER_COMP)
79 #define EHSM_NUM_COMPANIONS (((1UL<<4)-1)<<EHSS_NUM_COMPANIONS)
81 /* EHCI_HCCPARAMS defines */
82 #define EHCB_64BITS 0 /* Use 64 Bit pointers and structures */
83 #define EHCB_PROGFRAMELIST 1 /* Programmable Frame list size */
84 #define EHCB_ASYNCSCHEDPARK 2 /* Park feature for highspeed QH supported */
85 #define EHCS_EXTCAPOFFSET 8 /* Offset to extended capabilities registers */
87 #define EHCF_64BITS (1UL<<EHCB_64BITS)
88 #define EHCF_PROGFRAMELIST (1UL<<EHCB_PROGFRAMELIST)
89 #define EHCF_ASYNCSCHEDPARK (1UL<<EHCB_ASYNCSCHEDPARK)
90 #define EHCM_EXTCAPOFFSET (((1UL<<8)-1)<<EHCS_EXTCAPOFFSET)
92 /* Operational Registers */
93 #define EHCI_USBCMD 0x000 /* USB Command (r/w) */
94 #define EHCI_USBSTATUS 0x004 /* USB Status (r/wc) */
95 #define EHCI_USBINTEN 0x008 /* USB Interrupt enable (r/w) */
96 #define EHCI_FRAMECOUNT 0x00c /* Frame Number (r/w) */
97 #define EHCI_CTRLDSSEGMENT 0x010 /* Upper 32 bits in 64 Bit mode */
98 #define EHCI_PERIODICLIST 0x014 /* Periodic Frame List Base Address Register (4K aligned) */
99 #define EHCI_ASYNCADDR 0x018 /* Asynchronous List Address Register (32 byte aligned) */
100 #define EHCI_CONFIGFLAG 0x040 /* Configure flag (r/w) */
101 #define EHCI_PORTSC1 0x044 /* Port Status & Control 1 (r/w) */
103 /* EHCI_USBCMD defines */
104 #define EHUB_RUNSTOP 0 /* 1=Run, 0=Stop */
105 #define EHUB_HCRESET 1 /* Host Controller Reset */
106 #define EHUB_PERIODICENABLE 4 /* Enable Periodic Schedule */
107 #define EHUB_ASYNCENABLE 5 /* Enable Async Schedule */
108 #define EHUB_ASYNCDOORBELL 6 /* Cause interrupt on next Async schedule advance */
109 #define EHUB_LIGHTHCRESET 7 /* Light Host Controller Reset */
110 #define EHUB_ASYNCSCHEDPARK 11 /* Park Asynchroneous schedule */
112 #define EHUS_FRAMELISTSIZE 2 /* Size of framelist (divisor) */
113 #define EHUS_ASYNCPARKCOUNT 8 /* Number of successive transactions before continuing async */
114 #define EHUS_INTTHRESHOLD 16 /* Interrupt threshold control */
116 #define EHUF_RUNSTOP (1UL<<EHUB_RUNSTOP)
117 #define EHUF_HCRESET (1UL<<EHUB_HCRESET)
118 #define EHUF_PERIODICENABLE (1UL<<EHUB_PERIODICENABLE)
119 #define EHUF_ASYNCENABLE (1UL<<EHUB_ASYNCENABLE)
120 #define EHUF_ASYNCDOORBELL (1UL<<EHUB_ASYNCDOORBELL)
121 #define EHUF_LIGHTHCRESET (1UL<<EHUB_LIGHTHCRESET)
122 #define EHUF_ASYNCSCHEDPARK (1UL<<EHUB_ASYNCSCHEDPARK)
124 #define EHUM_FRAMELISTSIZE (((1UL<<2)-1)<<EHUS_FRAMELISTSIZE)
125 #define EHUM_ASYNCPARKCOUNT (((1UL<<2)-1)<<EHUS_ASYNCPARKCOUNT)
126 #define EHUM_INTTHRESHOLD (((1UL<<8)-1)<<EHUS_INTTHRESHOLD)
128 /* EHCI_USBSTS and EHCI_USBINTEN (0-5) defines */
129 #define EHSB_TDDONE 0 /* Transfer descriptor done */
130 #define EHSB_TDERROR 1 /* Some TD has errored */
131 #define EHSB_PORTCHANGED 2 /* Port Change detected */
132 #define EHSB_FRAMECOUNTOVER 3 /* Frame List Rollover */
133 #define EHSB_HOSTERROR 4 /* Host System Error */
134 #define EHSB_ASYNCADVANCE 5 /* Async Schedule has advanced */
135 #define EHSB_HCHALTED 12 /* Host controller halted */
136 #define EHSB_RECLAMATION 13 /* Empty asynchrous schedule */
137 #define EHSB_PERIODICACTIVE 14 /* Periodic schedule is running */
138 #define EHSB_ASYNCACTIVE 15 /* Async schedule is running */
140 #define EHSF_TDDONE (1UL<<EHSB_TDDONE)
141 #define EHSF_TDERROR (1UL<<EHSB_TDERROR)
142 #define EHSF_PORTCHANGED (1UL<<EHSB_PORTCHANGED)
143 #define EHSF_FRAMECOUNTOVER (1UL<<EHSB_FRAMECOUNTOVER)
144 #define EHSF_HOSTERROR (1UL<<EHSB_HOSTERROR)
145 #define EHSF_ASYNCADVANCE (1UL<<EHSB_ASYNCADVANCE)
146 #define EHSF_HCHALTED (1UL<<EHSB_HCHALTED)
147 #define EHSF_RECLAMATION (1UL<<EHSB_RECLAMATION)
148 #define EHSF_PERIODICACTIVE (1UL<<EHSB_PERIODICACTIVE)
149 #define EHSF_ASYNCACTIVE (1UL<<EHSB_ASYNCACTIVE)
151 #define EHSF_ALL_INTS (EHSF_TDDONE|EHSF_TDERROR|EHSF_PORTCHANGED|EHSF_FRAMECOUNTOVER|EHSF_HOSTERROR|EHSF_ASYNCADVANCE)
153 /* EHCI_CONFIGFLAG defines */
154 #define EHCB_CONFIGURED 0
155 #define EHCF_CONFIGURED (1UL<<EHCB_CONFIGURED)
157 /* EHCI_PORTSC defines */
158 #define EHPB_PORTCONNECTED 0 /* Port Connection status */
159 #define EHPB_CONNECTCHANGE 1 /* Port Connection change */
160 #define EHPB_PORTENABLE 2 /* Enable Port */
161 #define EHPB_ENABLECHANGE 3 /* Port eanbled status changed */
162 #define EHPB_OVERCURRENT 4 /* OVer current condition detected */
163 #define EHPB_OVERCURRENTCHG 5 /* Over current condition changed */
164 #define EHPB_RESUMEDTX 6 /* Resume detected */
165 #define EHPB_PORTSUSPEND 7 /* Port is suspended */
166 #define EHPB_PORTRESET 8 /* Port is in reset state */
167 #define EHPB_LINESTATUS_DM 10 /* Line Status D- */
168 #define EHPB_LINESTATUS_DP 11 /* Line Stauts D+ */
169 #define EHPB_PORTPOWER 12 /* Depends on PortPowerControl */
170 #define EHPB_NOTPORTOWNER 13 /* Inverse of CONFIGURED (0=Owner) */
171 #define EHPB_WAKECONNECT 20 /* Wake on Connect */
172 #define EHPB_WAKEDISCONNECT 21 /* Wake on Disconnect */
173 #define EHPB_WAKEOCENABLE 22 /* Wake on Over Current Condition */
175 #define EHPS_PORTINDICATOR 14 /* Port indicator leds (0=off, 1=amber, 2=green) */
177 #define EHPF_PORTCONNECTED (1UL<<EHPB_PORTCONNECTED)
178 #define EHPF_CONNECTCHANGE (1UL<<EHPB_CONNECTCHANGE)
179 #define EHPF_PORTENABLE (1UL<<EHPB_PORTENABLE)
180 #define EHPF_ENABLECHANGE (1UL<<EHPB_ENABLECHANGE)
181 #define EHPF_OVERCURRENT (1UL<<EHPB_OVERCURRENT)
182 #define EHPF_OVERCURRENTCHG (1UL<<EHPB_OVERCURRENTCHG)
183 #define EHPF_RESUMEDTX (1UL<<EHPB_RESUMEDTX)
184 #define EHPF_PORTSUSPEND (1UL<<EHPB_PORTSUSPEND)
185 #define EHPF_PORTRESET (1UL<<EHPB_PORTRESET)
186 #define EHPF_LINESTATUS_DM (1UL<<EHPB_LINESTATUS_DM)
187 #define EHPF_LINESTATUS_DP (1UL<<EHPB_LINESTATUS_DP)
188 #define EHPF_PORTPOWER (1UL<<EHPB_PORTPOWER)
189 #define EHPF_NOTPORTOWNER (1UL<<EHPB_NOTPORTOWNER)
190 #define EHPF_WAKECONNECT (1UL<<EHPB_WAKECONNECT)
191 #define EHPF_WAKEDISCONNECT (1UL<<EHPB_WAKEDISCONNECT)
192 #define EHPF_WAKEOCENABLE (1UL<<EHPB_WAKEOCENABLE)
194 #define EHPM_PORTINDICATOR (((1UL<<2)-1)<<EHPS_PORTINDICATOR)
195 #define EHPF_PORTIND_OFF (0UL<<EHPS_PORTINDICATOR)
196 #define EHPF_PORTIND_AMBER (1UL<<EHPS_PORTINDICATOR)
197 #define EHPF_PORTIND_GREEN (2UL<<EHPS_PORTINDICATOR)
199 /* Legacy support register */
200 #define EHLS_CAP_ID 0
201 #define EHLB_BIOS_OWNER 16
202 #define EHLB_OS_OWNER 24
204 #define EHLM_CAP_ID (((1UL<<8)-1)<<EHLS_CAP_ID)
205 #define EHLF_BIOS_OWNER (1UL<<EHLB_BIOS_OWNER)
206 #define EHLF_OS_OWNER (1UL<<EHLB_OS_OWNER)
208 /* Legacy support control / status */
210 /* data structures */
212 #define EHCI_FRAMELIST_SIZE 1024
213 #define EHCI_FRAMELIST_ALIGNMENT 0x0fff
215 #define EHCI_PAGE_SIZE 4096
216 #define EHCI_PAGE_MASK 0xfffff000
217 #define EHCI_OFFSET_MASK 0x00000fff
219 #define EHCI_TDQH_ALIGNMENT 0x001f
221 #define EHCI_QH_POOLSIZE 128
222 #define EHCI_TD_POOLSIZE 512
224 #define EHCI_TD_BULK_LIMIT (128<<10) // limit for one batch of BULK data TDs
226 /* pointer defines */
228 #define EHCI_PTRMASK 0xffffffe0 /* frame list pointer mask */
229 #define EHCI_TERMINATE 0x00000001 /* terminate list here */
230 #define EHCI_ISOTD 0x00000000 /* isochronous TD */
231 #define EHCI_QUEUEHEAD 0x00000002 /* pointer is a queue head */
232 #define EHCI_SPLITISOTD 0x00000004 /* split transaction isochronous TD */
233 #define EHCI_FRAMESPAN 0x00000006 /* frame span traversal node */
235 /* TD control and status word defines */
237 #define ETSB_PING 0 /* PING state instead of OUT */
238 #define ETSB_SPLITERR 0 /* periodic split transaction error handshake */
239 #define ETSB_COMPLETESPLIT 1 /* In complete-split state */
240 #define ETSB_MISSEDCSPLIT 2 /* Missed Micro-frame for complete-split */
241 #define ETSB_TRANSERR 3 /* Transaction error (Timeout, CRC, PID) */
242 #define ETSB_BABBLE 4 /* Babble detected on the bus */
243 #define ETSB_DATABUFFERERR 5 /* Data Buffer Error (Overrun / Underrun) */
244 #define ETSB_HALTED 6 /* TD has been halted */
245 #define ETCB_ACTIVE 7 /* TD is active / enable TD */
246 #define ETCB_READYINTEN 15 /* Interrupt on Complete enable */
247 #define ETCB_DATA1 31 /* Data toggle bit */
249 #define ETCS_PIDCODE 8 /* PID code */
250 #define ETCS_ERRORLIMIT 10 /* how many errors permitted */
251 #define ETSS_CURRENTPAGE 12 /* current page offset */
252 #define ETSS_TRANSLENGTH 16 /* bytes to transfer */
254 #define ETSF_PING (1UL<<ETSB_PING)
255 #define ETSF_SPLITERR (1UL<<ETSB_SPLITERR)
256 #define ETSF_COMPLETESPLIT (1UL<<ETSB_COMPLETESPLIT)
257 #define ETSF_MISSEDCSPLIT (1UL<<ETSB_MISSEDCSPLIT)
258 #define ETSF_TRANSERR (1UL<<ETSB_TRANSERR)
259 #define ETSF_BABBLE (1UL<<ETSB_BABBLE)
260 #define ETSF_DATABUFFERERR (1UL<<ETSB_DATABUFFERERR)
261 #define ETSF_HALTED (1UL<<ETSB_HALTED)
262 #define ETCF_ACTIVE (1UL<<ETCB_ACTIVE)
263 #define ETCF_READYINTEN (1UL<<ETCB_READYINTEN)
264 #define ETCF_DATA1 (1UL<<ETCB_DATA1)
266 #define ETCM_PIDCODE (((1UL<<2)-1)<<ETCS_PIDCODE)
267 #define ETCF_PIDCODE_OUT (0UL<<ETCS_PIDCODE)
268 #define ETCF_PIDCODE_IN (1UL<<ETCS_PIDCODE)
269 #define ETCF_PIDCODE_SETUP (2UL<<ETCS_PIDCODE)
271 #define ETCM_ERRORLIMIT (((1UL<<2)-1)<<ETCS_ERRORLIMIT)
272 #define ETCF_NOERRORLIMIT (0UL<<ETCS_ERRORLIMIT)
273 #define ETCF_1ERRORLIMIT (1UL<<ETCS_ERRORLIMIT)
274 #define ETCF_2ERRORSLIMIT (2UL<<ETCS_ERRORLIMIT)
275 #define ETCF_3ERRORSLIMIT (3UL<<ETCS_ERRORLIMIT)
277 #define ETSM_CURRENTPAGE (((1UL<<3)-1)<<ETSS_CURRENTPAGE)
278 #define ETSM_TRANSLENGTH (((1UL<<15)-1)<<ETSS_TRANSLENGTH)
280 /* QH EP Capabilitities */
282 #define EQEB_INACTIVATENEXT 7 /* Inactivate on next transaction for periodic schedule (FS/LS) */
283 #define EQEB_LOWSPEED 12 /* Lowspeed transaction */
284 #define EQEB_HIGHSPEED 13 /* Highspeed transaction */
285 #define EQEB_TOGGLEFROMTD 14 /* Data toggle comes from TD */
286 #define EQEB_RECLAMHEAD 15 /* Head Of Reclamation List Flag */
287 #define EQEB_SPLITCTRLEP 27 /* For Fullspeed/Lowspeed, signal Control Endpoint */
289 #define EQES_DEVADDR 0 /* Device Address */
290 #define EQES_ENDPOINT 8 /* Endpoint number */
291 #define EQES_MAXPKTLEN 16 /* Maximum Packet Length */
292 #define EQES_RELOAD 28 /* 0=Ignore NAKCOUNT, NAKCOUNT is loaded with this */
294 #define EQEF_INACTIVATENEXT (1UL<<EQEB_INACTIVATENEXT)
295 #define EQEF_LOWSPEED (1UL<<EQEB_LOWSPEED)
296 #define EQEF_HIGHSPEED (1UL<<EQEB_HIGHSPEED)
297 #define EQEF_TOGGLEFROMTD (1UL<<EQEB_TOGGLEFROMTD)
298 #define EQEF_RECLAMHEAD (1UL<<EQEB_RECLAMHEAD)
299 #define EQEF_SPLITCTRLEP (1UL<<EQEB_SPLITCTRLEP)
301 #define EQEM_DEVADDR (((1UL<<7)-1)<<EQES_DEVADDR)
302 #define EQEM_ENDPOINT (((1UL<<4)-1)<<EQES_ENDPOINT)
303 #define EQEM_MAXPKTLEN (((1UL<<11)-1)<<EQES_MAXPKTLEN)
304 #define EQEM_RELOAD (((1UL<<4)-1)<<EQES_RELOAD)
306 /* QH Split Ctrl */
307 #define EQSS_MUSOFACTIVE 0 /* µSOF Active */
308 #define EQSS_MUSOFCSPLIT 8 /* When to send the complete split */
310 #define EQSS_HUBADDRESS 16 /* Hub Device Address for Split Transaction */
311 #define EQSS_PORTNUMBER 23 /* Port Number of hub for Split Transaction */
312 #define EQSS_MULTIPLIER 30 /* Multiplier, how many successive packets are sent */
314 #define EQSM_MUSOFACTIVE (((1UL<<8)-1)<<EQSS_MUSOFACTIVE)
315 #define EQSM_MUSOFCSPLIT (((1UL<<8)-1)<<EQSS_MUSOFCSPLIT)
316 #define EQSM_HUBADDRESS (((1UL<<7)-1)<<EQSS_HUBADDRESS)
317 #define EQSM_PORTNUMBER (((1UL<<7)-1)<<EQSS_PORTNUMBER)
319 #define EQSM_MULTIPLIER (((1UL<<2)-1)<<EQSS_MULTIPLIER)
320 #define EQSF_MULTI_1 (1UL<<EQSS_MULTIPLIER)
321 #define EQSF_MULTI_2 (2UL<<EQSS_MULTIPLIER)
322 #define EQSF_MULTI_3 (3UL<<EQSS_MULTIPLIER)
324 #endif /* PCIEHCI_HC_H */