aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ixgbe/ixgbe_82599.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/ixgbe/ixgbe_82599.c')
-rw-r--r--drivers/net/ixgbe/ixgbe_82599.c24
1 files changed, 16 insertions, 8 deletions
diff --git a/drivers/net/ixgbe/ixgbe_82599.c b/drivers/net/ixgbe/ixgbe_82599.c
index 9a9998985004..72a0d27a19af 100644
--- a/drivers/net/ixgbe/ixgbe_82599.c
+++ b/drivers/net/ixgbe/ixgbe_82599.c
@@ -102,6 +102,9 @@ s32 ixgbe_setup_sfp_modules_82599(struct ixgbe_hw *hw)
102 102
103 if (hw->phy.sfp_type != ixgbe_sfp_type_unknown) { 103 if (hw->phy.sfp_type != ixgbe_sfp_type_unknown) {
104 ixgbe_init_mac_link_ops_82599(hw); 104 ixgbe_init_mac_link_ops_82599(hw);
105
106 hw->phy.ops.reset = NULL;
107
105 ret_val = ixgbe_get_sfp_init_sequence_offsets(hw, &list_offset, 108 ret_val = ixgbe_get_sfp_init_sequence_offsets(hw, &list_offset,
106 &data_offset); 109 &data_offset);
107 110
@@ -716,19 +719,24 @@ s32 ixgbe_reset_hw_82599(struct ixgbe_hw *hw)
716 /* Call adapter stop to disable tx/rx and clear interrupts */ 719 /* Call adapter stop to disable tx/rx and clear interrupts */
717 hw->mac.ops.stop_adapter(hw); 720 hw->mac.ops.stop_adapter(hw);
718 721
719 /* Reset PHY */ 722 /* PHY ops must be identified and initialized prior to reset */
720 if (hw->phy.reset_disable == false) {
721 /* PHY ops must be identified and initialized prior to reset */
722 723
723 /* Init PHY and function pointers, perform SFP setup */ 724 /* Init PHY and function pointers, perform SFP setup */
724 status = hw->phy.ops.init(hw); 725 status = hw->phy.ops.init(hw);
725 726
726 if (status == IXGBE_ERR_SFP_NOT_SUPPORTED) 727 if (status == IXGBE_ERR_SFP_NOT_SUPPORTED)
727 goto reset_hw_out; 728 goto reset_hw_out;
728 729
729 hw->phy.ops.reset(hw); 730 /* Setup SFP module if there is one present. */
731 if (hw->phy.sfp_setup_needed) {
732 status = hw->mac.ops.setup_sfp(hw);
733 hw->phy.sfp_setup_needed = false;
730 } 734 }
731 735
736 /* Reset PHY */
737 if (hw->phy.reset_disable == false && hw->phy.ops.reset != NULL)
738 hw->phy.ops.reset(hw);
739
732 /* 740 /*
733 * Prevent the PCI-E bus from from hanging by disabling PCI-E master 741 * Prevent the PCI-E bus from from hanging by disabling PCI-E master
734 * access and verify no pending requests before reset 742 * access and verify no pending requests before reset