xref: /rk3399_rockchip-uboot/include/usb_defs.h (revision 55f4b57542de9f4bee8dc0b7ca70686bd20e2aa4)
1012771d8Swdenk /*
2012771d8Swdenk  * (C) Copyright 2001
3012771d8Swdenk  * Denis Peter, MPL AG Switzerland
4012771d8Swdenk  *
5012771d8Swdenk  * See file CREDITS for list of people who contributed to this
6012771d8Swdenk  * project.
7012771d8Swdenk  *
8012771d8Swdenk  * This program is free software; you can redistribute it and/or
9012771d8Swdenk  * modify it under the terms of the GNU General Public License as
10012771d8Swdenk  * published by the Free Software Foundation; either version 2 of
11012771d8Swdenk  * the License, or (at your option) any later version.
12012771d8Swdenk  *
13012771d8Swdenk  * This program is distributed in the hope that it will be useful,
14012771d8Swdenk  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15012771d8Swdenk  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16012771d8Swdenk  * GNU General Public License for more details.
17012771d8Swdenk  *
18012771d8Swdenk  * You should have received a copy of the GNU General Public License
19012771d8Swdenk  * along with this program; if not, write to the Free Software
20012771d8Swdenk  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21012771d8Swdenk  * MA 02111-1307 USA
22012771d8Swdenk  *
23012771d8Swdenk  * Note: Part of this code has been derived from linux
24012771d8Swdenk  *
25012771d8Swdenk  */
26012771d8Swdenk #ifndef _USB_DEFS_H_
27012771d8Swdenk #define _USB_DEFS_H_
28012771d8Swdenk 
29012771d8Swdenk /* USB constants */
30012771d8Swdenk 
31012771d8Swdenk /* Device and/or Interface Class codes */
32012771d8Swdenk #define USB_CLASS_PER_INTERFACE  0	/* for DeviceClass */
33012771d8Swdenk #define USB_CLASS_AUDIO          1
34012771d8Swdenk #define USB_CLASS_COMM           2
35012771d8Swdenk #define USB_CLASS_HID            3
36012771d8Swdenk #define USB_CLASS_PRINTER	       7
37012771d8Swdenk #define USB_CLASS_MASS_STORAGE   8
38012771d8Swdenk #define USB_CLASS_HUB            9
39012771d8Swdenk #define USB_CLASS_DATA           10
40012771d8Swdenk #define USB_CLASS_VENDOR_SPEC    0xff
41012771d8Swdenk 
42012771d8Swdenk /* some HID sub classes */
43012771d8Swdenk #define USB_SUB_HID_NONE        0
44012771d8Swdenk #define USB_SUB_HID_BOOT        1
45012771d8Swdenk 
46012771d8Swdenk /* some UID Protocols */
47012771d8Swdenk #define USB_PROT_HID_NONE       0
48012771d8Swdenk #define USB_PROT_HID_KEYBOARD   1
49012771d8Swdenk #define USB_PROT_HID_MOUSE      2
50012771d8Swdenk 
51012771d8Swdenk 
52012771d8Swdenk /* Sub STORAGE Classes */
53012771d8Swdenk #define US_SC_RBC              1		/* Typically, flash devices */
54012771d8Swdenk #define US_SC_8020             2		/* CD-ROM */
55012771d8Swdenk #define US_SC_QIC              3		/* QIC-157 Tapes */
56012771d8Swdenk #define US_SC_UFI              4		/* Floppy */
57012771d8Swdenk #define US_SC_8070             5		/* Removable media */
58012771d8Swdenk #define US_SC_SCSI             6		/* Transparent */
59012771d8Swdenk #define US_SC_MIN              US_SC_RBC
60012771d8Swdenk #define US_SC_MAX              US_SC_SCSI
61012771d8Swdenk 
62012771d8Swdenk /* STORAGE Protocols */
63012771d8Swdenk #define US_PR_CB               1		/* Control/Bulk w/o interrupt */
64012771d8Swdenk #define US_PR_CBI              0		/* Control/Bulk/Interrupt */
65012771d8Swdenk #define US_PR_BULK             0x50		/* bulk only */
66012771d8Swdenk 
67012771d8Swdenk /* USB types */
68012771d8Swdenk #define USB_TYPE_STANDARD   (0x00 << 5)
69012771d8Swdenk #define USB_TYPE_CLASS      (0x01 << 5)
70012771d8Swdenk #define USB_TYPE_VENDOR     (0x02 << 5)
71012771d8Swdenk #define USB_TYPE_RESERVED   (0x03 << 5)
72012771d8Swdenk 
73012771d8Swdenk /* USB recipients */
74012771d8Swdenk #define USB_RECIP_DEVICE      0x00
75012771d8Swdenk #define USB_RECIP_INTERFACE   0x01
76012771d8Swdenk #define USB_RECIP_ENDPOINT    0x02
77012771d8Swdenk #define USB_RECIP_OTHER       0x03
78012771d8Swdenk 
79012771d8Swdenk /* USB directions */
80012771d8Swdenk #define USB_DIR_OUT           0
81012771d8Swdenk #define USB_DIR_IN            0x80
82012771d8Swdenk 
83012771d8Swdenk /* Descriptor types */
84012771d8Swdenk #define USB_DT_DEVICE        0x01
85012771d8Swdenk #define USB_DT_CONFIG        0x02
86012771d8Swdenk #define USB_DT_STRING        0x03
87012771d8Swdenk #define USB_DT_INTERFACE     0x04
88012771d8Swdenk #define USB_DT_ENDPOINT      0x05
89012771d8Swdenk 
90012771d8Swdenk #define USB_DT_HID          (USB_TYPE_CLASS | 0x01)
91012771d8Swdenk #define USB_DT_REPORT       (USB_TYPE_CLASS | 0x02)
92012771d8Swdenk #define USB_DT_PHYSICAL     (USB_TYPE_CLASS | 0x03)
93012771d8Swdenk #define USB_DT_HUB          (USB_TYPE_CLASS | 0x09)
94012771d8Swdenk 
95012771d8Swdenk /* Descriptor sizes per descriptor type */
96012771d8Swdenk #define USB_DT_DEVICE_SIZE      18
97012771d8Swdenk #define USB_DT_CONFIG_SIZE      9
98012771d8Swdenk #define USB_DT_INTERFACE_SIZE   9
99012771d8Swdenk #define USB_DT_ENDPOINT_SIZE    7
100012771d8Swdenk #define USB_DT_ENDPOINT_AUDIO_SIZE  9	/* Audio extension */
101012771d8Swdenk #define USB_DT_HUB_NONVAR_SIZE  7
102012771d8Swdenk #define USB_DT_HID_SIZE         9
103012771d8Swdenk 
104012771d8Swdenk /* Endpoints */
105012771d8Swdenk #define USB_ENDPOINT_NUMBER_MASK  0x0f	/* in bEndpointAddress */
106012771d8Swdenk #define USB_ENDPOINT_DIR_MASK     0x80
107012771d8Swdenk 
108012771d8Swdenk #define USB_ENDPOINT_XFERTYPE_MASK 0x03	/* in bmAttributes */
109012771d8Swdenk #define USB_ENDPOINT_XFER_CONTROL  0
110012771d8Swdenk #define USB_ENDPOINT_XFER_ISOC     1
111012771d8Swdenk #define USB_ENDPOINT_XFER_BULK     2
112012771d8Swdenk #define USB_ENDPOINT_XFER_INT      3
113012771d8Swdenk 
114012771d8Swdenk /* USB Packet IDs (PIDs) */
115012771d8Swdenk #define USB_PID_UNDEF_0             0xf0
116012771d8Swdenk #define USB_PID_OUT                 0xe1
117012771d8Swdenk #define USB_PID_ACK                 0xd2
118012771d8Swdenk #define USB_PID_DATA0               0xc3
119012771d8Swdenk #define USB_PID_UNDEF_4             0xb4
120012771d8Swdenk #define USB_PID_SOF                 0xa5
121012771d8Swdenk #define USB_PID_UNDEF_6             0x96
122012771d8Swdenk #define USB_PID_UNDEF_7             0x87
123012771d8Swdenk #define USB_PID_UNDEF_8             0x78
124012771d8Swdenk #define USB_PID_IN                  0x69
125012771d8Swdenk #define USB_PID_NAK                 0x5a
126012771d8Swdenk #define USB_PID_DATA1               0x4b
127012771d8Swdenk #define USB_PID_PREAMBLE            0x3c
128012771d8Swdenk #define USB_PID_SETUP               0x2d
129012771d8Swdenk #define USB_PID_STALL               0x1e
130012771d8Swdenk #define USB_PID_UNDEF_F             0x0f
131012771d8Swdenk 
132012771d8Swdenk /* Standard requests */
133012771d8Swdenk #define USB_REQ_GET_STATUS          0x00
134012771d8Swdenk #define USB_REQ_CLEAR_FEATURE       0x01
135012771d8Swdenk #define USB_REQ_SET_FEATURE         0x03
136012771d8Swdenk #define USB_REQ_SET_ADDRESS         0x05
137012771d8Swdenk #define USB_REQ_GET_DESCRIPTOR      0x06
138012771d8Swdenk #define USB_REQ_SET_DESCRIPTOR      0x07
139012771d8Swdenk #define USB_REQ_GET_CONFIGURATION   0x08
140012771d8Swdenk #define USB_REQ_SET_CONFIGURATION   0x09
141012771d8Swdenk #define USB_REQ_GET_INTERFACE       0x0A
142012771d8Swdenk #define USB_REQ_SET_INTERFACE       0x0B
143012771d8Swdenk #define USB_REQ_SYNCH_FRAME         0x0C
144012771d8Swdenk 
145012771d8Swdenk /* HID requests */
146012771d8Swdenk #define USB_REQ_GET_REPORT          0x01
147012771d8Swdenk #define USB_REQ_GET_IDLE            0x02
148012771d8Swdenk #define USB_REQ_GET_PROTOCOL        0x03
149012771d8Swdenk #define USB_REQ_SET_REPORT          0x09
150012771d8Swdenk #define USB_REQ_SET_IDLE            0x0A
151012771d8Swdenk #define USB_REQ_SET_PROTOCOL        0x0B
152012771d8Swdenk 
1537d9aa8fdSJulius Werner /* Device features */
1547d9aa8fdSJulius Werner #define USB_FEAT_HALT               0x00
1557d9aa8fdSJulius Werner #define USB_FEAT_WAKEUP             0x01
1567d9aa8fdSJulius Werner #define USB_FEAT_TEST               0x02
1577d9aa8fdSJulius Werner 
1587d9aa8fdSJulius Werner /* Test modes */
1597d9aa8fdSJulius Werner #define USB_TEST_MODE_J             0x01
1607d9aa8fdSJulius Werner #define USB_TEST_MODE_K             0x02
1617d9aa8fdSJulius Werner #define USB_TEST_MODE_SE0_NAK       0x03
1627d9aa8fdSJulius Werner #define USB_TEST_MODE_PACKET        0x04
1637d9aa8fdSJulius Werner #define USB_TEST_MODE_FORCE_ENABLE  0x05
1647d9aa8fdSJulius Werner 
165012771d8Swdenk 
166012771d8Swdenk /* "pipe" definitions */
167012771d8Swdenk 
168012771d8Swdenk #define PIPE_ISOCHRONOUS    0
169012771d8Swdenk #define PIPE_INTERRUPT      1
170012771d8Swdenk #define PIPE_CONTROL        2
171012771d8Swdenk #define PIPE_BULK           3
172012771d8Swdenk #define PIPE_DEVEP_MASK     0x0007ff00
173012771d8Swdenk 
174012771d8Swdenk #define USB_ISOCHRONOUS    0
175012771d8Swdenk #define USB_INTERRUPT      1
176012771d8Swdenk #define USB_CONTROL        2
177012771d8Swdenk #define USB_BULK           3
178012771d8Swdenk 
179012771d8Swdenk /* USB-status codes: */
180012771d8Swdenk #define USB_ST_ACTIVE           0x1		/* TD is active */
181012771d8Swdenk #define USB_ST_STALLED          0x2		/* TD is stalled */
182012771d8Swdenk #define USB_ST_BUF_ERR          0x4		/* buffer error */
183012771d8Swdenk #define USB_ST_BABBLE_DET       0x8		/* Babble detected */
184012771d8Swdenk #define USB_ST_NAK_REC          0x10	/* NAK Received*/
185012771d8Swdenk #define USB_ST_CRC_ERR          0x20	/* CRC/timeout Error */
186012771d8Swdenk #define USB_ST_BIT_ERR          0x40	/* Bitstuff error */
187012771d8Swdenk #define USB_ST_NOT_PROC         0x80000000L	/* Not yet processed */
188012771d8Swdenk 
189012771d8Swdenk 
190012771d8Swdenk /*************************************************************************
191012771d8Swdenk  * Hub defines
192012771d8Swdenk  */
193012771d8Swdenk 
194012771d8Swdenk /*
195012771d8Swdenk  * Hub request types
196012771d8Swdenk  */
197012771d8Swdenk 
198012771d8Swdenk #define USB_RT_HUB	(USB_TYPE_CLASS | USB_RECIP_DEVICE)
199012771d8Swdenk #define USB_RT_PORT	(USB_TYPE_CLASS | USB_RECIP_OTHER)
200012771d8Swdenk 
201012771d8Swdenk /*
202012771d8Swdenk  * Hub Class feature numbers
203012771d8Swdenk  */
204012771d8Swdenk #define C_HUB_LOCAL_POWER   0
205012771d8Swdenk #define C_HUB_OVER_CURRENT  1
206012771d8Swdenk 
207012771d8Swdenk /*
208012771d8Swdenk  * Port feature numbers
209012771d8Swdenk  */
210012771d8Swdenk #define USB_PORT_FEAT_CONNECTION     0
211012771d8Swdenk #define USB_PORT_FEAT_ENABLE         1
212012771d8Swdenk #define USB_PORT_FEAT_SUSPEND        2
213012771d8Swdenk #define USB_PORT_FEAT_OVER_CURRENT   3
214012771d8Swdenk #define USB_PORT_FEAT_RESET          4
215012771d8Swdenk #define USB_PORT_FEAT_POWER          8
216012771d8Swdenk #define USB_PORT_FEAT_LOWSPEED       9
2173e126484SMichael Trimarchi #define USB_PORT_FEAT_HIGHSPEED      10
218012771d8Swdenk #define USB_PORT_FEAT_C_CONNECTION   16
219012771d8Swdenk #define USB_PORT_FEAT_C_ENABLE       17
220012771d8Swdenk #define USB_PORT_FEAT_C_SUSPEND      18
221012771d8Swdenk #define USB_PORT_FEAT_C_OVER_CURRENT 19
222012771d8Swdenk #define USB_PORT_FEAT_C_RESET        20
2237d9aa8fdSJulius Werner #define USB_PORT_FEAT_TEST           21
224012771d8Swdenk 
225*55f4b575SVivek Gautam /*
226*55f4b575SVivek Gautam  * Changes to Port feature numbers for Super speed,
227*55f4b575SVivek Gautam  * from USB 3.0 spec Table 10-8
228*55f4b575SVivek Gautam  */
229*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_U1_TIMEOUT	23
230*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_U2_TIMEOUT	24
231*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_C_LINK_STATE	25
232*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_C_CONFIG_ERROR	26
233*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_BH_RESET	28
234*55f4b575SVivek Gautam #define USB_SS_PORT_FEAT_C_BH_RESET	29
235*55f4b575SVivek Gautam 
236012771d8Swdenk /* wPortStatus bits */
237012771d8Swdenk #define USB_PORT_STAT_CONNECTION    0x0001
238012771d8Swdenk #define USB_PORT_STAT_ENABLE        0x0002
239012771d8Swdenk #define USB_PORT_STAT_SUSPEND       0x0004
240012771d8Swdenk #define USB_PORT_STAT_OVERCURRENT   0x0008
241012771d8Swdenk #define USB_PORT_STAT_RESET         0x0010
242012771d8Swdenk #define USB_PORT_STAT_POWER         0x0100
243012771d8Swdenk #define USB_PORT_STAT_LOW_SPEED     0x0200
2443e126484SMichael Trimarchi #define USB_PORT_STAT_HIGH_SPEED    0x0400	/* support for EHCI */
245*55f4b575SVivek Gautam #define USB_PORT_STAT_SUPER_SPEED   0x0600	/* faking support to XHCI */
246*55f4b575SVivek Gautam #define USB_PORT_STAT_SPEED_MASK	\
247*55f4b575SVivek Gautam 	(USB_PORT_STAT_LOW_SPEED | USB_PORT_STAT_HIGH_SPEED)
2486497c667SVivek Gautam 
2496497c667SVivek Gautam /*
250*55f4b575SVivek Gautam  * Changes to wPortStatus bit field in USB 3.0
251*55f4b575SVivek Gautam  * See USB 3.0 spec Table 10-11
2526497c667SVivek Gautam  */
253*55f4b575SVivek Gautam #define USB_SS_PORT_STAT_LINK_STATE	0x01e0
2546497c667SVivek Gautam #define USB_SS_PORT_STAT_POWER		0x0200
2556497c667SVivek Gautam #define USB_SS_PORT_STAT_SPEED		0x1c00
256*55f4b575SVivek Gautam #define USB_SS_PORT_STAT_SPEED_5GBPS	0x0000
257012771d8Swdenk 
258012771d8Swdenk /* wPortChange bits */
259012771d8Swdenk #define USB_PORT_STAT_C_CONNECTION  0x0001
260012771d8Swdenk #define USB_PORT_STAT_C_ENABLE      0x0002
261012771d8Swdenk #define USB_PORT_STAT_C_SUSPEND     0x0004
262012771d8Swdenk #define USB_PORT_STAT_C_OVERCURRENT 0x0008
263012771d8Swdenk #define USB_PORT_STAT_C_RESET       0x0010
264012771d8Swdenk 
2656497c667SVivek Gautam /*
266*55f4b575SVivek Gautam  * Changes to wPortChange bit fields in USB 3.0
267*55f4b575SVivek Gautam  * See USB 3.0 spec Table 10-12
2686497c667SVivek Gautam  */
269*55f4b575SVivek Gautam #define USB_SS_PORT_STAT_C_BH_RESET	0x0020
270*55f4b575SVivek Gautam #define USB_SS_PORT_STAT_C_LINK_STATE	0x0040
271*55f4b575SVivek Gautam #define USB_SS_PORT_STAT_C_CONFIG_ERROR	0x0080
2726497c667SVivek Gautam 
273012771d8Swdenk /* wHubCharacteristics (masks) */
274012771d8Swdenk #define HUB_CHAR_LPSM               0x0003
275012771d8Swdenk #define HUB_CHAR_COMPOUND           0x0004
276012771d8Swdenk #define HUB_CHAR_OCPM               0x0018
277012771d8Swdenk 
278012771d8Swdenk /*
279012771d8Swdenk  * Hub Status & Hub Change bit masks
280012771d8Swdenk  */
281012771d8Swdenk #define HUB_STATUS_LOCAL_POWER	0x0001
282012771d8Swdenk #define HUB_STATUS_OVERCURRENT	0x0002
283012771d8Swdenk 
284012771d8Swdenk #define HUB_CHANGE_LOCAL_POWER	0x0001
285012771d8Swdenk #define HUB_CHANGE_OVERCURRENT	0x0002
286012771d8Swdenk 
287012771d8Swdenk #endif /*_USB_DEFS_H_ */
288