Re: [PATCH 2/2] Futex non-page-pinning fix

From: Andrew Morton
Date: Tue Aug 26 2003 - 03:24:14 EST


Muli Ben-Yehuda <mulix@xxxxxxxxx> wrote:
>
> > > umm, how about hashing only on offset into page? That reduces the number of
> > > threads which need to be visited in futex_wake() by a factor of up to 1024.
> >
> > How likely do you consider it that we then get a major collision?
> > I wouldn't be surprised if, say, glibc lays some hot futexes out in a
> > way that's the same for all processes in the system, like start of the
> > page.... Might as well not hash :)
>
> How about combining something that's shared to all of the threads that
> share a futex but not system wide (the mm?) with something simple that
> won't change, like the page offset?

The mm's could well be independent.

Some userspace help would be needed to avoid defeating the hash. In the
case where a bunch of threads with a shared mm are waiting on the same
futex things should automatically be OK.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/