From b079435208aa63b4d5a97d4851a41689cfb12a72 Mon Sep 17 00:00:00 2001 From: Nate Williams Date: Tue, 12 Mar 1996 06:09:34 +0000 Subject: [PATCH] Always initialize master_softc. This avoids panics in the idle loop due to unitialized data if the APM support is compiled in and the probe fails. --- sys/i386/apm/apm.c | 9 +++++++-- sys/i386/bios/apm.c | 9 +++++++-- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/sys/i386/apm/apm.c b/sys/i386/apm/apm.c index 268755916e14..9d039b1b14b6 100644 --- a/sys/i386/apm/apm.c +++ b/sys/i386/apm/apm.c @@ -13,7 +13,7 @@ * * Sep, 1994 Implemented on FreeBSD 1.1.5.1R (Toshiba AVS001WD) * - * $Id: apm.c,v 1.23 1995/12/27 16:16:02 bde Exp $ + * $Id: apm.c,v 1.24 1996/03/11 06:48:48 nate Exp $ */ #include "apm.h" @@ -604,6 +604,12 @@ apmprobe(struct isa_device *dvp) { int unit = dvp->id_unit; + /* + * XXX - This is necessary here so that we don't panic in the idle + * loop because master_softc is unitialized. + */ + master_softc = &apm_softc[unit]; + switch (apm_version) { case APMINI_CANTFIND: /* silent */ @@ -712,7 +718,6 @@ apmattach(struct isa_device *dvp) #define APM_KERNBASE KERNBASE struct apm_softc *sc = &apm_softc[unit]; - master_softc = sc; /* XXX */ sc->initialized = 0; sc->active = 0; sc->halt_cpu = 1; diff --git a/sys/i386/bios/apm.c b/sys/i386/bios/apm.c index 268755916e14..9d039b1b14b6 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.23 1995/12/27 16:16:02 bde Exp $ + * $Id: apm.c,v 1.24 1996/03/11 06:48:48 nate Exp $ */ #include "apm.h" @@ -604,6 +604,12 @@ apmprobe(struct isa_device *dvp) { int unit = dvp->id_unit; + /* + * XXX - This is necessary here so that we don't panic in the idle + * loop because master_softc is unitialized. + */ + master_softc = &apm_softc[unit]; + switch (apm_version) { case APMINI_CANTFIND: /* silent */ @@ -712,7 +718,6 @@ apmattach(struct isa_device *dvp) #define APM_KERNBASE KERNBASE struct apm_softc *sc = &apm_softc[unit]; - master_softc = sc; /* XXX */ sc->initialized = 0; sc->active = 0; sc->halt_cpu = 1;