* Copyright (c) 1988 University of Utah.
* Copyright (c) 1991 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%
* @(#)cons.c 7.2 (Berkeley) %G%
/* XXX - all this could be autoconfig()ed */
int pccnprobe(), pccninit(), pccngetc(), pccnputc();
int comcnprobe(), comcninit(), comcngetc(), comcnputc();
struct consdev constab
[] = {
{ pccnprobe
, pccninit
, pccngetc
, pccnputc
},
{ comcnprobe
, comcninit
, comcngetc
, comcnputc
},
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
)
cnopen(dev
, flag
, mode
, p
)
return ((*cdevsw
[major(dev
)].d_open
)(dev
, flag
, mode
, p
));
cnclose(dev
, flag
, mode
, p
)
return ((*cdevsw
[major(dev
)].d_close
)(dev
, flag
, mode
, p
));
return ((*cdevsw
[major(dev
)].d_read
)(dev
, uio
, flag
));
return ((*cdevsw
[major(dev
)].d_write
)(dev
, uio
, flag
));
cnioctl(dev
, cmd
, data
, flag
, p
)
* Superuser can always use this to wrest control of console
* output from the "virtual" console.
if (cmd
== TIOCCONS
&& constty
) {
error
= suser(p
->p_ucred
, (u_short
*) NULL
);
return ((*cdevsw
[major(dev
)].d_ioctl
)(dev
, cmd
, data
, flag
, p
));
return (ttselect(cn_tab
->cn_dev
, rw
, p
));
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');