diff options
-rw-r--r-- | net/bluetooth/af_bluetooth.c | 41 |
1 files changed, 23 insertions, 18 deletions
diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c index 8f9431a12c6f..41f07f549ba7 100644 --- a/net/bluetooth/af_bluetooth.c +++ b/net/bluetooth/af_bluetooth.c | |||
@@ -51,8 +51,9 @@ | |||
51 | /* Bluetooth sockets */ | 51 | /* Bluetooth sockets */ |
52 | #define BT_MAX_PROTO 8 | 52 | #define BT_MAX_PROTO 8 |
53 | static struct net_proto_family *bt_proto[BT_MAX_PROTO]; | 53 | static struct net_proto_family *bt_proto[BT_MAX_PROTO]; |
54 | static DEFINE_RWLOCK(bt_proto_lock); | ||
54 | 55 | ||
55 | static struct lock_class_key bt_slock_key[BT_MAX_PROTO]; | 56 | #ifdef CONFIG_DEBUG_LOCK_ALLOC |
56 | static struct lock_class_key bt_lock_key[BT_MAX_PROTO]; | 57 | static struct lock_class_key bt_lock_key[BT_MAX_PROTO]; |
57 | static const char *bt_key_strings[BT_MAX_PROTO] = { | 58 | static const char *bt_key_strings[BT_MAX_PROTO] = { |
58 | "sk_lock-AF_BLUETOOTH-BTPROTO_L2CAP", | 59 | "sk_lock-AF_BLUETOOTH-BTPROTO_L2CAP", |
@@ -65,6 +66,7 @@ static const char *bt_key_strings[BT_MAX_PROTO] = { | |||
65 | "sk_lock-AF_BLUETOOTH-BTPROTO_AVDTP", | 66 | "sk_lock-AF_BLUETOOTH-BTPROTO_AVDTP", |
66 | }; | 67 | }; |
67 | 68 | ||
69 | static struct lock_class_key bt_slock_key[BT_MAX_PROTO]; | ||
68 | static const char *bt_slock_key_strings[BT_MAX_PROTO] = { | 70 | static const char *bt_slock_key_strings[BT_MAX_PROTO] = { |
69 | "slock-AF_BLUETOOTH-BTPROTO_L2CAP", | 71 | "slock-AF_BLUETOOTH-BTPROTO_L2CAP", |
70 | "slock-AF_BLUETOOTH-BTPROTO_HCI", | 72 | "slock-AF_BLUETOOTH-BTPROTO_HCI", |
@@ -75,7 +77,25 @@ static const char *bt_slock_key_strings[BT_MAX_PROTO] = { | |||
75 | "slock-AF_BLUETOOTH-BTPROTO_HIDP", | 77 | "slock-AF_BLUETOOTH-BTPROTO_HIDP", |
76 | "slock-AF_BLUETOOTH-BTPROTO_AVDTP", | 78 | "slock-AF_BLUETOOTH-BTPROTO_AVDTP", |
77 | }; | 79 | }; |
78 | static DEFINE_RWLOCK(bt_proto_lock); | 80 | |
81 | static inline void bt_sock_reclassify_lock(struct socket *sock, int proto) | ||
82 | { | ||
83 | struct sock *sk = sock->sk; | ||
84 | |||
85 | if (!sk) | ||
86 | return; | ||
87 | |||
88 | BUG_ON(sock_owned_by_user(sk)); | ||
89 | |||
90 | sock_lock_init_class_and_name(sk, | ||
91 | bt_slock_key_strings[proto], &bt_slock_key[proto], | ||
92 | bt_key_strings[proto], &bt_lock_key[proto]); | ||
93 | } | ||
94 | #else | ||
95 | static inline void bt_sock_reclassify_lock(struct socket *sock, int proto) | ||
96 | { | ||
97 | } | ||
98 | #endif | ||
79 | 99 | ||
80 | int bt_sock_register(int proto, struct net_proto_family *ops) | 100 | int bt_sock_register(int proto, struct net_proto_family *ops) |
81 | { | 101 | { |
@@ -117,21 +137,6 @@ int bt_sock_unregister(int proto) | |||
117 | } | 137 | } |
118 | EXPORT_SYMBOL(bt_sock_unregister); | 138 | EXPORT_SYMBOL(bt_sock_unregister); |
119 | 139 | ||
120 | static void bt_reclassify_sock_lock(struct socket *sock, int proto) | ||
121 | { | ||
122 | struct sock *sk = sock->sk; | ||
123 | |||
124 | if (!sk) | ||
125 | return; | ||
126 | BUG_ON(sock_owned_by_user(sk)); | ||
127 | |||
128 | sock_lock_init_class_and_name(sk, | ||
129 | bt_slock_key_strings[proto], | ||
130 | &bt_slock_key[proto], | ||
131 | bt_key_strings[proto], | ||
132 | &bt_lock_key[proto]); | ||
133 | } | ||
134 | |||
135 | static int bt_sock_create(struct net *net, struct socket *sock, int proto) | 140 | static int bt_sock_create(struct net *net, struct socket *sock, int proto) |
136 | { | 141 | { |
137 | int err; | 142 | int err; |
@@ -151,7 +156,7 @@ static int bt_sock_create(struct net *net, struct socket *sock, int proto) | |||
151 | 156 | ||
152 | if (bt_proto[proto] && try_module_get(bt_proto[proto]->owner)) { | 157 | if (bt_proto[proto] && try_module_get(bt_proto[proto]->owner)) { |
153 | err = bt_proto[proto]->create(net, sock, proto); | 158 | err = bt_proto[proto]->create(net, sock, proto); |
154 | bt_reclassify_sock_lock(sock, proto); | 159 | bt_sock_reclassify_lock(sock, proto); |
155 | module_put(bt_proto[proto]->owner); | 160 | module_put(bt_proto[proto]->owner); |
156 | } | 161 | } |
157 | 162 | ||