Merge remote-tracking branch 'remotes/borntraeger/tags/s390x-20200310' into staging
[qemu/ar7.git] / linux-user / aarch64 / termbits.h
blob0ab448d090e764dab379072f94aa08ccbe0e7aa4
1 /* from asm/termbits.h */
2 /* NOTE: exactly the same as i386 */
4 #ifndef LINUX_USER_AARCH64_TERMBITS_H
5 #define LINUX_USER_AARCH64_TERMBITS_H
7 #define TARGET_NCCS 19
9 struct 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 */
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
33 #define TARGET_IUTF8 0040000
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
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) */
105 #define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */
106 #define TARGET_CRTSCTS 020000000000 /* flow control */
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
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
144 /* ioctls */
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
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)
190 /* Get Pty Number (of pty-mux device) */
191 #define TARGET_TIOCSPTLCK TARGET_IOW('T', 0x31, int)
192 /* Lock/unlock Pty */
193 #define TARGET_TIOCGPTPEER TARGET_IO('T', 0x41)
194 /* Safely open the slave */
196 #define TARGET_FIONCLEX 0x5450 /* these numbers need to be adjusted. */
197 #define TARGET_FIOCLEX 0x5451
198 #define TARGET_FIOASYNC 0x5452
199 #define TARGET_TIOCSERCONFIG 0x5453
200 #define TARGET_TIOCSERGWILD 0x5454
201 #define TARGET_TIOCSERSWILD 0x5455
202 #define TARGET_TIOCGLCKTRMIOS 0x5456
203 #define TARGET_TIOCSLCKTRMIOS 0x5457
204 #define TARGET_TIOCSERGSTRUCT 0x5458 /* For debugging only */
205 #define TARGET_TIOCSERGETLSR 0x5459 /* Get line status register */
206 #define TARGET_TIOCSERGETMULTI 0x545A /* Get multiport config */
207 #define TARGET_TIOCSERSETMULTI 0x545B /* Set multiport config */
209 #define TARGET_TIOCMIWAIT 0x545C
210 /* wait for a change on serial input line(s) */
211 #define TARGET_TIOCGICOUNT 0x545D
212 /* read serial port inline interrupt counts */
213 #define TARGET_TIOCGHAYESESP 0x545E /* Get Hayes ESP configuration */
214 #define TARGET_TIOCSHAYESESP 0x545F /* Set Hayes ESP configuration */
216 /* Used for packet mode */
217 #define TARGET_TIOCPKT_DATA 0
218 #define TARGET_TIOCPKT_FLUSHREAD 1
219 #define TARGET_TIOCPKT_FLUSHWRITE 2
220 #define TARGET_TIOCPKT_STOP 4
221 #define TARGET_TIOCPKT_START 8
222 #define TARGET_TIOCPKT_NOSTOP 16
223 #define TARGET_TIOCPKT_DOSTOP 32
225 #define TARGET_TIOCSER_TEMT 0x01 /* Transmitter physically empty */
227 #endif