cachepc-qemu

Fork of AMDESE/qemu with changes for cachepc side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-qemu
Log | Files | Refs | Submodules | LICENSE | sfeed.txt

termbits.h (11985B)


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