Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/atari/isa Fix silent hang during config_console() (...



details:   https://anonhg.NetBSD.org/src/rev/411341e6a28d
branches:  trunk
changeset: 829170:411341e6a28d
user:      tsutsui <tsutsui%NetBSD.org@localhost>
date:      Sat Jan 20 18:01:53 2018 +0000

description:
Fix silent hang during config_console() (before consinit()) on Milan.

config_console() was a dirty hack used by ancient m68k ports
to probe and initialize console devices before "real" configure(9),
using subset of configure(9) functions.

In that case, most device specific data (except I/O access method)
are not initialized so we must not access device specific device_t and
softc structures in config_console() cases.

diffstat:

 sys/arch/atari/isa/isa_machdep.c |  13 +++++++------
 1 files changed, 7 insertions(+), 6 deletions(-)

diffs (48 lines):

diff -r 93d5963310b4 -r 411341e6a28d sys/arch/atari/isa/isa_machdep.c
--- a/sys/arch/atari/isa/isa_machdep.c  Sat Jan 20 17:37:15 2018 +0000
+++ b/sys/arch/atari/isa/isa_machdep.c  Sat Jan 20 18:01:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: isa_machdep.c,v 1.40 2012/10/13 17:58:54 jdc Exp $     */
+/*     $NetBSD: isa_machdep.c,v 1.41 2018/01/20 18:01:53 tsutsui Exp $ */
 
 /*
  * Copyright (c) 1997 Leo Weppelman.  All rights reserved.
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: isa_machdep.c,v 1.40 2012/10/13 17:58:54 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: isa_machdep.c,v 1.41 2018/01/20 18:01:53 tsutsui Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -111,17 +111,14 @@
 void
 isabusattach(device_t parent, device_t self, void *aux)
 {
-       struct isabus_softc *sc = device_private(self);
+       struct isabus_softc *sc;
        struct isabus_attach_args       iba;
        extern struct atari_bus_dma_tag isa_bus_dma_tag;
        extern void isa_bus_init(void);
 
-       sc->sc_dev = self;
-
        iba.iba_dmat    = &isa_bus_dma_tag;
        iba.iba_iot     = leb_alloc_bus_space_tag(&bs_storage[0]);
        iba.iba_memt    = leb_alloc_bus_space_tag(&bs_storage[1]);
-       iba.iba_ic      = &sc->sc_chipset;
        if ((iba.iba_iot == NULL) || (iba.iba_memt == NULL)) {
                printf("leb_alloc_bus_space_tag failed!\n");
                return;
@@ -139,6 +136,10 @@
                return;
        }
 
+       sc = device_private(self);
+       sc->sc_dev = self;
+       iba.iba_ic = &sc->sc_chipset;
+
        printf("\n");
        config_found_ia(self, "isabus", &iba, atariisabusprint);
 }



Home | Main Index | Thread Index | Old Index