* 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
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* from: @(#)cons.c 7.2 (Berkeley) 5/9/91
* $Id: cons.c,v 1.3 1993/10/16 14:14:49 rgrimes Exp $
/* 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
));
if (constty
) /* 16 Aug 92*/
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');
pg(p
,q
,r
,s
,t
,u
,v
,w
,x
,y
,z
) char *p
; {
printf(p
,q
,r
,s
,t
,u
,v
,w
,x
,y
,z
);