From owner-cvs-all@FreeBSD.ORG Sun Feb 27 00:40:22 2005 Return-Path: Delivered-To: cvs-all@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 68C2B16A4CE; Sun, 27 Feb 2005 00:40:22 +0000 (GMT) Received: from freefall.freebsd.org (freefall.freebsd.org [216.136.204.21]) by mx1.FreeBSD.org (Postfix) with ESMTP id 4951743D2D; Sun, 27 Feb 2005 00:40:22 +0000 (GMT) (envelope-from davidxu@freebsd.org) Received: from [127.0.0.1] (davidxu@localhost [127.0.0.1]) by freefall.freebsd.org (8.13.1/8.13.1) with ESMTP id j1R0eKnQ008094; Sun, 27 Feb 2005 00:40:21 GMT (envelope-from davidxu@freebsd.org) Message-ID: <422116F0.7030604@freebsd.org> Date: Sun, 27 Feb 2005 08:40:16 +0800 From: David Xu User-Agent: Mozilla/5.0 (X11; U; FreeBSD i386; en-US; rv:1.7.5) Gecko/20041226 X-Accept-Language: en-us, en MIME-Version: 1.0 To: Olivier Houchard References: <200502261859.j1QIx1fL008419@repoman.freebsd.org> In-Reply-To: <200502261859.j1QIx1fL008419@repoman.freebsd.org> Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit cc: cvs-src@freebsd.org cc: src-committers@freebsd.org cc: cvs-all@freebsd.org Subject: Re: 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 X-BeenThere: cvs-all@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: CVS commit messages for the entire tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 27 Feb 2005 00:40:22 -0000 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 > >