* Copyright (c) 1988 University of Utah.
* Copyright (c) 1990 The Regents of the University of California.
* This code is derived from software contributed to Berkeley by
* the Systems Programming Group of the University of Utah Computer
* %sccs.include.redist.c%
* from: Utah $Hdr: cons.c 1.4 88/12/03$
* @(#)cons.c 7.1 (Berkeley) %G%
/* XXX - all this could be autoconfig()ed */
int itecnprobe(), itecninit(), itecngetc(), itecnputc();
int dcacnprobe(), dcacninit(), dcacngetc(), dcacnputc();
struct consdev constab
[] = {
{ itecnprobe
, itecninit
, itecngetc
, itecnputc
},
{ dcacnprobe
, dcacninit
, dcacngetc
, dcacnputc
},
extern struct consdev constab
[];
struct tty
*constty
= 0; /* virtual console output device */
struct consdev
*cn_tab
; /* physical console device info */
struct tty
*cn_tty
; /* XXX: console tty struct for tprintf */
register struct consdev
*cp
;
* Collect information about all possible consoles
* and find the one with highest priority
for (cp
= constab
; cp
->cn_probe
; cp
++) {
if (cp
->cn_pri
> CN_DEAD
&&
(cn_tab
== NULL
|| cp
->cn_pri
> cn_tab
->cn_pri
))
* No console, we can handle it
if ((cp
= cn_tab
) == NULL
)
return ((*cdevsw
[major(dev
)].d_open
)(dev
, flag
));
return ((*cdevsw
[major(dev
)].d_close
)(dev
, flag
));
return ((*cdevsw
[major(dev
)].d_read
)(dev
, uio
));
return ((*cdevsw
[major(dev
)].d_write
)(dev
, uio
));
cnioctl(dev
, cmd
, data
, flag
)
* Superuser can always use this to wrest control of console
* output from the "virtual" console.
if (cmd
== TIOCCONS
&& constty
) {
error
= suser(u
.u_cred
, &u
.u_acflag
);
return ((*cdevsw
[major(dev
)].d_ioctl
)(dev
, cmd
, data
, flag
));
return(ttselect(cn_tab
->cn_dev
, rw
));
return((*cn_tab
->cn_getc
)(cn_tab
->cn_dev
));
(*cn_tab
->cn_putc
)(cn_tab
->cn_dev
, c
);
(*cn_tab
->cn_putc
)(cn_tab
->cn_dev
, '\r');