diff options
| -rw-r--r-- | mm/page_cgroup.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/mm/page_cgroup.c b/mm/page_cgroup.c index 6c0081441a32..5bffada7cde1 100644 --- a/mm/page_cgroup.c +++ b/mm/page_cgroup.c | |||
| @@ -9,6 +9,7 @@ | |||
| 9 | #include <linux/vmalloc.h> | 9 | #include <linux/vmalloc.h> |
| 10 | #include <linux/cgroup.h> | 10 | #include <linux/cgroup.h> |
| 11 | #include <linux/swapops.h> | 11 | #include <linux/swapops.h> |
| 12 | #include <linux/kmemleak.h> | ||
| 12 | 13 | ||
| 13 | static void __meminit | 14 | static void __meminit |
| 14 | __init_page_cgroup(struct page_cgroup *pc, unsigned long pfn) | 15 | __init_page_cgroup(struct page_cgroup *pc, unsigned long pfn) |
| @@ -126,6 +127,12 @@ static int __init_refok init_section_page_cgroup(unsigned long pfn) | |||
| 126 | if (!base) | 127 | if (!base) |
| 127 | base = vmalloc(table_size); | 128 | base = vmalloc(table_size); |
| 128 | } | 129 | } |
| 130 | /* | ||
| 131 | * The value stored in section->page_cgroup is (base - pfn) | ||
| 132 | * and it does not point to the memory block allocated above, | ||
| 133 | * causing kmemleak false positives. | ||
| 134 | */ | ||
| 135 | kmemleak_not_leak(base); | ||
| 129 | } else { | 136 | } else { |
| 130 | /* | 137 | /* |
| 131 | * We don't have to allocate page_cgroup again, but | 138 | * We don't have to allocate page_cgroup again, but |
