fec: switch to net_device_ops
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
3644ee00c4
commit
009fda83ee
@@ -210,17 +210,13 @@ struct fec_enet_private {
|
|||||||
int full_duplex;
|
int full_duplex;
|
||||||
};
|
};
|
||||||
|
|
||||||
static int fec_enet_open(struct net_device *dev);
|
|
||||||
static int fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev);
|
|
||||||
static void fec_enet_mii(struct net_device *dev);
|
static void fec_enet_mii(struct net_device *dev);
|
||||||
static irqreturn_t fec_enet_interrupt(int irq, void * dev_id);
|
static irqreturn_t fec_enet_interrupt(int irq, void * dev_id);
|
||||||
static void fec_enet_tx(struct net_device *dev);
|
static void fec_enet_tx(struct net_device *dev);
|
||||||
static void fec_enet_rx(struct net_device *dev);
|
static void fec_enet_rx(struct net_device *dev);
|
||||||
static int fec_enet_close(struct net_device *dev);
|
static int fec_enet_close(struct net_device *dev);
|
||||||
static void set_multicast_list(struct net_device *dev);
|
|
||||||
static void fec_restart(struct net_device *dev, int duplex);
|
static void fec_restart(struct net_device *dev, int duplex);
|
||||||
static void fec_stop(struct net_device *dev);
|
static void fec_stop(struct net_device *dev);
|
||||||
static void fec_set_mac_address(struct net_device *dev);
|
|
||||||
|
|
||||||
|
|
||||||
/* MII processing. We keep this as simple as possible. Requests are
|
/* MII processing. We keep this as simple as possible. Requests are
|
||||||
@@ -1410,7 +1406,6 @@ fec_enet_open(struct net_device *dev)
|
|||||||
/* I should reset the ring buffers here, but I don't yet know
|
/* I should reset the ring buffers here, but I don't yet know
|
||||||
* a simple way to do that.
|
* a simple way to do that.
|
||||||
*/
|
*/
|
||||||
fec_set_mac_address(dev);
|
|
||||||
|
|
||||||
fep->sequence_done = 0;
|
fep->sequence_done = 0;
|
||||||
fep->link = 0;
|
fep->link = 0;
|
||||||
@@ -1543,19 +1538,35 @@ static void set_multicast_list(struct net_device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Set a MAC change in hardware. */
|
/* Set a MAC change in hardware. */
|
||||||
static void
|
static int
|
||||||
fec_set_mac_address(struct net_device *dev)
|
fec_set_mac_address(struct net_device *dev, void *p)
|
||||||
{
|
{
|
||||||
struct fec_enet_private *fep = netdev_priv(dev);
|
struct fec_enet_private *fep = netdev_priv(dev);
|
||||||
|
struct sockaddr *addr = p;
|
||||||
|
|
||||||
|
if (!is_valid_ether_addr(addr->sa_data))
|
||||||
|
return -EADDRNOTAVAIL;
|
||||||
|
|
||||||
|
memcpy(dev->dev_addr, addr->sa_data, dev->addr_len);
|
||||||
|
|
||||||
/* Set station address. */
|
|
||||||
writel(dev->dev_addr[3] | (dev->dev_addr[2] << 8) |
|
writel(dev->dev_addr[3] | (dev->dev_addr[2] << 8) |
|
||||||
(dev->dev_addr[1] << 16) | (dev->dev_addr[0] << 24),
|
(dev->dev_addr[1] << 16) | (dev->dev_addr[0] << 24),
|
||||||
fep->hwp + FEC_ADDR_LOW);
|
fep->hwp + FEC_ADDR_LOW);
|
||||||
writel((dev->dev_addr[5] << 16) | (dev->dev_addr[4] << 24),
|
writel((dev->dev_addr[5] << 16) | (dev->dev_addr[4] << 24),
|
||||||
fep + FEC_ADDR_HIGH);
|
fep + FEC_ADDR_HIGH);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct net_device_ops fec_netdev_ops = {
|
||||||
|
.ndo_open = fec_enet_open,
|
||||||
|
.ndo_stop = fec_enet_close,
|
||||||
|
.ndo_start_xmit = fec_enet_start_xmit,
|
||||||
|
.ndo_set_multicast_list = set_multicast_list,
|
||||||
|
.ndo_validate_addr = eth_validate_addr,
|
||||||
|
.ndo_tx_timeout = fec_timeout,
|
||||||
|
.ndo_set_mac_address = fec_set_mac_address,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XXX: We need to clean up on failure exits here.
|
* XXX: We need to clean up on failure exits here.
|
||||||
*
|
*
|
||||||
@@ -1651,12 +1662,8 @@ int __init fec_enet_init(struct net_device *dev, int index)
|
|||||||
fec_request_mii_intr(dev);
|
fec_request_mii_intr(dev);
|
||||||
#endif
|
#endif
|
||||||
/* The FEC Ethernet specific entries in the device structure */
|
/* The FEC Ethernet specific entries in the device structure */
|
||||||
dev->open = fec_enet_open;
|
|
||||||
dev->hard_start_xmit = fec_enet_start_xmit;
|
|
||||||
dev->tx_timeout = fec_timeout;
|
|
||||||
dev->watchdog_timeo = TX_TIMEOUT;
|
dev->watchdog_timeo = TX_TIMEOUT;
|
||||||
dev->stop = fec_enet_close;
|
dev->netdev_ops = &fec_netdev_ops;
|
||||||
dev->set_multicast_list = set_multicast_list;
|
|
||||||
|
|
||||||
for (i=0; i<NMII-1; i++)
|
for (i=0; i<NMII-1; i++)
|
||||||
mii_cmds[i].mii_next = &mii_cmds[i+1];
|
mii_cmds[i].mii_next = &mii_cmds[i+1];
|
||||||
@@ -1695,9 +1702,6 @@ fec_restart(struct net_device *dev, int duplex)
|
|||||||
/* Clear any outstanding interrupt. */
|
/* Clear any outstanding interrupt. */
|
||||||
writel(0xffc00000, fep->hwp + FEC_IEVENT);
|
writel(0xffc00000, fep->hwp + FEC_IEVENT);
|
||||||
|
|
||||||
/* Set station address. */
|
|
||||||
fec_set_mac_address(dev);
|
|
||||||
|
|
||||||
/* Reset all multicast. */
|
/* Reset all multicast. */
|
||||||
writel(0, fep->hwp + FEC_GRP_HASH_TABLE_HIGH);
|
writel(0, fep->hwp + FEC_GRP_HASH_TABLE_HIGH);
|
||||||
writel(0, fep->hwp + FEC_GRP_HASH_TABLE_LOW);
|
writel(0, fep->hwp + FEC_GRP_HASH_TABLE_LOW);
|
||||||
|
Reference in New Issue
Block a user