2cb154bc19
They are based on Linux kernel tilegx architecture for 64 bit binary, and also based on tilegx ABI reference document, and also reference from other targets implementations. Signed-off-by: Chen Gang <gang.chen.5i5j@gmail.com> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Message-Id: <BLU436-SMTP2508945F92945BB525605A3B9660@phx.gbl> Signed-off-by: Richard Henderson <rth@twiddle.net>
275 lines
9.9 KiB
C
275 lines
9.9 KiB
C
#ifndef TILEGX_TERMBITS_H
|
|
#define TILEGX_TERMBITS_H
|
|
|
|
/* From asm-generic/termbits.h, which is used by tilegx */
|
|
|
|
#define TARGET_NCCS 19
|
|
struct target_termios {
|
|
unsigned int c_iflag; /* input mode flags */
|
|
unsigned int c_oflag; /* output mode flags */
|
|
unsigned int c_cflag; /* control mode flags */
|
|
unsigned int c_lflag; /* local mode flags */
|
|
unsigned char c_line; /* line discipline */
|
|
unsigned char c_cc[TARGET_NCCS]; /* control characters */
|
|
};
|
|
|
|
struct target_termios2 {
|
|
unsigned int c_iflag; /* input mode flags */
|
|
unsigned int c_oflag; /* output mode flags */
|
|
unsigned int c_cflag; /* control mode flags */
|
|
unsigned int c_lflag; /* local mode flags */
|
|
unsigned char c_line; /* line discipline */
|
|
unsigned char c_cc[TARGET_NCCS]; /* control characters */
|
|
unsigned int c_ispeed; /* input speed */
|
|
unsigned int c_ospeed; /* output speed */
|
|
};
|
|
|
|
/* c_cc characters */
|
|
#define TARGET_VINTR 0
|
|
#define TARGET_VQUIT 1
|
|
#define TARGET_VERASE 2
|
|
#define TARGET_VKILL 3
|
|
#define TARGET_VEOF 4
|
|
#define TARGET_VTIME 5
|
|
#define TARGET_VMIN 6
|
|
#define TARGET_VSWTC 7
|
|
#define TARGET_VSTART 8
|
|
#define TARGET_VSTOP 9
|
|
#define TARGET_VSUSP 10
|
|
#define TARGET_VEOL 11
|
|
#define TARGET_VREPRINT 12
|
|
#define TARGET_VDISCARD 13
|
|
#define TARGET_VWERASE 14
|
|
#define TARGET_VLNEXT 15
|
|
#define TARGET_VEOL2 16
|
|
|
|
/* c_iflag bits */
|
|
#define TARGET_IGNBRK 0000001
|
|
#define TARGET_BRKINT 0000002
|
|
#define TARGET_IGNPAR 0000004
|
|
#define TARGET_PARMRK 0000010
|
|
#define TARGET_INPCK 0000020
|
|
#define TARGET_ISTRIP 0000040
|
|
#define TARGET_INLCR 0000100
|
|
#define TARGET_IGNCR 0000200
|
|
#define TARGET_ICRNL 0000400
|
|
#define TARGET_IUCLC 0001000
|
|
#define TARGET_IXON 0002000
|
|
#define TARGET_IXANY 0004000
|
|
#define TARGET_IXOFF 0010000
|
|
#define TARGET_IMAXBEL 0020000
|
|
#define TARGET_IUTF8 0040000
|
|
|
|
/* c_oflag bits */
|
|
#define TARGET_OPOST 0000001
|
|
#define TARGET_OLCUC 0000002
|
|
#define TARGET_ONLCR 0000004
|
|
#define TARGET_OCRNL 0000010
|
|
#define TARGET_ONOCR 0000020
|
|
#define TARGET_ONLRET 0000040
|
|
#define TARGET_OFILL 0000100
|
|
#define TARGET_OFDEL 0000200
|
|
#define TARGET_NLDLY 0000400
|
|
#define TARGET_NL0 0000000
|
|
#define TARGET_NL1 0000400
|
|
#define TARGET_CRDLY 0003000
|
|
#define TARGET_CR0 0000000
|
|
#define TARGET_CR1 0001000
|
|
#define TARGET_CR2 0002000
|
|
#define TARGET_CR3 0003000
|
|
#define TARGET_TABDLY 0014000
|
|
#define TARGET_TAB0 0000000
|
|
#define TARGET_TAB1 0004000
|
|
#define TARGET_TAB2 0010000
|
|
#define TARGET_TAB3 0014000
|
|
#define TARGET_XTABS 0014000
|
|
#define TARGET_BSDLY 0020000
|
|
#define TARGET_BS0 0000000
|
|
#define TARGET_BS1 0020000
|
|
#define TARGET_VTDLY 0040000
|
|
#define TARGET_VT0 0000000
|
|
#define TARGET_VT1 0040000
|
|
#define TARGET_FFDLY 0100000
|
|
#define TARGET_FF0 0000000
|
|
#define TARGET_FF1 0100000
|
|
|
|
/* c_cflag bit meaning */
|
|
#define TARGET_CBAUD 0010017
|
|
#define TARGET_B0 0000000 /* hang up */
|
|
#define TARGET_B50 0000001
|
|
#define TARGET_B75 0000002
|
|
#define TARGET_B110 0000003
|
|
#define TARGET_B134 0000004
|
|
#define TARGET_B150 0000005
|
|
#define TARGET_B200 0000006
|
|
#define TARGET_B300 0000007
|
|
#define TARGET_B600 0000010
|
|
#define TARGET_B1200 0000011
|
|
#define TARGET_B1800 0000012
|
|
#define TARGET_B2400 0000013
|
|
#define TARGET_B4800 0000014
|
|
#define TARGET_B9600 0000015
|
|
#define TARGET_B19200 0000016
|
|
#define TARGET_B38400 0000017
|
|
#define TARGET_EXTA TARGET_B19200
|
|
#define TARGET_EXTB TARGET_B38400
|
|
#define TARGET_CSIZE 0000060
|
|
#define TARGET_CS5 0000000
|
|
#define TARGET_CS6 0000020
|
|
#define TARGET_CS7 0000040
|
|
#define TARGET_CS8 0000060
|
|
#define TARGET_CSTOPB 0000100
|
|
#define TARGET_CREAD 0000200
|
|
#define TARGET_PARENB 0000400
|
|
#define TARGET_PARODD 0001000
|
|
#define TARGET_HUPCL 0002000
|
|
#define TARGET_CLOCAL 0004000
|
|
#define TARGET_CBAUDEX 0010000
|
|
#define TARGET_BOTHER 0010000
|
|
#define TARGET_B57600 0010001
|
|
#define TARGET_B115200 0010002
|
|
#define TARGET_B230400 0010003
|
|
#define TARGET_B460800 0010004
|
|
#define TARGET_B500000 0010005
|
|
#define TARGET_B576000 0010006
|
|
#define TARGET_B921600 0010007
|
|
#define TARGET_B1000000 0010010
|
|
#define TARGET_B1152000 0010011
|
|
#define TARGET_B1500000 0010012
|
|
#define TARGET_B2000000 0010013
|
|
#define TARGET_B2500000 0010014
|
|
#define TARGET_B3000000 0010015
|
|
#define TARGET_B3500000 0010016
|
|
#define TARGET_B4000000 0010017
|
|
#define TARGET_CIBAUD 002003600000 /* input baud rate */
|
|
#define TARGET_CMSPAR 010000000000 /* mark or space (stick) parity */
|
|
#define TARGET_CRTSCTS 020000000000 /* flow control */
|
|
|
|
#define TARGET_IBSHIFT 16 /* Shift from CBAUD to CIBAUD */
|
|
|
|
/* c_lflag bits */
|
|
#define TARGET_ISIG 0000001
|
|
#define TARGET_ICANON 0000002
|
|
#define TARGET_XCASE 0000004
|
|
#define TARGET_ECHO 0000010
|
|
#define TARGET_ECHOE 0000020
|
|
#define TARGET_ECHOK 0000040
|
|
#define TARGET_ECHONL 0000100
|
|
#define TARGET_NOFLSH 0000200
|
|
#define TARGET_TOSTOP 0000400
|
|
#define TARGET_ECHOCTL 0001000
|
|
#define TARGET_ECHOPRT 0002000
|
|
#define TARGET_ECHOKE 0004000
|
|
#define TARGET_FLUSHO 0010000
|
|
#define TARGET_PENDIN 0040000
|
|
#define TARGET_IEXTEN 0100000
|
|
#define TARGET_EXTPROC 0200000
|
|
|
|
/* tcflow() and TCXONC use these */
|
|
#define TARGET_TCOOFF 0
|
|
#define TARGET_TCOON 1
|
|
#define TARGET_TCIOFF 2
|
|
#define TARGET_TCION 3
|
|
|
|
/* tcflush() and TCFLSH use these */
|
|
#define TARGET_TCIFLUSH 0
|
|
#define TARGET_TCOFLUSH 1
|
|
#define TARGET_TCIOFLUSH 2
|
|
|
|
/* tcsetattr uses these */
|
|
#define TARGET_TCSANOW 0
|
|
#define TARGET_TCSADRAIN 1
|
|
#define TARGET_TCSAFLUSH 2
|
|
|
|
/* From asm-generic/ioctls.h, which is used by tilegx */
|
|
|
|
#define TARGET_TCGETS 0x5401
|
|
#define TARGET_TCSETS 0x5402
|
|
#define TARGET_TCSETSW 0x5403
|
|
#define TARGET_TCSETSF 0x5404
|
|
#define TARGET_TCGETA 0x5405
|
|
#define TARGET_TCSETA 0x5406
|
|
#define TARGET_TCSETAW 0x5407
|
|
#define TARGET_TCSETAF 0x5408
|
|
#define TARGET_TCSBRK 0x5409
|
|
#define TARGET_TCXONC 0x540A
|
|
#define TARGET_TCFLSH 0x540B
|
|
#define TARGET_TIOCEXCL 0x540C
|
|
#define TARGET_TIOCNXCL 0x540D
|
|
#define TARGET_TIOCSCTTY 0x540E
|
|
#define TARGET_TIOCGPGRP 0x540F
|
|
#define TARGET_TIOCSPGRP 0x5410
|
|
#define TARGET_TIOCOUTQ 0x5411
|
|
#define TARGET_TIOCSTI 0x5412
|
|
#define TARGET_TIOCGWINSZ 0x5413
|
|
#define TARGET_TIOCSWINSZ 0x5414
|
|
#define TARGET_TIOCMGET 0x5415
|
|
#define TARGET_TIOCMBIS 0x5416
|
|
#define TARGET_TIOCMBIC 0x5417
|
|
#define TARGET_TIOCMSET 0x5418
|
|
#define TARGET_TIOCGSOFTCAR 0x5419
|
|
#define TARGET_TIOCSSOFTCAR 0x541A
|
|
#define TARGET_FIONREAD 0x541B
|
|
#define TARGET_TIOCINQ TARGET_FIONREAD
|
|
#define TARGET_TIOCLINUX 0x541C
|
|
#define TARGET_TIOCCONS 0x541D
|
|
#define TARGET_TIOCGSERIAL 0x541E
|
|
#define TARGET_TIOCSSERIAL 0x541F
|
|
#define TARGET_TIOCPKT 0x5420
|
|
#define TARGET_FIONBIO 0x5421
|
|
#define TARGET_TIOCNOTTY 0x5422
|
|
#define TARGET_TIOCSETD 0x5423
|
|
#define TARGET_TIOCGETD 0x5424
|
|
#define TARGET_TCSBRKP 0x5425
|
|
#define TARGET_TIOCSBRK 0x5427
|
|
#define TARGET_TIOCCBRK 0x5428
|
|
#define TARGET_TIOCGSID 0x5429
|
|
#define TARGET_TCGETS2 TARGET_IOR('T', 0x2A, struct termios2)
|
|
#define TARGET_TCSETS2 TARGET_IOW('T', 0x2B, struct termios2)
|
|
#define TARGET_TCSETSW2 TARGET_IOW('T', 0x2C, struct termios2)
|
|
#define TARGET_TCSETSF2 TARGET_IOW('T', 0x2D, struct termios2)
|
|
#define TARGET_TIOCGRS485 0x542E
|
|
#define TARGET_TIOCSRS485 0x542F
|
|
#define TARGET_TIOCGPTN TARGET_IOR('T', 0x30, unsigned int)
|
|
#define TARGET_TIOCSPTLCK TARGET_IOW('T', 0x31, int)
|
|
#define TARGET_TIOCGDEV TARGET_IOR('T', 0x32, unsigned int)
|
|
#define TARGET_TCGETX 0x5432
|
|
#define TARGET_TCSETX 0x5433
|
|
#define TARGET_TCSETXF 0x5434
|
|
#define TARGET_TCSETXW 0x5435
|
|
#define TARGET_TIOCSIG TARGET_IOW('T', 0x36, int)
|
|
#define TARGET_TIOCVHANGUP 0x5437
|
|
#define TARGET_TIOCGPKT TARGET_IOR('T', 0x38, int)
|
|
#define TARGET_TIOCGPTLCK TARGET_IOR('T', 0x39, int)
|
|
#define TARGET_TIOCGEXCL TARGET_IOR('T', 0x40, int)
|
|
|
|
#define TARGET_FIONCLEX 0x5450
|
|
#define TARGET_FIOCLEX 0x5451
|
|
#define TARGET_FIOASYNC 0x5452
|
|
#define TARGET_TIOCSERCONFIG 0x5453
|
|
#define TARGET_TIOCSERGWILD 0x5454
|
|
#define TARGET_TIOCSERSWILD 0x5455
|
|
#define TARGET_TIOCGLCKTRMIOS 0x5456
|
|
#define TARGET_TIOCSLCKTRMIOS 0x5457
|
|
#define TARGET_TIOCSERGSTRUCT 0x5458
|
|
#define TARGET_TIOCSERGETLSR 0x5459
|
|
#define TARGET_TIOCSERGETMULTI 0x545A
|
|
#define TARGET_TIOCSERSETMULTI 0x545B
|
|
|
|
#define TARGET_TIOCMIWAIT 0x545C
|
|
#define TARGET_TIOCGICOUNT 0x545D
|
|
#define TARGET_FIOQSIZE 0x5460
|
|
|
|
#define TARGET_TIOCPKT_DATA 0
|
|
#define TARGET_TIOCPKT_FLUSHREAD 1
|
|
#define TARGET_TIOCPKT_FLUSHWRITE 2
|
|
#define TARGET_TIOCPKT_STOP 4
|
|
#define TARGET_TIOCPKT_START 8
|
|
#define TARGET_TIOCPKT_NOSTOP 16
|
|
#define TARGET_TIOCPKT_DOSTOP 32
|
|
#define TARGET_TIOCPKT_IOCTL 64
|
|
|
|
#define TARGET_TIOCSER_TEMT 0x01
|
|
|
|
#endif
|