mm: convert totalram_pages and totalhigh_pages variables to atomic
totalram_pages and totalhigh_pages are made static inline function. Main motivation was that managed_page_count_lock handling was complicating things. It was discussed in length here, https://lore.kernel.org/patchwork/patch/995739/#1181785 So it seemes better to remove the lock and convert variables to atomic, with preventing poteintial store-to-read tearing as a bonus. [akpm@linux-foundation.org: coding style fixes] Link: http://lkml.kernel.org/r/1542090790-21750-4-git-send-email-arunks@codeaurora.org Signed-off-by: Arun KS <arunks@codeaurora.org> Suggested-by: Michal Hocko <mhocko@suse.com> Suggested-by: Vlastimil Babka <vbabka@suse.cz> Reviewed-by: Konstantin Khlebnikov <khlebnikov@yandex-team.ru> Reviewed-by: Pavel Tatashin <pasha.tatashin@soleen.com> Acked-by: Michal Hocko <mhocko@suse.com> Acked-by: Vlastimil Babka <vbabka@suse.cz> Cc: David Hildenbrand <david@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
@@ -1576,7 +1576,7 @@ void __init __memblock_free_late(phys_addr_t base, phys_addr_t size)
|
||||
|
||||
for (; cursor < end; cursor++) {
|
||||
memblock_free_pages(pfn_to_page(cursor), cursor, 0);
|
||||
totalram_pages++;
|
||||
totalram_pages_inc();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1978,7 +1978,7 @@ unsigned long __init memblock_free_all(void)
|
||||
reset_all_zones_managed_pages();
|
||||
|
||||
pages = free_low_memory_core_early();
|
||||
totalram_pages += pages;
|
||||
totalram_pages_add(pages);
|
||||
|
||||
return pages;
|
||||
}
|
||||
|
Reference in New Issue
Block a user