ar71xx: ag71xx: make ring sizes configurable via ethtool
SVN-Revision: 27041
This commit is contained in:
parent
7a2651f633
commit
60d5abbc27
2 changed files with 56 additions and 0 deletions
|
@ -57,6 +57,9 @@
|
||||||
#define AG71XX_TX_RING_SIZE_DEFAULT 64
|
#define AG71XX_TX_RING_SIZE_DEFAULT 64
|
||||||
#define AG71XX_RX_RING_SIZE_DEFAULT 128
|
#define AG71XX_RX_RING_SIZE_DEFAULT 128
|
||||||
|
|
||||||
|
#define AG71XX_TX_RING_SIZE_MAX 256
|
||||||
|
#define AG71XX_RX_RING_SIZE_MAX 256
|
||||||
|
|
||||||
#ifdef CONFIG_AG71XX_DEBUG
|
#ifdef CONFIG_AG71XX_DEBUG
|
||||||
#define DBG(fmt, args...) printk(KERN_DEBUG fmt, ## args)
|
#define DBG(fmt, args...) printk(KERN_DEBUG fmt, ## args)
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -61,11 +61,64 @@ static void ag71xx_ethtool_set_msglevel(struct net_device *dev, u32 msg_level)
|
||||||
ag->msg_enable = msg_level;
|
ag->msg_enable = msg_level;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ag71xx_ethtool_get_ringparam(struct net_device *dev,
|
||||||
|
struct ethtool_ringparam *er)
|
||||||
|
{
|
||||||
|
struct ag71xx *ag = netdev_priv(dev);
|
||||||
|
|
||||||
|
er->tx_max_pending = AG71XX_TX_RING_SIZE_MAX;
|
||||||
|
er->rx_max_pending = AG71XX_RX_RING_SIZE_MAX;
|
||||||
|
er->rx_mini_max_pending = 0;
|
||||||
|
er->rx_jumbo_max_pending = 0;
|
||||||
|
|
||||||
|
er->tx_pending = ag->tx_ring.size;
|
||||||
|
er->rx_pending = ag->rx_ring.size;
|
||||||
|
er->rx_mini_pending = 0;
|
||||||
|
er->rx_jumbo_pending = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int ag71xx_ethtool_set_ringparam(struct net_device *dev,
|
||||||
|
struct ethtool_ringparam *er)
|
||||||
|
{
|
||||||
|
struct ag71xx *ag = netdev_priv(dev);
|
||||||
|
unsigned tx_size;
|
||||||
|
unsigned rx_size;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
if (er->rx_mini_pending != 0||
|
||||||
|
er->rx_jumbo_pending != 0 ||
|
||||||
|
er->rx_pending == 0 ||
|
||||||
|
er->tx_pending == 0)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
tx_size = er->tx_pending < AG71XX_TX_RING_SIZE_MAX ?
|
||||||
|
er->tx_pending : AG71XX_TX_RING_SIZE_MAX;
|
||||||
|
|
||||||
|
rx_size = er->rx_pending < AG71XX_RX_RING_SIZE_MAX ?
|
||||||
|
er->rx_pending : AG71XX_RX_RING_SIZE_MAX;
|
||||||
|
|
||||||
|
if (netif_running(dev)) {
|
||||||
|
err = dev->netdev_ops->ndo_stop(dev);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
ag->tx_ring.size = tx_size;
|
||||||
|
ag->rx_ring.size = rx_size;
|
||||||
|
|
||||||
|
if (netif_running(dev))
|
||||||
|
err = dev->netdev_ops->ndo_open(dev);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
struct ethtool_ops ag71xx_ethtool_ops = {
|
struct ethtool_ops ag71xx_ethtool_ops = {
|
||||||
.set_settings = ag71xx_ethtool_set_settings,
|
.set_settings = ag71xx_ethtool_set_settings,
|
||||||
.get_settings = ag71xx_ethtool_get_settings,
|
.get_settings = ag71xx_ethtool_get_settings,
|
||||||
.get_drvinfo = ag71xx_ethtool_get_drvinfo,
|
.get_drvinfo = ag71xx_ethtool_get_drvinfo,
|
||||||
.get_msglevel = ag71xx_ethtool_get_msglevel,
|
.get_msglevel = ag71xx_ethtool_get_msglevel,
|
||||||
.set_msglevel = ag71xx_ethtool_set_msglevel,
|
.set_msglevel = ag71xx_ethtool_set_msglevel,
|
||||||
|
.get_ringparam = ag71xx_ethtool_get_ringparam,
|
||||||
|
.set_ringparam = ag71xx_ethtool_set_ringparam,
|
||||||
.get_link = ethtool_op_get_link,
|
.get_link = ethtool_op_get_link,
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue