aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/bnx2x
diff options
context:
space:
mode:
authorDmitry Kravkov <dmitry@broadcom.com>2011-03-31 20:04:01 -0400
committerDavid S. Miller <davem@davemloft.net>2011-03-31 20:04:01 -0400
commit3b7f817e47bb66ae4d82ed73689a521af70a5410 (patch)
tree008296eafee09f5001a0ea9812f27a88dc297db5 /drivers/net/bnx2x
parent96b8e1a0e96bd30ffb07e739b29b8c4c5759b93f (diff)
bnx2x: don't write dcb/llfc fields in STORM memory
We could get hardware attention during DCB/FCoE traffic without this fix. Signed-off-by: Dmitry Kravkov <dmitry@broadcom.com> Signed-off-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/bnx2x')
-rw-r--r--drivers/net/bnx2x/bnx2x_cmn.h13
1 files changed, 12 insertions, 1 deletions
diff --git a/drivers/net/bnx2x/bnx2x_cmn.h b/drivers/net/bnx2x/bnx2x_cmn.h
index ef37b98d614..775fef031ad 100644
--- a/drivers/net/bnx2x/bnx2x_cmn.h
+++ b/drivers/net/bnx2x/bnx2x_cmn.h
@@ -1041,12 +1041,23 @@ static inline void storm_memset_cmng(struct bnx2x *bp,
1041 struct cmng_struct_per_port *cmng, 1041 struct cmng_struct_per_port *cmng,
1042 u8 port) 1042 u8 port)
1043{ 1043{
1044 size_t size = sizeof(struct cmng_struct_per_port); 1044 size_t size =
1045 sizeof(struct rate_shaping_vars_per_port) +
1046 sizeof(struct fairness_vars_per_port) +
1047 sizeof(struct safc_struct_per_port) +
1048 sizeof(struct pfc_struct_per_port);
1045 1049
1046 u32 addr = BAR_XSTRORM_INTMEM + 1050 u32 addr = BAR_XSTRORM_INTMEM +
1047 XSTORM_CMNG_PER_PORT_VARS_OFFSET(port); 1051 XSTORM_CMNG_PER_PORT_VARS_OFFSET(port);
1048 1052
1049 __storm_memset_struct(bp, addr, size, (u32 *)cmng); 1053 __storm_memset_struct(bp, addr, size, (u32 *)cmng);
1054
1055 addr += size + 4 /* SKIP DCB+LLFC */;
1056 size = sizeof(struct cmng_struct_per_port) -
1057 size /* written */ - 4 /*skipped*/;
1058
1059 __storm_memset_struct(bp, addr, size,
1060 (u32 *)(cmng->traffic_type_to_priority_cos));
1050} 1061}
1051 1062
1052/* HW Lock for shared dual port PHYs */ 1063/* HW Lock for shared dual port PHYs */