summaryrefslogtreecommitdiff
path: root/mm/memblock.c
diff options
context:
space:
mode:
authorAlex Shi <alex.shi@linaro.org>2017-09-01 04:04:22 (GMT)
committerAlex Shi <alex.shi@linaro.org>2017-09-01 04:04:22 (GMT)
commit99a15512fa583684b8cc4ad4805e1e690609cdc7 (patch)
tree6c6b4c091b4b89e9da69030b26d5a68e833d98a4 /mm/memblock.c
parent7c6819fafcd4d26f655ad9b0441f79773c69cf99 (diff)
parent0eed54bdbd1b922004fe05dc8bf3815f2e5723d7 (diff)
downloadlinux-99a15512fa583684b8cc4ad4805e1e690609cdc7.tar.xz
Merge tag 'v4.9.46' into linux-linaro-lsk-v4.9
This is the 4.9.46 stable release
Diffstat (limited to 'mm/memblock.c')
-rw-r--r--mm/memblock.c38
1 files changed, 17 insertions, 21 deletions
diff --git a/mm/memblock.c b/mm/memblock.c
index 9f6be74..3740af5 100644
--- a/mm/memblock.c
+++ b/mm/memblock.c
@@ -297,31 +297,27 @@ static void __init_memblock memblock_remove_region(struct memblock_type *type, u
}
#ifdef CONFIG_ARCH_DISCARD_MEMBLOCK
-
-phys_addr_t __init_memblock get_allocated_memblock_reserved_regions_info(
- phys_addr_t *addr)
-{
- if (memblock.reserved.regions == memblock_reserved_init_regions)
- return 0;
-
- *addr = __pa(memblock.reserved.regions);
-
- return PAGE_ALIGN(sizeof(struct memblock_region) *
- memblock.reserved.max);
-}
-
-phys_addr_t __init_memblock get_allocated_memblock_memory_regions_info(
- phys_addr_t *addr)
+/**
+ * Discard memory and reserved arrays if they were allocated
+ */
+void __init memblock_discard(void)
{
- if (memblock.memory.regions == memblock_memory_init_regions)
- return 0;
+ phys_addr_t addr, size;
- *addr = __pa(memblock.memory.regions);
+ if (memblock.reserved.regions != memblock_reserved_init_regions) {
+ addr = __pa(memblock.reserved.regions);
+ size = PAGE_ALIGN(sizeof(struct memblock_region) *
+ memblock.reserved.max);
+ __memblock_free_late(addr, size);
+ }
- return PAGE_ALIGN(sizeof(struct memblock_region) *
- memblock.memory.max);
+ if (memblock.memory.regions != memblock_memory_init_regions) {
+ addr = __pa(memblock.memory.regions);
+ size = PAGE_ALIGN(sizeof(struct memblock_region) *
+ memblock.memory.max);
+ __memblock_free_late(addr, size);
+ }
}
-
#endif
/**