From: Ingo Molnar <mingo@elte.hu>
To: Jeremy Fitzhardinge <jeremy@goop.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>,
linux-kernel@vger.kernel.org,
Peter Zijlstra <a.p.zijlstra@chello.nl>,
Thomas Gleixner <tglx@linutronix.de>,
Andrew Morton <akpm@linux-foundation.org>,
Mike Travis <travis@sgi.com>
Subject: Re: [git pull] core/percpu for v2.6.27
Date: Tue, 15 Jul 2008 23:00:02 +0200 [thread overview]
Message-ID: <20080715210002.GA7072@elte.hu> (raw)
In-Reply-To: <487CC671.3000501@goop.org>
* Jeremy Fitzhardinge <jeremy@goop.org> wrote:
> Linus Torvalds wrote:
>> Can you explain what this does and who needs it? The percpu_xchg()
>> looks particularly pointless, since it's always a locked SMP-safe
>> instruction on x86, so a nonpreemptible load+store will likely be much
>> faster.
>
> The essence of those changes is to work towards unifying the i386 and
> x86-64 percpu mechanisms. But I wasn't terribly convinced by some of
> the frills around the edges, like the xchg operation. The work is
> being driven by Mike Travis and the huge numa people, so perhaps they
> have a use for it.
yeah. It all centers around the '4096 CPUs' topic which has so wide
impact that it had to be scattered out a bit.
x86_percpu_xchg():
seems like a sensible extension of the API family to me. Linus is right
about the LOCK overhead but i'm not all that sure that LOCKed
instructions will always be slower. Combined with single-pointer per-cpu
(not the PDA-based redirection we do now) it can be done safely without
disabling preemption - and that would make the basic percpu ops usable
in preemptible code.
But indeed there are no very strong reasons.
These are the currently pending related topics:
# tip/cpus4096 - ready for upstream, i'll send the pull request once
# core/rcu is upstream
earth4:~/tip> git-log-line linus..cpus4096
9982fbf: Revert "cpumask: introduce new APIs"
68083e0: Merge commit 'v2.6.26-rc9' into cpus4096
7baac8b: cpumask: make for_each_cpu_mask a bit smaller
3f9b48a: net: Pass reference to cpumask variable in net/sunrpc/svc.c
cad0e45: clocksource/events: use performance variant for_each_cpu_mask_nr
5d7bfd0: infiniband: use performance variant for_each_cpu_mask_nr
334ef7a: x86: use performance variant for_each_cpu_mask_nr
0e12f84: net: use performance variant for_each_cpu_mask_nr
6d6a436: mm: use performance variant for_each_cpu_mask_nr
363ab6f: core: use performance variant for_each_cpu_mask_nr
068b127: cpufreq: use performance variant for_each_cpu_mask_nr
141ad06: acpi: use performance variant for_each_cpu_mask_nr
41df0d61: x86: Add performance variants of cpumask operators
143aa5c: cpu: change some globals to statics in drivers/base/cpu.c v2
a953e45: sched: replace MAX_NUMNODES with nr_node_ids in kernel/sched.c
# tip/core/percpu-zerobased: stalled - current approach is
# fragile to binutils bugs
earth4:~/tip> git-log-line linus..core/percpu-zerobased
a6d5d88: x86, 64-bit: replace xxx_pda() operations with x86_xxx_percpu().
6b17441: x86, 64-bit: replace cpu_pda ops with percpu ops
6aa952c: x86, 64-bit: reference zero-based percpu variables offset from gs
8c76b15: x86, 64-bit: fold pda into per cpu area
673698e: x86, 64-bit: fix early references to cpumask_of_cpu
in hindsight core/percpu indeed looks unfinished and direction-less
without core/percpu-zerobased - but the latter is not stable yet.
Ingo
next prev parent reply other threads:[~2008-07-15 21:00 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-07-14 14:34 [git pull] core/percpu for v2.6.27 Ingo Molnar
2008-07-14 22:27 ` Linus Torvalds
2008-07-15 15:46 ` Jeremy Fitzhardinge
2008-07-15 21:00 ` Ingo Molnar [this message]
2008-07-15 21:26 ` Mike Travis
2008-07-15 21:46 ` H. Peter Anvin
2008-07-18 22:17 ` Ingo Molnar
2008-07-18 22:54 ` Mike Travis
2008-07-25 15:18 ` Mike Travis
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080715210002.GA7072@elte.hu \
--to=mingo@elte.hu \
--cc=a.p.zijlstra@chello.nl \
--cc=akpm@linux-foundation.org \
--cc=jeremy@goop.org \
--cc=linux-kernel@vger.kernel.org \
--cc=tglx@linutronix.de \
--cc=torvalds@linux-foundation.org \
--cc=travis@sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox