summaryrefslogtreecommitdiffstats
path: root/freebsd/sys/dev/usb/serial/uftdi_reg.h
blob: a1ea325b89a26c4387442477311456a003a152e1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
/*	$NetBSD: uftdireg.h,v 1.6 2002/07/11 21:14:28 augustss Exp $ */
/*	$FreeBSD$	*/

/*
 * Definitions for the FTDI USB Single Port Serial Converter -
 * known as FTDI_SIO (Serial Input/Output application of the chipset)
 *
 * The device is based on the FTDI FT8U100AX chip. It has a DB25 on one side,
 * USB on the other.
 *
 * Thanx to FTDI (http://www.ftdi.co.uk) for so kindly providing details
 * of the protocol required to talk to the device and ongoing assistence
 * during development.
 *
 * Bill Ryder - bryder@sgi.com of Silicon Graphics, Inc. is the original
 * author of this file.
 */
/* Modified by Lennart Augustsson */

/* Vendor Request Interface */
#define	FTDI_SIO_RESET 		0	/* Reset the port */
#define	FTDI_SIO_MODEM_CTRL 	1	/* Set the modem control register */
#define	FTDI_SIO_SET_FLOW_CTRL	2	/* Set flow control register */
#define	FTDI_SIO_SET_BAUD_RATE	3	/* Set baud rate */
#define	FTDI_SIO_SET_DATA	4	/* Set the data characteristics of the
					 * port */
#define	FTDI_SIO_GET_STATUS	5	/* Retrieve current value of status
					 * reg */
#define	FTDI_SIO_SET_EVENT_CHAR	6	/* Set the event character */
#define	FTDI_SIO_SET_ERROR_CHAR	7	/* Set the error character */
#define	FTDI_SIO_SET_LATENCY	9	/* Set the latency timer */
#define	FTDI_SIO_GET_LATENCY	10	/* Read the latency timer */
#define	FTDI_SIO_SET_BITMODE	11	/* Set the bit bang I/O mode */
#define	FTDI_SIO_GET_BITMODE	12	/* Read pin states from any mode */
#define	FTDI_SIO_READ_EEPROM	144	/* Read eeprom word */
#define	FTDI_SIO_WRITE_EEPROM	145	/* Write eeprom word */
#define	FTDI_SIO_ERASE_EEPROM	146	/* Erase entire eeprom */

/* Port Identifier Table */
#define	FTDI_PIT_DEFAULT 	0	/* SIOA */
#define	FTDI_PIT_SIOA		1	/* SIOA */
#define	FTDI_PIT_SIOB		2	/* SIOB */
#define	FTDI_PIT_PARALLEL	3	/* Parallel */

/* Values for driver_info */
#define	UFTDI_JTAG_IFACE(i)	(1 << i)	/* Flag interface as jtag */
#define	UFTDI_JTAG_IFACES_MAX	8		/* Allow up to 8 jtag intfs */
#define	UFTDI_JTAG_CHECK_STRING	0xff		/* Check product names table */
#define	UFTDI_JTAG_MASK		0xff

/*
 * BmRequestType:  0100 0000B
 * bRequest:       FTDI_SIO_RESET
 * wValue:         Control Value
 *                   0 = Reset SIO
 *                   1 = Purge RX buffer
 *                   2 = Purge TX buffer
 * wIndex:         Port
 * wLength:        0
 * Data:           None
 *
 * The Reset SIO command has this effect:
 *
 *    Sets flow control set to 'none'
 *    Event char = 0x0d
 *    Event trigger = disabled
 *    Purge RX buffer
 *    Purge TX buffer
 *    Clear DTR
 *    Clear RTS
 *    baud and data format not reset
 *
 * The Purge RX and TX buffer commands affect nothing except the buffers
 */
/* FTDI_SIO_RESET */
#define	FTDI_SIO_RESET_SIO 0
#define	FTDI_SIO_RESET_PURGE_RX 1
#define	FTDI_SIO_RESET_PURGE_TX 2

/*
 * BmRequestType:  0100 0000B
 * bRequest:       FTDI_SIO_SET_BAUDRATE
 * wValue:         BaudRate low bits
 * wIndex:         Port and BaudRate high bits 
 * wLength:        0
 * Data:           None
 */
/* FTDI_SIO_SET_BAUDRATE */

/*
 * BmRequestType:  0100 0000B
 * bRequest:       FTDI_SIO_SET_DATA
 * wValue:         Data characteristics (see below)
 * wIndex:         Port
 * wLength:        0
 * Data:           No
 *
 * Data characteristics
 *
 *   B0..7   Number of data bits
 *   B8..10  Parity
 *           0 = None
 *           1 = Odd
 *           2 = Even
 *           3 = Mark
 *           4 = Space
 *   B11..13 Stop Bits
 *           0 = 1
 *           1 = 1.5
 *           2 = 2
 *   B14..15 Reserved
 *
 */
/* FTDI_SIO_SET_DATA */
#define	FTDI_SIO_SET_DATA_BITS(n) (n)
#define	FTDI_SIO_SET_DATA_PARITY_NONE (0x0 << 8)
#define	FTDI_SIO_SET_DATA_PARITY_ODD (0x1 << 8)
#define	FTDI_SIO_SET_DATA_PARITY_EVEN (0x2 << 8)
#define	FTDI_SIO_SET_DATA_PARITY_MARK (0x3 << 8)
#define	FTDI_SIO_SET_DATA_PARITY_SPACE (0x4 << 8)
#define	FTDI_SIO_SET_DATA_STOP_BITS_1 (0x0 << 11)
#define	FTDI_SIO_SET_DATA_STOP_BITS_15 (0x1 << 11)
#define	FTDI_SIO_SET_DATA_STOP_BITS_2 (0x2 << 11)
#define	FTDI_SIO_SET_BREAK (0x1 << 14)

/*
 * BmRequestType:   0100 0000B
 * bRequest:        FTDI_SIO_MODEM_CTRL
 * wValue:          ControlValue (see below)
 * wIndex:          Port
 * wLength:         0
 * Data:            None
 *
 * NOTE: If the device is in RTS/CTS flow control, the RTS set by this
 * command will be IGNORED without an error being returned
 * Also - you can not set DTR and RTS with one control message
 *
 * ControlValue
 * B0    DTR state
 *          0 = reset
 *          1 = set
 * B1    RTS state
 *          0 = reset
 *          1 = set
 * B2..7 Reserved
 * B8    DTR state enable
 *          0 = ignore
 *          1 = use DTR state
 * B9    RTS state enable
 *          0 = ignore
 *          1 = use RTS state
 * B10..15 Reserved
 */
/* FTDI_SIO_MODEM_CTRL */
#define	FTDI_SIO_SET_DTR_MASK 0x1
#define	FTDI_SIO_SET_DTR_HIGH (1 | ( FTDI_SIO_SET_DTR_MASK  << 8))
#define	FTDI_SIO_SET_DTR_LOW  (0 | ( FTDI_SIO_SET_DTR_MASK  << 8))
#define	FTDI_SIO_SET_RTS_MASK 0x2
#define	FTDI_SIO_SET_RTS_HIGH (2 | ( FTDI_SIO_SET_RTS_MASK << 8))
#define	FTDI_SIO_SET_RTS_LOW (0 | ( FTDI_SIO_SET_RTS_MASK << 8))

/*
 *   BmRequestType:  0100 0000b
 *   bRequest:       FTDI_SIO_SET_FLOW_CTRL
 *   wValue:         Xoff/Xon
 *   wIndex:         Protocol/Port - hIndex is protocol / lIndex is port
 *   wLength:        0
 *   Data:           None
 *
 * hIndex protocol is:
 *   B0 Output handshaking using RTS/CTS
 *       0 = disabled
 *       1 = enabled
 *   B1 Output handshaking using DTR/DSR
 *       0 = disabled
 *       1 = enabled
 *   B2 Xon/Xoff handshaking
 *       0 = disabled
 *       1 = enabled
 *
 * A value of zero in the hIndex field disables handshaking
 *
 * If Xon/Xoff handshaking is specified, the hValue field should contain the
 * XOFF character and the lValue field contains the XON character.
 */
/* FTDI_SIO_SET_FLOW_CTRL */
#define	FTDI_SIO_DISABLE_FLOW_CTRL 0x0
#define	FTDI_SIO_RTS_CTS_HS 0x1
#define	FTDI_SIO_DTR_DSR_HS 0x2
#define	FTDI_SIO_XON_XOFF_HS 0x4

/*
 *  BmRequestType:   0100 0000b
 *  bRequest:        FTDI_SIO_SET_EVENT_CHAR
 *  wValue:          Event Char
 *  wIndex:          Port
 *  wLength:         0
 *  Data:            None
 *
 * wValue:
 *   B0..7   Event Character
 *   B8      Event Character Processing
 *             0 = disabled
 *             1 = enabled
 *   B9..15  Reserved
 *
 * FTDI_SIO_SET_EVENT_CHAR
 *
 * Set the special event character for the specified communications port.
 * If the device sees this character it will immediately return the
 * data read so far - rather than wait 40ms or until 62 bytes are read
 * which is what normally happens.
 */

/*
 *  BmRequestType:  0100 0000b
 *  bRequest:       FTDI_SIO_SET_ERROR_CHAR
 *  wValue:         Error Char
 *  wIndex:         Port
 *  wLength:        0
 *  Data:           None
 *
 *  Error Char
 *  B0..7  Error Character
 *  B8     Error Character Processing
 *           0 = disabled
 *           1 = enabled
 *  B9..15 Reserved
 * FTDI_SIO_SET_ERROR_CHAR
 * Set the parity error replacement character for the specified communications
 * port.
 */

/*
 *   BmRequestType:   1100 0000b
 *   bRequest:        FTDI_SIO_GET_MODEM_STATUS
 *   wValue:          zero
 *   wIndex:          Port
 *   wLength:         1
 *   Data:            Status
 *
 * One byte of data is returned
 * B0..3 0
 * B4    CTS
 *         0 = inactive
 *         1 = active
 * B5    DSR
 *         0 = inactive
 *         1 = active
 * B6    Ring Indicator (RI)
 *         0 = inactive
 *         1 = active
 * B7    Receive Line Signal Detect (RLSD)
 *         0 = inactive
 *         1 = active
 *
 * FTDI_SIO_GET_MODEM_STATUS
 * Retrieve the current value of the modem status register.
 */
#define	FTDI_SIO_CTS_MASK 0x10
#define	FTDI_SIO_DSR_MASK 0x20
#define	FTDI_SIO_RI_MASK  0x40
#define	FTDI_SIO_RLSD_MASK 0x80

/*
 * DATA FORMAT
 *
 * IN Endpoint
 *
 * The device reserves the first two bytes of data on this endpoint to contain
 * the current values of the modem and line status registers. In the absence of
 * data, the device generates a message consisting of these two status bytes
 * every 40 ms.
 *
 * Byte 0: Modem Status
 *   NOTE: 4 upper bits have same layout as the MSR register in a 16550
 *
 * Offset	Description
 * B0..3	Port
 * B4		Clear to Send (CTS)
 * B5		Data Set Ready (DSR)
 * B6		Ring Indicator (RI)
 * B7		Receive Line Signal Detect (RLSD)
 *
 * Byte 1: Line Status
 *   NOTE: same layout as the LSR register in a 16550
 *
 * Offset	Description
 * B0	Data Ready (DR)
 * B1	Overrun Error (OE)
 * B2	Parity Error (PE)
 * B3	Framing Error (FE)
 * B4	Break Interrupt (BI)
 * B5	Transmitter Holding Register (THRE)
 * B6	Transmitter Empty (TEMT)
 * B7	Error in RCVR FIFO
 * OUT Endpoint
 *
 * This device reserves the first bytes of data on this endpoint contain the
 * length and port identifier of the message. For the FTDI USB Serial converter
 * the port identifier is always 1.
 *
 * Byte 0: Port & length
 *
 * Offset	Description
 * B0..1	Port
 * B2..7	Length of message - (not including Byte 0)
 */
#define	FTDI_PORT_MASK 0x0f
#define	FTDI_MSR_MASK 0xf0
#define	FTDI_GET_MSR(p) (((p)[0]) & FTDI_MSR_MASK)
#define	FTDI_GET_LSR(p) ((p)[1])
#define	FTDI_LSR_MASK (~0x60)		/* interesting bits */
#define	FTDI_OUT_TAG(len, port) (((len) << 2) | (port))