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: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e574f39816
commit
3fe01e2406
|
@ -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)
|
||||||
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)
|
||||||
{
|
{
|
||||||
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)
|
||||||
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)
|
||||||
{
|
{
|
||||||
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)
|
||||||
|
|
||||||
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)
|
||||||
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)
|
||||||
|
|
||||||
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,
|
||||||
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);
|
||||||
|
|
Loading…
Reference in New Issue