summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2011-02-22 02:30:09 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2011-02-22 02:30:09 +0000
commit70812baf944ac0f9bca46406db6034c109b97d65 (patch)
tree78302ff0c0dca639ccbb5b77522bfec5e8594ff3
parentcd63e27a8d8680c0081ff6581e3126e0aad381ed (diff)
ami figures out the names of the enclosure attached to it by snooping
commands on the passthru busses after the kernel becomes !cold. however, if the enclosure doesnt have any sensors then we dont issue regular commands to it, so ami cant see what its name is. this moves the name fetch from the passthru io path to a walk of all the devices on the bus just after they were attached. problem reported and fix tested by henning@ ok miod@
-rw-r--r--sys/dev/ic/ami.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index b0c4573da51..a039eddde8f 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.217 2010/10/12 00:53:32 krw Exp $ */
+/* $OpenBSD: ami.c,v 1.218 2011/02/22 02:30:08 dlg Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -575,6 +575,10 @@ ami_attach(struct ami_softc *sc)
for (sc->sc_rawsoftcs = rsc;
rsc < &sc->sc_rawsoftcs[sc->sc_channels]; rsc++) {
+ struct scsibus_softc *ptbus;
+ struct scsi_link *proclink;
+ struct device *procdev;
+
rsc->sc_softc = sc;
rsc->sc_channel = rsc - sc->sc_rawsoftcs;
rsc->sc_link.openings = sc->sc_maxcmds;
@@ -589,7 +593,19 @@ ami_attach(struct ami_softc *sc)
bzero(&saa, sizeof(saa));
saa.saa_sc_link = &rsc->sc_link;
- config_found(&sc->sc_dev, &saa, scsiprint);
+ ptbus = (struct scsibus_softc *)config_found(&sc->sc_dev,
+ &saa, scsiprint);
+
+ if (ptbus == NULL || rsc->sc_proctarget == -1)
+ continue;
+
+ proclink = scsi_get_link(ptbus, rsc->sc_proctarget, 0);
+ if (proclink == NULL)
+ continue;
+
+ procdev = proclink->device_softc;
+ strlcpy(rsc->sc_procdev, procdev->dv_xname,
+ sizeof(rsc->sc_procdev));
}
return (0);
@@ -1203,15 +1219,10 @@ ami_scsi_raw_cmd(struct scsi_xfer *xs)
struct ami_rawsoftc *rsc = link->adapter_softc;
struct ami_softc *sc = rsc->sc_softc;
u_int8_t channel = rsc->sc_channel, target = link->target;
- struct device *dev = link->device_softc;
struct ami_ccb *ccb;
AMI_DPRINTF(AMI_D_CMD, ("ami_scsi_raw_cmd "));
- if (!cold && target == rsc->sc_proctarget)
- strlcpy(rsc->sc_procdev, dev->dv_xname,
- sizeof(rsc->sc_procdev));
-
if (xs->cmdlen > AMI_MAX_CDB) {
AMI_DPRINTF(AMI_D_CMD, ("CDB too big %p ", xs));
bzero(&xs->sense, sizeof(xs->sense));