Annotation of 43BSDReno/sys/hpux/hpux_tty.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1988 University of Utah.
                      3:  * Copyright (c) 1990 The Regents of the University of California.
                      4:  * All rights reserved.
                      5:  *
                      6:  * This code is derived from software contributed to Berkeley by
                      7:  * the Systems Programming Group of the University of Utah Computer
                      8:  * Science Department.
                      9:  *
                     10:  * Redistribution is only permitted until one year after the first shipment
                     11:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
                     12:  * binary forms are permitted provided that: (1) source distributions retain
                     13:  * this entire copyright notice and comment, and (2) distributions including
                     14:  * binaries display the following acknowledgement:  This product includes
                     15:  * software developed by the University of California, Berkeley and its
                     16:  * contributors'' in the documentation or other materials provided with the
                     17:  * distribution and in all advertising materials mentioning features or use
                     18:  * of this software.  Neither the name of the University nor the names of
                     19:  * its contributors may be used to endorse or promote products derived from
                     20:  * this software without specific prior written permission.
                     21:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
                     22:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
                     23:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     24:  *
                     25:  * from: Utah $Hdr: hpux_tty.c 1.7 89/04/11$
                     26:  *
                     27:  *     @(#)hpux_tty.c  7.4 (Berkeley) 6/27/90
                     28:  */
                     29: 
                     30: /*
                     31:  * stty/gtty/termio emulation stuff
                     32:  */
                     33: #ifdef HPUXCOMPAT
                     34: 
                     35: #include "param.h"
                     36: #include "systm.h"
                     37: #include "user.h"
                     38: #include "ioctl.h"
                     39: #include "tty.h"
                     40: #include "proc.h"
                     41: #include "file.h"
                     42: #include "conf.h"
                     43: #include "buf.h"
                     44: #include "uio.h"
                     45: #include "kernel.h"
                     46: 
                     47: #include "hpux.h"
                     48: #include "hpux_termio.h"
                     49: 
                     50: /*
                     51:  * Map BSD/POSIX style termios info to and from SYS5 style termio stuff.
                     52:  */
                     53: hpuxtermio(fp, com, data)
                     54:        struct file *fp;
                     55:        caddr_t data;
                     56: {
                     57:        struct termios tios;
                     58:        int line, error, (*ioctlrout)();
                     59:        register struct hpuxtermio *tiop;
                     60: 
                     61:        ioctlrout = fp->f_ops->fo_ioctl;
                     62:        tiop = (struct hpuxtermio *)data;
                     63:        switch (com) {
                     64:        case HPUXTCGETA:
                     65:                /*
                     66:                 * Get BSD terminal state
                     67:                 */
                     68:                bzero(data, sizeof(struct hpuxtermio));
                     69:                if (error = (*ioctlrout)(fp, TIOCGETA, (caddr_t)&tios))
                     70:                        break;
                     71:                /*
                     72:                 * Set iflag.
                     73:                 * Same through ICRNL, no BSD equivs for IUCLC, IENQAK
                     74:                 */
                     75:                tiop->c_iflag = tios.c_iflag & 0x1ff;
                     76:                if (tios.c_iflag & IXON)
                     77:                        tiop->c_iflag |= TIO_IXON;
                     78:                if (tios.c_iflag & IXOFF)
                     79:                        tiop->c_iflag |= TIO_IXOFF;
                     80:                if (tios.c_iflag & IXANY)
                     81:                        tiop->c_iflag |= TIO_IXANY;
                     82:                /*
                     83:                 * Set oflag.
                     84:                 * No BSD equivs for OLCUC/OCRNL/ONOCR/ONLRET/OFILL/OFDEL
                     85:                 * or any of the delays.
                     86:                 */
                     87:                if (tios.c_oflag & OPOST)
                     88:                        tiop->c_oflag |= TIO_OPOST;
                     89:                if (tios.c_oflag & ONLCR)
                     90:                        tiop->c_oflag |= TIO_ONLCR;
                     91:                if (tios.c_oflag & OXTABS)
                     92:                        tiop->c_oflag |= TIO_TAB3;
                     93:                /*
                     94:                 * Set cflag.
                     95:                 * Baud from ospeed, rest from cflag.
                     96:                 */
                     97:                tiop->c_cflag = bsdtohpuxbaud(tios.c_ospeed);
                     98:                switch (tios.c_cflag & CSIZE) {
                     99:                case CS5:
                    100:                        tiop->c_cflag |= TIO_CS5; break;
                    101:                case CS6:
                    102:                        tiop->c_cflag |= TIO_CS6; break;
                    103:                case CS7:
                    104:                        tiop->c_cflag |= TIO_CS7; break;
                    105:                case CS8:
                    106:                        tiop->c_cflag |= TIO_CS8; break;
                    107:                }
                    108:                if (tios.c_cflag & CSTOPB)
                    109:                        tiop->c_cflag |= TIO_CSTOPB;
                    110:                if (tios.c_cflag & CREAD)
                    111:                        tiop->c_cflag |= TIO_CREAD;
                    112:                if (tios.c_cflag & PARENB)
                    113:                        tiop->c_cflag |= TIO_PARENB;
                    114:                if (tios.c_cflag & PARODD)
                    115:                        tiop->c_cflag |= TIO_PARODD;
                    116:                if (tios.c_cflag & HUPCL)
                    117:                        tiop->c_cflag |= TIO_HUPCL;
                    118:                if (tios.c_cflag & CLOCAL)
                    119:                        tiop->c_cflag |= TIO_CLOCAL;
                    120:                /*
                    121:                 * Set lflag.
                    122:                 * No BSD equiv for XCASE.
                    123:                 */
                    124:                if (tios.c_lflag & ECHOE)
                    125:                        tiop->c_lflag |= TIO_ECHOE;
                    126:                if (tios.c_lflag & ECHOK)
                    127:                        tiop->c_lflag |= TIO_ECHOK;
                    128:                if (tios.c_lflag & ECHO)
                    129:                        tiop->c_lflag |= TIO_ECHO;
                    130:                if (tios.c_lflag & ECHONL)
                    131:                        tiop->c_lflag |= TIO_ECHONL;
                    132:                if (tios.c_lflag & ISIG)
                    133:                        tiop->c_lflag |= TIO_ISIG;
                    134:                if (tios.c_lflag & ICANON)
                    135:                        tiop->c_lflag |= TIO_ICANON;
                    136:                if (tios.c_lflag & NOFLSH)
                    137:                        tiop->c_lflag |= TIO_NOFLSH;
                    138:                /*
                    139:                 * Line discipline
                    140:                 */
                    141:                line = 0;
                    142:                (void) (*ioctlrout)(fp, TIOCGETD, (caddr_t)&line);
                    143:                tiop->c_line = line;
                    144:                /*
                    145:                 * Set editing chars
                    146:                 */
                    147:                tiop->c_cc[HPUXVINTR] = tios.c_cc[VINTR];
                    148:                tiop->c_cc[HPUXVQUIT] = tios.c_cc[VQUIT];
                    149:                tiop->c_cc[HPUXVERASE] = tios.c_cc[VERASE];
                    150:                tiop->c_cc[HPUXVKILL] = tios.c_cc[VKILL];
                    151:                if (tiop->c_lflag & TIO_ICANON) {
                    152:                        tiop->c_cc[HPUXVEOF] = tios.c_cc[VEOF];
                    153:                        tiop->c_cc[HPUXVEOL] = tios.c_cc[VEOL];
                    154:                } else {
                    155:                        tiop->c_cc[HPUXVMIN] = tios.c_cc[VMIN];
                    156:                        tiop->c_cc[HPUXVTIME] = tios.c_cc[VTIME];
                    157:                }
                    158:                break;
                    159: 
                    160:        case HPUXTCSETA:
                    161:        case HPUXTCSETAW:
                    162:        case HPUXTCSETAF:
                    163:                /*
                    164:                 * Get old characteristics and determine if we are a tty.
                    165:                 */
                    166:                if (error = (*ioctlrout)(fp, TIOCGETA, (caddr_t)&tios))
                    167:                        break;
                    168:                /*
                    169:                 * Set iflag.
                    170:                 * Same through ICRNL, no HP-UX equiv for IMAXBEL
                    171:                 */
                    172:                tios.c_iflag &= ~(IXON|IXOFF|IXANY|0x1ff);
                    173:                tios.c_iflag |= tiop->c_iflag & 0x1ff;
                    174:                if (tiop->c_iflag & TIO_IXON)
                    175:                        tios.c_iflag |= IXON;
                    176:                if (tiop->c_iflag & TIO_IXOFF)
                    177:                        tios.c_iflag |= IXOFF;
                    178:                if (tiop->c_iflag & TIO_IXANY)
                    179:                        tios.c_iflag |= IXANY;
                    180:                /*
                    181:                 * Set oflag.
                    182:                 * No HP-UX equiv for ONOEOT
                    183:                 */
                    184:                tios.c_oflag &= ~(OPOST|ONLCR|OXTABS);
                    185:                if (tiop->c_oflag & TIO_OPOST)
                    186:                        tios.c_oflag |= OPOST;
                    187:                if (tiop->c_oflag & TIO_ONLCR)
                    188:                        tios.c_oflag |= ONLCR;
                    189:                if (tiop->c_oflag & TIO_TAB3)
                    190:                        tios.c_oflag |= OXTABS;
                    191:                /*
                    192:                 * Set cflag.
                    193:                 * No HP-UX equiv for CCTS_OFLOW/CCTS_IFLOW/MDMBUF
                    194:                 */
                    195:                tios.c_cflag &=
                    196:                        ~(CSIZE|CSTOPB|CREAD|PARENB|PARODD|HUPCL|CLOCAL);
                    197:                switch (tiop->c_cflag & TIO_CSIZE) {
                    198:                case TIO_CS5:
                    199:                        tios.c_cflag |= CS5; break;
                    200:                case TIO_CS6:
                    201:                        tios.c_cflag |= CS6; break;
                    202:                case TIO_CS7:
                    203:                        tios.c_cflag |= CS7; break;
                    204:                case TIO_CS8:
                    205:                        tios.c_cflag |= CS8; break;
                    206:                }
                    207:                if (tiop->c_cflag & TIO_CSTOPB)
                    208:                        tios.c_cflag |= CSTOPB;
                    209:                if (tiop->c_cflag & TIO_CREAD)
                    210:                        tios.c_cflag |= CREAD;
                    211:                if (tiop->c_cflag & TIO_PARENB)
                    212:                        tios.c_cflag |= PARENB;
                    213:                if (tiop->c_cflag & TIO_PARODD)
                    214:                        tios.c_cflag |= PARODD;
                    215:                if (tiop->c_cflag & TIO_HUPCL)
                    216:                        tios.c_cflag |= HUPCL;
                    217:                if (tiop->c_cflag & TIO_CLOCAL)
                    218:                        tios.c_cflag |= CLOCAL;
                    219:                /*
                    220:                 * Set lflag.
                    221:                 * No HP-UX equiv for ECHOKE/ECHOPRT/ECHOCTL
                    222:                 * IEXTEN treated as part of ICANON
                    223:                 */
                    224:                tios.c_lflag &= ~(ECHOE|ECHOK|ECHO|ISIG|ICANON|IEXTEN|NOFLSH);
                    225:                if (tiop->c_lflag & TIO_ECHOE)
                    226:                        tios.c_lflag |= ECHOE;
                    227:                if (tiop->c_lflag & TIO_ECHOK)
                    228:                        tios.c_lflag |= ECHOK;
                    229:                if (tiop->c_lflag & TIO_ECHO)
                    230:                        tios.c_lflag |= ECHO;
                    231:                if (tiop->c_lflag & TIO_ECHONL)
                    232:                        tios.c_lflag |= ECHONL;
                    233:                if (tiop->c_lflag & TIO_ISIG)
                    234:                        tios.c_lflag |= ISIG;
                    235:                if (tiop->c_lflag & TIO_ICANON)
                    236:                        tios.c_lflag |= (ICANON|IEXTEN);
                    237:                if (tiop->c_lflag & TIO_NOFLSH)
                    238:                        tios.c_lflag |= NOFLSH;
                    239:                /*
                    240:                 * Set editing chars.
                    241:                 * No HP-UX equivs of VEOL2/VWERASE/VREPRINT/VSUSP/VDSUSP
                    242:                 * VSTOP/VLNEXT/VDISCARD/VMIN/VTIME/VSTATUS/VERASE2
                    243:                 */
                    244:                tios.c_cc[VINTR] = tiop->c_cc[HPUXVINTR];
                    245:                tios.c_cc[VQUIT] = tiop->c_cc[HPUXVQUIT];
                    246:                tios.c_cc[VERASE] = tiop->c_cc[HPUXVERASE];
                    247:                tios.c_cc[VKILL] = tiop->c_cc[HPUXVKILL];
                    248:                if (tios.c_lflag & ICANON) {
                    249:                        tios.c_cc[VEOF] = tiop->c_cc[HPUXVEOF];
                    250:                        tios.c_cc[VEOL] = tiop->c_cc[HPUXVEOL];
                    251:                } else {
                    252:                        tios.c_cc[VMIN] = tiop->c_cc[HPUXVMIN];
                    253:                        tios.c_cc[VTIME] = tiop->c_cc[HPUXVTIME];
                    254:                }
                    255:                /*
                    256:                 * Set the new stuff
                    257:                 */
                    258:                if (com == HPUXTCSETA)
                    259:                        com = TIOCSETA;
                    260:                else if (com == HPUXTCSETAW)
                    261:                        com = TIOCSETAW;
                    262:                else
                    263:                        com = TIOCSETAF;
                    264:                error = (*ioctlrout)(fp, com, (caddr_t)&tios);
                    265:                if (error == 0) {
                    266:                        /*
                    267:                         * Set line discipline
                    268:                         */
                    269:                        line = tiop->c_line;
                    270:                        (void) (*ioctlrout)(fp, TIOCSETD, (caddr_t)&line);
                    271:                        /*
                    272:                         * Set non-blocking IO if VMIN == VTIME == 0.
                    273:                         * Should handle the other cases as well.  It also
                    274:                         * isn't correct to just turn it off as it could be
                    275:                         * on as the result of a fcntl operation.
                    276:                         * XXX - wouldn't need to do this at all if VMIN/VTIME
                    277:                         * were implemented.
                    278:                         */
                    279:                        line = (tiop->c_cc[HPUXVMIN] == 0 &&
                    280:                                tiop->c_cc[HPUXVTIME] == 0);
                    281:                        (void) fset(fp, FNDELAY, line);
                    282:                }
                    283:                break;
                    284: 
                    285:        default:
                    286:                error = EINVAL;
                    287:                break;
                    288:        }
                    289:        return(error);
                    290: }
                    291: 
                    292: bsdtohpuxbaud(bsdspeed)
                    293:        long bsdspeed;
                    294: {
                    295:        switch (bsdspeed) {
                    296:        case B0:     return(TIO_B0);
                    297:        case B50:    return(TIO_B50);
                    298:        case B75:    return(TIO_B75);
                    299:        case B110:   return(TIO_B110);
                    300:        case B134:   return(TIO_B134);
                    301:        case B150:   return(TIO_B150);
                    302:        case B200:   return(TIO_B200);
                    303:        case B300:   return(TIO_B300);
                    304:        case B600:   return(TIO_B600);
                    305:        case B1200:  return(TIO_B1200);
                    306:        case B1800:  return(TIO_B1800);
                    307:        case B2400:  return(TIO_B2400);
                    308:        case B4800:  return(TIO_B4800);
                    309:        case B9600:  return(TIO_B9600);
                    310:        case B19200: return(TIO_B19200);
                    311:        case B38400: return(TIO_B38400);
                    312:        default:     return(TIO_B0);
                    313:        }
                    314: }
                    315: 
                    316: hpuxtobsdbaud(hpuxspeed)
                    317:        int hpuxspeed;
                    318: {
                    319:        static char hpuxtobsdbaudtab[32] = {
                    320:                B0,     B50,    B75,    B110,   B134,   B150,   B200,   B300,
                    321:                B600,   B0,     B1200,  B1800,  B2400,  B0,     B4800,  B0,
                    322:                B9600,  B19200, B38400, B0,     B0,     B0,     B0,     B0,
                    323:                B0,     B0,     B0,     B0,     B0,     B0,     EXTA,   EXTB
                    324:        };
                    325: 
                    326:        return(hpuxtobsdbaudtab[hpuxspeed & TIO_CBAUD]);
                    327: }
                    328: 
                    329: /* #ifdef COMPAT */
                    330: ohpuxgtty(p, uap, retval)
                    331:        struct proc *p;
                    332:        struct args {
                    333:                int     fdes;
                    334:                caddr_t cmarg;
                    335:        } *uap;
                    336:        int *retval;
                    337: {
                    338: 
                    339:        return (getsettty(uap->fdes, HPUXTIOCGETP, uap->cmarg));
                    340: }
                    341: 
                    342: ohpuxstty(p, uap, retval)
                    343:        struct proc *p;
                    344:        struct args {
                    345:                int     fdes;
                    346:                caddr_t cmarg;
                    347:        } *uap;
                    348:        int *retval;
                    349: {
                    350: 
                    351:        return (getsettty(uap->fdes, HPUXTIOCSETP, uap->cmarg));
                    352: }
                    353: 
                    354: /*
                    355:  * Simplified version of ioctl() for use by
                    356:  * gtty/stty and TIOCGETP/TIOCSETP.
                    357:  */
                    358: getsettty(fdes, com, cmarg)
                    359:        int fdes, com;
                    360:        caddr_t cmarg;
                    361: {
                    362:        register struct file *fp;
                    363:        struct hpuxsgttyb hsb;
                    364:        struct sgttyb sb;
                    365:        int error;
                    366: 
                    367:        if ((unsigned)fdes >= NOFILE || (fp = u.u_ofile[fdes]) == NULL)
                    368:                return (EBADF);
                    369:        if ((fp->f_flag & (FREAD|FWRITE)) == 0)
                    370:                return (EBADF);
                    371:        if (com == HPUXTIOCSETP) {
                    372:                if (error = copyin(cmarg, (caddr_t)&hsb, sizeof hsb))
                    373:                        return (error);
                    374:                sb.sg_ispeed = hsb.sg_ispeed;
                    375:                sb.sg_ospeed = hsb.sg_ospeed;
                    376:                sb.sg_erase = hsb.sg_erase;
                    377:                sb.sg_kill = hsb.sg_kill;
                    378:                sb.sg_flags = hsb.sg_flags & ~(V7_HUPCL|V7_XTABS|V7_NOAL);
                    379:                if (hsb.sg_flags & V7_XTABS)
                    380:                        sb.sg_flags |= XTABS;
                    381:                if (hsb.sg_flags & V7_HUPCL)
                    382:                        (void)(*fp->f_ops->fo_ioctl)(fp, TIOCHPCL, (caddr_t)0);
                    383:                com = TIOCSETP;
                    384:        } else {
                    385:                bzero((caddr_t)&hsb, sizeof hsb);
                    386:                com = TIOCGETP;
                    387:        }
                    388:        error = (*fp->f_ops->fo_ioctl)(fp, com, (caddr_t)&sb);
                    389:        if (error == 0 && com == TIOCGETP) {
                    390:                hsb.sg_ispeed = sb.sg_ispeed;
                    391:                hsb.sg_ospeed = sb.sg_ospeed;
                    392:                hsb.sg_erase = sb.sg_erase;
                    393:                hsb.sg_kill = sb.sg_kill;
                    394:                hsb.sg_flags = sb.sg_flags & ~(V7_HUPCL|V7_XTABS|V7_NOAL);
                    395:                if (sb.sg_flags & XTABS)
                    396:                        hsb.sg_flags |= V7_XTABS;
                    397:                error = copyout((caddr_t)&hsb, cmarg, sizeof hsb);
                    398:        }
                    399:        return (error);
                    400: }
                    401: /* #endif */
                    402: #endif

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.