aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordave graham <david.graham@intel.com>2009-02-10 07:51:41 -0500
committerDavid S. Miller <davem@davemloft.net>2009-02-10 20:00:27 -0500
commit5df3f0eaf8b236cc785e2733a3df1e5c84e4aad8 (patch)
tree2a1839f02ef900c5bcbfd789c88839fed1f436fb
parent111b9dc5c981ba608b4afede37237cfeb67b07f2 (diff)
e1000e: Disable dynamic clock gating for 82571 per si errata.
82571 and 82572 Errata #13 documents that the Si feature DMA Dynamic Clock Gating should be disabled, and identifies the workaround of disabling the feature by EEPROM setting. EEPROM versions that do not include the recommended workaround have been found in the field, and so some customers remain at risk. Because the feature DMA Dynamic clock Gating can be disabled by directly setting the appropriate bit in the E1000_CTRL_EXT register, this patch overrides the EEPROM setting, and force-disables the feature. Signed-off-by: dave graham <david.graham@intel.com> Acked-by: Bruce Allan <bruce.w.allan@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/e1000e/82571.c12
-rw-r--r--drivers/net/e1000e/defines.h1
2 files changed, 13 insertions, 0 deletions
diff --git a/drivers/net/e1000e/82571.c b/drivers/net/e1000e/82571.c
index 0890162953e9..25f6bc94e69b 100644
--- a/drivers/net/e1000e/82571.c
+++ b/drivers/net/e1000e/82571.c
@@ -980,6 +980,18 @@ static void e1000_initialize_hw_bits_82571(struct e1000_hw *hw)
980 reg |= E1000_PBA_ECC_CORR_EN; 980 reg |= E1000_PBA_ECC_CORR_EN;
981 ew32(PBA_ECC, reg); 981 ew32(PBA_ECC, reg);
982 } 982 }
983 /*
984 * Workaround for hardware errata.
985 * Ensure that DMA Dynamic Clock gating is disabled on 82571 and 82572
986 */
987
988 if ((hw->mac.type == e1000_82571) ||
989 (hw->mac.type == e1000_82572)) {
990 reg = er32(CTRL_EXT);
991 reg &= ~E1000_CTRL_EXT_DMA_DYN_CLK_EN;
992 ew32(CTRL_EXT, reg);
993 }
994
983 995
984 /* PCI-Ex Control Registers */ 996 /* PCI-Ex Control Registers */
985 if (hw->mac.type == e1000_82574) { 997 if (hw->mac.type == e1000_82574) {
diff --git a/drivers/net/e1000e/defines.h b/drivers/net/e1000e/defines.h
index e6caf29d4252..243aa499fe90 100644
--- a/drivers/net/e1000e/defines.h
+++ b/drivers/net/e1000e/defines.h
@@ -69,6 +69,7 @@
69#define E1000_CTRL_EXT_SDP7_DATA 0x00000080 /* Value of SW Definable Pin 7 */ 69#define E1000_CTRL_EXT_SDP7_DATA 0x00000080 /* Value of SW Definable Pin 7 */
70#define E1000_CTRL_EXT_EE_RST 0x00002000 /* Reinitialize from EEPROM */ 70#define E1000_CTRL_EXT_EE_RST 0x00002000 /* Reinitialize from EEPROM */
71#define E1000_CTRL_EXT_RO_DIS 0x00020000 /* Relaxed Ordering disable */ 71#define E1000_CTRL_EXT_RO_DIS 0x00020000 /* Relaxed Ordering disable */
72#define E1000_CTRL_EXT_DMA_DYN_CLK_EN 0x00080000 /* DMA Dynamic Clock Gating */
72#define E1000_CTRL_EXT_LINK_MODE_MASK 0x00C00000 73#define E1000_CTRL_EXT_LINK_MODE_MASK 0x00C00000
73#define E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES 0x00C00000 74#define E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES 0x00C00000
74#define E1000_CTRL_EXT_EIAME 0x01000000 75#define E1000_CTRL_EXT_EIAME 0x01000000