termios.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. /* Copyright (C) 1992, 1993, 1996, 1997, 1998 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Library General Public License as
  5. published by the Free Software Foundation; either version 2 of the
  6. License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Library General Public License for more details.
  11. You should have received a copy of the GNU Library General Public
  12. License along with the GNU C Library; see the file COPYING.LIB. If not,
  13. write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  14. Boston, MA 02111-1307, USA.
  15. About the only thing remaining here fromthe original Linux-8086 C library
  16. version by Robert de Bath <robert@mayday.compulink.co.uk>, is the general
  17. layout. All else has been recently stolen from GNU libc, since that was
  18. much more current.
  19. */
  20. #include <errno.h>
  21. #include <stddef.h>
  22. #include <sys/ioctl.h>
  23. #include <termios.h>
  24. #include <unistd.h>
  25. #ifdef L_isatty
  26. /* Return 1 if FD is a terminal, 0 if not. */
  27. int isatty(int fd)
  28. {
  29. struct termios term;
  30. return tcgetattr(fd, &term) == 0;
  31. }
  32. #endif
  33. #ifdef L_tcdrain
  34. /* Wait for pending output to be written on FD. */
  35. int tcdrain (int fd)
  36. {
  37. /* With an argument of 1, TCSBRK waits for the output to drain. */
  38. return ioctl(fd, TCSBRK, 1);
  39. }
  40. #endif
  41. #ifdef L_tcflow
  42. /* Suspend or restart transmission on FD. */
  43. int tcflow ( int fd, int action)
  44. {
  45. return ioctl(fd, TCXONC, action);
  46. }
  47. #endif
  48. #ifdef L_tcflush
  49. /* Flush pending data on FD. */
  50. int tcflush ( int fd, int queue_selector)
  51. {
  52. return ioctl(fd, TCFLSH, queue_selector);
  53. }
  54. #endif
  55. #ifdef L_tcsendbreak
  56. /* Send zero bits on FD. */
  57. int tcsendbreak( int fd, int duration)
  58. {
  59. /*
  60. * The break lasts 0.25 to 0.5 seconds if DURATION is zero, and an
  61. * implementation-defined period if DURATION is nonzero. We define a
  62. * positive DURATION to be number of milliseconds to break.
  63. */
  64. if (duration <= 0)
  65. return ioctl(fd, TCSBRK, 0);
  66. /*
  67. * ioctl can't send a break of any other duration for us. This could be
  68. * changed to use trickery (e.g. lower speed and send a '\0') to send
  69. * the break, but for now just return an error.
  70. */
  71. errno = EINVAL;
  72. return -1;
  73. }
  74. #endif
  75. #ifdef L_tcsetpgrp
  76. /* Set the foreground process group ID of FD set PGRP_ID. */
  77. int tcsetpgrp ( int fd, pid_t pgrp_id)
  78. {
  79. return ioctl (fd, TIOCSPGRP, &pgrp_id);
  80. }
  81. #endif
  82. #ifdef L_tcgetpgrp
  83. /* Return the foreground process group ID of FD. */
  84. pid_t tcgetpgrp ( int fd)
  85. {
  86. int pgrp;
  87. if (ioctl (fd, TIOCGPGRP, &pgrp) < 0)
  88. return (pid_t) -1;
  89. return (pid_t) pgrp;
  90. }
  91. #endif
  92. /* This is a gross hack around a kernel bug. If the cfsetispeed functions is
  93. * called with the SPEED argument set to zero this means use the same speed as
  94. * for output. But we don't have independent input and output speeds and
  95. * therefore cannot record this.
  96. *
  97. * We use an unused bit in the `c_iflag' field to keep track of this use of
  98. * `cfsetispeed'. The value here must correspond to the one used in
  99. * `tcsetattr.c'. */
  100. #define IBAUD0 020000000000
  101. #ifdef L_cfgetospeed
  102. /* Return the output baud rate stored in *TERMIOS_P. */
  103. speed_t cfgetospeed ( const struct termios *termios_p)
  104. {
  105. return termios_p->c_cflag & (CBAUD | CBAUDEX);
  106. }
  107. #endif
  108. #ifdef L_cfgetispeed
  109. /* Return the input baud rate stored in *TERMIOS_P.
  110. * Although for Linux there is no difference between input and output
  111. * speed, the numerical 0 is a special case for the input baud rate. It
  112. * should set the input baud rate to the output baud rate. */
  113. speed_t cfgetispeed (const struct termios *termios_p)
  114. {
  115. return ((termios_p->c_iflag & IBAUD0)
  116. ? 0 : termios_p->c_cflag & (CBAUD | CBAUDEX));
  117. }
  118. #endif
  119. #ifdef L_cfsetospeed
  120. /* Set the output baud rate stored in *TERMIOS_P to SPEED. */
  121. int cfsetospeed (struct termios *termios_p, speed_t speed)
  122. {
  123. if ((speed & ~CBAUD) != 0
  124. && (speed < B57600 || speed > B460800))
  125. {
  126. errno=EINVAL;
  127. return -1;
  128. }
  129. termios_p->c_cflag &= ~(CBAUD | CBAUDEX);
  130. termios_p->c_cflag |= speed;
  131. return 0;
  132. }
  133. #endif
  134. #ifdef L_cfsetispeed
  135. /* Set the input baud rate stored in *TERMIOS_P to SPEED.
  136. * Although for Linux there is no difference between input and output
  137. * speed, the numerical 0 is a special case for the input baud rate. It
  138. * should set the input baud rate to the output baud rate. */
  139. int cfsetispeed ( struct termios *termios_p, speed_t speed)
  140. {
  141. if ((speed & ~CBAUD) != 0
  142. && (speed < B57600 || speed > B460800))
  143. {
  144. errno=EINVAL;
  145. return -1;
  146. }
  147. if (speed == 0)
  148. termios_p->c_iflag |= IBAUD0;
  149. else
  150. {
  151. termios_p->c_iflag &= ~IBAUD0;
  152. termios_p->c_cflag &= ~(CBAUD | CBAUDEX);
  153. termios_p->c_cflag |= speed;
  154. }
  155. return 0;
  156. }
  157. #endif
  158. #ifdef L_tcspeed
  159. struct speed_struct
  160. {
  161. speed_t value;
  162. speed_t internal;
  163. };
  164. static const struct speed_struct speeds[] =
  165. {
  166. #ifdef B0
  167. { 0, B0 },
  168. #endif
  169. #ifdef B50
  170. { 50, B50 },
  171. #endif
  172. #ifdef B75
  173. { 75, B75 },
  174. #endif
  175. #ifdef B110
  176. { 110, B110 },
  177. #endif
  178. #ifdef B134
  179. { 134, B134 },
  180. #endif
  181. #ifdef B150
  182. { 150, B150 },
  183. #endif
  184. #ifdef B200
  185. { 200, B200 },
  186. #endif
  187. #ifdef B300
  188. { 300, B300 },
  189. #endif
  190. #ifdef B600
  191. { 600, B600 },
  192. #endif
  193. #ifdef B1200
  194. { 1200, B1200 },
  195. #endif
  196. #ifdef B1200
  197. { 1200, B1200 },
  198. #endif
  199. #ifdef B1800
  200. { 1800, B1800 },
  201. #endif
  202. #ifdef B2400
  203. { 2400, B2400 },
  204. #endif
  205. #ifdef B4800
  206. { 4800, B4800 },
  207. #endif
  208. #ifdef B9600
  209. { 9600, B9600 },
  210. #endif
  211. #ifdef B19200
  212. { 19200, B19200 },
  213. #endif
  214. #ifdef B38400
  215. { 38400, B38400 },
  216. #endif
  217. #ifdef B57600
  218. { 57600, B57600 },
  219. #endif
  220. #ifdef B76800
  221. { 76800, B76800 },
  222. #endif
  223. #ifdef B115200
  224. { 115200, B115200 },
  225. #endif
  226. #ifdef B153600
  227. { 153600, B153600 },
  228. #endif
  229. #ifdef B230400
  230. { 230400, B230400 },
  231. #endif
  232. #ifdef B307200
  233. { 307200, B307200 },
  234. #endif
  235. #ifdef B460800
  236. { 460800, B460800 },
  237. #endif
  238. };
  239. /* Set both the input and output baud rates stored in *TERMIOS_P to SPEED. */
  240. int cfsetspeed (struct termios *termios_p, speed_t speed)
  241. {
  242. size_t cnt;
  243. for (cnt = 0; cnt < sizeof (speeds) / sizeof (speeds[0]); ++cnt)
  244. if (speed == speeds[cnt].internal)
  245. {
  246. cfsetispeed (termios_p, speed);
  247. cfsetospeed (termios_p, speed);
  248. return 0;
  249. }
  250. else if (speed == speeds[cnt].value)
  251. {
  252. cfsetispeed (termios_p, speeds[cnt].internal);
  253. cfsetospeed (termios_p, speeds[cnt].internal);
  254. return 0;
  255. }
  256. __set_errno (EINVAL);
  257. return -1;
  258. }
  259. #endif
  260. #ifdef L_cfmakeraw
  261. /* Copyright (C) 1992, 1996, 1997 Free Software Foundation, Inc.
  262. This file is part of the GNU C Library.
  263. */
  264. #include <termios.h>
  265. /* Set *T to indicate raw mode. */
  266. void
  267. cfmakeraw (t)
  268. struct termios *t;
  269. {
  270. t->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON);
  271. t->c_oflag &= ~OPOST;
  272. t->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN);
  273. t->c_cflag &= ~(CSIZE|PARENB);
  274. t->c_cflag |= CS8;
  275. t->c_cc[VMIN] = 1; /* read returns when one char is available. */
  276. t->c_cc[VTIME] = 0;
  277. }
  278. #endif