Commit e8b03391 authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'net-lan743x-pci11010-pci11414-devices-enhancements'

Raju Lakkaraju says:

====================
net: lan743x: PCI11010 / PCI11414 devices Enhancements

This patch series continues with the addition of supported features
for the Ethernet function of the PCI11010 / PCI11414 devices to
the LAN743x driver.
====================

Link: https://lore.kernel.org/r/20220616041226.26996-1-Raju.Lakkaraju@microchip.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents f0502724 311abcdd
...@@ -155,8 +155,8 @@ static int lan743x_otp_write(struct lan743x_adapter *adapter, u32 offset, ...@@ -155,8 +155,8 @@ static int lan743x_otp_write(struct lan743x_adapter *adapter, u32 offset,
return 0; return 0;
} }
static int lan743x_hs_syslock_acquire(struct lan743x_adapter *adapter, int lan743x_hs_syslock_acquire(struct lan743x_adapter *adapter,
u16 timeout) u16 timeout)
{ {
u16 timeout_cnt = 0; u16 timeout_cnt = 0;
u32 val; u32 val;
...@@ -192,7 +192,7 @@ static int lan743x_hs_syslock_acquire(struct lan743x_adapter *adapter, ...@@ -192,7 +192,7 @@ static int lan743x_hs_syslock_acquire(struct lan743x_adapter *adapter,
return 0; return 0;
} }
static void lan743x_hs_syslock_release(struct lan743x_adapter *adapter) void lan743x_hs_syslock_release(struct lan743x_adapter *adapter)
{ {
u32 val; u32 val;
...@@ -1149,7 +1149,12 @@ static void lan743x_ethtool_get_wol(struct net_device *netdev, ...@@ -1149,7 +1149,12 @@ static void lan743x_ethtool_get_wol(struct net_device *netdev,
wol->supported |= WAKE_BCAST | WAKE_UCAST | WAKE_MCAST | wol->supported |= WAKE_BCAST | WAKE_UCAST | WAKE_MCAST |
WAKE_MAGIC | WAKE_PHY | WAKE_ARP; WAKE_MAGIC | WAKE_PHY | WAKE_ARP;
if (adapter->is_pci11x1x)
wol->supported |= WAKE_MAGICSECURE;
wol->wolopts |= adapter->wolopts; wol->wolopts |= adapter->wolopts;
if (adapter->wolopts & WAKE_MAGICSECURE)
memcpy(wol->sopass, adapter->sopass, sizeof(wol->sopass));
} }
static int lan743x_ethtool_set_wol(struct net_device *netdev, static int lan743x_ethtool_set_wol(struct net_device *netdev,
...@@ -1170,6 +1175,13 @@ static int lan743x_ethtool_set_wol(struct net_device *netdev, ...@@ -1170,6 +1175,13 @@ static int lan743x_ethtool_set_wol(struct net_device *netdev,
adapter->wolopts |= WAKE_PHY; adapter->wolopts |= WAKE_PHY;
if (wol->wolopts & WAKE_ARP) if (wol->wolopts & WAKE_ARP)
adapter->wolopts |= WAKE_ARP; adapter->wolopts |= WAKE_ARP;
if (wol->wolopts & WAKE_MAGICSECURE &&
wol->wolopts & WAKE_MAGIC) {
memcpy(adapter->sopass, wol->sopass, sizeof(wol->sopass));
adapter->wolopts |= WAKE_MAGICSECURE;
} else {
memset(adapter->sopass, 0, sizeof(u8) * SOPASS_MAX);
}
device_set_wakeup_enable(&adapter->pdev->dev, (bool)wol->wolopts); device_set_wakeup_enable(&adapter->pdev->dev, (bool)wol->wolopts);
...@@ -1178,6 +1190,49 @@ static int lan743x_ethtool_set_wol(struct net_device *netdev, ...@@ -1178,6 +1190,49 @@ static int lan743x_ethtool_set_wol(struct net_device *netdev,
} }
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
static void lan743x_common_regs(struct net_device *dev,
struct ethtool_regs *regs, void *p)
{
struct lan743x_adapter *adapter = netdev_priv(dev);
u32 *rb = p;
memset(p, 0, (MAX_LAN743X_ETH_REGS * sizeof(u32)));
rb[ETH_PRIV_FLAGS] = adapter->flags;
rb[ETH_ID_REV] = lan743x_csr_read(adapter, ID_REV);
rb[ETH_FPGA_REV] = lan743x_csr_read(adapter, FPGA_REV);
rb[ETH_STRAP_READ] = lan743x_csr_read(adapter, STRAP_READ);
rb[ETH_INT_STS] = lan743x_csr_read(adapter, INT_STS);
rb[ETH_HW_CFG] = lan743x_csr_read(adapter, HW_CFG);
rb[ETH_PMT_CTL] = lan743x_csr_read(adapter, PMT_CTL);
rb[ETH_E2P_CMD] = lan743x_csr_read(adapter, E2P_CMD);
rb[ETH_E2P_DATA] = lan743x_csr_read(adapter, E2P_DATA);
rb[ETH_MAC_CR] = lan743x_csr_read(adapter, MAC_CR);
rb[ETH_MAC_RX] = lan743x_csr_read(adapter, MAC_RX);
rb[ETH_MAC_TX] = lan743x_csr_read(adapter, MAC_TX);
rb[ETH_FLOW] = lan743x_csr_read(adapter, MAC_FLOW);
rb[ETH_MII_ACC] = lan743x_csr_read(adapter, MAC_MII_ACC);
rb[ETH_MII_DATA] = lan743x_csr_read(adapter, MAC_MII_DATA);
rb[ETH_EEE_TX_LPI_REQ_DLY] = lan743x_csr_read(adapter,
MAC_EEE_TX_LPI_REQ_DLY_CNT);
rb[ETH_WUCSR] = lan743x_csr_read(adapter, MAC_WUCSR);
rb[ETH_WK_SRC] = lan743x_csr_read(adapter, MAC_WK_SRC);
}
static int lan743x_get_regs_len(struct net_device *dev)
{
return MAX_LAN743X_ETH_REGS * sizeof(u32);
}
static void lan743x_get_regs(struct net_device *dev,
struct ethtool_regs *regs, void *p)
{
regs->version = LAN743X_ETH_REG_VERSION;
lan743x_common_regs(dev, regs, p);
}
const struct ethtool_ops lan743x_ethtool_ops = { const struct ethtool_ops lan743x_ethtool_ops = {
.get_drvinfo = lan743x_ethtool_get_drvinfo, .get_drvinfo = lan743x_ethtool_get_drvinfo,
.get_msglevel = lan743x_ethtool_get_msglevel, .get_msglevel = lan743x_ethtool_get_msglevel,
...@@ -1202,6 +1257,8 @@ const struct ethtool_ops lan743x_ethtool_ops = { ...@@ -1202,6 +1257,8 @@ const struct ethtool_ops lan743x_ethtool_ops = {
.set_eee = lan743x_ethtool_set_eee, .set_eee = lan743x_ethtool_set_eee,
.get_link_ksettings = phy_ethtool_get_link_ksettings, .get_link_ksettings = phy_ethtool_get_link_ksettings,
.set_link_ksettings = phy_ethtool_set_link_ksettings, .set_link_ksettings = phy_ethtool_set_link_ksettings,
.get_regs_len = lan743x_get_regs_len,
.get_regs = lan743x_get_regs,
#ifdef CONFIG_PM #ifdef CONFIG_PM
.get_wol = lan743x_ethtool_get_wol, .get_wol = lan743x_ethtool_get_wol,
.set_wol = lan743x_ethtool_set_wol, .set_wol = lan743x_ethtool_set_wol,
......
...@@ -6,6 +6,32 @@ ...@@ -6,6 +6,32 @@
#include "linux/ethtool.h" #include "linux/ethtool.h"
#define LAN743X_ETH_REG_VERSION 1
enum {
ETH_PRIV_FLAGS,
ETH_ID_REV,
ETH_FPGA_REV,
ETH_STRAP_READ,
ETH_INT_STS,
ETH_HW_CFG,
ETH_PMT_CTL,
ETH_E2P_CMD,
ETH_E2P_DATA,
ETH_MAC_CR,
ETH_MAC_RX,
ETH_MAC_TX,
ETH_FLOW,
ETH_MII_ACC,
ETH_MII_DATA,
ETH_EEE_TX_LPI_REQ_DLY,
ETH_WUCSR,
ETH_WK_SRC,
/* Add new registers above */
MAX_LAN743X_ETH_REGS
};
extern const struct ethtool_ops lan743x_ethtool_ops; extern const struct ethtool_ops lan743x_ethtool_ops;
#endif /* _LAN743X_ETHTOOL_H */ #endif /* _LAN743X_ETHTOOL_H */
...@@ -43,6 +43,11 @@ ...@@ -43,6 +43,11 @@
#define STRAP_READ_ADV_PM_DISABLE_ BIT(0) #define STRAP_READ_ADV_PM_DISABLE_ BIT(0)
#define HW_CFG (0x010) #define HW_CFG (0x010)
#define HW_CFG_RST_PROTECT_PCIE_ BIT(19)
#define HW_CFG_HOT_RESET_DIS_ BIT(15)
#define HW_CFG_D3_VAUX_OVR_ BIT(14)
#define HW_CFG_D3_RESET_DIS_ BIT(13)
#define HW_CFG_RST_PROTECT_ BIT(12)
#define HW_CFG_RELOAD_TYPE_ALL_ (0x00000FC0) #define HW_CFG_RELOAD_TYPE_ALL_ (0x00000FC0)
#define HW_CFG_EE_OTP_RELOAD_ BIT(4) #define HW_CFG_EE_OTP_RELOAD_ BIT(4)
#define HW_CFG_LRST_ BIT(1) #define HW_CFG_LRST_ BIT(1)
...@@ -92,6 +97,11 @@ ...@@ -92,6 +97,11 @@
#define CONFIG_REG_ADDR_BASE (0x0000) #define CONFIG_REG_ADDR_BASE (0x0000)
#define ETH_EEPROM_REG_ADDR_BASE (0x0E00) #define ETH_EEPROM_REG_ADDR_BASE (0x0E00)
#define ETH_OTP_REG_ADDR_BASE (0x1000) #define ETH_OTP_REG_ADDR_BASE (0x1000)
#define GEN_SYS_CONFIG_LOAD_STARTED_REG (0x0078)
#define ETH_SYS_CONFIG_LOAD_STARTED_REG (ETH_SYS_REG_ADDR_BASE + \
CONFIG_REG_ADDR_BASE + \
GEN_SYS_CONFIG_LOAD_STARTED_REG)
#define GEN_SYS_LOAD_STARTED_REG_ETH_ BIT(4)
#define SYS_LOCK_REG (0x00A0) #define SYS_LOCK_REG (0x00A0)
#define SYS_LOCK_REG_MAIN_LOCK_ BIT(7) #define SYS_LOCK_REG_MAIN_LOCK_ BIT(7)
#define SYS_LOCK_REG_GEN_PERI_LOCK_ BIT(5) #define SYS_LOCK_REG_GEN_PERI_LOCK_ BIT(5)
...@@ -214,6 +224,7 @@ ...@@ -214,6 +224,7 @@
#define MAC_EEE_TX_LPI_REQ_DLY_CNT (0x130) #define MAC_EEE_TX_LPI_REQ_DLY_CNT (0x130)
#define MAC_WUCSR (0x140) #define MAC_WUCSR (0x140)
#define MAC_MP_SO_EN_ BIT(21)
#define MAC_WUCSR_RFE_WAKE_EN_ BIT(14) #define MAC_WUCSR_RFE_WAKE_EN_ BIT(14)
#define MAC_WUCSR_PFDA_EN_ BIT(3) #define MAC_WUCSR_PFDA_EN_ BIT(3)
#define MAC_WUCSR_WAKE_EN_ BIT(2) #define MAC_WUCSR_WAKE_EN_ BIT(2)
...@@ -221,6 +232,8 @@ ...@@ -221,6 +232,8 @@
#define MAC_WUCSR_BCST_EN_ BIT(0) #define MAC_WUCSR_BCST_EN_ BIT(0)
#define MAC_WK_SRC (0x144) #define MAC_WK_SRC (0x144)
#define MAC_MP_SO_HI (0x148)
#define MAC_MP_SO_LO (0x14C)
#define MAC_WUF_CFG0 (0x150) #define MAC_WUF_CFG0 (0x150)
#define MAC_NUM_OF_WUF_CFG (32) #define MAC_NUM_OF_WUF_CFG (32)
...@@ -280,11 +293,82 @@ ...@@ -280,11 +293,82 @@
#define MAC_WUCSR2 (0x600) #define MAC_WUCSR2 (0x600)
#define SGMII_ACC (0x720)
#define SGMII_ACC_SGMII_BZY_ BIT(31)
#define SGMII_ACC_SGMII_WR_ BIT(30)
#define SGMII_ACC_SGMII_MMD_SHIFT_ (16)
#define SGMII_ACC_SGMII_MMD_MASK_ GENMASK(20, 16)
#define SGMII_ACC_SGMII_MMD_VSR_ BIT(15)
#define SGMII_ACC_SGMII_ADDR_SHIFT_ (0)
#define SGMII_ACC_SGMII_ADDR_MASK_ GENMASK(15, 0)
#define SGMII_DATA (0x724)
#define SGMII_DATA_SHIFT_ (0)
#define SGMII_DATA_MASK_ GENMASK(15, 0)
#define SGMII_CTL (0x728) #define SGMII_CTL (0x728)
#define SGMII_CTL_SGMII_ENABLE_ BIT(31) #define SGMII_CTL_SGMII_ENABLE_ BIT(31)
#define SGMII_CTL_LINK_STATUS_SOURCE_ BIT(8) #define SGMII_CTL_LINK_STATUS_SOURCE_ BIT(8)
#define SGMII_CTL_SGMII_POWER_DN_ BIT(1) #define SGMII_CTL_SGMII_POWER_DN_ BIT(1)
/* Vendor Specific SGMII MMD details */
#define SR_VSMMD_PCS_ID1 0x0004
#define SR_VSMMD_PCS_ID2 0x0005
#define SR_VSMMD_STS 0x0008
#define SR_VSMMD_CTRL 0x0009
#define VR_MII_DIG_CTRL1 0x8000
#define VR_MII_DIG_CTRL1_VR_RST_ BIT(15)
#define VR_MII_DIG_CTRL1_R2TLBE_ BIT(14)
#define VR_MII_DIG_CTRL1_EN_VSMMD1_ BIT(13)
#define VR_MII_DIG_CTRL1_CS_EN_ BIT(10)
#define VR_MII_DIG_CTRL1_MAC_AUTO_SW_ BIT(9)
#define VR_MII_DIG_CTRL1_INIT_ BIT(8)
#define VR_MII_DIG_CTRL1_DTXLANED_0_ BIT(4)
#define VR_MII_DIG_CTRL1_CL37_TMR_OVR_RIDE_ BIT(3)
#define VR_MII_DIG_CTRL1_EN_2_5G_MODE_ BIT(2)
#define VR_MII_DIG_CTRL1_BYP_PWRUP_ BIT(1)
#define VR_MII_DIG_CTRL1_PHY_MODE_CTRL_ BIT(0)
#define VR_MII_AN_CTRL 0x8001
#define VR_MII_AN_CTRL_MII_CTRL_ BIT(8)
#define VR_MII_AN_CTRL_SGMII_LINK_STS_ BIT(4)
#define VR_MII_AN_CTRL_TX_CONFIG_ BIT(3)
#define VR_MII_AN_CTRL_1000BASE_X_ (0)
#define VR_MII_AN_CTRL_SGMII_MODE_ (2)
#define VR_MII_AN_CTRL_QSGMII_MODE_ (3)
#define VR_MII_AN_CTRL_PCS_MODE_SHIFT_ (1)
#define VR_MII_AN_CTRL_PCS_MODE_MASK_ GENMASK(2, 1)
#define VR_MII_AN_CTRL_MII_AN_INTR_EN_ BIT(0)
#define VR_MII_AN_INTR_STS 0x8002
#define VR_MII_AN_INTR_STS_LINK_UP_ BIT(4)
#define VR_MII_AN_INTR_STS_SPEED_MASK_ GENMASK(3, 2)
#define VR_MII_AN_INTR_STS_1000_MBPS_ BIT(3)
#define VR_MII_AN_INTR_STS_100_MBPS_ BIT(2)
#define VR_MII_AN_INTR_STS_10_MBPS_ (0)
#define VR_MII_AN_INTR_STS_FDX_ BIT(1)
#define VR_MII_AN_INTR_STS_CL37_ANCMPLT_INTR_ BIT(0)
#define VR_MII_LINK_TIMER_CTRL 0x800A
#define VR_MII_DIG_STS 0x8010
#define VR_MII_DIG_STS_PSEQ_STATE_MASK_ GENMASK(4, 2)
#define VR_MII_DIG_STS_PSEQ_STATE_POS_ (2)
#define VR_MII_GEN2_4_MPLL_CTRL0 0x8078
#define VR_MII_MPLL_CTRL0_REF_CLK_DIV2_ BIT(12)
#define VR_MII_MPLL_CTRL0_USE_REFCLK_PAD_ BIT(4)
#define VR_MII_GEN2_4_MPLL_CTRL1 0x8079
#define VR_MII_MPLL_CTRL1_MPLL_MULTIPLIER_ GENMASK(6, 0)
#define VR_MII_BAUD_RATE_3P125GBPS (3125)
#define VR_MII_BAUD_RATE_1P25GBPS (1250)
#define VR_MII_MPLL_MULTIPLIER_125 (125)
#define VR_MII_MPLL_MULTIPLIER_100 (100)
#define VR_MII_MPLL_MULTIPLIER_50 (50)
#define VR_MII_MPLL_MULTIPLIER_40 (40)
#define VR_MII_GEN2_4_MISC_CTRL1 0x809A
#define VR_MII_CTRL1_RX_RATE_0_MASK_ GENMASK(3, 2)
#define VR_MII_CTRL1_RX_RATE_0_SHIFT_ (2)
#define VR_MII_CTRL1_TX_RATE_0_MASK_ GENMASK(1, 0)
#define VR_MII_MPLL_BAUD_CLK (0)
#define VR_MII_MPLL_BAUD_CLK_DIV_2 (1)
#define VR_MII_MPLL_BAUD_CLK_DIV_4 (2)
#define INT_STS (0x780) #define INT_STS (0x780)
#define INT_BIT_DMA_RX_(channel) BIT(24 + (channel)) #define INT_BIT_DMA_RX_(channel) BIT(24 + (channel))
#define INT_BIT_ALL_RX_ (0x0F000000) #define INT_BIT_ALL_RX_ (0x0F000000)
...@@ -906,12 +990,28 @@ struct lan743x_rx { ...@@ -906,12 +990,28 @@ struct lan743x_rx {
struct sk_buff *skb_head, *skb_tail; struct sk_buff *skb_head, *skb_tail;
}; };
/* SGMII Link Speed Duplex status */
enum lan743x_sgmii_lsd {
POWER_DOWN = 0,
LINK_DOWN,
ANEG_BUSY,
LINK_10HD,
LINK_10FD,
LINK_100HD,
LINK_100FD,
LINK_1000_MASTER,
LINK_1000_SLAVE,
LINK_2500_MASTER,
LINK_2500_SLAVE
};
struct lan743x_adapter { struct lan743x_adapter {
struct net_device *netdev; struct net_device *netdev;
struct mii_bus *mdiobus; struct mii_bus *mdiobus;
int msg_enable; int msg_enable;
#ifdef CONFIG_PM #ifdef CONFIG_PM
u32 wolopts; u32 wolopts;
u8 sopass[SOPASS_MAX];
#endif #endif
struct pci_dev *pdev; struct pci_dev *pdev;
struct lan743x_csr csr; struct lan743x_csr csr;
...@@ -931,12 +1031,16 @@ struct lan743x_adapter { ...@@ -931,12 +1031,16 @@ struct lan743x_adapter {
spinlock_t eth_syslock_spinlock; spinlock_t eth_syslock_spinlock;
bool eth_syslock_en; bool eth_syslock_en;
u32 eth_syslock_acquire_cnt; u32 eth_syslock_acquire_cnt;
struct mutex sgmii_rw_lock;
/* SGMII Link Speed & Duplex status */
enum lan743x_sgmii_lsd sgmii_lsd;
u8 max_tx_channels; u8 max_tx_channels;
u8 used_tx_channels; u8 used_tx_channels;
u8 max_vector_count; u8 max_vector_count;
#define LAN743X_ADAPTER_FLAG_OTP BIT(0) #define LAN743X_ADAPTER_FLAG_OTP BIT(0)
u32 flags; u32 flags;
u32 hw_cfg;
}; };
#define LAN743X_COMPONENT_FLAG_RX(channel) BIT(20 + (channel)) #define LAN743X_COMPONENT_FLAG_RX(channel) BIT(20 + (channel))
...@@ -1049,5 +1153,7 @@ struct lan743x_rx_buffer_info { ...@@ -1049,5 +1153,7 @@ struct lan743x_rx_buffer_info {
u32 lan743x_csr_read(struct lan743x_adapter *adapter, int offset); u32 lan743x_csr_read(struct lan743x_adapter *adapter, int offset);
void lan743x_csr_write(struct lan743x_adapter *adapter, int offset, u32 data); void lan743x_csr_write(struct lan743x_adapter *adapter, int offset, u32 data);
int lan743x_hs_syslock_acquire(struct lan743x_adapter *adapter, u16 timeout);
void lan743x_hs_syslock_release(struct lan743x_adapter *adapter);
#endif /* _LAN743X_H */ #endif /* _LAN743X_H */
...@@ -295,6 +295,9 @@ static void gpy_update_interface(struct phy_device *phydev) ...@@ -295,6 +295,9 @@ static void gpy_update_interface(struct phy_device *phydev)
ret); ret);
break; break;
} }
if (phydev->speed == SPEED_2500 || phydev->speed == SPEED_1000)
genphy_read_master_slave(phydev);
} }
static int gpy_read_status(struct phy_device *phydev) static int gpy_read_status(struct phy_device *phydev)
......
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