Commit 3c09be5a authored by Kemeng Shi's avatar Kemeng Shi Committed by Andrew Morton

mm/page_ext: remove rollback for untouched mem_section in online_page_ext

If init_section_page_ext failed, we only need rollback for mem_section
before failed mem_section.  Make rollback end point to failed mem_section
to remove unnecessary rollback.

As pfn += PAGES_PER_SECTION will be executed even if init_section_page_ext
failed.  So pfn points to mem_section after failed mem_section.  Subtract
one mem_section from pfn to get failed mem_section.

Link: https://lkml.kernel.org/r/20230714114749.1743032-3-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 063ff7cd
...@@ -424,6 +424,7 @@ static int __meminit online_page_ext(unsigned long start_pfn, ...@@ -424,6 +424,7 @@ static int __meminit online_page_ext(unsigned long start_pfn,
return 0; return 0;
/* rollback */ /* rollback */
end = pfn - PAGES_PER_SECTION;
for (pfn = start; pfn < end; pfn += PAGES_PER_SECTION) for (pfn = start; pfn < end; pfn += PAGES_PER_SECTION)
__free_page_ext(pfn); __free_page_ext(pfn);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment