diff options
Diffstat (limited to 'include/linux/inetdevice.h')
| -rw-r--r-- | include/linux/inetdevice.h | 21 | 
1 files changed, 11 insertions, 10 deletions
diff --git a/include/linux/inetdevice.h b/include/linux/inetdevice.h index 2be1a1a2beb..ccd5b07d678 100644 --- a/include/linux/inetdevice.h +++ b/include/linux/inetdevice.h @@ -9,6 +9,7 @@  #include <linux/rcupdate.h>  #include <linux/timer.h>  #include <linux/sysctl.h> +#include <linux/rtnetlink.h>  enum  { @@ -158,7 +159,12 @@ struct in_ifaddr {  extern int register_inetaddr_notifier(struct notifier_block *nb);  extern int unregister_inetaddr_notifier(struct notifier_block *nb); -extern struct net_device *ip_dev_find(struct net *net, __be32 addr); +extern struct net_device *__ip_dev_find(struct net *net, __be32 addr, bool devref); +static inline struct net_device *ip_dev_find(struct net *net, __be32 addr) +{ +	return __ip_dev_find(net, addr, true); +} +  extern int		inet_addr_onlink(struct in_device *in_dev, __be32 a, __be32 b);  extern int		devinet_ioctl(struct net *net, unsigned int cmd, void __user *);  extern void		devinet_init(void); @@ -198,14 +204,10 @@ static __inline__ int bad_mask(__be32 mask, __be32 addr)  static inline struct in_device *__in_dev_get_rcu(const struct net_device *dev)  { -	struct in_device *in_dev = dev->ip_ptr; -	if (in_dev) -		in_dev = rcu_dereference(in_dev); -	return in_dev; +	return rcu_dereference(dev->ip_ptr);  } -static __inline__ struct in_device * -in_dev_get(const struct net_device *dev) +static inline struct in_device *in_dev_get(const struct net_device *dev)  {  	struct in_device *in_dev; @@ -217,10 +219,9 @@ in_dev_get(const struct net_device *dev)  	return in_dev;  } -static __inline__ struct in_device * -__in_dev_get_rtnl(const struct net_device *dev) +static inline struct in_device *__in_dev_get_rtnl(const struct net_device *dev)  { -	return (struct in_device*)dev->ip_ptr; +	return rcu_dereference_check(dev->ip_ptr, lockdep_rtnl_is_held());  }  extern void in_dev_finish_destroy(struct in_device *idev);  |