(unsigned long long)base + size - 1,
                     (void *)_RET_IP_);
 
+       kmemleak_free_part(__va(base), size);
        return memblock_remove_range(&memblock.reserved, base, size);
 }
 
                align = SMP_CACHE_BYTES;
 
        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 0;
 }
 
 
 void __init free_bootmem_node(pg_data_t *pgdat, unsigned long physaddr,
                              unsigned long size)
 {
-       kmemleak_free_part(__va(physaddr), size);
        memblock_free(physaddr, size);
 }
 
  */
 void __init free_bootmem(unsigned long addr, unsigned long size)
 {
-       kmemleak_free_part(__va(addr), size);
        memblock_free(addr, size);
 }