login
Login
/
Register
Search
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2007
»
September
»
12
Re: [patch] sunrpc: make closing of old temporary sockets work (was: problems with lockd in 2.6.22.6)
view
thread
!MAILaRCHIVE_VOTE_RePLACE
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
[view in full thread]
From:
J. Bruce Fields <bfields@...>
To: Wolfgang Walter <wolfgang.walter@...>
Cc: Neil Brown <neilb@...>, <trond.myklebust@...>, <netdev@...>, <nfs@...>, <linux-kernel@...>
Subject:
Re: [patch] sunrpc: make closing of old temporary sockets work (was: problems with lockd in 2.6.22.6)
Date: Wednesday, September 12, 2007 - 3:55 pm
On Wed, Sep 12, 2007 at 09:40:57PM +0200, Wolfgang Walter wrote:
quoted text
> On Wednesday 12 September 2007, J. Bruce Fields wrote: > > On Wed, Sep 12, 2007 at 04:14:06PM +0200, Neil Brown wrote: > > > So it is in 2.6.21 and later and should probably go to .stable for .21 > > > and .22. > > > > > > Bruce: for you :-) > > > > OK, thanks! But, (as is alas often the case) I'm still confused: > > > > > if (!test_and_set_bit(SK_OLD, &svsk->sk_flags)) > > > continue; > > > - if (atomic_read(&svsk->sk_inuse) || test_bit(SK_BUSY, &svsk->sk_flags)) > > > + if (atomic_read(&svsk->sk_inuse) > 1 > > > + || test_bit(SK_BUSY, &svsk->sk_flags)) > > > continue; > > > atomic_inc(&svsk->sk_inuse); > > > list_move(le, &to_be_aged); > > > > What is it that ensures svsk->sk_inuse isn't incremented or SK_BUSY set > > after that test? Not all the code that does either of those is under > > the same serv->sv_lock lock that this code is. > > > > This should not matter - SK_CLOSED may be set at any time. > > svc_age_temp_sockets only detaches the socket, sets SK_CLOSED and then > enqueues it. If SK_BUSY is set its already enqueued and svc_sock_enqueue > ensures that it is not enqueued twice.
Oh, got it. And the list manipulation is safe thanks to sv_lock. Neat, thanks. Can you verify that this solves your problem? --b. -
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
Messages in current thread:
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, Neil Brown
, (Wed Sep 12, 10:14 am)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, J. Bruce Fields
, (Wed Sep 12, 2:42 pm)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, Wolfgang Walter
, (Wed Sep 12, 3:40 pm)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, J. Bruce Fields
, (Wed Sep 12, 3:55 pm)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, Wolfgang Walter
, (Fri Sep 14, 5:12 am)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, J. Bruce Fields
, (Fri Sep 14, 10:29 am)
Re: [patch] sunrpc: make closing of old temporary sockets wo...
, Wolfgang Walter
, (Wed Sep 12, 6:18 pm)
Navigation
Create content
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Peter Zijlstra
[PATCH 00/23] per device dirty throttling -v8
david
Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3
Greg Kroah-Hartman
[PATCH 005/196] Chinese: add translation of SubmittingDrivers
Vladislav Bolkhovitin
Re: Integration of SCST in the mainstream Linux kernel
git
:
openbsd-misc
:
linux-netdev
:
Gerrit Renker
[PATCH 03/37] dccp: List management for new feature negotiation
Frans Pop
svc: failed to register lockdv1 RPC service (errno 97).
David Miller
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
David Miller
[GIT]: Networking
Colocation donated by:
Who's online
There are currently
3 users
and
707 guests
online.
Online users
huntairtuz
beth01manz
roundthejollyro
Syndicate