summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2015-11-13 19:33:13 +0000
committermav <mav@FreeBSD.org>2015-11-13 19:33:13 +0000
commit67908f731a92cadc30781fe96e0afcd0e5957402 (patch)
tree67d34446e71998bbd8e68c48d13c911005e3676d
parentc10b89e1bc5ae585128e879990e8465ee932cdff (diff)
downloadFreeBSD-src-67908f731a92cadc30781fe96e0afcd0e5957402.zip
FreeBSD-src-67908f731a92cadc30781fe96e0afcd0e5957402.tar.gz
MFC r289620: Decode more firmware attributes.
-rw-r--r--sys/dev/isp/isp.c57
-rw-r--r--sys/dev/isp/ispmbox.h12
2 files changed, 67 insertions, 2 deletions
diff --git a/sys/dev/isp/isp.c b/sys/dev/isp/isp.c
index 9e8e29b..2b8f2ce 100644
--- a/sys/dev/isp/isp.c
+++ b/sys/dev/isp/isp.c
@@ -1090,8 +1090,13 @@ isp_reset(ispsoftc_t *isp, int do_load_defaults)
} else {
isp->isp_fwattr = mbs.param[6];
}
- if (IS_24XX(isp) && (isp->isp_fwattr & ISP2400_FW_ATTR_EXTNDED)) {
- isp->isp_fwattr |= (((uint64_t) mbs.param[15]) << 16) | (((uint64_t) mbs.param[16]) << 32) | (((uint64_t) mbs.param[17]) << 48);
+ if (IS_24XX(isp)) {
+ isp->isp_fwattr |= ((uint64_t) mbs.param[15]) << 16;
+ if (isp->isp_fwattr & ISP2400_FW_ATTR_EXTNDED) {
+ isp->isp_fwattr |=
+ (((uint64_t) mbs.param[16]) << 32) |
+ (((uint64_t) mbs.param[17]) << 48);
+ }
}
} else if (IS_SCSI(isp)) {
#ifndef ISP_TARGET_MODE
@@ -1132,6 +1137,18 @@ isp_reset(ispsoftc_t *isp, int do_load_defaults)
fwt ^=ISP2400_FW_ATTR_VI;
ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s VI", buf);
}
+ if (fwt & ISP2400_FW_ATTR_MQ) {
+ fwt ^=ISP2400_FW_ATTR_MQ;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s MQ", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_MSIX) {
+ fwt ^=ISP2400_FW_ATTR_MSIX;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s MSIX", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_FCOE) {
+ fwt ^=ISP2400_FW_ATTR_FCOE;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s FCOE", buf);
+ }
if (fwt & ISP2400_FW_ATTR_VP0) {
fwt ^= ISP2400_FW_ATTR_VP0;
ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s VP0_Decoupling", buf);
@@ -1140,7 +1157,43 @@ isp_reset(ispsoftc_t *isp, int do_load_defaults)
fwt ^= ISP2400_FW_ATTR_EXPFW;
ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s (Experimental)", buf);
}
+ if (fwt & ISP2400_FW_ATTR_HOTFW) {
+ fwt ^= ISP2400_FW_ATTR_HOTFW;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s HotFW", buf);
+ }
fwt &= ~ISP2400_FW_ATTR_EXTNDED;
+ if (fwt & ISP2400_FW_ATTR_EXTVP) {
+ fwt ^= ISP2400_FW_ATTR_EXTVP;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s ExtVP", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_VN2VN) {
+ fwt ^= ISP2400_FW_ATTR_VN2VN;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s VN2VN", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_EXMOFF) {
+ fwt ^= ISP2400_FW_ATTR_EXMOFF;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s EXMOFF", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_NPMOFF) {
+ fwt ^= ISP2400_FW_ATTR_NPMOFF;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s NPMOFF", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_DIFCHOP) {
+ fwt ^= ISP2400_FW_ATTR_DIFCHOP;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s DIFCHOP", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_SRIOV) {
+ fwt ^= ISP2400_FW_ATTR_SRIOV;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s SRIOV", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_ASICTMP) {
+ fwt ^= ISP2400_FW_ATTR_ASICTMP;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s ASICTMP", buf);
+ }
+ if (fwt & ISP2400_FW_ATTR_ATIOMQ) {
+ fwt ^= ISP2400_FW_ATTR_ATIOMQ;
+ ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s ATIOMQ", buf);
+ }
if (fwt) {
ISP_SNPRINTF(buf, ISP_FC_SCRLEN - strlen(buf), "%s (unknown 0x%08x%08x)", buf,
(uint32_t) (fwt >> 32), (uint32_t) fwt);
diff --git a/sys/dev/isp/ispmbox.h b/sys/dev/isp/ispmbox.h
index d2a29b2..7cb5032 100644
--- a/sys/dev/isp/ispmbox.h
+++ b/sys/dev/isp/ispmbox.h
@@ -820,9 +820,21 @@ typedef struct {
#define ISP2400_FW_ATTR_SB2 0x0008
#define ISP2400_FW_ATTR_T10CRC 0x0010
#define ISP2400_FW_ATTR_VI 0x0020
+#define ISP2400_FW_ATTR_MQ 0x0040
+#define ISP2400_FW_ATTR_MSIX 0x0080
+#define ISP2400_FW_ATTR_FCOE 0x0800
#define ISP2400_FW_ATTR_VP0 0x1000
#define ISP2400_FW_ATTR_EXPFW 0x2000
+#define ISP2400_FW_ATTR_HOTFW 0x4000
#define ISP2400_FW_ATTR_EXTNDED 0x8000
+#define ISP2400_FW_ATTR_EXTVP 0x00010000
+#define ISP2400_FW_ATTR_VN2VN 0x00040000
+#define ISP2400_FW_ATTR_EXMOFF 0x00080000
+#define ISP2400_FW_ATTR_NPMOFF 0x00100000
+#define ISP2400_FW_ATTR_DIFCHOP 0x00400000
+#define ISP2400_FW_ATTR_SRIOV 0x02000000
+#define ISP2400_FW_ATTR_ASICTMP 0x0200000000
+#define ISP2400_FW_ATTR_ATIOMQ 0x0400000000
/*
* These are either manifestly true or are dependent on f/w attributes
OpenPOWER on IntegriCloud