mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-12 16:47:06 +07:00
95ad97554a
This patch adds a third argument to macros which create function definitions for page flags. This argument defines how page-flags helpers behave on compound functions. For now we define four policies: - PF_ANY: the helper function operates on the page it gets, regardless if it's non-compound, head or tail. - PF_HEAD: the helper function operates on the head page of the compound page if it gets tail page. - PF_NO_TAIL: only head and non-compond pages are acceptable for this helper function. - PF_NO_COMPOUND: only non-compound pages are acceptable for this helper function. For now we use policy PF_ANY for all helpers, which matches current behaviour. We do not enforce the policy for TESTPAGEFLAG, because we have flags checked for random pages all over the kernel. Noticeable exception to this is PageTransHuge() which triggers VM_BUG_ON() for tail page. Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Hugh Dickins <hughd@google.com> Cc: Dave Hansen <dave.hansen@intel.com> Cc: Mel Gorman <mgorman@suse.de> Cc: Rik van Riel <riel@redhat.com> Cc: Vlastimil Babka <vbabka@suse.cz> Cc: Christoph Lameter <cl@linux.com> Cc: Naoya Horiguchi <n-horiguchi@ah.jp.nec.com> Cc: Steve Capper <steve.capper@linaro.org> Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com> Cc: Johannes Weiner <hannes@cmpxchg.org> Cc: Michal Hocko <mhocko@suse.cz> Cc: Jerome Marchand <jmarchan@redhat.com> Cc: Jérôme Glisse <jglisse@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
66 lines
1.8 KiB
C
66 lines
1.8 KiB
C
#ifndef LINUX_MM_DEBUG_H
|
|
#define LINUX_MM_DEBUG_H 1
|
|
|
|
#include <linux/bug.h>
|
|
#include <linux/stringify.h>
|
|
|
|
struct page;
|
|
struct vm_area_struct;
|
|
struct mm_struct;
|
|
|
|
extern void dump_page(struct page *page, const char *reason);
|
|
extern void dump_page_badflags(struct page *page, const char *reason,
|
|
unsigned long badflags);
|
|
void dump_vma(const struct vm_area_struct *vma);
|
|
void dump_mm(const struct mm_struct *mm);
|
|
|
|
#ifdef CONFIG_DEBUG_VM
|
|
#define VM_BUG_ON(cond) BUG_ON(cond)
|
|
#define VM_BUG_ON_PAGE(cond, page) \
|
|
do { \
|
|
if (unlikely(cond)) { \
|
|
dump_page(page, "VM_BUG_ON_PAGE(" __stringify(cond)")");\
|
|
BUG(); \
|
|
} \
|
|
} while (0)
|
|
#define VM_BUG_ON_VMA(cond, vma) \
|
|
do { \
|
|
if (unlikely(cond)) { \
|
|
dump_vma(vma); \
|
|
BUG(); \
|
|
} \
|
|
} while (0)
|
|
#define VM_BUG_ON_MM(cond, mm) \
|
|
do { \
|
|
if (unlikely(cond)) { \
|
|
dump_mm(mm); \
|
|
BUG(); \
|
|
} \
|
|
} while (0)
|
|
#define VM_WARN_ON(cond) WARN_ON(cond)
|
|
#define VM_WARN_ON_ONCE(cond) WARN_ON_ONCE(cond)
|
|
#define VM_WARN_ONCE(cond, format...) WARN_ONCE(cond, format)
|
|
#else
|
|
#define VM_BUG_ON(cond) BUILD_BUG_ON_INVALID(cond)
|
|
#define VM_BUG_ON_PAGE(cond, page) VM_BUG_ON(cond)
|
|
#define VM_BUG_ON_VMA(cond, vma) VM_BUG_ON(cond)
|
|
#define VM_BUG_ON_MM(cond, mm) VM_BUG_ON(cond)
|
|
#define VM_WARN_ON(cond) BUILD_BUG_ON_INVALID(cond)
|
|
#define VM_WARN_ON_ONCE(cond) BUILD_BUG_ON_INVALID(cond)
|
|
#define VM_WARN_ONCE(cond, format...) BUILD_BUG_ON_INVALID(cond)
|
|
#endif
|
|
|
|
#ifdef CONFIG_DEBUG_VIRTUAL
|
|
#define VIRTUAL_BUG_ON(cond) BUG_ON(cond)
|
|
#else
|
|
#define VIRTUAL_BUG_ON(cond) do { } while (0)
|
|
#endif
|
|
|
|
#ifdef CONFIG_DEBUG_VM_PGFLAGS
|
|
#define VM_BUG_ON_PGFLAGS(cond, page) VM_BUG_ON_PAGE(cond, page)
|
|
#else
|
|
#define VM_BUG_ON_PGFLAGS(cond, page) BUILD_BUG_ON_INVALID(cond)
|
|
#endif
|
|
|
|
#endif
|