blob: 5ac416e2d339f923b694eafbc978ca1e13edc9f3 [file] [log] [blame]
Catalin Marinas3c7b4e62009-06-11 13:22:39 +01001/*
2 * include/linux/kmemleak.h
3 *
4 * Copyright (C) 2008 ARM Limited
5 * Written by Catalin Marinas <catalin.marinas@arm.com>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 */
20
21#ifndef __KMEMLEAK_H
22#define __KMEMLEAK_H
23
Andrew Morton66f2ca72014-12-12 16:55:41 -080024#include <linux/slab.h>
Catalin Marinas94f4a162017-07-06 15:40:22 -070025#include <linux/vmalloc.h>
Andrew Morton66f2ca72014-12-12 16:55:41 -080026
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010027#ifdef CONFIG_DEBUG_KMEMLEAK
28
Nicolas Iooss98e89cf2015-12-11 13:40:43 -080029extern void kmemleak_init(void) __init;
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010030extern void kmemleak_alloc(const void *ptr, size_t size, int min_count,
Catalin Marinasa6186d82009-08-27 14:29:16 +010031 gfp_t gfp) __ref;
Larry Finger8a8c35f2015-06-24 16:58:51 -070032extern void kmemleak_alloc_percpu(const void __percpu *ptr, size_t size,
33 gfp_t gfp) __ref;
Catalin Marinas94f4a162017-07-06 15:40:22 -070034extern void kmemleak_vmalloc(const struct vm_struct *area, size_t size,
35 gfp_t gfp) __ref;
Catalin Marinasa6186d82009-08-27 14:29:16 +010036extern void kmemleak_free(const void *ptr) __ref;
37extern void kmemleak_free_part(const void *ptr, size_t size) __ref;
Catalin Marinasf528f0b2011-09-26 17:12:53 +010038extern void kmemleak_free_percpu(const void __percpu *ptr) __ref;
Catalin Marinasffe2c742014-06-06 14:38:17 -070039extern void kmemleak_update_trace(const void *ptr) __ref;
Catalin Marinasa6186d82009-08-27 14:29:16 +010040extern void kmemleak_not_leak(const void *ptr) __ref;
41extern void kmemleak_ignore(const void *ptr) __ref;
Catalin Marinasc017b4b2009-10-28 13:33:09 +000042extern void kmemleak_scan_area(const void *ptr, size_t size, gfp_t gfp) __ref;
Catalin Marinasa6186d82009-08-27 14:29:16 +010043extern void kmemleak_no_scan(const void *ptr) __ref;
Catalin Marinas9099dae2016-10-11 13:55:11 -070044extern void kmemleak_alloc_phys(phys_addr_t phys, size_t size, int min_count,
45 gfp_t gfp) __ref;
46extern void kmemleak_free_part_phys(phys_addr_t phys, size_t size) __ref;
47extern void kmemleak_not_leak_phys(phys_addr_t phys) __ref;
48extern void kmemleak_ignore_phys(phys_addr_t phys) __ref;
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010049
50static inline void kmemleak_alloc_recursive(const void *ptr, size_t size,
Alexey Dobriyand50112e2017-11-15 17:32:18 -080051 int min_count, slab_flags_t flags,
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010052 gfp_t gfp)
53{
54 if (!(flags & SLAB_NOLEAKTRACE))
55 kmemleak_alloc(ptr, size, min_count, gfp);
56}
57
Alexey Dobriyand50112e2017-11-15 17:32:18 -080058static inline void kmemleak_free_recursive(const void *ptr, slab_flags_t flags)
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010059{
60 if (!(flags & SLAB_NOLEAKTRACE))
61 kmemleak_free(ptr);
62}
63
64static inline void kmemleak_erase(void **ptr)
65{
66 *ptr = NULL;
67}
68
69#else
70
71static inline void kmemleak_init(void)
72{
73}
74static inline void kmemleak_alloc(const void *ptr, size_t size, int min_count,
75 gfp_t gfp)
76{
77}
78static inline void kmemleak_alloc_recursive(const void *ptr, size_t size,
Alexey Dobriyand50112e2017-11-15 17:32:18 -080079 int min_count, slab_flags_t flags,
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010080 gfp_t gfp)
81{
82}
Larry Finger8a8c35f2015-06-24 16:58:51 -070083static inline void kmemleak_alloc_percpu(const void __percpu *ptr, size_t size,
84 gfp_t gfp)
Catalin Marinasf528f0b2011-09-26 17:12:53 +010085{
86}
Catalin Marinas94f4a162017-07-06 15:40:22 -070087static inline void kmemleak_vmalloc(const struct vm_struct *area, size_t size,
88 gfp_t gfp)
89{
90}
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010091static inline void kmemleak_free(const void *ptr)
92{
93}
Catalin Marinas53238a62009-07-07 10:33:00 +010094static inline void kmemleak_free_part(const void *ptr, size_t size)
95{
96}
Alexey Dobriyand50112e2017-11-15 17:32:18 -080097static inline void kmemleak_free_recursive(const void *ptr, slab_flags_t flags)
Catalin Marinas3c7b4e62009-06-11 13:22:39 +010098{
99}
Catalin Marinasf528f0b2011-09-26 17:12:53 +0100100static inline void kmemleak_free_percpu(const void __percpu *ptr)
101{
102}
Catalin Marinasffe2c742014-06-06 14:38:17 -0700103static inline void kmemleak_update_trace(const void *ptr)
104{
105}
Catalin Marinas3c7b4e62009-06-11 13:22:39 +0100106static inline void kmemleak_not_leak(const void *ptr)
107{
108}
109static inline void kmemleak_ignore(const void *ptr)
110{
111}
Catalin Marinasc017b4b2009-10-28 13:33:09 +0000112static inline void kmemleak_scan_area(const void *ptr, size_t size, gfp_t gfp)
Catalin Marinas3c7b4e62009-06-11 13:22:39 +0100113{
114}
115static inline void kmemleak_erase(void **ptr)
116{
117}
118static inline void kmemleak_no_scan(const void *ptr)
119{
120}
Catalin Marinas9099dae2016-10-11 13:55:11 -0700121static inline void kmemleak_alloc_phys(phys_addr_t phys, size_t size,
122 int min_count, gfp_t gfp)
123{
124}
125static inline void kmemleak_free_part_phys(phys_addr_t phys, size_t size)
126{
127}
128static inline void kmemleak_not_leak_phys(phys_addr_t phys)
129{
130}
131static inline void kmemleak_ignore_phys(phys_addr_t phys)
132{
133}
Catalin Marinas3c7b4e62009-06-11 13:22:39 +0100134
135#endif /* CONFIG_DEBUG_KMEMLEAK */
136
137#endif /* __KMEMLEAK_H */