summaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
Diffstat (limited to 'mm')
-rw-r--r--mm/memblock.c10
-rw-r--r--mm/nobootmem.c2
2 files changed, 8 insertions, 4 deletions
diff --git a/mm/memblock.c b/mm/memblock.c
index 0aa0d2b07624..6d2f219a48b0 100644
--- a/mm/memblock.c
+++ b/mm/memblock.c
@@ -691,6 +691,7 @@ int __init_memblock memblock_free(phys_addr_t base, phys_addr_t size)
691 (unsigned long long)base + size - 1, 691 (unsigned long long)base + size - 1,
692 (void *)_RET_IP_); 692 (void *)_RET_IP_);
693 693
694 kmemleak_free_part(__va(base), size);
694 return memblock_remove_range(&memblock.reserved, base, size); 695 return memblock_remove_range(&memblock.reserved, base, size);
695} 696}
696 697
@@ -1043,9 +1044,14 @@ static phys_addr_t __init memblock_alloc_range_nid(phys_addr_t size,
1043 align = SMP_CACHE_BYTES; 1044 align = SMP_CACHE_BYTES;
1044 1045
1045 found = memblock_find_in_range_node(size, align, start, end, nid); 1046 found = memblock_find_in_range_node(size, align, start, end, nid);
1046 if (found && !memblock_reserve(found, size)) 1047 if (found && !memblock_reserve(found, size)) {
1048 /*
1049 * The min_count is set to 0 so that memblock allocations are
1050 * never reported as leaks.
1051 */
1052 kmemleak_alloc(__va(found), size, 0, 0);
1047 return found; 1053 return found;
1048 1054 }
1049 return 0; 1055 return 0;
1050} 1056}
1051 1057
diff --git a/mm/nobootmem.c b/mm/nobootmem.c
index 04a9d94333a5..7ed58602e71b 100644
--- a/mm/nobootmem.c
+++ b/mm/nobootmem.c
@@ -197,7 +197,6 @@ unsigned long __init free_all_bootmem(void)
197void __init free_bootmem_node(pg_data_t *pgdat, unsigned long physaddr, 197void __init free_bootmem_node(pg_data_t *pgdat, unsigned long physaddr,
198 unsigned long size) 198 unsigned long size)
199{ 199{
200 kmemleak_free_part(__va(physaddr), size);
201 memblock_free(physaddr, size); 200 memblock_free(physaddr, size);
202} 201}
203 202
@@ -212,7 +211,6 @@ void __init free_bootmem_node(pg_data_t *pgdat, unsigned long physaddr,
212 */ 211 */
213void __init free_bootmem(unsigned long addr, unsigned long size) 212void __init free_bootmem(unsigned long addr, unsigned long size)
214{ 213{
215 kmemleak_free_part(__va(addr), size);
216 memblock_free(addr, size); 214 memblock_free(addr, size);
217} 215}
218 216