x86/numa_emulation: Assign physnode_mask directly from numa_nodes_parsed
numa_init() has already called init_func(), which is responsible for setting numa_nodes_parsed, so use this nodemask instead of re-finding it when calling numa_emulation(). This patch gets the physnode_mask directly from numa_nodes_parsed. At the same time, it corrects the comment of these two functions. Signed-off-by: Wei Yang <richard.weiyang@gmail.com> Reviewed-by: Borislav Petkov <bp@suse.de> Acked-by: Thomas Gleixner <tglx@linutronix.de> Acked-by: David Rientjes <rientjes@google.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: bp@alien8.de Cc: kirill@shutemov.name Cc: tj@kernel.org Link: http://lkml.kernel.org/r/20170708013059.29708-3-richard.weiyang@gmail.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
@@ -75,13 +75,15 @@ static int __init emu_setup_memblk(struct numa_meminfo *ei,
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Sets up nr_nodes fake nodes interleaved over physical nodes ranging from addr
|
* Sets up nr_nodes fake nodes interleaved over physical nodes ranging from addr
|
||||||
* to max_addr. The return value is the number of nodes allocated.
|
* to max_addr.
|
||||||
|
*
|
||||||
|
* Returns zero on success or negative on error.
|
||||||
*/
|
*/
|
||||||
static int __init split_nodes_interleave(struct numa_meminfo *ei,
|
static int __init split_nodes_interleave(struct numa_meminfo *ei,
|
||||||
struct numa_meminfo *pi,
|
struct numa_meminfo *pi,
|
||||||
u64 addr, u64 max_addr, int nr_nodes)
|
u64 addr, u64 max_addr, int nr_nodes)
|
||||||
{
|
{
|
||||||
nodemask_t physnode_mask = NODE_MASK_NONE;
|
nodemask_t physnode_mask = numa_nodes_parsed;
|
||||||
u64 size;
|
u64 size;
|
||||||
int big;
|
int big;
|
||||||
int nid = 0;
|
int nid = 0;
|
||||||
@@ -116,9 +118,6 @@ static int __init split_nodes_interleave(struct numa_meminfo *ei,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < pi->nr_blks; i++)
|
|
||||||
node_set(pi->blk[i].nid, physnode_mask);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Continue to fill physical nodes with fake nodes until there is no
|
* Continue to fill physical nodes with fake nodes until there is no
|
||||||
* memory left on any of them.
|
* memory left on any of them.
|
||||||
@@ -200,13 +199,15 @@ static u64 __init find_end_of_node(u64 start, u64 max_addr, u64 size)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Sets up fake nodes of `size' interleaved over physical nodes ranging from
|
* Sets up fake nodes of `size' interleaved over physical nodes ranging from
|
||||||
* `addr' to `max_addr'. The return value is the number of nodes allocated.
|
* `addr' to `max_addr'.
|
||||||
|
*
|
||||||
|
* Returns zero on success or negative on error.
|
||||||
*/
|
*/
|
||||||
static int __init split_nodes_size_interleave(struct numa_meminfo *ei,
|
static int __init split_nodes_size_interleave(struct numa_meminfo *ei,
|
||||||
struct numa_meminfo *pi,
|
struct numa_meminfo *pi,
|
||||||
u64 addr, u64 max_addr, u64 size)
|
u64 addr, u64 max_addr, u64 size)
|
||||||
{
|
{
|
||||||
nodemask_t physnode_mask = NODE_MASK_NONE;
|
nodemask_t physnode_mask = numa_nodes_parsed;
|
||||||
u64 min_size;
|
u64 min_size;
|
||||||
int nid = 0;
|
int nid = 0;
|
||||||
int i, ret;
|
int i, ret;
|
||||||
@@ -231,9 +232,6 @@ static int __init split_nodes_size_interleave(struct numa_meminfo *ei,
|
|||||||
}
|
}
|
||||||
size &= FAKE_NODE_MIN_HASH_MASK;
|
size &= FAKE_NODE_MIN_HASH_MASK;
|
||||||
|
|
||||||
for (i = 0; i < pi->nr_blks; i++)
|
|
||||||
node_set(pi->blk[i].nid, physnode_mask);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fill physical nodes with fake nodes of size until there is no memory
|
* Fill physical nodes with fake nodes of size until there is no memory
|
||||||
* left on any of them.
|
* left on any of them.
|
||||||
|
Reference in New Issue
Block a user