mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 19:12:33 +08:00
da98603597
This PR is a blend of several kernel bumps authored by ldir taken from his staging tree w/ some further adjustments made by me and update_kernel.sh Summary: Deleted upstreamed patches: generic: 742-v5.5-net-sfp-add-support-for-module-quirks.patch 743-v5.5-net-sfp-add-some-quirks-for-GPON-modules.patch bcm63xx: 022-v5.8-mtd-rawnand-brcmnand-correctly-verify-erased-pages.patch 024-v5.8-mtd-rawnand-brcmnand-fix-CS0-layout.patch mediatek: 0402-net-ethernet-mtk_eth_soc-Always-call-mtk_gmac0_rgmii.patch Deleted patches applied differently upstream: generic: 641-sch_cake-fix-IP-protocol-handling-in-the-presence-of.patch Manually merged patches: generic: 395-v5.8-net-sch_cake-Take-advantage-of-skb-hash-where-appropriate.patch bcm27xx: 950-0132-lan78xx-Debounce-link-events-to-minimize-poll-storm.patch layerscape: 701-net-0231-enetc-Use-DT-protocol-information-to-set-up-the-port.patch Build system: x86_64 Build-tested: ath79/generic, bcm27xx/bcm2708, bcm27xx/bcm2711, imx6, mvebu/cortexa9, sunxi/a53 Run-tested: Netgear R7800 (ipq806x) No dmesg regressions, everything functional Signed-off-by: John Audia <graysky@archlinux.us> Tested-By: Lucian Cristian <Lucian.cristian@gmail.com> [mvebu] Tested-By: Curtis Deptuck <curtdept@me.com> [x86/64] [do not remove 395-v5.8-net-sch_cake-Take-advantage-... patch, adjust and refresh patches, adjust commit message] Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de> Tested-By: John Audia <graysky@archlinux.us> [ipq806x]
196 lines
5.8 KiB
Diff
196 lines
5.8 KiB
Diff
From 98f64a89977a32df96cdb8aaf3884086b2309924 Mon Sep 17 00:00:00 2001
|
|
From: Alex Marginean <alexandru.marginean@nxp.com>
|
|
Date: Tue, 27 Aug 2019 15:14:11 +0300
|
|
Subject: [PATCH] enetc: Use DT protocol information to set up the ports
|
|
|
|
Use DT information rather than in-band information from bootloader to
|
|
set up MAC for XGMII. For RGMII use the DT indication in addition to
|
|
RGMII defaults in hardware.
|
|
However, this implies that PHY connection information needs to be
|
|
extracted before netdevice creation, when the ENETC Port MAC is
|
|
being configured.
|
|
|
|
Signed-off-by: Alex Marginean <alexandru.marginean@nxp.com>
|
|
Signed-off-by: Claudiu Manoil <claudiu.manoil@nxp.com>
|
|
---
|
|
drivers/net/ethernet/freescale/enetc/enetc_pf.c | 55 ++++++++++++++-----------
|
|
drivers/net/ethernet/freescale/enetc/enetc_pf.h | 3 ++
|
|
2 files changed, 33 insertions(+), 25 deletions(-)
|
|
|
|
--- a/drivers/net/ethernet/freescale/enetc/enetc_pf.c
|
|
+++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.c
|
|
@@ -507,7 +507,8 @@ static void enetc_port_si_configure(stru
|
|
enetc_port_wr(hw, ENETC_PSIVLANFMR, ENETC_PSIVLANFMR_VS);
|
|
}
|
|
|
|
-static void enetc_configure_port_mac(struct enetc_hw *hw)
|
|
+static void enetc_configure_port_mac(struct enetc_hw *hw,
|
|
+ phy_interface_t phy_mode)
|
|
{
|
|
enetc_port_wr(hw, ENETC_PM0_MAXFRM,
|
|
ENETC_SET_MAXFRM(ENETC_RX_MAXFRM_SIZE));
|
|
@@ -523,9 +524,11 @@ static void enetc_configure_port_mac(str
|
|
ENETC_PM0_CMD_TXP | ENETC_PM0_PROMISC |
|
|
ENETC_PM0_TX_EN | ENETC_PM0_RX_EN);
|
|
/* set auto-speed for RGMII */
|
|
- if (enetc_port_rd(hw, ENETC_PM0_IF_MODE) & ENETC_PMO_IFM_RG)
|
|
+ if (enetc_port_rd(hw, ENETC_PM0_IF_MODE) & ENETC_PMO_IFM_RG ||
|
|
+ phy_mode == PHY_INTERFACE_MODE_RGMII)
|
|
enetc_port_wr(hw, ENETC_PM0_IF_MODE, ENETC_PM0_IFM_RGAUTO);
|
|
- if (enetc_global_rd(hw, ENETC_G_EPFBLPR(1)) == ENETC_G_EPFBLPR1_XGMII)
|
|
+
|
|
+ if (phy_mode == PHY_INTERFACE_MODE_XGMII)
|
|
enetc_port_wr(hw, ENETC_PM0_IF_MODE, ENETC_PM0_IFM_XGMII);
|
|
}
|
|
|
|
@@ -549,7 +552,7 @@ static void enetc_configure_port(struct
|
|
|
|
enetc_configure_port_pmac(hw);
|
|
|
|
- enetc_configure_port_mac(hw);
|
|
+ enetc_configure_port_mac(hw, pf->if_mode);
|
|
|
|
enetc_port_si_configure(pf->si);
|
|
|
|
@@ -749,28 +752,28 @@ static void enetc_pf_netdev_setup(struct
|
|
enetc_get_primary_mac_addr(&si->hw, ndev->dev_addr);
|
|
}
|
|
|
|
-static int enetc_of_get_phy(struct enetc_ndev_priv *priv)
|
|
+static int enetc_of_get_phy(struct enetc_pf *pf)
|
|
{
|
|
- struct enetc_pf *pf = enetc_si_priv(priv->si);
|
|
- struct device_node *np = priv->dev->of_node;
|
|
+ struct device *dev = &pf->si->pdev->dev;
|
|
+ struct device_node *np = dev->of_node;
|
|
struct device_node *mdio_np;
|
|
int phy_mode;
|
|
int err;
|
|
|
|
- priv->phy_node = of_parse_phandle(np, "phy-handle", 0);
|
|
- if (!priv->phy_node) {
|
|
+ pf->phy_node = of_parse_phandle(np, "phy-handle", 0);
|
|
+ if (!pf->phy_node) {
|
|
if (!of_phy_is_fixed_link(np)) {
|
|
- dev_err(priv->dev, "PHY not specified\n");
|
|
+ dev_err(dev, "PHY not specified\n");
|
|
return -ENODEV;
|
|
}
|
|
|
|
err = of_phy_register_fixed_link(np);
|
|
if (err < 0) {
|
|
- dev_err(priv->dev, "fixed link registration failed\n");
|
|
+ dev_err(dev, "fixed link registration failed\n");
|
|
return err;
|
|
}
|
|
|
|
- priv->phy_node = of_node_get(np);
|
|
+ pf->phy_node = of_node_get(np);
|
|
}
|
|
|
|
mdio_np = of_get_child_by_name(np, "mdio");
|
|
@@ -778,28 +781,28 @@ static int enetc_of_get_phy(struct enetc
|
|
of_node_put(mdio_np);
|
|
err = enetc_mdio_probe(pf);
|
|
if (err) {
|
|
- of_node_put(priv->phy_node);
|
|
+ of_node_put(pf->phy_node);
|
|
return err;
|
|
}
|
|
}
|
|
|
|
phy_mode = of_get_phy_mode(np);
|
|
if (phy_mode < 0)
|
|
- priv->if_mode = PHY_INTERFACE_MODE_NA; /* fixed link */
|
|
+ pf->if_mode = PHY_INTERFACE_MODE_NA; /* fixed link */
|
|
else
|
|
- priv->if_mode = phy_mode;
|
|
+ pf->if_mode = phy_mode;
|
|
|
|
return 0;
|
|
}
|
|
|
|
-static void enetc_of_put_phy(struct enetc_ndev_priv *priv)
|
|
+static void enetc_of_put_phy(struct enetc_pf *pf)
|
|
{
|
|
- struct device_node *np = priv->dev->of_node;
|
|
+ struct device_node *np = pf->si->pdev->dev.of_node;
|
|
|
|
if (np && of_phy_is_fixed_link(np))
|
|
of_phy_deregister_fixed_link(np);
|
|
- if (priv->phy_node)
|
|
- of_node_put(priv->phy_node);
|
|
+ if (pf->phy_node)
|
|
+ of_node_put(pf->phy_node);
|
|
}
|
|
|
|
static void enetc_configure_sgmii(struct mii_bus *imdio)
|
|
@@ -888,6 +891,10 @@ static int enetc_pf_probe(struct pci_dev
|
|
pf->si = si;
|
|
pf->total_vfs = pci_sriov_get_totalvfs(pdev);
|
|
|
|
+ err = enetc_of_get_phy(pf);
|
|
+ if (err)
|
|
+ dev_warn(&pdev->dev, "Fallback to PHY-less operation\n");
|
|
+
|
|
enetc_configure_port(pf);
|
|
|
|
enetc_get_si_caps(si);
|
|
@@ -902,6 +909,8 @@ static int enetc_pf_probe(struct pci_dev
|
|
enetc_pf_netdev_setup(si, ndev, &enetc_ndev_ops);
|
|
|
|
priv = netdev_priv(ndev);
|
|
+ priv->phy_node = pf->phy_node;
|
|
+ priv->if_mode = pf->if_mode;
|
|
|
|
enetc_init_si_rings_params(priv);
|
|
|
|
@@ -917,10 +926,6 @@ static int enetc_pf_probe(struct pci_dev
|
|
goto err_alloc_msix;
|
|
}
|
|
|
|
- err = enetc_of_get_phy(priv);
|
|
- if (err)
|
|
- dev_warn(&pdev->dev, "Fallback to PHY-less operation\n");
|
|
-
|
|
err = enetc_configure_serdes(priv);
|
|
if (err)
|
|
dev_warn(&pdev->dev, "Attempted serdes config but failed\n");
|
|
@@ -938,7 +943,6 @@ static int enetc_pf_probe(struct pci_dev
|
|
|
|
err_reg_netdev:
|
|
enetc_mdio_remove(pf);
|
|
- enetc_of_put_phy(priv);
|
|
enetc_free_msix(priv);
|
|
err_alloc_msix:
|
|
enetc_free_si_resources(priv);
|
|
@@ -946,6 +950,7 @@ err_alloc_si_res:
|
|
si->ndev = NULL;
|
|
free_netdev(ndev);
|
|
err_alloc_netdev:
|
|
+ enetc_of_put_phy(pf);
|
|
err_map_pf_space:
|
|
enetc_pci_remove(pdev);
|
|
|
|
@@ -968,7 +973,7 @@ static void enetc_pf_remove(struct pci_d
|
|
unregister_netdev(si->ndev);
|
|
|
|
enetc_mdio_remove(pf);
|
|
- enetc_of_put_phy(priv);
|
|
+ enetc_of_put_phy(pf);
|
|
|
|
enetc_free_msix(priv);
|
|
|
|
--- a/drivers/net/ethernet/freescale/enetc/enetc_pf.h
|
|
+++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.h
|
|
@@ -45,6 +45,9 @@ struct enetc_pf {
|
|
|
|
struct mii_bus *mdio; /* saved for cleanup */
|
|
struct mii_bus *imdio;
|
|
+
|
|
+ struct device_node *phy_node;
|
|
+ phy_interface_t if_mode;
|
|
};
|
|
|
|
int enetc_msg_psi_init(struct enetc_pf *pf);
|