|
@@ -691,6 +691,7 @@ int __init_memblock memblock_free(phys_addr_t base, phys_addr_t size)
|
|
(unsigned long long)base + size - 1,
|
|
(unsigned long long)base + size - 1,
|
|
(void *)_RET_IP_);
|
|
(void *)_RET_IP_);
|
|
|
|
|
|
|
|
+ kmemleak_free_part(__va(base), size);
|
|
return memblock_remove_range(&memblock.reserved, base, size);
|
|
return memblock_remove_range(&memblock.reserved, base, size);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1043,9 +1044,14 @@ static phys_addr_t __init memblock_alloc_range_nid(phys_addr_t size,
|
|
align = SMP_CACHE_BYTES;
|
|
align = SMP_CACHE_BYTES;
|
|
|
|
|
|
found = memblock_find_in_range_node(size, align, start, end, nid);
|
|
found = memblock_find_in_range_node(size, align, start, end, nid);
|
|
- if (found && !memblock_reserve(found, size))
|
|
|
|
|
|
+ if (found && !memblock_reserve(found, size)) {
|
|
|
|
+ /*
|
|
|
|
+ * The min_count is set to 0 so that memblock allocations are
|
|
|
|
+ * never reported as leaks.
|
|
|
|
+ */
|
|
|
|
+ kmemleak_alloc(__va(found), size, 0, 0);
|
|
return found;
|
|
return found;
|
|
-
|
|
|
|
|
|
+ }
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|