From: "David S. Miller" <davem@redhat.com>
To: torvalds@osdl.org
Cc: linux-arch@vger.kernel.org
Subject: clear_user_highpage()
Date: Wed, 11 Aug 2004 16:15:37 -0700 [thread overview]
Message-ID: <20040811161537.5e24c2b6.davem@redhat.com> (raw)
During a kernel build, this is what tops the profiling charts
for me on sparc64 currently. This drives me crazy :-)
I've optimized the sparc64 page zero as much as I possibly
could, so that's not worth tinkering with any longer.
The PPC people used to zero out pages in the cpu idle loop
and I'd definitely like to do something along those lines
on sparc64 as well, I feel it would be extremely effective.
There is a lot of code path in there for alloc_pages_vma().
I don't think adding arch overridable stuff is the way
to go here. Something generic in the per-cpu hot/cold
page list handling that the cpu_idle() loop of each architecture
could call.
Perhaps a page flags bit that says "pre-zeroed" or something.
Then my clear_user_page() code on sparc64 could just test the
page bit and return if it is set. Page free would need to
clear that bit of course.
I have no real concrete ideas, but I know that while looking
at some source code in an editor, my cpus could zero out all
the free pages in the system in a second or two :-)
Comments?
next reply other threads:[~2004-08-11 23:16 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-08-11 23:15 David S. Miller [this message]
2004-08-11 23:31 ` clear_user_highpage() Benjamin Herrenschmidt
2004-08-11 23:55 ` clear_user_highpage() David S. Miller
2004-08-12 0:03 ` clear_user_highpage() Benjamin Herrenschmidt
2004-08-12 1:18 ` clear_user_highpage() William Lee Irwin III
2004-08-12 2:11 ` clear_user_highpage() Andi Kleen
2004-08-12 9:23 ` clear_user_highpage() Martin Schwidefsky
2004-08-11 23:46 ` clear_user_highpage() Linus Torvalds
2004-08-11 23:53 ` clear_user_highpage() David S. Miller
2004-08-12 0:00 ` clear_user_highpage() Linus Torvalds
2004-08-12 0:06 ` clear_user_highpage() Benjamin Herrenschmidt
2004-08-12 0:24 ` clear_user_highpage() David S. Miller
2004-08-12 0:23 ` clear_user_highpage() David S. Miller
2004-08-12 1:46 ` clear_user_highpage() Linus Torvalds
2004-08-12 2:51 ` clear_user_highpage() David S. Miller
2004-08-16 1:58 ` clear_user_highpage() Paul Mackerras
2004-08-12 2:08 ` clear_user_highpage() Andi Kleen
2004-08-12 2:45 ` clear_user_highpage() David S. Miller
2004-08-12 9:09 ` clear_user_highpage() Andi Kleen
2004-08-12 19:50 ` clear_user_highpage() David S. Miller
2004-08-12 20:00 ` clear_user_highpage() Andi Kleen
2004-08-12 20:30 ` clear_user_highpage() David S. Miller
2004-08-12 21:34 ` clear_user_highpage() Matthew Wilcox
2004-08-13 8:16 ` clear_user_highpage() David Mosberger
2004-08-12 0:00 ` clear_user_highpage() Benjamin Herrenschmidt
2004-08-12 0:21 ` clear_user_highpage() Linus Torvalds
2004-08-12 0:46 ` clear_user_highpage() William Lee Irwin III
2004-08-12 1:01 ` clear_user_highpage() David S. Miller
2004-08-12 2:18 ` clear_user_highpage() Linus Torvalds
2004-08-12 2:43 ` clear_user_highpage() David S. Miller
2004-08-12 4:19 ` clear_user_highpage() Linus Torvalds
2004-08-12 4:46 ` clear_user_highpage() William Lee Irwin III
2004-08-15 6:22 ` clear_user_highpage() Andrew Morton
2004-08-15 6:38 ` clear_user_highpage() William Lee Irwin III
2004-08-12 2:57 ` clear_user_highpage() David S. Miller
2004-08-12 3:20 ` clear_user_highpage() William Lee Irwin III
2004-08-13 21:41 ` clear_user_highpage() David S. Miller
2004-08-16 13:00 ` clear_user_highpage() David Mosberger
2004-08-22 19:51 ` clear_user_highpage() Linus Torvalds
2005-09-17 19:01 ` clear_user_highpage() Andi Kleen
2005-09-17 19:16 ` clear_user_highpage() Andi Kleen
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=20040811161537.5e24c2b6.davem@redhat.com \
--to=davem@redhat.com \
--cc=linux-arch@vger.kernel.org \
--cc=torvalds@osdl.org \
/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