xref: /rk3399_rockchip-uboot/include/usb_defs.h (revision 3e126484df7868e341545cce740b24b62b0cd3b7)
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 
83*3e126484SMichael Trimarchi /* USB device speeds */
84*3e126484SMichael Trimarchi #define USB_SPEED_FULL		0x0	/* 12Mbps */
85*3e126484SMichael Trimarchi #define USB_SPEED_LOW		0x1	/* 1.5Mbps */
86*3e126484SMichael Trimarchi #define USB_SPEED_HIGH		0x2	/* 480Mbps */
87*3e126484SMichael Trimarchi #define USB_SPEED_RESERVED	0x3
88*3e126484SMichael Trimarchi 
89012771d8Swdenk /* Descriptor types */
90012771d8Swdenk #define USB_DT_DEVICE        0x01
91012771d8Swdenk #define USB_DT_CONFIG        0x02
92012771d8Swdenk #define USB_DT_STRING        0x03
93012771d8Swdenk #define USB_DT_INTERFACE     0x04
94012771d8Swdenk #define USB_DT_ENDPOINT      0x05
95012771d8Swdenk 
96012771d8Swdenk #define USB_DT_HID          (USB_TYPE_CLASS | 0x01)
97012771d8Swdenk #define USB_DT_REPORT       (USB_TYPE_CLASS | 0x02)
98012771d8Swdenk #define USB_DT_PHYSICAL     (USB_TYPE_CLASS | 0x03)
99012771d8Swdenk #define USB_DT_HUB          (USB_TYPE_CLASS | 0x09)
100012771d8Swdenk 
101012771d8Swdenk /* Descriptor sizes per descriptor type */
102012771d8Swdenk #define USB_DT_DEVICE_SIZE      18
103012771d8Swdenk #define USB_DT_CONFIG_SIZE      9
104012771d8Swdenk #define USB_DT_INTERFACE_SIZE   9
105012771d8Swdenk #define USB_DT_ENDPOINT_SIZE    7
106012771d8Swdenk #define USB_DT_ENDPOINT_AUDIO_SIZE  9	/* Audio extension */
107012771d8Swdenk #define USB_DT_HUB_NONVAR_SIZE  7
108012771d8Swdenk #define USB_DT_HID_SIZE         9
109012771d8Swdenk 
110012771d8Swdenk /* Endpoints */
111012771d8Swdenk #define USB_ENDPOINT_NUMBER_MASK  0x0f	/* in bEndpointAddress */
112012771d8Swdenk #define USB_ENDPOINT_DIR_MASK     0x80
113012771d8Swdenk 
114012771d8Swdenk #define USB_ENDPOINT_XFERTYPE_MASK 0x03	/* in bmAttributes */
115012771d8Swdenk #define USB_ENDPOINT_XFER_CONTROL  0
116012771d8Swdenk #define USB_ENDPOINT_XFER_ISOC     1
117012771d8Swdenk #define USB_ENDPOINT_XFER_BULK     2
118012771d8Swdenk #define USB_ENDPOINT_XFER_INT      3
119012771d8Swdenk 
120012771d8Swdenk /* USB Packet IDs (PIDs) */
121012771d8Swdenk #define USB_PID_UNDEF_0             0xf0
122012771d8Swdenk #define USB_PID_OUT                 0xe1
123012771d8Swdenk #define USB_PID_ACK                 0xd2
124012771d8Swdenk #define USB_PID_DATA0               0xc3
125012771d8Swdenk #define USB_PID_UNDEF_4             0xb4
126012771d8Swdenk #define USB_PID_SOF                 0xa5
127012771d8Swdenk #define USB_PID_UNDEF_6             0x96
128012771d8Swdenk #define USB_PID_UNDEF_7             0x87
129012771d8Swdenk #define USB_PID_UNDEF_8             0x78
130012771d8Swdenk #define USB_PID_IN                  0x69
131012771d8Swdenk #define USB_PID_NAK                 0x5a
132012771d8Swdenk #define USB_PID_DATA1               0x4b
133012771d8Swdenk #define USB_PID_PREAMBLE            0x3c
134012771d8Swdenk #define USB_PID_SETUP               0x2d
135012771d8Swdenk #define USB_PID_STALL               0x1e
136012771d8Swdenk #define USB_PID_UNDEF_F             0x0f
137012771d8Swdenk 
138012771d8Swdenk /* Standard requests */
139012771d8Swdenk #define USB_REQ_GET_STATUS          0x00
140012771d8Swdenk #define USB_REQ_CLEAR_FEATURE       0x01
141012771d8Swdenk #define USB_REQ_SET_FEATURE         0x03
142012771d8Swdenk #define USB_REQ_SET_ADDRESS         0x05
143012771d8Swdenk #define USB_REQ_GET_DESCRIPTOR      0x06
144012771d8Swdenk #define USB_REQ_SET_DESCRIPTOR      0x07
145012771d8Swdenk #define USB_REQ_GET_CONFIGURATION   0x08
146012771d8Swdenk #define USB_REQ_SET_CONFIGURATION   0x09
147012771d8Swdenk #define USB_REQ_GET_INTERFACE       0x0A
148012771d8Swdenk #define USB_REQ_SET_INTERFACE       0x0B
149012771d8Swdenk #define USB_REQ_SYNCH_FRAME         0x0C
150012771d8Swdenk 
151012771d8Swdenk /* HID requests */
152012771d8Swdenk #define USB_REQ_GET_REPORT          0x01
153012771d8Swdenk #define USB_REQ_GET_IDLE            0x02
154012771d8Swdenk #define USB_REQ_GET_PROTOCOL        0x03
155012771d8Swdenk #define USB_REQ_SET_REPORT          0x09
156012771d8Swdenk #define USB_REQ_SET_IDLE            0x0A
157012771d8Swdenk #define USB_REQ_SET_PROTOCOL        0x0B
158012771d8Swdenk 
159012771d8Swdenk 
160012771d8Swdenk /* "pipe" definitions */
161012771d8Swdenk 
162012771d8Swdenk #define PIPE_ISOCHRONOUS    0
163012771d8Swdenk #define PIPE_INTERRUPT      1
164012771d8Swdenk #define PIPE_CONTROL        2
165012771d8Swdenk #define PIPE_BULK           3
166012771d8Swdenk #define PIPE_DEVEP_MASK     0x0007ff00
167012771d8Swdenk 
168012771d8Swdenk #define USB_ISOCHRONOUS    0
169012771d8Swdenk #define USB_INTERRUPT      1
170012771d8Swdenk #define USB_CONTROL        2
171012771d8Swdenk #define USB_BULK           3
172012771d8Swdenk 
173012771d8Swdenk /* USB-status codes: */
174012771d8Swdenk #define USB_ST_ACTIVE           0x1		/* TD is active */
175012771d8Swdenk #define USB_ST_STALLED          0x2		/* TD is stalled */
176012771d8Swdenk #define USB_ST_BUF_ERR          0x4		/* buffer error */
177012771d8Swdenk #define USB_ST_BABBLE_DET       0x8		/* Babble detected */
178012771d8Swdenk #define USB_ST_NAK_REC          0x10	/* NAK Received*/
179012771d8Swdenk #define USB_ST_CRC_ERR          0x20	/* CRC/timeout Error */
180012771d8Swdenk #define USB_ST_BIT_ERR          0x40	/* Bitstuff error */
181012771d8Swdenk #define USB_ST_NOT_PROC         0x80000000L	/* Not yet processed */
182012771d8Swdenk 
183012771d8Swdenk 
184012771d8Swdenk /*************************************************************************
185012771d8Swdenk  * Hub defines
186012771d8Swdenk  */
187012771d8Swdenk 
188012771d8Swdenk /*
189012771d8Swdenk  * Hub request types
190012771d8Swdenk  */
191012771d8Swdenk 
192012771d8Swdenk #define USB_RT_HUB	(USB_TYPE_CLASS | USB_RECIP_DEVICE)
193012771d8Swdenk #define USB_RT_PORT	(USB_TYPE_CLASS | USB_RECIP_OTHER)
194012771d8Swdenk 
195012771d8Swdenk /*
196012771d8Swdenk  * Hub Class feature numbers
197012771d8Swdenk  */
198012771d8Swdenk #define C_HUB_LOCAL_POWER   0
199012771d8Swdenk #define C_HUB_OVER_CURRENT  1
200012771d8Swdenk 
201012771d8Swdenk /*
202012771d8Swdenk  * Port feature numbers
203012771d8Swdenk  */
204012771d8Swdenk #define USB_PORT_FEAT_CONNECTION     0
205012771d8Swdenk #define USB_PORT_FEAT_ENABLE         1
206012771d8Swdenk #define USB_PORT_FEAT_SUSPEND        2
207012771d8Swdenk #define USB_PORT_FEAT_OVER_CURRENT   3
208012771d8Swdenk #define USB_PORT_FEAT_RESET          4
209012771d8Swdenk #define USB_PORT_FEAT_POWER          8
210012771d8Swdenk #define USB_PORT_FEAT_LOWSPEED       9
211*3e126484SMichael Trimarchi #define USB_PORT_FEAT_HIGHSPEED      10
212012771d8Swdenk #define USB_PORT_FEAT_C_CONNECTION   16
213012771d8Swdenk #define USB_PORT_FEAT_C_ENABLE       17
214012771d8Swdenk #define USB_PORT_FEAT_C_SUSPEND      18
215012771d8Swdenk #define USB_PORT_FEAT_C_OVER_CURRENT 19
216012771d8Swdenk #define USB_PORT_FEAT_C_RESET        20
217012771d8Swdenk 
218012771d8Swdenk /* wPortStatus bits */
219012771d8Swdenk #define USB_PORT_STAT_CONNECTION    0x0001
220012771d8Swdenk #define USB_PORT_STAT_ENABLE        0x0002
221012771d8Swdenk #define USB_PORT_STAT_SUSPEND       0x0004
222012771d8Swdenk #define USB_PORT_STAT_OVERCURRENT   0x0008
223012771d8Swdenk #define USB_PORT_STAT_RESET         0x0010
224012771d8Swdenk #define USB_PORT_STAT_POWER         0x0100
225012771d8Swdenk #define USB_PORT_STAT_LOW_SPEED     0x0200
226*3e126484SMichael Trimarchi #define USB_PORT_STAT_HIGH_SPEED    0x0400	/* support for EHCI */
227*3e126484SMichael Trimarchi #define USB_PORT_STAT_SPEED	\
228*3e126484SMichael Trimarchi 	(USB_PORT_STAT_LOW_SPEED | USB_PORT_STAT_HIGH_SPEED)
229012771d8Swdenk 
230012771d8Swdenk /* wPortChange bits */
231012771d8Swdenk #define USB_PORT_STAT_C_CONNECTION  0x0001
232012771d8Swdenk #define USB_PORT_STAT_C_ENABLE      0x0002
233012771d8Swdenk #define USB_PORT_STAT_C_SUSPEND     0x0004
234012771d8Swdenk #define USB_PORT_STAT_C_OVERCURRENT 0x0008
235012771d8Swdenk #define USB_PORT_STAT_C_RESET       0x0010
236012771d8Swdenk 
237012771d8Swdenk /* wHubCharacteristics (masks) */
238012771d8Swdenk #define HUB_CHAR_LPSM               0x0003
239012771d8Swdenk #define HUB_CHAR_COMPOUND           0x0004
240012771d8Swdenk #define HUB_CHAR_OCPM               0x0018
241012771d8Swdenk 
242012771d8Swdenk /*
243012771d8Swdenk  *Hub Status & Hub Change bit masks
244012771d8Swdenk  */
245012771d8Swdenk #define HUB_STATUS_LOCAL_POWER	0x0001
246012771d8Swdenk #define HUB_STATUS_OVERCURRENT	0x0002
247012771d8Swdenk 
248012771d8Swdenk #define HUB_CHANGE_LOCAL_POWER	0x0001
249012771d8Swdenk #define HUB_CHANGE_OVERCURRENT	0x0002
250012771d8Swdenk 
251012771d8Swdenk #endif /*_USB_DEFS_H_ */
252