2019-01-22 01:05:50 +07:00
|
|
|
// SPDX-License-Identifier: (GPL-2.0 OR MIT)
|
2016-08-05 19:24:21 +07:00
|
|
|
/*
|
|
|
|
* Driver for Microsemi VSC85xx PHYs
|
|
|
|
*
|
|
|
|
* Author: Nagaraju Lakkaraju
|
|
|
|
* License: Dual MIT/GPL
|
|
|
|
* Copyright (c) 2016 Microsemi Corporation
|
|
|
|
*/
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
#include <linux/firmware.h>
|
|
|
|
#include <linux/jiffies.h>
|
2016-08-05 19:24:21 +07:00
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/mdio.h>
|
|
|
|
#include <linux/mii.h>
|
|
|
|
#include <linux/phy.h>
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
#include <linux/of.h>
|
2016-10-05 15:49:27 +07:00
|
|
|
#include <linux/netdevice.h>
|
2017-02-07 20:40:26 +07:00
|
|
|
#include <dt-bindings/net/mscc-phy-vsc8531.h>
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2020-03-13 16:48:01 +07:00
|
|
|
#include "mscc.h"
|
2018-10-08 17:07:24 +07:00
|
|
|
|
|
|
|
static const struct vsc85xx_hw_stat vsc85xx_hw_stats[] = {
|
|
|
|
{
|
|
|
|
.string = "phy_receive_errors",
|
|
|
|
.reg = MSCC_PHY_ERR_RX_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_false_carrier",
|
|
|
|
.reg = MSCC_PHY_ERR_FALSE_CARRIER_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_link_disconnect",
|
|
|
|
.reg = MSCC_PHY_ERR_LINK_DISCONNECT_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_crc_good_count",
|
|
|
|
.reg = MSCC_PHY_CU_MEDIA_CRC_VALID_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
.mask = VALID_CRC_CNT_CRC_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_crc_error_count",
|
|
|
|
.reg = MSCC_PHY_EXT_PHY_CNTL_4,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
static const struct vsc85xx_hw_stat vsc8584_hw_stats[] = {
|
|
|
|
{
|
|
|
|
.string = "phy_receive_errors",
|
|
|
|
.reg = MSCC_PHY_ERR_RX_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_false_carrier",
|
|
|
|
.reg = MSCC_PHY_ERR_FALSE_CARRIER_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_link_disconnect",
|
|
|
|
.reg = MSCC_PHY_ERR_LINK_DISCONNECT_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_STANDARD,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_crc_good_count",
|
|
|
|
.reg = MSCC_PHY_CU_MEDIA_CRC_VALID_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
.mask = VALID_CRC_CNT_CRC_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_cu_media_crc_error_count",
|
|
|
|
.reg = MSCC_PHY_EXT_PHY_CNTL_4,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_serdes_tx_good_pkt_count",
|
|
|
|
.reg = MSCC_PHY_SERDES_TX_VALID_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED_3,
|
|
|
|
.mask = VALID_CRC_CNT_CRC_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_serdes_tx_bad_crc_count",
|
|
|
|
.reg = MSCC_PHY_SERDES_TX_CRC_ERR_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED_3,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_serdes_rx_good_pkt_count",
|
|
|
|
.reg = MSCC_PHY_SERDES_RX_VALID_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED_3,
|
|
|
|
.mask = VALID_CRC_CNT_CRC_MASK,
|
|
|
|
}, {
|
|
|
|
.string = "phy_serdes_rx_bad_crc_count",
|
|
|
|
.reg = MSCC_PHY_SERDES_RX_CRC_ERR_CNT,
|
|
|
|
.page = MSCC_PHY_PAGE_EXTENDED_3,
|
|
|
|
.mask = ERR_CNT_MASK,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
#ifdef CONFIG_OF_MDIO
|
|
|
|
static const struct vsc8531_edge_rate_table edge_table[] = {
|
|
|
|
{MSCC_VDDMAC_3300, { 0, 2, 4, 7, 10, 17, 29, 53} },
|
|
|
|
{MSCC_VDDMAC_2500, { 0, 3, 6, 10, 14, 23, 37, 63} },
|
|
|
|
{MSCC_VDDMAC_1800, { 0, 5, 9, 16, 23, 35, 52, 76} },
|
|
|
|
{MSCC_VDDMAC_1500, { 0, 6, 14, 21, 29, 42, 58, 77} },
|
|
|
|
};
|
2020-03-13 16:48:01 +07:00
|
|
|
#endif
|
2016-10-12 20:47:51 +07:00
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
static int vsc85xx_phy_read_page(struct phy_device *phydev)
|
2016-08-05 19:24:21 +07:00
|
|
|
{
|
2018-10-08 17:07:23 +07:00
|
|
|
return __phy_read(phydev, MSCC_EXT_PAGE_ACCESS);
|
|
|
|
}
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
static int vsc85xx_phy_write_page(struct phy_device *phydev, int page)
|
|
|
|
{
|
|
|
|
return __phy_write(phydev, MSCC_EXT_PAGE_ACCESS, page);
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:24 +07:00
|
|
|
static int vsc85xx_get_sset_count(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
|
|
|
|
|
|
|
if (!priv)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return priv->nstats;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void vsc85xx_get_strings(struct phy_device *phydev, u8 *data)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (!priv)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i = 0; i < priv->nstats; i++)
|
|
|
|
strlcpy(data + i * ETH_GSTRING_LEN, priv->hw_stats[i].string,
|
|
|
|
ETH_GSTRING_LEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
static u64 vsc85xx_get_stat(struct phy_device *phydev, int i)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
|
|
|
int val;
|
|
|
|
|
|
|
|
val = phy_read_paged(phydev, priv->hw_stats[i].page,
|
|
|
|
priv->hw_stats[i].reg);
|
|
|
|
if (val < 0)
|
|
|
|
return U64_MAX;
|
|
|
|
|
|
|
|
val = val & priv->hw_stats[i].mask;
|
|
|
|
priv->stats[i] += val;
|
|
|
|
|
|
|
|
return priv->stats[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
static void vsc85xx_get_stats(struct phy_device *phydev,
|
|
|
|
struct ethtool_stats *stats, u64 *data)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (!priv)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i = 0; i < priv->nstats; i++)
|
|
|
|
data[i] = vsc85xx_get_stat(phydev, i);
|
|
|
|
}
|
|
|
|
|
2017-02-07 20:40:26 +07:00
|
|
|
static int vsc85xx_led_cntl_set(struct phy_device *phydev,
|
|
|
|
u8 led_num,
|
|
|
|
u8 mode)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
u16 reg_val;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
|
|
|
reg_val = phy_read(phydev, MSCC_PHY_LED_MODE_SEL);
|
2018-09-03 15:48:47 +07:00
|
|
|
reg_val &= ~LED_MODE_SEL_MASK(led_num);
|
|
|
|
reg_val |= LED_MODE_SEL(led_num, (u16)mode);
|
2017-02-07 20:40:26 +07:00
|
|
|
rc = phy_write(phydev, MSCC_PHY_LED_MODE_SEL, reg_val);
|
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2016-11-29 16:46:48 +07:00
|
|
|
static int vsc85xx_mdix_get(struct phy_device *phydev, u8 *mdix)
|
|
|
|
{
|
|
|
|
u16 reg_val;
|
|
|
|
|
|
|
|
reg_val = phy_read(phydev, MSCC_PHY_DEV_AUX_CNTL);
|
|
|
|
if (reg_val & HP_AUTO_MDIX_X_OVER_IND_MASK)
|
|
|
|
*mdix = ETH_TP_MDI_X;
|
|
|
|
else
|
|
|
|
*mdix = ETH_TP_MDI;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_mdix_set(struct phy_device *phydev, u8 mdix)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
u16 reg_val;
|
|
|
|
|
|
|
|
reg_val = phy_read(phydev, MSCC_PHY_BYPASS_CONTROL);
|
2018-10-08 17:07:26 +07:00
|
|
|
if (mdix == ETH_TP_MDI || mdix == ETH_TP_MDI_X) {
|
2016-11-29 16:46:48 +07:00
|
|
|
reg_val |= (DISABLE_PAIR_SWAP_CORR_MASK |
|
|
|
|
DISABLE_POLARITY_CORR_MASK |
|
|
|
|
DISABLE_HP_AUTO_MDIX_MASK);
|
|
|
|
} else {
|
|
|
|
reg_val &= ~(DISABLE_PAIR_SWAP_CORR_MASK |
|
|
|
|
DISABLE_POLARITY_CORR_MASK |
|
|
|
|
DISABLE_HP_AUTO_MDIX_MASK);
|
|
|
|
}
|
|
|
|
rc = phy_write(phydev, MSCC_PHY_BYPASS_CONTROL, reg_val);
|
2018-10-08 17:07:27 +07:00
|
|
|
if (rc)
|
2016-11-29 16:46:48 +07:00
|
|
|
return rc;
|
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = 0;
|
2016-11-29 16:46:48 +07:00
|
|
|
|
|
|
|
if (mdix == ETH_TP_MDI)
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = FORCE_MDI_CROSSOVER_MDI;
|
2016-11-29 16:46:48 +07:00
|
|
|
else if (mdix == ETH_TP_MDI_X)
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = FORCE_MDI_CROSSOVER_MDIX;
|
2016-11-29 16:46:48 +07:00
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
MSCC_PHY_EXT_MODE_CNTL, FORCE_MDI_CROSSOVER_MASK,
|
|
|
|
reg_val);
|
|
|
|
if (rc < 0)
|
2016-11-29 16:46:48 +07:00
|
|
|
return rc;
|
|
|
|
|
|
|
|
return genphy_restart_aneg(phydev);
|
|
|
|
}
|
|
|
|
|
2016-11-17 19:07:24 +07:00
|
|
|
static int vsc85xx_downshift_get(struct phy_device *phydev, u8 *count)
|
|
|
|
{
|
2018-10-17 00:35:11 +07:00
|
|
|
int reg_val;
|
2016-11-17 19:07:24 +07:00
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = phy_read_paged(phydev, MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
MSCC_PHY_ACTIPHY_CNTL);
|
|
|
|
if (reg_val < 0)
|
|
|
|
return reg_val;
|
2016-11-17 19:07:24 +07:00
|
|
|
|
|
|
|
reg_val &= DOWNSHIFT_CNTL_MASK;
|
|
|
|
if (!(reg_val & DOWNSHIFT_EN))
|
|
|
|
*count = DOWNSHIFT_DEV_DISABLE;
|
|
|
|
else
|
|
|
|
*count = ((reg_val & ~DOWNSHIFT_EN) >> DOWNSHIFT_CNTL_POS) + 2;
|
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
return 0;
|
2016-11-17 19:07:24 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_downshift_set(struct phy_device *phydev, u8 count)
|
|
|
|
{
|
|
|
|
if (count == DOWNSHIFT_DEV_DEFAULT_COUNT) {
|
|
|
|
/* Default downshift count 3 (i.e. Bit3:2 = 0b01) */
|
|
|
|
count = ((1 << DOWNSHIFT_CNTL_POS) | DOWNSHIFT_EN);
|
|
|
|
} else if (count > DOWNSHIFT_COUNT_MAX || count == 1) {
|
|
|
|
phydev_err(phydev, "Downshift count should be 2,3,4 or 5\n");
|
|
|
|
return -ERANGE;
|
|
|
|
} else if (count) {
|
|
|
|
/* Downshift count is either 2,3,4 or 5 */
|
|
|
|
count = (((count - 2) << DOWNSHIFT_CNTL_POS) | DOWNSHIFT_EN);
|
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
return phy_modify_paged(phydev, MSCC_PHY_PAGE_EXTENDED,
|
|
|
|
MSCC_PHY_ACTIPHY_CNTL, DOWNSHIFT_CNTL_MASK,
|
|
|
|
count);
|
2016-11-17 19:07:24 +07:00
|
|
|
}
|
|
|
|
|
2016-10-05 15:49:27 +07:00
|
|
|
static int vsc85xx_wol_set(struct phy_device *phydev,
|
|
|
|
struct ethtool_wolinfo *wol)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
u16 reg_val;
|
|
|
|
u8 i;
|
|
|
|
u16 pwd[3] = {0, 0, 0};
|
|
|
|
struct ethtool_wolinfo *wol_conf = wol;
|
|
|
|
u8 *mac_addr = phydev->attached_dev->dev_addr;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
2018-10-08 17:07:23 +07:00
|
|
|
rc = phy_select_page(phydev, MSCC_PHY_PAGE_EXTENDED_2);
|
|
|
|
if (rc < 0) {
|
|
|
|
rc = phy_restore_page(phydev, rc, rc);
|
2016-10-05 15:49:27 +07:00
|
|
|
goto out_unlock;
|
2018-10-08 17:07:23 +07:00
|
|
|
}
|
2016-10-05 15:49:27 +07:00
|
|
|
|
|
|
|
if (wol->wolopts & WAKE_MAGIC) {
|
|
|
|
/* Store the device address for the magic packet */
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pwd); i++)
|
|
|
|
pwd[i] = mac_addr[5 - (i * 2 + 1)] << 8 |
|
|
|
|
mac_addr[5 - i * 2];
|
2018-10-08 17:07:23 +07:00
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_LOWER_MAC_ADDR, pwd[0]);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_MID_MAC_ADDR, pwd[1]);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_UPPER_MAC_ADDR, pwd[2]);
|
2016-10-05 15:49:27 +07:00
|
|
|
} else {
|
2018-10-08 17:07:23 +07:00
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_LOWER_MAC_ADDR, 0);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_MID_MAC_ADDR, 0);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_UPPER_MAC_ADDR, 0);
|
2016-10-05 15:49:27 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (wol_conf->wolopts & WAKE_MAGICSECURE) {
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pwd); i++)
|
|
|
|
pwd[i] = wol_conf->sopass[5 - (i * 2 + 1)] << 8 |
|
|
|
|
wol_conf->sopass[5 - i * 2];
|
2018-10-08 17:07:23 +07:00
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_LOWER_PASSWD, pwd[0]);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_MID_PASSWD, pwd[1]);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_UPPER_PASSWD, pwd[2]);
|
2016-10-05 15:49:27 +07:00
|
|
|
} else {
|
2018-10-08 17:07:23 +07:00
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_LOWER_PASSWD, 0);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_MID_PASSWD, 0);
|
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_UPPER_PASSWD, 0);
|
2016-10-05 15:49:27 +07:00
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = __phy_read(phydev, MSCC_PHY_WOL_MAC_CONTROL);
|
2016-10-05 15:49:27 +07:00
|
|
|
if (wol_conf->wolopts & WAKE_MAGICSECURE)
|
|
|
|
reg_val |= SECURE_ON_ENABLE;
|
|
|
|
else
|
|
|
|
reg_val &= ~SECURE_ON_ENABLE;
|
2018-10-08 17:07:23 +07:00
|
|
|
__phy_write(phydev, MSCC_PHY_WOL_MAC_CONTROL, reg_val);
|
2016-10-05 15:49:27 +07:00
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
rc = phy_restore_page(phydev, rc, rc > 0 ? 0 : rc);
|
|
|
|
if (rc < 0)
|
2016-10-05 15:49:27 +07:00
|
|
|
goto out_unlock;
|
|
|
|
|
|
|
|
if (wol->wolopts & WAKE_MAGIC) {
|
|
|
|
/* Enable the WOL interrupt */
|
|
|
|
reg_val = phy_read(phydev, MII_VSC85XX_INT_MASK);
|
|
|
|
reg_val |= MII_VSC85XX_INT_MASK_WOL;
|
|
|
|
rc = phy_write(phydev, MII_VSC85XX_INT_MASK, reg_val);
|
2018-10-08 17:07:27 +07:00
|
|
|
if (rc)
|
2016-10-05 15:49:27 +07:00
|
|
|
goto out_unlock;
|
|
|
|
} else {
|
|
|
|
/* Disable the WOL interrupt */
|
|
|
|
reg_val = phy_read(phydev, MII_VSC85XX_INT_MASK);
|
|
|
|
reg_val &= (~MII_VSC85XX_INT_MASK_WOL);
|
|
|
|
rc = phy_write(phydev, MII_VSC85XX_INT_MASK, reg_val);
|
2018-10-08 17:07:27 +07:00
|
|
|
if (rc)
|
2016-10-05 15:49:27 +07:00
|
|
|
goto out_unlock;
|
|
|
|
}
|
|
|
|
/* Clear WOL iterrupt status */
|
|
|
|
reg_val = phy_read(phydev, MII_VSC85XX_INT_STATUS);
|
|
|
|
|
|
|
|
out_unlock:
|
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void vsc85xx_wol_get(struct phy_device *phydev,
|
|
|
|
struct ethtool_wolinfo *wol)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
u16 reg_val;
|
|
|
|
u8 i;
|
|
|
|
u16 pwd[3] = {0, 0, 0};
|
|
|
|
struct ethtool_wolinfo *wol_conf = wol;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
2018-10-08 17:07:23 +07:00
|
|
|
rc = phy_select_page(phydev, MSCC_PHY_PAGE_EXTENDED_2);
|
|
|
|
if (rc < 0)
|
2016-10-05 15:49:27 +07:00
|
|
|
goto out_unlock;
|
|
|
|
|
2018-10-08 17:07:23 +07:00
|
|
|
reg_val = __phy_read(phydev, MSCC_PHY_WOL_MAC_CONTROL);
|
2016-10-05 15:49:27 +07:00
|
|
|
if (reg_val & SECURE_ON_ENABLE)
|
|
|
|
wol_conf->wolopts |= WAKE_MAGICSECURE;
|
|
|
|
if (wol_conf->wolopts & WAKE_MAGICSECURE) {
|
2018-10-08 17:07:23 +07:00
|
|
|
pwd[0] = __phy_read(phydev, MSCC_PHY_WOL_LOWER_PASSWD);
|
|
|
|
pwd[1] = __phy_read(phydev, MSCC_PHY_WOL_MID_PASSWD);
|
|
|
|
pwd[2] = __phy_read(phydev, MSCC_PHY_WOL_UPPER_PASSWD);
|
2016-10-05 15:49:27 +07:00
|
|
|
for (i = 0; i < ARRAY_SIZE(pwd); i++) {
|
|
|
|
wol_conf->sopass[5 - i * 2] = pwd[i] & 0x00ff;
|
|
|
|
wol_conf->sopass[5 - (i * 2 + 1)] = (pwd[i] & 0xff00)
|
|
|
|
>> 8;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
out_unlock:
|
2018-10-08 17:07:23 +07:00
|
|
|
phy_restore_page(phydev, rc, rc > 0 ? 0 : rc);
|
2016-10-05 15:49:27 +07:00
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
}
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
#ifdef CONFIG_OF_MDIO
|
|
|
|
static int vsc85xx_edge_rate_magic_get(struct phy_device *phydev)
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
{
|
2018-09-03 15:48:50 +07:00
|
|
|
u32 vdd, sd;
|
2018-10-08 17:07:28 +07:00
|
|
|
int i, j;
|
2016-10-12 20:47:51 +07:00
|
|
|
struct device *dev = &phydev->mdio.dev;
|
|
|
|
struct device_node *of_node = dev->of_node;
|
|
|
|
u8 sd_array_size = ARRAY_SIZE(edge_table[0].slowdown);
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
if (!of_node)
|
|
|
|
return -ENODEV;
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
|
2018-10-08 17:07:28 +07:00
|
|
|
if (of_property_read_u32(of_node, "vsc8531,vddmac", &vdd))
|
2016-10-12 20:47:51 +07:00
|
|
|
vdd = MSCC_VDDMAC_3300;
|
|
|
|
|
2018-10-08 17:07:28 +07:00
|
|
|
if (of_property_read_u32(of_node, "vsc8531,edge-slowdown", &sd))
|
2016-10-12 20:47:51 +07:00
|
|
|
sd = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(edge_table); i++)
|
|
|
|
if (edge_table[i].vddmac == vdd)
|
|
|
|
for (j = 0; j < sd_array_size; j++)
|
|
|
|
if (edge_table[i].slowdown[j] == sd)
|
|
|
|
return (sd_array_size - j - 1);
|
|
|
|
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2017-02-07 20:40:26 +07:00
|
|
|
|
|
|
|
static int vsc85xx_dt_led_mode_get(struct phy_device *phydev,
|
|
|
|
char *led,
|
2018-09-03 15:48:51 +07:00
|
|
|
u32 default_mode)
|
2017-02-07 20:40:26 +07:00
|
|
|
{
|
2018-09-03 15:48:48 +07:00
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
2017-02-07 20:40:26 +07:00
|
|
|
struct device *dev = &phydev->mdio.dev;
|
|
|
|
struct device_node *of_node = dev->of_node;
|
2018-09-03 15:48:51 +07:00
|
|
|
u32 led_mode;
|
2017-02-07 20:40:26 +07:00
|
|
|
int err;
|
|
|
|
|
|
|
|
if (!of_node)
|
|
|
|
return -ENODEV;
|
|
|
|
|
|
|
|
led_mode = default_mode;
|
2018-09-03 15:48:51 +07:00
|
|
|
err = of_property_read_u32(of_node, led, &led_mode);
|
2018-09-03 15:48:48 +07:00
|
|
|
if (!err && !(BIT(led_mode) & priv->supp_led_modes)) {
|
2017-02-07 20:40:26 +07:00
|
|
|
phydev_err(phydev, "DT %s invalid\n", led);
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return led_mode;
|
|
|
|
}
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
#else
|
|
|
|
static int vsc85xx_edge_rate_magic_get(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
return 0;
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
}
|
2017-02-07 20:40:26 +07:00
|
|
|
|
|
|
|
static int vsc85xx_dt_led_mode_get(struct phy_device *phydev,
|
|
|
|
char *led,
|
|
|
|
u8 default_mode)
|
|
|
|
{
|
|
|
|
return default_mode;
|
|
|
|
}
|
2016-10-12 20:47:51 +07:00
|
|
|
#endif /* CONFIG_OF_MDIO */
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
|
2018-09-03 15:48:51 +07:00
|
|
|
static int vsc85xx_dt_led_modes_get(struct phy_device *phydev,
|
|
|
|
u32 *default_mode)
|
2018-09-03 15:48:47 +07:00
|
|
|
{
|
|
|
|
struct vsc8531_private *priv = phydev->priv;
|
2018-09-26 20:20:11 +07:00
|
|
|
char led_dt_prop[28];
|
2018-09-03 15:48:47 +07:00
|
|
|
int i, ret;
|
|
|
|
|
|
|
|
for (i = 0; i < priv->nleds; i++) {
|
|
|
|
ret = sprintf(led_dt_prop, "vsc8531,led-%d-mode", i);
|
|
|
|
if (ret < 0)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
ret = vsc85xx_dt_led_mode_get(phydev, led_dt_prop,
|
|
|
|
default_mode[i]);
|
|
|
|
if (ret < 0)
|
|
|
|
return ret;
|
|
|
|
priv->leds_mode[i] = ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
static int vsc85xx_edge_rate_cntl_set(struct phy_device *phydev, u8 edge_rate)
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
2018-10-08 17:07:23 +07:00
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_EXTENDED_2,
|
|
|
|
MSCC_PHY_WOL_MAC_CONTROL, EDGE_RATE_CNTL_MASK,
|
|
|
|
edge_rate << EDGE_RATE_CNTL_POS);
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2016-09-19 17:03:54 +07:00
|
|
|
static int vsc85xx_mac_if_set(struct phy_device *phydev,
|
|
|
|
phy_interface_t interface)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
u16 reg_val;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
|
|
|
reg_val = phy_read(phydev, MSCC_PHY_EXT_PHY_CNTL_1);
|
|
|
|
reg_val &= ~(MAC_IF_SELECTION_MASK);
|
|
|
|
switch (interface) {
|
2020-03-20 04:16:47 +07:00
|
|
|
case PHY_INTERFACE_MODE_RGMII_TXID:
|
|
|
|
case PHY_INTERFACE_MODE_RGMII_RXID:
|
|
|
|
case PHY_INTERFACE_MODE_RGMII_ID:
|
2016-09-19 17:03:54 +07:00
|
|
|
case PHY_INTERFACE_MODE_RGMII:
|
|
|
|
reg_val |= (MAC_IF_SELECTION_RGMII << MAC_IF_SELECTION_POS);
|
|
|
|
break;
|
|
|
|
case PHY_INTERFACE_MODE_RMII:
|
|
|
|
reg_val |= (MAC_IF_SELECTION_RMII << MAC_IF_SELECTION_POS);
|
|
|
|
break;
|
|
|
|
case PHY_INTERFACE_MODE_MII:
|
|
|
|
case PHY_INTERFACE_MODE_GMII:
|
|
|
|
reg_val |= (MAC_IF_SELECTION_GMII << MAC_IF_SELECTION_POS);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
rc = -EINVAL;
|
|
|
|
goto out_unlock;
|
|
|
|
}
|
|
|
|
rc = phy_write(phydev, MSCC_PHY_EXT_PHY_CNTL_1, reg_val);
|
2018-10-08 17:07:27 +07:00
|
|
|
if (rc)
|
2016-09-19 17:03:54 +07:00
|
|
|
goto out_unlock;
|
|
|
|
|
|
|
|
rc = genphy_soft_reset(phydev);
|
|
|
|
|
|
|
|
out_unlock:
|
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2020-03-24 21:13:58 +07:00
|
|
|
/* Set the RGMII RX and TX clock skews individually, according to the PHY
|
|
|
|
* interface type, to:
|
|
|
|
* * 0.2 ns (their default, and lowest, hardware value) if delays should
|
|
|
|
* not be enabled
|
|
|
|
* * 2.0 ns (which causes the data to be sampled at exactly half way between
|
|
|
|
* clock transitions at 1000 Mbps) if delays should be enabled
|
|
|
|
*/
|
|
|
|
static int vsc85xx_rgmii_set_skews(struct phy_device *phydev, u32 rgmii_cntl,
|
|
|
|
u16 rgmii_rx_delay_mask,
|
|
|
|
u16 rgmii_tx_delay_mask)
|
2016-08-05 19:24:21 +07:00
|
|
|
{
|
2020-03-24 21:13:58 +07:00
|
|
|
u16 rgmii_rx_delay_pos = ffs(rgmii_rx_delay_mask) - 1;
|
|
|
|
u16 rgmii_tx_delay_pos = ffs(rgmii_tx_delay_mask) - 1;
|
2020-03-20 04:16:48 +07:00
|
|
|
u16 reg_val = 0;
|
2016-09-08 15:39:31 +07:00
|
|
|
int rc;
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
mutex_lock(&phydev->lock);
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2020-03-20 04:16:48 +07:00
|
|
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID ||
|
|
|
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_ID)
|
2020-03-24 21:13:58 +07:00
|
|
|
reg_val |= RGMII_CLK_DELAY_2_0_NS << rgmii_rx_delay_pos;
|
2020-03-20 04:16:48 +07:00
|
|
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID ||
|
|
|
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_ID)
|
2020-03-24 21:13:58 +07:00
|
|
|
reg_val |= RGMII_CLK_DELAY_2_0_NS << rgmii_tx_delay_pos;
|
2018-11-24 01:01:51 +07:00
|
|
|
|
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_EXTENDED_2,
|
2020-03-24 21:13:58 +07:00
|
|
|
rgmii_cntl,
|
|
|
|
rgmii_rx_delay_mask | rgmii_tx_delay_mask,
|
2018-11-24 01:01:51 +07:00
|
|
|
reg_val);
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
mutex_unlock(&phydev->lock);
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
return rc;
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
2020-03-24 21:13:58 +07:00
|
|
|
static int vsc85xx_default_config(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
phydev->mdix_ctrl = ETH_TP_MDI_AUTO;
|
|
|
|
|
|
|
|
if (phy_interface_mode_is_rgmii(phydev->interface)) {
|
|
|
|
rc = vsc85xx_rgmii_set_skews(phydev, VSC8502_RGMII_CNTL,
|
|
|
|
VSC8502_RGMII_RX_DELAY_MASK,
|
|
|
|
VSC8502_RGMII_TX_DELAY_MASK);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-11-17 19:07:24 +07:00
|
|
|
static int vsc85xx_get_tunable(struct phy_device *phydev,
|
|
|
|
struct ethtool_tunable *tuna, void *data)
|
|
|
|
{
|
|
|
|
switch (tuna->id) {
|
|
|
|
case ETHTOOL_PHY_DOWNSHIFT:
|
|
|
|
return vsc85xx_downshift_get(phydev, (u8 *)data);
|
|
|
|
default:
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_set_tunable(struct phy_device *phydev,
|
|
|
|
struct ethtool_tunable *tuna,
|
|
|
|
const void *data)
|
|
|
|
{
|
|
|
|
switch (tuna->id) {
|
|
|
|
case ETHTOOL_PHY_DOWNSHIFT:
|
|
|
|
return vsc85xx_downshift_set(phydev, *(u8 *)data);
|
|
|
|
default:
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:25 +07:00
|
|
|
/* mdiobus lock should be locked when using this function */
|
|
|
|
static void vsc85xx_tr_write(struct phy_device *phydev, u16 addr, u32 val)
|
|
|
|
{
|
|
|
|
__phy_write(phydev, MSCC_PHY_TR_MSB, val >> 16);
|
|
|
|
__phy_write(phydev, MSCC_PHY_TR_LSB, val & GENMASK(15, 0));
|
|
|
|
__phy_write(phydev, MSCC_PHY_TR_CNTL, TR_WRITE | TR_ADDR(addr));
|
|
|
|
}
|
|
|
|
|
2018-12-18 16:27:56 +07:00
|
|
|
static int vsc8531_pre_init_seq_set(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int rc;
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val init_seq[] = {
|
2018-12-18 16:27:56 +07:00
|
|
|
{0x0f90, 0x00688980},
|
|
|
|
{0x0696, 0x00000003},
|
|
|
|
{0x07fa, 0x0050100f},
|
|
|
|
{0x1686, 0x00000004},
|
|
|
|
};
|
|
|
|
unsigned int i;
|
|
|
|
int oldpage;
|
|
|
|
|
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_STANDARD,
|
|
|
|
MSCC_PHY_EXT_CNTL_STATUS, SMI_BROADCAST_WR_EN,
|
|
|
|
SMI_BROADCAST_WR_EN);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_TEST,
|
|
|
|
MSCC_PHY_TEST_PAGE_24, 0, 0x0400);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_TEST,
|
|
|
|
MSCC_PHY_TEST_PAGE_5, 0x0a00, 0x0e00);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
rc = phy_modify_paged(phydev, MSCC_PHY_PAGE_TEST,
|
|
|
|
MSCC_PHY_TEST_PAGE_8, 0x8000, 0x8000);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
|
|
|
oldpage = phy_select_page(phydev, MSCC_PHY_PAGE_TR);
|
|
|
|
if (oldpage < 0)
|
|
|
|
goto out_unlock;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(init_seq); i++)
|
|
|
|
vsc85xx_tr_write(phydev, init_seq[i].reg, init_seq[i].val);
|
|
|
|
|
|
|
|
out_unlock:
|
|
|
|
oldpage = phy_restore_page(phydev, oldpage, oldpage);
|
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return oldpage;
|
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:25 +07:00
|
|
|
static int vsc85xx_eee_init_seq_set(struct phy_device *phydev)
|
|
|
|
{
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val init_eee[] = {
|
2018-10-08 17:07:25 +07:00
|
|
|
{0x0f82, 0x0012b00a},
|
|
|
|
{0x1686, 0x00000004},
|
|
|
|
{0x168c, 0x00d2c46f},
|
|
|
|
{0x17a2, 0x00000620},
|
|
|
|
{0x16a0, 0x00eeffdd},
|
|
|
|
{0x16a6, 0x00071448},
|
|
|
|
{0x16a4, 0x0013132f},
|
|
|
|
{0x16a8, 0x00000000},
|
|
|
|
{0x0ffc, 0x00c0a028},
|
|
|
|
{0x0fe8, 0x0091b06c},
|
|
|
|
{0x0fea, 0x00041600},
|
|
|
|
{0x0f80, 0x00000af4},
|
|
|
|
{0x0fec, 0x00901809},
|
|
|
|
{0x0fee, 0x0000a6a1},
|
|
|
|
{0x0ffe, 0x00b01007},
|
|
|
|
{0x16b0, 0x00eeff00},
|
|
|
|
{0x16b2, 0x00007000},
|
|
|
|
{0x16b4, 0x00000814},
|
|
|
|
};
|
|
|
|
unsigned int i;
|
|
|
|
int oldpage;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->lock);
|
|
|
|
oldpage = phy_select_page(phydev, MSCC_PHY_PAGE_TR);
|
|
|
|
if (oldpage < 0)
|
|
|
|
goto out_unlock;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(init_eee); i++)
|
|
|
|
vsc85xx_tr_write(phydev, init_eee[i].reg, init_eee[i].val);
|
|
|
|
|
|
|
|
out_unlock:
|
|
|
|
oldpage = phy_restore_page(phydev, oldpage, oldpage);
|
|
|
|
mutex_unlock(&phydev->lock);
|
|
|
|
|
|
|
|
return oldpage;
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
/* phydev->bus->mdio_lock should be locked when using this function */
|
|
|
|
static int phy_base_write(struct phy_device *phydev, u32 regnum, u16 val)
|
|
|
|
{
|
|
|
|
if (unlikely(!mutex_is_locked(&phydev->mdio.bus->mdio_lock))) {
|
|
|
|
dev_err(&phydev->mdio.dev, "MDIO bus lock not held!\n");
|
|
|
|
dump_stack();
|
|
|
|
}
|
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
return __phy_package_write(phydev, regnum, val);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* phydev->bus->mdio_lock should be locked when using this function */
|
|
|
|
static int phy_base_read(struct phy_device *phydev, u32 regnum)
|
|
|
|
{
|
|
|
|
if (unlikely(!mutex_is_locked(&phydev->mdio.bus->mdio_lock))) {
|
|
|
|
dev_err(&phydev->mdio.dev, "MDIO bus lock not held!\n");
|
|
|
|
dump_stack();
|
|
|
|
}
|
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
return __phy_package_read(phydev, regnum);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static void vsc8584_csr_write(struct phy_device *phydev, u16 addr, u32 val)
|
|
|
|
{
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_MSB, val >> 16);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_LSB, val & GENMASK(15, 0));
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_CNTL, TR_WRITE | TR_ADDR(addr));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_cmd(struct phy_device *phydev, u16 val)
|
|
|
|
{
|
|
|
|
unsigned long deadline;
|
|
|
|
u16 reg_val;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_PROC_CMD, PROC_CMD_NCOMPLETED | val);
|
|
|
|
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
reg_val = phy_base_read(phydev, MSCC_PHY_PROC_CMD);
|
|
|
|
} while (time_before(jiffies, deadline) &&
|
|
|
|
(reg_val & PROC_CMD_NCOMPLETED) &&
|
|
|
|
!(reg_val & PROC_CMD_FAILED));
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
if (reg_val & PROC_CMD_FAILED)
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
if (reg_val & PROC_CMD_NCOMPLETED)
|
|
|
|
return -ETIMEDOUT;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_micro_deassert_reset(struct phy_device *phydev,
|
|
|
|
bool patch_en)
|
|
|
|
{
|
|
|
|
u32 enable, release;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
enable = RUN_FROM_INT_ROM | MICRO_CLK_EN | DW8051_CLK_EN;
|
|
|
|
release = MICRO_NSOFT_RESET | RUN_FROM_INT_ROM | DW8051_CLK_EN |
|
|
|
|
MICRO_CLK_EN;
|
|
|
|
|
|
|
|
if (patch_en) {
|
|
|
|
enable |= MICRO_PATCH_EN;
|
|
|
|
release |= MICRO_PATCH_EN;
|
|
|
|
|
|
|
|
/* Clear all patches */
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, READ_RAM);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Enable 8051 Micro clock; CLEAR/SET patch present; disable PRAM clock
|
|
|
|
* override and addr. auto-incr; operate at 125 MHz
|
|
|
|
*/
|
|
|
|
phy_base_write(phydev, MSCC_DW8051_CNTL_STATUS, enable);
|
|
|
|
/* Release 8051 Micro SW reset */
|
|
|
|
phy_base_write(phydev, MSCC_DW8051_CNTL_STATUS, release);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_micro_assert_reset(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
u16 reg;
|
|
|
|
|
|
|
|
ret = vsc8584_cmd(phydev, PROC_CMD_NOP);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_INT_MEM_CNTL);
|
|
|
|
reg &= ~EN_PATCH_RAM_TRAP_ADDR(4);
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_TRAP_ROM_ADDR(4), 0x005b);
|
|
|
|
phy_base_write(phydev, MSCC_PATCH_RAM_ADDR(4), 0x005b);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_INT_MEM_CNTL);
|
|
|
|
reg |= EN_PATCH_RAM_TRAP_ADDR(4);
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_PROC_CMD, PROC_CMD_NOP);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_DW8051_CNTL_STATUS);
|
|
|
|
reg &= ~MICRO_NSOFT_RESET;
|
|
|
|
phy_base_write(phydev, MSCC_DW8051_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_PROC_CMD, PROC_CMD_MCB_ACCESS_MAC_CONF |
|
|
|
|
PROC_CMD_SGMII_PORT(0) | PROC_CMD_NO_MAC_CONF |
|
|
|
|
PROC_CMD_READ);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_INT_MEM_CNTL);
|
|
|
|
reg &= ~EN_PATCH_RAM_TRAP_ADDR(4);
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_get_fw_crc(struct phy_device *phydev, u16 start, u16 size,
|
|
|
|
u16 *crc)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_VERIPHY_CNTL_2, start);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_VERIPHY_CNTL_3, size);
|
|
|
|
|
|
|
|
/* Start Micro command */
|
|
|
|
ret = vsc8584_cmd(phydev, PROC_CMD_CRC16);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED);
|
|
|
|
|
|
|
|
*crc = phy_base_read(phydev, MSCC_PHY_VERIPHY_CNTL_2);
|
|
|
|
|
|
|
|
out:
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_patch_fw(struct phy_device *phydev,
|
|
|
|
const struct firmware *fw)
|
|
|
|
{
|
|
|
|
int i, ret;
|
|
|
|
|
|
|
|
ret = vsc8584_micro_assert_reset(phydev);
|
|
|
|
if (ret) {
|
|
|
|
dev_err(&phydev->mdio.dev,
|
|
|
|
"%s: failed to assert reset of micro\n", __func__);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
/* Hold 8051 Micro in SW Reset, Enable auto incr address and patch clock
|
|
|
|
* Disable the 8051 Micro clock
|
|
|
|
*/
|
|
|
|
phy_base_write(phydev, MSCC_DW8051_CNTL_STATUS, RUN_FROM_INT_ROM |
|
|
|
|
AUTOINC_ADDR | PATCH_RAM_CLK | MICRO_CLK_EN |
|
|
|
|
MICRO_CLK_DIVIDE(2));
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, READ_PRAM | INT_MEM_WRITE_EN |
|
|
|
|
INT_MEM_DATA(2));
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_ADDR, 0x0000);
|
|
|
|
|
|
|
|
for (i = 0; i < fw->size; i++)
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, READ_PRAM |
|
|
|
|
INT_MEM_WRITE_EN | fw->data[i]);
|
|
|
|
|
|
|
|
/* Clear internal memory access */
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL, READ_RAM);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static bool vsc8574_is_serdes_init(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
u16 reg;
|
|
|
|
bool ret;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_TRAP_ROM_ADDR(1));
|
|
|
|
if (reg != 0x3eb7) {
|
|
|
|
ret = false;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PATCH_RAM_ADDR(1));
|
|
|
|
if (reg != 0x4012) {
|
|
|
|
ret = false;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_INT_MEM_CNTL);
|
|
|
|
if (reg != EN_PATCH_RAM_TRAP_ADDR(1)) {
|
|
|
|
ret = false;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_DW8051_CNTL_STATUS);
|
|
|
|
if ((MICRO_NSOFT_RESET | RUN_FROM_INT_ROM | DW8051_CLK_EN |
|
|
|
|
MICRO_CLK_EN) != (reg & MSCC_DW8051_VLD_MASK)) {
|
|
|
|
ret = false;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
ret = true;
|
|
|
|
out:
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8574_config_pre_init(struct phy_device *phydev)
|
|
|
|
{
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val pre_init1[] = {
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
{0x0fae, 0x000401bd},
|
|
|
|
{0x0fac, 0x000f000f},
|
|
|
|
{0x17a0, 0x00a0f147},
|
|
|
|
{0x0fe4, 0x00052f54},
|
|
|
|
{0x1792, 0x0027303d},
|
|
|
|
{0x07fe, 0x00000704},
|
|
|
|
{0x0fe0, 0x00060150},
|
|
|
|
{0x0f82, 0x0012b00a},
|
|
|
|
{0x0f80, 0x00000d74},
|
|
|
|
{0x02e0, 0x00000012},
|
|
|
|
{0x03a2, 0x00050208},
|
|
|
|
{0x03b2, 0x00009186},
|
|
|
|
{0x0fb0, 0x000e3700},
|
|
|
|
{0x1688, 0x00049f81},
|
|
|
|
{0x0fd2, 0x0000ffff},
|
|
|
|
{0x168a, 0x00039fa2},
|
|
|
|
{0x1690, 0x0020640b},
|
|
|
|
{0x0258, 0x00002220},
|
|
|
|
{0x025a, 0x00002a20},
|
|
|
|
{0x025c, 0x00003060},
|
|
|
|
{0x025e, 0x00003fa0},
|
|
|
|
{0x03a6, 0x0000e0f0},
|
|
|
|
{0x0f92, 0x00001489},
|
|
|
|
{0x16a2, 0x00007000},
|
|
|
|
{0x16a6, 0x00071448},
|
|
|
|
{0x16a0, 0x00eeffdd},
|
|
|
|
{0x0fe8, 0x0091b06c},
|
|
|
|
{0x0fea, 0x00041600},
|
|
|
|
{0x16b0, 0x00eeff00},
|
|
|
|
{0x16b2, 0x00007000},
|
|
|
|
{0x16b4, 0x00000814},
|
|
|
|
{0x0f90, 0x00688980},
|
|
|
|
{0x03a4, 0x0000d8f0},
|
|
|
|
{0x0fc0, 0x00000400},
|
|
|
|
{0x07fa, 0x0050100f},
|
|
|
|
{0x0796, 0x00000003},
|
|
|
|
{0x07f8, 0x00c3ff98},
|
|
|
|
{0x0fa4, 0x0018292a},
|
|
|
|
{0x168c, 0x00d2c46f},
|
|
|
|
{0x17a2, 0x00000620},
|
|
|
|
{0x16a4, 0x0013132f},
|
|
|
|
{0x16a8, 0x00000000},
|
|
|
|
{0x0ffc, 0x00c0a028},
|
|
|
|
{0x0fec, 0x00901c09},
|
|
|
|
{0x0fee, 0x0004a6a1},
|
|
|
|
{0x0ffe, 0x00b01807},
|
|
|
|
};
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val pre_init2[] = {
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
{0x0486, 0x0008a518},
|
|
|
|
{0x0488, 0x006dc696},
|
|
|
|
{0x048a, 0x00000912},
|
|
|
|
{0x048e, 0x00000db6},
|
|
|
|
{0x049c, 0x00596596},
|
|
|
|
{0x049e, 0x00000514},
|
|
|
|
{0x04a2, 0x00410280},
|
|
|
|
{0x04a4, 0x00000000},
|
|
|
|
{0x04a6, 0x00000000},
|
|
|
|
{0x04a8, 0x00000000},
|
|
|
|
{0x04aa, 0x00000000},
|
|
|
|
{0x04ae, 0x007df7dd},
|
|
|
|
{0x04b0, 0x006d95d4},
|
|
|
|
{0x04b2, 0x00492410},
|
|
|
|
};
|
|
|
|
struct device *dev = &phydev->mdio.dev;
|
|
|
|
const struct firmware *fw;
|
|
|
|
unsigned int i;
|
|
|
|
u16 crc, reg;
|
|
|
|
bool serdes_init;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
/* all writes below are broadcasted to all PHYs in the same package */
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg |= SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MII_VSC85XX_INT_MASK, 0);
|
|
|
|
|
|
|
|
/* The below register writes are tweaking analog and electrical
|
|
|
|
* configuration that were determined through characterization by PHY
|
|
|
|
* engineers. These don't mean anything more than "these are the best
|
|
|
|
* values".
|
|
|
|
*/
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_PHY_CNTL_2, 0x0040);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_20, 0x4320);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_24, 0x0c00);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_9, 0x18ca);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_5, 0x1b20);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg |= 0x8000;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TR);
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pre_init1); i++)
|
|
|
|
vsc8584_csr_write(phydev, pre_init1[i].reg, pre_init1[i].val);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED_2);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_CU_PMD_TX_CNTL, 0x028e);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TR);
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pre_init2); i++)
|
|
|
|
vsc8584_csr_write(phydev, pre_init2[i].reg, pre_init2[i].val);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg &= ~0x8000;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
/* end of write broadcasting */
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg &= ~SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
ret = request_firmware(&fw, MSCC_VSC8574_REVB_INT8051_FW, dev);
|
|
|
|
if (ret) {
|
|
|
|
dev_err(dev, "failed to load firmware %s, ret: %d\n",
|
|
|
|
MSCC_VSC8574_REVB_INT8051_FW, ret);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add one byte to size for the one added by the patch_fw function */
|
|
|
|
ret = vsc8584_get_fw_crc(phydev,
|
|
|
|
MSCC_VSC8574_REVB_INT8051_FW_START_ADDR,
|
|
|
|
fw->size + 1, &crc);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
if (crc == MSCC_VSC8574_REVB_INT8051_FW_CRC) {
|
|
|
|
serdes_init = vsc8574_is_serdes_init(phydev);
|
|
|
|
|
|
|
|
if (!serdes_init) {
|
|
|
|
ret = vsc8584_micro_assert_reset(phydev);
|
|
|
|
if (ret) {
|
|
|
|
dev_err(dev,
|
|
|
|
"%s: failed to assert reset of micro\n",
|
|
|
|
__func__);
|
2018-10-17 00:37:35 +07:00
|
|
|
goto out;
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
dev_dbg(dev, "FW CRC is not the expected one, patching FW\n");
|
|
|
|
|
|
|
|
serdes_init = false;
|
|
|
|
|
|
|
|
if (vsc8584_patch_fw(phydev, fw))
|
|
|
|
dev_warn(dev,
|
|
|
|
"failed to patch FW, expect non-optimal device\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!serdes_init) {
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_TRAP_ROM_ADDR(1), 0x3eb7);
|
|
|
|
phy_base_write(phydev, MSCC_PATCH_RAM_ADDR(1), 0x4012);
|
|
|
|
phy_base_write(phydev, MSCC_INT_MEM_CNTL,
|
|
|
|
EN_PATCH_RAM_TRAP_ADDR(1));
|
|
|
|
|
|
|
|
vsc8584_micro_deassert_reset(phydev, false);
|
|
|
|
|
|
|
|
/* Add one byte to size for the one added by the patch_fw
|
|
|
|
* function
|
|
|
|
*/
|
|
|
|
ret = vsc8584_get_fw_crc(phydev,
|
|
|
|
MSCC_VSC8574_REVB_INT8051_FW_START_ADDR,
|
|
|
|
fw->size + 1, &crc);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
if (crc != MSCC_VSC8574_REVB_INT8051_FW_CRC)
|
|
|
|
dev_warn(dev,
|
|
|
|
"FW CRC after patching is not the expected one, expect non-optimal device\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
ret = vsc8584_cmd(phydev, PROC_CMD_1588_DEFAULT_INIT |
|
|
|
|
PROC_CMD_PHY_INIT);
|
|
|
|
|
|
|
|
out:
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
release_firmware(fw);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
/* bus->mdio_lock should be locked when using this function */
|
|
|
|
static int vsc8584_config_pre_init(struct phy_device *phydev)
|
|
|
|
{
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val pre_init1[] = {
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
{0x07fa, 0x0050100f},
|
|
|
|
{0x1688, 0x00049f81},
|
|
|
|
{0x0f90, 0x00688980},
|
|
|
|
{0x03a4, 0x0000d8f0},
|
|
|
|
{0x0fc0, 0x00000400},
|
|
|
|
{0x0f82, 0x0012b002},
|
|
|
|
{0x1686, 0x00000004},
|
|
|
|
{0x168c, 0x00d2c46f},
|
|
|
|
{0x17a2, 0x00000620},
|
|
|
|
{0x16a0, 0x00eeffdd},
|
|
|
|
{0x16a6, 0x00071448},
|
|
|
|
{0x16a4, 0x0013132f},
|
|
|
|
{0x16a8, 0x00000000},
|
|
|
|
{0x0ffc, 0x00c0a028},
|
|
|
|
{0x0fe8, 0x0091b06c},
|
|
|
|
{0x0fea, 0x00041600},
|
|
|
|
{0x0f80, 0x00fffaff},
|
|
|
|
{0x0fec, 0x00901809},
|
|
|
|
{0x0ffe, 0x00b01007},
|
|
|
|
{0x16b0, 0x00eeff00},
|
|
|
|
{0x16b2, 0x00007000},
|
|
|
|
{0x16b4, 0x00000814},
|
|
|
|
};
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val pre_init2[] = {
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
{0x0486, 0x0008a518},
|
|
|
|
{0x0488, 0x006dc696},
|
|
|
|
{0x048a, 0x00000912},
|
|
|
|
};
|
|
|
|
const struct firmware *fw;
|
|
|
|
struct device *dev = &phydev->mdio.dev;
|
|
|
|
unsigned int i;
|
|
|
|
u16 crc, reg;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
/* all writes below are broadcasted to all PHYs in the same package */
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg |= SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MII_VSC85XX_INT_MASK, 0);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_BYPASS_CONTROL);
|
|
|
|
reg |= PARALLEL_DET_IGNORE_ADVERTISED;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_BYPASS_CONTROL, reg);
|
|
|
|
|
|
|
|
/* The below register writes are tweaking analog and electrical
|
|
|
|
* configuration that were determined through characterization by PHY
|
|
|
|
* engineers. These don't mean anything more than "these are the best
|
|
|
|
* values".
|
|
|
|
*/
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED_3);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_SERDES_TX_CRC_ERR_CNT, 0x2000);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_5, 0x1f20);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg |= 0x8000;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TR);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_CNTL, TR_WRITE | TR_ADDR(0x2fa4));
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TR_MSB);
|
|
|
|
reg &= ~0x007f;
|
|
|
|
reg |= 0x0019;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_MSB, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TR_CNTL, TR_WRITE | TR_ADDR(0x0fa4));
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pre_init1); i++)
|
|
|
|
vsc8584_csr_write(phydev, pre_init1[i].reg, pre_init1[i].val);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED_2);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_PHY_CU_PMD_TX_CNTL, 0x028e);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TR);
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pre_init2); i++)
|
|
|
|
vsc8584_csr_write(phydev, pre_init2[i].reg, pre_init2[i].val);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg &= ~0x8000;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
/* end of write broadcasting */
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg &= ~SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
ret = request_firmware(&fw, MSCC_VSC8584_REVB_INT8051_FW, dev);
|
|
|
|
if (ret) {
|
|
|
|
dev_err(dev, "failed to load firmware %s, ret: %d\n",
|
|
|
|
MSCC_VSC8584_REVB_INT8051_FW, ret);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add one byte to size for the one added by the patch_fw function */
|
|
|
|
ret = vsc8584_get_fw_crc(phydev,
|
|
|
|
MSCC_VSC8584_REVB_INT8051_FW_START_ADDR,
|
|
|
|
fw->size + 1, &crc);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
if (crc != MSCC_VSC8584_REVB_INT8051_FW_CRC) {
|
|
|
|
dev_dbg(dev, "FW CRC is not the expected one, patching FW\n");
|
|
|
|
if (vsc8584_patch_fw(phydev, fw))
|
|
|
|
dev_warn(dev,
|
|
|
|
"failed to patch FW, expect non-optimal device\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
vsc8584_micro_deassert_reset(phydev, false);
|
|
|
|
|
|
|
|
/* Add one byte to size for the one added by the patch_fw function */
|
|
|
|
ret = vsc8584_get_fw_crc(phydev,
|
|
|
|
MSCC_VSC8584_REVB_INT8051_FW_START_ADDR,
|
|
|
|
fw->size + 1, &crc);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
if (crc != MSCC_VSC8584_REVB_INT8051_FW_CRC)
|
|
|
|
dev_warn(dev,
|
|
|
|
"FW CRC after patching is not the expected one, expect non-optimal device\n");
|
|
|
|
|
|
|
|
ret = vsc8584_micro_assert_reset(phydev);
|
|
|
|
if (ret)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
vsc8584_micro_deassert_reset(phydev, true);
|
|
|
|
|
|
|
|
out:
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
release_firmware(fw);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
static void vsc8584_get_base_addr(struct phy_device *phydev)
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
{
|
2020-05-06 21:53:15 +07:00
|
|
|
struct vsc8531_private *vsc8531 = phydev->priv;
|
|
|
|
u16 val, addr;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
mutex_lock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
__phy_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_EXTENDED);
|
2019-11-13 23:33:15 +07:00
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
addr = __phy_read(phydev, MSCC_PHY_EXT_PHY_CNTL_4);
|
|
|
|
addr >>= PHY_CNTL_4_ADDR_POS;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
val = __phy_read(phydev, MSCC_PHY_ACTIPHY_CNTL);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
__phy_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
if (val & PHY_ADDR_REVERSED)
|
|
|
|
vsc8531->base_addr = phydev->mdio.addr + addr;
|
|
|
|
else
|
|
|
|
vsc8531->base_addr = phydev->mdio.addr - addr;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-05-25 03:47:27 +07:00
|
|
|
vsc8531->addr = addr;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc8584_config_init(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531 = phydev->priv;
|
|
|
|
int ret, i;
|
2020-05-06 21:53:15 +07:00
|
|
|
u16 val;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
|
|
|
phydev->mdix_ctrl = ETH_TP_MDI_AUTO;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
|
|
|
|
/* Some parts of the init sequence are identical for every PHY in the
|
|
|
|
* package. Some parts are modifying the GPIO register bank which is a
|
|
|
|
* set of registers that are affecting all PHYs, a few resetting the
|
|
|
|
* microprocessor common to all PHYs. The CRC check responsible of the
|
|
|
|
* checking the firmware within the 8051 microprocessor can only be
|
|
|
|
* accessed via the PHY whose internal address in the package is 0.
|
|
|
|
* All PHYs' interrupts mask register has to be zeroed before enabling
|
|
|
|
* any PHY's interrupt in this register.
|
|
|
|
* For all these reasons, we need to do the init sequence once and only
|
|
|
|
* once whatever is the first PHY in the package that is initialized and
|
|
|
|
* do the correct init sequence for all PHYs that are package-critical
|
|
|
|
* in this pre-init function.
|
|
|
|
*/
|
2020-05-06 21:53:15 +07:00
|
|
|
if (phy_package_init_once(phydev)) {
|
2019-11-13 23:33:15 +07:00
|
|
|
/* The following switch statement assumes that the lowest
|
|
|
|
* nibble of the phy_id_mask is always 0. This works because
|
|
|
|
* the lowest nibble of the PHY_ID's below are also 0.
|
|
|
|
*/
|
|
|
|
WARN_ON(phydev->drv->phy_id_mask & 0xf);
|
|
|
|
|
|
|
|
switch (phydev->phy_id & phydev->drv->phy_id_mask) {
|
|
|
|
case PHY_ID_VSC8504:
|
|
|
|
case PHY_ID_VSC8552:
|
|
|
|
case PHY_ID_VSC8572:
|
|
|
|
case PHY_ID_VSC8574:
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
ret = vsc8574_config_pre_init(phydev);
|
2019-11-13 23:33:15 +07:00
|
|
|
break;
|
|
|
|
case PHY_ID_VSC856X:
|
|
|
|
case PHY_ID_VSC8575:
|
|
|
|
case PHY_ID_VSC8582:
|
|
|
|
case PHY_ID_VSC8584:
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
ret = vsc8584_config_pre_init(phydev);
|
2019-11-13 23:33:15 +07:00
|
|
|
break;
|
|
|
|
default:
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
ret = -EINVAL;
|
2019-11-13 23:33:15 +07:00
|
|
|
break;
|
2019-11-16 05:38:34 +07:00
|
|
|
}
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
}
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
val = phy_base_read(phydev, MSCC_PHY_MAC_CFG_FASTLINK);
|
|
|
|
val &= ~MAC_CFG_MASK;
|
2020-03-19 21:19:57 +07:00
|
|
|
if (phydev->interface == PHY_INTERFACE_MODE_QSGMII) {
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
val |= MAC_CFG_QSGMII;
|
2020-03-19 21:19:57 +07:00
|
|
|
} else if (phydev->interface == PHY_INTERFACE_MODE_SGMII) {
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
val |= MAC_CFG_SGMII;
|
2020-03-19 21:19:57 +07:00
|
|
|
} else if (phy_interface_is_rgmii(phydev)) {
|
|
|
|
val |= MAC_CFG_RGMII;
|
|
|
|
} else {
|
|
|
|
ret = -EINVAL;
|
|
|
|
goto err;
|
|
|
|
}
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
|
|
|
ret = phy_base_write(phydev, MSCC_PHY_MAC_CFG_FASTLINK, val);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
2020-03-19 21:19:57 +07:00
|
|
|
if (!phy_interface_is_rgmii(phydev)) {
|
|
|
|
val = PROC_CMD_MCB_ACCESS_MAC_CONF | PROC_CMD_RST_CONF_PORT |
|
|
|
|
PROC_CMD_READ_MOD_WRITE_PORT;
|
|
|
|
if (phydev->interface == PHY_INTERFACE_MODE_QSGMII)
|
|
|
|
val |= PROC_CMD_QSGMII_MAC;
|
|
|
|
else
|
|
|
|
val |= PROC_CMD_SGMII_MAC;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-03-19 21:19:57 +07:00
|
|
|
ret = vsc8584_cmd(phydev, val);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-03-19 21:19:57 +07:00
|
|
|
usleep_range(10000, 20000);
|
|
|
|
}
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
|
|
|
/* Disable SerDes for 100Base-FX */
|
|
|
|
ret = vsc8584_cmd(phydev, PROC_CMD_FIBER_MEDIA_CONF |
|
2020-05-06 21:53:15 +07:00
|
|
|
PROC_CMD_FIBER_PORT(vsc8531->base_addr) |
|
|
|
|
PROC_CMD_FIBER_DISABLE |
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
PROC_CMD_READ_MOD_WRITE_PORT |
|
|
|
|
PROC_CMD_RST_CONF_PORT | PROC_CMD_FIBER_100BASE_FX);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
/* Disable SerDes for 1000Base-X */
|
|
|
|
ret = vsc8584_cmd(phydev, PROC_CMD_FIBER_MEDIA_CONF |
|
2020-05-06 21:53:15 +07:00
|
|
|
PROC_CMD_FIBER_PORT(vsc8531->base_addr) |
|
|
|
|
PROC_CMD_FIBER_DISABLE |
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
PROC_CMD_READ_MOD_WRITE_PORT |
|
|
|
|
PROC_CMD_RST_CONF_PORT | PROC_CMD_FIBER_1000BASE_X);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
|
2020-03-13 16:48:01 +07:00
|
|
|
ret = vsc8584_macsec_init(phydev);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
2020-01-14 05:31:45 +07:00
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
phy_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
val = phy_read(phydev, MSCC_PHY_EXT_PHY_CNTL_1);
|
|
|
|
val &= ~(MEDIA_OP_MODE_MASK | VSC8584_MAC_IF_SELECTION_MASK);
|
2020-02-26 21:40:34 +07:00
|
|
|
val |= (MEDIA_OP_MODE_COPPER << MEDIA_OP_MODE_POS) |
|
|
|
|
(VSC8584_MAC_IF_SELECTION_SGMII << VSC8584_MAC_IF_SELECTION_POS);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
ret = phy_write(phydev, MSCC_PHY_EXT_PHY_CNTL_1, val);
|
2020-03-19 19:48:19 +07:00
|
|
|
if (ret)
|
|
|
|
return ret;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
2020-03-24 21:13:58 +07:00
|
|
|
if (phy_interface_is_rgmii(phydev)) {
|
|
|
|
ret = vsc85xx_rgmii_set_skews(phydev, VSC8572_RGMII_CNTL,
|
|
|
|
VSC8572_RGMII_RX_DELAY_MASK,
|
|
|
|
VSC8572_RGMII_TX_DELAY_MASK);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
}
|
2020-03-19 21:19:58 +07:00
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
ret = genphy_soft_reset(phydev);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
for (i = 0; i < vsc8531->nleds; i++) {
|
|
|
|
ret = vsc85xx_led_cntl_set(phydev, i, vsc8531->leds_mode[i]);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2019-08-17 17:29:25 +07:00
|
|
|
return 0;
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
|
|
|
|
err:
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2020-03-17 04:32:33 +07:00
|
|
|
static irqreturn_t vsc8584_handle_interrupt(struct phy_device *phydev)
|
2020-01-14 05:31:48 +07:00
|
|
|
{
|
2020-03-17 04:32:33 +07:00
|
|
|
int irq_status;
|
|
|
|
|
|
|
|
irq_status = phy_read(phydev, MII_VSC85XX_INT_STATUS);
|
|
|
|
if (irq_status < 0 || !(irq_status & MII_VSC85XX_INT_MASK_MASK))
|
|
|
|
return IRQ_NONE;
|
|
|
|
|
2020-03-17 04:33:31 +07:00
|
|
|
if (irq_status & MII_VSC85XX_INT_MASK_EXT)
|
|
|
|
vsc8584_handle_macsec_interrupt(phydev);
|
|
|
|
|
|
|
|
if (irq_status & MII_VSC85XX_INT_MASK_LINK_CHG)
|
|
|
|
phy_mac_interrupt(phydev);
|
2020-03-17 04:32:33 +07:00
|
|
|
|
|
|
|
return IRQ_HANDLED;
|
2020-01-14 05:31:48 +07:00
|
|
|
}
|
|
|
|
|
2016-08-05 19:24:21 +07:00
|
|
|
static int vsc85xx_config_init(struct phy_device *phydev)
|
|
|
|
{
|
2018-12-18 16:27:56 +07:00
|
|
|
int rc, i, phy_id;
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
struct vsc8531_private *vsc8531 = phydev->priv;
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
rc = vsc85xx_default_config(phydev);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
2016-09-19 17:03:54 +07:00
|
|
|
|
|
|
|
rc = vsc85xx_mac_if_set(phydev, phydev->interface);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
rc = vsc85xx_edge_rate_cntl_set(phydev, vsc8531->rate_magic);
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
|
2018-12-18 16:27:56 +07:00
|
|
|
phy_id = phydev->drv->phy_id & phydev->drv->phy_id_mask;
|
|
|
|
if (PHY_ID_VSC8531 == phy_id || PHY_ID_VSC8541 == phy_id ||
|
|
|
|
PHY_ID_VSC8530 == phy_id || PHY_ID_VSC8540 == phy_id) {
|
|
|
|
rc = vsc8531_pre_init_seq_set(phydev);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2018-10-08 17:07:25 +07:00
|
|
|
rc = vsc85xx_eee_init_seq_set(phydev);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
|
2018-09-03 15:48:47 +07:00
|
|
|
for (i = 0; i < vsc8531->nleds; i++) {
|
|
|
|
rc = vsc85xx_led_cntl_set(phydev, i, vsc8531->leds_mode[i]);
|
|
|
|
if (rc)
|
|
|
|
return rc;
|
|
|
|
}
|
2017-02-07 20:40:26 +07:00
|
|
|
|
2019-08-17 17:29:25 +07:00
|
|
|
return 0;
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
static int vsc8584_did_interrupt(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int rc = 0;
|
|
|
|
|
|
|
|
if (phydev->interrupts == PHY_INTERRUPT_ENABLED)
|
|
|
|
rc = phy_read(phydev, MII_VSC85XX_INT_STATUS);
|
|
|
|
|
|
|
|
return (rc < 0) ? 0 : rc & MII_VSC85XX_INT_MASK_MASK;
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
static int vsc8514_config_pre_init(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
/* These are the settings to override the silicon default
|
|
|
|
* values to handle hardware performance of PHY. They
|
|
|
|
* are set at Power-On state and remain until PHY Reset.
|
|
|
|
*/
|
2019-10-07 19:03:08 +07:00
|
|
|
static const struct reg_val pre_init1[] = {
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
{0x0f90, 0x00688980},
|
|
|
|
{0x0786, 0x00000003},
|
|
|
|
{0x07fa, 0x0050100f},
|
|
|
|
{0x0f82, 0x0012b002},
|
|
|
|
{0x1686, 0x00000004},
|
|
|
|
{0x168c, 0x00d2c46f},
|
|
|
|
{0x17a2, 0x00000620},
|
|
|
|
{0x16a0, 0x00eeffdd},
|
|
|
|
{0x16a6, 0x00071448},
|
|
|
|
{0x16a4, 0x0013132f},
|
|
|
|
{0x16a8, 0x00000000},
|
|
|
|
{0x0ffc, 0x00c0a028},
|
|
|
|
{0x0fe8, 0x0091b06c},
|
|
|
|
{0x0fea, 0x00041600},
|
|
|
|
{0x0f80, 0x00fffaff},
|
|
|
|
{0x0fec, 0x00901809},
|
|
|
|
{0x0ffe, 0x00b01007},
|
|
|
|
{0x16b0, 0x00eeff00},
|
|
|
|
{0x16b2, 0x00007000},
|
|
|
|
{0x16b4, 0x00000814},
|
|
|
|
};
|
|
|
|
unsigned int i;
|
|
|
|
u16 reg;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
/* all writes below are broadcasted to all PHYs in the same package */
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg |= SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg |= BIT(15);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TR);
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(pre_init1); i++)
|
|
|
|
vsc8584_csr_write(phydev, pre_init1[i].reg, pre_init1[i].val);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_TEST);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_TEST_PAGE_8);
|
|
|
|
reg &= ~BIT(15);
|
|
|
|
phy_base_write(phydev, MSCC_PHY_TEST_PAGE_8, reg);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
reg = phy_base_read(phydev, MSCC_PHY_EXT_CNTL_STATUS);
|
|
|
|
reg &= ~SMI_BROADCAST_WR_EN;
|
|
|
|
phy_base_write(phydev, MSCC_PHY_EXT_CNTL_STATUS, reg);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static u32 vsc85xx_csr_ctrl_phy_read(struct phy_device *phydev,
|
|
|
|
u32 target, u32 reg)
|
|
|
|
{
|
|
|
|
unsigned long deadline;
|
|
|
|
u32 val, val_l, val_h;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_CSR_CNTL);
|
|
|
|
|
|
|
|
/* CSR registers are grouped under different Target IDs.
|
|
|
|
* 6-bit Target_ID is split between MSCC_EXT_PAGE_CSR_CNTL_20 and
|
|
|
|
* MSCC_EXT_PAGE_CSR_CNTL_19 registers.
|
|
|
|
* Target_ID[5:2] maps to bits[3:0] of MSCC_EXT_PAGE_CSR_CNTL_20
|
|
|
|
* and Target_ID[1:0] maps to bits[13:12] of MSCC_EXT_PAGE_CSR_CNTL_19.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Setup the Target ID */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_20,
|
|
|
|
MSCC_PHY_CSR_CNTL_20_TARGET(target >> 2));
|
|
|
|
|
|
|
|
/* Trigger CSR Action - Read into the CSR's */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_19,
|
|
|
|
MSCC_PHY_CSR_CNTL_19_CMD | MSCC_PHY_CSR_CNTL_19_READ |
|
|
|
|
MSCC_PHY_CSR_CNTL_19_REG_ADDR(reg) |
|
|
|
|
MSCC_PHY_CSR_CNTL_19_TARGET(target & 0x3));
|
|
|
|
|
|
|
|
/* Wait for register access*/
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
usleep_range(500, 1000);
|
|
|
|
val = phy_base_read(phydev, MSCC_EXT_PAGE_CSR_CNTL_19);
|
|
|
|
} while (time_before(jiffies, deadline) &&
|
|
|
|
!(val & MSCC_PHY_CSR_CNTL_19_CMD));
|
|
|
|
|
|
|
|
if (!(val & MSCC_PHY_CSR_CNTL_19_CMD))
|
|
|
|
return 0xffffffff;
|
|
|
|
|
|
|
|
/* Read the Least Significant Word (LSW) (17) */
|
|
|
|
val_l = phy_base_read(phydev, MSCC_EXT_PAGE_CSR_CNTL_17);
|
|
|
|
|
|
|
|
/* Read the Most Significant Word (MSW) (18) */
|
|
|
|
val_h = phy_base_read(phydev, MSCC_EXT_PAGE_CSR_CNTL_18);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return (val_h << 16) | val_l;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_csr_ctrl_phy_write(struct phy_device *phydev,
|
|
|
|
u32 target, u32 reg, u32 val)
|
|
|
|
{
|
|
|
|
unsigned long deadline;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_CSR_CNTL);
|
|
|
|
|
|
|
|
/* CSR registers are grouped under different Target IDs.
|
|
|
|
* 6-bit Target_ID is split between MSCC_EXT_PAGE_CSR_CNTL_20 and
|
|
|
|
* MSCC_EXT_PAGE_CSR_CNTL_19 registers.
|
|
|
|
* Target_ID[5:2] maps to bits[3:0] of MSCC_EXT_PAGE_CSR_CNTL_20
|
|
|
|
* and Target_ID[1:0] maps to bits[13:12] of MSCC_EXT_PAGE_CSR_CNTL_19.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Setup the Target ID */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_20,
|
|
|
|
MSCC_PHY_CSR_CNTL_20_TARGET(target >> 2));
|
|
|
|
|
|
|
|
/* Write the Least Significant Word (LSW) (17) */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_17, (u16)val);
|
|
|
|
|
|
|
|
/* Write the Most Significant Word (MSW) (18) */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_18, (u16)(val >> 16));
|
|
|
|
|
|
|
|
/* Trigger CSR Action - Write into the CSR's */
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_CSR_CNTL_19,
|
|
|
|
MSCC_PHY_CSR_CNTL_19_CMD |
|
|
|
|
MSCC_PHY_CSR_CNTL_19_REG_ADDR(reg) |
|
|
|
|
MSCC_PHY_CSR_CNTL_19_TARGET(target & 0x3));
|
|
|
|
|
|
|
|
/* Wait for register access */
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
usleep_range(500, 1000);
|
|
|
|
val = phy_base_read(phydev, MSCC_EXT_PAGE_CSR_CNTL_19);
|
|
|
|
} while (time_before(jiffies, deadline) &&
|
|
|
|
!(val & MSCC_PHY_CSR_CNTL_19_CMD));
|
|
|
|
|
|
|
|
if (!(val & MSCC_PHY_CSR_CNTL_19_CMD))
|
|
|
|
return -ETIMEDOUT;
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int __phy_write_mcb_s6g(struct phy_device *phydev, u32 reg, u8 mcb,
|
|
|
|
u32 op)
|
|
|
|
{
|
|
|
|
unsigned long deadline;
|
|
|
|
u32 val;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET, reg,
|
|
|
|
op | (1 << mcb));
|
|
|
|
if (ret)
|
|
|
|
return -EINVAL;
|
|
|
|
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
usleep_range(500, 1000);
|
|
|
|
val = vsc85xx_csr_ctrl_phy_read(phydev, PHY_MCB_TARGET, reg);
|
|
|
|
|
|
|
|
if (val == 0xffffffff)
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
} while (time_before(jiffies, deadline) && (val & op));
|
|
|
|
|
|
|
|
if (val & op)
|
|
|
|
return -ETIMEDOUT;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Trigger a read to the spcified MCB */
|
|
|
|
static int phy_update_mcb_s6g(struct phy_device *phydev, u32 reg, u8 mcb)
|
|
|
|
{
|
|
|
|
return __phy_write_mcb_s6g(phydev, reg, mcb, PHY_MCB_S6G_READ);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Trigger a write to the spcified MCB */
|
|
|
|
static int phy_commit_mcb_s6g(struct phy_device *phydev, u32 reg, u8 mcb)
|
|
|
|
{
|
|
|
|
return __phy_write_mcb_s6g(phydev, reg, mcb, PHY_MCB_S6G_WRITE);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc8514_config_init(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531 = phydev->priv;
|
|
|
|
unsigned long deadline;
|
|
|
|
int ret, i;
|
2020-05-06 21:53:15 +07:00
|
|
|
u16 val;
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
u32 reg;
|
|
|
|
|
|
|
|
phydev->mdix_ctrl = ETH_TP_MDI_AUTO;
|
|
|
|
|
|
|
|
mutex_lock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
|
|
|
|
/* Some parts of the init sequence are identical for every PHY in the
|
|
|
|
* package. Some parts are modifying the GPIO register bank which is a
|
|
|
|
* set of registers that are affecting all PHYs, a few resetting the
|
|
|
|
* microprocessor common to all PHYs.
|
|
|
|
* All PHYs' interrupts mask register has to be zeroed before enabling
|
|
|
|
* any PHY's interrupt in this register.
|
|
|
|
* For all these reasons, we need to do the init sequence once and only
|
|
|
|
* once whatever is the first PHY in the package that is initialized and
|
|
|
|
* do the correct init sequence for all PHYs that are package-critical
|
|
|
|
* in this pre-init function.
|
|
|
|
*/
|
2020-05-06 21:53:15 +07:00
|
|
|
if (phy_package_init_once(phydev))
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
vsc8514_config_pre_init(phydev);
|
|
|
|
|
|
|
|
phy_base_write(phydev, MSCC_EXT_PAGE_ACCESS,
|
|
|
|
MSCC_PHY_PAGE_EXTENDED_GPIO);
|
|
|
|
|
|
|
|
val = phy_base_read(phydev, MSCC_PHY_MAC_CFG_FASTLINK);
|
|
|
|
|
|
|
|
val &= ~MAC_CFG_MASK;
|
|
|
|
val |= MAC_CFG_QSGMII;
|
|
|
|
ret = phy_base_write(phydev, MSCC_PHY_MAC_CFG_FASTLINK, val);
|
|
|
|
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
ret = vsc8584_cmd(phydev,
|
|
|
|
PROC_CMD_MCB_ACCESS_MAC_CONF |
|
|
|
|
PROC_CMD_RST_CONF_PORT |
|
|
|
|
PROC_CMD_READ_MOD_WRITE_PORT | PROC_CMD_QSGMII_MAC);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
/* 6g mcb */
|
|
|
|
phy_update_mcb_s6g(phydev, PHY_MCB_S6G_CFG, 0);
|
|
|
|
/* lcpll mcb */
|
|
|
|
phy_update_mcb_s6g(phydev, PHY_S6G_LCPLL_CFG, 0);
|
|
|
|
/* pll5gcfg0 */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_PLL5G_CFG0, 0x7036f145);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
phy_commit_mcb_s6g(phydev, PHY_S6G_LCPLL_CFG, 0);
|
|
|
|
/* pllcfg */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_PLL_CFG,
|
|
|
|
(3 << PHY_S6G_PLL_ENA_OFFS_POS) |
|
|
|
|
(120 << PHY_S6G_PLL_FSM_CTRL_DATA_POS)
|
|
|
|
| (0 << PHY_S6G_PLL_FSM_ENA_POS));
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
/* commoncfg */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_COMMON_CFG,
|
|
|
|
(0 << PHY_S6G_SYS_RST_POS) |
|
|
|
|
(0 << PHY_S6G_ENA_LANE_POS) |
|
|
|
|
(0 << PHY_S6G_ENA_LOOP_POS) |
|
|
|
|
(0 << PHY_S6G_QRATE_POS) |
|
|
|
|
(3 << PHY_S6G_IF_MODE_POS));
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
/* misccfg */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_MISC_CFG, 1);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
/* gpcfg */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_GPC_CFG, 768);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
phy_commit_mcb_s6g(phydev, PHY_S6G_DFT_CFG2, 0);
|
|
|
|
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
usleep_range(500, 1000);
|
|
|
|
phy_update_mcb_s6g(phydev, PHY_MCB_S6G_CFG,
|
|
|
|
0); /* read 6G MCB into CSRs */
|
|
|
|
reg = vsc85xx_csr_ctrl_phy_read(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_PLL_STATUS);
|
|
|
|
if (reg == 0xffffffff) {
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return -EIO;
|
|
|
|
}
|
|
|
|
|
|
|
|
} while (time_before(jiffies, deadline) && (reg & BIT(12)));
|
|
|
|
|
|
|
|
if (reg & BIT(12)) {
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return -ETIMEDOUT;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* misccfg */
|
|
|
|
ret = vsc85xx_csr_ctrl_phy_write(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_MISC_CFG, 0);
|
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
phy_commit_mcb_s6g(phydev, PHY_MCB_S6G_CFG, 0);
|
|
|
|
|
|
|
|
deadline = jiffies + msecs_to_jiffies(PROC_CMD_NCOMPLETED_TIMEOUT_MS);
|
|
|
|
do {
|
|
|
|
usleep_range(500, 1000);
|
|
|
|
phy_update_mcb_s6g(phydev, PHY_MCB_S6G_CFG,
|
|
|
|
0); /* read 6G MCB into CSRs */
|
|
|
|
reg = vsc85xx_csr_ctrl_phy_read(phydev, PHY_MCB_TARGET,
|
|
|
|
PHY_S6G_IB_STATUS0);
|
|
|
|
if (reg == 0xffffffff) {
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return -EIO;
|
|
|
|
}
|
|
|
|
|
|
|
|
} while (time_before(jiffies, deadline) && !(reg & BIT(8)));
|
|
|
|
|
|
|
|
if (!(reg & BIT(8))) {
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return -ETIMEDOUT;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
|
|
|
|
ret = phy_write(phydev, MSCC_EXT_PAGE_ACCESS, MSCC_PHY_PAGE_STANDARD);
|
|
|
|
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
ret = phy_modify(phydev, MSCC_PHY_EXT_PHY_CNTL_1, MEDIA_OP_MODE_MASK,
|
2020-02-26 21:40:34 +07:00
|
|
|
MEDIA_OP_MODE_COPPER << MEDIA_OP_MODE_POS);
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
ret = genphy_soft_reset(phydev);
|
|
|
|
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
for (i = 0; i < vsc8531->nleds; i++) {
|
|
|
|
ret = vsc85xx_led_cntl_set(phydev, i, vsc8531->leds_mode[i]);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
err:
|
|
|
|
mutex_unlock(&phydev->mdio.bus->mdio_lock);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2016-08-05 19:24:21 +07:00
|
|
|
static int vsc85xx_ack_interrupt(struct phy_device *phydev)
|
|
|
|
{
|
2016-09-08 15:39:31 +07:00
|
|
|
int rc = 0;
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
if (phydev->interrupts == PHY_INTERRUPT_ENABLED)
|
|
|
|
rc = phy_read(phydev, MII_VSC85XX_INT_STATUS);
|
2016-08-05 19:24:21 +07:00
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
return (rc < 0) ? rc : 0;
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_config_intr(struct phy_device *phydev)
|
|
|
|
{
|
2016-09-08 15:39:31 +07:00
|
|
|
int rc;
|
|
|
|
|
|
|
|
if (phydev->interrupts == PHY_INTERRUPT_ENABLED) {
|
2020-03-13 16:48:01 +07:00
|
|
|
vsc8584_config_macsec_intr(phydev);
|
|
|
|
|
2016-09-08 15:39:31 +07:00
|
|
|
rc = phy_write(phydev, MII_VSC85XX_INT_MASK,
|
|
|
|
MII_VSC85XX_INT_MASK_MASK);
|
|
|
|
} else {
|
|
|
|
rc = phy_write(phydev, MII_VSC85XX_INT_MASK, 0);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
rc = phy_read(phydev, MII_VSC85XX_INT_STATUS);
|
|
|
|
}
|
|
|
|
|
|
|
|
return rc;
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
2016-11-29 16:46:48 +07:00
|
|
|
static int vsc85xx_config_aneg(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = vsc85xx_mdix_set(phydev, phydev->mdix_ctrl);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
|
|
|
|
return genphy_config_aneg(phydev);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vsc85xx_read_status(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = vsc85xx_mdix_get(phydev, &phydev->mdix);
|
|
|
|
if (rc < 0)
|
|
|
|
return rc;
|
|
|
|
|
|
|
|
return genphy_read_status(phydev);
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
static int vsc8514_probe(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531;
|
|
|
|
u32 default_mode[4] = {VSC8531_LINK_1000_ACTIVITY,
|
|
|
|
VSC8531_LINK_100_ACTIVITY, VSC8531_LINK_ACTIVITY,
|
|
|
|
VSC8531_DUPLEX_COLLISION};
|
|
|
|
|
|
|
|
vsc8531 = devm_kzalloc(&phydev->mdio.dev, sizeof(*vsc8531), GFP_KERNEL);
|
|
|
|
if (!vsc8531)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
phydev->priv = vsc8531;
|
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
vsc8584_get_base_addr(phydev);
|
|
|
|
devm_phy_package_join(&phydev->mdio.dev, phydev,
|
|
|
|
vsc8531->base_addr, 0);
|
|
|
|
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
vsc8531->nleds = 4;
|
|
|
|
vsc8531->supp_led_modes = VSC85XX_SUPP_LED_MODES;
|
|
|
|
vsc8531->hw_stats = vsc85xx_hw_stats;
|
|
|
|
vsc8531->nstats = ARRAY_SIZE(vsc85xx_hw_stats);
|
2019-07-24 22:32:57 +07:00
|
|
|
vsc8531->stats = devm_kcalloc(&phydev->mdio.dev, vsc8531->nstats,
|
|
|
|
sizeof(u64), GFP_KERNEL);
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
if (!vsc8531->stats)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
return vsc85xx_dt_led_modes_get(phydev, default_mode);
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
static int vsc8574_probe(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531;
|
|
|
|
u32 default_mode[4] = {VSC8531_LINK_1000_ACTIVITY,
|
|
|
|
VSC8531_LINK_100_ACTIVITY, VSC8531_LINK_ACTIVITY,
|
|
|
|
VSC8531_DUPLEX_COLLISION};
|
|
|
|
|
|
|
|
vsc8531 = devm_kzalloc(&phydev->mdio.dev, sizeof(*vsc8531), GFP_KERNEL);
|
|
|
|
if (!vsc8531)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
phydev->priv = vsc8531;
|
|
|
|
|
2020-05-29 16:49:09 +07:00
|
|
|
vsc8584_get_base_addr(phydev);
|
|
|
|
devm_phy_package_join(&phydev->mdio.dev, phydev,
|
|
|
|
vsc8531->base_addr, 0);
|
|
|
|
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
vsc8531->nleds = 4;
|
|
|
|
vsc8531->supp_led_modes = VSC8584_SUPP_LED_MODES;
|
|
|
|
vsc8531->hw_stats = vsc8584_hw_stats;
|
|
|
|
vsc8531->nstats = ARRAY_SIZE(vsc8584_hw_stats);
|
2019-07-24 22:32:57 +07:00
|
|
|
vsc8531->stats = devm_kcalloc(&phydev->mdio.dev, vsc8531->nstats,
|
|
|
|
sizeof(u64), GFP_KERNEL);
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
if (!vsc8531->stats)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
return vsc85xx_dt_led_modes_get(phydev, default_mode);
|
|
|
|
}
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
static int vsc8584_probe(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531;
|
|
|
|
u32 default_mode[4] = {VSC8531_LINK_1000_ACTIVITY,
|
|
|
|
VSC8531_LINK_100_ACTIVITY, VSC8531_LINK_ACTIVITY,
|
|
|
|
VSC8531_DUPLEX_COLLISION};
|
|
|
|
|
|
|
|
if ((phydev->phy_id & MSCC_DEV_REV_MASK) != VSC8584_REVB) {
|
|
|
|
dev_err(&phydev->mdio.dev, "Only VSC8584 revB is supported.\n");
|
|
|
|
return -ENOTSUPP;
|
|
|
|
}
|
|
|
|
|
|
|
|
vsc8531 = devm_kzalloc(&phydev->mdio.dev, sizeof(*vsc8531), GFP_KERNEL);
|
|
|
|
if (!vsc8531)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
phydev->priv = vsc8531;
|
|
|
|
|
2020-05-06 21:53:15 +07:00
|
|
|
vsc8584_get_base_addr(phydev);
|
|
|
|
devm_phy_package_join(&phydev->mdio.dev, phydev,
|
|
|
|
vsc8531->base_addr, 0);
|
|
|
|
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
vsc8531->nleds = 4;
|
|
|
|
vsc8531->supp_led_modes = VSC8584_SUPP_LED_MODES;
|
|
|
|
vsc8531->hw_stats = vsc8584_hw_stats;
|
|
|
|
vsc8531->nstats = ARRAY_SIZE(vsc8584_hw_stats);
|
2019-07-24 22:32:57 +07:00
|
|
|
vsc8531->stats = devm_kcalloc(&phydev->mdio.dev, vsc8531->nstats,
|
|
|
|
sizeof(u64), GFP_KERNEL);
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
if (!vsc8531->stats)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
return vsc85xx_dt_led_modes_get(phydev, default_mode);
|
|
|
|
}
|
|
|
|
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
static int vsc85xx_probe(struct phy_device *phydev)
|
|
|
|
{
|
|
|
|
struct vsc8531_private *vsc8531;
|
2017-02-07 20:40:26 +07:00
|
|
|
int rate_magic;
|
2018-09-03 15:48:51 +07:00
|
|
|
u32 default_mode[2] = {VSC8531_LINK_1000_ACTIVITY,
|
2018-09-03 15:48:47 +07:00
|
|
|
VSC8531_LINK_100_ACTIVITY};
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
rate_magic = vsc85xx_edge_rate_magic_get(phydev);
|
|
|
|
if (rate_magic < 0)
|
|
|
|
return rate_magic;
|
|
|
|
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
vsc8531 = devm_kzalloc(&phydev->mdio.dev, sizeof(*vsc8531), GFP_KERNEL);
|
|
|
|
if (!vsc8531)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
phydev->priv = vsc8531;
|
|
|
|
|
2016-10-12 20:47:51 +07:00
|
|
|
vsc8531->rate_magic = rate_magic;
|
2018-09-03 15:48:47 +07:00
|
|
|
vsc8531->nleds = 2;
|
2018-09-03 15:48:48 +07:00
|
|
|
vsc8531->supp_led_modes = VSC85XX_SUPP_LED_MODES;
|
2018-10-08 17:07:24 +07:00
|
|
|
vsc8531->hw_stats = vsc85xx_hw_stats;
|
|
|
|
vsc8531->nstats = ARRAY_SIZE(vsc85xx_hw_stats);
|
2019-07-24 22:32:57 +07:00
|
|
|
vsc8531->stats = devm_kcalloc(&phydev->mdio.dev, vsc8531->nstats,
|
|
|
|
sizeof(u64), GFP_KERNEL);
|
2018-10-08 17:07:24 +07:00
|
|
|
if (!vsc8531->stats)
|
|
|
|
return -ENOMEM;
|
2016-10-12 20:47:51 +07:00
|
|
|
|
2018-09-03 15:48:47 +07:00
|
|
|
return vsc85xx_dt_led_modes_get(phydev, default_mode);
|
net: phy: Add Edge-rate driver for Microsemi PHYs.
Edge-rate:
As system and networking speeds increase, a signal's output transition,
also know as the edge rate or slew rate (V/ns), takes on greater importance
because high-speed signals come with a price. That price is an assortment of
interference problems like ringing on the line, signal overshoot and
undershoot, extended signal settling times, crosstalk noise, transmission
line reflections, false signal detection by the receiving device and
electromagnetic interference (EMI) -- all of which can negate the potential
gains designers are seeking when they try to increase system speeds through
the use of higher performance logic devices. The fact is, faster signaling
edge rates can cause a higher level of electrical noise or other type of
interference that can actually lead to slower line speeds and lower maximum
system frequencies. This parameter allow the board designers to change the
driving strange, and thereby change the EMI behavioral.
Edge-rate parameters (vddmac, edge-slowdown) get from Device Tree.
Tested on Beaglebone Black with VSC 8531 PHY.
Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microsemi.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-10-03 14:23:13 +07:00
|
|
|
}
|
|
|
|
|
2016-08-05 19:24:21 +07:00
|
|
|
/* Microsemi VSC85xx PHYs */
|
|
|
|
static struct phy_driver vsc85xx_driver[] = {
|
2020-03-20 04:16:49 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8502,
|
|
|
|
.name = "Microsemi GE VSC8502 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_BASIC_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc85xx_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc85xx_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
2019-11-13 23:33:15 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8504,
|
|
|
|
.name = "Microsemi GE VSC8504 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8574_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8514,
|
|
|
|
.name = "Microsemi GE VSC8514 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8514_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8514_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
2016-10-28 17:10:11 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8530,
|
|
|
|
.name = "Microsemi FE VSC8530",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_BASIC_FEATURES */
|
2016-10-28 17:10:11 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc85xx_config_init,
|
2016-11-29 16:46:48 +07:00
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2016-10-28 17:10:11 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc85xx_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
2016-11-17 19:07:24 +07:00
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
2018-10-08 17:07:23 +07:00
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
2018-10-08 17:07:24 +07:00
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
2016-10-28 17:10:11 +07:00
|
|
|
},
|
2016-08-05 19:24:21 +07:00
|
|
|
{
|
2016-09-08 15:39:31 +07:00
|
|
|
.phy_id = PHY_ID_VSC8531,
|
|
|
|
.name = "Microsemi VSC8531",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_GBIT_FEATURES */
|
2016-09-08 15:39:31 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc85xx_config_init,
|
2016-11-29 16:46:48 +07:00
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2016-09-08 15:39:31 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
2016-10-12 20:47:51 +07:00
|
|
|
.probe = &vsc85xx_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
2016-11-17 19:07:24 +07:00
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
2018-10-08 17:07:23 +07:00
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
2018-10-08 17:07:24 +07:00
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
2016-08-05 19:24:21 +07:00
|
|
|
},
|
2016-10-28 17:10:11 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8540,
|
|
|
|
.name = "Microsemi FE VSC8540 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_BASIC_FEATURES */
|
2016-10-28 17:10:11 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc85xx_config_init,
|
2016-11-29 16:46:48 +07:00
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2016-10-28 17:10:11 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc85xx_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
2016-11-17 19:07:24 +07:00
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
2018-10-08 17:07:23 +07:00
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
2018-10-08 17:07:24 +07:00
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
2016-10-28 17:10:11 +07:00
|
|
|
},
|
2016-08-05 19:24:21 +07:00
|
|
|
{
|
2016-09-08 15:39:31 +07:00
|
|
|
.phy_id = PHY_ID_VSC8541,
|
|
|
|
.name = "Microsemi VSC8541 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_GBIT_FEATURES */
|
2016-09-08 15:39:31 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc85xx_config_init,
|
2016-11-29 16:46:48 +07:00
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2016-09-08 15:39:31 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
2016-10-12 20:47:51 +07:00
|
|
|
.probe = &vsc85xx_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
2016-11-17 19:07:24 +07:00
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
2018-10-08 17:07:23 +07:00
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
2018-10-08 17:07:24 +07:00
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
},
|
2019-11-13 23:33:15 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8552,
|
|
|
|
.name = "Microsemi GE VSC8552 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8574_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC856X,
|
|
|
|
.name = "Microsemi GE VSC856X SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8584_probe,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8572,
|
|
|
|
.name = "Microsemi GE VSC8572 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2020-01-14 05:31:48 +07:00
|
|
|
.handle_interrupt = &vsc8584_handle_interrupt,
|
2019-11-13 23:33:15 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8574_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8574,
|
|
|
|
.name = "Microsemi GE VSC8574 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_GBIT_FEATURES */
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8574_probe,
|
|
|
|
.set_wol = &vsc85xx_wol_set,
|
|
|
|
.get_wol = &vsc85xx_wol_get,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
2019-11-13 23:33:15 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8575,
|
|
|
|
.name = "Microsemi GE VSC8575 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2020-01-14 05:31:48 +07:00
|
|
|
.handle_interrupt = &vsc8584_handle_interrupt,
|
2019-11-13 23:33:15 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8584_probe,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8582,
|
|
|
|
.name = "Microsemi GE VSC8582 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
|
|
|
/* PHY_GBIT_FEATURES */
|
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2020-01-14 05:31:48 +07:00
|
|
|
.handle_interrupt = &vsc8584_handle_interrupt,
|
2019-11-13 23:33:15 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8584_probe,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
|
|
|
},
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
{
|
|
|
|
.phy_id = PHY_ID_VSC8584,
|
|
|
|
.name = "Microsemi GE VSC8584 SyncE",
|
|
|
|
.phy_id_mask = 0xfffffff0,
|
2019-04-13 01:47:03 +07:00
|
|
|
/* PHY_GBIT_FEATURES */
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
.soft_reset = &genphy_soft_reset,
|
|
|
|
.config_init = &vsc8584_config_init,
|
|
|
|
.config_aneg = &vsc85xx_config_aneg,
|
|
|
|
.aneg_done = &genphy_aneg_done,
|
|
|
|
.read_status = &vsc85xx_read_status,
|
2020-01-14 05:31:48 +07:00
|
|
|
.handle_interrupt = &vsc8584_handle_interrupt,
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
.ack_interrupt = &vsc85xx_ack_interrupt,
|
|
|
|
.config_intr = &vsc85xx_config_intr,
|
|
|
|
.did_interrupt = &vsc8584_did_interrupt,
|
|
|
|
.suspend = &genphy_suspend,
|
|
|
|
.resume = &genphy_resume,
|
|
|
|
.probe = &vsc8584_probe,
|
|
|
|
.get_tunable = &vsc85xx_get_tunable,
|
|
|
|
.set_tunable = &vsc85xx_set_tunable,
|
|
|
|
.read_page = &vsc85xx_phy_read_page,
|
|
|
|
.write_page = &vsc85xx_phy_write_page,
|
|
|
|
.get_sset_count = &vsc85xx_get_sset_count,
|
|
|
|
.get_strings = &vsc85xx_get_strings,
|
|
|
|
.get_stats = &vsc85xx_get_stats,
|
2016-08-05 19:24:21 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
module_phy_driver(vsc85xx_driver);
|
|
|
|
|
|
|
|
static struct mdio_device_id __maybe_unused vsc85xx_tbl[] = {
|
2019-11-13 23:33:15 +07:00
|
|
|
{ PHY_ID_VSC8504, 0xfffffff0, },
|
net: phy: mscc: add support for VSC8514 PHY.
The VSC8514 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X, can communicate with the MAC via QSGMII.
The MAC interface protocol for each port within QSGMII can
be either 1000BASE-X or SGMII, if the QSGMII MAC that the VSC8514 is
connecting to supports this functionality.
VSC8514 also supports SGMII MAC-side autonegotiation on each individual
port, downshifting, can set the blinking pattern of each of its 4 LEDs,
SyncE, 1000BASE-T Ring Resiliency as well as HP Auto-MDIX detection.
This adds support for 10BASE-T, 100BASE-TX, and 1000BASE-T,
QSGMII link with the MAC, downshifting, HP Auto-MDIX detection
and blinking pattern for its 4 LEDs.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Kavya Sree Kotagiri <kavyasree.kotagiri@microchip.com>
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Co-developed-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2019-04-22 18:51:35 +07:00
|
|
|
{ PHY_ID_VSC8514, 0xfffffff0, },
|
2016-10-28 17:10:11 +07:00
|
|
|
{ PHY_ID_VSC8530, 0xfffffff0, },
|
2016-09-08 15:39:31 +07:00
|
|
|
{ PHY_ID_VSC8531, 0xfffffff0, },
|
2016-10-28 17:10:11 +07:00
|
|
|
{ PHY_ID_VSC8540, 0xfffffff0, },
|
2016-09-08 15:39:31 +07:00
|
|
|
{ PHY_ID_VSC8541, 0xfffffff0, },
|
2019-11-13 23:33:15 +07:00
|
|
|
{ PHY_ID_VSC8552, 0xfffffff0, },
|
|
|
|
{ PHY_ID_VSC856X, 0xfffffff0, },
|
|
|
|
{ PHY_ID_VSC8572, 0xfffffff0, },
|
net: phy: mscc: add support for VSC8574 PHY
The VSC8574 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with
the MAC via SGMII, QSGMII or 1000BASE-X, supports WOL, downshifting and
can set the blinking pattern of each of its 4 LEDs, supports SyncE as
well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
WOL, downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8574 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:43 +07:00
|
|
|
{ PHY_ID_VSC8574, 0xfffffff0, },
|
2019-11-13 23:33:15 +07:00
|
|
|
{ PHY_ID_VSC8575, 0xfffffff0, },
|
|
|
|
{ PHY_ID_VSC8582, 0xfffffff0, },
|
net: phy: mscc: add support for VSC8584 PHY
The VSC8584 PHY is a 4-ports PHY that is 10/100/1000BASE-T, 100BASE-FX,
1000BASE-X and triple-speed copper SFP capable, can communicate with the
MAC via SGMII, QSGMII or 1000BASE-X, supports downshifting and can set
the blinking pattern of each of its 4 LEDs, supports hardware offloading
of MACsec and supports SyncE as well as HP Auto-MDIX detection.
This adds support for 10/100/1000BASE-T, SGMII/QSGMII link with the MAC,
downshifting, HP Auto-MDIX detection and blinking pattern for its 4
LEDs.
The VSC8584 has also an internal Intel 8051 microcontroller whose
firmware needs to be patched when the PHY is reset. If the 8051's
firmware has the expected CRC, its patching can be skipped. The
microcontroller can be accessed from any port of the PHY, though the CRC
function can only be done through the PHY that is the base PHY of the
package (internal address 0) due to a limitation of the firmware.
The GPIO register bank is a set of registers that are common to all PHYs
in the package. So any modification in any register of this bank affects
all PHYs of the package.
If the PHYs haven't been reset before booting the Linux kernel and were
configured to use interrupts for e.g. link status updates, it is
required to clear the interrupts mask register of all PHYs before being
able to use interrupts with any PHY. The first PHY of the package that
will be init will take care of clearing all PHYs interrupts mask
registers. Thus, we need to keep track of the init sequence in the
package, if it's already been done or if it's to be done.
Most of the init sequence of a PHY of the package is common to all PHYs
in the package, thus we use the SMI broadcast feature which enables us
to propagate a write in one register of one PHY to all PHYs in the same
package.
The revA of the VSC8584 PHY (which is not and will not be publicly
released) should NOT patch the firmware of the microcontroller or it'll
make things worse, the easiest way is just to not support it.
Signed-off-by: Quentin Schulz <quentin.schulz@bootlin.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-10-08 17:14:42 +07:00
|
|
|
{ PHY_ID_VSC8584, 0xfffffff0, },
|
2016-09-08 15:39:31 +07:00
|
|
|
{ }
|
2016-08-05 19:24:21 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
MODULE_DEVICE_TABLE(mdio, vsc85xx_tbl);
|
|
|
|
|
|
|
|
MODULE_DESCRIPTION("Microsemi VSC85xx PHY driver");
|
|
|
|
MODULE_AUTHOR("Nagaraju Lakkaraju");
|
|
|
|
MODULE_LICENSE("Dual MIT/GPL");
|