diff options
author | julian <julian@FreeBSD.org> | 1995-12-08 11:19:42 +0000 |
---|---|---|
committer | julian <julian@FreeBSD.org> | 1995-12-08 11:19:42 +0000 |
commit | 1900eea896e2aaeae8a9fa8affa5fded2068c9b4 (patch) | |
tree | 5150d199464d64c1021f91b2c2f112d48546a8bf /sys/kern/tty_cons.c | |
parent | aaf9d7f10ecc63adae1dc4f55cfd31a2926c605a (diff) | |
download | FreeBSD-src-1900eea896e2aaeae8a9fa8affa5fded2068c9b4.zip FreeBSD-src-1900eea896e2aaeae8a9fa8affa5fded2068c9b4.tar.gz |
Pass 3 of the great devsw changes
most devsw referenced functions are now static, as they are
in the same file as their devsw structure. I've also added DEVFS
support for nearly every device in the system, however
many of the devices have 'incorrect' names under DEVFS
because I couldn't quickly work out the correct naming conventions.
(but devfs won't be coming on line for a month or so anyhow so that doesn't
matter)
If you "OWN" a device which would normally have an entry in /dev
then search for the devfs_add_devsw() entries and munge to make them right..
check out similar devices to see what I might have done in them in you
can't see what's going on..
for a laugh compare conf.c conf.h defore and after... :)
I have not doen DEVFS entries for any DISKSLICE devices yet as that will be
a much more complicated job.. (pass 5 :)
pass 4 will be to make the devsw tables of type (cdevsw * )
rather than (cdevsw)
seems to work here..
complaints to the usual places.. :)
Diffstat (limited to 'sys/kern/tty_cons.c')
-rw-r--r-- | sys/kern/tty_cons.c | 65 |
1 files changed, 38 insertions, 27 deletions
diff --git a/sys/kern/tty_cons.c b/sys/kern/tty_cons.c index 7f2e4d7..4624a28 100644 --- a/sys/kern/tty_cons.c +++ b/sys/kern/tty_cons.c @@ -36,26 +36,22 @@ * SUCH DAMAGE. * * from: @(#)cons.c 7.2 (Berkeley) 5/9/91 - * $Id: cons.c,v 1.35 1995/11/29 10:47:17 julian Exp $ + * $Id: cons.c,v 1.36 1995/11/29 14:39:24 julian Exp $ */ #include <sys/param.h> +#ifdef DEVFS +#include <sys/devfsext.h> +#endif /*DEVFS*/ #include <sys/systm.h> #include <sys/conf.h> +#include <sys/kernel.h> #include <sys/proc.h> #include <sys/tty.h> #include <machine/cons.h> #include <machine/stdarg.h> -#ifdef JREMOD -#include <sys/kernel.h> -#ifdef DEVFS -#include <sys/devfsext.h> -#endif /*DEVFS*/ -#define CDEV_MAJOR 0 -#endif /*JREMOD*/ - /* XXX this should be config(8)ed. */ #include "sc.h" #include "vt.h" @@ -73,6 +69,19 @@ static struct consdev constab[] = { { 0 }, }; +static d_open_t cnopen; +static d_close_t cnclose; +static d_read_t cnread; +static d_write_t cnwrite; +static d_ioctl_t cnioctl; +static d_select_t cnselect; + +#define CDEV_MAJOR 0 +struct cdevsw cn_cdevsw = + { cnopen, cnclose, cnread, cnwrite, /*0*/ + cnioctl, nullstop, nullreset, nodevtotty,/* console */ + cnselect, nommap, NULL, "console", NULL, -1 }; + struct tty *constty = 0; /* virtual console output device */ struct tty *cn_tty; /* XXX: console tty struct for tprintf */ int cons_unavail = 0; /* XXX: @@ -86,6 +95,9 @@ static d_close_t *cn_phys_close; /* physical device close function */ static d_open_t *cn_phys_open; /* physical device open function */ static struct consdev *cn_tab; /* physical console device info */ static struct tty *cn_tp; /* physical console tty struct */ +#ifdef DEVFS +void *cn_devfs_token; /* represents the devfs entry */ +#endif /* DEVFS */ void cninit() @@ -148,7 +160,7 @@ cninit_finish() cn_tty = cn_tp; } -int +static int cnopen(dev, flag, mode, p) dev_t dev; int flag, mode; @@ -171,7 +183,7 @@ cnopen(dev, flag, mode, p) return (retval); } -int +static int cnclose(dev, flag, mode, p) dev_t dev; int flag, mode; @@ -204,7 +216,7 @@ cnclose(dev, flag, mode, p) return ((*cn_phys_close)(dev, flag, mode, p)); } -int +static int cnread(dev, uio, flag) dev_t dev; struct uio *uio; @@ -216,7 +228,7 @@ cnread(dev, uio, flag) return ((*cdevsw[major(dev)].d_read)(dev, uio, flag)); } -int +static int cnwrite(dev, uio, flag) dev_t dev; struct uio *uio; @@ -231,7 +243,7 @@ cnwrite(dev, uio, flag) return ((*cdevsw[major(dev)].d_write)(dev, uio, flag)); } -int +static int cnioctl(dev, cmd, data, flag, p) dev_t dev; int cmd; @@ -258,7 +270,7 @@ cnioctl(dev, cmd, data, flag, p) return ((*cdevsw[major(dev)].d_ioctl)(dev, cmd, data, flag, p)); } -int +static int cnselect(dev, rw, p) dev_t dev; int rw; @@ -312,18 +324,11 @@ pg(const char *p, ...) { return(cngetc()); } - -#ifdef JREMOD -struct cdevsw cn_cdevsw = - { cnopen, cnclose, cnread, cnwrite, /*0*/ - cnioctl, nullstop, nullreset, nodevtotty,/* console */ - cnselect, nommap, NULL }; - static cn_devsw_installed = 0; -static void cn_drvinit(void *unused) +static void +cn_drvinit(void *unused) { - void * x; dev_t dev; if( ! cn_devsw_installed ) { @@ -331,13 +336,19 @@ static void cn_drvinit(void *unused) cdevsw_add(&dev,&cn_cdevsw,NULL); cn_devsw_installed = 1; #ifdef DEVFS - /* path,name,major,minor,type,uid,gid,perm */ - x=devfs_add_devsw("/","console",major(dev),0,DV_CHR,0,0,0640); + cn_devfs_token = devfs_add_devsw( + "/", + "console", + &cn_cdevsw, + 0, + DV_CHR, + 0, + 0, + 0640); #endif } } SYSINIT(cndev,SI_SUB_DRIVERS,SI_ORDER_MIDDLE+CDEV_MAJOR,cn_drvinit,NULL) -#endif /* JREMOD */ |