1*7c478bd9Sstevel@tonic-gate /* 2*7c478bd9Sstevel@tonic-gate * CDDL HEADER START 3*7c478bd9Sstevel@tonic-gate * 4*7c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*7c478bd9Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only 6*7c478bd9Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance 7*7c478bd9Sstevel@tonic-gate * with the License. 8*7c478bd9Sstevel@tonic-gate * 9*7c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*7c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 11*7c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 12*7c478bd9Sstevel@tonic-gate * and limitations under the License. 13*7c478bd9Sstevel@tonic-gate * 14*7c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 15*7c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*7c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 17*7c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 18*7c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 19*7c478bd9Sstevel@tonic-gate * 20*7c478bd9Sstevel@tonic-gate * CDDL HEADER END 21*7c478bd9Sstevel@tonic-gate */ 22*7c478bd9Sstevel@tonic-gate /* 23*7c478bd9Sstevel@tonic-gate * Copyright 1997 Sun Microsystems, Inc. All rights reserved. 24*7c478bd9Sstevel@tonic-gate * Use is subject to license terms. 25*7c478bd9Sstevel@tonic-gate */ 26*7c478bd9Sstevel@tonic-gate 27*7c478bd9Sstevel@tonic-gate /* Copyright (c) 1988 AT&T */ 28*7c478bd9Sstevel@tonic-gate /* All Rights Reserved */ 29*7c478bd9Sstevel@tonic-gate 30*7c478bd9Sstevel@tonic-gate /* 31*7c478bd9Sstevel@tonic-gate * University Copyright- Copyright (c) 1982, 1986, 1988 32*7c478bd9Sstevel@tonic-gate * The Regents of the University of California 33*7c478bd9Sstevel@tonic-gate * All Rights Reserved 34*7c478bd9Sstevel@tonic-gate * 35*7c478bd9Sstevel@tonic-gate * University Acknowledgment- Portions of this document are derived from 36*7c478bd9Sstevel@tonic-gate * software developed by the University of California, Berkeley, and its 37*7c478bd9Sstevel@tonic-gate * contributors. 38*7c478bd9Sstevel@tonic-gate */ 39*7c478bd9Sstevel@tonic-gate 40*7c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 41*7c478bd9Sstevel@tonic-gate 42*7c478bd9Sstevel@tonic-gate /*LINTLIBRARY*/ 43*7c478bd9Sstevel@tonic-gate 44*7c478bd9Sstevel@tonic-gate #include <unistd.h> 45*7c478bd9Sstevel@tonic-gate #include <sys/types.h> 46*7c478bd9Sstevel@tonic-gate #include "curses_inc.h" 47*7c478bd9Sstevel@tonic-gate 48*7c478bd9Sstevel@tonic-gate /* 49*7c478bd9Sstevel@tonic-gate * Code for various kinds of delays. Most of this is nonportable and 50*7c478bd9Sstevel@tonic-gate * requires various enhancements to the operating system, so it won't 51*7c478bd9Sstevel@tonic-gate * work on all systems. It is included in curses to provide a portable 52*7c478bd9Sstevel@tonic-gate * interface, and so curses itself can use it for function keys. 53*7c478bd9Sstevel@tonic-gate */ 54*7c478bd9Sstevel@tonic-gate 55*7c478bd9Sstevel@tonic-gate #define NAPINTERVAL 100 56*7c478bd9Sstevel@tonic-gate /* 57*7c478bd9Sstevel@tonic-gate * Wait until the output has drained enough that it will only take 58*7c478bd9Sstevel@tonic-gate * ms more milliseconds to drain completely. 59*7c478bd9Sstevel@tonic-gate * Needs Berkeley TIOCOUTQ ioctl. Returns ERR if impossible. 60*7c478bd9Sstevel@tonic-gate */ 61*7c478bd9Sstevel@tonic-gate 62*7c478bd9Sstevel@tonic-gate int 63*7c478bd9Sstevel@tonic-gate draino(int ms) 64*7c478bd9Sstevel@tonic-gate { 65*7c478bd9Sstevel@tonic-gate #ifdef TIOCOUTQ 66*7c478bd9Sstevel@tonic-gate #define _DRAINO 67*7c478bd9Sstevel@tonic-gate /* number of chars = that many ms */ 68*7c478bd9Sstevel@tonic-gate long ncneeded; 69*7c478bd9Sstevel@tonic-gate 70*7c478bd9Sstevel@tonic-gate /* 10 bits/char, 1000 ms/sec, baudrate in bits/sec */ 71*7c478bd9Sstevel@tonic-gate ncneeded = SP->baud * ms / (10 * 1000); 72*7c478bd9Sstevel@tonic-gate /*CONSTCOND*/ 73*7c478bd9Sstevel@tonic-gate while (TRUE) { 74*7c478bd9Sstevel@tonic-gate int rv; /* ioctl return value */ 75*7c478bd9Sstevel@tonic-gate int ncthere = 0; /* number of chars actually in */ 76*7c478bd9Sstevel@tonic-gate /* output queue */ 77*7c478bd9Sstevel@tonic-gate 78*7c478bd9Sstevel@tonic-gate rv = ioctl(cur_term->Filedes, TIOCOUTQ, &ncthere); 79*7c478bd9Sstevel@tonic-gate #ifdef DEBUG 80*7c478bd9Sstevel@tonic-gate if (outf) 81*7c478bd9Sstevel@tonic-gate fprintf(outf, "draino: rv %d, ncneeded %d, " 82*7c478bd9Sstevel@tonic-gate "ncthere %d\n", rv, ncneeded, ncthere); 83*7c478bd9Sstevel@tonic-gate #endif /* DEBUG */ 84*7c478bd9Sstevel@tonic-gate if (rv < 0) 85*7c478bd9Sstevel@tonic-gate return (ERR); /* ioctl didn't work */ 86*7c478bd9Sstevel@tonic-gate if (ncthere <= ncneeded) 87*7c478bd9Sstevel@tonic-gate return (OK); 88*7c478bd9Sstevel@tonic-gate (void) napms(NAPINTERVAL); 89*7c478bd9Sstevel@tonic-gate } 90*7c478bd9Sstevel@tonic-gate #else /* TIOCOUTQ */ 91*7c478bd9Sstevel@tonic-gate 92*7c478bd9Sstevel@tonic-gate #ifdef TCSETAW 93*7c478bd9Sstevel@tonic-gate #define _DRAINO 94*7c478bd9Sstevel@tonic-gate /* 95*7c478bd9Sstevel@tonic-gate * SYSV simulation - waits until the entire queue is empty, 96*7c478bd9Sstevel@tonic-gate * then sets the state to what it already is (e.g. no-op). 97*7c478bd9Sstevel@tonic-gate * Unfortunately this only works if ms is zero. 98*7c478bd9Sstevel@tonic-gate */ 99*7c478bd9Sstevel@tonic-gate if (ms <= 0) { 100*7c478bd9Sstevel@tonic-gate #ifdef SYSV 101*7c478bd9Sstevel@tonic-gate if (prog_istermios < 0) { 102*7c478bd9Sstevel@tonic-gate int i; 103*7c478bd9Sstevel@tonic-gate 104*7c478bd9Sstevel@tonic-gate PROGTTY.c_lflag = PROGTTYS.c_lflag; 105*7c478bd9Sstevel@tonic-gate PROGTTY.c_oflag = PROGTTYS.c_oflag; 106*7c478bd9Sstevel@tonic-gate PROGTTY.c_iflag = PROGTTYS.c_iflag; 107*7c478bd9Sstevel@tonic-gate PROGTTY.c_cflag = PROGTTYS.c_cflag; 108*7c478bd9Sstevel@tonic-gate for (i = 0; i < NCC; i++) 109*7c478bd9Sstevel@tonic-gate PROGTTY.c_cc[i] = PROGTTYS.c_cc[i]; 110*7c478bd9Sstevel@tonic-gate (void) ioctl(cur_term->Filedes, TCSETAW, &PROGTTY); 111*7c478bd9Sstevel@tonic-gate } else 112*7c478bd9Sstevel@tonic-gate (void) ioctl(cur_term->Filedes, TCSETSW, &PROGTTYS); 113*7c478bd9Sstevel@tonic-gate #else /* SYSV */ 114*7c478bd9Sstevel@tonic-gate (void) ioctl(cur_term->Filedes, TCSETAW, &PROGTTY); 115*7c478bd9Sstevel@tonic-gate #endif /* SYSV */ 116*7c478bd9Sstevel@tonic-gate return (OK); 117*7c478bd9Sstevel@tonic-gate } else 118*7c478bd9Sstevel@tonic-gate return (ERR); 119*7c478bd9Sstevel@tonic-gate #endif /* TCSETAW */ 120*7c478bd9Sstevel@tonic-gate #endif /* TIOCOUTQ */ 121*7c478bd9Sstevel@tonic-gate 122*7c478bd9Sstevel@tonic-gate #ifndef _DRAINO 123*7c478bd9Sstevel@tonic-gate /* 124*7c478bd9Sstevel@tonic-gate * No way to fake it, so we return failure. 125*7c478bd9Sstevel@tonic-gate * Used #else to avoid warning from compiler about unreached stmt 126*7c478bd9Sstevel@tonic-gate */ 127*7c478bd9Sstevel@tonic-gate return (ERR); 128*7c478bd9Sstevel@tonic-gate #endif /* _DRAINO */ 129*7c478bd9Sstevel@tonic-gate /*NOTREACHED*/ 130*7c478bd9Sstevel@tonic-gate } 131