Commit 3fe01e24 authored by Andrew Lunn's avatar Andrew Lunn Committed by David S. Miller

staging: netlogic: Fix build error due to missed API change

Fix a number of build errors due to moving the phy_map and centralizing
interrupt allocation.
Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent e574f398
...@@ -165,13 +165,18 @@ static void xlr_net_fmn_handler(int bkt, int src_stnid, int size, ...@@ -165,13 +165,18 @@ static void xlr_net_fmn_handler(int bkt, int src_stnid, int size,
} }
} }
static struct phy_device *xlr_get_phydev(struct xlr_net_priv *priv)
{
return mdiobus_get_phy(priv->mii_bus, priv->phy_addr);
}
/* /*
* Ethtool operation * Ethtool operation
*/ */
static int xlr_get_settings(struct net_device *ndev, struct ethtool_cmd *ecmd) static int xlr_get_settings(struct net_device *ndev, struct ethtool_cmd *ecmd)
{ {
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
if (!phydev) if (!phydev)
return -ENODEV; return -ENODEV;
...@@ -181,7 +186,7 @@ static int xlr_get_settings(struct net_device *ndev, struct ethtool_cmd *ecmd) ...@@ -181,7 +186,7 @@ static int xlr_get_settings(struct net_device *ndev, struct ethtool_cmd *ecmd)
static int xlr_set_settings(struct net_device *ndev, struct ethtool_cmd *ecmd) static int xlr_set_settings(struct net_device *ndev, struct ethtool_cmd *ecmd)
{ {
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
if (!phydev) if (!phydev)
return -ENODEV; return -ENODEV;
...@@ -218,7 +223,7 @@ static int xlr_net_open(struct net_device *ndev) ...@@ -218,7 +223,7 @@ static int xlr_net_open(struct net_device *ndev)
{ {
u32 err; u32 err;
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
/* schedule a link state check */ /* schedule a link state check */
phy_start(phydev); phy_start(phydev);
...@@ -239,7 +244,7 @@ static int xlr_net_open(struct net_device *ndev) ...@@ -239,7 +244,7 @@ static int xlr_net_open(struct net_device *ndev)
static int xlr_net_stop(struct net_device *ndev) static int xlr_net_stop(struct net_device *ndev)
{ {
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
phy_stop(phydev); phy_stop(phydev);
netif_tx_stop_all_queues(ndev); netif_tx_stop_all_queues(ndev);
...@@ -268,7 +273,7 @@ static void __maybe_unused xlr_wakeup_queue(unsigned long dev) ...@@ -268,7 +273,7 @@ static void __maybe_unused xlr_wakeup_queue(unsigned long dev)
{ {
struct net_device *ndev = (struct net_device *) dev; struct net_device *ndev = (struct net_device *) dev;
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
if (phydev->link) if (phydev->link)
netif_tx_wake_queue(netdev_get_tx_queue(ndev, priv->wakeup_q)); netif_tx_wake_queue(netdev_get_tx_queue(ndev, priv->wakeup_q));
...@@ -771,7 +776,7 @@ static void xlr_sgmii_init(struct xlr_net_priv *priv) ...@@ -771,7 +776,7 @@ static void xlr_sgmii_init(struct xlr_net_priv *priv)
void xlr_set_gmac_speed(struct xlr_net_priv *priv) void xlr_set_gmac_speed(struct xlr_net_priv *priv)
{ {
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
int speed; int speed;
if (phydev->interface == PHY_INTERFACE_MODE_SGMII) if (phydev->interface == PHY_INTERFACE_MODE_SGMII)
...@@ -813,7 +818,7 @@ void xlr_set_gmac_speed(struct xlr_net_priv *priv) ...@@ -813,7 +818,7 @@ void xlr_set_gmac_speed(struct xlr_net_priv *priv)
static void xlr_gmac_link_adjust(struct net_device *ndev) static void xlr_gmac_link_adjust(struct net_device *ndev)
{ {
struct xlr_net_priv *priv = netdev_priv(ndev); struct xlr_net_priv *priv = netdev_priv(ndev);
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
u32 intreg; u32 intreg;
intreg = xlr_nae_rdreg(priv->base_addr, R_INTREG); intreg = xlr_nae_rdreg(priv->base_addr, R_INTREG);
...@@ -830,7 +835,7 @@ static void xlr_gmac_link_adjust(struct net_device *ndev) ...@@ -830,7 +835,7 @@ static void xlr_gmac_link_adjust(struct net_device *ndev)
static int xlr_mii_probe(struct xlr_net_priv *priv) static int xlr_mii_probe(struct xlr_net_priv *priv)
{ {
struct phy_device *phydev = priv->mii_bus->phy_map[priv->phy_addr]; struct phy_device *phydev = xlr_get_phydev(priv);
if (!phydev) { if (!phydev) {
pr_err("no PHY found on phy_addr %d\n", priv->phy_addr); pr_err("no PHY found on phy_addr %d\n", priv->phy_addr);
...@@ -876,14 +881,6 @@ static int xlr_setup_mdio(struct xlr_net_priv *priv, ...@@ -876,14 +881,6 @@ static int xlr_setup_mdio(struct xlr_net_priv *priv,
priv->mii_bus->read = xlr_mii_read; priv->mii_bus->read = xlr_mii_read;
priv->mii_bus->write = xlr_mii_write; priv->mii_bus->write = xlr_mii_write;
priv->mii_bus->parent = &pdev->dev; priv->mii_bus->parent = &pdev->dev;
priv->mii_bus->irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL);
if (priv->mii_bus->irq == NULL) {
pr_err("irq alloc failed\n");
mdiobus_free(priv->mii_bus);
return -ENOMEM;
}
priv->mii_bus->irq[priv->phy_addr] = priv->ndev->irq;
/* Scan only the enabled address */ /* Scan only the enabled address */
priv->mii_bus->phy_mask = ~(1 << priv->phy_addr); priv->mii_bus->phy_mask = ~(1 << priv->phy_addr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment