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*49822Sbostic static char sccsid[] = "@(#)termios.c 5.9 (Berkeley) 05/20/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; 4349231Smarc 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 { 61*49822Sbostic int s; 6247868Smarc 63*49822Sbostic s = pgrp; 64*49822Sbostic return(ioctl(fd, TIOCSPGRP, &s)); 6535766Smarc } 6635766Smarc 6746597Sdonn pid_t 6835766Smarc tcgetpgrp(fd) 6935766Smarc { 7047731Sbostic int s; 7135766Smarc 7247731Sbostic if (ioctl(fd, TIOCGPGRP, &s) < 0) 7347731Sbostic return((pid_t)-1); 7447868Smarc 7547731Sbostic return((pid_t)s); 7635766Smarc } 7735766Smarc 7846597Sdonn speed_t 7935766Smarc cfgetospeed(t) 8046597Sdonn const struct termios *t; 8135766Smarc { 8247868Smarc 8335766Smarc return(t->c_ospeed); 8435766Smarc } 8535766Smarc 8646597Sdonn speed_t 8735766Smarc cfgetispeed(t) 8846597Sdonn const struct termios *t; 8935766Smarc { 9047868Smarc 9135766Smarc return(t->c_ispeed); 9235766Smarc } 9335766Smarc 9446597Sdonn int 9535766Smarc cfsetospeed(t, speed) 9635766Smarc struct termios *t; 9746597Sdonn speed_t speed; 9835766Smarc { 9935766Smarc t->c_ospeed = speed; 10047868Smarc 10147868Smarc return (0); 10235766Smarc } 10335766Smarc 10446597Sdonn int 10535766Smarc cfsetispeed(t, speed) 10635766Smarc struct termios *t; 10746597Sdonn speed_t speed; 10835766Smarc { 10935766Smarc t->c_ispeed = speed; 11047868Smarc 11147868Smarc return (0); 11235766Smarc } 11335766Smarc 11446597Sdonn void 11535766Smarc cfsetspeed(t, speed) 11635766Smarc struct termios *t; 11746597Sdonn speed_t speed; 11835766Smarc { 11935766Smarc t->c_ispeed = t->c_ospeed = speed; 12035766Smarc } 12135766Smarc 12246248Skarels /* 12346248Skarels * Make a pre-existing termios structure into "raw" mode: 12446248Skarels * character-at-a-time mode with no characters interpreted, 12546248Skarels * 8-bit data path. 12646248Skarels */ 12746597Sdonn void 12835766Smarc cfmakeraw(t) 12935766Smarc struct termios *t; 13035766Smarc { 13146248Skarels t->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); 13246248Skarels t->c_oflag &= ~OPOST; 13338596Skarels t->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); 13446248Skarels t->c_cflag &= ~(CSIZE|PARENB); 13546248Skarels t->c_cflag |= CS8; 13635766Smarc /* set MIN/TIME */ 13735766Smarc } 13847868Smarc 13947868Smarc tcsendbreak(fd, len) 14047868Smarc int fd, len; 14147868Smarc { 14247868Smarc struct timeval sleepytime; 14347868Smarc 14447868Smarc sleepytime.tv_sec = 0; 14547868Smarc sleepytime.tv_usec = 400000; 14647868Smarc if (ioctl(fd, TIOCSBRK, 0) == -1) 14747868Smarc return (-1); 14847868Smarc select(0, 0, 0, 0, &sleepytime); 14947868Smarc if (ioctl(fd, TIOCCBRK, 0) == -1) 15047868Smarc return (-1); 15147868Smarc 15247868Smarc return (0); 15347868Smarc } 15447868Smarc 15547868Smarc tcdrain(fd) 15647868Smarc int fd; 15747868Smarc { 15847868Smarc if (ioctl(fd, TIOCDRAIN, 0) == -1) 15947868Smarc return (-1); 16047868Smarc 16147868Smarc return (0); 16247868Smarc } 16347868Smarc 16447868Smarc tcflush(fd, which) 16547868Smarc int fd, which; 16647868Smarc { 16747868Smarc int com; 16847868Smarc 16947868Smarc switch (which) { 17047868Smarc case TCIFLUSH: 17147868Smarc com = FREAD; 17247868Smarc break; 17347868Smarc case TCOFLUSH: 17447868Smarc com = FWRITE; 17547868Smarc break; 17647868Smarc case TCIOFLUSH: 17747868Smarc com = FREAD | FWRITE; 17847868Smarc break; 17947868Smarc default: 18047868Smarc errno = EINVAL; 18147868Smarc return (-1); 18247868Smarc } 18347868Smarc if (ioctl(fd, TIOCFLUSH, &com) == -1) 18447868Smarc return (-1); 18547868Smarc 18647868Smarc return (0); 18747868Smarc } 18847868Smarc 18947868Smarc tcflow(fd, action) 19047868Smarc int fd, action; 19147868Smarc { 19247868Smarc switch (action) { 19347868Smarc case TCOOFF: 19447868Smarc return (ioctl(fd, TIOCSTOP, 0)); 19547868Smarc break; 19647868Smarc case TCOON: 19747868Smarc return (ioctl(fd, TIOCSTART, 0)); 19847868Smarc break; 19947868Smarc case TCIOFF: 20047868Smarc case TCION: { /* these posix functions are STUPID */ 20147868Smarc struct termios term; 20248860Smarc unsigned char c; 20347868Smarc 20448860Smarc if (tcgetattr(fd, &term) == -1) 20547868Smarc return (-1); 20647868Smarc c = term.c_cc[action == TCIOFF ? VSTOP : VSTART]; 20747868Smarc if (c != _POSIX_VDISABLE && write(fd, &c, 1) == -1) 20847868Smarc return (-1); 20947868Smarc break; 21047868Smarc } 21147868Smarc default: 21247868Smarc errno = EINVAL; 21347868Smarc return (-1); 21447868Smarc } 21547868Smarc 21647868Smarc return (0); 21747868Smarc } 218