blob: ce6fb081e355a32620189469dd24a4a3e643d3c0 [file] [log] [blame]
Max Filippovba7651f2017-01-25 10:54:11 -08001/*
2 * include/asm-xtensa/termbits.h
3 *
4 * Copied from SH.
5 *
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
8 * for more details.
9 *
10 * Copyright (C) 2001 - 2005 Tensilica Inc.
11 */
12
Markus Armbrustera8b991b2019-03-15 15:51:21 +010013#ifndef XTENSA_TERMBITS_H
14#define XTENSA_TERMBITS_H
Max Filippovba7651f2017-01-25 10:54:11 -080015
16#include <linux/posix_types.h>
17
Max Filippovba7651f2017-01-25 10:54:11 -080018#define TARGET_NCCS 19
Filip Bozutac218b4e2020-07-23 23:02:32 +020019
20typedef unsigned char target_cc_t; /* cc_t */
21typedef unsigned int target_speed_t; /* speed_t */
22typedef unsigned int target_tcflag_t; /* tcflag_t */
23
Max Filippovba7651f2017-01-25 10:54:11 -080024struct target_termios {
Filip Bozutac218b4e2020-07-23 23:02:32 +020025 target_tcflag_t c_iflag; /* input mode flags */
26 target_tcflag_t c_oflag; /* output mode flags */
27 target_tcflag_t c_cflag; /* control mode flags */
28 target_tcflag_t c_lflag; /* local mode flags */
29 target_cc_t c_line; /* line discipline */
30 target_cc_t c_cc[TARGET_NCCS]; /* control characters */
Max Filippovba7651f2017-01-25 10:54:11 -080031};
32
Filip Bozutac218b4e2020-07-23 23:02:32 +020033
Max Filippovba7651f2017-01-25 10:54:11 -080034struct target_termios2 {
Filip Bozutac218b4e2020-07-23 23:02:32 +020035 target_tcflag_t c_iflag; /* input mode flags */
36 target_tcflag_t c_oflag; /* output mode flags */
37 target_tcflag_t c_cflag; /* control mode flags */
38 target_tcflag_t c_lflag; /* local mode flags */
39 target_cc_t c_line; /* line discipline */
40 target_cc_t c_cc[TARGET_NCCS]; /* control characters */
41 target_speed_t c_ispeed; /* input speed */
42 target_speed_t c_ospeed; /* output speed */
Max Filippovba7651f2017-01-25 10:54:11 -080043};
44
45struct target_ktermios {
Filip Bozutac218b4e2020-07-23 23:02:32 +020046 target_tcflag_t c_iflag; /* input mode flags */
47 target_tcflag_t c_oflag; /* output mode flags */
48 target_tcflag_t c_cflag; /* control mode flags */
49 target_tcflag_t c_lflag; /* local mode flags */
50 target_cc_t c_line; /* line discipline */
51 target_cc_t c_cc[TARGET_NCCS]; /* control characters */
52 target_speed_t c_ispeed; /* input speed */
53 target_speed_t c_ospeed; /* output speed */
Max Filippovba7651f2017-01-25 10:54:11 -080054};
55
56/* c_cc characters */
57
58#define TARGET_VINTR 0
59#define TARGET_VQUIT 1
60#define TARGET_VERASE 2
61#define TARGET_VKILL 3
62#define TARGET_VEOF 4
63#define TARGET_VTIME 5
64#define TARGET_VMIN 6
65#define TARGET_VSWTC 7
66#define TARGET_VSTART 8
67#define TARGET_VSTOP 9
68#define TARGET_VSUSP 10
69#define TARGET_VEOL 11
70#define TARGET_VREPRINT 12
71#define TARGET_VDISCARD 13
72#define TARGET_VWERASE 14
73#define TARGET_VLNEXT 15
74#define TARGET_VEOL2 16
75
76/* c_iflag bits */
77
78#define TARGET_IGNBRK 0000001
79#define TARGET_BRKINT 0000002
80#define TARGET_IGNPAR 0000004
81#define TARGET_PARMRK 0000010
82#define TARGET_INPCK 0000020
83#define TARGET_ISTRIP 0000040
84#define TARGET_INLCR 0000100
85#define TARGET_IGNCR 0000200
86#define TARGET_ICRNL 0000400
87#define TARGET_IUCLC 0001000
88#define TARGET_IXON 0002000
89#define TARGET_IXANY 0004000
90#define TARGET_IXOFF 0010000
91#define TARGET_IMAXBEL 0020000
92#define TARGET_IUTF8 0040000
93
94/* c_oflag bits */
95
96#define TARGET_OPOST 0000001
97#define TARGET_OLCUC 0000002
98#define TARGET_ONLCR 0000004
99#define TARGET_OCRNL 0000010
100#define TARGET_ONOCR 0000020
101#define TARGET_ONLRET 0000040
102#define TARGET_OFILL 0000100
103#define TARGET_OFDEL 0000200
104#define TARGET_NLDLY 0000400
105#define TARGET_NL0 0000000
106#define TARGET_NL1 0000400
107#define TARGET_CRDLY 0003000
108#define TARGET_CR0 0000000
109#define TARGET_CR1 0001000
110#define TARGET_CR2 0002000
111#define TARGET_CR3 0003000
112#define TARGET_TABDLY 0014000
113#define TARGET_TAB0 0000000
114#define TARGET_TAB1 0004000
115#define TARGET_TAB2 0010000
116#define TARGET_TAB3 0014000
117#define TARGET_XTABS 0014000
118#define TARGET_BSDLY 0020000
119#define TARGET_BS0 0000000
120#define TARGET_BS1 0020000
121#define TARGET_VTDLY 0040000
122#define TARGET_VT0 0000000
123#define TARGET_VT1 0040000
124#define TARGET_FFDLY 0100000
125#define TARGET_FF0 0000000
126#define TARGET_FF1 0100000
127
128/* c_cflag bit meaning */
129
130#define TARGET_CBAUD 0010017
131#define TARGET_B0 0000000 /* hang up */
132#define TARGET_B50 0000001
133#define TARGET_B75 0000002
134#define TARGET_B110 0000003
135#define TARGET_B134 0000004
136#define TARGET_B150 0000005
137#define TARGET_B200 0000006
138#define TARGET_B300 0000007
139#define TARGET_B600 0000010
140#define TARGET_B1200 0000011
141#define TARGET_B1800 0000012
142#define TARGET_B2400 0000013
143#define TARGET_B4800 0000014
144#define TARGET_B9600 0000015
145#define TARGET_B19200 0000016
146#define TARGET_B38400 0000017
147#define TARGET_EXTA B19200
148#define TARGET_EXTB B38400
149#define TARGET_CSIZE 0000060
150#define TARGET_CS5 0000000
151#define TARGET_CS6 0000020
152#define TARGET_CS7 0000040
153#define TARGET_CS8 0000060
154#define TARGET_CSTOPB 0000100
155#define TARGET_CREAD 0000200
156#define TARGET_PARENB 0000400
157#define TARGET_PARODD 0001000
158#define TARGET_HUPCL 0002000
159#define TARGET_CLOCAL 0004000
160#define TARGET_CBAUDEX 0010000
161#define TARGET_BOTHER 0010000
162#define TARGET_B57600 0010001
163#define TARGET_B115200 0010002
164#define TARGET_B230400 0010003
165#define TARGET_B460800 0010004
166#define TARGET_B500000 0010005
167#define TARGET_B576000 0010006
168#define TARGET_B921600 0010007
169#define TARGET_B1000000 0010010
170#define TARGET_B1152000 0010011
171#define TARGET_B1500000 0010012
172#define TARGET_B2000000 0010013
173#define TARGET_B2500000 0010014
174#define TARGET_B3000000 0010015
175#define TARGET_B3500000 0010016
176#define TARGET_B4000000 0010017
177#define TARGET_CIBAUD 002003600000 /* input baud rate */
178#define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */
179#define TARGET_CRTSCTS 020000000000 /* flow control */
180
181#define TARGET_IBSHIFT 16 /* Shift from CBAUD to CIBAUD */
182
183/* c_lflag bits */
184
185#define TARGET_ISIG 0000001
186#define TARGET_ICANON 0000002
187#define TARGET_XCASE 0000004
188#define TARGET_ECHO 0000010
189#define TARGET_ECHOE 0000020
190#define TARGET_ECHOK 0000040
191#define TARGET_ECHONL 0000100
192#define TARGET_NOFLSH 0000200
193#define TARGET_TOSTOP 0000400
194#define TARGET_ECHOCTL 0001000
195#define TARGET_ECHOPRT 0002000
196#define TARGET_ECHOKE 0004000
197#define TARGET_FLUSHO 0010000
198#define TARGET_PENDIN 0040000
199#define TARGET_IEXTEN 0100000
Filip Bozutac218b4e2020-07-23 23:02:32 +0200200#define TARGET_EXTPROC 0200000
Max Filippovba7651f2017-01-25 10:54:11 -0800201
202/* tcflow() and TCXONC use these */
203
204#define TARGET_TCOOFF 0
205#define TARGET_TCOON 1
206#define TARGET_TCIOFF 2
207#define TARGET_TCION 3
208
209/* tcflush() and TCFLSH use these */
210
211#define TARGET_TCIFLUSH 0
212#define TARGET_TCOFLUSH 1
213#define TARGET_TCIOFLUSH 2
214
215/* tcsetattr uses these */
216
217#define TARGET_TCSANOW 0
218#define TARGET_TCSADRAIN 1
219#define TARGET_TCSAFLUSH 2
220
221/* from arch/xtensa/include/uapi/asm/ioctls.h */
222
223#define TARGET_FIOCLEX _IO('f', 1)
224#define TARGET_FIONCLEX _IO('f', 2)
225#define TARGET_FIOASYNC _IOW('f', 125, int)
226#define TARGET_FIONBIO _IOW('f', 126, int)
227#define TARGET_FIONREAD _IOR('f', 127, int)
228#define TARGET_TIOCINQ FIONREAD
229#define TARGET_FIOQSIZE _IOR('f', 128, loff_t)
230
231#define TARGET_TCGETS 0x5401
232#define TARGET_TCSETS 0x5402
233#define TARGET_TCSETSW 0x5403
234#define TARGET_TCSETSF 0x5404
235
236#define TARGET_TCGETA 0x80127417 /* _IOR('t', 23, struct termio) */
237#define TARGET_TCSETA 0x40127418 /* _IOW('t', 24, struct termio) */
238#define TARGET_TCSETAW 0x40127419 /* _IOW('t', 25, struct termio) */
239#define TARGET_TCSETAF 0x4012741C /* _IOW('t', 28, struct termio) */
240
241#define TARGET_TCSBRK _IO('t', 29)
242#define TARGET_TCXONC _IO('t', 30)
243#define TARGET_TCFLSH _IO('t', 31)
244
245#define TARGET_TIOCSWINSZ 0x40087467 /* _IOW('t', 103, struct winsize) */
246#define TARGET_TIOCGWINSZ 0x80087468 /* _IOR('t', 104, struct winsize) */
247#define TARGET_TIOCSTART _IO('t', 110) /* start output, like ^Q */
248#define TARGET_TIOCSTOP _IO('t', 111) /* stop output, like ^S */
249#define TARGET_TIOCOUTQ _IOR('t', 115, int) /* output queue size */
250
251#define TARGET_TIOCSPGRP _IOW('t', 118, int)
252#define TARGET_TIOCGPGRP _IOR('t', 119, int)
253
254#define TARGET_TIOCEXCL _IO('T', 12)
255#define TARGET_TIOCNXCL _IO('T', 13)
256#define TARGET_TIOCSCTTY _IO('T', 14)
257
258#define TARGET_TIOCSTI _IOW('T', 18, char)
259#define TARGET_TIOCMGET _IOR('T', 21, unsigned int)
260#define TARGET_TIOCMBIS _IOW('T', 22, unsigned int)
261#define TARGET_TIOCMBIC _IOW('T', 23, unsigned int)
262#define TARGET_TIOCMSET _IOW('T', 24, unsigned int)
263# define TARGET_TIOCM_LE 0x001
264# define TARGET_TIOCM_DTR 0x002
265# define TARGET_TIOCM_RTS 0x004
266# define TARGET_TIOCM_ST 0x008
267# define TARGET_TIOCM_SR 0x010
268# define TARGET_TIOCM_CTS 0x020
269# define TARGET_TIOCM_CAR 0x040
270# define TARGET_TIOCM_RNG 0x080
271# define TARGET_TIOCM_DSR 0x100
272# define TARGET_TIOCM_CD TIOCM_CAR
273# define TARGET_TIOCM_RI TIOCM_RNG
274
275#define TARGET_TIOCGSOFTCAR _IOR('T', 25, unsigned int)
276#define TARGET_TIOCSSOFTCAR _IOW('T', 26, unsigned int)
277#define TARGET_TIOCLINUX _IOW('T', 28, char)
278#define TARGET_TIOCCONS _IO('T', 29)
279#define TARGET_TIOCGSERIAL 0x803C541E /*_IOR('T', 30, struct serial_struct)*/
280#define TARGET_TIOCSSERIAL 0x403C541F /*_IOW('T', 31, struct serial_struct)*/
281#define TARGET_TIOCPKT _IOW('T', 32, int)
282# define TARGET_TIOCPKT_DATA 0
283# define TARGET_TIOCPKT_FLUSHREAD 1
284# define TARGET_TIOCPKT_FLUSHWRITE 2
285# define TARGET_TIOCPKT_STOP 4
286# define TARGET_TIOCPKT_START 8
287# define TARGET_TIOCPKT_NOSTOP 16
288# define TARGET_TIOCPKT_DOSTOP 32
289# define TARGET_TIOCPKT_IOCTL 64
290
291
292#define TARGET_TIOCNOTTY _IO('T', 34)
293#define TARGET_TIOCSETD _IOW('T', 35, int)
294#define TARGET_TIOCGETD _IOR('T', 36, int)
295#define TARGET_TCSBRKP _IOW('T', 37, int) /* Needed for POSIX tcsendbreak()*/
296#define TARGET_TIOCSBRK _IO('T', 39) /* BSD compatibility */
297#define TARGET_TIOCCBRK _IO('T', 40) /* BSD compatibility */
298#define TARGET_TIOCGSID _IOR('T', 41, pid_t) /* Return the session ID of FD*/
299#define TARGET_TCGETS2 _IOR('T', 42, struct termios2)
300#define TARGET_TCSETS2 _IOW('T', 43, struct termios2)
301#define TARGET_TCSETSW2 _IOW('T', 44, struct termios2)
302#define TARGET_TCSETSF2 _IOW('T', 45, struct termios2)
303#define TARGET_TIOCGRS485 _IOR('T', 46, struct serial_rs485)
304#define TARGET_TIOCSRS485 _IOWR('T', 47, struct serial_rs485)
305#define TARGET_TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
306#define TARGET_TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */
307#define TARGET_TIOCGDEV _IOR('T',0x32, unsigned int) /* Get primary device node of /dev/console */
308#define TARGET_TIOCSIG _IOW('T',0x36, int) /* Generate signal on Pty slave */
309#define TARGET_TIOCVHANGUP _IO('T', 0x37)
310#define TARGET_TIOCGPKT _IOR('T', 0x38, int) /* Get packet mode state */
311#define TARGET_TIOCGPTLCK _IOR('T', 0x39, int) /* Get Pty lock state */
312#define TARGET_TIOCGEXCL _IOR('T', 0x40, int) /* Get exclusive mode state */
313#define TARGET_TIOCGPTPEER _IO('T', 0x41) /* Safely open the slave */
314
315#define TARGET_TIOCSERCONFIG _IO('T', 83)
316#define TARGET_TIOCSERGWILD _IOR('T', 84, int)
317#define TARGET_TIOCSERSWILD _IOW('T', 85, int)
318#define TARGET_TIOCGLCKTRMIOS 0x5456
319#define TARGET_TIOCSLCKTRMIOS 0x5457
320#define TARGET_TIOCSERGSTRUCT 0x5458 /* For debugging only */
321#define TARGET_TIOCSERGETLSR _IOR('T', 89, unsigned int) /* Get line status reg. */
322/* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
323# define TARGET_TIOCSER_TEMT 0x01 /* Transmitter physically empty */
324#define TARGET_TIOCSERGETMULTI 0x80a8545a /* Get multiport config */
325/* _IOR('T', 90, struct serial_multiport_struct) */
326#define TARGET_TIOCSERSETMULTI 0x40a8545b /* Set multiport config */
327/* _IOW('T', 91, struct serial_multiport_struct) */
328
329#define TARGET_TIOCMIWAIT _IO('T', 92) /* wait for a change on serial input line(s) */
330#define TARGET_TIOCGICOUNT 0x545D /* read serial port inline interrupt counts */
Markus Armbrustera8b991b2019-03-15 15:51:21 +0100331#endif /* XTENSA_TERMBITS_H */