ioctls.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. /*
  3. * include/asm-xtensa/ioctls.h
  4. *
  5. * This file is subject to the terms and conditions of the GNU General Public
  6. * License. See the file "COPYING" in the main directory of this archive
  7. * for more details.
  8. *
  9. * Copyright (C) 2003 - 2005 Tensilica Inc.
  10. *
  11. * Derived from "include/asm-i386/ioctls.h"
  12. */
  13. #ifndef _XTENSA_IOCTLS_H
  14. #define _XTENSA_IOCTLS_H
  15. #include <asm/ioctl.h>
  16. #define FIOCLEX _IO('f', 1)
  17. #define FIONCLEX _IO('f', 2)
  18. #define FIOASYNC _IOW('f', 125, int)
  19. #define FIONBIO _IOW('f', 126, int)
  20. #define FIONREAD _IOR('f', 127, int)
  21. #define TIOCINQ FIONREAD
  22. #define FIOQSIZE _IOR('f', 128, loff_t)
  23. #define TCGETS 0x5401
  24. #define TCSETS 0x5402
  25. #define TCSETSW 0x5403
  26. #define TCSETSF 0x5404
  27. #define TCGETA 0x80127417 /* _IOR('t', 23, struct termio) */
  28. #define TCSETA 0x40127418 /* _IOW('t', 24, struct termio) */
  29. #define TCSETAW 0x40127419 /* _IOW('t', 25, struct termio) */
  30. #define TCSETAF 0x4012741C /* _IOW('t', 28, struct termio) */
  31. #define TCSBRK _IO('t', 29)
  32. #define TCXONC _IO('t', 30)
  33. #define TCFLSH _IO('t', 31)
  34. #define TIOCSWINSZ 0x40087467 /* _IOW('t', 103, struct winsize) */
  35. #define TIOCGWINSZ 0x80087468 /* _IOR('t', 104, struct winsize) */
  36. #define TIOCSTART _IO('t', 110) /* start output, like ^Q */
  37. #define TIOCSTOP _IO('t', 111) /* stop output, like ^S */
  38. #define TIOCOUTQ _IOR('t', 115, int) /* output queue size */
  39. #define TIOCSPGRP _IOW('t', 118, int)
  40. #define TIOCGPGRP _IOR('t', 119, int)
  41. #define TIOCEXCL _IO('T', 12)
  42. #define TIOCNXCL _IO('T', 13)
  43. #define TIOCSCTTY _IO('T', 14)
  44. #define TIOCSTI _IOW('T', 18, char)
  45. #define TIOCMGET _IOR('T', 21, unsigned int)
  46. #define TIOCMBIS _IOW('T', 22, unsigned int)
  47. #define TIOCMBIC _IOW('T', 23, unsigned int)
  48. #define TIOCMSET _IOW('T', 24, unsigned int)
  49. # define TIOCM_LE 0x001
  50. # define TIOCM_DTR 0x002
  51. # define TIOCM_RTS 0x004
  52. # define TIOCM_ST 0x008
  53. # define TIOCM_SR 0x010
  54. # define TIOCM_CTS 0x020
  55. # define TIOCM_CAR 0x040
  56. # define TIOCM_RNG 0x080
  57. # define TIOCM_DSR 0x100
  58. # define TIOCM_CD TIOCM_CAR
  59. # define TIOCM_RI TIOCM_RNG
  60. #define TIOCGSOFTCAR _IOR('T', 25, unsigned int)
  61. #define TIOCSSOFTCAR _IOW('T', 26, unsigned int)
  62. #define TIOCLINUX _IOW('T', 28, char)
  63. #define TIOCCONS _IO('T', 29)
  64. #define TIOCGSERIAL 0x803C541E /*_IOR('T', 30, struct serial_struct)*/
  65. #define TIOCSSERIAL 0x403C541F /*_IOW('T', 31, struct serial_struct)*/
  66. #define TIOCPKT _IOW('T', 32, int)
  67. # define TIOCPKT_DATA 0
  68. # define TIOCPKT_FLUSHREAD 1
  69. # define TIOCPKT_FLUSHWRITE 2
  70. # define TIOCPKT_STOP 4
  71. # define TIOCPKT_START 8
  72. # define TIOCPKT_NOSTOP 16
  73. # define TIOCPKT_DOSTOP 32
  74. # define TIOCPKT_IOCTL 64
  75. #define TIOCNOTTY _IO('T', 34)
  76. #define TIOCSETD _IOW('T', 35, int)
  77. #define TIOCGETD _IOR('T', 36, int)
  78. #define TCSBRKP _IOW('T', 37, int) /* Needed for POSIX tcsendbreak()*/
  79. #define TIOCSBRK _IO('T', 39) /* BSD compatibility */
  80. #define TIOCCBRK _IO('T', 40) /* BSD compatibility */
  81. #define TIOCGSID _IOR('T', 41, pid_t) /* Return the session ID of FD*/
  82. #define TCGETS2 _IOR('T', 42, struct termios2)
  83. #define TCSETS2 _IOW('T', 43, struct termios2)
  84. #define TCSETSW2 _IOW('T', 44, struct termios2)
  85. #define TCSETSF2 _IOW('T', 45, struct termios2)
  86. #define TIOCGRS485 _IOR('T', 46, struct serial_rs485)
  87. #define TIOCSRS485 _IOWR('T', 47, struct serial_rs485)
  88. #define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
  89. #define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */
  90. #define TIOCGDEV _IOR('T',0x32, unsigned int) /* Get primary device node of /dev/console */
  91. #define TIOCSIG _IOW('T',0x36, int) /* Generate signal on Pty slave */
  92. #define TIOCVHANGUP _IO('T', 0x37)
  93. #define TIOCGPKT _IOR('T', 0x38, int) /* Get packet mode state */
  94. #define TIOCGPTLCK _IOR('T', 0x39, int) /* Get Pty lock state */
  95. #define TIOCGEXCL _IOR('T', 0x40, int) /* Get exclusive mode state */
  96. #define TIOCGPTPEER _IO('T', 0x41) /* Safely open the slave */
  97. #define TIOCGISO7816 _IOR('T', 0x42, struct serial_iso7816)
  98. #define TIOCSISO7816 _IOWR('T', 0x43, struct serial_iso7816)
  99. #define TIOCSERCONFIG _IO('T', 83)
  100. #define TIOCSERGWILD _IOR('T', 84, int)
  101. #define TIOCSERSWILD _IOW('T', 85, int)
  102. #define TIOCGLCKTRMIOS 0x5456
  103. #define TIOCSLCKTRMIOS 0x5457
  104. #define TIOCSERGSTRUCT 0x5458 /* For debugging only */
  105. #define TIOCSERGETLSR _IOR('T', 89, unsigned int) /* Get line status reg. */
  106. /* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
  107. # define TIOCSER_TEMT 0x01 /* Transmitter physically empty */
  108. #define TIOCSERGETMULTI 0x80a8545a /* Get multiport config */
  109. /* _IOR('T', 90, struct serial_multiport_struct) */
  110. #define TIOCSERSETMULTI 0x40a8545b /* Set multiport config */
  111. /* _IOW('T', 91, struct serial_multiport_struct) */
  112. #define TIOCMIWAIT _IO('T', 92) /* wait for a change on serial input line(s) */
  113. #define TIOCGICOUNT 0x545D /* read serial port inline interrupt counts */
  114. #endif /* _XTENSA_IOCTLS_H */