[BACK]Return to hpux_tty.c CVS log [TXT][DIR] Up to [local] / sys / compat / hpux

Annotation of sys/compat/hpux/hpux_tty.c, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: hpux_tty.c,v 1.12 2004/09/19 21:58:41 mickey Exp $    */
                      2: /*     $NetBSD: hpux_tty.c,v 1.14 1997/04/01 19:59:05 scottr Exp $     */
                      3:
                      4: /*
                      5:  * Copyright (c) 1988 University of Utah.
                      6:  * Copyright (c) 1990, 1993
                      7:  *     The Regents of the University of California.  All rights reserved.
                      8:  *
                      9:  * This code is derived from software contributed to Berkeley by
                     10:  * the Systems Programming Group of the University of Utah Computer
                     11:  * Science Department.
                     12:  *
                     13:  * Redistribution and use in source and binary forms, with or without
                     14:  * modification, are permitted provided that the following conditions
                     15:  * are met:
                     16:  * 1. Redistributions of source code must retain the above copyright
                     17:  *    notice, this list of conditions and the following disclaimer.
                     18:  * 2. Redistributions in binary form must reproduce the above copyright
                     19:  *    notice, this list of conditions and the following disclaimer in the
                     20:  *    documentation and/or other materials provided with the distribution.
                     21:  * 3. Neither the name of the University nor the names of its contributors
                     22:  *    may be used to endorse or promote products derived from this software
                     23:  *    without specific prior written permission.
                     24:  *
                     25:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
                     26:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     27:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     28:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
                     29:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     30:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     31:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     32:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     33:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     34:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     35:  * SUCH DAMAGE.
                     36:  *
                     37:  * from: Utah $Hdr: hpux_tty.c 1.14 93/08/05$
                     38:  *
                     39:  *     @(#)hpux_tty.c  8.3 (Berkeley) 1/12/94
                     40:  */
                     41:
                     42: /*
                     43:  * stty/gtty/termio emulation stuff
                     44:  */
                     45:
                     46: #ifndef COMPAT_43
                     47: #define COMPAT_43
                     48: #endif
                     49:
                     50: #include <sys/param.h>
                     51: #include <sys/systm.h>
                     52: #include <sys/filedesc.h>
                     53: #include <sys/ioctl.h>
                     54: #include <sys/proc.h>
                     55: #include <sys/tty.h>
                     56: #include <sys/file.h>
                     57: #include <sys/conf.h>
                     58: #include <sys/buf.h>
                     59: #include <sys/kernel.h>
                     60:
                     61: #include <compat/hpux/hpux.h>
                     62: #include <compat/hpux/hpux_termio.h>
                     63: #include <compat/hpux/hpux_syscallargs.h>
                     64:
                     65: /*
                     66:  * Map BSD/POSIX style termios info to and from SYS5 style termio stuff.
                     67:  */
                     68: int
                     69: hpux_termio(fd, com, data, p)
                     70:        int fd, com;
                     71:        caddr_t data;
                     72:        struct proc *p;
                     73: {
                     74:        struct file *fp;
                     75:        struct termios tios;
                     76:        struct hpux_termios htios;
                     77:        int line, error;
                     78:        int newi = 0;
                     79:        int (*ioctlrout)(struct file *fp, u_long com,
                     80:            caddr_t data, struct proc *p);
                     81:
                     82:        if ((fp = fd_getfile(p->p_fd, fd)) == NULL)
                     83:                return (EBADF);
                     84:        FREF(fp);
                     85:        ioctlrout = fp->f_ops->fo_ioctl;
                     86:        switch (com) {
                     87:        case HPUXTCGETATTR:
                     88:                newi = 1;
                     89:                /* fall into ... */
                     90:        case HPUXTCGETA:
                     91:                /*
                     92:                 * Get BSD terminal state
                     93:                 */
                     94:                if ((error = (*ioctlrout)(fp, TIOCGETA, (caddr_t)&tios, p)))
                     95:                        break;
                     96:                bzero((char *)&htios, sizeof htios);
                     97:                /*
                     98:                 * Set iflag.
                     99:                 * Same through ICRNL, no BSD equivs for IUCLC, IENQAK
                    100:                 */
                    101:                htios.c_iflag = tios.c_iflag & 0x1ff;
                    102:                if (tios.c_iflag & IXON)
                    103:                        htios.c_iflag |= TIO_IXON;
                    104:                if (tios.c_iflag & IXOFF)
                    105:                        htios.c_iflag |= TIO_IXOFF;
                    106:                if (tios.c_iflag & IXANY)
                    107:                        htios.c_iflag |= TIO_IXANY;
                    108:                /*
                    109:                 * Set oflag.
                    110:                 * No BSD equivs for OLCUC/OCRNL/ONOCR/ONLRET/OFILL/OFDEL
                    111:                 * or any of the delays.
                    112:                 */
                    113:                if (tios.c_oflag & OPOST)
                    114:                        htios.c_oflag |= TIO_OPOST;
                    115:                if (tios.c_oflag & ONLCR)
                    116:                        htios.c_oflag |= TIO_ONLCR;
                    117:                if (tios.c_oflag & OXTABS)
                    118:                        htios.c_oflag |= TIO_TAB3;
                    119:                /*
                    120:                 * Set cflag.
                    121:                 * Baud from ospeed, rest from cflag.
                    122:                 */
                    123:                htios.c_cflag = bsdtohpuxbaud(tios.c_ospeed);
                    124:                switch (tios.c_cflag & CSIZE) {
                    125:                case CS5:
                    126:                        htios.c_cflag |= TIO_CS5; break;
                    127:                case CS6:
                    128:                        htios.c_cflag |= TIO_CS6; break;
                    129:                case CS7:
                    130:                        htios.c_cflag |= TIO_CS7; break;
                    131:                case CS8:
                    132:                        htios.c_cflag |= TIO_CS8; break;
                    133:                }
                    134:                if (tios.c_cflag & CSTOPB)
                    135:                        htios.c_cflag |= TIO_CSTOPB;
                    136:                if (tios.c_cflag & CREAD)
                    137:                        htios.c_cflag |= TIO_CREAD;
                    138:                if (tios.c_cflag & PARENB)
                    139:                        htios.c_cflag |= TIO_PARENB;
                    140:                if (tios.c_cflag & PARODD)
                    141:                        htios.c_cflag |= TIO_PARODD;
                    142:                if (tios.c_cflag & HUPCL)
                    143:                        htios.c_cflag |= TIO_HUPCL;
                    144:                if (tios.c_cflag & CLOCAL)
                    145:                        htios.c_cflag |= TIO_CLOCAL;
                    146:                /*
                    147:                 * Set lflag.
                    148:                 * No BSD equiv for XCASE.
                    149:                 */
                    150:                if (tios.c_lflag & ECHOE)
                    151:                        htios.c_lflag |= TIO_ECHOE;
                    152:                if (tios.c_lflag & ECHOK)
                    153:                        htios.c_lflag |= TIO_ECHOK;
                    154:                if (tios.c_lflag & ECHO)
                    155:                        htios.c_lflag |= TIO_ECHO;
                    156:                if (tios.c_lflag & ECHONL)
                    157:                        htios.c_lflag |= TIO_ECHONL;
                    158:                if (tios.c_lflag & ISIG)
                    159:                        htios.c_lflag |= TIO_ISIG;
                    160:                if (tios.c_lflag & ICANON)
                    161:                        htios.c_lflag |= TIO_ICANON;
                    162:                if (tios.c_lflag & NOFLSH)
                    163:                        htios.c_lflag |= TIO_NOFLSH;
                    164:                /*
                    165:                 * Line discipline
                    166:                 */
                    167:                if (!newi) {
                    168:                        line = 0;
                    169:                        (void) (*ioctlrout)(fp, TIOCGETD, (caddr_t)&line, p);
                    170:                        htios.c_reserved = line;
                    171:                }
                    172:                /*
                    173:                 * Set editing chars.
                    174:                 * No BSD equiv for VSWTCH.
                    175:                 */
                    176:                htios.c_cc[HPUXVINTR] = tios.c_cc[VINTR];
                    177:                htios.c_cc[HPUXVQUIT] = tios.c_cc[VQUIT];
                    178:                htios.c_cc[HPUXVERASE] = tios.c_cc[VERASE];
                    179:                htios.c_cc[HPUXVKILL] = tios.c_cc[VKILL];
                    180:                htios.c_cc[HPUXVEOF] = tios.c_cc[VEOF];
                    181:                htios.c_cc[HPUXVEOL] = tios.c_cc[VEOL];
                    182:                htios.c_cc[HPUXVEOL2] = tios.c_cc[VEOL2];
                    183:                htios.c_cc[HPUXVSWTCH] = 0;
                    184: #if 1
                    185:                /*
                    186:                 * XXX since VMIN and VTIME are not implemented,
                    187:                 * we need to return something reasonable.
                    188:                 * Otherwise a GETA/SETA combo would always put
                    189:                 * the tty in non-blocking mode (since VMIN == VTIME == 0).
                    190:                 */
                    191:                if (fp->f_flag & FNONBLOCK) {
                    192:                        htios.c_cc[HPUXVMINS] = 0;
                    193:                        htios.c_cc[HPUXVTIMES] = 0;
                    194:                } else {
                    195:                        htios.c_cc[HPUXVMINS] = 6;
                    196:                        htios.c_cc[HPUXVTIMES] = 1;
                    197:                }
                    198: #else
                    199:                htios.c_cc[HPUXVMINS] = tios.c_cc[VMIN];
                    200:                htios.c_cc[HPUXVTIMES] = tios.c_cc[VTIME];
                    201: #endif
                    202:                htios.c_cc[HPUXVSUSP] = tios.c_cc[VSUSP];
                    203:                htios.c_cc[HPUXVSTART] = tios.c_cc[VSTART];
                    204:                htios.c_cc[HPUXVSTOP] = tios.c_cc[VSTOP];
                    205:                if (newi)
                    206:                        bcopy((char *)&htios, data, sizeof htios);
                    207:                else
                    208:                        termiostotermio(&htios, (struct hpux_termio *)data);
                    209:                break;
                    210:
                    211:        case HPUXTCSETATTR:
                    212:        case HPUXTCSETATTRD:
                    213:        case HPUXTCSETATTRF:
                    214:                newi = 1;
                    215:                /* fall into ... */
                    216:        case HPUXTCSETA:
                    217:        case HPUXTCSETAW:
                    218:        case HPUXTCSETAF:
                    219:                /*
                    220:                 * Get old characteristics and determine if we are a tty.
                    221:                 */
                    222:                if ((error = (*ioctlrout)(fp, TIOCGETA, (caddr_t)&tios, p)))
                    223:                        break;
                    224:                if (newi)
                    225:                        bcopy(data, (char *)&htios, sizeof htios);
                    226:                else
                    227:                        termiototermios((struct hpux_termio *)data,
                    228:                            &htios, &tios);
                    229:                /*
                    230:                 * Set iflag.
                    231:                 * Same through ICRNL, no HP-UX equiv for IMAXBEL
                    232:                 */
                    233:                tios.c_iflag &= ~(IXON|IXOFF|IXANY|0x1ff);
                    234:                tios.c_iflag |= htios.c_iflag & 0x1ff;
                    235:                if (htios.c_iflag & TIO_IXON)
                    236:                        tios.c_iflag |= IXON;
                    237:                if (htios.c_iflag & TIO_IXOFF)
                    238:                        tios.c_iflag |= IXOFF;
                    239:                if (htios.c_iflag & TIO_IXANY)
                    240:                        tios.c_iflag |= IXANY;
                    241:                /*
                    242:                 * Set oflag.
                    243:                 * No HP-UX equiv for ONOEOT
                    244:                 */
                    245:                tios.c_oflag &= ~(OPOST|ONLCR|OXTABS);
                    246:                if (htios.c_oflag & TIO_OPOST)
                    247:                        tios.c_oflag |= OPOST;
                    248:                if (htios.c_oflag & TIO_ONLCR)
                    249:                        tios.c_oflag |= ONLCR;
                    250:                if (htios.c_oflag & TIO_TAB3)
                    251:                        tios.c_oflag |= OXTABS;
                    252:                /*
                    253:                 * Set cflag.
                    254:                 * No HP-UX equiv for CCTS_OFLOW/CCTS_IFLOW/MDMBUF
                    255:                 */
                    256:                tios.c_cflag &=
                    257:                        ~(CSIZE|CSTOPB|CREAD|PARENB|PARODD|HUPCL|CLOCAL);
                    258:                switch (htios.c_cflag & TIO_CSIZE) {
                    259:                case TIO_CS5:
                    260:                        tios.c_cflag |= CS5; break;
                    261:                case TIO_CS6:
                    262:                        tios.c_cflag |= CS6; break;
                    263:                case TIO_CS7:
                    264:                        tios.c_cflag |= CS7; break;
                    265:                case TIO_CS8:
                    266:                        tios.c_cflag |= CS8; break;
                    267:                }
                    268:                if (htios.c_cflag & TIO_CSTOPB)
                    269:                        tios.c_cflag |= CSTOPB;
                    270:                if (htios.c_cflag & TIO_CREAD)
                    271:                        tios.c_cflag |= CREAD;
                    272:                if (htios.c_cflag & TIO_PARENB)
                    273:                        tios.c_cflag |= PARENB;
                    274:                if (htios.c_cflag & TIO_PARODD)
                    275:                        tios.c_cflag |= PARODD;
                    276:                if (htios.c_cflag & TIO_HUPCL)
                    277:                        tios.c_cflag |= HUPCL;
                    278:                if (htios.c_cflag & TIO_CLOCAL)
                    279:                        tios.c_cflag |= CLOCAL;
                    280:                /*
                    281:                 * Set lflag.
                    282:                 * No HP-UX equiv for ECHOKE/ECHOPRT/ECHOCTL
                    283:                 * IEXTEN treated as part of ICANON
                    284:                 */
                    285:                tios.c_lflag &= ~(ECHOE|ECHOK|ECHO|ISIG|ICANON|IEXTEN|NOFLSH);
                    286:                if (htios.c_lflag & TIO_ECHOE)
                    287:                        tios.c_lflag |= ECHOE;
                    288:                if (htios.c_lflag & TIO_ECHOK)
                    289:                        tios.c_lflag |= ECHOK;
                    290:                if (htios.c_lflag & TIO_ECHO)
                    291:                        tios.c_lflag |= ECHO;
                    292:                if (htios.c_lflag & TIO_ECHONL)
                    293:                        tios.c_lflag |= ECHONL;
                    294:                if (htios.c_lflag & TIO_ISIG)
                    295:                        tios.c_lflag |= ISIG;
                    296:                if (htios.c_lflag & TIO_ICANON)
                    297:                        tios.c_lflag |= (ICANON|IEXTEN);
                    298:                if (htios.c_lflag & TIO_NOFLSH)
                    299:                        tios.c_lflag |= NOFLSH;
                    300:                /*
                    301:                 * Set editing chars.
                    302:                 * No HP-UX equivs of VWERASE/VREPRINT/VDSUSP/VLNEXT
                    303:                 * /VDISCARD/VSTATUS/VERASE2
                    304:                 */
                    305:                tios.c_cc[VINTR] = htios.c_cc[HPUXVINTR];
                    306:                tios.c_cc[VQUIT] = htios.c_cc[HPUXVQUIT];
                    307:                tios.c_cc[VERASE] = htios.c_cc[HPUXVERASE];
                    308:                tios.c_cc[VKILL] = htios.c_cc[HPUXVKILL];
                    309:                tios.c_cc[VEOF] = htios.c_cc[HPUXVEOF];
                    310:                tios.c_cc[VEOL] = htios.c_cc[HPUXVEOL];
                    311:                tios.c_cc[VEOL2] = htios.c_cc[HPUXVEOL2];
                    312:                tios.c_cc[VMIN] = htios.c_cc[HPUXVMINS];
                    313:                tios.c_cc[VTIME] = htios.c_cc[HPUXVTIMES];
                    314:                tios.c_cc[VSUSP] = htios.c_cc[HPUXVSUSP];
                    315:                tios.c_cc[VSTART] = htios.c_cc[HPUXVSTART];
                    316:                tios.c_cc[VSTOP] = htios.c_cc[HPUXVSTOP];
                    317:
                    318:                /*
                    319:                 * Set the new stuff
                    320:                 */
                    321:                if (com == HPUXTCSETA || com == HPUXTCSETATTR)
                    322:                        com = TIOCSETA;
                    323:                else if (com == HPUXTCSETAW || com == HPUXTCSETATTRD)
                    324:                        com = TIOCSETAW;
                    325:                else
                    326:                        com = TIOCSETAF;
                    327:                error = (*ioctlrout)(fp, com, (caddr_t)&tios, p);
                    328:                if (error == 0) {
                    329:                        /*
                    330:                         * Set line discipline
                    331:                         */
                    332:                        if (!newi) {
                    333:                                line = htios.c_reserved;
                    334:                                (void) (*ioctlrout)(fp, TIOCSETD,
                    335:                                                    (caddr_t)&line, p);
                    336:                        }
                    337:                        /*
                    338:                         * Set non-blocking IO if VMIN == VTIME == 0, clear
                    339:                         * if not.  Should handle the other cases as well.
                    340:                         * Note it isn't correct to just turn NBIO off like
                    341:                         * we do as it could be on as the result of a fcntl
                    342:                         * operation.
                    343:                         *
                    344:                         * XXX - wouldn't need to do this at all if VMIN/VTIME
                    345:                         * were implemented.
                    346:                         */
                    347:                        {
                    348:                                struct hpux_sys_fcntl_args {
                    349:                                        int fdes, cmd, arg;
                    350:                                } args;
                    351:                                int flags, nbio;
                    352:
                    353:                                nbio = (htios.c_cc[HPUXVMINS] == 0 &&
                    354:                                        htios.c_cc[HPUXVTIMES] == 0);
                    355:                                if ((nbio && (fp->f_flag & FNONBLOCK) == 0) ||
                    356:                                    (!nbio && (fp->f_flag & FNONBLOCK))) {
                    357:                                        args.fdes = fd;
                    358:                                        args.cmd = F_GETFL;
                    359:                                        args.arg = 0;
                    360:                                        (void) hpux_sys_fcntl(p, &args, &flags);
                    361:                                        if (nbio)
                    362:                                                flags |= HPUXNDELAY;
                    363:                                        else
                    364:                                                flags &= ~HPUXNDELAY;
                    365:                                        args.cmd = F_SETFL;
                    366:                                        args.arg = flags;
                    367:                                        (void) hpux_sys_fcntl(p, &args, &flags);
                    368:                                }
                    369:                        }
                    370:                }
                    371:                break;
                    372:
                    373:        default:
                    374:                error = EINVAL;
                    375:                break;
                    376:        }
                    377:        FRELE(fp);
                    378:        return(error);
                    379: }
                    380:
                    381: void
                    382: termiototermios(tio, tios, bsdtios)
                    383:        struct hpux_termio *tio;
                    384:        struct hpux_termios *tios;
                    385:        struct termios *bsdtios;
                    386: {
                    387:        int i;
                    388:
                    389:        bzero((char *)tios, sizeof *tios);
                    390:        tios->c_iflag = tio->c_iflag;
                    391:        tios->c_oflag = tio->c_oflag;
                    392:        tios->c_cflag = tio->c_cflag;
                    393:        tios->c_lflag = tio->c_lflag;
                    394:        tios->c_reserved = tio->c_line;
                    395:        for (i = 0; i <= HPUXVSWTCH; i++)
                    396:                tios->c_cc[i] = tio->c_cc[i];
                    397:        if (tios->c_lflag & TIO_ICANON) {
                    398:                tios->c_cc[HPUXVEOF] = tio->c_cc[HPUXVEOF];
                    399:                tios->c_cc[HPUXVEOL] = tio->c_cc[HPUXVEOL];
                    400:                tios->c_cc[HPUXVMINS] = 0;
                    401:                tios->c_cc[HPUXVTIMES] = 0;
                    402:        } else {
                    403:                tios->c_cc[HPUXVEOF] = 0;
                    404:                tios->c_cc[HPUXVEOL] = 0;
                    405:                tios->c_cc[HPUXVMINS] = tio->c_cc[HPUXVMIN];
                    406:                tios->c_cc[HPUXVTIMES] = tio->c_cc[HPUXVTIME];
                    407:        }
                    408:        tios->c_cc[HPUXVSUSP] = bsdtios->c_cc[VSUSP];
                    409:        tios->c_cc[HPUXVSTART] = bsdtios->c_cc[VSTART];
                    410:        tios->c_cc[HPUXVSTOP] = bsdtios->c_cc[VSTOP];
                    411: }
                    412:
                    413: void
                    414: termiostotermio(tios, tio)
                    415:        struct hpux_termios *tios;
                    416:        struct hpux_termio *tio;
                    417: {
                    418:        int i;
                    419:
                    420:        tio->c_iflag = tios->c_iflag;
                    421:        tio->c_oflag = tios->c_oflag;
                    422:        tio->c_cflag = tios->c_cflag;
                    423:        tio->c_lflag = tios->c_lflag;
                    424:        tio->c_line = tios->c_reserved;
                    425:        for (i = 0; i <= HPUXVSWTCH; i++)
                    426:                tio->c_cc[i] = tios->c_cc[i];
                    427:        if (tios->c_lflag & TIO_ICANON) {
                    428:                tio->c_cc[HPUXVEOF] = tios->c_cc[HPUXVEOF];
                    429:                tio->c_cc[HPUXVEOL] = tios->c_cc[HPUXVEOL];
                    430:        } else {
                    431:                tio->c_cc[HPUXVMIN] = tios->c_cc[HPUXVMINS];
                    432:                tio->c_cc[HPUXVTIME] = tios->c_cc[HPUXVTIMES];
                    433:        }
                    434: }
                    435:
                    436: int
                    437: bsdtohpuxbaud(bsdspeed)
                    438:        long bsdspeed;
                    439: {
                    440:        switch (bsdspeed) {
                    441:        case B0:     return(TIO_B0);
                    442:        case B50:    return(TIO_B50);
                    443:        case B75:    return(TIO_B75);
                    444:        case B110:   return(TIO_B110);
                    445:        case B134:   return(TIO_B134);
                    446:        case B150:   return(TIO_B150);
                    447:        case B200:   return(TIO_B200);
                    448:        case B300:   return(TIO_B300);
                    449:        case B600:   return(TIO_B600);
                    450:        case B1200:  return(TIO_B1200);
                    451:        case B1800:  return(TIO_B1800);
                    452:        case B2400:  return(TIO_B2400);
                    453:        case B4800:  return(TIO_B4800);
                    454:        case B9600:  return(TIO_B9600);
                    455:        case B19200: return(TIO_B19200);
                    456:        case B38400: return(TIO_B38400);
                    457:        default:     return(TIO_B0);
                    458:        }
                    459: }
                    460:
                    461: int
                    462: hpuxtobsdbaud(hpux_speed)
                    463:        int hpux_speed;
                    464: {
                    465:        static const int hpuxtobsdbaudtab[32] = {
                    466:                B0,     B50,    B75,    B110,   B134,   B150,   B200,   B300,
                    467:                B600,   B0,     B1200,  B1800,  B2400,  B0,     B4800,  B0,
                    468:                B9600,  B19200, B38400, B0,     B0,     B0,     B0,     B0,
                    469:                B0,     B0,     B0,     B0,     B0,     B0,     EXTA,   EXTB
                    470:        };
                    471:
                    472:        return(hpuxtobsdbaudtab[hpux_speed & TIO_CBAUD]);
                    473: }
                    474:
                    475: int
                    476: hpux_sys_stty_6x(p, v, retval)
                    477:        struct proc *p;
                    478:        void *v;
                    479:        register_t *retval;
                    480: {
                    481:        struct hpux_sys_stty_6x_args /* {
                    482:                syscallarg(int) fd;
                    483:                syscallarg(caddr_t) arg;
                    484:        } */ *uap = v;
                    485:
                    486:        return (getsettty(p, SCARG(uap, fd), HPUXTIOCGETP, SCARG(uap, arg)));
                    487: }
                    488:
                    489: int
                    490: hpux_sys_gtty_6x(p, v, retval)
                    491:        struct proc *p;
                    492:        void *v;
                    493:        register_t *retval;
                    494: {
                    495:        struct hpux_sys_gtty_6x_args /* {
                    496:                syscallarg(int) fd;
                    497:                syscallarg(caddr_t) arg;
                    498:        } */ *uap = v;
                    499:
                    500:        return (getsettty(p, SCARG(uap, fd), HPUXTIOCSETP, SCARG(uap, arg)));
                    501: }
                    502:
                    503: /*
                    504:  * Simplified version of ioctl() for use by
                    505:  * gtty/stty and TIOCGETP/TIOCSETP.
                    506:  */
                    507: int
                    508: getsettty(p, fdes, com, cmarg)
                    509:        struct proc *p;
                    510:        int fdes, com;
                    511:        caddr_t cmarg;
                    512: {
                    513:        struct filedesc *fdp = p->p_fd;
                    514:        struct file *fp;
                    515:        struct hpux_sgttyb hsb;
                    516:        struct sgttyb sb;
                    517:        int error;
                    518:
                    519:        if ((fp = fd_getfile(fdp, fdes)) == NULL)
                    520:                return (EBADF);
                    521:        if ((fp->f_flag & (FREAD|FWRITE)) == 0)
                    522:                return (EBADF);
                    523:        FREF(fp);
                    524:        if (com == HPUXTIOCSETP) {
                    525:                if ((error = copyin(cmarg, (caddr_t)&hsb, sizeof hsb)))
                    526:                        goto bad;
                    527:                sb.sg_ispeed = hsb.sg_ispeed;
                    528:                sb.sg_ospeed = hsb.sg_ospeed;
                    529:                sb.sg_erase = hsb.sg_erase;
                    530:                sb.sg_kill = hsb.sg_kill;
                    531:                sb.sg_flags = hsb.sg_flags & ~(V7_HUPCL|V7_XTABS|V7_NOAL);
                    532:                if (hsb.sg_flags & V7_XTABS)
                    533:                        sb.sg_flags |= XTABS;
                    534:                if (hsb.sg_flags & V7_HUPCL)
                    535:                        (void)(*fp->f_ops->fo_ioctl)
                    536:                                (fp, TIOCHPCL, (caddr_t)0, p);
                    537:                com = TIOCSETP;
                    538:        } else {
                    539:                bzero((caddr_t)&hsb, sizeof hsb);
                    540:                com = TIOCGETP;
                    541:        }
                    542:        error = (*fp->f_ops->fo_ioctl)(fp, com, (caddr_t)&sb, p);
                    543:        if (error == 0 && com == TIOCGETP) {
                    544:                hsb.sg_ispeed = sb.sg_ispeed;
                    545:                hsb.sg_ospeed = sb.sg_ospeed;
                    546:                hsb.sg_erase = sb.sg_erase;
                    547:                hsb.sg_kill = sb.sg_kill;
                    548:                hsb.sg_flags = sb.sg_flags & ~(V7_HUPCL|V7_XTABS|V7_NOAL);
                    549:                if (sb.sg_flags & XTABS)
                    550:                        hsb.sg_flags |= V7_XTABS;
                    551:                error = copyout((caddr_t)&hsb, cmarg, sizeof hsb);
                    552:        }
                    553: bad:
                    554:        FRELE(fp);
                    555:        return (error);
                    556: }

CVSweb