aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorStephen Hemminger <shemminger@osdl.org>2006-03-21 01:23:58 -0500
committerDavid S. Miller <davem@davemloft.net>2006-03-21 01:23:58 -0500
commit6756ae4b4e97aba48c042b4aa6b77a18f507d2cb (patch)
tree05bf37711d782fb0089d474716026c44a454f89b /include/linux
parent253aa11578c1b89757282430891bb66ae5300092 (diff)
[NET]: Convert RTNL to mutex.
This patch turns the RTNL from a semaphore to a new 2.6.16 mutex and gets rid of some of the leftover legacy. Signed-off-by: Stephen Hemminger <shemminger@osdl.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/rtnetlink.h20
1 files changed, 7 insertions, 13 deletions
diff --git a/include/linux/rtnetlink.h b/include/linux/rtnetlink.h
index edccefb45188..d263853a8f1c 100644
--- a/include/linux/rtnetlink.h
+++ b/include/linux/rtnetlink.h
@@ -907,6 +907,7 @@ struct tcamsg
907#ifdef __KERNEL__ 907#ifdef __KERNEL__
908 908
909#include <linux/config.h> 909#include <linux/config.h>
910#include <linux/mutex.h>
910 911
911extern size_t rtattr_strlcpy(char *dest, const struct rtattr *rta, size_t size); 912extern size_t rtattr_strlcpy(char *dest, const struct rtattr *rta, size_t size);
912static __inline__ int rtattr_strcmp(const struct rtattr *rta, const char *str) 913static __inline__ int rtattr_strcmp(const struct rtattr *rta, const char *str)
@@ -1038,24 +1039,17 @@ __rta_reserve(struct sk_buff *skb, int attrtype, int attrlen)
1038 1039
1039extern void rtmsg_ifinfo(int type, struct net_device *dev, unsigned change); 1040extern void rtmsg_ifinfo(int type, struct net_device *dev, unsigned change);
1040 1041
1041extern struct semaphore rtnl_sem; 1042/* RTNL is used as a global lock for all changes to network configuration */
1042
1043#define rtnl_shlock() down(&rtnl_sem)
1044#define rtnl_shlock_nowait() down_trylock(&rtnl_sem)
1045
1046#define rtnl_shunlock() do { up(&rtnl_sem); \
1047 if (rtnl && rtnl->sk_receive_queue.qlen) \
1048 rtnl->sk_data_ready(rtnl, 0); \
1049 } while(0)
1050
1051extern void rtnl_lock(void); 1043extern void rtnl_lock(void);
1052extern int rtnl_lock_interruptible(void);
1053extern void rtnl_unlock(void); 1044extern void rtnl_unlock(void);
1045extern int rtnl_trylock(void);
1046
1054extern void rtnetlink_init(void); 1047extern void rtnetlink_init(void);
1048extern void __rtnl_unlock(void);
1055 1049
1056#define ASSERT_RTNL() do { \ 1050#define ASSERT_RTNL() do { \
1057 if (unlikely(down_trylock(&rtnl_sem) == 0)) { \ 1051 if (unlikely(rtnl_trylock())) { \
1058 up(&rtnl_sem); \ 1052 rtnl_unlock(); \
1059 printk(KERN_ERR "RTNL: assertion failed at %s (%d)\n", \ 1053 printk(KERN_ERR "RTNL: assertion failed at %s (%d)\n", \
1060 __FILE__, __LINE__); \ 1054 __FILE__, __LINE__); \
1061 dump_stack(); \ 1055 dump_stack(); \