提交 8346aa76 编写于 作者: G Greg Kroah-Hartman

Revert "mm: Check if section present during memory block (un)registering"

This reverts commit 7568fb63 as it's
already in Linus's tree through a different patch.
Reported-by: NTony Luck <tony.luck@intel.com>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: stable@vger.kernel.org #v3.15
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 dbe2256d
...@@ -390,18 +390,7 @@ int register_mem_sect_under_node(struct memory_block *mem_blk, int nid) ...@@ -390,18 +390,7 @@ int register_mem_sect_under_node(struct memory_block *mem_blk, int nid)
sect_end_pfn = section_nr_to_pfn(mem_blk->end_section_nr); sect_end_pfn = section_nr_to_pfn(mem_blk->end_section_nr);
sect_end_pfn += PAGES_PER_SECTION - 1; sect_end_pfn += PAGES_PER_SECTION - 1;
for (pfn = sect_start_pfn; pfn <= sect_end_pfn; pfn++) { for (pfn = sect_start_pfn; pfn <= sect_end_pfn; pfn++) {
int page_nid, scn_nr; int page_nid;
/*
* memory block could have several absent sections from start.
* skip pfn range from absent section
*/
scn_nr = pfn_to_section_nr(pfn);
if (!present_section_nr(scn_nr)) {
pfn = round_down(pfn + PAGES_PER_SECTION,
PAGES_PER_SECTION) - 1;
continue;
}
/* /*
* memory block could have several absent sections from start. * memory block could have several absent sections from start.
...@@ -447,22 +436,10 @@ int unregister_mem_sect_under_nodes(struct memory_block *mem_blk, ...@@ -447,22 +436,10 @@ int unregister_mem_sect_under_nodes(struct memory_block *mem_blk,
return -ENOMEM; return -ENOMEM;
nodes_clear(*unlinked_nodes); nodes_clear(*unlinked_nodes);
sect_start_pfn = section_nr_to_pfn(mem_blk->start_section_nr); sect_start_pfn = section_nr_to_pfn(phys_index);
sect_end_pfn = section_nr_to_pfn(mem_blk->end_section_nr); sect_end_pfn = sect_start_pfn + PAGES_PER_SECTION - 1;
sect_end_pfn += PAGES_PER_SECTION - 1;
for (pfn = sect_start_pfn; pfn <= sect_end_pfn; pfn++) { for (pfn = sect_start_pfn; pfn <= sect_end_pfn; pfn++) {
int nid, scn_nr; int nid;
/*
* memory block could have several absent sections from start.
* skip pfn range from absent section
*/
scn_nr = pfn_to_section_nr(pfn);
if (!present_section_nr(scn_nr)) {
pfn = round_down(pfn + PAGES_PER_SECTION,
PAGES_PER_SECTION) - 1;
continue;
}
nid = get_nid_for_pfn(pfn); nid = get_nid_for_pfn(pfn);
if (nid < 0) if (nid < 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册