144301Smarc /*- 238597Skarels * Copyright (c) 1989 The Regents of the University of California. 338597Skarels * All rights reserved. 438597Skarels * 544301Smarc * %sccs.include.redist.c% 638597Skarels */ 738597Skarels 838597Skarels #if defined(LIBC_SCCS) && !defined(lint) 9*52492Skarels static char sccsid[] = "@(#)termios.c 5.12 (Berkeley) 02/14/92"; 1038597Skarels #endif /* LIBC_SCCS and not lint */ 1138597Skarels 1235766Smarc #include <sys/types.h> 1335766Smarc #include <sys/errno.h> 1444301Smarc #include <sys/ioctl.h> 1544301Smarc #include <sys/tty.h> 1652295Sbostic #define KERNEL /* XXX - FREAD and FWRITE ifdef'd KERNEL*/ 1747868Smarc #include <sys/fcntl.h> 1847868Smarc #undef KERNEL 1946597Sdonn #include <termios.h> 2035766Smarc #include <stdio.h> 2146597Sdonn #include <unistd.h> 2235766Smarc 2346597Sdonn int 2435766Smarc tcgetattr(fd, t) 2535766Smarc int fd; 2635766Smarc struct termios *t; 2735766Smarc { 2835766Smarc 2952295Sbostic return (ioctl(fd, TIOCGETA, t)); 3035766Smarc } 3135766Smarc 3246597Sdonn int 3335766Smarc tcsetattr(fd, opt, t) 3435766Smarc int fd, opt; 3546597Sdonn const struct termios *t; 3635766Smarc { 3744301Smarc struct termios localterm; 3835766Smarc 3944301Smarc if (opt & TCSASOFT) { 4044301Smarc localterm = *t; 4144301Smarc localterm.c_cflag |= CIGNORE; 4244301Smarc t = &localterm; 4335766Smarc } 4452489Skarels switch (opt & ~TCSASOFT) { 4552295Sbostic case TCSANOW: 4644301Smarc return (ioctl(fd, TIOCSETA, t)); 4752295Sbostic case TCSADRAIN: 4844301Smarc return (ioctl(fd, TIOCSETAW, t)); 4952489Skarels case TCSAFLUSH: 5052295Sbostic return (ioctl(fd, TIOCSETAF, t)); 5152295Sbostic default: 5252295Sbostic errno = EINVAL; 5352295Sbostic return (-1); 5452295Sbostic } 5535766Smarc } 5635766Smarc 5746597Sdonn int 5846597Sdonn #if __STDC__ 5946597Sdonn tcsetpgrp(int fd, pid_t pgrp) 6046597Sdonn #else 6135766Smarc tcsetpgrp(fd, pgrp) 6246597Sdonn int fd; 6346597Sdonn pid_t pgrp; 6446597Sdonn #endif 6535766Smarc { 6649822Sbostic int s; 6747868Smarc 6849822Sbostic s = pgrp; 6952295Sbostic return (ioctl(fd, TIOCSPGRP, &s)); 7035766Smarc } 7135766Smarc 7246597Sdonn pid_t 7335766Smarc tcgetpgrp(fd) 7435766Smarc { 7547731Sbostic int s; 7635766Smarc 7747731Sbostic if (ioctl(fd, TIOCGPGRP, &s) < 0) 7852295Sbostic return ((pid_t)-1); 7947868Smarc 8052295Sbostic return ((pid_t)s); 8135766Smarc } 8235766Smarc 8346597Sdonn speed_t 8435766Smarc cfgetospeed(t) 8546597Sdonn const struct termios *t; 8635766Smarc { 8747868Smarc 8852295Sbostic return (t->c_ospeed); 8935766Smarc } 9035766Smarc 9146597Sdonn speed_t 9235766Smarc cfgetispeed(t) 9346597Sdonn const struct termios *t; 9435766Smarc { 9547868Smarc 9652295Sbostic return (t->c_ispeed); 9735766Smarc } 9835766Smarc 9946597Sdonn int 10035766Smarc cfsetospeed(t, speed) 10135766Smarc struct termios *t; 10246597Sdonn speed_t speed; 10335766Smarc { 104*52492Skarels 10535766Smarc t->c_ospeed = speed; 10647868Smarc return (0); 10735766Smarc } 10835766Smarc 10946597Sdonn int 11035766Smarc cfsetispeed(t, speed) 11135766Smarc struct termios *t; 11246597Sdonn speed_t speed; 11335766Smarc { 114*52492Skarels 11535766Smarc t->c_ispeed = speed; 11647868Smarc return (0); 11735766Smarc } 11835766Smarc 11952295Sbostic int 12035766Smarc cfsetspeed(t, speed) 12135766Smarc struct termios *t; 12246597Sdonn speed_t speed; 12335766Smarc { 124*52492Skarels 12535766Smarc t->c_ispeed = t->c_ospeed = speed; 12652295Sbostic return (0); 12735766Smarc } 12835766Smarc 12946248Skarels /* 13052295Sbostic * Make a pre-existing termios structure into "raw" mode: character-at-a-time 13152295Sbostic * mode with no characters interpreted, 8-bit data path. 13246248Skarels */ 13346597Sdonn void 13435766Smarc cfmakeraw(t) 13535766Smarc struct termios *t; 13635766Smarc { 137*52492Skarels 13846248Skarels t->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); 13946248Skarels t->c_oflag &= ~OPOST; 14038596Skarels t->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); 14146248Skarels t->c_cflag &= ~(CSIZE|PARENB); 14246248Skarels t->c_cflag |= CS8; 14352295Sbostic /* XXX set MIN/TIME */ 14435766Smarc } 14547868Smarc 14647868Smarc tcsendbreak(fd, len) 14747868Smarc int fd, len; 14847868Smarc { 14947868Smarc struct timeval sleepytime; 15047868Smarc 15147868Smarc sleepytime.tv_sec = 0; 15247868Smarc sleepytime.tv_usec = 400000; 15347868Smarc if (ioctl(fd, TIOCSBRK, 0) == -1) 15447868Smarc return (-1); 15552295Sbostic (void)select(0, 0, 0, 0, &sleepytime); 15647868Smarc if (ioctl(fd, TIOCCBRK, 0) == -1) 15747868Smarc return (-1); 15847868Smarc return (0); 15947868Smarc } 16047868Smarc 16147868Smarc tcdrain(fd) 16247868Smarc int fd; 16347868Smarc { 164*52492Skarels 165*52492Skarels return (ioctl(fd, TIOCDRAIN, 0)); 16647868Smarc } 16747868Smarc 16847868Smarc tcflush(fd, which) 16947868Smarc int fd, which; 17047868Smarc { 17147868Smarc int com; 17247868Smarc 17347868Smarc switch (which) { 17447868Smarc case TCIFLUSH: 17547868Smarc com = FREAD; 17647868Smarc break; 17747868Smarc case TCOFLUSH: 17847868Smarc com = FWRITE; 17947868Smarc break; 18047868Smarc case TCIOFLUSH: 18147868Smarc com = FREAD | FWRITE; 18247868Smarc break; 18347868Smarc default: 18447868Smarc errno = EINVAL; 18547868Smarc return (-1); 18647868Smarc } 187*52492Skarels return (ioctl(fd, TIOCFLUSH, &com)); 18847868Smarc } 18947868Smarc 19047868Smarc tcflow(fd, action) 19147868Smarc int fd, action; 19247868Smarc { 19352295Sbostic struct termios term; 19452295Sbostic u_char c; 19552295Sbostic 19647868Smarc switch (action) { 19747868Smarc case TCOOFF: 198*52492Skarels return (ioctl(fd, TIOCSTOP, 0)); 19947868Smarc case TCOON: 200*52492Skarels return (ioctl(fd, TIOCSTART, 0)); 20152295Sbostic case TCION: 20247868Smarc case TCIOFF: 20348860Smarc if (tcgetattr(fd, &term) == -1) 20447868Smarc return (-1); 20547868Smarc c = term.c_cc[action == TCIOFF ? VSTOP : VSTART]; 20652295Sbostic if (c != _POSIX_VDISABLE && write(fd, &c, sizeof(c)) == -1) 20747868Smarc return (-1); 20852295Sbostic return (0); 20947868Smarc default: 21047868Smarc errno = EINVAL; 21147868Smarc return (-1); 21247868Smarc } 21352295Sbostic /* NOTREACHED */ 21447868Smarc } 215