summaryrefslogtreecommitdiffstats
path: root/sys/i386/bios
diff options
context:
space:
mode:
authorjulian <julian@FreeBSD.org>1995-11-29 10:49:16 +0000
committerjulian <julian@FreeBSD.org>1995-11-29 10:49:16 +0000
commitf2f63c6ece7d25485976323df6d684743fe14bb6 (patch)
tree5ed2d747156a38098db0e540f833114bc9dd1b51 /sys/i386/bios
parentbe48321f04abe146ffbc5091fe940b107f46c175 (diff)
downloadFreeBSD-src-f2f63c6ece7d25485976323df6d684743fe14bb6.zip
FreeBSD-src-f2f63c6ece7d25485976323df6d684743fe14bb6.tar.gz
OK, that's it..
That's EVERY SINGLE driver that has an entry in conf.c.. my next trick will be to define cdevsw[] and bdevsw[] as empty arrays and remove all those DAMNED defines as well.. Each of these drivers has a SYSINIT linker set entry that comes in very early.. and asks teh driver to add it's own entry to the two devsw[] tables. some slight reworking of the commits from yesterday (added the SYSINIT stuff and some usually wrong but token DEVFS entries to all these devices. BTW does anyone know where the 'ata' entries in conf.c actually reside? seems we don't actually have a 'ataopen() etc... If you want to add a new device in conf.c please make sure I know so I can keep it up to date too.. as before, this is all dependent on #if defined(JREMOD) (and #ifdef DEVFS in parts)
Diffstat (limited to 'sys/i386/bios')
-rw-r--r--sys/i386/bios/apm.c43
1 files changed, 27 insertions, 16 deletions
diff --git a/sys/i386/bios/apm.c b/sys/i386/bios/apm.c
index 8543a18..2b286b4 100644
--- a/sys/i386/bios/apm.c
+++ b/sys/i386/bios/apm.c
@@ -13,7 +13,7 @@
*
* Sep, 1994 Implemented on FreeBSD 1.1.5.1R (Toshiba AVS001WD)
*
- * $Id: apm.c,v 1.15 1995/11/18 04:37:23 bde Exp $
+ * $Id: apm.c,v 1.16 1995/11/28 09:44:42 julian Exp $
*/
#include "apm.h"
@@ -25,6 +25,10 @@
#include "conf.h"
#ifdef JREMOD
#include <sys/conf.h>
+#include <sys/kernel.h>
+#ifdef DEVFS
+#include <sys/devfsext.h>
+#endif /*DEVFS*/
#endif /*JREMOD*/
#include <sys/kernel.h>
#include <sys/systm.h>
@@ -104,7 +108,6 @@ extern void fix_desc(struct fake_descriptor *, int);
static timeout_t apm_timeout;
#ifdef JREMOD
#define CDEV_MAJOR 39
-static void apm_devsw_install();
#endif /* JREMOD */
#endif /* __FreeBSD__ */
#ifdef MACH_KERNEL
@@ -690,11 +693,6 @@ int
printf("apm%d: 32-bit connection error.\n", unit);
return 0;
}
-#ifdef __FreeBSD__
-#ifdef JREMOD
- apm_devsw_install();
-#endif /*JREMOD*/
-#endif /* __FreeBSD__ */
return -1;
}
@@ -981,6 +979,8 @@ apmioctl(dev_t dev, int cmd, caddr_t addr, int flag, struct proc *p)
}
return error;
}
+
+
#ifdef JREMOD
struct cdevsw apm_cdevsw =
{ apmopen, apmclose, noread, nowrite, /*39*/
@@ -989,20 +989,31 @@ struct cdevsw apm_cdevsw =
static apm_devsw_installed = 0;
-static void apm_devsw_install()
+static void apm_drvinit(void *unused)
{
- dev_t descript;
+ dev_t dev;
+
if( ! apm_devsw_installed ) {
- descript = makedev(CDEV_MAJOR,0)
- cdevsw_add(&descript,&apm_cdevsw,NULL);
-#if defined(BDEV_MAJOR)
- descript = makedev(BDEV_MAJOR,0)
- bdevsw_add(&descript,&apm_bdevsw,NULL);
-#endif /*BDEV_MAJOR*/
+ dev = makedev(CDEV_MAJOR,0);
+ cdevsw_add(&dev,&apm_cdevsw,NULL);
apm_devsw_installed = 1;
- }
+#ifdef DEVFS
+ {
+ int x;
+/* default for a simple device with no probe routine (usually delete this) */
+ x=devfs_add_devsw(
+/* path name devsw minor type uid gid perm*/
+ "/", "apm", major(dev), 0, DV_CHR, 0, 0, 0600);
+ }
+ }
+#endif
}
+
+SYSINIT(apmdev,SI_SUB_DRIVERS,SI_ORDER_MIDDLE+CDEV_MAJOR,apm_drvinit,NULL)
+
#endif /* JREMOD */
+
+
#endif /* __FreeBSD__ */
#ifdef MACH_KERNEL
OpenPOWER on IntegriCloud