migration/rdma: Plug memory leaks in qemu_rdma_registration_stop()
[qemu/armbru.git] / linux-user / openrisc / termbits.h
blob7a635ffbc6feb17727f6a93969a5ece310680e67
1 #ifndef LINUX_USER_OPENRISC_TERMBITS_H
2 #define LINUX_USER_OPENRISC_TERMBITS_H
4 typedef unsigned char target_openrisc_cc; /*cc_t*/
5 typedef unsigned int target_openrisc_speed; /*speed_t*/
6 typedef unsigned int target_openrisc_tcflag; /*tcflag_t*/
8 #define TARGET_NCCS 19
9 struct target_termios {
10 target_openrisc_tcflag c_iflag; /* input mode flags */
11 target_openrisc_tcflag c_oflag; /* output mode flags */
12 target_openrisc_tcflag c_cflag; /* control mode flags */
13 target_openrisc_tcflag c_lflag; /* local mode flags */
14 target_openrisc_cc c_line; /* line discipline */
15 target_openrisc_cc c_cc[TARGET_NCCS]; /* control characters */
18 struct target_termios2 {
19 target_openrisc_tcflag c_iflag; /* input mode flags */
20 target_openrisc_tcflag c_oflag; /* output mode flags */
21 target_openrisc_tcflag c_cflag; /* control mode flags */
22 target_openrisc_tcflag c_lflag; /* local mode flags */
23 target_openrisc_cc c_line; /* line discipline */
24 target_openrisc_cc c_cc[TARGET_NCCS]; /* control characters */
25 target_openrisc_speed c_ispeed; /* input speed */
26 target_openrisc_speed c_ospeed; /* output speed */
29 struct target_termios3 {
30 target_openrisc_tcflag c_iflag; /* input mode flags */
31 target_openrisc_tcflag c_oflag; /* output mode flags */
32 target_openrisc_tcflag c_cflag; /* control mode flags */
33 target_openrisc_tcflag c_lflag; /* local mode flags */
34 target_openrisc_cc c_line; /* line discipline */
35 target_openrisc_cc c_cc[TARGET_NCCS]; /* control characters */
36 target_openrisc_speed c_ispeed; /* input speed */
37 target_openrisc_speed c_ospeed; /* output speed */
40 /* c_cc characters */
41 #define TARGET_VINTR 0
42 #define TARGET_VQUIT 1
43 #define TARGET_VERASE 2
44 #define TARGET_VKILL 3
45 #define TARGET_VEOF 4
46 #define TARGET_VTIME 5
47 #define TARGET_VMIN 6
48 #define TARGET_VSWTC 7
49 #define TARGET_VSTART 8
50 #define TARGET_VSTOP 9
51 #define TARGET_VSUSP 10
52 #define TARGET_VEOL 11
53 #define TARGET_VREPRINT 12
54 #define TARGET_VDISCARD 13
55 #define TARGET_VWERASE 14
56 #define TARGET_VLNEXT 15
57 #define TARGET_VEOL2 16
59 /* c_iflag bits */
60 #define TARGET_IGNBRK 0000001
61 #define TARGET_BRKINT 0000002
62 #define TARGET_IGNPAR 0000004
63 #define TARGET_PARMRK 0000010
64 #define TARGET_INPCK 0000020
65 #define TARGET_ISTRIP 0000040
66 #define TARGET_INLCR 0000100
67 #define TARGET_IGNCR 0000200
68 #define TARGET_ICRNL 0000400
69 #define TARGET_IUCLC 0001000
70 #define TARGET_IXON 0002000
71 #define TARGET_IXANY 0004000
72 #define TARGET_IXOFF 0010000
73 #define TARGET_IMAXBEL 0020000
74 #define TARGET_IUTF8 0040000
76 /* c_oflag bits */
77 #define TARGET_OPOST 0000001
78 #define TARGET_OLCUC 0000002
79 #define TARGET_ONLCR 0000004
80 #define TARGET_OCRNL 0000010
81 #define TARGET_ONOCR 0000020
82 #define TARGET_ONLRET 0000040
83 #define TARGET_OFILL 0000100
84 #define TARGET_OFDEL 0000200
85 #define TARGET_NLDLY 0000400
86 #define TARGET_NL0 0000000
87 #define TARGET_NL1 0000400
88 #define TARGET_CRDLY 0003000
89 #define TARGET_CR0 0000000
90 #define TARGET_CR1 0001000
91 #define TARGET_CR2 0002000
92 #define TARGET_CR3 0003000
93 #define TARGET_TABDLY 0014000
94 #define TARGET_TAB0 0000000
95 #define TARGET_TAB1 0004000
96 #define TARGET_TAB2 0010000
97 #define TARGET_TAB3 0014000
98 #define TARGET_XTABS 0014000
99 #define TARGET_BSDLY 0020000
100 #define TARGET_BS0 0000000
101 #define TARGET_BS1 0020000
102 #define TARGET_VTDLY 0040000
103 #define TARGET_VT0 0000000
104 #define TARGET_VT1 0040000
105 #define TARGET_FFDLY 0100000
106 #define TARGET_FF0 0000000
107 #define TARGET_FF1 0100000
109 /* c_cflag bit meaning */
110 #define TARGET_CBAUD 0010017
111 #define TARGET_B0 0000000 /* hang up */
112 #define TARGET_B50 0000001
113 #define TARGET_B75 0000002
114 #define TARGET_B110 0000003
115 #define TARGET_B134 0000004
116 #define TARGET_B150 0000005
117 #define TARGET_B200 0000006
118 #define TARGET_B300 0000007
119 #define TARGET_B600 0000010
120 #define TARGET_B1200 0000011
121 #define TARGET_B1800 0000012
122 #define TARGET_B2400 0000013
123 #define TARGET_B4800 0000014
124 #define TARGET_B9600 0000015
125 #define TARGET_B19200 0000016
126 #define TARGET_B38400 0000017
127 #define TARGET_EXTA B19200
128 #define TARGET_EXTB B38400
129 #define TARGET_CSIZE 0000060
130 #define TARGET_CS5 0000000
131 #define TARGET_CS6 0000020
132 #define TARGET_CS7 0000040
133 #define TARGET_CS8 0000060
134 #define TARGET_CSTOPB 0000100
135 #define TARGET_CREAD 0000200
136 #define TARGET_PARENB 0000400
137 #define TARGET_PARODD 0001000
138 #define TARGET_HUPCL 0002000
139 #define TARGET_CLOCAL 0004000
140 #define TARGET_CBAUDEX 0010000
141 #define TARGET_BOTHER 0010000
142 #define TARGET_B57600 0010001
143 #define TARGET_B115200 0010002
144 #define TARGET_B230400 0010003
145 #define TARGET_B460800 0010004
146 #define TARGET_B500000 0010005
147 #define TARGET_B576000 0010006
148 #define TARGET_B921600 0010007
149 #define TARGET_B1000000 0010010
150 #define TARGET_B1152000 0010011
151 #define TARGET_B1500000 0010012
152 #define TARGET_B2000000 0010013
153 #define TARGET_B2500000 0010014
154 #define TARGET_B3000000 0010015
155 #define TARGET_B3500000 0010016
156 #define TARGET_B4000000 0010017
157 #define TARGET_CIBAUD 002003600000 /* input baud rate */
158 #define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */
159 #define TARGET_CRTSCTS 020000000000 /* flow control */
161 #define TARGET_IBSHIFT 16 /* Shift from CBAUD to CIBAUD */
163 /* c_lflag bits */
164 #define TARGET_ISIG 0000001
165 #define TARGET_ICANON 0000002
166 #define TARGET_XCASE 0000004
167 #define TARGET_ECHO 0000010
168 #define TARGET_ECHOE 0000020
169 #define TARGET_ECHOK 0000040
170 #define TARGET_ECHONL 0000100
171 #define TARGET_NOFLSH 0000200
172 #define TARGET_TOSTOP 0000400
173 #define TARGET_ECHOCTL 0001000
174 #define TARGET_ECHOPRT 0002000
175 #define TARGET_ECHOKE 0004000
176 #define TARGET_FLUSHO 0010000
177 #define TARGET_PENDIN 0040000
178 #define TARGET_IEXTEN 0100000
179 #define TARGET_EXTPROC 0200000
181 /* tcflow() and TCXONC use these */
182 #define TARGET_TCOOFF 0
183 #define TARGET_TCOON 1
184 #define TARGET_TCIOFF 2
185 #define TARGET_TCION 3
187 /* tcflush() and TCFLSH use these */
188 #define TARGET_TCIFLUSH 0
189 #define TARGET_TCOFLUSH 1
190 #define TARGET_TCIOFLUSH 2
192 /* tcsetattr uses these */
193 #define TARGET_TCSANOW 0
194 #define TARGET_TCSADRAIN 1
195 #define TARGET_TCSAFLUSH 2
197 /* ioctls */
198 #define TARGET_TCGETS 0x5401
199 #define TARGET_TCSETS 0x5402
200 #define TARGET_TCSETSW 0x5403
201 #define TARGET_TCSETSF 0x5404
202 #define TARGET_TCGETA 0x5405
203 #define TARGET_TCSETA 0x5406
204 #define TARGET_TCSETAW 0x5407
205 #define TARGET_TCSETAF 0x5408
206 #define TARGET_TCSBRK 0x5409
207 #define TARGET_TCXONC 0x540A
208 #define TARGET_TCFLSH 0x540B
209 #define TARGET_TIOCEXCL 0x540C
210 #define TARGET_TIOCNXCL 0x540D
211 #define TARGET_TIOCSCTTY 0x540E
212 #define TARGET_TIOCGPGRP 0x540F
213 #define TARGET_TIOCSPGRP 0x5410
214 #define TARGET_TIOCOUTQ 0x5411
215 #define TARGET_TIOCSTI 0x5412
216 #define TARGET_TIOCGWINSZ 0x5413
217 #define TARGET_TIOCSWINSZ 0x5414
218 #define TARGET_TIOCMGET 0x5415
219 #define TARGET_TIOCMBIS 0x5416
220 #define TARGET_TIOCMBIC 0x5417
221 #define TARGET_TIOCMSET 0x5418
222 #define TARGET_TIOCGSOFTCAR 0x5419
223 #define TARGET_TIOCSSOFTCAR 0x541A
224 #define TARGET_FIONREAD 0x541B
225 #define TARGET_TIOCINQ FIONREAD
226 #define TARGET_TIOCLINUX 0x541C
227 #define TARGET_TIOCCONS 0x541D
228 #define TARGET_TIOCGSERIAL 0x541E
229 #define TARGET_TIOCSSERIAL 0x541F
230 #define TARGET_TIOCPKT 0x5420
231 #define TARGET_FIONBIO 0x5421
232 #define TARGET_TIOCNOTTY 0x5422
233 #define TARGET_TIOCSETD 0x5423
234 #define TARGET_TIOCGETD 0x5424
235 #define TARGET_TCSBRKP 0x5425 /* Needed for POSIX tcsendbreak() */
236 #define TARGET_TIOCSBRK 0x5427 /* BSD compatibility */
237 #define TARGET_TIOCCBRK 0x5428 /* BSD compatibility */
238 #define TARGET_TIOCGSID 0x5429 /* Return the session ID of FD */
239 #define TARGET_TCGETS2 TARGET_IOR('T', 0x2A, struct termios2)
240 #define TARGET_TCSETS2 TARGET_IOW('T', 0x2B, struct termios2)
241 #define TARGET_TCSETSW2 TARGET_IOW('T', 0x2C, struct termios2)
242 #define TARGET_TCSETSF2 TARGET_IOW('T', 0x2D, struct termios2)
243 #define TARGET_TIOCGRS485 0x542E
244 #ifndef TARGET_TIOCSRS485
245 #define TARGET_TIOCSRS485 0x542F
246 #endif
247 /* Get Pty Number (of pty-mux device) */
248 #define TARGET_TIOCGPTN TARGET_IOR('T', 0x30, unsigned int)
249 /* Lock/unlock Pty */
250 #define TARGET_TIOCSPTLCK TARGET_IOW('T', 0x31, int)
251 /* Safely open the slave */
252 #define TARGET_TIOCGPTPEER TARGET_IO('T', 0x41)
253 /* Get primary device node of /dev/console */
254 #define TARGET_TIOCGDEV TARGET_IOR('T', 0x32, unsigned int)
255 #define TARGET_TCGETX 0x5432 /* SYS5 TCGETX compatibility */
256 #define TARGET_TCSETX 0x5433
257 #define TARGET_TCSETXF 0x5434
258 #define TARGET_TCSETXW 0x5435
259 /* pty: generate signal */
260 #define TARGET_TIOCSIG TARGET_IOW('T', 0x36, int)
261 #define TARGET_TIOCVHANGUP 0x5437
263 #define TARGET_FIONCLEX 0x5450
264 #define TARGET_FIOCLEX 0x5451
265 #define TARGET_FIOASYNC 0x5452
266 #define TARGET_TIOCSERCONFIG 0x5453
267 #define TARGET_TIOCSERGWILD 0x5454
268 #define TARGET_TIOCSERSWILD 0x5455
269 #define TARGET_TIOCGLCKTRMIOS 0x5456
270 #define TARGET_TIOCSLCKTRMIOS 0x5457
271 #define TARGET_TIOCSERGSTRUCT 0x5458 /* For debugging only */
272 #define TARGET_TIOCSERGETLSR 0x5459 /* Get line status register */
273 #define TARGET_TIOCSERGETMULTI 0x545A /* Get multiport config */
274 #define TARGET_TIOCSERSETMULTI 0x545B /* Set multiport config */
276 /* wait for a change on serial input line(s) */
277 #define TARGET_TIOCMIWAIT 0x545C
278 /* read serial port inline interrupt counts */
279 #define TARGET_TIOCGICOUNT 0x545D
282 * Some arches already define TARGET_FIOQSIZE due to a historical
283 * conflict with a Hayes modem-specific ioctl value.
285 #ifndef TARGET_FIOQSIZE
286 #define TARGET_FIOQSIZE 0x5460
287 #endif
289 /* Used for packet mode */
290 #define TARGET_TIOCPKT_DATA 0
291 #define TARGET_TIOCPKT_FLUSHREAD 1
292 #define TARGET_TIOCPKT_FLUSHWRITE 2
293 #define TARGET_TIOCPKT_STOP 4
294 #define TARGET_TIOCPKT_START 8
295 #define TARGET_TIOCPKT_NOSTOP 16
296 #define TARGET_TIOCPKT_DOSTOP 32
297 #define TARGET_TIOCPKT_IOCTL 64
299 #define TARGET_TIOCSER_TEMT 0x01 /* Transmitter physically empty */
301 #endif