qemu/linux-user/s390x/termbits.h
<<
>>
Prefs
   1/*
   2 *  include/asm-s390/termbits.h
   3 *
   4 *  S390 version
   5 *
   6 *  Derived from "include/asm-i386/termbits.h"
   7 */
   8
   9#ifndef LINUX_USER_S390X_TERMBITS_H
  10#define LINUX_USER_S390X_TERMBITS_H
  11
  12#define TARGET_NCCS 19
  13struct target_termios {
  14    unsigned int c_iflag;               /* input mode flags */
  15    unsigned int c_oflag;               /* output mode flags */
  16    unsigned int c_cflag;               /* control mode flags */
  17    unsigned int c_lflag;               /* local mode flags */
  18    unsigned char c_line;                       /* line discipline */
  19    unsigned char c_cc[TARGET_NCCS];            /* control characters */
  20};
  21
  22struct target_termios2 {
  23    unsigned int c_iflag;               /* input mode flags */
  24    unsigned int c_oflag;               /* output mode flags */
  25    unsigned int c_cflag;               /* control mode flags */
  26    unsigned int c_lflag;               /* local mode flags */
  27    unsigned char c_line;                       /* line discipline */
  28    unsigned char c_cc[TARGET_NCCS];            /* control characters */
  29    unsigned int c_ispeed;              /* input speed */
  30    unsigned int c_ospeed;              /* output speed */
  31};
  32
  33struct target_ktermios {
  34    unsigned int c_iflag;               /* input mode flags */
  35    unsigned int c_oflag;               /* output mode flags */
  36    unsigned int c_cflag;               /* control mode flags */
  37    unsigned int c_lflag;               /* local mode flags */
  38    unsigned char c_line;                       /* line discipline */
  39    unsigned char c_cc[TARGET_NCCS];            /* control characters */
  40    unsigned int c_ispeed;              /* input speed */
  41    unsigned int c_ospeed;              /* output speed */
  42};
  43
  44/* c_cc characters */
  45#define TARGET_VINTR 0
  46#define TARGET_VQUIT 1
  47#define TARGET_VERASE 2
  48#define TARGET_VKILL 3
  49#define TARGET_VEOF 4
  50#define TARGET_VTIME 5
  51#define TARGET_VMIN 6
  52#define TARGET_VSWTC 7
  53#define TARGET_VSTART 8
  54#define TARGET_VSTOP 9
  55#define TARGET_VSUSP 10
  56#define TARGET_VEOL 11
  57#define TARGET_VREPRINT 12
  58#define TARGET_VDISCARD 13
  59#define TARGET_VWERASE 14
  60#define TARGET_VLNEXT 15
  61#define TARGET_VEOL2 16
  62
  63/* c_iflag bits */
  64#define TARGET_IGNBRK   0000001
  65#define TARGET_BRKINT   0000002
  66#define TARGET_IGNPAR   0000004
  67#define TARGET_PARMRK   0000010
  68#define TARGET_INPCK    0000020
  69#define TARGET_ISTRIP   0000040
  70#define TARGET_INLCR    0000100
  71#define TARGET_IGNCR    0000200
  72#define TARGET_ICRNL    0000400
  73#define TARGET_IUCLC    0001000
  74#define TARGET_IXON     0002000
  75#define TARGET_IXANY    0004000
  76#define TARGET_IXOFF    0010000
  77#define TARGET_IMAXBEL  0020000
  78#define TARGET_IUTF8    0040000
  79
  80/* c_oflag bits */
  81#define TARGET_OPOST    0000001
  82#define TARGET_OLCUC    0000002
  83#define TARGET_ONLCR    0000004
  84#define TARGET_OCRNL    0000010
  85#define TARGET_ONOCR    0000020
  86#define TARGET_ONLRET   0000040
  87#define TARGET_OFILL    0000100
  88#define TARGET_OFDEL    0000200
  89#define TARGET_NLDLY    0000400
  90#define TARGET_NL0      0000000
  91#define TARGET_NL1      0000400
  92#define TARGET_CRDLY    0003000
  93#define TARGET_CR0      0000000
  94#define TARGET_CR1      0001000
  95#define TARGET_CR2      0002000
  96#define TARGET_CR3      0003000
  97#define TARGET_TABDLY   0014000
  98#define TARGET_TAB0     0000000
  99#define TARGET_TAB1     0004000
 100#define TARGET_TAB2     0010000
 101#define TARGET_TAB3     0014000
 102#define TARGET_XTABS    0014000
 103#define TARGET_BSDLY    0020000
 104#define TARGET_BS0      0000000
 105#define TARGET_BS1      0020000
 106#define TARGET_VTDLY    0040000
 107#define TARGET_VT0      0000000
 108#define TARGET_VT1      0040000
 109#define TARGET_FFDLY    0100000
 110#define TARGET_FF0      0000000
 111#define TARGET_FF1      0100000
 112
 113/* c_cflag bit meaning */
 114#define TARGET_CBAUD    0010017
 115#define TARGET_B0       0000000         /* hang up */
 116#define TARGET_B50      0000001
 117#define TARGET_B75      0000002
 118#define TARGET_B110     0000003
 119#define TARGET_B134     0000004
 120#define TARGET_B150     0000005
 121#define TARGET_B200     0000006
 122#define TARGET_B300     0000007
 123#define TARGET_B600     0000010
 124#define TARGET_B1200    0000011
 125#define TARGET_B1800    0000012
 126#define TARGET_B2400    0000013
 127#define TARGET_B4800    0000014
 128#define TARGET_B9600    0000015
 129#define TARGET_B19200   0000016
 130#define TARGET_B38400   0000017
 131#define TARGET_EXTA B19200
 132#define TARGET_EXTB B38400
 133#define TARGET_CSIZE    0000060
 134#define TARGET_CS5      0000000
 135#define TARGET_CS6      0000020
 136#define TARGET_CS7      0000040
 137#define TARGET_CS8      0000060
 138#define TARGET_CSTOPB   0000100
 139#define TARGET_CREAD    0000200
 140#define TARGET_PARENB   0000400
 141#define TARGET_PARODD   0001000
 142#define TARGET_HUPCL    0002000
 143#define TARGET_CLOCAL   0004000
 144#define TARGET_CBAUDEX 0010000
 145#define TARGET_BOTHER  0010000
 146#define TARGET_B57600  0010001
 147#define TARGET_B115200 0010002
 148#define TARGET_B230400 0010003
 149#define TARGET_B460800 0010004
 150#define TARGET_B500000 0010005
 151#define TARGET_B576000 0010006
 152#define TARGET_B921600 0010007
 153#define TARGET_B1000000 0010010
 154#define TARGET_B1152000 0010011
 155#define TARGET_B1500000 0010012
 156#define TARGET_B2000000 0010013
 157#define TARGET_B2500000 0010014
 158#define TARGET_B3000000 0010015
 159#define TARGET_B3500000 0010016
 160#define TARGET_B4000000 0010017
 161#define TARGET_CIBAUD     002003600000  /* input baud rate */
 162#define TARGET_CMSPAR     010000000000          /* mark or space (stick) parity */
 163#define TARGET_CRTSCTS    020000000000          /* flow control */
 164
 165#define TARGET_IBSHIFT    16            /* Shift from CBAUD to CIBAUD */
 166
 167/* c_lflag bits */
 168#define TARGET_ISIG     0000001
 169#define TARGET_ICANON   0000002
 170#define TARGET_XCASE    0000004
 171#define TARGET_ECHO     0000010
 172#define TARGET_ECHOE    0000020
 173#define TARGET_ECHOK    0000040
 174#define TARGET_ECHONL   0000100
 175#define TARGET_NOFLSH   0000200
 176#define TARGET_TOSTOP   0000400
 177#define TARGET_ECHOCTL  0001000
 178#define TARGET_ECHOPRT  0002000
 179#define TARGET_ECHOKE   0004000
 180#define TARGET_FLUSHO   0010000
 181#define TARGET_PENDIN   0040000
 182#define TARGET_IEXTEN   0100000
 183
 184/* tcflow() and TCXONC use these */
 185#define TARGET_TCOOFF           0
 186#define TARGET_TCOON            1
 187#define TARGET_TCIOFF           2
 188#define TARGET_TCION            3
 189
 190/* tcflush() and TCFLSH use these */
 191#define TARGET_TCIFLUSH 0
 192#define TARGET_TCOFLUSH 1
 193#define TARGET_TCIOFLUSH        2
 194
 195/* tcsetattr uses these */
 196#define TARGET_TCSANOW          0
 197#define TARGET_TCSADRAIN        1
 198#define TARGET_TCSAFLUSH        2
 199
 200/*
 201 *  include/asm-s390/ioctls.h
 202 *
 203 *  S390 version
 204 *
 205 *  Derived from "include/asm-i386/ioctls.h"
 206 */
 207
 208/* 0x54 is just a magic number to make these relatively unique ('T') */
 209
 210#define TARGET_TCGETS           0x5401
 211#define TARGET_TCSETS           0x5402
 212#define TARGET_TCSETSW          0x5403
 213#define TARGET_TCSETSF          0x5404
 214#define TARGET_TCGETA           0x5405
 215#define TARGET_TCSETA           0x5406
 216#define TARGET_TCSETAW          0x5407
 217#define TARGET_TCSETAF          0x5408
 218#define TARGET_TCSBRK           0x5409
 219#define TARGET_TCXONC           0x540A
 220#define TARGET_TCFLSH           0x540B
 221#define TARGET_TIOCEXCL 0x540C
 222#define TARGET_TIOCNXCL 0x540D
 223#define TARGET_TIOCSCTTY        0x540E
 224#define TARGET_TIOCGPGRP        0x540F
 225#define TARGET_TIOCSPGRP        0x5410
 226#define TARGET_TIOCOUTQ 0x5411
 227#define TARGET_TIOCSTI          0x5412
 228#define TARGET_TIOCGWINSZ       0x5413
 229#define TARGET_TIOCSWINSZ       0x5414
 230#define TARGET_TIOCMGET 0x5415
 231#define TARGET_TIOCMBIS 0x5416
 232#define TARGET_TIOCMBIC 0x5417
 233#define TARGET_TIOCMSET 0x5418
 234#define TARGET_TIOCGSOFTCAR     0x5419
 235#define TARGET_TIOCSSOFTCAR     0x541A
 236#define TARGET_FIONREAD 0x541B
 237#define TARGET_TIOCINQ          FIONREAD
 238#define TARGET_TIOCLINUX        0x541C
 239#define TARGET_TIOCCONS 0x541D
 240#define TARGET_TIOCGSERIAL      0x541E
 241#define TARGET_TIOCSSERIAL      0x541F
 242#define TARGET_TIOCPKT          0x5420
 243#define TARGET_FIONBIO          0x5421
 244#define TARGET_TIOCNOTTY        0x5422
 245#define TARGET_TIOCSETD 0x5423
 246#define TARGET_TIOCGETD 0x5424
 247#define TARGET_TCSBRKP          0x5425  /* Needed for POSIX tcsendbreak() */
 248#define TARGET_TIOCSBRK 0x5427  /* BSD compatibility */
 249#define TARGET_TIOCCBRK 0x5428  /* BSD compatibility */
 250#define TARGET_TIOCGSID 0x5429  /* Return the session ID of FD */
 251#define TARGET_TCGETS2          _IOR('T',0x2A, struct termios2)
 252#define TARGET_TCSETS2          _IOW('T',0x2B, struct termios2)
 253#define TARGET_TCSETSW2 _IOW('T',0x2C, struct termios2)
 254#define TARGET_TCSETSF2 _IOW('T',0x2D, struct termios2)
 255#define TARGET_TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
 256#define TARGET_TIOCSPTLCK       _IOW('T',0x31, int)  /* Lock/unlock Pty */
 257#define TARGET_TIOCGDEV _IOR('T',0x32, unsigned int) /* Get real dev no below /dev/console */
 258#define TARGET_TIOCGPTPEER      TARGET_IO('T', 0x41) /* Safely open the slave */
 259
 260#define TARGET_FIONCLEX 0x5450  /* these numbers need to be adjusted. */
 261#define TARGET_FIOCLEX          0x5451
 262#define TARGET_FIOASYNC 0x5452
 263#define TARGET_TIOCSERCONFIG    0x5453
 264#define TARGET_TIOCSERGWILD     0x5454
 265#define TARGET_TIOCSERSWILD     0x5455
 266#define TARGET_TIOCGLCKTRMIOS   0x5456
 267#define TARGET_TIOCSLCKTRMIOS   0x5457
 268#define TARGET_TIOCSERGSTRUCT   0x5458 /* For debugging only */
 269#define TARGET_TIOCSERGETLSR   0x5459 /* Get line status register */
 270#define TARGET_TIOCSERGETMULTI 0x545A /* Get multiport config  */
 271#define TARGET_TIOCSERSETMULTI 0x545B /* Set multiport config */
 272
 273#define TARGET_TIOCMIWAIT       0x545C  /* wait for a change on serial input line(s) */
 274#define TARGET_TIOCGICOUNT      0x545D  /* read serial port inline interrupt counts */
 275#define TARGET_FIOQSIZE 0x545E
 276
 277/* Used for packet mode */
 278#define TARGET_TIOCPKT_DATA              0
 279#define TARGET_TIOCPKT_FLUSHREAD         1
 280#define TARGET_TIOCPKT_FLUSHWRITE        2
 281#define TARGET_TIOCPKT_STOP              4
 282#define TARGET_TIOCPKT_START             8
 283#define TARGET_TIOCPKT_NOSTOP           16
 284#define TARGET_TIOCPKT_DOSTOP           32
 285
 286#define TARGET_TIOCSER_TEMT    0x01     /* Transmitter physically empty */
 287
 288#endif
 289