Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 41596
b: refs/heads/master
c: fcc70d5
h: refs/heads/master
v: v3
  • Loading branch information
Peter Zijlstra authored and David S. Miller committed Dec 3, 2006
1 parent fc35171 commit 1541c4b
Show file tree
Hide file tree
Showing 4 changed files with 13 additions and 7 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 67f83cbf081a70426ff667e8d14f94e13ed3bdca
refs/heads/master: fcc70d5fdc9b0bd3e99c9dacb8198224af2b4b42
8 changes: 7 additions & 1 deletion trunk/include/net/sock.h
Original file line number Diff line number Diff line change
Expand Up @@ -745,7 +745,13 @@ static inline int sk_stream_wmem_schedule(struct sock *sk, int size)
*/
#define sock_owned_by_user(sk) ((sk)->sk_lock.owner)

extern void FASTCALL(lock_sock(struct sock *sk));
extern void FASTCALL(lock_sock_nested(struct sock *sk, int subclass));

static inline void lock_sock(struct sock *sk)
{
lock_sock_nested(sk, 0);
}

extern void FASTCALL(release_sock(struct sock *sk));

/* BH context may only use the following locking interface. */
Expand Down
4 changes: 2 additions & 2 deletions trunk/net/bluetooth/l2cap.c
Original file line number Diff line number Diff line change
Expand Up @@ -770,7 +770,7 @@ static int l2cap_sock_accept(struct socket *sock, struct socket *newsock, int fl
long timeo;
int err = 0;

lock_sock(sk);
lock_sock_nested(sk, SINGLE_DEPTH_NESTING);

if (sk->sk_state != BT_LISTEN) {
err = -EBADFD;
Expand All @@ -792,7 +792,7 @@ static int l2cap_sock_accept(struct socket *sock, struct socket *newsock, int fl

release_sock(sk);
timeo = schedule_timeout(timeo);
lock_sock(sk);
lock_sock_nested(sk, SINGLE_DEPTH_NESTING);

if (sk->sk_state != BT_LISTEN) {
err = -EBADFD;
Expand Down
6 changes: 3 additions & 3 deletions trunk/net/core/sock.c
Original file line number Diff line number Diff line change
Expand Up @@ -1527,7 +1527,7 @@ void sock_init_data(struct socket *sock, struct sock *sk)
atomic_set(&sk->sk_refcnt, 1);
}

void fastcall lock_sock(struct sock *sk)
void fastcall lock_sock_nested(struct sock *sk, int subclass)
{
might_sleep();
spin_lock_bh(&sk->sk_lock.slock);
Expand All @@ -1538,11 +1538,11 @@ void fastcall lock_sock(struct sock *sk)
/*
* The sk_lock has mutex_lock() semantics here:
*/
mutex_acquire(&sk->sk_lock.dep_map, 0, 0, _RET_IP_);
mutex_acquire(&sk->sk_lock.dep_map, subclass, 0, _RET_IP_);
local_bh_enable();
}

EXPORT_SYMBOL(lock_sock);
EXPORT_SYMBOL(lock_sock_nested);

void fastcall release_sock(struct sock *sk)
{
Expand Down

0 comments on commit 1541c4b

Please sign in to comment.