This is the mail archive of the
libc-alpha@sourceware.org
mailing list for the glibc project.
Re: [discuss] Re: FOR REVIEW: New x86-64 vsyscall vgetcpu()
- From: Andi Kleen <ak at suse dot de>
- To: discuss at x86-64 dot org
- Cc: Chase Venters <chase dot venters at clientec dot com>, Brent Casavant <bcasavan at sgi dot com>, Zoltan Menyhart <Zoltan dot Menyhart at bull dot net>, Jes Sorensen <jes at sgi dot com>, Tony Luck <tony dot luck at intel dot com>, linux-kernel at vger dot kernel dot org, libc-alpha at sourceware dot org, vojtech at suse dot cz, linux-ia64 at vger dot kernel dot org
- Date: Sat, 17 Jun 2006 08:55:48 +0200
- Subject: Re: [discuss] Re: FOR REVIEW: New x86-64 vsyscall vgetcpu()
- References: <200606140942.31150.ak@suse.de> <200606161740.18611.ak@suse.de> <Pine.LNX.4.64.0606161615450.23743@turbotaz.ourhouse>
On Friday 16 June 2006 23:19, Chase Venters wrote:
> On Fri, 16 Jun 2006, Andi Kleen wrote:
> >> To this last point, it might be more reasonable to map in a page that
> >> contained a new structure with a stable ABI, which mirrored some of
> >> the task_struct information, and likely other useful information as
> >> needs are identified in the future. In any case, it would be hard
> >> to beat a single memory read for performance.
> >
> > That would mean making the context switch and possibly other
> > things slower.
>
> Well, if every process had a page of its own, what would the context
> switch overhead be?
For process zero, for thread quite high on x86 because you
would need per CPU page tables. Doing that would be extremly
nasty because you would potentially need to allocate a new
set of page tables every time the process is scheduled to a new
CPU it hasn't run on before.
If you limit it to a process then you can't get the current CPU
from such a mapping because a process can run threaded on
multiple CPUs.
My reference was more to high suggestion of keeping a second version
of task_struct for export. That would require changing everything
in task struct that is changed on switch_to and should be exported
in the other function too.
-Andi