Merge branch 'intel'
Jeff Kirsher says: ==================== This series contains updates to ixgbe and e1000e. The ixgbe patches are a mix of fixes, cleanup and added functionality. The first fix is for traffic classes, where if the mapping has changed reset the NIC. The other ixgbe fix resolves an issue where the device lookup neglected to do a pci_dev_put() to decrement the device reference count. The ixgbe cleanup was done by Josh, where the auto-negotiation variables were renamed/cleaned up and refactored. The remaining patches are from Bruce to do additional cleanup on e1000e as well as bump the driver version. Most notably is the cleanup to use the kernel IEEE MII definitions where possible instead of the local MII definitions. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
daef2262a7
@ -624,16 +624,16 @@ static s32 e1000_phy_force_speed_duplex_80003es2lan(struct e1000_hw *hw)
|
||||
|
||||
e_dbg("GG82563 PSCR: %X\n", phy_data);
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e1000e_phy_force_speed_duplex_setup(hw, &phy_data);
|
||||
|
||||
/* Reset the phy to commit changes. */
|
||||
phy_data |= MII_CR_RESET;
|
||||
phy_data |= BMCR_RESET;
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_data);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1438,18 +1438,18 @@ static const struct e1000_phy_operations es2_phy_ops = {
|
||||
.acquire = e1000_acquire_phy_80003es2lan,
|
||||
.check_polarity = e1000_check_polarity_m88,
|
||||
.check_reset_block = e1000e_check_reset_block_generic,
|
||||
.commit = e1000e_phy_sw_reset,
|
||||
.force_speed_duplex = e1000_phy_force_speed_duplex_80003es2lan,
|
||||
.get_cfg_done = e1000_get_cfg_done_80003es2lan,
|
||||
.get_cable_length = e1000_get_cable_length_80003es2lan,
|
||||
.get_info = e1000e_get_phy_info_m88,
|
||||
.read_reg = e1000_read_phy_reg_gg82563_80003es2lan,
|
||||
.commit = e1000e_phy_sw_reset,
|
||||
.force_speed_duplex = e1000_phy_force_speed_duplex_80003es2lan,
|
||||
.get_cfg_done = e1000_get_cfg_done_80003es2lan,
|
||||
.get_cable_length = e1000_get_cable_length_80003es2lan,
|
||||
.get_info = e1000e_get_phy_info_m88,
|
||||
.read_reg = e1000_read_phy_reg_gg82563_80003es2lan,
|
||||
.release = e1000_release_phy_80003es2lan,
|
||||
.reset = e1000e_phy_hw_reset_generic,
|
||||
.set_d0_lplu_state = NULL,
|
||||
.set_d3_lplu_state = e1000e_set_d3_lplu_state,
|
||||
.write_reg = e1000_write_phy_reg_gg82563_80003es2lan,
|
||||
.cfg_on_link_up = e1000_cfg_on_link_up_80003es2lan,
|
||||
.reset = e1000e_phy_hw_reset_generic,
|
||||
.set_d0_lplu_state = NULL,
|
||||
.set_d3_lplu_state = e1000e_set_d3_lplu_state,
|
||||
.write_reg = e1000_write_phy_reg_gg82563_80003es2lan,
|
||||
.cfg_on_link_up = e1000_cfg_on_link_up_80003es2lan,
|
||||
};
|
||||
|
||||
static const struct e1000_nvm_operations es2_nvm_ops = {
|
||||
|
@ -447,13 +447,13 @@ static s32 e1000_get_phy_id_82571(struct e1000_hw *hw)
|
||||
break;
|
||||
case e1000_82574:
|
||||
case e1000_82583:
|
||||
ret_val = e1e_rphy(hw, PHY_ID1, &phy_id);
|
||||
ret_val = e1e_rphy(hw, MII_PHYSID1, &phy_id);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy->id = (u32)(phy_id << 16);
|
||||
udelay(20);
|
||||
ret_val = e1e_rphy(hw, PHY_ID2, &phy_id);
|
||||
ret_val = e1e_rphy(hw, MII_PHYSID2, &phy_id);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1327,9 +1327,10 @@ static void e1000_clear_vfta_82571(struct e1000_hw *hw)
|
||||
*/
|
||||
vfta_offset = (hw->mng_cookie.vlan_id >>
|
||||
E1000_VFTA_ENTRY_SHIFT) &
|
||||
E1000_VFTA_ENTRY_MASK;
|
||||
vfta_bit_in_reg = 1 << (hw->mng_cookie.vlan_id &
|
||||
E1000_VFTA_ENTRY_BIT_SHIFT_MASK);
|
||||
E1000_VFTA_ENTRY_MASK;
|
||||
vfta_bit_in_reg =
|
||||
1 << (hw->mng_cookie.vlan_id &
|
||||
E1000_VFTA_ENTRY_BIT_SHIFT_MASK);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
@ -1931,7 +1932,7 @@ static const struct e1000_phy_operations e82_phy_ops_igp = {
|
||||
.set_d0_lplu_state = e1000_set_d0_lplu_state_82571,
|
||||
.set_d3_lplu_state = e1000e_set_d3_lplu_state,
|
||||
.write_reg = e1000e_write_phy_reg_igp,
|
||||
.cfg_on_link_up = NULL,
|
||||
.cfg_on_link_up = NULL,
|
||||
};
|
||||
|
||||
static const struct e1000_phy_operations e82_phy_ops_m88 = {
|
||||
@ -1949,7 +1950,7 @@ static const struct e1000_phy_operations e82_phy_ops_m88 = {
|
||||
.set_d0_lplu_state = e1000_set_d0_lplu_state_82571,
|
||||
.set_d3_lplu_state = e1000e_set_d3_lplu_state,
|
||||
.write_reg = e1000e_write_phy_reg_m88,
|
||||
.cfg_on_link_up = NULL,
|
||||
.cfg_on_link_up = NULL,
|
||||
};
|
||||
|
||||
static const struct e1000_phy_operations e82_phy_ops_bm = {
|
||||
@ -1967,7 +1968,7 @@ static const struct e1000_phy_operations e82_phy_ops_bm = {
|
||||
.set_d0_lplu_state = e1000_set_d0_lplu_state_82571,
|
||||
.set_d3_lplu_state = e1000e_set_d3_lplu_state,
|
||||
.write_reg = e1000e_write_phy_reg_bm2,
|
||||
.cfg_on_link_up = NULL,
|
||||
.cfg_on_link_up = NULL,
|
||||
};
|
||||
|
||||
static const struct e1000_nvm_operations e82571_nvm_ops = {
|
||||
|
@ -29,25 +29,6 @@
|
||||
#ifndef _E1000_DEFINES_H_
|
||||
#define _E1000_DEFINES_H_
|
||||
|
||||
#define E1000_TXD_POPTS_IXSM 0x01 /* Insert IP checksum */
|
||||
#define E1000_TXD_POPTS_TXSM 0x02 /* Insert TCP/UDP checksum */
|
||||
#define E1000_TXD_CMD_EOP 0x01000000 /* End of Packet */
|
||||
#define E1000_TXD_CMD_IFCS 0x02000000 /* Insert FCS (Ethernet CRC) */
|
||||
#define E1000_TXD_CMD_IC 0x04000000 /* Insert Checksum */
|
||||
#define E1000_TXD_CMD_RS 0x08000000 /* Report Status */
|
||||
#define E1000_TXD_CMD_RPS 0x10000000 /* Report Packet Sent */
|
||||
#define E1000_TXD_CMD_DEXT 0x20000000 /* Descriptor extension (0 = legacy) */
|
||||
#define E1000_TXD_CMD_VLE 0x40000000 /* Add VLAN tag */
|
||||
#define E1000_TXD_CMD_IDE 0x80000000 /* Enable Tidv register */
|
||||
#define E1000_TXD_STAT_DD 0x00000001 /* Descriptor Done */
|
||||
#define E1000_TXD_STAT_EC 0x00000002 /* Excess Collisions */
|
||||
#define E1000_TXD_STAT_LC 0x00000004 /* Late Collisions */
|
||||
#define E1000_TXD_STAT_TU 0x00000008 /* Transmit underrun */
|
||||
#define E1000_TXD_CMD_TCP 0x01000000 /* TCP packet */
|
||||
#define E1000_TXD_CMD_IP 0x02000000 /* IP packet */
|
||||
#define E1000_TXD_CMD_TSE 0x04000000 /* TCP Seg enable */
|
||||
#define E1000_TXD_STAT_TC 0x00000004 /* Tx Underrun */
|
||||
|
||||
/* Number of Transmit and Receive Descriptors must be a multiple of 8 */
|
||||
#define REQ_TX_DESCRIPTOR_MULTIPLE 8
|
||||
#define REQ_RX_DESCRIPTOR_MULTIPLE 8
|
||||
@ -86,7 +67,6 @@
|
||||
#define E1000_CTRL_EXT_EIAME 0x01000000
|
||||
#define E1000_CTRL_EXT_DRV_LOAD 0x10000000 /* Driver loaded bit for FW */
|
||||
#define E1000_CTRL_EXT_IAME 0x08000000 /* Interrupt acknowledge Auto-mask */
|
||||
#define E1000_CTRL_EXT_INT_TIMER_CLR 0x20000000 /* Clear Interrupt timers after IMS clear */
|
||||
#define E1000_CTRL_EXT_PBA_CLR 0x80000000 /* PBA Clear */
|
||||
#define E1000_CTRL_EXT_LSECCK 0x00001000
|
||||
#define E1000_CTRL_EXT_PHYPDEN 0x00100000
|
||||
@ -116,19 +96,19 @@
|
||||
|
||||
/* mask to determine if packets should be dropped due to frame errors */
|
||||
#define E1000_RXD_ERR_FRAME_ERR_MASK ( \
|
||||
E1000_RXD_ERR_CE | \
|
||||
E1000_RXD_ERR_SE | \
|
||||
E1000_RXD_ERR_SEQ | \
|
||||
E1000_RXD_ERR_CXE | \
|
||||
E1000_RXD_ERR_RXE)
|
||||
E1000_RXD_ERR_CE | \
|
||||
E1000_RXD_ERR_SE | \
|
||||
E1000_RXD_ERR_SEQ | \
|
||||
E1000_RXD_ERR_CXE | \
|
||||
E1000_RXD_ERR_RXE)
|
||||
|
||||
/* Same mask, but for extended and packet split descriptors */
|
||||
#define E1000_RXDEXT_ERR_FRAME_ERR_MASK ( \
|
||||
E1000_RXDEXT_STATERR_CE | \
|
||||
E1000_RXDEXT_STATERR_SE | \
|
||||
E1000_RXDEXT_STATERR_SEQ | \
|
||||
E1000_RXDEXT_STATERR_CXE | \
|
||||
E1000_RXDEXT_STATERR_RXE)
|
||||
E1000_RXDEXT_STATERR_CE | \
|
||||
E1000_RXDEXT_STATERR_SE | \
|
||||
E1000_RXDEXT_STATERR_SEQ | \
|
||||
E1000_RXDEXT_STATERR_CXE | \
|
||||
E1000_RXDEXT_STATERR_RXE)
|
||||
|
||||
#define E1000_MRQC_RSS_FIELD_MASK 0xFFFF0000
|
||||
#define E1000_MRQC_RSS_FIELD_IPV4_TCP 0x00010000
|
||||
@ -273,14 +253,15 @@
|
||||
#define ADVERTISE_1000_FULL 0x0020
|
||||
|
||||
/* 1000/H is not supported, nor spec-compliant. */
|
||||
#define E1000_ALL_SPEED_DUPLEX ( ADVERTISE_10_HALF | ADVERTISE_10_FULL | \
|
||||
ADVERTISE_100_HALF | ADVERTISE_100_FULL | \
|
||||
ADVERTISE_1000_FULL)
|
||||
#define E1000_ALL_NOT_GIG ( ADVERTISE_10_HALF | ADVERTISE_10_FULL | \
|
||||
ADVERTISE_100_HALF | ADVERTISE_100_FULL)
|
||||
#define E1000_ALL_100_SPEED (ADVERTISE_100_HALF | ADVERTISE_100_FULL)
|
||||
#define E1000_ALL_10_SPEED (ADVERTISE_10_HALF | ADVERTISE_10_FULL)
|
||||
#define E1000_ALL_HALF_DUPLEX (ADVERTISE_10_HALF | ADVERTISE_100_HALF)
|
||||
#define E1000_ALL_SPEED_DUPLEX ( \
|
||||
ADVERTISE_10_HALF | ADVERTISE_10_FULL | ADVERTISE_100_HALF | \
|
||||
ADVERTISE_100_FULL | ADVERTISE_1000_FULL)
|
||||
#define E1000_ALL_NOT_GIG ( \
|
||||
ADVERTISE_10_HALF | ADVERTISE_10_FULL | ADVERTISE_100_HALF | \
|
||||
ADVERTISE_100_FULL)
|
||||
#define E1000_ALL_100_SPEED (ADVERTISE_100_HALF | ADVERTISE_100_FULL)
|
||||
#define E1000_ALL_10_SPEED (ADVERTISE_10_HALF | ADVERTISE_10_FULL)
|
||||
#define E1000_ALL_HALF_DUPLEX (ADVERTISE_10_HALF | ADVERTISE_100_HALF)
|
||||
|
||||
#define AUTONEG_ADVERTISE_SPEED_DEFAULT E1000_ALL_SPEED_DUPLEX
|
||||
|
||||
@ -442,11 +423,11 @@
|
||||
* o LSC = Link Status Change
|
||||
*/
|
||||
#define IMS_ENABLE_MASK ( \
|
||||
E1000_IMS_RXT0 | \
|
||||
E1000_IMS_TXDW | \
|
||||
E1000_IMS_RXDMT0 | \
|
||||
E1000_IMS_RXSEQ | \
|
||||
E1000_IMS_LSC)
|
||||
E1000_IMS_RXT0 | \
|
||||
E1000_IMS_TXDW | \
|
||||
E1000_IMS_RXDMT0 | \
|
||||
E1000_IMS_RXSEQ | \
|
||||
E1000_IMS_LSC)
|
||||
|
||||
/* Interrupt Mask Set */
|
||||
#define E1000_IMS_TXDW E1000_ICR_TXDW /* Transmit desc written back */
|
||||
@ -546,7 +527,6 @@
|
||||
#define E1000_RXCW_SYNCH 0x40000000 /* Receive config synch */
|
||||
|
||||
#define E1000_TSYNCTXCTL_VALID 0x00000001 /* Tx timestamp valid */
|
||||
#define E1000_TSYNCRXCTL_TYPE_ALL 0x08
|
||||
#define E1000_TSYNCTXCTL_ENABLED 0x00000010 /* enable Tx timestamping */
|
||||
|
||||
#define E1000_TSYNCRXCTL_VALID 0x00000001 /* Rx timestamp valid */
|
||||
@ -583,66 +563,6 @@
|
||||
E1000_GCR_TXDSCW_NO_SNOOP | \
|
||||
E1000_GCR_TXDSCR_NO_SNOOP)
|
||||
|
||||
/* PHY Control Register */
|
||||
#define MII_CR_FULL_DUPLEX 0x0100 /* FDX =1, half duplex =0 */
|
||||
#define MII_CR_RESTART_AUTO_NEG 0x0200 /* Restart auto negotiation */
|
||||
#define MII_CR_POWER_DOWN 0x0800 /* Power down */
|
||||
#define MII_CR_AUTO_NEG_EN 0x1000 /* Auto Neg Enable */
|
||||
#define MII_CR_LOOPBACK 0x4000 /* 0 = normal, 1 = loopback */
|
||||
#define MII_CR_RESET 0x8000 /* 0 = normal, 1 = PHY reset */
|
||||
#define MII_CR_SPEED_1000 0x0040
|
||||
#define MII_CR_SPEED_100 0x2000
|
||||
#define MII_CR_SPEED_10 0x0000
|
||||
|
||||
/* PHY Status Register */
|
||||
#define MII_SR_LINK_STATUS 0x0004 /* Link Status 1 = link */
|
||||
#define MII_SR_AUTONEG_COMPLETE 0x0020 /* Auto Neg Complete */
|
||||
|
||||
/* Autoneg Advertisement Register */
|
||||
#define NWAY_AR_10T_HD_CAPS 0x0020 /* 10T Half Duplex Capable */
|
||||
#define NWAY_AR_10T_FD_CAPS 0x0040 /* 10T Full Duplex Capable */
|
||||
#define NWAY_AR_100TX_HD_CAPS 0x0080 /* 100TX Half Duplex Capable */
|
||||
#define NWAY_AR_100TX_FD_CAPS 0x0100 /* 100TX Full Duplex Capable */
|
||||
#define NWAY_AR_PAUSE 0x0400 /* Pause operation desired */
|
||||
#define NWAY_AR_ASM_DIR 0x0800 /* Asymmetric Pause Direction bit */
|
||||
|
||||
/* Link Partner Ability Register (Base Page) */
|
||||
#define NWAY_LPAR_100TX_FD_CAPS 0x0100 /* LP 100TX Full Dplx Capable */
|
||||
#define NWAY_LPAR_PAUSE 0x0400 /* LP Pause operation desired */
|
||||
#define NWAY_LPAR_ASM_DIR 0x0800 /* LP Asymmetric Pause Direction bit */
|
||||
|
||||
/* Autoneg Expansion Register */
|
||||
#define NWAY_ER_LP_NWAY_CAPS 0x0001 /* LP has Auto Neg Capability */
|
||||
|
||||
/* 1000BASE-T Control Register */
|
||||
#define CR_1000T_HD_CAPS 0x0100 /* Advertise 1000T HD capability */
|
||||
#define CR_1000T_FD_CAPS 0x0200 /* Advertise 1000T FD capability */
|
||||
/* 0=DTE device */
|
||||
#define CR_1000T_MS_VALUE 0x0800 /* 1=Configure PHY as Master */
|
||||
/* 0=Configure PHY as Slave */
|
||||
#define CR_1000T_MS_ENABLE 0x1000 /* 1=Master/Slave manual config value */
|
||||
/* 0=Automatic Master/Slave config */
|
||||
|
||||
/* 1000BASE-T Status Register */
|
||||
#define SR_1000T_REMOTE_RX_STATUS 0x1000 /* Remote receiver OK */
|
||||
#define SR_1000T_LOCAL_RX_STATUS 0x2000 /* Local receiver OK */
|
||||
|
||||
|
||||
/* PHY 1000 MII Register/Bit Definitions */
|
||||
/* PHY Registers defined by IEEE */
|
||||
#define PHY_CONTROL 0x00 /* Control Register */
|
||||
#define PHY_STATUS 0x01 /* Status Register */
|
||||
#define PHY_ID1 0x02 /* Phy Id Reg (word 1) */
|
||||
#define PHY_ID2 0x03 /* Phy Id Reg (word 2) */
|
||||
#define PHY_AUTONEG_ADV 0x04 /* Autoneg Advertisement */
|
||||
#define PHY_LP_ABILITY 0x05 /* Link Partner Ability (Base Page) */
|
||||
#define PHY_AUTONEG_EXP 0x06 /* Autoneg Expansion Reg */
|
||||
#define PHY_1000T_CTRL 0x09 /* 1000Base-T Control Reg */
|
||||
#define PHY_1000T_STATUS 0x0A /* 1000Base-T Status Reg */
|
||||
#define PHY_EXT_STATUS 0x0F /* Extended Status Reg */
|
||||
|
||||
#define PHY_CONTROL_LB 0x4000 /* PHY Loopback bit */
|
||||
|
||||
/* NVM Control */
|
||||
#define E1000_EECD_SK 0x00000001 /* NVM Clock */
|
||||
#define E1000_EECD_CS 0x00000002 /* NVM Chip Select */
|
||||
|
@ -45,6 +45,7 @@
|
||||
#include <linux/net_tstamp.h>
|
||||
#include <linux/ptp_clock_kernel.h>
|
||||
#include <linux/ptp_classify.h>
|
||||
#include <linux/mii.h>
|
||||
#include "hw.h"
|
||||
|
||||
struct e1000_info;
|
||||
|
@ -418,7 +418,7 @@ static void e1000_set_msglevel(struct net_device *netdev, u32 data)
|
||||
adapter->msg_enable = data;
|
||||
}
|
||||
|
||||
static int e1000_get_regs_len(struct net_device *netdev)
|
||||
static int e1000_get_regs_len(struct net_device __always_unused *netdev)
|
||||
{
|
||||
#define E1000_REGS_LEN 32 /* overestimate */
|
||||
return E1000_REGS_LEN * sizeof(u32);
|
||||
@ -472,10 +472,10 @@ static void e1000_get_regs(struct net_device *netdev,
|
||||
regs_buff[22] = adapter->phy_stats.receive_errors;
|
||||
regs_buff[23] = regs_buff[13]; /* mdix mode */
|
||||
}
|
||||
regs_buff[21] = 0; /* was idle_errors */
|
||||
e1e_rphy(hw, PHY_1000T_STATUS, &phy_data);
|
||||
regs_buff[24] = (u32)phy_data; /* phy local receiver status */
|
||||
regs_buff[25] = regs_buff[24]; /* phy remote receiver status */
|
||||
regs_buff[21] = 0; /* was idle_errors */
|
||||
e1e_rphy(hw, MII_STAT1000, &phy_data);
|
||||
regs_buff[24] = (u32)phy_data; /* phy local receiver status */
|
||||
regs_buff[25] = regs_buff[24]; /* phy remote receiver status */
|
||||
}
|
||||
|
||||
static int e1000_get_eeprom_len(struct net_device *netdev)
|
||||
@ -934,7 +934,7 @@ static int e1000_eeprom_test(struct e1000_adapter *adapter, u64 *data)
|
||||
return *data;
|
||||
}
|
||||
|
||||
static irqreturn_t e1000_test_intr(int irq, void *data)
|
||||
static irqreturn_t e1000_test_intr(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = (struct net_device *) data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1284,7 +1284,7 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
||||
|
||||
if (hw->phy.type == e1000_phy_ife) {
|
||||
/* force 100, set loopback */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x6100);
|
||||
e1e_wphy(hw, MII_BMCR, 0x6100);
|
||||
|
||||
/* Now set up the MAC to the same speed/duplex as the PHY. */
|
||||
ctrl_reg = er32(CTRL);
|
||||
@ -1307,9 +1307,9 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
||||
/* Auto-MDI/MDIX Off */
|
||||
e1e_wphy(hw, M88E1000_PHY_SPEC_CTRL, 0x0808);
|
||||
/* reset to update Auto-MDI/MDIX */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x9140);
|
||||
e1e_wphy(hw, MII_BMCR, 0x9140);
|
||||
/* autoneg off */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x8140);
|
||||
e1e_wphy(hw, MII_BMCR, 0x8140);
|
||||
break;
|
||||
case e1000_phy_gg82563:
|
||||
e1e_wphy(hw, GG82563_PHY_KMRN_MODE_CTRL, 0x1CC);
|
||||
@ -1363,7 +1363,7 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
||||
}
|
||||
|
||||
/* force 1000, set loopback */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x4140);
|
||||
e1e_wphy(hw, MII_BMCR, 0x4140);
|
||||
mdelay(250);
|
||||
|
||||
/* Now set up the MAC to the same speed/duplex as the PHY. */
|
||||
@ -1538,10 +1538,10 @@ static void e1000_loopback_cleanup(struct e1000_adapter *adapter)
|
||||
hw->mac.autoneg = 1;
|
||||
if (hw->phy.type == e1000_phy_gg82563)
|
||||
e1e_wphy(hw, GG82563_PHY_KMRN_MODE_CTRL, 0x180);
|
||||
e1e_rphy(hw, PHY_CONTROL, &phy_reg);
|
||||
if (phy_reg & MII_CR_LOOPBACK) {
|
||||
phy_reg &= ~MII_CR_LOOPBACK;
|
||||
e1e_wphy(hw, PHY_CONTROL, phy_reg);
|
||||
e1e_rphy(hw, MII_BMCR, &phy_reg);
|
||||
if (phy_reg & BMCR_LOOPBACK) {
|
||||
phy_reg &= ~BMCR_LOOPBACK;
|
||||
e1e_wphy(hw, MII_BMCR, phy_reg);
|
||||
if (hw->phy.ops.commit)
|
||||
hw->phy.ops.commit(hw);
|
||||
}
|
||||
@ -1705,7 +1705,8 @@ static int e1000_link_test(struct e1000_adapter *adapter, u64 *data)
|
||||
return *data;
|
||||
}
|
||||
|
||||
static int e1000e_get_sset_count(struct net_device *netdev, int sset)
|
||||
static int e1000e_get_sset_count(struct net_device __always_unused *netdev,
|
||||
int sset)
|
||||
{
|
||||
switch (sset) {
|
||||
case ETH_SS_TEST:
|
||||
@ -1968,7 +1969,7 @@ static int e1000_nway_reset(struct net_device *netdev)
|
||||
}
|
||||
|
||||
static void e1000_get_ethtool_stats(struct net_device *netdev,
|
||||
struct ethtool_stats *stats,
|
||||
struct ethtool_stats __always_unused *stats,
|
||||
u64 *data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1997,8 +1998,8 @@ static void e1000_get_ethtool_stats(struct net_device *netdev,
|
||||
}
|
||||
}
|
||||
|
||||
static void e1000_get_strings(struct net_device *netdev, u32 stringset,
|
||||
u8 *data)
|
||||
static void e1000_get_strings(struct net_device __always_unused *netdev,
|
||||
u32 stringset, u8 *data)
|
||||
{
|
||||
u8 *p = data;
|
||||
int i;
|
||||
@ -2018,7 +2019,8 @@ static void e1000_get_strings(struct net_device *netdev, u32 stringset,
|
||||
}
|
||||
|
||||
static int e1000_get_rxnfc(struct net_device *netdev,
|
||||
struct ethtool_rxnfc *info, u32 *rule_locs)
|
||||
struct ethtool_rxnfc *info,
|
||||
u32 __always_unused *rule_locs)
|
||||
{
|
||||
info->data = 0;
|
||||
|
||||
|
@ -312,12 +312,12 @@ static bool e1000_phy_is_accessible_pchlan(struct e1000_hw *hw)
|
||||
u16 retry_count;
|
||||
|
||||
for (retry_count = 0; retry_count < 2; retry_count++) {
|
||||
ret_val = e1e_rphy_locked(hw, PHY_ID1, &phy_reg);
|
||||
ret_val = e1e_rphy_locked(hw, MII_PHYSID1, &phy_reg);
|
||||
if (ret_val || (phy_reg == 0xFFFF))
|
||||
continue;
|
||||
phy_id = (u32)(phy_reg << 16);
|
||||
|
||||
ret_val = e1e_rphy_locked(hw, PHY_ID2, &phy_reg);
|
||||
ret_val = e1e_rphy_locked(hw, MII_PHYSID2, &phy_reg);
|
||||
if (ret_val || (phy_reg == 0xFFFF)) {
|
||||
phy_id = 0;
|
||||
continue;
|
||||
@ -882,8 +882,8 @@ static s32 e1000_set_eee_pchlan(struct e1000_hw *hw)
|
||||
lpi_ctrl |= I82579_LPI_CTRL_1000_ENABLE;
|
||||
|
||||
if (dev_spec->eee_lp_ability & I82579_EEE_100_SUPPORTED) {
|
||||
e1e_rphy_locked(hw, PHY_LP_ABILITY, &data);
|
||||
if (data & NWAY_LPAR_100TX_FD_CAPS)
|
||||
e1e_rphy_locked(hw, MII_LPA, &data);
|
||||
if (data & LPA_100FULL)
|
||||
lpi_ctrl |= I82579_LPI_CTRL_100_ENABLE;
|
||||
else
|
||||
/* EEE is not supported in 100Half, so ignore
|
||||
@ -1082,7 +1082,7 @@ static DEFINE_MUTEX(nvm_mutex);
|
||||
*
|
||||
* Acquires the mutex for performing NVM operations.
|
||||
**/
|
||||
static s32 e1000_acquire_nvm_ich8lan(struct e1000_hw *hw)
|
||||
static s32 e1000_acquire_nvm_ich8lan(struct e1000_hw __always_unused *hw)
|
||||
{
|
||||
mutex_lock(&nvm_mutex);
|
||||
|
||||
@ -1095,7 +1095,7 @@ static s32 e1000_acquire_nvm_ich8lan(struct e1000_hw *hw)
|
||||
*
|
||||
* Releases the mutex used while performing NVM operations.
|
||||
**/
|
||||
static void e1000_release_nvm_ich8lan(struct e1000_hw *hw)
|
||||
static void e1000_release_nvm_ich8lan(struct e1000_hw __always_unused *hw)
|
||||
{
|
||||
mutex_unlock(&nvm_mutex);
|
||||
}
|
||||
@ -1792,7 +1792,7 @@ static s32 e1000_hv_phy_workarounds_ich8lan(struct e1000_hw *hw)
|
||||
*/
|
||||
if (hw->phy.revision < 2) {
|
||||
e1000e_phy_sw_reset(hw);
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, 0x3140);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, 0x3140);
|
||||
}
|
||||
}
|
||||
|
||||
@ -4507,7 +4507,7 @@ static const struct e1000_mac_operations ich8_mac_ops = {
|
||||
.reset_hw = e1000_reset_hw_ich8lan,
|
||||
.init_hw = e1000_init_hw_ich8lan,
|
||||
.setup_link = e1000_setup_link_ich8lan,
|
||||
.setup_physical_interface= e1000_setup_copper_link_ich8lan,
|
||||
.setup_physical_interface = e1000_setup_copper_link_ich8lan,
|
||||
/* id_led_init dependent on mac type */
|
||||
.config_collision_dist = e1000e_config_collision_dist_generic,
|
||||
.rar_set = e1000e_rar_set_generic,
|
||||
@ -4529,7 +4529,7 @@ static const struct e1000_phy_operations ich8_phy_ops = {
|
||||
|
||||
static const struct e1000_nvm_operations ich8_nvm_ops = {
|
||||
.acquire = e1000_acquire_nvm_ich8lan,
|
||||
.read = e1000_read_nvm_ich8lan,
|
||||
.read = e1000_read_nvm_ich8lan,
|
||||
.release = e1000_release_nvm_ich8lan,
|
||||
.reload = e1000e_reload_nvm_generic,
|
||||
.update = e1000_update_nvm_checksum_ich8lan,
|
||||
|
@ -1053,14 +1053,14 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
|
||||
* has completed. We read this twice because this reg has
|
||||
* some "sticky" (latched) bits.
|
||||
*/
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &mii_status_reg);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &mii_status_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &mii_status_reg);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &mii_status_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
if (!(mii_status_reg & MII_SR_AUTONEG_COMPLETE)) {
|
||||
if (!(mii_status_reg & BMSR_ANEGCOMPLETE)) {
|
||||
e_dbg("Copper PHY and Auto Neg has not completed.\n");
|
||||
return ret_val;
|
||||
}
|
||||
@ -1071,11 +1071,10 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
|
||||
* Page Ability Register (Address 5) to determine how
|
||||
* flow control was negotiated.
|
||||
*/
|
||||
ret_val = e1e_rphy(hw, PHY_AUTONEG_ADV, &mii_nway_adv_reg);
|
||||
ret_val = e1e_rphy(hw, MII_ADVERTISE, &mii_nway_adv_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
ret_val =
|
||||
e1e_rphy(hw, PHY_LP_ABILITY, &mii_nway_lp_ability_reg);
|
||||
ret_val = e1e_rphy(hw, MII_LPA, &mii_nway_lp_ability_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1112,8 +1111,8 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
|
||||
* 1 | DC | 1 | DC | E1000_fc_full
|
||||
*
|
||||
*/
|
||||
if ((mii_nway_adv_reg & NWAY_AR_PAUSE) &&
|
||||
(mii_nway_lp_ability_reg & NWAY_LPAR_PAUSE)) {
|
||||
if ((mii_nway_adv_reg & ADVERTISE_PAUSE_CAP) &&
|
||||
(mii_nway_lp_ability_reg & LPA_PAUSE_CAP)) {
|
||||
/* Now we need to check if the user selected Rx ONLY
|
||||
* of pause frames. In this case, we had to advertise
|
||||
* FULL flow control because we could not advertise Rx
|
||||
@ -1135,10 +1134,10 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
|
||||
*-------|---------|-------|---------|--------------------
|
||||
* 0 | 1 | 1 | 1 | e1000_fc_tx_pause
|
||||
*/
|
||||
else if (!(mii_nway_adv_reg & NWAY_AR_PAUSE) &&
|
||||
(mii_nway_adv_reg & NWAY_AR_ASM_DIR) &&
|
||||
(mii_nway_lp_ability_reg & NWAY_LPAR_PAUSE) &&
|
||||
(mii_nway_lp_ability_reg & NWAY_LPAR_ASM_DIR)) {
|
||||
else if (!(mii_nway_adv_reg & ADVERTISE_PAUSE_CAP) &&
|
||||
(mii_nway_adv_reg & ADVERTISE_PAUSE_ASYM) &&
|
||||
(mii_nway_lp_ability_reg & LPA_PAUSE_CAP) &&
|
||||
(mii_nway_lp_ability_reg & LPA_PAUSE_ASYM)) {
|
||||
hw->fc.current_mode = e1000_fc_tx_pause;
|
||||
e_dbg("Flow Control = Tx PAUSE frames only.\n");
|
||||
}
|
||||
@ -1149,10 +1148,10 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
|
||||
*-------|---------|-------|---------|--------------------
|
||||
* 1 | 1 | 0 | 1 | e1000_fc_rx_pause
|
||||
*/
|
||||
else if ((mii_nway_adv_reg & NWAY_AR_PAUSE) &&
|
||||
(mii_nway_adv_reg & NWAY_AR_ASM_DIR) &&
|
||||
!(mii_nway_lp_ability_reg & NWAY_LPAR_PAUSE) &&
|
||||
(mii_nway_lp_ability_reg & NWAY_LPAR_ASM_DIR)) {
|
||||
else if ((mii_nway_adv_reg & ADVERTISE_PAUSE_CAP) &&
|
||||
(mii_nway_adv_reg & ADVERTISE_PAUSE_ASYM) &&
|
||||
!(mii_nway_lp_ability_reg & LPA_PAUSE_CAP) &&
|
||||
(mii_nway_lp_ability_reg & LPA_PAUSE_ASYM)) {
|
||||
hw->fc.current_mode = e1000_fc_rx_pause;
|
||||
e_dbg("Flow Control = Rx PAUSE frames only.\n");
|
||||
} else {
|
||||
@ -1356,8 +1355,8 @@ s32 e1000e_get_speed_and_duplex_copper(struct e1000_hw *hw, u16 *speed,
|
||||
* Sets the speed and duplex to gigabit full duplex (the only possible option)
|
||||
* for fiber/serdes links.
|
||||
**/
|
||||
s32 e1000e_get_speed_and_duplex_fiber_serdes(struct e1000_hw *hw, u16 *speed,
|
||||
u16 *duplex)
|
||||
s32 e1000e_get_speed_and_duplex_fiber_serdes(struct e1000_hw __always_unused
|
||||
*hw, u16 *speed, u16 *duplex)
|
||||
{
|
||||
*speed = SPEED_1000;
|
||||
*duplex = FULL_DUPLEX;
|
||||
|
@ -42,7 +42,6 @@
|
||||
#include <linux/slab.h>
|
||||
#include <net/checksum.h>
|
||||
#include <net/ip6_checksum.h>
|
||||
#include <linux/mii.h>
|
||||
#include <linux/ethtool.h>
|
||||
#include <linux/if_vlan.h>
|
||||
#include <linux/cpu.h>
|
||||
@ -56,7 +55,7 @@
|
||||
|
||||
#define DRV_EXTRAVERSION "-k"
|
||||
|
||||
#define DRV_VERSION "2.1.4" DRV_EXTRAVERSION
|
||||
#define DRV_VERSION "2.2.14" DRV_EXTRAVERSION
|
||||
char e1000e_driver_name[] = "e1000e";
|
||||
const char e1000e_driver_version[] = DRV_VERSION;
|
||||
|
||||
@ -1117,9 +1116,9 @@ static void e1000_print_hw_hang(struct work_struct *work)
|
||||
adapter->tx_hang_recheck = false;
|
||||
netif_stop_queue(netdev);
|
||||
|
||||
e1e_rphy(hw, PHY_STATUS, &phy_status);
|
||||
e1e_rphy(hw, PHY_1000T_STATUS, &phy_1000t_status);
|
||||
e1e_rphy(hw, PHY_EXT_STATUS, &phy_ext_status);
|
||||
e1e_rphy(hw, MII_BMSR, &phy_status);
|
||||
e1e_rphy(hw, MII_STAT1000, &phy_1000t_status);
|
||||
e1e_rphy(hw, MII_ESTATUS, &phy_ext_status);
|
||||
|
||||
pci_read_config_word(adapter->pdev, PCI_STATUS, &pci_status);
|
||||
|
||||
@ -1747,7 +1746,7 @@ static void e1000e_downshift_workaround(struct work_struct *work)
|
||||
* @irq: interrupt number
|
||||
* @data: pointer to a network interface device structure
|
||||
**/
|
||||
static irqreturn_t e1000_intr_msi(int irq, void *data)
|
||||
static irqreturn_t e1000_intr_msi(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1813,7 +1812,7 @@ static irqreturn_t e1000_intr_msi(int irq, void *data)
|
||||
* @irq: interrupt number
|
||||
* @data: pointer to a network interface device structure
|
||||
**/
|
||||
static irqreturn_t e1000_intr(int irq, void *data)
|
||||
static irqreturn_t e1000_intr(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1888,7 +1887,7 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static irqreturn_t e1000_msix_other(int irq, void *data)
|
||||
static irqreturn_t e1000_msix_other(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1920,8 +1919,7 @@ no_link_interrupt:
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
|
||||
static irqreturn_t e1000_intr_msix_tx(int irq, void *data)
|
||||
static irqreturn_t e1000_intr_msix_tx(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -1939,7 +1937,7 @@ static irqreturn_t e1000_intr_msix_tx(int irq, void *data)
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static irqreturn_t e1000_intr_msix_rx(int irq, void *data)
|
||||
static irqreturn_t e1000_intr_msix_rx(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -2496,9 +2494,7 @@ void e1000e_free_rx_resources(struct e1000_ring *rx_ring)
|
||||
* while increasing bulk throughput. This functionality is controlled
|
||||
* by the InterruptThrottleRate module parameter.
|
||||
**/
|
||||
static unsigned int e1000_update_itr(struct e1000_adapter *adapter,
|
||||
u16 itr_setting, int packets,
|
||||
int bytes)
|
||||
static unsigned int e1000_update_itr(u16 itr_setting, int packets, int bytes)
|
||||
{
|
||||
unsigned int retval = itr_setting;
|
||||
|
||||
@ -2558,18 +2554,16 @@ static void e1000_set_itr(struct e1000_adapter *adapter)
|
||||
goto set_itr_now;
|
||||
}
|
||||
|
||||
adapter->tx_itr = e1000_update_itr(adapter,
|
||||
adapter->tx_itr,
|
||||
adapter->total_tx_packets,
|
||||
adapter->total_tx_bytes);
|
||||
adapter->tx_itr = e1000_update_itr(adapter->tx_itr,
|
||||
adapter->total_tx_packets,
|
||||
adapter->total_tx_bytes);
|
||||
/* conservative mode (itr 3) eliminates the lowest_latency setting */
|
||||
if (adapter->itr_setting == 3 && adapter->tx_itr == lowest_latency)
|
||||
adapter->tx_itr = low_latency;
|
||||
|
||||
adapter->rx_itr = e1000_update_itr(adapter,
|
||||
adapter->rx_itr,
|
||||
adapter->total_rx_packets,
|
||||
adapter->total_rx_bytes);
|
||||
adapter->rx_itr = e1000_update_itr(adapter->rx_itr,
|
||||
adapter->total_rx_packets,
|
||||
adapter->total_rx_bytes);
|
||||
/* conservative mode (itr 3) eliminates the lowest_latency setting */
|
||||
if (adapter->itr_setting == 3 && adapter->rx_itr == lowest_latency)
|
||||
adapter->rx_itr = low_latency;
|
||||
@ -4115,7 +4109,7 @@ static int e1000_sw_init(struct e1000_adapter *adapter)
|
||||
* @irq: interrupt number
|
||||
* @data: pointer to a network interface device structure
|
||||
**/
|
||||
static irqreturn_t e1000_intr_msi_test(int irq, void *data)
|
||||
static irqreturn_t e1000_intr_msi_test(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -4682,14 +4676,14 @@ static void e1000_phy_read_status(struct e1000_adapter *adapter)
|
||||
(adapter->hw.phy.media_type == e1000_media_type_copper)) {
|
||||
int ret_val;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy->bmcr);
|
||||
ret_val |= e1e_rphy(hw, PHY_STATUS, &phy->bmsr);
|
||||
ret_val |= e1e_rphy(hw, PHY_AUTONEG_ADV, &phy->advertise);
|
||||
ret_val |= e1e_rphy(hw, PHY_LP_ABILITY, &phy->lpa);
|
||||
ret_val |= e1e_rphy(hw, PHY_AUTONEG_EXP, &phy->expansion);
|
||||
ret_val |= e1e_rphy(hw, PHY_1000T_CTRL, &phy->ctrl1000);
|
||||
ret_val |= e1e_rphy(hw, PHY_1000T_STATUS, &phy->stat1000);
|
||||
ret_val |= e1e_rphy(hw, PHY_EXT_STATUS, &phy->estatus);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy->bmcr);
|
||||
ret_val |= e1e_rphy(hw, MII_BMSR, &phy->bmsr);
|
||||
ret_val |= e1e_rphy(hw, MII_ADVERTISE, &phy->advertise);
|
||||
ret_val |= e1e_rphy(hw, MII_LPA, &phy->lpa);
|
||||
ret_val |= e1e_rphy(hw, MII_EXPANSION, &phy->expansion);
|
||||
ret_val |= e1e_rphy(hw, MII_CTRL1000, &phy->ctrl1000);
|
||||
ret_val |= e1e_rphy(hw, MII_STAT1000, &phy->stat1000);
|
||||
ret_val |= e1e_rphy(hw, MII_ESTATUS, &phy->estatus);
|
||||
if (ret_val)
|
||||
e_warn("Error reading PHY register\n");
|
||||
} else {
|
||||
@ -4861,9 +4855,9 @@ static void e1000_watchdog_task(struct work_struct *work)
|
||||
(adapter->link_duplex == HALF_DUPLEX)) {
|
||||
u16 autoneg_exp;
|
||||
|
||||
e1e_rphy(hw, PHY_AUTONEG_EXP, &autoneg_exp);
|
||||
e1e_rphy(hw, MII_EXPANSION, &autoneg_exp);
|
||||
|
||||
if (!(autoneg_exp & NWAY_ER_LP_NWAY_CAPS))
|
||||
if (!(autoneg_exp & EXPANSION_NWAY))
|
||||
e_info("Autonegotiated half duplex but link partner cannot autoneg. Try forcing full duplex if link gets many collisions.\n");
|
||||
}
|
||||
|
||||
@ -6249,7 +6243,7 @@ static void e1000_shutdown(struct pci_dev *pdev)
|
||||
|
||||
#ifdef CONFIG_NET_POLL_CONTROLLER
|
||||
|
||||
static irqreturn_t e1000_intr_msix(int irq, void *data)
|
||||
static irqreturn_t e1000_intr_msix(int __always_unused irq, void *data)
|
||||
{
|
||||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
@ -6571,8 +6565,8 @@ static int e1000_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
||||
}
|
||||
|
||||
err = pci_request_selected_regions_exclusive(pdev,
|
||||
pci_select_bars(pdev, IORESOURCE_MEM),
|
||||
e1000e_driver_name);
|
||||
pci_select_bars(pdev, IORESOURCE_MEM),
|
||||
e1000e_driver_name);
|
||||
if (err)
|
||||
goto err_pci_reg;
|
||||
|
||||
|
@ -53,8 +53,7 @@ MODULE_PARM_DESC(copybreak,
|
||||
*/
|
||||
#define E1000_PARAM_INIT { [0 ... E1000_MAX_NIC] = OPTION_UNSET }
|
||||
#define E1000_PARAM(X, desc) \
|
||||
static int X[E1000_MAX_NIC+1] \
|
||||
= E1000_PARAM_INIT; \
|
||||
static int X[E1000_MAX_NIC+1] = E1000_PARAM_INIT; \
|
||||
static unsigned int num_##X; \
|
||||
module_param_array_named(X, X, int, &num_##X, 0); \
|
||||
MODULE_PARM_DESC(X, desc);
|
||||
|
@ -131,13 +131,13 @@ s32 e1000e_get_phy_id(struct e1000_hw *hw)
|
||||
return 0;
|
||||
|
||||
while (retry_count < 2) {
|
||||
ret_val = e1e_rphy(hw, PHY_ID1, &phy_id);
|
||||
ret_val = e1e_rphy(hw, MII_PHYSID1, &phy_id);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy->id = (u32)(phy_id << 16);
|
||||
udelay(20);
|
||||
ret_val = e1e_rphy(hw, PHY_ID2, &phy_id);
|
||||
ret_val = e1e_rphy(hw, MII_PHYSID2, &phy_id);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -641,31 +641,31 @@ static s32 e1000_set_master_slave_mode(struct e1000_hw *hw)
|
||||
u16 phy_data;
|
||||
|
||||
/* Resolve Master/Slave mode */
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_CTRL, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_CTRL1000, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
/* load defaults for future use */
|
||||
hw->phy.original_ms_type = (phy_data & CR_1000T_MS_ENABLE) ?
|
||||
((phy_data & CR_1000T_MS_VALUE) ?
|
||||
hw->phy.original_ms_type = (phy_data & CTL1000_ENABLE_MASTER) ?
|
||||
((phy_data & CTL1000_AS_MASTER) ?
|
||||
e1000_ms_force_master : e1000_ms_force_slave) : e1000_ms_auto;
|
||||
|
||||
switch (hw->phy.ms_type) {
|
||||
case e1000_ms_force_master:
|
||||
phy_data |= (CR_1000T_MS_ENABLE | CR_1000T_MS_VALUE);
|
||||
phy_data |= (CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER);
|
||||
break;
|
||||
case e1000_ms_force_slave:
|
||||
phy_data |= CR_1000T_MS_ENABLE;
|
||||
phy_data &= ~(CR_1000T_MS_VALUE);
|
||||
phy_data |= CTL1000_ENABLE_MASTER;
|
||||
phy_data &= ~(CTL1000_AS_MASTER);
|
||||
break;
|
||||
case e1000_ms_auto:
|
||||
phy_data &= ~CR_1000T_MS_ENABLE;
|
||||
phy_data &= ~CTL1000_ENABLE_MASTER;
|
||||
/* fall-through */
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return e1e_wphy(hw, PHY_1000T_CTRL, phy_data);
|
||||
return e1e_wphy(hw, MII_CTRL1000, phy_data);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -943,12 +943,12 @@ s32 e1000e_copper_link_setup_igp(struct e1000_hw *hw)
|
||||
return ret_val;
|
||||
|
||||
/* Set auto Master/Slave resolution process */
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_CTRL, &data);
|
||||
ret_val = e1e_rphy(hw, MII_CTRL1000, &data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
data &= ~CR_1000T_MS_ENABLE;
|
||||
ret_val = e1e_wphy(hw, PHY_1000T_CTRL, data);
|
||||
data &= ~CTL1000_ENABLE_MASTER;
|
||||
ret_val = e1e_wphy(hw, MII_CTRL1000, data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
}
|
||||
@ -978,13 +978,13 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw)
|
||||
phy->autoneg_advertised &= phy->autoneg_mask;
|
||||
|
||||
/* Read the MII Auto-Neg Advertisement Register (Address 4). */
|
||||
ret_val = e1e_rphy(hw, PHY_AUTONEG_ADV, &mii_autoneg_adv_reg);
|
||||
ret_val = e1e_rphy(hw, MII_ADVERTISE, &mii_autoneg_adv_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
if (phy->autoneg_mask & ADVERTISE_1000_FULL) {
|
||||
/* Read the MII 1000Base-T Control Register (Address 9). */
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_CTRL, &mii_1000t_ctrl_reg);
|
||||
ret_val = e1e_rphy(hw, MII_CTRL1000, &mii_1000t_ctrl_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
}
|
||||
@ -1000,36 +1000,35 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw)
|
||||
* Advertisement Register (Address 4) and the 1000 mb speed bits in
|
||||
* the 1000Base-T Control Register (Address 9).
|
||||
*/
|
||||
mii_autoneg_adv_reg &= ~(NWAY_AR_100TX_FD_CAPS |
|
||||
NWAY_AR_100TX_HD_CAPS |
|
||||
NWAY_AR_10T_FD_CAPS |
|
||||
NWAY_AR_10T_HD_CAPS);
|
||||
mii_1000t_ctrl_reg &= ~(CR_1000T_HD_CAPS | CR_1000T_FD_CAPS);
|
||||
mii_autoneg_adv_reg &= ~(ADVERTISE_100FULL |
|
||||
ADVERTISE_100HALF |
|
||||
ADVERTISE_10FULL | ADVERTISE_10HALF);
|
||||
mii_1000t_ctrl_reg &= ~(ADVERTISE_1000HALF | ADVERTISE_1000FULL);
|
||||
|
||||
e_dbg("autoneg_advertised %x\n", phy->autoneg_advertised);
|
||||
|
||||
/* Do we want to advertise 10 Mb Half Duplex? */
|
||||
if (phy->autoneg_advertised & ADVERTISE_10_HALF) {
|
||||
e_dbg("Advertise 10mb Half duplex\n");
|
||||
mii_autoneg_adv_reg |= NWAY_AR_10T_HD_CAPS;
|
||||
mii_autoneg_adv_reg |= ADVERTISE_10HALF;
|
||||
}
|
||||
|
||||
/* Do we want to advertise 10 Mb Full Duplex? */
|
||||
if (phy->autoneg_advertised & ADVERTISE_10_FULL) {
|
||||
e_dbg("Advertise 10mb Full duplex\n");
|
||||
mii_autoneg_adv_reg |= NWAY_AR_10T_FD_CAPS;
|
||||
mii_autoneg_adv_reg |= ADVERTISE_10FULL;
|
||||
}
|
||||
|
||||
/* Do we want to advertise 100 Mb Half Duplex? */
|
||||
if (phy->autoneg_advertised & ADVERTISE_100_HALF) {
|
||||
e_dbg("Advertise 100mb Half duplex\n");
|
||||
mii_autoneg_adv_reg |= NWAY_AR_100TX_HD_CAPS;
|
||||
mii_autoneg_adv_reg |= ADVERTISE_100HALF;
|
||||
}
|
||||
|
||||
/* Do we want to advertise 100 Mb Full Duplex? */
|
||||
if (phy->autoneg_advertised & ADVERTISE_100_FULL) {
|
||||
e_dbg("Advertise 100mb Full duplex\n");
|
||||
mii_autoneg_adv_reg |= NWAY_AR_100TX_FD_CAPS;
|
||||
mii_autoneg_adv_reg |= ADVERTISE_100FULL;
|
||||
}
|
||||
|
||||
/* We do not allow the Phy to advertise 1000 Mb Half Duplex */
|
||||
@ -1039,14 +1038,14 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw)
|
||||
/* Do we want to advertise 1000 Mb Full Duplex? */
|
||||
if (phy->autoneg_advertised & ADVERTISE_1000_FULL) {
|
||||
e_dbg("Advertise 1000mb Full duplex\n");
|
||||
mii_1000t_ctrl_reg |= CR_1000T_FD_CAPS;
|
||||
mii_1000t_ctrl_reg |= ADVERTISE_1000FULL;
|
||||
}
|
||||
|
||||
/* Check for a software override of the flow control settings, and
|
||||
* setup the PHY advertisement registers accordingly. If
|
||||
* auto-negotiation is enabled, then software will have to set the
|
||||
* "PAUSE" bits to the correct value in the Auto-Negotiation
|
||||
* Advertisement Register (PHY_AUTONEG_ADV) and re-start auto-
|
||||
* Advertisement Register (MII_ADVERTISE) and re-start auto-
|
||||
* negotiation.
|
||||
*
|
||||
* The possible values of the "fc" parameter are:
|
||||
@ -1064,7 +1063,8 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw)
|
||||
/* Flow control (Rx & Tx) is completely disabled by a
|
||||
* software over-ride.
|
||||
*/
|
||||
mii_autoneg_adv_reg &= ~(NWAY_AR_ASM_DIR | NWAY_AR_PAUSE);
|
||||
mii_autoneg_adv_reg &=
|
||||
~(ADVERTISE_PAUSE_ASYM | ADVERTISE_PAUSE_CAP);
|
||||
break;
|
||||
case e1000_fc_rx_pause:
|
||||
/* Rx Flow control is enabled, and Tx Flow control is
|
||||
@ -1076,34 +1076,36 @@ static s32 e1000_phy_setup_autoneg(struct e1000_hw *hw)
|
||||
* (in e1000e_config_fc_after_link_up) we will disable the
|
||||
* hw's ability to send PAUSE frames.
|
||||
*/
|
||||
mii_autoneg_adv_reg |= (NWAY_AR_ASM_DIR | NWAY_AR_PAUSE);
|
||||
mii_autoneg_adv_reg |=
|
||||
(ADVERTISE_PAUSE_ASYM | ADVERTISE_PAUSE_CAP);
|
||||
break;
|
||||
case e1000_fc_tx_pause:
|
||||
/* Tx Flow control is enabled, and Rx Flow control is
|
||||
* disabled, by a software over-ride.
|
||||
*/
|
||||
mii_autoneg_adv_reg |= NWAY_AR_ASM_DIR;
|
||||
mii_autoneg_adv_reg &= ~NWAY_AR_PAUSE;
|
||||
mii_autoneg_adv_reg |= ADVERTISE_PAUSE_ASYM;
|
||||
mii_autoneg_adv_reg &= ~ADVERTISE_PAUSE_CAP;
|
||||
break;
|
||||
case e1000_fc_full:
|
||||
/* Flow control (both Rx and Tx) is enabled by a software
|
||||
* over-ride.
|
||||
*/
|
||||
mii_autoneg_adv_reg |= (NWAY_AR_ASM_DIR | NWAY_AR_PAUSE);
|
||||
mii_autoneg_adv_reg |=
|
||||
(ADVERTISE_PAUSE_ASYM | ADVERTISE_PAUSE_CAP);
|
||||
break;
|
||||
default:
|
||||
e_dbg("Flow control param set incorrectly\n");
|
||||
return -E1000_ERR_CONFIG;
|
||||
}
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_AUTONEG_ADV, mii_autoneg_adv_reg);
|
||||
ret_val = e1e_wphy(hw, MII_ADVERTISE, mii_autoneg_adv_reg);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e_dbg("Auto-Neg Advertising %x\n", mii_autoneg_adv_reg);
|
||||
|
||||
if (phy->autoneg_mask & ADVERTISE_1000_FULL)
|
||||
ret_val = e1e_wphy(hw, PHY_1000T_CTRL, mii_1000t_ctrl_reg);
|
||||
ret_val = e1e_wphy(hw, MII_CTRL1000, mii_1000t_ctrl_reg);
|
||||
|
||||
return ret_val;
|
||||
}
|
||||
@ -1145,12 +1147,12 @@ static s32 e1000_copper_link_autoneg(struct e1000_hw *hw)
|
||||
/* Restart auto-negotiation by setting the Auto Neg Enable bit and
|
||||
* the Auto Neg Restart bit in the PHY control register.
|
||||
*/
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_ctrl);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_ctrl);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy_ctrl |= (MII_CR_AUTO_NEG_EN | MII_CR_RESTART_AUTO_NEG);
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_ctrl);
|
||||
phy_ctrl |= (BMCR_ANENABLE | BMCR_ANRESTART);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_ctrl);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1237,13 +1239,13 @@ s32 e1000e_phy_force_speed_duplex_igp(struct e1000_hw *hw)
|
||||
u16 phy_data;
|
||||
bool link;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e1000e_phy_force_speed_duplex_setup(hw, &phy_data);
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_data);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1315,13 +1317,13 @@ s32 e1000e_phy_force_speed_duplex_m88(struct e1000_hw *hw)
|
||||
|
||||
e_dbg("M88E1000 PSCR: %X\n", phy_data);
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e1000e_phy_force_speed_duplex_setup(hw, &phy_data);
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_data);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1408,13 +1410,13 @@ s32 e1000_phy_force_speed_duplex_ife(struct e1000_hw *hw)
|
||||
u16 data;
|
||||
bool link;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &data);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e1000e_phy_force_speed_duplex_setup(hw, &data);
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, data);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -1458,13 +1460,13 @@ s32 e1000_phy_force_speed_duplex_ife(struct e1000_hw *hw)
|
||||
/**
|
||||
* e1000e_phy_force_speed_duplex_setup - Configure forced PHY speed/duplex
|
||||
* @hw: pointer to the HW structure
|
||||
* @phy_ctrl: pointer to current value of PHY_CONTROL
|
||||
* @phy_ctrl: pointer to current value of MII_BMCR
|
||||
*
|
||||
* Forces speed and duplex on the PHY by doing the following: disable flow
|
||||
* control, force speed/duplex on the MAC, disable auto speed detection,
|
||||
* disable auto-negotiation, configure duplex, configure speed, configure
|
||||
* the collision distance, write configuration to CTRL register. The
|
||||
* caller must write to the PHY_CONTROL register for these settings to
|
||||
* caller must write to the MII_BMCR register for these settings to
|
||||
* take affect.
|
||||
**/
|
||||
void e1000e_phy_force_speed_duplex_setup(struct e1000_hw *hw, u16 *phy_ctrl)
|
||||
@ -1484,29 +1486,28 @@ void e1000e_phy_force_speed_duplex_setup(struct e1000_hw *hw, u16 *phy_ctrl)
|
||||
ctrl &= ~E1000_CTRL_ASDE;
|
||||
|
||||
/* Disable autoneg on the phy */
|
||||
*phy_ctrl &= ~MII_CR_AUTO_NEG_EN;
|
||||
*phy_ctrl &= ~BMCR_ANENABLE;
|
||||
|
||||
/* Forcing Full or Half Duplex? */
|
||||
if (mac->forced_speed_duplex & E1000_ALL_HALF_DUPLEX) {
|
||||
ctrl &= ~E1000_CTRL_FD;
|
||||
*phy_ctrl &= ~MII_CR_FULL_DUPLEX;
|
||||
*phy_ctrl &= ~BMCR_FULLDPLX;
|
||||
e_dbg("Half Duplex\n");
|
||||
} else {
|
||||
ctrl |= E1000_CTRL_FD;
|
||||
*phy_ctrl |= MII_CR_FULL_DUPLEX;
|
||||
*phy_ctrl |= BMCR_FULLDPLX;
|
||||
e_dbg("Full Duplex\n");
|
||||
}
|
||||
|
||||
/* Forcing 10mb or 100mb? */
|
||||
if (mac->forced_speed_duplex & E1000_ALL_100_SPEED) {
|
||||
ctrl |= E1000_CTRL_SPD_100;
|
||||
*phy_ctrl |= MII_CR_SPEED_100;
|
||||
*phy_ctrl &= ~(MII_CR_SPEED_1000 | MII_CR_SPEED_10);
|
||||
*phy_ctrl |= BMCR_SPEED100;
|
||||
*phy_ctrl &= ~BMCR_SPEED1000;
|
||||
e_dbg("Forcing 100mb\n");
|
||||
} else {
|
||||
ctrl &= ~(E1000_CTRL_SPD_1000 | E1000_CTRL_SPD_100);
|
||||
*phy_ctrl |= MII_CR_SPEED_10;
|
||||
*phy_ctrl &= ~(MII_CR_SPEED_1000 | MII_CR_SPEED_100);
|
||||
*phy_ctrl &= ~(BMCR_SPEED1000 | BMCR_SPEED100);
|
||||
e_dbg("Forcing 10mb\n");
|
||||
}
|
||||
|
||||
@ -1747,13 +1748,13 @@ static s32 e1000_wait_autoneg(struct e1000_hw *hw)
|
||||
|
||||
/* Break after autoneg completes or PHY_AUTO_NEG_LIMIT expires. */
|
||||
for (i = PHY_AUTO_NEG_LIMIT; i > 0; i--) {
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &phy_status);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &phy_status);
|
||||
if (ret_val)
|
||||
break;
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &phy_status);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &phy_status);
|
||||
if (ret_val)
|
||||
break;
|
||||
if (phy_status & MII_SR_AUTONEG_COMPLETE)
|
||||
if (phy_status & BMSR_ANEGCOMPLETE)
|
||||
break;
|
||||
msleep(100);
|
||||
}
|
||||
@ -1780,21 +1781,21 @@ s32 e1000e_phy_has_link_generic(struct e1000_hw *hw, u32 iterations,
|
||||
u16 i, phy_status;
|
||||
|
||||
for (i = 0; i < iterations; i++) {
|
||||
/* Some PHYs require the PHY_STATUS register to be read
|
||||
/* Some PHYs require the MII_BMSR register to be read
|
||||
* twice due to the link bit being sticky. No harm doing
|
||||
* it across the board.
|
||||
*/
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &phy_status);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &phy_status);
|
||||
if (ret_val)
|
||||
/* If the first read fails, another entity may have
|
||||
* ownership of the resources, wait and try again to
|
||||
* see if they have relinquished the resources yet.
|
||||
*/
|
||||
udelay(usec_interval);
|
||||
ret_val = e1e_rphy(hw, PHY_STATUS, &phy_status);
|
||||
ret_val = e1e_rphy(hw, MII_BMSR, &phy_status);
|
||||
if (ret_val)
|
||||
break;
|
||||
if (phy_status & MII_SR_LINK_STATUS)
|
||||
if (phy_status & BMSR_LSTATUS)
|
||||
break;
|
||||
if (usec_interval >= 1000)
|
||||
mdelay(usec_interval/1000);
|
||||
@ -1968,17 +1969,15 @@ s32 e1000e_get_phy_info_m88(struct e1000_hw *hw)
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_STATUS, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_STAT1000, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy->local_rx = (phy_data & SR_1000T_LOCAL_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->local_rx = (phy_data & LPA_1000LOCALRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
|
||||
phy->remote_rx = (phy_data & SR_1000T_REMOTE_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->remote_rx = (phy_data & LPA_1000REMRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
} else {
|
||||
/* Set values to "undefined" */
|
||||
phy->cable_length = E1000_CABLE_LENGTH_UNDEFINED;
|
||||
@ -2032,17 +2031,15 @@ s32 e1000e_get_phy_info_igp(struct e1000_hw *hw)
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_STATUS, &data);
|
||||
ret_val = e1e_rphy(hw, MII_STAT1000, &data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy->local_rx = (data & SR_1000T_LOCAL_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->local_rx = (data & LPA_1000LOCALRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
|
||||
phy->remote_rx = (data & SR_1000T_REMOTE_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->remote_rx = (data & LPA_1000REMRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
} else {
|
||||
phy->cable_length = E1000_CABLE_LENGTH_UNDEFINED;
|
||||
phy->local_rx = e1000_1000t_rx_status_undefined;
|
||||
@ -2116,12 +2113,12 @@ s32 e1000e_phy_sw_reset(struct e1000_hw *hw)
|
||||
s32 ret_val;
|
||||
u16 phy_ctrl;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_ctrl);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_ctrl);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy_ctrl |= MII_CR_RESET;
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_ctrl);
|
||||
phy_ctrl |= BMCR_RESET;
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_ctrl);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -2178,7 +2175,7 @@ s32 e1000e_phy_hw_reset_generic(struct e1000_hw *hw)
|
||||
* Generic function to wait 10 milli-seconds for configuration to complete
|
||||
* and return success.
|
||||
**/
|
||||
s32 e1000e_get_cfg_done_generic(struct e1000_hw *hw)
|
||||
s32 e1000e_get_cfg_done_generic(struct e1000_hw __always_unused *hw)
|
||||
{
|
||||
mdelay(10);
|
||||
|
||||
@ -2751,9 +2748,9 @@ void e1000_power_up_phy_copper(struct e1000_hw *hw)
|
||||
u16 mii_reg = 0;
|
||||
|
||||
/* The PHY will retain its settings across a power down/up cycle */
|
||||
e1e_rphy(hw, PHY_CONTROL, &mii_reg);
|
||||
mii_reg &= ~MII_CR_POWER_DOWN;
|
||||
e1e_wphy(hw, PHY_CONTROL, mii_reg);
|
||||
e1e_rphy(hw, MII_BMCR, &mii_reg);
|
||||
mii_reg &= ~BMCR_PDOWN;
|
||||
e1e_wphy(hw, MII_BMCR, mii_reg);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -2769,9 +2766,9 @@ void e1000_power_down_phy_copper(struct e1000_hw *hw)
|
||||
u16 mii_reg = 0;
|
||||
|
||||
/* The PHY will retain its settings across a power down/up cycle */
|
||||
e1e_rphy(hw, PHY_CONTROL, &mii_reg);
|
||||
mii_reg |= MII_CR_POWER_DOWN;
|
||||
e1e_wphy(hw, PHY_CONTROL, mii_reg);
|
||||
e1e_rphy(hw, MII_BMCR, &mii_reg);
|
||||
mii_reg |= BMCR_PDOWN;
|
||||
e1e_wphy(hw, MII_BMCR, mii_reg);
|
||||
usleep_range(1000, 2000);
|
||||
}
|
||||
|
||||
@ -3087,8 +3084,8 @@ s32 e1000_link_stall_workaround_hv(struct e1000_hw *hw)
|
||||
return 0;
|
||||
|
||||
/* Do not apply workaround if in PHY loopback bit 14 set */
|
||||
e1e_rphy(hw, PHY_CONTROL, &data);
|
||||
if (data & PHY_CONTROL_LB)
|
||||
e1e_rphy(hw, MII_BMCR, &data);
|
||||
if (data & BMCR_LOOPBACK)
|
||||
return 0;
|
||||
|
||||
/* check if link is up and at 1Gbps */
|
||||
@ -3106,8 +3103,9 @@ s32 e1000_link_stall_workaround_hv(struct e1000_hw *hw)
|
||||
msleep(200);
|
||||
|
||||
/* flush the packets in the fifo buffer */
|
||||
ret_val = e1e_wphy(hw, HV_MUX_DATA_CTRL, HV_MUX_DATA_CTRL_GEN_TO_MAC |
|
||||
HV_MUX_DATA_CTRL_FORCE_SPEED);
|
||||
ret_val = e1e_wphy(hw, HV_MUX_DATA_CTRL,
|
||||
(HV_MUX_DATA_CTRL_GEN_TO_MAC |
|
||||
HV_MUX_DATA_CTRL_FORCE_SPEED));
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -3151,13 +3149,13 @@ s32 e1000_phy_force_speed_duplex_82577(struct e1000_hw *hw)
|
||||
u16 phy_data;
|
||||
bool link;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_CONTROL, &phy_data);
|
||||
ret_val = e1e_rphy(hw, MII_BMCR, &phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
e1000e_phy_force_speed_duplex_setup(hw, &phy_data);
|
||||
|
||||
ret_val = e1e_wphy(hw, PHY_CONTROL, phy_data);
|
||||
ret_val = e1e_wphy(hw, MII_BMCR, phy_data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
@ -3225,17 +3223,15 @@ s32 e1000_get_phy_info_82577(struct e1000_hw *hw)
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
ret_val = e1e_rphy(hw, PHY_1000T_STATUS, &data);
|
||||
ret_val = e1e_rphy(hw, MII_STAT1000, &data);
|
||||
if (ret_val)
|
||||
return ret_val;
|
||||
|
||||
phy->local_rx = (data & SR_1000T_LOCAL_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->local_rx = (data & LPA_1000LOCALRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
|
||||
phy->remote_rx = (data & SR_1000T_REMOTE_RX_STATUS)
|
||||
? e1000_1000t_rx_status_ok
|
||||
: e1000_1000t_rx_status_not_ok;
|
||||
phy->remote_rx = (data & LPA_1000REMRXOK)
|
||||
? e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
|
||||
} else {
|
||||
phy->cable_length = E1000_CABLE_LENGTH_UNDEFINED;
|
||||
phy->local_rx = e1000_1000t_rx_status_undefined;
|
||||
|
@ -165,8 +165,9 @@ static int e1000e_phc_settime(struct ptp_clock_info *ptp,
|
||||
* Enable (or disable) ancillary features of the PHC subsystem.
|
||||
* Currently, no ancillary features are supported.
|
||||
**/
|
||||
static int e1000e_phc_enable(struct ptp_clock_info *ptp,
|
||||
struct ptp_clock_request *request, int on)
|
||||
static int e1000e_phc_enable(struct ptp_clock_info __always_unused *ptp,
|
||||
struct ptp_clock_request __always_unused *request,
|
||||
int __always_unused on)
|
||||
{
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
@ -41,7 +41,6 @@
|
||||
|
||||
static s32 ixgbe_setup_copper_link_82598(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_read_i2c_eeprom_82598(struct ixgbe_hw *hw, u8 byte_offset,
|
||||
u8 *eeprom_data);
|
||||
@ -633,15 +632,15 @@ out:
|
||||
* ixgbe_setup_mac_link_82598 - Set MAC link speed
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if auto-negotiation enabled
|
||||
* @autoneg_wait_to_complete: true when waiting for completion is needed
|
||||
*
|
||||
* Set the link speed in the AUTOC register and restarts link.
|
||||
**/
|
||||
static s32 ixgbe_setup_mac_link_82598(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed, bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
bool autoneg = false;
|
||||
s32 status = 0;
|
||||
ixgbe_link_speed link_capabilities = IXGBE_LINK_SPEED_UNKNOWN;
|
||||
u32 curr_autoc = IXGBE_READ_REG(hw, IXGBE_AUTOC);
|
||||
@ -685,20 +684,18 @@ static s32 ixgbe_setup_mac_link_82598(struct ixgbe_hw *hw,
|
||||
* ixgbe_setup_copper_link_82598 - Set the PHY autoneg advertised field
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true if waiting is needed to complete
|
||||
*
|
||||
* Sets the link speed in the AUTOC register in the MAC and restarts link.
|
||||
**/
|
||||
static s32 ixgbe_setup_copper_link_82598(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
s32 status;
|
||||
|
||||
/* Setup the PHY according to input speed */
|
||||
status = hw->phy.ops.setup_link_speed(hw, speed, autoneg,
|
||||
status = hw->phy.ops.setup_link_speed(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
/* Set up MAC */
|
||||
ixgbe_start_mac_link_82598(hw, autoneg_wait_to_complete);
|
||||
@ -1311,4 +1308,3 @@ struct ixgbe_info ixgbe_82598_info = {
|
||||
.eeprom_ops = &eeprom_ops_82598,
|
||||
.phy_ops = &phy_ops_82598,
|
||||
};
|
||||
|
||||
|
@ -45,21 +45,17 @@ static void ixgbe_enable_tx_laser_multispeed_fiber(struct ixgbe_hw *hw);
|
||||
static void ixgbe_flap_tx_laser_multispeed_fiber(struct ixgbe_hw *hw);
|
||||
static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_setup_mac_link_smartspeed(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_start_mac_link_82599(struct ixgbe_hw *hw,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_setup_mac_link_82599(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_setup_copper_link_82599(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
static s32 ixgbe_verify_fw_version_82599(struct ixgbe_hw *hw);
|
||||
|
||||
@ -234,13 +230,13 @@ static s32 ixgbe_init_phy_ops_82599(struct ixgbe_hw *hw)
|
||||
* ixgbe_get_link_capabilities_82599 - Determines link capabilities
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: pointer to link speed
|
||||
* @negotiation: true when autoneg or autotry is enabled
|
||||
* @autoneg: true when autoneg or autotry is enabled
|
||||
*
|
||||
* Determines the link capabilities by reading the AUTOC register.
|
||||
**/
|
||||
static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed *speed,
|
||||
bool *negotiation)
|
||||
bool *autoneg)
|
||||
{
|
||||
s32 status = 0;
|
||||
u32 autoc = 0;
|
||||
@ -251,7 +247,7 @@ static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core0 ||
|
||||
hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1) {
|
||||
*speed = IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = true;
|
||||
*autoneg = true;
|
||||
goto out;
|
||||
}
|
||||
|
||||
@ -268,22 +264,22 @@ static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
switch (autoc & IXGBE_AUTOC_LMS_MASK) {
|
||||
case IXGBE_AUTOC_LMS_1G_LINK_NO_AN:
|
||||
*speed = IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = false;
|
||||
*autoneg = false;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_10G_LINK_NO_AN:
|
||||
*speed = IXGBE_LINK_SPEED_10GB_FULL;
|
||||
*negotiation = false;
|
||||
*autoneg = false;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_1G_AN:
|
||||
*speed = IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = true;
|
||||
*autoneg = true;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_10G_SERIAL:
|
||||
*speed = IXGBE_LINK_SPEED_10GB_FULL;
|
||||
*negotiation = false;
|
||||
*autoneg = false;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_KX4_KX_KR:
|
||||
@ -295,7 +291,7 @@ static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
*speed |= IXGBE_LINK_SPEED_10GB_FULL;
|
||||
if (autoc & IXGBE_AUTOC_KX_SUPP)
|
||||
*speed |= IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = true;
|
||||
*autoneg = true;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_KX4_KX_KR_SGMII:
|
||||
@ -306,12 +302,12 @@ static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
*speed |= IXGBE_LINK_SPEED_10GB_FULL;
|
||||
if (autoc & IXGBE_AUTOC_KX_SUPP)
|
||||
*speed |= IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = true;
|
||||
*autoneg = true;
|
||||
break;
|
||||
|
||||
case IXGBE_AUTOC_LMS_SGMII_1G_100M:
|
||||
*speed = IXGBE_LINK_SPEED_1GB_FULL | IXGBE_LINK_SPEED_100_FULL;
|
||||
*negotiation = false;
|
||||
*autoneg = false;
|
||||
break;
|
||||
|
||||
default:
|
||||
@ -323,7 +319,7 @@ static s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
|
||||
if (hw->phy.multispeed_fiber) {
|
||||
*speed |= IXGBE_LINK_SPEED_10GB_FULL |
|
||||
IXGBE_LINK_SPEED_1GB_FULL;
|
||||
*negotiation = true;
|
||||
*autoneg = true;
|
||||
}
|
||||
|
||||
out:
|
||||
@ -510,14 +506,12 @@ static void ixgbe_flap_tx_laser_multispeed_fiber(struct ixgbe_hw *hw)
|
||||
* ixgbe_setup_mac_link_multispeed_fiber - Set MAC link speed
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true when waiting for completion is needed
|
||||
*
|
||||
* Set the link speed in the AUTOC register and restarts link.
|
||||
**/
|
||||
static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
s32 status = 0;
|
||||
@ -527,11 +521,11 @@ static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
u32 esdp_reg = IXGBE_READ_REG(hw, IXGBE_ESDP);
|
||||
u32 i = 0;
|
||||
bool link_up = false;
|
||||
bool negotiation;
|
||||
bool autoneg = false;
|
||||
|
||||
/* Mask off requested but non-supported speeds */
|
||||
status = hw->mac.ops.get_link_capabilities(hw, &link_speed,
|
||||
&negotiation);
|
||||
&autoneg);
|
||||
if (status != 0)
|
||||
return status;
|
||||
|
||||
@ -564,7 +558,6 @@ static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
|
||||
status = ixgbe_setup_mac_link_82599(hw,
|
||||
IXGBE_LINK_SPEED_10GB_FULL,
|
||||
autoneg,
|
||||
autoneg_wait_to_complete);
|
||||
if (status != 0)
|
||||
return status;
|
||||
@ -617,7 +610,6 @@ static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
|
||||
status = ixgbe_setup_mac_link_82599(hw,
|
||||
IXGBE_LINK_SPEED_1GB_FULL,
|
||||
autoneg,
|
||||
autoneg_wait_to_complete);
|
||||
if (status != 0)
|
||||
return status;
|
||||
@ -646,7 +638,6 @@ static s32 ixgbe_setup_mac_link_multispeed_fiber(struct ixgbe_hw *hw,
|
||||
if (speedcnt > 1)
|
||||
status = ixgbe_setup_mac_link_multispeed_fiber(hw,
|
||||
highest_link_speed,
|
||||
autoneg,
|
||||
autoneg_wait_to_complete);
|
||||
|
||||
out:
|
||||
@ -666,13 +657,12 @@ out:
|
||||
* ixgbe_setup_mac_link_smartspeed - Set MAC link speed using SmartSpeed
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true when waiting for completion is needed
|
||||
*
|
||||
* Implements the Intel SmartSpeed algorithm.
|
||||
**/
|
||||
static s32 ixgbe_setup_mac_link_smartspeed(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed, bool autoneg,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
s32 status = 0;
|
||||
@ -703,7 +693,7 @@ static s32 ixgbe_setup_mac_link_smartspeed(struct ixgbe_hw *hw,
|
||||
/* First, try to get link with full advertisement */
|
||||
hw->phy.smart_speed_active = false;
|
||||
for (j = 0; j < IXGBE_SMARTSPEED_MAX_RETRIES; j++) {
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed, autoneg,
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
if (status != 0)
|
||||
goto out;
|
||||
@ -738,7 +728,7 @@ static s32 ixgbe_setup_mac_link_smartspeed(struct ixgbe_hw *hw,
|
||||
|
||||
/* Turn SmartSpeed on to disable KR support */
|
||||
hw->phy.smart_speed_active = true;
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed, autoneg,
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
if (status != 0)
|
||||
goto out;
|
||||
@ -764,7 +754,7 @@ static s32 ixgbe_setup_mac_link_smartspeed(struct ixgbe_hw *hw,
|
||||
|
||||
/* We didn't get link. Turn SmartSpeed back off. */
|
||||
hw->phy.smart_speed_active = false;
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed, autoneg,
|
||||
status = ixgbe_setup_mac_link_82599(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
|
||||
out:
|
||||
@ -778,14 +768,13 @@ out:
|
||||
* ixgbe_setup_mac_link_82599 - Set MAC link speed
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true when waiting for completion is needed
|
||||
*
|
||||
* Set the link speed in the AUTOC register and restarts link.
|
||||
**/
|
||||
static s32 ixgbe_setup_mac_link_82599(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed, bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
s32 status = 0;
|
||||
u32 autoc = IXGBE_READ_REG(hw, IXGBE_AUTOC);
|
||||
@ -799,6 +788,7 @@ static s32 ixgbe_setup_mac_link_82599(struct ixgbe_hw *hw,
|
||||
u32 i;
|
||||
ixgbe_link_speed link_capabilities = IXGBE_LINK_SPEED_UNKNOWN;
|
||||
bool got_lock = false;
|
||||
bool autoneg = false;
|
||||
|
||||
/* Check to see if speed passed in is supported. */
|
||||
status = hw->mac.ops.get_link_capabilities(hw, &link_capabilities,
|
||||
@ -911,20 +901,18 @@ out:
|
||||
* ixgbe_setup_copper_link_82599 - Set the PHY autoneg advertised field
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true if waiting is needed to complete
|
||||
*
|
||||
* Restarts link on PHY and MAC based on settings passed in.
|
||||
**/
|
||||
static s32 ixgbe_setup_copper_link_82599(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
s32 status;
|
||||
|
||||
/* Setup the PHY according to input speed */
|
||||
status = hw->phy.ops.setup_link_speed(hw, speed, autoneg,
|
||||
status = hw->phy.ops.setup_link_speed(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
/* Set up MAC */
|
||||
ixgbe_start_mac_link_82599(hw, autoneg_wait_to_complete);
|
||||
|
@ -302,7 +302,6 @@ static void ixgbe_dcbnl_get_pfc_cfg(struct net_device *netdev, int priority,
|
||||
*setting = adapter->dcb_cfg.tc_config[priority].dcb_pfc;
|
||||
}
|
||||
|
||||
#ifdef IXGBE_FCOE
|
||||
static void ixgbe_dcbnl_devreset(struct net_device *dev)
|
||||
{
|
||||
struct ixgbe_adapter *adapter = netdev_priv(dev);
|
||||
@ -321,7 +320,6 @@ static void ixgbe_dcbnl_devreset(struct net_device *dev)
|
||||
|
||||
clear_bit(__IXGBE_RESETTING, &adapter->state);
|
||||
}
|
||||
#endif
|
||||
|
||||
static u8 ixgbe_dcbnl_set_all(struct net_device *netdev)
|
||||
{
|
||||
@ -542,6 +540,7 @@ static int ixgbe_dcbnl_ieee_setets(struct net_device *dev,
|
||||
int max_frame = dev->mtu + ETH_HLEN + ETH_FCS_LEN;
|
||||
int i, err = 0;
|
||||
__u8 max_tc = 0;
|
||||
__u8 map_chg = 0;
|
||||
|
||||
if (!(adapter->dcbx_cap & DCB_CAP_DCBX_VER_IEEE))
|
||||
return -EINVAL;
|
||||
@ -551,15 +550,22 @@ static int ixgbe_dcbnl_ieee_setets(struct net_device *dev,
|
||||
GFP_KERNEL);
|
||||
if (!adapter->ixgbe_ieee_ets)
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
memcpy(adapter->ixgbe_ieee_ets, ets, sizeof(*adapter->ixgbe_ieee_ets));
|
||||
/* initialize UP2TC mappings to invalid value */
|
||||
for (i = 0; i < IEEE_8021QAZ_MAX_TCS; i++)
|
||||
adapter->ixgbe_ieee_ets->prio_tc[i] =
|
||||
IEEE_8021QAZ_MAX_TCS;
|
||||
}
|
||||
|
||||
for (i = 0; i < IEEE_8021QAZ_MAX_TCS; i++) {
|
||||
if (ets->prio_tc[i] > max_tc)
|
||||
max_tc = ets->prio_tc[i];
|
||||
if (ets->prio_tc[i] != adapter->ixgbe_ieee_ets->prio_tc[i])
|
||||
map_chg = 1;
|
||||
}
|
||||
|
||||
memcpy(adapter->ixgbe_ieee_ets, ets, sizeof(*adapter->ixgbe_ieee_ets));
|
||||
|
||||
if (max_tc)
|
||||
max_tc++;
|
||||
|
||||
@ -568,6 +574,8 @@ static int ixgbe_dcbnl_ieee_setets(struct net_device *dev,
|
||||
|
||||
if (max_tc != netdev_get_num_tc(dev))
|
||||
err = ixgbe_setup_tc(dev, max_tc);
|
||||
else if (map_chg)
|
||||
ixgbe_dcbnl_devreset(dev);
|
||||
|
||||
if (err)
|
||||
goto err_out;
|
||||
|
@ -156,7 +156,7 @@ static int ixgbe_get_settings(struct net_device *netdev,
|
||||
struct ixgbe_hw *hw = &adapter->hw;
|
||||
ixgbe_link_speed supported_link;
|
||||
u32 link_speed = 0;
|
||||
bool autoneg;
|
||||
bool autoneg = false;
|
||||
bool link_up;
|
||||
|
||||
hw->mac.ops.get_link_capabilities(hw, &supported_link, &autoneg);
|
||||
@ -333,10 +333,10 @@ static int ixgbe_set_settings(struct net_device *netdev,
|
||||
return err;
|
||||
/* this sets the link speed and restarts auto-neg */
|
||||
hw->mac.autotry_restart = true;
|
||||
err = hw->mac.ops.setup_link(hw, advertised, true, true);
|
||||
err = hw->mac.ops.setup_link(hw, advertised, true);
|
||||
if (err) {
|
||||
e_info(probe, "setup link failed with code %d\n", err);
|
||||
hw->mac.ops.setup_link(hw, old, true, true);
|
||||
hw->mac.ops.setup_link(hw, old, true);
|
||||
}
|
||||
} else {
|
||||
/* in this case we currently only support 10Gb/FULL */
|
||||
|
@ -2178,10 +2178,10 @@ static void ixgbe_check_overtemp_subtask(struct ixgbe_adapter *adapter)
|
||||
return;
|
||||
|
||||
if (!(eicr & IXGBE_EICR_LSC) && hw->mac.ops.check_link) {
|
||||
u32 autoneg;
|
||||
u32 speed;
|
||||
bool link_up = false;
|
||||
|
||||
hw->mac.ops.check_link(hw, &autoneg, &link_up, false);
|
||||
hw->mac.ops.check_link(hw, &speed, &link_up, false);
|
||||
|
||||
if (link_up)
|
||||
return;
|
||||
@ -3994,25 +3994,25 @@ static void ixgbe_sfp_link_config(struct ixgbe_adapter *adapter)
|
||||
**/
|
||||
static int ixgbe_non_sfp_link_config(struct ixgbe_hw *hw)
|
||||
{
|
||||
u32 autoneg;
|
||||
bool negotiation, link_up = false;
|
||||
u32 speed;
|
||||
bool autoneg, link_up = false;
|
||||
u32 ret = IXGBE_ERR_LINK_SETUP;
|
||||
|
||||
if (hw->mac.ops.check_link)
|
||||
ret = hw->mac.ops.check_link(hw, &autoneg, &link_up, false);
|
||||
ret = hw->mac.ops.check_link(hw, &speed, &link_up, false);
|
||||
|
||||
if (ret)
|
||||
goto link_cfg_out;
|
||||
|
||||
autoneg = hw->phy.autoneg_advertised;
|
||||
if ((!autoneg) && (hw->mac.ops.get_link_capabilities))
|
||||
ret = hw->mac.ops.get_link_capabilities(hw, &autoneg,
|
||||
&negotiation);
|
||||
speed = hw->phy.autoneg_advertised;
|
||||
if ((!speed) && (hw->mac.ops.get_link_capabilities))
|
||||
ret = hw->mac.ops.get_link_capabilities(hw, &speed,
|
||||
&autoneg);
|
||||
if (ret)
|
||||
goto link_cfg_out;
|
||||
|
||||
if (hw->mac.ops.setup_link)
|
||||
ret = hw->mac.ops.setup_link(hw, autoneg, negotiation, link_up);
|
||||
ret = hw->mac.ops.setup_link(hw, speed, link_up);
|
||||
link_cfg_out:
|
||||
return ret;
|
||||
}
|
||||
@ -5739,8 +5739,8 @@ sfp_out:
|
||||
static void ixgbe_sfp_link_config_subtask(struct ixgbe_adapter *adapter)
|
||||
{
|
||||
struct ixgbe_hw *hw = &adapter->hw;
|
||||
u32 autoneg;
|
||||
bool negotiation;
|
||||
u32 speed;
|
||||
bool autoneg = false;
|
||||
|
||||
if (!(adapter->flags & IXGBE_FLAG_NEED_LINK_CONFIG))
|
||||
return;
|
||||
@ -5751,11 +5751,11 @@ static void ixgbe_sfp_link_config_subtask(struct ixgbe_adapter *adapter)
|
||||
|
||||
adapter->flags &= ~IXGBE_FLAG_NEED_LINK_CONFIG;
|
||||
|
||||
autoneg = hw->phy.autoneg_advertised;
|
||||
if ((!autoneg) && (hw->mac.ops.get_link_capabilities))
|
||||
hw->mac.ops.get_link_capabilities(hw, &autoneg, &negotiation);
|
||||
speed = hw->phy.autoneg_advertised;
|
||||
if ((!speed) && (hw->mac.ops.get_link_capabilities))
|
||||
hw->mac.ops.get_link_capabilities(hw, &speed, &autoneg);
|
||||
if (hw->mac.ops.setup_link)
|
||||
hw->mac.ops.setup_link(hw, autoneg, negotiation, true);
|
||||
hw->mac.ops.setup_link(hw, speed, true);
|
||||
|
||||
adapter->flags |= IXGBE_FLAG_NEED_LINK_UPDATE;
|
||||
adapter->link_check_timeout = jiffies;
|
||||
@ -7758,6 +7758,8 @@ static pci_ers_result_t ixgbe_io_error_detected(struct pci_dev *pdev,
|
||||
if (vfdev) {
|
||||
e_dev_err("Issuing VFLR to VF %d\n", vf);
|
||||
pci_write_config_dword(vfdev, 0xA8, 0x00008000);
|
||||
/* Free device reference count */
|
||||
pci_dev_put(vfdev);
|
||||
}
|
||||
|
||||
pci_cleanup_aer_uncorrect_error_status(pdev);
|
||||
|
@ -494,11 +494,9 @@ s32 ixgbe_setup_phy_link_generic(struct ixgbe_hw *hw)
|
||||
* ixgbe_setup_phy_link_speed_generic - Sets the auto advertised capabilities
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
**/
|
||||
s32 ixgbe_setup_phy_link_speed_generic(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
|
||||
|
@ -98,7 +98,6 @@ s32 ixgbe_write_phy_reg_generic(struct ixgbe_hw *hw, u32 reg_addr,
|
||||
s32 ixgbe_setup_phy_link_generic(struct ixgbe_hw *hw);
|
||||
s32 ixgbe_setup_phy_link_speed_generic(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg,
|
||||
bool autoneg_wait_to_complete);
|
||||
s32 ixgbe_get_copper_link_capabilities_generic(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed *speed,
|
||||
|
@ -2822,7 +2822,7 @@ struct ixgbe_mac_operations {
|
||||
void (*disable_tx_laser)(struct ixgbe_hw *);
|
||||
void (*enable_tx_laser)(struct ixgbe_hw *);
|
||||
void (*flap_tx_laser)(struct ixgbe_hw *);
|
||||
s32 (*setup_link)(struct ixgbe_hw *, ixgbe_link_speed, bool, bool);
|
||||
s32 (*setup_link)(struct ixgbe_hw *, ixgbe_link_speed, bool);
|
||||
s32 (*check_link)(struct ixgbe_hw *, ixgbe_link_speed *, bool *, bool);
|
||||
s32 (*get_link_capabilities)(struct ixgbe_hw *, ixgbe_link_speed *,
|
||||
bool *);
|
||||
@ -2869,8 +2869,7 @@ struct ixgbe_phy_operations {
|
||||
s32 (*read_reg)(struct ixgbe_hw *, u32, u32, u16 *);
|
||||
s32 (*write_reg)(struct ixgbe_hw *, u32, u32, u16);
|
||||
s32 (*setup_link)(struct ixgbe_hw *);
|
||||
s32 (*setup_link_speed)(struct ixgbe_hw *, ixgbe_link_speed, bool,
|
||||
bool);
|
||||
s32 (*setup_link_speed)(struct ixgbe_hw *, ixgbe_link_speed, bool);
|
||||
s32 (*check_link)(struct ixgbe_hw *, ixgbe_link_speed *, bool *);
|
||||
s32 (*get_firmware_version)(struct ixgbe_hw *, u16 *);
|
||||
s32 (*read_i2c_byte)(struct ixgbe_hw *, u8, u8, u8 *);
|
||||
|
@ -72,14 +72,13 @@ static s32 ixgbe_get_invariants_X540(struct ixgbe_hw *hw)
|
||||
* ixgbe_setup_mac_link_X540 - Set the auto advertised capabilitires
|
||||
* @hw: pointer to hardware structure
|
||||
* @speed: new link speed
|
||||
* @autoneg: true if autonegotiation enabled
|
||||
* @autoneg_wait_to_complete: true when waiting for completion is needed
|
||||
**/
|
||||
static s32 ixgbe_setup_mac_link_X540(struct ixgbe_hw *hw,
|
||||
ixgbe_link_speed speed, bool autoneg,
|
||||
bool autoneg_wait_to_complete)
|
||||
ixgbe_link_speed speed,
|
||||
bool autoneg_wait_to_complete)
|
||||
{
|
||||
return hw->phy.ops.setup_link_speed(hw, speed, autoneg,
|
||||
return hw->phy.ops.setup_link_speed(hw, speed,
|
||||
autoneg_wait_to_complete);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user