|
@@ -930,12 +930,13 @@ EXPORT_SYMBOL_GPL(kmemleak_alloc);
|
|
|
* kmemleak_alloc_percpu - register a newly allocated __percpu object
|
|
|
* @ptr: __percpu pointer to beginning of the object
|
|
|
* @size: size of the object
|
|
|
+ * @gfp: flags used for kmemleak internal memory allocations
|
|
|
*
|
|
|
* This function is called from the kernel percpu allocator when a new object
|
|
|
- * (memory block) is allocated (alloc_percpu). It assumes GFP_KERNEL
|
|
|
- * allocation.
|
|
|
+ * (memory block) is allocated (alloc_percpu).
|
|
|
*/
|
|
|
-void __ref kmemleak_alloc_percpu(const void __percpu *ptr, size_t size)
|
|
|
+void __ref kmemleak_alloc_percpu(const void __percpu *ptr, size_t size,
|
|
|
+ gfp_t gfp)
|
|
|
{
|
|
|
unsigned int cpu;
|
|
|
|
|
@@ -948,7 +949,7 @@ void __ref kmemleak_alloc_percpu(const void __percpu *ptr, size_t size)
|
|
|
if (kmemleak_enabled && ptr && !IS_ERR(ptr))
|
|
|
for_each_possible_cpu(cpu)
|
|
|
create_object((unsigned long)per_cpu_ptr(ptr, cpu),
|
|
|
- size, 0, GFP_KERNEL);
|
|
|
+ size, 0, gfp);
|
|
|
else if (kmemleak_early_log)
|
|
|
log_early(KMEMLEAK_ALLOC_PERCPU, ptr, size, 0);
|
|
|
}
|