Add an assertion mechanism to check for more abnormal conditions.

This commit is contained in:
mycroft 1994-11-29 21:29:56 +00:00
parent 58cb5339d6
commit 51bed8d804
3 changed files with 93 additions and 42 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: aic6360.c,v 1.17 1994/11/29 20:57:28 mycroft Exp $ */ /* $NetBSD: aic6360.c,v 1.18 1994/11/29 21:29:56 mycroft Exp $ */
/* /*
* Copyright (c) 1994 Charles Hannum. All rights reserved. * Copyright (c) 1994 Charles Hannum. All rights reserved.
@ -622,9 +622,11 @@ struct aic_softc { /* One of these per adapter */
int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/ int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/
#define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0) #define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0)
#define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0) #define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0)
#define AIC_ASSERT(x) do {if (x) {} else {printf("aic at line %d: assertion failed\n", __LINE__); Debugger();}} while (0)
#else #else
#define AIC_PRINT(b, s) #define AIC_PRINT(b, s)
#define AIC_BREAK() #define AIC_BREAK()
#define AIC_ASSERT(x)
#endif #endif
#define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s) #define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s)
@ -888,7 +890,7 @@ aic_init(aic)
TAILQ_INIT(&aic->ready_list); TAILQ_INIT(&aic->ready_list);
TAILQ_INIT(&aic->nexus_list); TAILQ_INIT(&aic->nexus_list);
TAILQ_INIT(&aic->free_list); TAILQ_INIT(&aic->free_list);
aic->nexus = 0; aic->nexus = NULL;
acb = aic->acb; acb = aic->acb;
bzero(acb, sizeof(aic->acb)); bzero(acb, sizeof(aic->acb));
for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) { for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) {
@ -1180,7 +1182,8 @@ aic_sched(aic)
* Find first acb in ready queue that is for a target/lunit pair that * Find first acb in ready queue that is for a target/lunit pair that
* is not busy. * is not busy.
*/ */
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) { for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
ti = &aic->tinfo[sc->target]; ti = &aic->tinfo[sc->target];
if ((ti->lubusy & (1<<sc->lun)) == 0) { if ((ti->lubusy & (1<<sc->lun)) == 0) {
@ -1286,7 +1289,7 @@ aic_done(acb)
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
} else { } else {
register struct acb *acb2; register struct acb *acb2;
for (acb2 = aic->nexus_list.tqh_first; acb2; for (acb2 = aic->nexus_list.tqh_first; acb2 != NULL;
acb2 = acb2->chain.tqe_next) acb2 = acb2->chain.tqe_next)
if (acb2 == acb) { if (acb2 == acb) {
TAILQ_REMOVE(&aic->nexus_list, acb, chain); TAILQ_REMOVE(&aic->nexus_list, acb, chain);
@ -1294,7 +1297,7 @@ aic_done(acb)
/* XXXX Should we call aic_sched() here? */ /* XXXX Should we call aic_sched() here? */
break; break;
} }
if (acb2) if (acb2 != NULL)
; ;
else if (acb->chain.tqe_next) { else if (acb->chain.tqe_next) {
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
@ -1447,14 +1450,16 @@ nextbyte:
u_char selid, target, lun; u_char selid, target, lun;
case AIC_CONNECTED: case AIC_CONNECTED:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; ti = &aic->tinfo[acb->xs->sc_link->target];
ti = &aic->tinfo[sc->target];
switch (aic->imess[0]) { switch (aic->imess[0]) {
case MSG_CMDCOMPLETE: case MSG_CMDCOMPLETE:
if (aic->dleft < 0) { if (aic->dleft < 0) {
printf("aic: %d extra bytes from %d:%d\n", sc = acb->xs->sc_link;
printf("%s: %d extra bytes from %d:%d\n",
aic->sc_dev.dv_xname,
-aic->dleft, sc->target, sc->lun); -aic->dleft, sc->target, sc->lun);
acb->dleft = 0; acb->dleft = 0;
} }
@ -1595,13 +1600,13 @@ nextbyte:
*/ */
target = ffs(selid) - 1; target = ffs(selid) - 1;
lun = aic->imess[0] & 0x07; lun = aic->imess[0] & 0x07;
for (acb = aic->nexus_list.tqh_first; acb != 0; for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) { acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
if (sc->target == target && sc->lun == lun) if (sc->target == target && sc->lun == lun)
break; break;
} }
if (acb == 0) { if (acb == NULL) {
printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun); printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun);
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
@ -1720,6 +1725,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun); aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun);
n = 1; n = 1;
@ -1731,6 +1737,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[4] = MSG_EXTENDED; aic->omess[4] = MSG_EXTENDED;
aic->omess[3] = 3; aic->omess[3] = 3;
@ -1746,6 +1753,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[3] = MSG_EXTENDED; aic->omess[3] = MSG_EXTENDED;
aic->omess[2] = 2; aic->omess[2] = 2;
@ -2181,6 +2189,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
@ -2222,6 +2231,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL1, 0); outb(SXFRCTL1, 0);
@ -2267,11 +2277,13 @@ aicintr(aic)
printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__); printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__);
AIC_BREAK(); AIC_BREAK();
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
acb->xs->error = XS_DRIVER_STUFFUP; acb->xs->error = XS_DRIVER_STUFFUP;
goto finish; goto finish;
case AIC_DISCONNECT: case AIC_DISCONNECT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->state = AIC_IDLE; aic->state = AIC_IDLE;
aic->nexus = NULL; aic->nexus = NULL;
@ -2280,6 +2292,7 @@ aicintr(aic)
goto out; goto out;
case AIC_CMDCOMPLETE: case AIC_CMDCOMPLETE:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
finish: finish:
untimeout(aic_timeout, acb); untimeout(aic_timeout, acb);
@ -2321,6 +2334,7 @@ aicintr(aic)
case PH_CMD: /* CMD phase & REQ asserted */ case PH_CMD: /* CMD phase & REQ asserted */
#if AIC_DEBUG #if AIC_DEBUG
if ((aic_debug & AIC_SHOWMISC) != 0) { if ((aic_debug & AIC_SHOWMISC) != 0) {
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
printf("cmd=0x%02x+%d ", printf("cmd=0x%02x+%d ",
acb->cmd.opcode, acb->clen-1); acb->cmd.opcode, acb->clen-1);
@ -2345,6 +2359,7 @@ aicintr(aic)
goto nextphase; goto nextphase;
case PH_STAT: case PH_STAT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL0, CHEN|SPIOEN); outb(SXFRCTL0, CHEN|SPIOEN);
outb(DMACNTRL0, RSTFIFO); outb(DMACNTRL0, RSTFIFO);
@ -2434,13 +2449,15 @@ aic_print_active_acb()
struct aic_softc *aic = aiccd.cd_devs[0]; struct aic_softc *aic = aiccd.cd_devs[0];
printf("ready list:\n"); printf("ready list:\n");
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
printf("nexus:\n"); printf("nexus:\n");
if (aic->nexus) if (aic->nexus != NULL)
aic_print_acb(aic->nexus); aic_print_acb(aic->nexus);
printf("nexus list:\n"); printf("nexus list:\n");
for (acb = aic->nexus_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
} }

View File

@ -1,4 +1,4 @@
/* $NetBSD: aic6360.c,v 1.17 1994/11/29 20:57:28 mycroft Exp $ */ /* $NetBSD: aic6360.c,v 1.18 1994/11/29 21:29:56 mycroft Exp $ */
/* /*
* Copyright (c) 1994 Charles Hannum. All rights reserved. * Copyright (c) 1994 Charles Hannum. All rights reserved.
@ -622,9 +622,11 @@ struct aic_softc { /* One of these per adapter */
int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/ int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/
#define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0) #define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0)
#define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0) #define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0)
#define AIC_ASSERT(x) do {if (x) {} else {printf("aic at line %d: assertion failed\n", __LINE__); Debugger();}} while (0)
#else #else
#define AIC_PRINT(b, s) #define AIC_PRINT(b, s)
#define AIC_BREAK() #define AIC_BREAK()
#define AIC_ASSERT(x)
#endif #endif
#define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s) #define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s)
@ -888,7 +890,7 @@ aic_init(aic)
TAILQ_INIT(&aic->ready_list); TAILQ_INIT(&aic->ready_list);
TAILQ_INIT(&aic->nexus_list); TAILQ_INIT(&aic->nexus_list);
TAILQ_INIT(&aic->free_list); TAILQ_INIT(&aic->free_list);
aic->nexus = 0; aic->nexus = NULL;
acb = aic->acb; acb = aic->acb;
bzero(acb, sizeof(aic->acb)); bzero(acb, sizeof(aic->acb));
for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) { for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) {
@ -1180,7 +1182,8 @@ aic_sched(aic)
* Find first acb in ready queue that is for a target/lunit pair that * Find first acb in ready queue that is for a target/lunit pair that
* is not busy. * is not busy.
*/ */
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) { for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
ti = &aic->tinfo[sc->target]; ti = &aic->tinfo[sc->target];
if ((ti->lubusy & (1<<sc->lun)) == 0) { if ((ti->lubusy & (1<<sc->lun)) == 0) {
@ -1286,7 +1289,7 @@ aic_done(acb)
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
} else { } else {
register struct acb *acb2; register struct acb *acb2;
for (acb2 = aic->nexus_list.tqh_first; acb2; for (acb2 = aic->nexus_list.tqh_first; acb2 != NULL;
acb2 = acb2->chain.tqe_next) acb2 = acb2->chain.tqe_next)
if (acb2 == acb) { if (acb2 == acb) {
TAILQ_REMOVE(&aic->nexus_list, acb, chain); TAILQ_REMOVE(&aic->nexus_list, acb, chain);
@ -1294,7 +1297,7 @@ aic_done(acb)
/* XXXX Should we call aic_sched() here? */ /* XXXX Should we call aic_sched() here? */
break; break;
} }
if (acb2) if (acb2 != NULL)
; ;
else if (acb->chain.tqe_next) { else if (acb->chain.tqe_next) {
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
@ -1447,14 +1450,16 @@ nextbyte:
u_char selid, target, lun; u_char selid, target, lun;
case AIC_CONNECTED: case AIC_CONNECTED:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; ti = &aic->tinfo[acb->xs->sc_link->target];
ti = &aic->tinfo[sc->target];
switch (aic->imess[0]) { switch (aic->imess[0]) {
case MSG_CMDCOMPLETE: case MSG_CMDCOMPLETE:
if (aic->dleft < 0) { if (aic->dleft < 0) {
printf("aic: %d extra bytes from %d:%d\n", sc = acb->xs->sc_link;
printf("%s: %d extra bytes from %d:%d\n",
aic->sc_dev.dv_xname,
-aic->dleft, sc->target, sc->lun); -aic->dleft, sc->target, sc->lun);
acb->dleft = 0; acb->dleft = 0;
} }
@ -1595,13 +1600,13 @@ nextbyte:
*/ */
target = ffs(selid) - 1; target = ffs(selid) - 1;
lun = aic->imess[0] & 0x07; lun = aic->imess[0] & 0x07;
for (acb = aic->nexus_list.tqh_first; acb != 0; for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) { acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
if (sc->target == target && sc->lun == lun) if (sc->target == target && sc->lun == lun)
break; break;
} }
if (acb == 0) { if (acb == NULL) {
printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun); printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun);
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
@ -1720,6 +1725,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun); aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun);
n = 1; n = 1;
@ -1731,6 +1737,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[4] = MSG_EXTENDED; aic->omess[4] = MSG_EXTENDED;
aic->omess[3] = 3; aic->omess[3] = 3;
@ -1746,6 +1753,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[3] = MSG_EXTENDED; aic->omess[3] = MSG_EXTENDED;
aic->omess[2] = 2; aic->omess[2] = 2;
@ -2181,6 +2189,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
@ -2222,6 +2231,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL1, 0); outb(SXFRCTL1, 0);
@ -2267,11 +2277,13 @@ aicintr(aic)
printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__); printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__);
AIC_BREAK(); AIC_BREAK();
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
acb->xs->error = XS_DRIVER_STUFFUP; acb->xs->error = XS_DRIVER_STUFFUP;
goto finish; goto finish;
case AIC_DISCONNECT: case AIC_DISCONNECT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->state = AIC_IDLE; aic->state = AIC_IDLE;
aic->nexus = NULL; aic->nexus = NULL;
@ -2280,6 +2292,7 @@ aicintr(aic)
goto out; goto out;
case AIC_CMDCOMPLETE: case AIC_CMDCOMPLETE:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
finish: finish:
untimeout(aic_timeout, acb); untimeout(aic_timeout, acb);
@ -2321,6 +2334,7 @@ aicintr(aic)
case PH_CMD: /* CMD phase & REQ asserted */ case PH_CMD: /* CMD phase & REQ asserted */
#if AIC_DEBUG #if AIC_DEBUG
if ((aic_debug & AIC_SHOWMISC) != 0) { if ((aic_debug & AIC_SHOWMISC) != 0) {
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
printf("cmd=0x%02x+%d ", printf("cmd=0x%02x+%d ",
acb->cmd.opcode, acb->clen-1); acb->cmd.opcode, acb->clen-1);
@ -2345,6 +2359,7 @@ aicintr(aic)
goto nextphase; goto nextphase;
case PH_STAT: case PH_STAT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL0, CHEN|SPIOEN); outb(SXFRCTL0, CHEN|SPIOEN);
outb(DMACNTRL0, RSTFIFO); outb(DMACNTRL0, RSTFIFO);
@ -2434,13 +2449,15 @@ aic_print_active_acb()
struct aic_softc *aic = aiccd.cd_devs[0]; struct aic_softc *aic = aiccd.cd_devs[0];
printf("ready list:\n"); printf("ready list:\n");
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
printf("nexus:\n"); printf("nexus:\n");
if (aic->nexus) if (aic->nexus != NULL)
aic_print_acb(aic->nexus); aic_print_acb(aic->nexus);
printf("nexus list:\n"); printf("nexus list:\n");
for (acb = aic->nexus_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
} }

View File

@ -1,4 +1,4 @@
/* $NetBSD: aic6360.c,v 1.17 1994/11/29 20:57:28 mycroft Exp $ */ /* $NetBSD: aic6360.c,v 1.18 1994/11/29 21:29:56 mycroft Exp $ */
/* /*
* Copyright (c) 1994 Charles Hannum. All rights reserved. * Copyright (c) 1994 Charles Hannum. All rights reserved.
@ -622,9 +622,11 @@ struct aic_softc { /* One of these per adapter */
int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/ int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; /**/
#define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0) #define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0)
#define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0) #define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0)
#define AIC_ASSERT(x) do {if (x) {} else {printf("aic at line %d: assertion failed\n", __LINE__); Debugger();}} while (0)
#else #else
#define AIC_PRINT(b, s) #define AIC_PRINT(b, s)
#define AIC_BREAK() #define AIC_BREAK()
#define AIC_ASSERT(x)
#endif #endif
#define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s) #define AIC_ACBS(s) AIC_PRINT(AIC_SHOWACBS, s)
@ -888,7 +890,7 @@ aic_init(aic)
TAILQ_INIT(&aic->ready_list); TAILQ_INIT(&aic->ready_list);
TAILQ_INIT(&aic->nexus_list); TAILQ_INIT(&aic->nexus_list);
TAILQ_INIT(&aic->free_list); TAILQ_INIT(&aic->free_list);
aic->nexus = 0; aic->nexus = NULL;
acb = aic->acb; acb = aic->acb;
bzero(acb, sizeof(aic->acb)); bzero(acb, sizeof(aic->acb));
for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) { for (r = 0; r < sizeof(aic->acb) / sizeof(*acb); r++) {
@ -1180,7 +1182,8 @@ aic_sched(aic)
* Find first acb in ready queue that is for a target/lunit pair that * Find first acb in ready queue that is for a target/lunit pair that
* is not busy. * is not busy.
*/ */
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) { for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
ti = &aic->tinfo[sc->target]; ti = &aic->tinfo[sc->target];
if ((ti->lubusy & (1<<sc->lun)) == 0) { if ((ti->lubusy & (1<<sc->lun)) == 0) {
@ -1286,7 +1289,7 @@ aic_done(acb)
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
} else { } else {
register struct acb *acb2; register struct acb *acb2;
for (acb2 = aic->nexus_list.tqh_first; acb2; for (acb2 = aic->nexus_list.tqh_first; acb2 != NULL;
acb2 = acb2->chain.tqe_next) acb2 = acb2->chain.tqe_next)
if (acb2 == acb) { if (acb2 == acb) {
TAILQ_REMOVE(&aic->nexus_list, acb, chain); TAILQ_REMOVE(&aic->nexus_list, acb, chain);
@ -1294,7 +1297,7 @@ aic_done(acb)
/* XXXX Should we call aic_sched() here? */ /* XXXX Should we call aic_sched() here? */
break; break;
} }
if (acb2) if (acb2 != NULL)
; ;
else if (acb->chain.tqe_next) { else if (acb->chain.tqe_next) {
TAILQ_REMOVE(&aic->ready_list, acb, chain); TAILQ_REMOVE(&aic->ready_list, acb, chain);
@ -1447,14 +1450,16 @@ nextbyte:
u_char selid, target, lun; u_char selid, target, lun;
case AIC_CONNECTED: case AIC_CONNECTED:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; ti = &aic->tinfo[acb->xs->sc_link->target];
ti = &aic->tinfo[sc->target];
switch (aic->imess[0]) { switch (aic->imess[0]) {
case MSG_CMDCOMPLETE: case MSG_CMDCOMPLETE:
if (aic->dleft < 0) { if (aic->dleft < 0) {
printf("aic: %d extra bytes from %d:%d\n", sc = acb->xs->sc_link;
printf("%s: %d extra bytes from %d:%d\n",
aic->sc_dev.dv_xname,
-aic->dleft, sc->target, sc->lun); -aic->dleft, sc->target, sc->lun);
acb->dleft = 0; acb->dleft = 0;
} }
@ -1595,13 +1600,13 @@ nextbyte:
*/ */
target = ffs(selid) - 1; target = ffs(selid) - 1;
lun = aic->imess[0] & 0x07; lun = aic->imess[0] & 0x07;
for (acb = aic->nexus_list.tqh_first; acb != 0; for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) { acb = acb->chain.tqe_next) {
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
if (sc->target == target && sc->lun == lun) if (sc->target == target && sc->lun == lun)
break; break;
} }
if (acb == 0) { if (acb == NULL) {
printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun); printf("aic at line %d: reselect from target %d lun %d with no nexus; sending DEVICE RESET\n", __LINE__, target, lun);
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
@ -1720,6 +1725,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun); aic->omess[0] = MSG_IDENTIFY(acb->xs->sc_link->lun);
n = 1; n = 1;
@ -1731,6 +1737,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[4] = MSG_EXTENDED; aic->omess[4] = MSG_EXTENDED;
aic->omess[3] = 3; aic->omess[3] = 3;
@ -1746,6 +1753,7 @@ nextmsg:
AIC_BREAK(); AIC_BREAK();
goto noop; goto noop;
} }
AIC_ASSERT(aic->nexus != NULL);
ti = &aic->tinfo[aic->nexus->xs->sc_link->target]; ti = &aic->tinfo[aic->nexus->xs->sc_link->target];
aic->omess[3] = MSG_EXTENDED; aic->omess[3] = MSG_EXTENDED;
aic->omess[2] = 2; aic->omess[2] = 2;
@ -2181,6 +2189,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
sc = acb->xs->sc_link; sc = acb->xs->sc_link;
@ -2222,6 +2231,7 @@ aicintr(aic)
AIC_BREAK(); AIC_BREAK();
goto reset; goto reset;
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL1, 0); outb(SXFRCTL1, 0);
@ -2267,11 +2277,13 @@ aicintr(aic)
printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__); printf("aic at line %d: unexpected BUS FREE; aborting\n", __LINE__);
AIC_BREAK(); AIC_BREAK();
} }
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
acb->xs->error = XS_DRIVER_STUFFUP; acb->xs->error = XS_DRIVER_STUFFUP;
goto finish; goto finish;
case AIC_DISCONNECT: case AIC_DISCONNECT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
aic->state = AIC_IDLE; aic->state = AIC_IDLE;
aic->nexus = NULL; aic->nexus = NULL;
@ -2280,6 +2292,7 @@ aicintr(aic)
goto out; goto out;
case AIC_CMDCOMPLETE: case AIC_CMDCOMPLETE:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
finish: finish:
untimeout(aic_timeout, acb); untimeout(aic_timeout, acb);
@ -2321,6 +2334,7 @@ aicintr(aic)
case PH_CMD: /* CMD phase & REQ asserted */ case PH_CMD: /* CMD phase & REQ asserted */
#if AIC_DEBUG #if AIC_DEBUG
if ((aic_debug & AIC_SHOWMISC) != 0) { if ((aic_debug & AIC_SHOWMISC) != 0) {
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
printf("cmd=0x%02x+%d ", printf("cmd=0x%02x+%d ",
acb->cmd.opcode, acb->clen-1); acb->cmd.opcode, acb->clen-1);
@ -2345,6 +2359,7 @@ aicintr(aic)
goto nextphase; goto nextphase;
case PH_STAT: case PH_STAT:
AIC_ASSERT(aic->nexus != NULL);
acb = aic->nexus; acb = aic->nexus;
outb(SXFRCTL0, CHEN|SPIOEN); outb(SXFRCTL0, CHEN|SPIOEN);
outb(DMACNTRL0, RSTFIFO); outb(DMACNTRL0, RSTFIFO);
@ -2434,13 +2449,15 @@ aic_print_active_acb()
struct aic_softc *aic = aiccd.cd_devs[0]; struct aic_softc *aic = aiccd.cd_devs[0];
printf("ready list:\n"); printf("ready list:\n");
for (acb = aic->ready_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
printf("nexus:\n"); printf("nexus:\n");
if (aic->nexus) if (aic->nexus != NULL)
aic_print_acb(aic->nexus); aic_print_acb(aic->nexus);
printf("nexus list:\n"); printf("nexus list:\n");
for (acb = aic->nexus_list.tqh_first; acb; acb = acb->chain.tqe_next) for (acb = aic->nexus_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next)
aic_print_acb(acb); aic_print_acb(acb);
} }