blob: 5d0767cb424aaa3478c8c35e97fe1a723c95b53a [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jiri Slaby59ea7462008-06-12 13:56:40 +02002#ifndef LINUX_MM_DEBUG_H
3#define LINUX_MM_DEBUG_H 1
4
James Morse1d5cda42015-12-18 14:22:07 -08005#include <linux/bug.h>
Dave Hansene4f67422014-06-04 16:07:02 -07006#include <linux/stringify.h>
7
Sasha Levin309381fea2014-01-23 15:52:54 -08008struct page;
Sasha Levin0bf55132014-10-09 15:28:06 -07009struct vm_area_struct;
Sasha Levin31c9afa2014-10-09 15:28:37 -070010struct mm_struct;
Sasha Levin309381fea2014-01-23 15:52:54 -080011
Kirill A. Shutemovd230dec2014-04-07 15:37:38 -070012extern void dump_page(struct page *page, const char *reason);
Vlastimil Babkaff8e8112016-03-15 14:56:24 -070013extern void __dump_page(struct page *page, const char *reason);
Sasha Levin0bf55132014-10-09 15:28:06 -070014void dump_vma(const struct vm_area_struct *vma);
Sasha Levin31c9afa2014-10-09 15:28:37 -070015void dump_mm(const struct mm_struct *mm);
Sasha Levin309381fea2014-01-23 15:52:54 -080016
Jiri Slaby59ea7462008-06-12 13:56:40 +020017#ifdef CONFIG_DEBUG_VM
18#define VM_BUG_ON(cond) BUG_ON(cond)
Dave Hansene4f67422014-06-04 16:07:02 -070019#define VM_BUG_ON_PAGE(cond, page) \
20 do { \
21 if (unlikely(cond)) { \
22 dump_page(page, "VM_BUG_ON_PAGE(" __stringify(cond)")");\
23 BUG(); \
24 } \
25 } while (0)
Sasha Levinfa3759cc2014-10-09 15:28:08 -070026#define VM_BUG_ON_VMA(cond, vma) \
27 do { \
28 if (unlikely(cond)) { \
29 dump_vma(vma); \
30 BUG(); \
31 } \
32 } while (0)
Sasha Levin31c9afa2014-10-09 15:28:37 -070033#define VM_BUG_ON_MM(cond, mm) \
34 do { \
35 if (unlikely(cond)) { \
36 dump_mm(mm); \
37 BUG(); \
38 } \
39 } while (0)
Alex Shia4055882020-12-18 14:01:31 -080040#define VM_WARN_ON_ONCE_PAGE(cond, page) ({ \
41 static bool __section(".data.once") __warned; \
42 int __ret_warn_once = !!(cond); \
43 \
44 if (unlikely(__ret_warn_once && !__warned)) { \
45 dump_page(page, "VM_WARN_ON_ONCE_PAGE(" __stringify(cond)")");\
46 __warned = true; \
47 WARN_ON(1); \
48 } \
49 unlikely(__ret_warn_once); \
50})
51
Michal Hocko91241682018-04-05 16:25:30 -070052#define VM_WARN_ON(cond) (void)WARN_ON(cond)
53#define VM_WARN_ON_ONCE(cond) (void)WARN_ON_ONCE(cond)
54#define VM_WARN_ONCE(cond, format...) (void)WARN_ONCE(cond, format)
55#define VM_WARN(cond, format...) (void)WARN(cond, format)
Jiri Slaby59ea7462008-06-12 13:56:40 +020056#else
Konstantin Khlebnikov02602a12012-05-29 15:06:28 -070057#define VM_BUG_ON(cond) BUILD_BUG_ON_INVALID(cond)
Sasha Levin309381fea2014-01-23 15:52:54 -080058#define VM_BUG_ON_PAGE(cond, page) VM_BUG_ON(cond)
Sasha Levinfa3759cc2014-10-09 15:28:08 -070059#define VM_BUG_ON_VMA(cond, vma) VM_BUG_ON(cond)
Sasha Levin31c9afa2014-10-09 15:28:37 -070060#define VM_BUG_ON_MM(cond, mm) VM_BUG_ON(cond)
Andrew Morton02a8efe2014-06-04 16:06:59 -070061#define VM_WARN_ON(cond) BUILD_BUG_ON_INVALID(cond)
62#define VM_WARN_ON_ONCE(cond) BUILD_BUG_ON_INVALID(cond)
Alex Shia4055882020-12-18 14:01:31 -080063#define VM_WARN_ON_ONCE_PAGE(cond, page) BUILD_BUG_ON_INVALID(cond)
Andrew Mortonef6b5712014-08-06 16:06:30 -070064#define VM_WARN_ONCE(cond, format...) BUILD_BUG_ON_INVALID(cond)
Aneesh Kumar K.Va54f9ae2016-07-26 15:22:36 -070065#define VM_WARN(cond, format...) BUILD_BUG_ON_INVALID(cond)
Jiri Slaby59ea7462008-06-12 13:56:40 +020066#endif
67
68#ifdef CONFIG_DEBUG_VIRTUAL
69#define VIRTUAL_BUG_ON(cond) BUG_ON(cond)
70#else
Ingo Molnar7aa413d2008-06-19 13:28:11 +020071#define VIRTUAL_BUG_ON(cond) do { } while (0)
Jiri Slaby59ea7462008-06-12 13:56:40 +020072#endif
73
Kirill A. Shutemov95ad9752016-01-15 16:51:21 -080074#ifdef CONFIG_DEBUG_VM_PGFLAGS
75#define VM_BUG_ON_PGFLAGS(cond, page) VM_BUG_ON_PAGE(cond, page)
76#else
77#define VM_BUG_ON_PGFLAGS(cond, page) BUILD_BUG_ON_INVALID(cond)
78#endif
79
Jiri Slaby59ea7462008-06-12 13:56:40 +020080#endif