diff options
author | mjacob <mjacob@cvs.openbsd.org> | 2001-03-15 20:08:44 +0000 |
---|---|---|
committer | mjacob <mjacob@cvs.openbsd.org> | 2001-03-15 20:08:44 +0000 |
commit | 67a33b44e1e648bc77ce4f8ed297ea6c317c8133 (patch) | |
tree | 34d50a57002863dc331e979b5785551a6f108242 /sys/scsi | |
parent | c86526492b645d61d387cefd15a80a024a36c21e (diff) |
Move status reads to chopen- there's no need to hang up the boot
process finding out the changer parameters.
Print out changer parameters only if they're changed from the last
read of changer parameters. This works for the first time, and for
99.9% of all other cases will be silent ever after. The only time
this will then be chatty afterwards is if you change something
within the changer (add a drive, etc.).
Diffstat (limited to 'sys/scsi')
-rw-r--r-- | sys/scsi/ch.c | 88 |
1 files changed, 43 insertions, 45 deletions
diff --git a/sys/scsi/ch.c b/sys/scsi/ch.c index 8aae1578307..f4f0ea2b590 100644 --- a/sys/scsi/ch.c +++ b/sys/scsi/ch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ch.c,v 1.9 2000/04/08 19:19:33 csapuntz Exp $ */ +/* $OpenBSD: ch.c,v 1.10 2001/03/15 20:08:43 mjacob Exp $ */ /* $NetBSD: ch.c,v 1.26 1997/02/21 22:06:52 thorpej Exp $ */ /* @@ -86,7 +86,7 @@ struct ch_softc { /* * Quirks; see below. */ - int sc_settledelay; /* delay for settle */ + int sc_settledelay; /* delay for settle */ }; @@ -170,49 +170,10 @@ chattach(parent, self, aux) printf("\n"); /* - * Find out our device's quirks. + * Store our our device's quirks. */ ch_get_quirks(sc, sa->sa_inqbuf); - /* - * Some changers require a long time to settle out, to do - * tape inventory, for instance. - */ - if (sc->sc_settledelay) { - printf("%s: waiting %d seconds for changer to settle...\n", - sc->sc_dev.dv_xname, sc->sc_settledelay); - delay(1000000 * sc->sc_settledelay); - } - - /* - * Get information about the device. Note we can't use - * interrupts yet. - */ - if (ch_get_params(sc, scsi_autoconf)) - printf("%s: offline\n", sc->sc_dev.dv_xname); - else { -#define PLURAL(c) (c) == 1 ? "" : "s" - printf("%s: %d slot%s, %d drive%s, %d picker%s, %d portal%s\n", - sc->sc_dev.dv_xname, - sc->sc_counts[CHET_ST], PLURAL(sc->sc_counts[CHET_ST]), - sc->sc_counts[CHET_DT], PLURAL(sc->sc_counts[CHET_DT]), - sc->sc_counts[CHET_MT], PLURAL(sc->sc_counts[CHET_MT]), - sc->sc_counts[CHET_IE], PLURAL(sc->sc_counts[CHET_IE])); -#undef PLURAL -#ifdef CHANGER_DEBUG - printf("%s: move mask: 0x%x 0x%x 0x%x 0x%x\n", - sc->sc_dev.dv_xname, - sc->sc_movemask[CHET_MT], sc->sc_movemask[CHET_ST], - sc->sc_movemask[CHET_IE], sc->sc_movemask[CHET_DT]); - printf("%s: exchange mask: 0x%x 0x%x 0x%x 0x%x\n", - sc->sc_dev.dv_xname, - sc->sc_exchangemask[CHET_MT], sc->sc_exchangemask[CHET_ST], - sc->sc_exchangemask[CHET_IE], sc->sc_exchangemask[CHET_DT]); -#endif /* CHANGER_DEBUG */ - } - - /* Default the current picker. */ - sc->sc_picker = sc->sc_firsts[CHET_MT]; } int @@ -222,7 +183,8 @@ chopen(dev, flags, fmt, p) struct proc *p; { struct ch_softc *sc; - int unit, error = 0; + int oldcounts[4]; + int i, unit, error = 0; unit = CHUNIT(dev); if ((unit >= ch_cd.cd_ndevs) || @@ -248,10 +210,46 @@ chopen(dev, flags, fmt, p) goto bad; /* - * Make sure our parameters are up to date. + * Get information about the device. Save old information + * so we can decide whether to be verbose about new parameters. */ - if ((error = ch_get_params(sc, 0)) != 0) + for (i = 0; i < 4; i++) { + oldcounts[i] = sc->sc_counts[i]; + } + error = ch_get_params(sc, scsi_autoconf); + if (error) { + printf("%s: offline\n", sc->sc_dev.dv_xname); goto bad; + } + + for (i = 0; i < 4; i++) { + if (oldcounts[i] != sc->sc_counts[i]) { + break; + } + } + if (i < 4) { +#define PLURAL(c) (c) == 1 ? "" : "s" + printf("%s: %d slot%s, %d drive%s, %d picker%s, %d portal%s\n", + sc->sc_dev.dv_xname, + sc->sc_counts[CHET_ST], PLURAL(sc->sc_counts[CHET_ST]), + sc->sc_counts[CHET_DT], PLURAL(sc->sc_counts[CHET_DT]), + sc->sc_counts[CHET_MT], PLURAL(sc->sc_counts[CHET_MT]), + sc->sc_counts[CHET_IE], PLURAL(sc->sc_counts[CHET_IE])); +#undef PLURAL +#ifdef CHANGER_DEBUG + printf("%s: move mask: 0x%x 0x%x 0x%x 0x%x\n", + sc->sc_dev.dv_xname, + sc->sc_movemask[CHET_MT], sc->sc_movemask[CHET_ST], + sc->sc_movemask[CHET_IE], sc->sc_movemask[CHET_DT]); + printf("%s: exchange mask: 0x%x 0x%x 0x%x 0x%x\n", + sc->sc_dev.dv_xname, + sc->sc_exchangemask[CHET_MT], sc->sc_exchangemask[CHET_ST], + sc->sc_exchangemask[CHET_IE], sc->sc_exchangemask[CHET_DT]); +#endif /* CHANGER_DEBUG */ + } + + /* Default the current picker. */ + sc->sc_picker = sc->sc_firsts[CHET_MT]; return (0); |