Commit 01dea536 authored by Philippe Reynes's avatar Philippe Reynes Committed by David S. Miller
Browse files

net: ethernet: arc: emac: use phydev from struct net_device



The private structure contain a pointer to phydev, but the structure
net_device already contain such pointer. So we can remove the pointer
phy in the private structure, and update the driver to use the
one contained in struct net_device.

Signed-off-by: default avatarPhilippe Reynes <tremyfr@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent fa018484
Loading
Loading
Loading
Loading
+0 −1
Original line number Original line Diff line number Diff line
@@ -134,7 +134,6 @@ struct arc_emac_priv {


	/* Devices */
	/* Devices */
	struct device *dev;
	struct device *dev;
	struct phy_device *phy_dev;
	struct mii_bus *bus;
	struct mii_bus *bus;
	struct arc_emac_mdio_bus_data bus_data;
	struct arc_emac_mdio_bus_data bus_data;


+12 −17
Original line number Original line Diff line number Diff line
@@ -47,7 +47,7 @@ static inline int arc_emac_tx_avail(struct arc_emac_priv *priv)
static void arc_emac_adjust_link(struct net_device *ndev)
static void arc_emac_adjust_link(struct net_device *ndev)
{
{
	struct arc_emac_priv *priv = netdev_priv(ndev);
	struct arc_emac_priv *priv = netdev_priv(ndev);
	struct phy_device *phy_dev = priv->phy_dev;
	struct phy_device *phy_dev = ndev->phydev;
	unsigned int reg, state_changed = 0;
	unsigned int reg, state_changed = 0;


	if (priv->link != phy_dev->link) {
	if (priv->link != phy_dev->link) {
@@ -92,9 +92,7 @@ static void arc_emac_adjust_link(struct net_device *ndev)
static int arc_emac_get_settings(struct net_device *ndev,
static int arc_emac_get_settings(struct net_device *ndev,
				 struct ethtool_cmd *cmd)
				 struct ethtool_cmd *cmd)
{
{
	struct arc_emac_priv *priv = netdev_priv(ndev);
	return phy_ethtool_gset(ndev->phydev, cmd);

	return phy_ethtool_gset(priv->phy_dev, cmd);
}
}


/**
/**
@@ -111,12 +109,10 @@ static int arc_emac_get_settings(struct net_device *ndev,
static int arc_emac_set_settings(struct net_device *ndev,
static int arc_emac_set_settings(struct net_device *ndev,
				 struct ethtool_cmd *cmd)
				 struct ethtool_cmd *cmd)
{
{
	struct arc_emac_priv *priv = netdev_priv(ndev);

	if (!capable(CAP_NET_ADMIN))
	if (!capable(CAP_NET_ADMIN))
		return -EPERM;
		return -EPERM;


	return phy_ethtool_sset(priv->phy_dev, cmd);
	return phy_ethtool_sset(ndev->phydev, cmd);
}
}


/**
/**
@@ -403,7 +399,7 @@ static void arc_emac_poll_controller(struct net_device *dev)
static int arc_emac_open(struct net_device *ndev)
static int arc_emac_open(struct net_device *ndev)
{
{
	struct arc_emac_priv *priv = netdev_priv(ndev);
	struct arc_emac_priv *priv = netdev_priv(ndev);
	struct phy_device *phy_dev = priv->phy_dev;
	struct phy_device *phy_dev = ndev->phydev;
	int i;
	int i;


	phy_dev->autoneg = AUTONEG_ENABLE;
	phy_dev->autoneg = AUTONEG_ENABLE;
@@ -474,7 +470,7 @@ static int arc_emac_open(struct net_device *ndev)
	/* Enable EMAC */
	/* Enable EMAC */
	arc_reg_or(priv, R_CTRL, EN_MASK);
	arc_reg_or(priv, R_CTRL, EN_MASK);


	phy_start_aneg(priv->phy_dev);
	phy_start_aneg(ndev->phydev);


	netif_start_queue(ndev);
	netif_start_queue(ndev);


@@ -772,6 +768,7 @@ int arc_emac_probe(struct net_device *ndev, int interface)
	struct device *dev = ndev->dev.parent;
	struct device *dev = ndev->dev.parent;
	struct resource res_regs;
	struct resource res_regs;
	struct device_node *phy_node;
	struct device_node *phy_node;
	struct phy_device *phydev = NULL;
	struct arc_emac_priv *priv;
	struct arc_emac_priv *priv;
	const char *mac_addr;
	const char *mac_addr;
	unsigned int id, clock_frequency, irq;
	unsigned int id, clock_frequency, irq;
@@ -887,16 +884,16 @@ int arc_emac_probe(struct net_device *ndev, int interface)
		goto out_clken;
		goto out_clken;
	}
	}


	priv->phy_dev = of_phy_connect(ndev, phy_node, arc_emac_adjust_link, 0,
	phydev = of_phy_connect(ndev, phy_node, arc_emac_adjust_link, 0,
				interface);
				interface);
	if (!priv->phy_dev) {
	if (!phydev) {
		dev_err(dev, "of_phy_connect() failed\n");
		dev_err(dev, "of_phy_connect() failed\n");
		err = -ENODEV;
		err = -ENODEV;
		goto out_mdio;
		goto out_mdio;
	}
	}


	dev_info(dev, "connected to %s phy with id 0x%x\n",
	dev_info(dev, "connected to %s phy with id 0x%x\n",
		 priv->phy_dev->drv->name, priv->phy_dev->phy_id);
		 phydev->drv->name, phydev->phy_id);


	netif_napi_add(ndev, &priv->napi, arc_emac_poll, ARC_EMAC_NAPI_WEIGHT);
	netif_napi_add(ndev, &priv->napi, arc_emac_poll, ARC_EMAC_NAPI_WEIGHT);


@@ -910,8 +907,7 @@ int arc_emac_probe(struct net_device *ndev, int interface)


out_netif_api:
out_netif_api:
	netif_napi_del(&priv->napi);
	netif_napi_del(&priv->napi);
	phy_disconnect(priv->phy_dev);
	phy_disconnect(phydev);
	priv->phy_dev = NULL;
out_mdio:
out_mdio:
	arc_mdio_remove(priv);
	arc_mdio_remove(priv);
out_clken:
out_clken:
@@ -925,8 +921,7 @@ int arc_emac_remove(struct net_device *ndev)
{
{
	struct arc_emac_priv *priv = netdev_priv(ndev);
	struct arc_emac_priv *priv = netdev_priv(ndev);


	phy_disconnect(priv->phy_dev);
	phy_disconnect(ndev->phydev);
	priv->phy_dev = NULL;
	arc_mdio_remove(priv);
	arc_mdio_remove(priv);
	unregister_netdev(ndev);
	unregister_netdev(ndev);
	netif_napi_del(&priv->napi);
	netif_napi_del(&priv->napi);