[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.2.00.1006091023341.4506@i5.linux-foundation.org>
Date: Wed, 9 Jun 2010 10:25:50 -0700 (PDT)
From: Linus Torvalds <torvalds@...ux-foundation.org>
To: tytso@....edu
cc: Ingo Molnar <mingo@...e.hu>, Salman <sqazi@...gle.com>,
Andrew Morton <akpm@...ux-foundation.org>,
peterz@...radead.org, akpm@...x-foundation.org,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
tytso@...gle.com, Thomas Gleixner <tglx@...utronix.de>
Subject: Re: [PATCH] Fix a race in pid generation that causes pids to be
reused immediately.
On Wed, 9 Jun 2010, Linus Torvalds wrote:
>
> Otherwise you have three threads, two of which pick the same pid (because
> the test-and-set isn't atomic), and a third of which picks a new one.
In fact, I don't think you need three threads at all. It's perfectly ok to
just have two threads, and they'd both end up picking the same 'pid'
without the atomicity guarantees of that 'test_and_set()' bitmap access.
And they'd both be perfectly fine setting last_pid to that (shared) pid if
I read that cmpxchg loop right. No?
Linus
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists