summaryrefslogtreecommitdiff
path: root/sys/dev/ic/ami.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic/ami.c')
-rw-r--r--sys/dev/ic/ami.c31
1 files changed, 23 insertions, 8 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index 66c00273e49..0d1138d4709 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.53 2005/08/05 04:16:51 marco Exp $ */
+/* $OpenBSD: ami.c,v 1.54 2005/08/08 03:11:36 marco Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -1485,6 +1485,7 @@ ami_scsi_cmd(xs)
{
struct scsi_link *link = xs->sc_link;
struct ami_softc *sc = link->adapter_softc;
+ struct device *dev = link->device_softc;
struct ami_ccb *ccb;
struct ami_iocmd *cmd;
struct scsi_inquiry_data inq;
@@ -1521,6 +1522,11 @@ ami_scsi_cmd(xs)
switch (xs->cmd->opcode) {
case TEST_UNIT_READY:
+ /* save off sd? after autoconf */
+ if (!cold) /* XXX bogus */
+ strlcpy(sc->sc_hdr[target].dev, dev->dv_xname,
+ sizeof(sc->sc_hdr[target].dev));
+
case START_STOP:
#if 0
case VERIFY:
@@ -1766,6 +1772,7 @@ ami_scsi_ioctl(struct scsi_link *link, u_long cmd,
caddr_t addr, int flag, struct proc *p)
{
struct ami_softc *sc = (struct ami_softc *)link->adapter_softc;
+ /* struct device *dev = (struct device *)link->device_softc; */
/* u_int8_t target = link->target; */
if (sc->sc_ioctl)
@@ -1997,6 +2004,8 @@ ami_ioctl_inq(sc, bi)
bi->novol = p->ada_nld;
bi->nodisk = 0;
+ strlcpy(bi->dev, sc->sc_dev.dv_xname, sizeof(bi->dev));
+
/* do we actually care how many disks we have at this point? */
for (i = 0; i < p->ada_nld; i++)
for (s = 0; s < p->ald[i].adl_spandepth; s++)
@@ -2092,8 +2101,10 @@ ami_ioctl_vol(sc, bv)
if (p->ald[i].adl_spandepth > 1)
bv->level *= 10;
- bv->size *= (quad_t)512;
+ bv->size *= (u_quad_t)512;
+ strlcpy(bv->dev, sc->sc_hdr[i].dev, sizeof(bv->dev));
+
bail:
free(p, M_DEVBUF);
@@ -2110,6 +2121,7 @@ ami_ioctl_disk(sc, bd)
int i, s, t, d;
int off;
int error = 0;
+ u_int16_t ch, tg;
p = malloc(sizeof *p, M_DEVBUF, M_NOWAIT);
if (!p) {
@@ -2166,15 +2178,18 @@ ami_ioctl_disk(sc, bd)
bd->status = BIOC_SDINVALID;
}
- bd->size = (quad_t)p->apd[off].adp_size * (quad_t)512;
+ bd->size = (u_quad_t)p->apd[off].adp_size *
+ (u_quad_t)512;
- if (!ami_drv_inq(sc,
- (p->ald[i].asp[s].adv[t].add_target >> 4),
- (p->ald[i].asp[s].adv[t].add_target & 0x0f),
- &inqbuf)) {
+ ch = p->ald[i].asp[s].adv[t].add_target >> 4;
+ tg = p->ald[i].asp[s].adv[t].add_target & 0x0f;
+
+ if (!ami_drv_inq(sc, ch, tg, &inqbuf))
strlcpy(bd->vendor, inqbuf.vendor,
8 + 16 + 4 + 1); /* vendor prod rev zero */
- }
+
+ bd->channel = ch;
+ bd->target = tg;
error = 0;
goto bail;