From: Paul Jackson <pj@sgi.com>
To: Andi Kleen <ak@suse.de>, linux-kernel@vger.kernel.org
Subject: numa mm/mempolicy.c maxnode off by one
Date: Sun, 18 Jul 2004 18:18:55 -0700 [thread overview]
Message-ID: <20040718181855.07226c74.pj@sgi.com> (raw)
Andi,
As best as I can tell from code reading, the value of maxnode that is
passed in on the numa system calls mbind, get_mempolicy and
set_mempolicy is "off by one". This seems to be undocumented, and so
far as I have yet been able to imagine, unjustified.
The kernel code in mm/mempolicy.c expects a value one larger than is
natural, and then decrements it, or it uses "maxnode-1" (sometimes one
way, sometimes the other, inconsistently). Your libnuma user library
hides this off by one with a corresponding increment by one of maxnode.
But we are not all using libnuma. Some of us are using the actual
system calls, for our own nefarious purposes.
For example, on my 256 node system, with 256 bit user nodemasks, I have
to pass in a maxnode value of 257. And the libnuma library, and numactl
command utility based on it, which are hardcoded for 2048 bit nodemasks,
always pass in a maxnode value of 2049.
Someday, someone is going to pass in some nice power of two value,
corresponding to the actual number of nodes in their nodemasks, not
expecting that their last node is being ignored.
Andi - could you explain how this came to be, and perhaps recommend a
way to fix it (or explain why it's not broken and shouldn't be fixed)?
I could propose ways to fix this without breaking any libnuma that
you've already shipped. But first I should find out if my understanding
of the situation is correct.
--
I won't rest till it's the best ...
Programmer, Linux Scalability
Paul Jackson <pj@sgi.com> 1.650.933.1373
next reply other threads:[~2004-07-19 1:19 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-07-19 1:18 Paul Jackson [this message]
2004-07-20 0:31 ` numa mm/mempolicy.c maxnode off by one Paul Jackson
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=20040718181855.07226c74.pj@sgi.com \
--to=pj@sgi.com \
--cc=ak@suse.de \
--cc=linux-kernel@vger.kernel.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