[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <200702022120.52055.ak@suse.de>
Date: Fri, 2 Feb 2007 21:20:51 +0100
From: Andi Kleen <ak@...e.de>
To: Rick Jones <rick.jones2@...com>
Cc: Linux Network Development list <netdev@...r.kernel.org>
Subject: Re: "meaningful" spinlock contention when bound to non-intr CPU?
> Perhaps a poor choice of words on my part - something along the lines of:
>
> hold_lock();
> wake_up_someone();
> release_lock();
>
> where the someone being awoken can try to grab the lock before the path
> doing the waking manages to release it.
Yes the wakeup happens deep inside the critical section and if the process
is running on another CPU it could race to the lock.
Hmm, i suppose the wakeup could be moved out, but it would need some restructuring
of the code. Also to be safe the code would still need to at least hold a
reference count of the sock during the wakeup, and when that is released
then you have another cache line to bounce, which might not be any better
than the lock. So it might not be actually worth it.
I suppose the socket release could be at least partially protected with
RCU against this case so that could be done without a reference count, but
it might be tricky to get this right.
Again still not sure it's worth handling this.
-Andi
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists