cvs commit: src/lib/libthread_xu Makefile pthread.map src/lib/libthread_xu/arch Makefile.inc src/lib/libthread_xu/arch/alpha Makefile.inc src/lib/libthread_xu/arch/alpha/alpha pthread_md.c src/lib/libthread_xu/arch/alpha/include pthread_md.h src/lib/libthread_xu/arch/amd64 ...

Matthew Dillon dillon at apollo.backplane.com
Tue Feb 1 10:41:49 PST 2005


:We have to touch the page tables for a process switch anyway, it's not
:that expensive to have a thread-local page mapping there I think.
:On the other hand the LDT approach costs for every access.
:
:Joerg

    The rfork'd processes are sharing the same page table, and the switch
    code detects this and does not bother to reload %cr3 (which saves a lot
    of cpu cycles), so you can't create a thread-local page mapping that way.

    As far as I know the LDT is the only way to create uniqueness between
    different processes sharing the same page table.  It's expensive, but 
    probably not as expensive as reloading %cr3.

    It would be interesting to test that hypothesis... what is more expensive?
    reloading %cr3 on every switch or reloading the LDT on every switch ?

					-Matt
					Matthew Dillon 
					<dillon at xxxxxxxxxxxxx>





More information about the Commits mailing list