diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-06 19:35:10 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-06 19:35:10 -0400 |
commit | 57d326169e878a1a37b2bccd1cf81f6809ee67b9 (patch) | |
tree | 86ed74ae4dc2beaebce1c67b8459f1873b777d3a /mm/memblock.c | |
parent | 7b215de3d0abbc4f6daf2efd19e8809af0564490 (diff) | |
parent | 0244756edc4b98c129e92c7061d9f383708cf786 (diff) |
Merge branch 'akpm' (patches from Andrew Morton) into next
Merge more updates from Andrew Morton:
- Most of the rest of MM.
This includes "mark remap_file_pages syscall as deprecated" but the
actual "replace remap_file_pages syscall with emulation" is held
back. I guess we'll need to work out when to pull the trigger on
that one.
- various minor cleanups to obscure filesystems
- the drivers/rtc queue
- hfsplus updates
- ufs, hpfs, fatfs, affs, reiserfs
- Documentation/
- signals
- procfs
- cpu hotplug
- lib/idr.c
- rapidio
- sysctl
- ipc updates
* emailed patches from Andrew Morton <akpm@linux-foundation.org>: (171 commits)
ufs: sb mutex merge + mutex_destroy
powerpc: update comments for generic idle conversion
cris: update comments for generic idle conversion
idle: remove cpu_idle() forward declarations
nbd: zero from and len fields in NBD_CMD_DISCONNECT.
mm: convert some level-less printks to pr_*
MAINTAINERS: adi-buildroot-devel is moderated
MAINTAINERS: add linux-api for review of API/ABI changes
mm/kmemleak-test.c: use pr_fmt for logging
fs/dlm/debug_fs.c: replace seq_printf by seq_puts
fs/dlm/lockspace.c: convert simple_str to kstr
fs/dlm/config.c: convert simple_str to kstr
mm: mark remap_file_pages() syscall as deprecated
mm: memcontrol: remove unnecessary memcg argument from soft limit functions
mm: memcontrol: clean up memcg zoneinfo lookup
mm/memblock.c: call kmemleak directly from memblock_(alloc|free)
mm/mempool.c: update the kmemleak stack trace for mempool allocations
lib/radix-tree.c: update the kmemleak stack trace for radix tree allocations
mm: introduce kmemleak_update_trace()
mm/kmemleak.c: use %u to print ->checksum
...
Diffstat (limited to 'mm/memblock.c')
-rw-r--r-- | mm/memblock.c | 10 |
1 files changed, 8 insertions, 2 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 | ||