diff options
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/ic/qlw.c | 43 | ||||
-rw-r--r-- | sys/dev/ic/qlwreg.h | 7 | ||||
-rw-r--r-- | sys/dev/ic/qlwvar.h | 4 |
3 files changed, 18 insertions, 36 deletions
diff --git a/sys/dev/ic/qlw.c b/sys/dev/ic/qlw.c index 3c956925003..c2f2217d218 100644 --- a/sys/dev/ic/qlw.c +++ b/sys/dev/ic/qlw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: qlw.c,v 1.7 2014/03/08 16:34:29 kettenis Exp $ */ +/* $OpenBSD: qlw.c,v 1.8 2014/03/08 16:56:29 kettenis Exp $ */ /* * Copyright (c) 2011 David Gwynne <dlg@openbsd.org> @@ -234,28 +234,10 @@ qlw_attach(struct qlw_softc *sc) if (sc->sc_isp_config & QLW_BURST_ENABLE) qlw_dma_burst_enable(sc); -#if 0 - /* set SCSI termination */ - qlw_write(sc, QLW_GPIO_ENABLE, 0x8f); - qlw_write(sc, QLW_GPIO_DATA, sc->sc_nvram.termination); -#endif - -#if 0 - sc->sc_mbox[0] = QLW_MBOX_SET_SYSTEM_PARAMETER; - sc->sc_mbox[1] = sc->sc_nvram.isp_parameter; - if (qlw_mbox(sc, 0x0003, 0x0001)) { - printf("couldn't set system parameter: %x\n", sc->sc_mbox[0]); - return (ENXIO); - } -#endif - sc->sc_mbox[0] = QLW_MBOX_SET_FIRMWARE_FEATURES; -#if 0 - sc->sc_mbox[1] = letoh16(sc->sc_nvram.fw_options); -#else - sc->sc_mbox[1] = 0x000a; - sc->sc_mbox[1] = 0x0002; -#endif + sc->sc_mbox[1] = 0; + if (sc->sc_fw_features & QLW_FW_FEATURE_LVD_NOTIFY) + sc->sc_mbox[1] |= QLW_FW_FEATURE_LVD_NOTIFY; if (qlw_mbox(sc, 0x0003, 0x0001)) { printf("couldn't set firmware features: %x\n", sc->sc_mbox[0]); return (ENXIO); @@ -296,18 +278,9 @@ qlw_attach(struct qlw_softc *sc) return (ENXIO); } -#if 0 - sc->sc_mbox[0] = QLW_MBOX_SET_DATA_OVERRUN_RECOVERY; - sc->sc_mbox[1] = 2; - if (qlw_mbox(sc, 0x0003, 0x0001)) { - printf("couldn't set data overrun recovery: %x\n", sc->sc_mbox[0]); - return (ENXIO); - } -#endif - sc->sc_mbox[0] = QLW_MBOX_SET_TAG_AGE_LIMIT; - sc->sc_mbox[1] = 8; - sc->sc_mbox[2] = 8; + sc->sc_mbox[1] = sc->sc_tag_age_limit[0]; + sc->sc_mbox[2] = sc->sc_tag_age_limit[1]; if (qlw_mbox(sc, 0x0007, 0x0001)) { printf("couldn't set tag age limit: %x\n", sc->sc_mbox[0]); return (ENXIO); @@ -1454,6 +1427,7 @@ qlw_parse_nvram_1040(struct qlw_softc *sc, int bus) sc->sc_retry_count[0] = nv->retry_count; sc->sc_retry_delay[0] = nv->retry_delay; sc->sc_reset_delay[0] = nv->reset_delay; + sc->sc_tag_age_limit[0] = nv->tag_age_limit; sc->sc_selection_timeout[0] = letoh16(nv->selection_timeout); sc->sc_max_queue_depth[0] = letoh16(nv->max_queue_depth); sc->sc_async_data_setup[0] = (nv->config2 & 0x0f); @@ -1478,6 +1452,7 @@ qlw_parse_nvram_1080(struct qlw_softc *sc, int bus) int target; sc->sc_isp_config = nvram->isp_config; + sc->sc_fw_features = nvram->fw_features; if (!ISSET(sc->sc_flags, QLW_FLAG_INITIATOR)) sc->sc_initiator[bus] = (nv->config1 & 0x0f); @@ -1516,12 +1491,14 @@ qlw_init_defaults(struct qlw_softc *sc, int bus) case QLW_GEN_ISP1080: case QLW_GEN_ISP12160: sc->sc_isp_config = QLW_BURST_ENABLE | QLW_PCI_FIFO_128; + sc->sc_fw_features = QLW_FW_FEATURE_LVD_NOTIFY; break; } sc->sc_retry_count[bus] = 0; sc->sc_retry_delay[bus] = 0; sc->sc_reset_delay[bus] = 3; + sc->sc_tag_age_limit[bus] = 8; sc->sc_selection_timeout[bus] = 250; sc->sc_max_queue_depth[bus] = 32; if (sc->sc_clock > 40) diff --git a/sys/dev/ic/qlwreg.h b/sys/dev/ic/qlwreg.h index a84b54c11b2..33b00711144 100644 --- a/sys/dev/ic/qlwreg.h +++ b/sys/dev/ic/qlwreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: qlwreg.h,v 1.2 2014/03/08 15:13:12 kettenis Exp $ */ +/* $OpenBSD: qlwreg.h,v 1.3 2014/03/08 16:56:29 kettenis Exp $ */ /* * Copyright (c) 2013, 2014 Jonathan Matthew <jmatthew@openbsd.org> @@ -141,6 +141,9 @@ #define QLW_MBOX_ABOUT_FIRMWARE_OUT 0x004f #define QLW_MBOX_INIT_FIRMWARE_IN 0x00fd +#define QLW_FW_FEATURE_FAST_POSTING 0x0001 +#define QLW_FW_FEATURE_LVD_NOTIFY 0x0002 + /* nvram layout */ struct qlw_nvram_target { u_int8_t parameter; @@ -193,7 +196,7 @@ struct qlw_nvram_1080 { u_int8_t isp_config; u_int8_t termination; u_int16_t isp_parameter; - u_int16_t fw_options; + u_int16_t fw_features; u_int16_t reserved_1; struct qlw_nvram_bus bus[2]; u_int8_t reserved_2[2]; diff --git a/sys/dev/ic/qlwvar.h b/sys/dev/ic/qlwvar.h index 7ce708d6229..882e5df32ff 100644 --- a/sys/dev/ic/qlwvar.h +++ b/sys/dev/ic/qlwvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: qlwvar.h,v 1.6 2014/03/08 15:13:12 kettenis Exp $ */ +/* $OpenBSD: qlwvar.h,v 1.7 2014/03/08 16:56:29 kettenis Exp $ */ /* * Copyright (c) 2013, 2014 Jonathan Matthew <jmatthew@openbsd.org> @@ -121,11 +121,13 @@ struct qlw_softc { int sc_nvram_minversion; u_int16_t sc_isp_config; + u_int16_t sc_fw_features; u_int8_t sc_initiator[2]; u_int8_t sc_retry_count[2]; u_int8_t sc_retry_delay[2]; u_int8_t sc_reset_delay[2]; + u_int8_t sc_tag_age_limit[2]; u_int16_t sc_selection_timeout[2]; u_int16_t sc_max_queue_depth[2]; u_int8_t sc_async_data_setup[2]; |