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