Some stylistic changes, but also use the new INT_PENDING macro. Start

tracking LIP sequence numbers.
This commit is contained in:
mjacob 1999-10-17 01:38:27 +00:00
parent 4fdbb0d1a0
commit 4938c2371d

View File

@ -1,4 +1,4 @@
/* $NetBSD: isp.c,v 1.38 1999/10/14 02:27:12 mjacob Exp $ */
/* $NetBSD: isp.c,v 1.39 1999/10/17 01:38:27 mjacob Exp $ */
/*
* Copyright (C) 1997, 1998, 1999 National Aeronautics & Space Administration
* All rights reserved.
@ -2142,22 +2142,12 @@ isp_intr(arg)
} while (isr != isrb);
sema = ISP_READ(isp, BIU_SEMA) & 0x1;
IDPRINTF(5, ("%s: isp_intr isr %x sem %x\n", isp->isp_name, isr, sema));
if (IS_FC(isp)) {
if (isr == 0 || (isr & BIU2100_ISR_RISC_INT) == 0) {
if (isr) {
IDPRINTF(4, ("%s: isp_intr isr=%x\n",
isp->isp_name, isr));
}
return (0);
}
} else {
if (isr == 0 || (isr & BIU_ISR_RISC_INT) == 0) {
if (isr) {
IDPRINTF(4, ("%s: isp_intr isr=%x\n",
isp->isp_name, isr));
}
return (0);
}
if (isr == 0) {
return (0);
}
if (!INT_PENDING(isp, isr)) {
IDPRINTF(4, ("%s: isp_intr isr=%x\n", isp->isp_name, isr));
return (0);
}
if (isp->isp_state != ISP_RUNSTATE) {
IDPRINTF(3, ("%s: interrupt (isr=%x,sema=%x) when not ready\n",
@ -2543,6 +2533,8 @@ isp_parse_async(isp, mbox)
break;
case ASYNC_LIP_OCCURRED:
((fcparam *) isp->isp_param)->isp_lipseq =
ISP_READ(isp, OUTMAILBOX1);
((fcparam *) isp->isp_param)->isp_fwstate = FW_CONFIG_WAIT;
((fcparam *) isp->isp_param)->isp_loopstate = LOOP_LIP_RCVD;
isp->isp_sendmarker = 1;
@ -3124,6 +3116,8 @@ command_known:
*/
if (mbox & 0x8000) {
fph = isp_parse_async(isp, (int) mbox);
IDPRINTF(5, ("%s: line %d, fph %d\n",
isp->isp_name, __LINE__, fph));
ISP_WRITE(isp, BIU_SEMA, 0);
ISP_WRITE(isp, HCCR, HCCR_CMD_CLEAR_RISC_INT);
if (fph < 0) {
@ -3141,11 +3135,15 @@ command_known:
* eat this here.
*/
if (mbox & 0x4000) {
IDPRINTF(5, ("%s: line %d, mbox 0x%x\n",
isp->isp_name, __LINE__, mbox));
ISP_WRITE(isp, BIU_SEMA, 0);
ISP_WRITE(isp, HCCR, HCCR_CMD_CLEAR_RISC_INT);
SYS_DELAY(100);
goto command_known;
}
PRINTF("%s: isp_mboxcmd sees mailbox int with 0x%x in "
"mbox0\n", isp->isp_name, mbox);
}
SYS_DELAY(100);
if (--loops < 0) {
@ -3181,6 +3179,7 @@ command_known:
case MBOX_SET_TAG_AGE_LIMIT:
case MBOX_SET_SELECT_TIMEOUT:
ISP_WRITE(isp, INMAILBOX2, mbp->param[2]);
mbp->param[2] = 0;
break;
}
}
@ -3289,7 +3288,7 @@ command_known:
/*
* Pick up output parameters. Special case some of the readbacks
* for the dual port SCSI cards or FC Cards...
* for the dual port SCSI cards.
*/
if (IS_12X0(isp)) {
switch (opcode) {
@ -3309,14 +3308,6 @@ command_known:
mbp->param[2] = ISP_READ(isp, OUTMAILBOX2);
break;
}
} else if (IS_FC(isp)) {
switch (opcode) {
case MBOX_GET_LOOP_ID:
mbp->param[6] = ISP_READ(isp, OUTMAILBOX6);
break;
default:
break;
}
}
switch (outparam) {
@ -3347,24 +3338,32 @@ command_known:
case MBOX_COMMAND_COMPLETE:
break;
case MBOX_INVALID_COMMAND:
IDPRINTF(2, ("%s: mbox cmd %x fails with INVALID_COMMAND\n",
IDPRINTF(2, ("%s: mbox cmd %x failed with INVALID_COMMAND\n",
isp->isp_name, opcode));
break;
case MBOX_HOST_INTERFACE_ERROR:
IDPRINTF(2, ("%s: mbox cmd %x fails with HOST_INTERFACE_ERR\n",
isp->isp_name, opcode));
PRINTF("%s: mbox cmd %x failed with HOST_INTERFACE_ERROR\n",
isp->isp_name, opcode);
break;
case MBOX_TEST_FAILED:
IDPRINTF(2, ("%s: mbox cmd %x fails with TEST_FAILED\n",
isp->isp_name, opcode));
PRINTF("%s: mbox cmd %x failed with TEST_FAILED\n",
isp->isp_name, opcode);
break;
case MBOX_COMMAND_ERROR:
IDPRINTF(2, ("%s: mbox cmd %x fails with COMMAND_ERROR\n",
isp->isp_name, opcode));
if (opcode != MBOX_ABOUT_FIRMWARE)
PRINTF("%s: mbox cmd %x failed with COMMAND_ERROR\n",
isp->isp_name, opcode);
break;
case MBOX_COMMAND_PARAM_ERROR:
IDPRINTF(2, ("%s: mbox cmd %x fails with COMMAND_PARAM_ERROR\n",
isp->isp_name, opcode));
switch (opcode) {
case MBOX_GET_PORT_DB:
case MBOX_GET_PORT_NAME:
case MBOX_GET_DEV_QUEUE_PARAMS:
break;
default:
PRINTF("%s: mbox cmd %x failed with "
"COMMAND_PARAM_ERROR\n", isp->isp_name, opcode);
}
break;
/*
@ -3374,8 +3373,10 @@ command_known:
((fcparam *) isp->isp_param)->isp_loopstate = LOOP_PDB_RCVD;
break;
case ASYNC_LOOP_UP:
case ASYNC_LIP_OCCURRED:
((fcparam *) isp->isp_param)->isp_lipseq = mbp->param[1];
/* FALLTHROUGH */
case ASYNC_LOOP_UP:
((fcparam *) isp->isp_param)->isp_fwstate = FW_CONFIG_WAIT;
((fcparam *) isp->isp_param)->isp_loopstate = LOOP_LIP_RCVD;
break;
@ -3496,8 +3497,10 @@ again:
fcp->isp_fwstate = FW_CONFIG_WAIT;
fcp->isp_loopstate = LOOP_PDB_RCVD;
goto again;
case ASYNC_LOOP_UP:
case ASYNC_LIP_OCCURRED:
fcp->isp_lipseq = mbs.param[1];
/* FALLTHROUGH */
case ASYNC_LOOP_UP:
fcp->isp_fwstate = FW_CONFIG_WAIT;
fcp->isp_loopstate = LOOP_LIP_RCVD;
if (once++ < 10) {