tty.h revision 7c478bd95313f5f23a4c958a745db2134aa03244
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 1998 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/*
* University Copyright- Copyright (c) 1982, 1986, 1988
* The Regents of the University of California
* All Rights Reserved
*
* University Acknowledgment- Portions of this document are derived from
* software developed by the University of California, Berkeley, and its
* contributors.
*/
#ifndef _SYS_TTY_H
#define _SYS_TTY_H
#pragma ident "%Z%%M% %I% %E% SMI"
#include <sys/ttychars.h>
#ifdef __cplusplus
extern "C" {
#endif
/*
* A clist structure is the head of a linked list queue of characters.
* The routines getc* and putc* manipulate these structures.
*/
struct clist {
int c_cc; /* character count */
};
/* Macro to find clist structure given pointer into it */
/* Character control block for interrupt level control */
struct ccblock {
};
/*
* A tty structure is needed for each UNIX character device that
* is used for normal terminal IO.
*/
#define NCC 8
struct tty {
int (* t_proc)(); /* routine for device functions */
short t_state; /* internal state */
char t_line; /* line discipline */
char t_delct; /* delimiter count */
char t_term; /* terminal type */
char t_tmflag; /* terminal flags */
char t_col; /* current column */
char t_row; /* current row */
char t_vrow; /* variable row */
char t_lrow; /* last physical row */
char t_hqcnt; /* no. high queue packets on t_outq */
char t_dstat;
/* used by terminal handlers and line disciplines */
};
/*
* The structure of a clist block
*/
#define CLSIZE 64
struct cblock {
char c_first;
char c_last;
};
extern int cfreecnt;
struct chead {
int c_size;
int c_flag;
};
struct inter {
int cnt;
};
#define TTIPRI 28
#define TTOPRI 29
#ifdef u3b15
/*
* following defs allow for job control in both vpm and
* stand-alone tty environments
*/
#define VPMTTY 1
#define SATTY 2
#endif
/* limits */
#define TTYHOG 256
#define TTXOLO 132
#define TTXOHI 180
/* Hardware bits */
#define DONE 0200
#define IENABLE 0100
#define OVERRUN 040000
#define FRERROR 020000
#define PERROR 010000
/* Internal state */
#define TBLOCK 010
#define TACT 02000
#define TTIOW 020000
#define TTXON 040000
#define TTXOFF 0100000
/* l_output status */
#define CPRES 0100000
/* device commands */
#define T_OUTPUT 0
#define T_TIME 1
#define T_SUSPEND 2
#define T_RESUME 3
#define T_BLOCK 4
#define T_UNBLOCK 5
#define T_RFLUSH 6
#define T_WFLUSH 7
#define T_BREAK 8
#define T_INPUT 9
#define T_DISCONNECT 10
#define T_PARM 11
#define T_SWTCH 12
/*
* Terminal flags (set in t_tmflgs).
*/
/* Usually used to indicate that an esc */
/* character has arrived and that the */
/* next character is special. */
/* This bit is the same as the TM_SET */
/* bit which may never be set by a user */
/*
* device reports
*/
#define L_BUF 0
#define L_BREAK 3
#ifdef __cplusplus
}
#endif
#endif /* _SYS_TTY_H */