blob: c8bb5996b1eb8135c4921284ab5b1b056a2ab52b [file] [log] [blame]
Markus Armbrusterf91005e2019-06-04 20:16:18 +02001#ifndef LINUX_USER_X86_64_TERMBITS_H
2#define LINUX_USER_X86_64_TERMBITS_H
3
j_mayer74aa0422007-04-06 06:40:51 +00004#define TARGET_NCCS 19
5
Anthony Liguoric227f092009-10-01 16:12:16 -05006typedef unsigned char target_cc_t;
7typedef unsigned int target_speed_t;
8typedef unsigned int target_tcflag_t;
j_mayer74aa0422007-04-06 06:40:51 +00009struct target_termios {
Anthony Liguoric227f092009-10-01 16:12:16 -050010 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 */
j_mayer74aa0422007-04-06 06:40:51 +000016};
17
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
36
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
53
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
86
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 */
138
139#define TARGET_IBSHIFT 8 /* Shift from CBAUD to CIBAUD */
140
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
157
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
163
164/* tcflush() and TCFLSH use these */
165#define TARGET_TCIFLUSH 0
166#define TARGET_TCOFLUSH 1
167#define TARGET_TCIOFLUSH 2
168
169/* tcsetattr uses these */
170#define TARGET_TCSANOW 0
171#define TARGET_TCSADRAIN 1
172#define TARGET_TCSAFLUSH 2
173
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 */
Timothy Pearson5b7f7bb2016-06-18 19:15:35 -0500215#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 */
Andreas Schwab2b74f622018-01-29 11:47:06 +0100221#define TARGET_TIOCGPTPEER TARGET_IO('T', 0x41) /* Safely open the slave */
j_mayer74aa0422007-04-06 06:40:51 +0000222
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 */
235
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
241
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
250
251#define TARGET_TIOCSER_TEMT 0x01 /* Transmitter physically empty */
Markus Armbrusterf91005e2019-06-04 20:16:18 +0200252
253#endif