blob: 877ef226f90fb3b945831c7e8f9edbabba1e9775 [file] [log] [blame]
Jiri Slaby59ea7462008-06-12 13:56:40 +02001#ifndef LINUX_MM_DEBUG_H
2#define LINUX_MM_DEBUG_H 1
3
Dave Hansene4f67422014-06-04 16:07:02 -07004#include <linux/stringify.h>
5
Sasha Levin309381fea2014-01-23 15:52:54 -08006struct page;
Sasha Levin0bf55132014-10-09 15:28:06 -07007struct vm_area_struct;
Sasha Levin31c9afa2014-10-09 15:28:37 -07008struct mm_struct;
Sasha Levin309381fea2014-01-23 15:52:54 -08009
Kirill A. Shutemovd230dec2014-04-07 15:37:38 -070010extern void dump_page(struct page *page, const char *reason);
11extern void dump_page_badflags(struct page *page, const char *reason,
Sasha Levin309381fea2014-01-23 15:52:54 -080012 unsigned long badflags);
Sasha Levin0bf55132014-10-09 15:28:06 -070013void dump_vma(const struct vm_area_struct *vma);
Sasha Levin31c9afa2014-10-09 15:28:37 -070014void dump_mm(const struct mm_struct *mm);
Sasha Levin309381fea2014-01-23 15:52:54 -080015
Jiri Slaby59ea7462008-06-12 13:56:40 +020016#ifdef CONFIG_DEBUG_VM
17#define VM_BUG_ON(cond) BUG_ON(cond)
Dave Hansene4f67422014-06-04 16:07:02 -070018#define VM_BUG_ON_PAGE(cond, page) \
19 do { \
20 if (unlikely(cond)) { \
21 dump_page(page, "VM_BUG_ON_PAGE(" __stringify(cond)")");\
22 BUG(); \
23 } \
24 } while (0)
Sasha Levinfa3759c2014-10-09 15:28:08 -070025#define VM_BUG_ON_VMA(cond, vma) \
26 do { \
27 if (unlikely(cond)) { \
28 dump_vma(vma); \
29 BUG(); \
30 } \
31 } while (0)
Sasha Levin31c9afa2014-10-09 15:28:37 -070032#define VM_BUG_ON_MM(cond, mm) \
33 do { \
34 if (unlikely(cond)) { \
35 dump_mm(mm); \
36 BUG(); \
37 } \
38 } while (0)
Andrew Morton02a8efe2014-06-04 16:06:59 -070039#define VM_WARN_ON(cond) WARN_ON(cond)
40#define VM_WARN_ON_ONCE(cond) WARN_ON_ONCE(cond)
Andrew Mortonef6b5712014-08-06 16:06:30 -070041#define VM_WARN_ONCE(cond, format...) WARN_ONCE(cond, format)
Jiri Slaby59ea7462008-06-12 13:56:40 +020042#else
Konstantin Khlebnikov02602a12012-05-29 15:06:28 -070043#define VM_BUG_ON(cond) BUILD_BUG_ON_INVALID(cond)
Sasha Levin309381fea2014-01-23 15:52:54 -080044#define VM_BUG_ON_PAGE(cond, page) VM_BUG_ON(cond)
Sasha Levinfa3759c2014-10-09 15:28:08 -070045#define VM_BUG_ON_VMA(cond, vma) VM_BUG_ON(cond)
Sasha Levin31c9afa2014-10-09 15:28:37 -070046#define VM_BUG_ON_MM(cond, mm) VM_BUG_ON(cond)
Andrew Morton02a8efe2014-06-04 16:06:59 -070047#define VM_WARN_ON(cond) BUILD_BUG_ON_INVALID(cond)
48#define VM_WARN_ON_ONCE(cond) BUILD_BUG_ON_INVALID(cond)
Andrew Mortonef6b5712014-08-06 16:06:30 -070049#define VM_WARN_ONCE(cond, format...) BUILD_BUG_ON_INVALID(cond)
Jiri Slaby59ea7462008-06-12 13:56:40 +020050#endif
51
52#ifdef CONFIG_DEBUG_VIRTUAL
53#define VIRTUAL_BUG_ON(cond) BUG_ON(cond)
54#else
Ingo Molnar7aa413d2008-06-19 13:28:11 +020055#define VIRTUAL_BUG_ON(cond) do { } while (0)
Jiri Slaby59ea7462008-06-12 13:56:40 +020056#endif
57
58#endif