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