1 /* 2 * include/asm-xtensa/termbits.h 3 * 4 * Copied from SH. 5 * 6 * This file is subject to the terms and conditions of the GNU General Public 7 * License. See the file "COPYING" in the main directory of this archive 8 * for more details. 9 * 10 * Copyright (C) 2001 - 2005 Tensilica Inc. 11 */ 12 13 #ifndef XTENSA_TERMBITS_H 14 #define XTENSA_TERMBITS_H 15 16 #include <linux/posix_types.h> 17 18 typedef unsigned char cc_t; 19 typedef unsigned int speed_t; 20 typedef unsigned int tcflag_t; 21 22 #define TARGET_NCCS 19 23 struct target_termios { 24 tcflag_t c_iflag; /* input mode flags */ 25 tcflag_t c_oflag; /* output mode flags */ 26 tcflag_t c_cflag; /* control mode flags */ 27 tcflag_t c_lflag; /* local mode flags */ 28 cc_t c_line; /* line discipline */ 29 cc_t c_cc[TARGET_NCCS]; /* control characters */ 30 }; 31 32 struct target_termios2 { 33 tcflag_t c_iflag; /* input mode flags */ 34 tcflag_t c_oflag; /* output mode flags */ 35 tcflag_t c_cflag; /* control mode flags */ 36 tcflag_t c_lflag; /* local mode flags */ 37 cc_t c_line; /* line discipline */ 38 cc_t c_cc[TARGET_NCCS]; /* control characters */ 39 speed_t c_ispeed; /* input speed */ 40 speed_t c_ospeed; /* output speed */ 41 }; 42 43 struct target_ktermios { 44 tcflag_t c_iflag; /* input mode flags */ 45 tcflag_t c_oflag; /* output mode flags */ 46 tcflag_t c_cflag; /* control mode flags */ 47 tcflag_t c_lflag; /* local mode flags */ 48 cc_t c_line; /* line discipline */ 49 cc_t c_cc[TARGET_NCCS]; /* control characters */ 50 speed_t c_ispeed; /* input speed */ 51 speed_t c_ospeed; /* output speed */ 52 }; 53 54 /* c_cc characters */ 55 56 #define TARGET_VINTR 0 57 #define TARGET_VQUIT 1 58 #define TARGET_VERASE 2 59 #define TARGET_VKILL 3 60 #define TARGET_VEOF 4 61 #define TARGET_VTIME 5 62 #define TARGET_VMIN 6 63 #define TARGET_VSWTC 7 64 #define TARGET_VSTART 8 65 #define TARGET_VSTOP 9 66 #define TARGET_VSUSP 10 67 #define TARGET_VEOL 11 68 #define TARGET_VREPRINT 12 69 #define TARGET_VDISCARD 13 70 #define TARGET_VWERASE 14 71 #define TARGET_VLNEXT 15 72 #define TARGET_VEOL2 16 73 74 /* c_iflag bits */ 75 76 #define TARGET_IGNBRK 0000001 77 #define TARGET_BRKINT 0000002 78 #define TARGET_IGNPAR 0000004 79 #define TARGET_PARMRK 0000010 80 #define TARGET_INPCK 0000020 81 #define TARGET_ISTRIP 0000040 82 #define TARGET_INLCR 0000100 83 #define TARGET_IGNCR 0000200 84 #define TARGET_ICRNL 0000400 85 #define TARGET_IUCLC 0001000 86 #define TARGET_IXON 0002000 87 #define TARGET_IXANY 0004000 88 #define TARGET_IXOFF 0010000 89 #define TARGET_IMAXBEL 0020000 90 #define TARGET_IUTF8 0040000 91 92 /* c_oflag bits */ 93 94 #define TARGET_OPOST 0000001 95 #define TARGET_OLCUC 0000002 96 #define TARGET_ONLCR 0000004 97 #define TARGET_OCRNL 0000010 98 #define TARGET_ONOCR 0000020 99 #define TARGET_ONLRET 0000040 100 #define TARGET_OFILL 0000100 101 #define TARGET_OFDEL 0000200 102 #define TARGET_NLDLY 0000400 103 #define TARGET_NL0 0000000 104 #define TARGET_NL1 0000400 105 #define TARGET_CRDLY 0003000 106 #define TARGET_CR0 0000000 107 #define TARGET_CR1 0001000 108 #define TARGET_CR2 0002000 109 #define TARGET_CR3 0003000 110 #define TARGET_TABDLY 0014000 111 #define TARGET_TAB0 0000000 112 #define TARGET_TAB1 0004000 113 #define TARGET_TAB2 0010000 114 #define TARGET_TAB3 0014000 115 #define TARGET_XTABS 0014000 116 #define TARGET_BSDLY 0020000 117 #define TARGET_BS0 0000000 118 #define TARGET_BS1 0020000 119 #define TARGET_VTDLY 0040000 120 #define TARGET_VT0 0000000 121 #define TARGET_VT1 0040000 122 #define TARGET_FFDLY 0100000 123 #define TARGET_FF0 0000000 124 #define TARGET_FF1 0100000 125 126 /* c_cflag bit meaning */ 127 128 #define TARGET_CBAUD 0010017 129 #define TARGET_B0 0000000 /* hang up */ 130 #define TARGET_B50 0000001 131 #define TARGET_B75 0000002 132 #define TARGET_B110 0000003 133 #define TARGET_B134 0000004 134 #define TARGET_B150 0000005 135 #define TARGET_B200 0000006 136 #define TARGET_B300 0000007 137 #define TARGET_B600 0000010 138 #define TARGET_B1200 0000011 139 #define TARGET_B1800 0000012 140 #define TARGET_B2400 0000013 141 #define TARGET_B4800 0000014 142 #define TARGET_B9600 0000015 143 #define TARGET_B19200 0000016 144 #define TARGET_B38400 0000017 145 #define TARGET_EXTA B19200 146 #define TARGET_EXTB B38400 147 #define TARGET_CSIZE 0000060 148 #define TARGET_CS5 0000000 149 #define TARGET_CS6 0000020 150 #define TARGET_CS7 0000040 151 #define TARGET_CS8 0000060 152 #define TARGET_CSTOPB 0000100 153 #define TARGET_CREAD 0000200 154 #define TARGET_PARENB 0000400 155 #define TARGET_PARODD 0001000 156 #define TARGET_HUPCL 0002000 157 #define TARGET_CLOCAL 0004000 158 #define TARGET_CBAUDEX 0010000 159 #define TARGET_BOTHER 0010000 160 #define TARGET_B57600 0010001 161 #define TARGET_B115200 0010002 162 #define TARGET_B230400 0010003 163 #define TARGET_B460800 0010004 164 #define TARGET_B500000 0010005 165 #define TARGET_B576000 0010006 166 #define TARGET_B921600 0010007 167 #define TARGET_B1000000 0010010 168 #define TARGET_B1152000 0010011 169 #define TARGET_B1500000 0010012 170 #define TARGET_B2000000 0010013 171 #define TARGET_B2500000 0010014 172 #define TARGET_B3000000 0010015 173 #define TARGET_B3500000 0010016 174 #define TARGET_B4000000 0010017 175 #define TARGET_CIBAUD 002003600000 /* input baud rate */ 176 #define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */ 177 #define TARGET_CRTSCTS 020000000000 /* flow control */ 178 179 #define TARGET_IBSHIFT 16 /* Shift from CBAUD to CIBAUD */ 180 181 /* c_lflag bits */ 182 183 #define TARGET_ISIG 0000001 184 #define TARGET_ICANON 0000002 185 #define TARGET_XCASE 0000004 186 #define TARGET_ECHO 0000010 187 #define TARGET_ECHOE 0000020 188 #define TARGET_ECHOK 0000040 189 #define TARGET_ECHONL 0000100 190 #define TARGET_NOFLSH 0000200 191 #define TARGET_TOSTOP 0000400 192 #define TARGET_ECHOCTL 0001000 193 #define TARGET_ECHOPRT 0002000 194 #define TARGET_ECHOKE 0004000 195 #define TARGET_FLUSHO 0010000 196 #define TARGET_PENDIN 0040000 197 #define TARGET_IEXTEN 0100000 198 199 /* tcflow() and TCXONC use these */ 200 201 #define TARGET_TCOOFF 0 202 #define TARGET_TCOON 1 203 #define TARGET_TCIOFF 2 204 #define TARGET_TCION 3 205 206 /* tcflush() and TCFLSH use these */ 207 208 #define TARGET_TCIFLUSH 0 209 #define TARGET_TCOFLUSH 1 210 #define TARGET_TCIOFLUSH 2 211 212 /* tcsetattr uses these */ 213 214 #define TARGET_TCSANOW 0 215 #define TARGET_TCSADRAIN 1 216 #define TARGET_TCSAFLUSH 2 217 218 /* from arch/xtensa/include/uapi/asm/ioctls.h */ 219 220 #define TARGET_FIOCLEX _IO('f', 1) 221 #define TARGET_FIONCLEX _IO('f', 2) 222 #define TARGET_FIOASYNC _IOW('f', 125, int) 223 #define TARGET_FIONBIO _IOW('f', 126, int) 224 #define TARGET_FIONREAD _IOR('f', 127, int) 225 #define TARGET_TIOCINQ FIONREAD 226 #define TARGET_FIOQSIZE _IOR('f', 128, loff_t) 227 228 #define TARGET_TCGETS 0x5401 229 #define TARGET_TCSETS 0x5402 230 #define TARGET_TCSETSW 0x5403 231 #define TARGET_TCSETSF 0x5404 232 233 #define TARGET_TCGETA 0x80127417 /* _IOR('t', 23, struct termio) */ 234 #define TARGET_TCSETA 0x40127418 /* _IOW('t', 24, struct termio) */ 235 #define TARGET_TCSETAW 0x40127419 /* _IOW('t', 25, struct termio) */ 236 #define TARGET_TCSETAF 0x4012741C /* _IOW('t', 28, struct termio) */ 237 238 #define TARGET_TCSBRK _IO('t', 29) 239 #define TARGET_TCXONC _IO('t', 30) 240 #define TARGET_TCFLSH _IO('t', 31) 241 242 #define TARGET_TIOCSWINSZ 0x40087467 /* _IOW('t', 103, struct winsize) */ 243 #define TARGET_TIOCGWINSZ 0x80087468 /* _IOR('t', 104, struct winsize) */ 244 #define TARGET_TIOCSTART _IO('t', 110) /* start output, like ^Q */ 245 #define TARGET_TIOCSTOP _IO('t', 111) /* stop output, like ^S */ 246 #define TARGET_TIOCOUTQ _IOR('t', 115, int) /* output queue size */ 247 248 #define TARGET_TIOCSPGRP _IOW('t', 118, int) 249 #define TARGET_TIOCGPGRP _IOR('t', 119, int) 250 251 #define TARGET_TIOCEXCL _IO('T', 12) 252 #define TARGET_TIOCNXCL _IO('T', 13) 253 #define TARGET_TIOCSCTTY _IO('T', 14) 254 255 #define TARGET_TIOCSTI _IOW('T', 18, char) 256 #define TARGET_TIOCMGET _IOR('T', 21, unsigned int) 257 #define TARGET_TIOCMBIS _IOW('T', 22, unsigned int) 258 #define TARGET_TIOCMBIC _IOW('T', 23, unsigned int) 259 #define TARGET_TIOCMSET _IOW('T', 24, unsigned int) 260 # define TARGET_TIOCM_LE 0x001 261 # define TARGET_TIOCM_DTR 0x002 262 # define TARGET_TIOCM_RTS 0x004 263 # define TARGET_TIOCM_ST 0x008 264 # define TARGET_TIOCM_SR 0x010 265 # define TARGET_TIOCM_CTS 0x020 266 # define TARGET_TIOCM_CAR 0x040 267 # define TARGET_TIOCM_RNG 0x080 268 # define TARGET_TIOCM_DSR 0x100 269 # define TARGET_TIOCM_CD TIOCM_CAR 270 # define TARGET_TIOCM_RI TIOCM_RNG 271 272 #define TARGET_TIOCGSOFTCAR _IOR('T', 25, unsigned int) 273 #define TARGET_TIOCSSOFTCAR _IOW('T', 26, unsigned int) 274 #define TARGET_TIOCLINUX _IOW('T', 28, char) 275 #define TARGET_TIOCCONS _IO('T', 29) 276 #define TARGET_TIOCGSERIAL 0x803C541E /*_IOR('T', 30, struct serial_struct)*/ 277 #define TARGET_TIOCSSERIAL 0x403C541F /*_IOW('T', 31, struct serial_struct)*/ 278 #define TARGET_TIOCPKT _IOW('T', 32, int) 279 # define TARGET_TIOCPKT_DATA 0 280 # define TARGET_TIOCPKT_FLUSHREAD 1 281 # define TARGET_TIOCPKT_FLUSHWRITE 2 282 # define TARGET_TIOCPKT_STOP 4 283 # define TARGET_TIOCPKT_START 8 284 # define TARGET_TIOCPKT_NOSTOP 16 285 # define TARGET_TIOCPKT_DOSTOP 32 286 # define TARGET_TIOCPKT_IOCTL 64 287 288 289 #define TARGET_TIOCNOTTY _IO('T', 34) 290 #define TARGET_TIOCSETD _IOW('T', 35, int) 291 #define TARGET_TIOCGETD _IOR('T', 36, int) 292 #define TARGET_TCSBRKP _IOW('T', 37, int) /* Needed for POSIX tcsendbreak()*/ 293 #define TARGET_TIOCSBRK _IO('T', 39) /* BSD compatibility */ 294 #define TARGET_TIOCCBRK _IO('T', 40) /* BSD compatibility */ 295 #define TARGET_TIOCGSID _IOR('T', 41, pid_t) /* Return the session ID of FD*/ 296 #define TARGET_TCGETS2 _IOR('T', 42, struct termios2) 297 #define TARGET_TCSETS2 _IOW('T', 43, struct termios2) 298 #define TARGET_TCSETSW2 _IOW('T', 44, struct termios2) 299 #define TARGET_TCSETSF2 _IOW('T', 45, struct termios2) 300 #define TARGET_TIOCGRS485 _IOR('T', 46, struct serial_rs485) 301 #define TARGET_TIOCSRS485 _IOWR('T', 47, struct serial_rs485) 302 #define TARGET_TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */ 303 #define TARGET_TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */ 304 #define TARGET_TIOCGDEV _IOR('T',0x32, unsigned int) /* Get primary device node of /dev/console */ 305 #define TARGET_TIOCSIG _IOW('T',0x36, int) /* Generate signal on Pty slave */ 306 #define TARGET_TIOCVHANGUP _IO('T', 0x37) 307 #define TARGET_TIOCGPKT _IOR('T', 0x38, int) /* Get packet mode state */ 308 #define TARGET_TIOCGPTLCK _IOR('T', 0x39, int) /* Get Pty lock state */ 309 #define TARGET_TIOCGEXCL _IOR('T', 0x40, int) /* Get exclusive mode state */ 310 #define TARGET_TIOCGPTPEER _IO('T', 0x41) /* Safely open the slave */ 311 312 #define TARGET_TIOCSERCONFIG _IO('T', 83) 313 #define TARGET_TIOCSERGWILD _IOR('T', 84, int) 314 #define TARGET_TIOCSERSWILD _IOW('T', 85, int) 315 #define TARGET_TIOCGLCKTRMIOS 0x5456 316 #define TARGET_TIOCSLCKTRMIOS 0x5457 317 #define TARGET_TIOCSERGSTRUCT 0x5458 /* For debugging only */ 318 #define TARGET_TIOCSERGETLSR _IOR('T', 89, unsigned int) /* Get line status reg. */ 319 /* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */ 320 # define TARGET_TIOCSER_TEMT 0x01 /* Transmitter physically empty */ 321 #define TARGET_TIOCSERGETMULTI 0x80a8545a /* Get multiport config */ 322 /* _IOR('T', 90, struct serial_multiport_struct) */ 323 #define TARGET_TIOCSERSETMULTI 0x40a8545b /* Set multiport config */ 324 /* _IOW('T', 91, struct serial_multiport_struct) */ 325 326 #define TARGET_TIOCMIWAIT _IO('T', 92) /* wait for a change on serial input line(s) */ 327 #define TARGET_TIOCGICOUNT 0x545D /* read serial port inline interrupt counts */ 328 #endif /* XTENSA_TERMBITS_H */ 329