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