ethtool: device independent rx_csum and get_flags routines
This helps avoid error messages with ethtool -k on devices that don't provide device specific routines. Signed-off-by: Sridhar Samudrala <sri@us.ibm.com> ------------------------------------------------------------------ Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7d073c68a4
commit
1896e61ff7
1 changed files with 11 additions and 2 deletions
|
@ -30,6 +30,11 @@ u32 ethtool_op_get_link(struct net_device *dev)
|
||||||
return netif_carrier_ok(dev) ? 1 : 0;
|
return netif_carrier_ok(dev) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u32 ethtool_op_get_rx_csum(struct net_device *dev)
|
||||||
|
{
|
||||||
|
return (dev->features & NETIF_F_ALL_CSUM) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
u32 ethtool_op_get_tx_csum(struct net_device *dev)
|
u32 ethtool_op_get_tx_csum(struct net_device *dev)
|
||||||
{
|
{
|
||||||
return (dev->features & NETIF_F_ALL_CSUM) != 0;
|
return (dev->features & NETIF_F_ALL_CSUM) != 0;
|
||||||
|
@ -1004,7 +1009,9 @@ int dev_ethtool(struct net *net, struct ifreq *ifr)
|
||||||
break;
|
break;
|
||||||
case ETHTOOL_GRXCSUM:
|
case ETHTOOL_GRXCSUM:
|
||||||
rc = ethtool_get_value(dev, useraddr, ethcmd,
|
rc = ethtool_get_value(dev, useraddr, ethcmd,
|
||||||
dev->ethtool_ops->get_rx_csum);
|
(dev->ethtool_ops->get_rx_csum ?
|
||||||
|
dev->ethtool_ops->get_rx_csum :
|
||||||
|
ethtool_op_get_rx_csum));
|
||||||
break;
|
break;
|
||||||
case ETHTOOL_SRXCSUM:
|
case ETHTOOL_SRXCSUM:
|
||||||
rc = ethtool_set_rx_csum(dev, useraddr);
|
rc = ethtool_set_rx_csum(dev, useraddr);
|
||||||
|
@ -1068,7 +1075,9 @@ int dev_ethtool(struct net *net, struct ifreq *ifr)
|
||||||
break;
|
break;
|
||||||
case ETHTOOL_GFLAGS:
|
case ETHTOOL_GFLAGS:
|
||||||
rc = ethtool_get_value(dev, useraddr, ethcmd,
|
rc = ethtool_get_value(dev, useraddr, ethcmd,
|
||||||
dev->ethtool_ops->get_flags);
|
(dev->ethtool_ops->get_flags ?
|
||||||
|
dev->ethtool_ops->get_flags :
|
||||||
|
ethtool_op_get_flags));
|
||||||
break;
|
break;
|
||||||
case ETHTOOL_SFLAGS:
|
case ETHTOOL_SFLAGS:
|
||||||
rc = ethtool_set_value(dev, useraddr,
|
rc = ethtool_set_value(dev, useraddr,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue