summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1999-10-26 18:16:49 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1999-10-26 18:16:49 +0000
commitc8d20d07ed395d9276b87ddb1ab57d931cb582a1 (patch)
tree1aff1a65414789b6ba40ec60f9d43437c82634e8 /sys
parente352ea149e63509c593d024f5363a979a6807fe5 (diff)
modify bootapiver chekups to use bitwise operations.
factor out /boot options parser from biosattach(). add logic to warn about ancient /boots. cleanup vanishing cruft. @niklas ok
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/i386/i386/bios.c100
-rw-r--r--sys/arch/i386/i386/machdep.c7
-rw-r--r--sys/arch/i386/include/biosvar.h6
3 files changed, 69 insertions, 44 deletions
diff --git a/sys/arch/i386/i386/bios.c b/sys/arch/i386/i386/bios.c
index e530b419064..370ec5685c7 100644
--- a/sys/arch/i386/i386/bios.c
+++ b/sys/arch/i386/i386/bios.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bios.c,v 1.24 1999/08/25 00:54:18 mickey Exp $ */
+/* $OpenBSD: bios.c,v 1.25 1999/10/26 18:16:48 mickey Exp $ */
/*
* Copyright (c) 1997-1999 Michael Shalayeff
@@ -81,10 +81,14 @@ struct cfdriver bios_cd = {
extern dev_t bootdev;
+#if NAPM > 0
+bios_apminfo_t *apm;
+#endif
#if NPCI > 0
-bios_pciinfo_t *bios_pciinfo = NULL;
+bios_pciinfo_t *bios_pciinfo;
#endif
-bios_diskinfo_t *bios_diskinfo = NULL;
+bios_diskinfo_t *bios_diskinfo;
+bios_memmap_t *bios_memmap;
u_int32_t bios_cksumlen;
bios_diskinfo_t *bios_getdiskinfo __P((dev_t));
@@ -105,7 +109,7 @@ biosprobe(parent, match, aux)
if (bios_cd.cd_ndevs || strcmp(bia->bios_dev, bios_cd.cd_name))
return 0;
- if (bootapiver < BOOTARG_APIVER || bootargp == NULL )
+ if (!(bootapiver & BAPIV_VECTOR) || bootargp == NULL )
return 0;
return 1;
@@ -116,16 +120,12 @@ biosattach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
- struct bios_softc *sc = (void *) self;
+ /* struct bios_softc *sc = (void *) self; */
#if NAPM > 0
struct bios_attach_args *bia = aux;
#endif
-#if NAPM > 0 || defined(DEBUG)
- bios_apminfo_t *apm = NULL;
-#endif
u_int8_t *va = ISA_HOLE_VADDR(0xffff0);
char *str;
- bootarg_t *q;
switch (va[14]) {
default:
@@ -141,24 +141,65 @@ biosattach(parent, self, aux)
printf(": %s(%02x) BIOS, date %c%c/%c%c/%c%c\n",
str, va[15], va[5], va[6], va[8], va[9], va[11], va[12]);
- printf("%s:", sc->sc_dev.dv_xname);
+#if NAPM > 0
+ if (apm) {
+ struct bios_attach_args ba;
+#if defined(DEBUG) || defined(APMDEBUG)
+ printf("apminfo: %x, code %x[%x]/%x[%x], data %x[%x], ept %x\n",
+ apm->apm_detail,
+ apm->apm_code32_base, apm->apm_code_len,
+ apm->apm_code16_base, apm->apm_code16_len,
+ apm->apm_data_base, apm->apm_data_len, apm->apm_entry);
+#endif
+ ba.bios_dev = "apm";
+ ba.bios_func = 0x15;
+ ba.bios_memt = bia->bios_memt;
+ ba.bios_iot = bia->bios_iot;
+ ba.bios_apmp = apm;
+ config_found(self, &ba, bios_print);
+ }
+#endif
+}
+
+void
+bios_getopt()
+{
+ bootarg_t *q;
+
+ printf("bootargv:");
for(q = bootargp; q->ba_type != BOOTARG_END; q = q->ba_next) {
q->ba_next = (bootarg_t *)((caddr_t)q + q->ba_size);
switch (q->ba_type) {
case BOOTARG_MEMMAP:
- printf(" memmap %p", q->ba_arg);
+ bios_memmap = (bios_memmap_t *)q->ba_arg;
+ if (bootapiver & BAPIV_BMEMMAP)
+ printf(" memmap %p", bios_memmap);
+ else {
+ register bios_memmap_t *p;
+ printf(" omemmap %p", bios_memmap);
+ /*
+ * older /boots passed memmap in Kbytes,
+ * which is very inconvinient from the
+ * point of view of memory management
+ */
+ for (p = bios_memmap;
+ p->type != BIOS_MAP_END; p++) {
+ p->addr /= 1024;
+ p->size *= 1024;
+ }
+ }
break;
case BOOTARG_DISKINFO:
bios_diskinfo = (bios_diskinfo_t *)q->ba_arg;
printf(" diskinfo %p", bios_diskinfo);
break;
+#if NAPM > 0 || defined(DEBUG)
case BOOTARG_APMINFO:
printf(" apminfo %p", q->ba_arg);
-#if NAPM > 0 || defined(DEBUG)
apm = (bios_apminfo_t *)q->ba_arg;
-#endif
break;
+#endif
case BOOTARG_CKSUMLEN:
bios_cksumlen = *(u_int32_t *)q->ba_arg;
printf(" cksumlen %d", bios_cksumlen);
@@ -169,6 +210,10 @@ biosattach(parent, self, aux)
printf(" pciinfo %p", bios_pciinfo);
break;
#endif
+ case BOOTARG_CONSDEV:
+ cnset(*(dev_t *)q->ba_arg);
+ break;
+
default:
printf(" unsupported arg (%d) %p", q->ba_type,
q->ba_arg);
@@ -176,23 +221,6 @@ biosattach(parent, self, aux)
}
printf("\n");
-#if NAPM > 0
- if (apm) {
- struct bios_attach_args ba;
-#if defined(DEBUG) || defined(APMDEBUG)
- printf("apminfo: %x, code %x/%x[%x], data %x[%x], entry %x\n",
- apm->apm_detail, apm->apm_code32_base,
- apm->apm_code16_base, apm->apm_code_len,
- apm->apm_data_base, apm->apm_data_len, apm->apm_entry);
-#endif
- ba.bios_dev = "apm";
- ba.bios_func = 0x15;
- ba.bios_memt = bia->bios_memt;
- ba.bios_iot = bia->bios_iot;
- ba.bios_apmp = apm;
- config_found(self, &ba, bios_print);
- }
-#endif
}
int
@@ -319,7 +347,6 @@ bios_sysctl(name, namelen, oldp, oldlenp, newp, newlen, p)
size_t newlen;
struct proc *p;
{
- extern u_int cnvmem, extmem; /* locore.s */
bios_diskinfo_t *pdi;
int biosdev;
@@ -327,10 +354,11 @@ bios_sysctl(name, namelen, oldp, oldlenp, newp, newlen, p)
if (namelen != 1 && name[0] != BIOS_DISKINFO)
return (ENOTDIR); /* overloaded */
+ if (!(bootapiver & BAPIV_VECTOR))
+ return EOPNOTSUPP;
+
switch (name[0]) {
case BIOS_DEV:
- if (bootapiver < BOOTARG_APIVER)
- return EOPNOTSUPP;
if ((pdi = bios_getdiskinfo(bootdev)) == NULL)
return ENXIO;
biosdev = pdi->bios_number;
@@ -338,15 +366,9 @@ bios_sysctl(name, namelen, oldp, oldlenp, newp, newlen, p)
case BIOS_DISKINFO:
if (namelen != 2)
return ENOTDIR;
- if (bootapiver < BOOTARG_APIVER)
- return EOPNOTSUPP;
if ((pdi = bios_getdiskinfo(name[1])) == NULL)
return ENXIO;
return sysctl_rdstruct(oldp, oldlenp, newp, pdi, sizeof(*pdi));
- case BIOS_CNVMEM:
- return sysctl_rdint(oldp, oldlenp, newp, cnvmem);
- case BIOS_EXTMEM:
- return sysctl_rdint(oldp, oldlenp, newp, extmem);
case BIOS_CKSUMLEN:
return sysctl_rdint(oldp, oldlenp, newp, bios_cksumlen);
default:
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index bf70b0e2b18..d559be47fd1 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.115 1999/10/14 20:09:09 niklas Exp $ */
+/* $OpenBSD: machdep.c,v 1.116 1999/10/26 18:16:48 mickey Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -315,15 +315,16 @@ cpu_startup()
msgbufmapped = 1;
/* Boot arguments are in page 1 */
- if (bootapiver >= 2) {
+ if (bootapiver & BAPIV_VECTOR) {
pa = (vm_offset_t)bootargv;
for (i = 0; i < btoc(bootargc); i++, pa += NBPG)
pmap_enter(pmap_kernel(),
(vm_offset_t)((caddr_t)bootargp + i * NBPG), pa,
VM_PROT_READ|VM_PROT_WRITE, TRUE,
VM_PROT_READ|VM_PROT_WRITE);
+ bios_getopt();
} else
- bootargp = NULL;
+ panic("/boot is too old: upgrade");
printf(version);
startrtclock();
diff --git a/sys/arch/i386/include/biosvar.h b/sys/arch/i386/include/biosvar.h
index 1779fe843f9..3e5ad2aa693 100644
--- a/sys/arch/i386/include/biosvar.h
+++ b/sys/arch/i386/include/biosvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: biosvar.h,v 1.30 1999/08/25 00:54:18 mickey Exp $ */
+/* $OpenBSD: biosvar.h,v 1.31 1999/10/26 18:16:47 mickey Exp $ */
/*
* Copyright (c) 1997-1999 Michael Shalayeff
@@ -190,8 +190,10 @@ void bioscninit __P((struct consdev *));
void bioscnputc __P((dev_t, int));
int bioscngetc __P((dev_t));
void bioscnpollc __P((dev_t, int));
+void bios_getopt __P((void));
-extern u_int bootapiver;
+extern u_int bootapiver;
+extern bios_memmap_t *bios_memmap;
#endif /* _KERNEL */
#endif /* _LOCORE */