Commit bcb3244c authored by Sasha Neftin's avatar Sasha Neftin Committed by Jeff Kirsher

igc: Add PHY power management control

PHY power management control should provide a reliable and accurate
indication of PHY reset completion and decrease the delay time
after a PHY reset
Signed-off-by: default avatarSasha Neftin <sasha.neftin@intel.com>
Tested-by: default avatarAaron Brown <aaron.f.brown@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent f38b782d
...@@ -464,6 +464,7 @@ ...@@ -464,6 +464,7 @@
/* PHY Status Register */ /* PHY Status Register */
#define MII_SR_LINK_STATUS 0x0004 /* Link Status 1 = link */ #define MII_SR_LINK_STATUS 0x0004 /* Link Status 1 = link */
#define MII_SR_AUTONEG_COMPLETE 0x0020 /* Auto Neg Complete */ #define MII_SR_AUTONEG_COMPLETE 0x0020 /* Auto Neg Complete */
#define IGC_PHY_RST_COMP 0x0100 /* Internal PHY reset completion */
/* PHY 1000 MII Register/Bit Definitions */ /* PHY 1000 MII Register/Bit Definitions */
/* PHY Registers defined by IEEE */ /* PHY Registers defined by IEEE */
......
...@@ -173,6 +173,7 @@ s32 igc_check_downshift(struct igc_hw *hw) ...@@ -173,6 +173,7 @@ s32 igc_check_downshift(struct igc_hw *hw)
s32 igc_phy_hw_reset(struct igc_hw *hw) s32 igc_phy_hw_reset(struct igc_hw *hw)
{ {
struct igc_phy_info *phy = &hw->phy; struct igc_phy_info *phy = &hw->phy;
u32 phpm = 0, timeout = 10000;
s32 ret_val; s32 ret_val;
u32 ctrl; u32 ctrl;
...@@ -186,6 +187,8 @@ s32 igc_phy_hw_reset(struct igc_hw *hw) ...@@ -186,6 +187,8 @@ s32 igc_phy_hw_reset(struct igc_hw *hw)
if (ret_val) if (ret_val)
goto out; goto out;
phpm = rd32(IGC_I225_PHPM);
ctrl = rd32(IGC_CTRL); ctrl = rd32(IGC_CTRL);
wr32(IGC_CTRL, ctrl | IGC_CTRL_PHY_RST); wr32(IGC_CTRL, ctrl | IGC_CTRL_PHY_RST);
wrfl(); wrfl();
...@@ -195,7 +198,18 @@ s32 igc_phy_hw_reset(struct igc_hw *hw) ...@@ -195,7 +198,18 @@ s32 igc_phy_hw_reset(struct igc_hw *hw)
wr32(IGC_CTRL, ctrl); wr32(IGC_CTRL, ctrl);
wrfl(); wrfl();
usleep_range(1500, 2000); /* SW should guarantee 100us for the completion of the PHY reset */
usleep_range(100, 150);
do {
phpm = rd32(IGC_I225_PHPM);
timeout--;
udelay(1);
} while (!(phpm & IGC_PHY_RST_COMP) && timeout);
if (!timeout)
hw_dbg("Timeout is expired after a phy reset\n");
usleep_range(100, 150);
phy->ops.release(hw); phy->ops.release(hw);
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
#define IGC_MDIC 0x00020 /* MDI Control - RW */ #define IGC_MDIC 0x00020 /* MDI Control - RW */
#define IGC_MDICNFG 0x00E04 /* MDC/MDIO Configuration - RW */ #define IGC_MDICNFG 0x00E04 /* MDC/MDIO Configuration - RW */
#define IGC_CONNSW 0x00034 /* Copper/Fiber switch control - RW */ #define IGC_CONNSW 0x00034 /* Copper/Fiber switch control - RW */
#define IGC_I225_PHPM 0x00E14 /* I225 PHY Power Management */
/* Internal Packet Buffer Size Registers */ /* Internal Packet Buffer Size Registers */
#define IGC_RXPBS 0x02404 /* Rx Packet Buffer Size - RW */ #define IGC_RXPBS 0x02404 /* Rx Packet Buffer Size - RW */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment