Skip to content

Commit

Permalink
net: Call netdev_features_change() from netdev_update_features()
Browse files Browse the repository at this point in the history
Issue FEAT_CHANGE notification when features are changed by
netdev_update_features().  This will allow changes made by extra constraints
on e.g. MTU change to be properly propagated like changes via ethtool.

Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Michał Mirosław authored and David S. Miller committed Apr 3, 2011
1 parent e9403c8 commit 6cb6a27
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 9 deletions.
1 change: 1 addition & 0 deletions include/linux/netdevice.h
Original file line number Diff line number Diff line change
Expand Up @@ -2550,6 +2550,7 @@ static inline u32 netdev_get_wanted_features(struct net_device *dev)
}
u32 netdev_increment_features(u32 all, u32 one, u32 mask);
u32 netdev_fix_features(struct net_device *dev, u32 features);
int __netdev_update_features(struct net_device *dev);
void netdev_update_features(struct net_device *dev);

void netif_stacked_transfer_operstate(const struct net_device *rootdev,
Expand Down
23 changes: 17 additions & 6 deletions net/core/dev.c
Original file line number Diff line number Diff line change
Expand Up @@ -5236,7 +5236,7 @@ u32 netdev_fix_features(struct net_device *dev, u32 features)
}
EXPORT_SYMBOL(netdev_fix_features);

void netdev_update_features(struct net_device *dev)
int __netdev_update_features(struct net_device *dev)
{
u32 features;
int err = 0;
Expand All @@ -5250,20 +5250,31 @@ void netdev_update_features(struct net_device *dev)
features = netdev_fix_features(dev, features);

if (dev->features == features)
return;
return 0;

netdev_info(dev, "Features changed: 0x%08x -> 0x%08x\n",
dev->features, features);

if (dev->netdev_ops->ndo_set_features)
err = dev->netdev_ops->ndo_set_features(dev, features);

if (!err)
dev->features = features;
else if (err < 0)
if (unlikely(err < 0)) {
netdev_err(dev,
"set_features() failed (%d); wanted 0x%08x, left 0x%08x\n",
err, features, dev->features);
return -1;
}

if (!err)
dev->features = features;

return 1;
}

void netdev_update_features(struct net_device *dev)
{
if (__netdev_update_features(dev))
netdev_features_change(dev);
}
EXPORT_SYMBOL(netdev_update_features);

Expand Down Expand Up @@ -5430,7 +5441,7 @@ int register_netdevice(struct net_device *dev)
goto err_uninit;
dev->reg_state = NETREG_REGISTERED;

netdev_update_features(dev);
__netdev_update_features(dev);

/*
* Default initial state at registry is that the
Expand Down
6 changes: 3 additions & 3 deletions net/core/ethtool.c
Original file line number Diff line number Diff line change
Expand Up @@ -317,7 +317,7 @@ static int ethtool_set_features(struct net_device *dev, void __user *useraddr)

dev->wanted_features &= ~features[0].valid;
dev->wanted_features |= features[0].valid & features[0].requested;
netdev_update_features(dev);
__netdev_update_features(dev);

if ((dev->wanted_features ^ dev->features) & features[0].valid)
ret |= ETHTOOL_F_WISH;
Expand Down Expand Up @@ -499,7 +499,7 @@ static int ethtool_set_one_feature(struct net_device *dev,
else
dev->wanted_features &= ~mask;

netdev_update_features(dev);
__netdev_update_features(dev);
return 0;
}

Expand Down Expand Up @@ -551,7 +551,7 @@ int __ethtool_set_flags(struct net_device *dev, u32 data)
dev->wanted_features =
(dev->wanted_features & ~changed) | data;

netdev_update_features(dev);
__netdev_update_features(dev);

return 0;
}
Expand Down

0 comments on commit 6cb6a27

Please sign in to comment.