]> git.proxmox.com Git - mirror_qemu.git/blame - linux-user/i386/termbits.h
Fix input-linux reading from device
[mirror_qemu.git] / linux-user / i386 / termbits.h
CommitLineData
3bfd9da1
FB
1/* from asm/termbits.h */
2
3#define TARGET_NCCS 19
4
5struct 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
f05d35d2 29#define TARGET_IUTF8 0040000
3bfd9da1
FB
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
f05d35d2
TS
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
3bfd9da1 111#define TARGET_CIBAUD 002003600000 /* input baud rate (not used) */
f05d35d2
TS
112#define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */
113#define TARGET_CRTSCTS 020000000000 /* flow control */
3bfd9da1
FB
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 */