xref: /rk3399_rockchip-uboot/include/usb_defs.h (revision 7d9aa8fd87171164a6f14167a0c9c066f4312b8d)
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 
153*7d9aa8fdSJulius Werner /* Device features */
154*7d9aa8fdSJulius Werner #define USB_FEAT_HALT               0x00
155*7d9aa8fdSJulius Werner #define USB_FEAT_WAKEUP             0x01
156*7d9aa8fdSJulius Werner #define USB_FEAT_TEST               0x02
157*7d9aa8fdSJulius Werner 
158*7d9aa8fdSJulius Werner /* Test modes */
159*7d9aa8fdSJulius Werner #define USB_TEST_MODE_J             0x01
160*7d9aa8fdSJulius Werner #define USB_TEST_MODE_K             0x02
161*7d9aa8fdSJulius Werner #define USB_TEST_MODE_SE0_NAK       0x03
162*7d9aa8fdSJulius Werner #define USB_TEST_MODE_PACKET        0x04
163*7d9aa8fdSJulius Werner #define USB_TEST_MODE_FORCE_ENABLE  0x05
164*7d9aa8fdSJulius 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
223*7d9aa8fdSJulius Werner #define USB_PORT_FEAT_TEST           21
224012771d8Swdenk 
225012771d8Swdenk /* wPortStatus bits */
226012771d8Swdenk #define USB_PORT_STAT_CONNECTION    0x0001
227012771d8Swdenk #define USB_PORT_STAT_ENABLE        0x0002
228012771d8Swdenk #define USB_PORT_STAT_SUSPEND       0x0004
229012771d8Swdenk #define USB_PORT_STAT_OVERCURRENT   0x0008
230012771d8Swdenk #define USB_PORT_STAT_RESET         0x0010
231012771d8Swdenk #define USB_PORT_STAT_POWER         0x0100
232012771d8Swdenk #define USB_PORT_STAT_LOW_SPEED     0x0200
2333e126484SMichael Trimarchi #define USB_PORT_STAT_HIGH_SPEED    0x0400	/* support for EHCI */
2343e126484SMichael Trimarchi #define USB_PORT_STAT_SPEED	\
2353e126484SMichael Trimarchi 	(USB_PORT_STAT_LOW_SPEED | USB_PORT_STAT_HIGH_SPEED)
236012771d8Swdenk 
237012771d8Swdenk /* wPortChange bits */
238012771d8Swdenk #define USB_PORT_STAT_C_CONNECTION  0x0001
239012771d8Swdenk #define USB_PORT_STAT_C_ENABLE      0x0002
240012771d8Swdenk #define USB_PORT_STAT_C_SUSPEND     0x0004
241012771d8Swdenk #define USB_PORT_STAT_C_OVERCURRENT 0x0008
242012771d8Swdenk #define USB_PORT_STAT_C_RESET       0x0010
243012771d8Swdenk 
244012771d8Swdenk /* wHubCharacteristics (masks) */
245012771d8Swdenk #define HUB_CHAR_LPSM               0x0003
246012771d8Swdenk #define HUB_CHAR_COMPOUND           0x0004
247012771d8Swdenk #define HUB_CHAR_OCPM               0x0018
248012771d8Swdenk 
249012771d8Swdenk /*
250012771d8Swdenk  *Hub Status & Hub Change bit masks
251012771d8Swdenk  */
252012771d8Swdenk #define HUB_STATUS_LOCAL_POWER	0x0001
253012771d8Swdenk #define HUB_STATUS_OVERCURRENT	0x0002
254012771d8Swdenk 
255012771d8Swdenk #define HUB_CHANGE_LOCAL_POWER	0x0001
256012771d8Swdenk #define HUB_CHANGE_OVERCURRENT	0x0002
257012771d8Swdenk 
258012771d8Swdenk #endif /*_USB_DEFS_H_ */
259