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*49231Smarc static char sccsid[] = "@(#)termios.c 5.8 (Berkeley) 05/06/91"; 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> 1647868Smarc #define KERNEL /* XXX - FREAD and FWRITE was 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 2935766Smarc 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; 43*49231Smarc opt &= ~TCSASOFT; 4435766Smarc } 4544301Smarc if (opt == TCSANOW) 4644301Smarc return (ioctl(fd, TIOCSETA, t)); 4744301Smarc else if (opt == TCSADRAIN) 4844301Smarc return (ioctl(fd, TIOCSETAW, t)); 4946597Sdonn return (ioctl(fd, TIOCSETAF, t)); 5035766Smarc } 5135766Smarc 5246597Sdonn int 5346597Sdonn #if __STDC__ 5446597Sdonn tcsetpgrp(int fd, pid_t pgrp) 5546597Sdonn #else 5635766Smarc tcsetpgrp(fd, pgrp) 5746597Sdonn int fd; 5846597Sdonn pid_t pgrp; 5946597Sdonn #endif 6035766Smarc { 6147868Smarc 6235766Smarc return(ioctl(fd, TIOCSPGRP, &pgrp)); 6335766Smarc } 6435766Smarc 6546597Sdonn pid_t 6635766Smarc tcgetpgrp(fd) 6735766Smarc { 6847731Sbostic int s; 6935766Smarc 7047731Sbostic if (ioctl(fd, TIOCGPGRP, &s) < 0) 7147731Sbostic return((pid_t)-1); 7247868Smarc 7347731Sbostic return((pid_t)s); 7435766Smarc } 7535766Smarc 7646597Sdonn speed_t 7735766Smarc cfgetospeed(t) 7846597Sdonn const struct termios *t; 7935766Smarc { 8047868Smarc 8135766Smarc return(t->c_ospeed); 8235766Smarc } 8335766Smarc 8446597Sdonn speed_t 8535766Smarc cfgetispeed(t) 8646597Sdonn const struct termios *t; 8735766Smarc { 8847868Smarc 8935766Smarc return(t->c_ispeed); 9035766Smarc } 9135766Smarc 9246597Sdonn int 9335766Smarc cfsetospeed(t, speed) 9435766Smarc struct termios *t; 9546597Sdonn speed_t speed; 9635766Smarc { 9735766Smarc t->c_ospeed = speed; 9847868Smarc 9947868Smarc return (0); 10035766Smarc } 10135766Smarc 10246597Sdonn int 10335766Smarc cfsetispeed(t, speed) 10435766Smarc struct termios *t; 10546597Sdonn speed_t speed; 10635766Smarc { 10735766Smarc t->c_ispeed = speed; 10847868Smarc 10947868Smarc return (0); 11035766Smarc } 11135766Smarc 11246597Sdonn void 11335766Smarc cfsetspeed(t, speed) 11435766Smarc struct termios *t; 11546597Sdonn speed_t speed; 11635766Smarc { 11735766Smarc t->c_ispeed = t->c_ospeed = speed; 11835766Smarc } 11935766Smarc 12046248Skarels /* 12146248Skarels * Make a pre-existing termios structure into "raw" mode: 12246248Skarels * character-at-a-time mode with no characters interpreted, 12346248Skarels * 8-bit data path. 12446248Skarels */ 12546597Sdonn void 12635766Smarc cfmakeraw(t) 12735766Smarc struct termios *t; 12835766Smarc { 12946248Skarels t->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); 13046248Skarels t->c_oflag &= ~OPOST; 13138596Skarels t->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); 13246248Skarels t->c_cflag &= ~(CSIZE|PARENB); 13346248Skarels t->c_cflag |= CS8; 13435766Smarc /* set MIN/TIME */ 13535766Smarc } 13647868Smarc 13747868Smarc tcsendbreak(fd, len) 13847868Smarc int fd, len; 13947868Smarc { 14047868Smarc struct timeval sleepytime; 14147868Smarc 14247868Smarc sleepytime.tv_sec = 0; 14347868Smarc sleepytime.tv_usec = 400000; 14447868Smarc if (ioctl(fd, TIOCSBRK, 0) == -1) 14547868Smarc return (-1); 14647868Smarc select(0, 0, 0, 0, &sleepytime); 14747868Smarc if (ioctl(fd, TIOCCBRK, 0) == -1) 14847868Smarc return (-1); 14947868Smarc 15047868Smarc return (0); 15147868Smarc } 15247868Smarc 15347868Smarc tcdrain(fd) 15447868Smarc int fd; 15547868Smarc { 15647868Smarc if (ioctl(fd, TIOCDRAIN, 0) == -1) 15747868Smarc return (-1); 15847868Smarc 15947868Smarc return (0); 16047868Smarc } 16147868Smarc 16247868Smarc tcflush(fd, which) 16347868Smarc int fd, which; 16447868Smarc { 16547868Smarc int com; 16647868Smarc 16747868Smarc switch (which) { 16847868Smarc case TCIFLUSH: 16947868Smarc com = FREAD; 17047868Smarc break; 17147868Smarc case TCOFLUSH: 17247868Smarc com = FWRITE; 17347868Smarc break; 17447868Smarc case TCIOFLUSH: 17547868Smarc com = FREAD | FWRITE; 17647868Smarc break; 17747868Smarc default: 17847868Smarc errno = EINVAL; 17947868Smarc return (-1); 18047868Smarc } 18147868Smarc if (ioctl(fd, TIOCFLUSH, &com) == -1) 18247868Smarc return (-1); 18347868Smarc 18447868Smarc return (0); 18547868Smarc } 18647868Smarc 18747868Smarc tcflow(fd, action) 18847868Smarc int fd, action; 18947868Smarc { 19047868Smarc switch (action) { 19147868Smarc case TCOOFF: 19247868Smarc return (ioctl(fd, TIOCSTOP, 0)); 19347868Smarc break; 19447868Smarc case TCOON: 19547868Smarc return (ioctl(fd, TIOCSTART, 0)); 19647868Smarc break; 19747868Smarc case TCIOFF: 19847868Smarc case TCION: { /* these posix functions are STUPID */ 19947868Smarc struct termios term; 20048860Smarc unsigned char c; 20147868Smarc 20248860Smarc if (tcgetattr(fd, &term) == -1) 20347868Smarc return (-1); 20447868Smarc c = term.c_cc[action == TCIOFF ? VSTOP : VSTART]; 20547868Smarc if (c != _POSIX_VDISABLE && write(fd, &c, 1) == -1) 20647868Smarc return (-1); 20747868Smarc break; 20847868Smarc } 20947868Smarc default: 21047868Smarc errno = EINVAL; 21147868Smarc return (-1); 21247868Smarc } 21347868Smarc 21447868Smarc return (0); 21547868Smarc } 216