diff options
author | mjacob <mjacob@FreeBSD.org> | 2002-08-17 17:23:15 +0000 |
---|---|---|
committer | mjacob <mjacob@FreeBSD.org> | 2002-08-17 17:23:15 +0000 |
commit | 9e1cfa1b261671432fafe791503bd193d89c8438 (patch) | |
tree | 7fa14beeb04ddaee6b9382672616c2a4393dd1b3 /sys/dev/isp | |
parent | 4b94fc7cec90e6c9a59c2e98c481e8d40b185268 (diff) | |
download | FreeBSD-src-9e1cfa1b261671432fafe791503bd193d89c8438.zip FreeBSD-src-9e1cfa1b261671432fafe791503bd193d89c8438.tar.gz |
We only do isp_reinit from isp_async if ISP_FW_CRASH_DUMP is defined-
otherwise the core code does this.
Diffstat (limited to 'sys/dev/isp')
-rw-r--r-- | sys/dev/isp/isp_freebsd.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/sys/dev/isp/isp_freebsd.c b/sys/dev/isp/isp_freebsd.c index 25d5976..b6580dc 100644 --- a/sys/dev/isp/isp_freebsd.c +++ b/sys/dev/isp/isp_freebsd.c @@ -3040,7 +3040,19 @@ isp_async(struct ispsoftc *isp, ispasync_t cmd, void *arg) isp_prt(isp, ISP_LOGERR, "Internal Firmware Error on bus %d @ RISC Address 0x%x", mbox6, mbox1); +#ifdef ISP_FW_CRASH_DUMP + /* + * XXX: really need a thread to do this right. + */ + if (IS_FC(isp)) { + FCPARAM(isp)->isp_fwstate = FW_CONFIG_WAIT; + FCPARAM(isp)->isp_loopstate = LOOP_NIL; + isp_freeze_loopdown(isp, "f/w crash"); + isp_fw_dump(isp); + } isp_reinit(isp); + isp_async(isp, ISPASYNC_FW_RESTARTED, NULL); +#endif break; } case ISPASYNC_UNHANDLED_RESPONSE: |