diff options
-rw-r--r-- | sys/dev/biovar.h | 5 | ||||
-rw-r--r-- | sys/dev/ic/ami.c | 15 | ||||
-rw-r--r-- | sys/dev/ic/amivar.h | 5 |
3 files changed, 21 insertions, 4 deletions
diff --git a/sys/dev/biovar.h b/sys/dev/biovar.h index 44d71ef5b55..82d913cc7e4 100644 --- a/sys/dev/biovar.h +++ b/sys/dev/biovar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: biovar.h,v 1.11 2005/08/08 04:02:30 deraadt Exp $ */ +/* $OpenBSD: biovar.h,v 1.12 2005/08/08 20:23:46 marco Exp $ */ /* * Copyright (c) 2002 Niklas Hallqvist. All rights reserved. @@ -94,7 +94,8 @@ struct bioc_disk { char bd_product[16]; /* product string */ char bd_revision[4]; /* revision string */ char bd_pad[4]; /* zero terminate in here */ - char bd_serial[16]; + char bd_serial[16]; /* serial number */ + char bd_procdev[16]; /* processor device */ }; #define BIOCVOL _IOWR('B', 34, struct bioc_vol) diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c index 6f9a2c9d78a..604ed5cf99d 100644 --- a/sys/dev/ic/ami.c +++ b/sys/dev/ic/ami.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ami.c,v 1.55 2005/08/08 04:02:31 deraadt Exp $ */ +/* $OpenBSD: ami.c,v 1.56 2005/08/08 20:23:46 marco Exp $ */ /* * Copyright (c) 2001 Michael Shalayeff @@ -636,6 +636,7 @@ ami_attach(sc) rsc->sc_link.openings = sc->sc_maxcmds; rsc->sc_link.adapter_softc = rsc; rsc->sc_link.adapter = &ami_raw_switch; + rsc->sc_proctarget = -1; /* TODO fetch it from the controller */ rsc->sc_link.adapter_target = 16; rsc->sc_link.adapter_buswidth = 16; @@ -1320,6 +1321,7 @@ ami_scsi_raw_cmd(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; struct ami_iocmd *cmd; struct ami_passthrough *ps; @@ -1355,6 +1357,11 @@ ami_scsi_raw_cmd(xs) case READ_BIG: case READ_BUFFER: case RECEIVE_DIAGNOSTIC: + if (!cold) /* XXX bogus */ + if (target == rsc->sc_proctarget) + strlcpy(rsc->sc_procdev, dev->dv_xname, + sizeof(rsc->sc_procdev)); + direction = AMI_PT_IN; break; @@ -1460,8 +1467,11 @@ ami_scsi_raw_cmd(xs) if (!(type == T_PROCESSOR || type == T_ENCLOSURE)) xs->error = XS_DRIVER_STUFFUP; + else + rsc->sc_proctarget = target; /* save off target */ } + if (ccb->ami_pt.dir == AMI_PT_IN) memcpy(xs->data, ccb->ami_pt.idata + sizeof *ps, xs->datalen); @@ -2191,6 +2201,9 @@ ami_ioctl_disk(sc, bd) bd->bd_channel = ch; bd->bd_target = tg; + strlcpy(bd->bd_procdev, sc->sc_rawsoftcs[ch].sc_procdev, + sizeof(bd->bd_procdev)); + error = 0; goto bail; } diff --git a/sys/dev/ic/amivar.h b/sys/dev/ic/amivar.h index 4ff0a74dbe8..3131ccd2ec8 100644 --- a/sys/dev/ic/amivar.h +++ b/sys/dev/ic/amivar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: amivar.h,v 1.16 2005/08/08 03:11:36 marco Exp $ */ +/* $OpenBSD: amivar.h,v 1.17 2005/08/08 20:23:46 marco Exp $ */ /* * Copyright (c) 2001 Michael Shalayeff @@ -59,6 +59,9 @@ struct ami_rawsoftc { struct scsi_link sc_link; struct ami_softc *sc_softc; u_int8_t sc_channel; + + int sc_proctarget; /* ses/safte target id */ + char sc_procdev[16]; /* ses/safte device */ }; struct ami_softc { |