From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jeff Mahoney Date: Tue, 20 Oct 2009 14:18:02 +0000 Subject: Re: Commit 34d76c41 causes linker errors on ia64 with NR_CPUS=4096 Message-Id: <4ADDC69A.5000701@suse.com> List-Id: References: <4ADB967A.4080707@suse.com> <4ADD48D1.1040701@kernel.org> <4ADD54D4.70808@kernel.org> <4ADD5530.3050107@kernel.org> In-Reply-To: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Jiri Kosina Cc: Tejun Heo , Peter Zijlstra , Linux Kernel Mailing List , Tony Luck , Fenghua Yu , linux-ia64@vger.kernel.org On 10/20/2009 02:27 AM, Jiri Kosina wrote: > @@ -1627,11 +1623,10 @@ static int tg_shares_up(struct task_group *tg, void *data) > return 0; > > local_irq_save(flags); > - usd = &__get_cpu_var(update_shares_data); > > for_each_cpu(i, sched_domain_span(sd)) { > weight = tg->cfs_rq[i]->load.weight; > - usd->rq_weight[i] = weight; > + usd = *per_cpu_ptr(update_shares_data, i) = weight; > > /* > * If there are currently no tasks on the cpu pretend there I don't think this is what you want here. In the original version, usd is the percpu var using the current cpu. In your version, usd is the percpu var using i instead of the current cpu. I'll post my version of the patch shortly. I don't think keeping most of the original version is a bad thing. We can just allocate it dynamically instead. -Jeff -- Jeff Mahoney SUSE Labs