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