From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Message-ID: <17506.29128.591758.502430@cargo.ozlabs.ibm.com> Date: Thu, 11 May 2006 09:05:44 +1000 From: Paul Mackerras To: Richard Henderson Subject: Re: [RFC/PATCH] Make powerpc64 use __thread for per-cpu variables In-Reply-To: <20060510154702.GA28938@twiddle.net> References: <17505.26159.807484.477212@cargo.ozlabs.ibm.com> <20060510154702.GA28938@twiddle.net> Cc: linux-arch@vger.kernel.org, linuxppc-dev@ozlabs.org, linux-kernel@vger.kernel.org, t@twiddle.net List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Richard Henderson writes: > How do you plan to address the compiler optimizing > > __thread int foo; > { > use(foo); > schedule(); > use(foo); > } > > into > > { > int *tmp = &foo; // tls arithmetic here > use(*tmp); > schedule(); > use(*tmp); > } Hmmm... Would it be sufficient to use a RELOC_HIDE in __get_cpu_var, like this? #define __get_cpu_var(x) (*(RELOC_HIDE(&per_cpu__##x, 0))) Paul.