diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2014-03-15 13:08:53 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2014-03-15 13:08:53 +0000 |
commit | c21f43c2774fc089e91ae1bb2e11ece956417b7c (patch) | |
tree | 947df3abca9b78262cb55d2b2e9d4365ca0c78b6 | |
parent | 5812f75c6c47c929c934283ecea3828bb21236d9 (diff) |
More ISP1000 (SBus) bits.
-rw-r--r-- | sys/dev/ic/qlw.c | 32 | ||||
-rw-r--r-- | sys/dev/ic/qlwreg.h | 23 | ||||
-rw-r--r-- | sys/dev/ic/qlwvar.h | 10 | ||||
-rw-r--r-- | sys/dev/pci/qlw_pci.c | 7 |
4 files changed, 54 insertions, 18 deletions
diff --git a/sys/dev/ic/qlw.c b/sys/dev/ic/qlw.c index be14288375d..35d5eabd78c 100644 --- a/sys/dev/ic/qlw.c +++ b/sys/dev/ic/qlw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: qlw.c,v 1.15 2014/03/15 12:28:47 kettenis Exp $ */ +/* $OpenBSD: qlw.c,v 1.16 2014/03/15 13:08:52 kettenis Exp $ */ /* * Copyright (c) 2011 David Gwynne <dlg@openbsd.org> @@ -123,8 +123,17 @@ qlw_xs_bus(struct qlw_softc *sc, struct scsi_xfer *xs) return ((xs->sc_link->scsibus == sc->sc_link[0].scsibus) ? 0 : 1); } -#define qlw_queue_read(_sc, _r) qlw_read((_sc), (_r)) -#define qlw_queue_write(_sc, _r, _v) qlw_write((_sc), (_r), (_v)) +static inline u_int16_t +qlw_queue_read(struct qlw_softc *sc, bus_size_t offset) +{ + return qlw_read(sc, sc->sc_mbox_base + offset); +} + +static inline void +qlw_queue_write(struct qlw_softc *sc, bus_size_t offset, u_int16_t value) +{ + qlw_write(sc, sc->sc_mbox_base + offset, value); +} struct scsi_adapter qlw_switch = { qlw_scsi_cmd, @@ -145,6 +154,9 @@ qlw_attach(struct qlw_softc *sc) task_set(&sc->sc_update_task, qlw_update_task, sc, NULL); switch (sc->sc_isp_gen) { + case QLW_GEN_ISP1000: + sc->sc_nvram_size = 0; + break; case QLW_GEN_ISP1040: sc->sc_nvram_size = 128; sc->sc_nvram_minversion = 2; @@ -940,19 +952,19 @@ u_int16_t qlw_read_mbox(struct qlw_softc *sc, int mbox) { /* could range-check mboxes according to chip type? */ - return (qlw_read(sc, QLW_MBOX_BASE + (mbox * 2))); + return (qlw_read(sc, sc->sc_mbox_base + (mbox * 2))); } void qlw_write_mbox(struct qlw_softc *sc, int mbox, u_int16_t value) { - qlw_write(sc, QLW_MBOX_BASE + (mbox * 2), value); + qlw_write(sc, sc->sc_mbox_base + (mbox * 2), value); } void qlw_host_cmd(struct qlw_softc *sc, u_int16_t cmd) { - qlw_write(sc, QLW_HOST_CMD_CTRL, cmd << QLW_HOST_CMD_SHIFT); + qlw_write(sc, sc->sc_host_cmd_ctrl, cmd << QLW_HOST_CMD_SHIFT); } #define MBOX_COMMAND_TIMEOUT 4000 @@ -1131,7 +1143,8 @@ qlw_softreset(struct qlw_softc *sc) void qlw_dma_burst_enable(struct qlw_softc *sc) { - if (sc->sc_isp_gen == QLW_GEN_ISP1040) { + if (sc->sc_isp_gen == QLW_GEN_ISP1000 || + sc->sc_isp_gen == QLW_GEN_ISP1040) { qlw_write(sc, QLW_CDMA_CFG, qlw_read(sc, QLW_CDMA_CFG) | QLW_DMA_BURST_ENABLE); qlw_write(sc, QLW_DDMA_CFG, @@ -1384,6 +1397,9 @@ qlw_read_nvram(struct qlw_softc *sc) int reqcmd; int nbits; + if (sc->sc_nvram_size == 0) + return (1); + if (sc->sc_nvram_size == 128) { reqcmd = (QLW_NVRAM_CMD_READ << 6); nbits = 8; @@ -1532,6 +1548,8 @@ qlw_init_defaults(struct qlw_softc *sc, int bus) int target; switch (sc->sc_isp_gen) { + case QLW_GEN_ISP1000: + break; case QLW_GEN_ISP1040: sc->sc_isp_config = QLW_BURST_ENABLE | QLW_PCI_FIFO_64; break; diff --git a/sys/dev/ic/qlwreg.h b/sys/dev/ic/qlwreg.h index 07d78c0ff0d..b3602dbb139 100644 --- a/sys/dev/ic/qlwreg.h +++ b/sys/dev/ic/qlwreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: qlwreg.h,v 1.5 2014/03/15 12:28:47 kettenis Exp $ */ +/* $OpenBSD: qlwreg.h,v 1.6 2014/03/15 13:08:52 kettenis Exp $ */ /* * Copyright (c) 2013, 2014 Jonathan Matthew <jmatthew@openbsd.org> @@ -37,17 +37,20 @@ #define QLW_FLASH_BIOS_ADDR 0x12 #define QLW_CDMA_CFG 0x20 #define QLW_DDMA_CFG 0x40 -#define QLW_MBOX_BASE 0x70 +#define QLW_MBOX_BASE_PCI 0x70 +#define QLW_MBOX_BASE_SBUS 0x80 #define QLW_CDMA_CFG_1080 0x80 #define QLW_DDMA_CFG_1080 0xa0 -#define QLW_HOST_CMD_CTRL 0xc0 +#define QLW_HOST_CMD_CTRL_PCI 0xc0 #define QLW_GPIO_DATA 0xcc #define QLW_GPIO_ENABLE 0xce -#define QLW_REQ_IN QLW_MBOX_BASE + 0x8 -#define QLW_REQ_OUT QLW_MBOX_BASE + 0x8 -#define QLW_RESP_IN QLW_MBOX_BASE + 0xa -#define QLW_RESP_OUT QLW_MBOX_BASE + 0xa +#define QLW_HOST_CMD_CTRL_SBUS 0x440 + +#define QLW_REQ_IN 0x08 +#define QLW_REQ_OUT 0x08 +#define QLW_RESP_IN 0x0a +#define QLW_RESP_OUT 0x0a /* QLW_CFG1 */ #define QLW_BURST_ENABLE 0x0004 @@ -56,6 +59,12 @@ #define QLW_PCI_FIFO_64 0x0030 #define QLW_PCI_FIFO_128 0x0040 #define QLW_PCI_FIFO_MASK 0x0070 +#define QLW_SBUS_FIFO_64 0x0003 +#define QLW_SBUS_FIFO_32 0x0002 +#define QLW_SBUS_FIFO_16 0x0001 +#define QLW_SBUS_FIFO_8 0x0000 +#define QLW_SBUS_FIFO_MASK 0x0003 +#define QLW_SBUS_BURST_8 0x0008 #define QLW_DMA_BANK 0x0300 /* QLW_INT_CTRL */ diff --git a/sys/dev/ic/qlwvar.h b/sys/dev/ic/qlwvar.h index beefc58ba9d..6c6c3aab21a 100644 --- a/sys/dev/ic/qlwvar.h +++ b/sys/dev/ic/qlwvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: qlwvar.h,v 1.9 2014/03/13 10:31:53 kettenis Exp $ */ +/* $OpenBSD: qlwvar.h,v 1.10 2014/03/15 13:08:52 kettenis Exp $ */ /* * Copyright (c) 2013, 2014 Jonathan Matthew <jmatthew@openbsd.org> @@ -28,13 +28,15 @@ struct qlw_softc; enum qlw_isp_gen { - QLW_GEN_ISP1040 = 1, + QLW_GEN_ISP1000 = 1, + QLW_GEN_ISP1040, QLW_GEN_ISP1080, QLW_GEN_ISP12160, }; enum qlw_isp_type { - QLW_ISP1020 = 1, + QLW_ISP1000 = 1, + QLW_ISP1020, QLW_ISP1020A, QLW_ISP1040, QLW_ISP1040A, @@ -101,6 +103,8 @@ struct qlw_softc { int sc_numbusses; int sc_clock; + int sc_host_cmd_ctrl; + int sc_mbox_base; u_int16_t sc_mbox[8]; int sc_mbox_pending; diff --git a/sys/dev/pci/qlw_pci.c b/sys/dev/pci/qlw_pci.c index ab7fad86781..ef15e7c81df 100644 --- a/sys/dev/pci/qlw_pci.c +++ b/sys/dev/pci/qlw_pci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: qlw_pci.c,v 1.8 2014/03/09 20:23:43 kettenis Exp $ */ +/* $OpenBSD: qlw_pci.c,v 1.9 2014/03/15 13:08:52 kettenis Exp $ */ /* * Copyright (c) 2011 David Gwynne <dlg@openbsd.org> @@ -249,6 +249,8 @@ qlw_pci_attach(struct device *parent, struct device *self, void *aux) case QLW_GEN_ISP12160: sc->sc_firmware = isp_12160_risc_code; break; + default: + break; } #endif @@ -285,6 +287,9 @@ qlw_pci_attach(struct device *parent, struct device *self, void *aux) } #endif + sc->sc_host_cmd_ctrl = QLW_HOST_CMD_CTRL_PCI; + sc->sc_mbox_base = QLW_MBOX_BASE_PCI; + if (qlw_attach(sc) != 0) { /* error printed by qlw_attach */ goto deintr; |