cvs commit: src/sys/arm/include machdep.h pmap.h sysarch.h src/sys/arm/arm cpufunc_asm.S genassym.c machdep.c pmap.c swtch.S src/sys/arm/xscale std.xscale src/sys/arm/xscale/i80321 std.i80321

David Xu davidxu at freebsd.org
Sun Feb 27 00:40:22 GMT 2005


I am thinking why you can finish the task in such short time. :=)

Should sysarch(ARM_SET_TP,...) write the thread pointer to
ARM_TP_ADDRESS now not just remembers it or did I miss
something ?

David Xu

Olivier Houchard wrote:

>cognet      2005-02-26 18:59:01 UTC
>
>  FreeBSD src repository
>
>  Modified files:
>    sys/arm/include      sysarch.h pmap.h machdep.h 
>    sys/arm/arm          cpufunc_asm.S genassym.c machdep.c pmap.c 
>                         swtch.S 
>    sys/arm/xscale/i80321 std.i80321 
>  Added files:
>    sys/arm/xscale       std.xscale 
>  Log:
>  Instead of using sysarch() to store-retrieve the tp, add a magic address,
>  ARM_TP_ADDRESS, where the tp will be stored. On CPUs that support it, a cache
>  line will be allocated and locked for this address, so that it will never go
>  to RAM. On CPUs that does not, a page is allocated for it (it will be a bit
>  slower, and is wrong for SMP, but should be fine for UP).
>  The tp is still stored in the mdthread struct, and at each context switch,
>  ARM_TP_ADDRESS gets updated.
>  
>  Suggested by:   davidxu
>  
>



More information about the cvs-all mailing list