13c7b4e6bSCatalin Marinas /* 23c7b4e6bSCatalin Marinas * include/linux/kmemleak.h 33c7b4e6bSCatalin Marinas * 43c7b4e6bSCatalin Marinas * Copyright (C) 2008 ARM Limited 53c7b4e6bSCatalin Marinas * Written by Catalin Marinas <catalin.marinas@arm.com> 63c7b4e6bSCatalin Marinas * 73c7b4e6bSCatalin Marinas * This program is free software; you can redistribute it and/or modify 83c7b4e6bSCatalin Marinas * it under the terms of the GNU General Public License version 2 as 93c7b4e6bSCatalin Marinas * published by the Free Software Foundation. 103c7b4e6bSCatalin Marinas * 113c7b4e6bSCatalin Marinas * This program is distributed in the hope that it will be useful, 123c7b4e6bSCatalin Marinas * but WITHOUT ANY WARRANTY; without even the implied warranty of 133c7b4e6bSCatalin Marinas * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 143c7b4e6bSCatalin Marinas * GNU General Public License for more details. 153c7b4e6bSCatalin Marinas * 163c7b4e6bSCatalin Marinas * You should have received a copy of the GNU General Public License 173c7b4e6bSCatalin Marinas * along with this program; if not, write to the Free Software 183c7b4e6bSCatalin Marinas * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 193c7b4e6bSCatalin Marinas */ 203c7b4e6bSCatalin Marinas 213c7b4e6bSCatalin Marinas #ifndef __KMEMLEAK_H 223c7b4e6bSCatalin Marinas #define __KMEMLEAK_H 233c7b4e6bSCatalin Marinas 2466f2ca7eSAndrew Morton #include <linux/slab.h> 2566f2ca7eSAndrew Morton 263c7b4e6bSCatalin Marinas #ifdef CONFIG_DEBUG_KMEMLEAK 273c7b4e6bSCatalin Marinas 2898e89cf0SNicolas Iooss extern void kmemleak_init(void) __init; 293c7b4e6bSCatalin Marinas extern void kmemleak_alloc(const void *ptr, size_t size, int min_count, 30a6186d89SCatalin Marinas gfp_t gfp) __ref; 318a8c35faSLarry Finger extern void kmemleak_alloc_percpu(const void __percpu *ptr, size_t size, 328a8c35faSLarry Finger gfp_t gfp) __ref; 33a6186d89SCatalin Marinas extern void kmemleak_free(const void *ptr) __ref; 34a6186d89SCatalin Marinas extern void kmemleak_free_part(const void *ptr, size_t size) __ref; 35f528f0b8SCatalin Marinas extern void kmemleak_free_percpu(const void __percpu *ptr) __ref; 36ffe2c748SCatalin Marinas extern void kmemleak_update_trace(const void *ptr) __ref; 37a6186d89SCatalin Marinas extern void kmemleak_not_leak(const void *ptr) __ref; 38a6186d89SCatalin Marinas extern void kmemleak_ignore(const void *ptr) __ref; 39c017b4beSCatalin Marinas extern void kmemleak_scan_area(const void *ptr, size_t size, gfp_t gfp) __ref; 40a6186d89SCatalin Marinas extern void kmemleak_no_scan(const void *ptr) __ref; 413c7b4e6bSCatalin Marinas 423c7b4e6bSCatalin Marinas static inline void kmemleak_alloc_recursive(const void *ptr, size_t size, 433c7b4e6bSCatalin Marinas int min_count, unsigned long flags, 443c7b4e6bSCatalin Marinas gfp_t gfp) 453c7b4e6bSCatalin Marinas { 463c7b4e6bSCatalin Marinas if (!(flags & SLAB_NOLEAKTRACE)) 473c7b4e6bSCatalin Marinas kmemleak_alloc(ptr, size, min_count, gfp); 483c7b4e6bSCatalin Marinas } 493c7b4e6bSCatalin Marinas 503c7b4e6bSCatalin Marinas static inline void kmemleak_free_recursive(const void *ptr, unsigned long flags) 513c7b4e6bSCatalin Marinas { 523c7b4e6bSCatalin Marinas if (!(flags & SLAB_NOLEAKTRACE)) 533c7b4e6bSCatalin Marinas kmemleak_free(ptr); 543c7b4e6bSCatalin Marinas } 553c7b4e6bSCatalin Marinas 563c7b4e6bSCatalin Marinas static inline void kmemleak_erase(void **ptr) 573c7b4e6bSCatalin Marinas { 583c7b4e6bSCatalin Marinas *ptr = NULL; 593c7b4e6bSCatalin Marinas } 603c7b4e6bSCatalin Marinas 613c7b4e6bSCatalin Marinas #else 623c7b4e6bSCatalin Marinas 633c7b4e6bSCatalin Marinas static inline void kmemleak_init(void) 643c7b4e6bSCatalin Marinas { 653c7b4e6bSCatalin Marinas } 663c7b4e6bSCatalin Marinas static inline void kmemleak_alloc(const void *ptr, size_t size, int min_count, 673c7b4e6bSCatalin Marinas gfp_t gfp) 683c7b4e6bSCatalin Marinas { 693c7b4e6bSCatalin Marinas } 703c7b4e6bSCatalin Marinas static inline void kmemleak_alloc_recursive(const void *ptr, size_t size, 713c7b4e6bSCatalin Marinas int min_count, unsigned long flags, 723c7b4e6bSCatalin Marinas gfp_t gfp) 733c7b4e6bSCatalin Marinas { 743c7b4e6bSCatalin Marinas } 758a8c35faSLarry Finger static inline void kmemleak_alloc_percpu(const void __percpu *ptr, size_t size, 768a8c35faSLarry Finger gfp_t gfp) 77f528f0b8SCatalin Marinas { 78f528f0b8SCatalin Marinas } 793c7b4e6bSCatalin Marinas static inline void kmemleak_free(const void *ptr) 803c7b4e6bSCatalin Marinas { 813c7b4e6bSCatalin Marinas } 8253238a60SCatalin Marinas static inline void kmemleak_free_part(const void *ptr, size_t size) 8353238a60SCatalin Marinas { 8453238a60SCatalin Marinas } 853c7b4e6bSCatalin Marinas static inline void kmemleak_free_recursive(const void *ptr, unsigned long flags) 863c7b4e6bSCatalin Marinas { 873c7b4e6bSCatalin Marinas } 88f528f0b8SCatalin Marinas static inline void kmemleak_free_percpu(const void __percpu *ptr) 89f528f0b8SCatalin Marinas { 90f528f0b8SCatalin Marinas } 91ffe2c748SCatalin Marinas static inline void kmemleak_update_trace(const void *ptr) 92ffe2c748SCatalin Marinas { 93ffe2c748SCatalin Marinas } 943c7b4e6bSCatalin Marinas static inline void kmemleak_not_leak(const void *ptr) 953c7b4e6bSCatalin Marinas { 963c7b4e6bSCatalin Marinas } 973c7b4e6bSCatalin Marinas static inline void kmemleak_ignore(const void *ptr) 983c7b4e6bSCatalin Marinas { 993c7b4e6bSCatalin Marinas } 100c017b4beSCatalin Marinas static inline void kmemleak_scan_area(const void *ptr, size_t size, gfp_t gfp) 1013c7b4e6bSCatalin Marinas { 1023c7b4e6bSCatalin Marinas } 1033c7b4e6bSCatalin Marinas static inline void kmemleak_erase(void **ptr) 1043c7b4e6bSCatalin Marinas { 1053c7b4e6bSCatalin Marinas } 1063c7b4e6bSCatalin Marinas static inline void kmemleak_no_scan(const void *ptr) 1073c7b4e6bSCatalin Marinas { 1083c7b4e6bSCatalin Marinas } 1093c7b4e6bSCatalin Marinas 1103c7b4e6bSCatalin Marinas #endif /* CONFIG_DEBUG_KMEMLEAK */ 1113c7b4e6bSCatalin Marinas 1123c7b4e6bSCatalin Marinas #endif /* __KMEMLEAK_H */ 113