/* * Copyright (c) 1988 University of Utah. * Copyright (c) 1992 The Regents of the University of California. * All rights reserved. * * This code is derived from software contributed to Berkeley by * the Systems Programming Group of the University of Utah Computer * Science Department and Ralph Campbell. * * %sccs.include.redist.c% * * from: Utah $Hdr: cons.c 1.1 90/07/09$ * * @(#)cons.c 7.5 (Berkeley) 11/15/92 */ #include #include #include #include #include #include #include #include #include /* * Console I/O is redirected to the appropriate device, either a screen and * keyboard or a serial port. */ #include struct consdev cn_tab = { 1, 1, NODEV, (struct pmax_fb *)0, (int (*)())0, (int (*)())0, (void (*)())0, (struct tty *)0, }; cnopen(dev, flag, mode, p) dev_t dev; int flag, mode; struct proc *p; { if (cn_tab.cn_dev == NODEV) return (0); dev = cn_tab.cn_dev; return ((*cdevsw[major(dev)].d_open)(dev, flag, mode, p)); } cnclose(dev, flag, mode, p) dev_t dev; int flag, mode; struct proc *p; { if (cn_tab.cn_dev == NODEV) return (0); dev = cn_tab.cn_dev; return ((*cdevsw[major(dev)].d_close)(dev, flag, mode, p)); } cnread(dev, uio, flag) dev_t dev; struct uio *uio; { if (cn_tab.cn_dev == NODEV) return (0); dev = cn_tab.cn_dev; return ((*cdevsw[major(dev)].d_read)(dev, uio, flag)); } cnwrite(dev, uio, flag) dev_t dev; struct uio *uio; { if (cn_tab.cn_dev == NODEV) return (0); dev = cn_tab.cn_dev; return ((*cdevsw[major(dev)].d_write)(dev, uio, flag)); } cnioctl(dev, cmd, data, flag, p) dev_t dev; caddr_t data; struct proc *p; { int error; if (cn_tab.cn_dev == NODEV) return (0); dev = cn_tab.cn_dev; return ((*cdevsw[major(dev)].d_ioctl)(dev, cmd, data, flag, p)); } /*ARGSUSED*/ cnselect(dev, rw, p) dev_t dev; int rw; struct proc *p; { if (cn_tab.cn_dev == NODEV) return (1); return (ttselect(cn_tab.cn_dev, rw, p)); } /* * Get character from console. */ cngetc() { /* check to be sure device has been initialized */ if (cn_tab.cn_dev == NODEV || cn_tab.cn_disabled) return ((*callv->getchar)()); return ((*cn_tab.cn_getc)(cn_tab.cn_dev)); } /* * Print a character on console. */ cnputc(c) register int c; { int s; if (cn_tab.cn_dev == NODEV || cn_tab.cn_disabled) { s = splhigh(); (*callv->printf)("%c", c); splx(s); } else if (c) { if (c == '\n') (*cn_tab.cn_putc)(cn_tab.cn_dev, '\r'); (*cn_tab.cn_putc)(cn_tab.cn_dev, c); } }