xref: /qemu/linux-user/xtensa/termbits.h (revision e3a6e0da)
1 /*
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 
13 #ifndef XTENSA_TERMBITS_H
14 #define XTENSA_TERMBITS_H
15 
16 #include <linux/posix_types.h>
17 
18 #define TARGET_NCCS 19
19 
20 typedef unsigned char   target_cc_t;        /* cc_t */
21 typedef unsigned int    target_speed_t;     /* speed_t */
22 typedef unsigned int    target_tcflag_t;    /* tcflag_t */
23 
24 struct target_termios {
25     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 */
31 };
32 
33 
34 struct target_termios2 {
35     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 */
43 };
44 
45 struct target_ktermios {
46     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 */
54 };
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
200 #define TARGET_EXTPROC  0200000
201 
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 */
331 #endif /* XTENSA_TERMBITS_H */
332