aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/linux/huge_mm.h1
-rw-r--r--include/linux/khugepaged.h66
-rw-r--r--include/linux/sched.h1
3 files changed, 68 insertions, 0 deletions
diff --git a/include/linux/huge_mm.h b/include/linux/huge_mm.h
index d9ab70d776e..43a694ef890 100644
--- a/include/linux/huge_mm.h
+++ b/include/linux/huge_mm.h
@@ -25,6 +25,7 @@ enum transparent_hugepage_flag {
25 TRANSPARENT_HUGEPAGE_REQ_MADV_FLAG, 25 TRANSPARENT_HUGEPAGE_REQ_MADV_FLAG,
26 TRANSPARENT_HUGEPAGE_DEFRAG_FLAG, 26 TRANSPARENT_HUGEPAGE_DEFRAG_FLAG,
27 TRANSPARENT_HUGEPAGE_DEFRAG_REQ_MADV_FLAG, 27 TRANSPARENT_HUGEPAGE_DEFRAG_REQ_MADV_FLAG,
28 TRANSPARENT_HUGEPAGE_DEFRAG_KHUGEPAGED_FLAG,
28#ifdef CONFIG_DEBUG_VM 29#ifdef CONFIG_DEBUG_VM
29 TRANSPARENT_HUGEPAGE_DEBUG_COW_FLAG, 30 TRANSPARENT_HUGEPAGE_DEBUG_COW_FLAG,
30#endif 31#endif
diff --git a/include/linux/khugepaged.h b/include/linux/khugepaged.h
new file mode 100644
index 00000000000..552f3184756
--- /dev/null
+++ b/include/linux/khugepaged.h
@@ -0,0 +1,66 @@
1#ifndef _LINUX_KHUGEPAGED_H
2#define _LINUX_KHUGEPAGED_H
3
4#include <linux/sched.h> /* MMF_VM_HUGEPAGE */
5
6#ifdef CONFIG_TRANSPARENT_HUGEPAGE
7extern int __khugepaged_enter(struct mm_struct *mm);
8extern void __khugepaged_exit(struct mm_struct *mm);
9extern int khugepaged_enter_vma_merge(struct vm_area_struct *vma);
10
11#define khugepaged_enabled() \
12 (transparent_hugepage_flags & \
13 ((1<<TRANSPARENT_HUGEPAGE_FLAG) | \
14 (1<<TRANSPARENT_HUGEPAGE_REQ_MADV_FLAG)))
15#define khugepaged_always() \
16 (transparent_hugepage_flags & \
17 (1<<TRANSPARENT_HUGEPAGE_FLAG))
18#define khugepaged_req_madv() \
19 (transparent_hugepage_flags & \
20 (1<<TRANSPARENT_HUGEPAGE_REQ_MADV_FLAG))
21#define khugepaged_defrag() \
22 (transparent_hugepage_flags & \
23 (1<<TRANSPARENT_HUGEPAGE_DEFRAG_KHUGEPAGED_FLAG))
24
25static inline int khugepaged_fork(struct mm_struct *mm, struct mm_struct *oldmm)
26{
27 if (test_bit(MMF_VM_HUGEPAGE, &oldmm->flags))
28 return __khugepaged_enter(mm);
29 return 0;
30}
31
32static inline void khugepaged_exit(struct mm_struct *mm)
33{
34 if (test_bit(MMF_VM_HUGEPAGE, &mm->flags))
35 __khugepaged_exit(mm);
36}
37
38static inline int khugepaged_enter(struct vm_area_struct *vma)
39{
40 if (!test_bit(MMF_VM_HUGEPAGE, &vma->vm_mm->flags))
41 if (khugepaged_always() ||
42 (khugepaged_req_madv() &&
43 vma->vm_flags & VM_HUGEPAGE))
44 if (__khugepaged_enter(vma->vm_mm))
45 return -ENOMEM;
46 return 0;
47}
48#else /* CONFIG_TRANSPARENT_HUGEPAGE */
49static inline int khugepaged_fork(struct mm_struct *mm, struct mm_struct *oldmm)
50{
51 return 0;
52}
53static inline void khugepaged_exit(struct mm_struct *mm)
54{
55}
56static inline int khugepaged_enter(struct vm_area_struct *vma)
57{
58 return 0;
59}
60static inline int khugepaged_enter_vma_merge(struct vm_area_struct *vma)
61{
62 return 0;
63}
64#endif /* CONFIG_TRANSPARENT_HUGEPAGE */
65
66#endif /* _LINUX_KHUGEPAGED_H */
diff --git a/include/linux/sched.h b/include/linux/sched.h
index f23b5bb6f52..d747f948b34 100644
--- a/include/linux/sched.h
+++ b/include/linux/sched.h
@@ -434,6 +434,7 @@ extern int get_dumpable(struct mm_struct *mm);
434#endif 434#endif
435 /* leave room for more dump flags */ 435 /* leave room for more dump flags */
436#define MMF_VM_MERGEABLE 16 /* KSM may merge identical pages */ 436#define MMF_VM_MERGEABLE 16 /* KSM may merge identical pages */
437#define MMF_VM_HUGEPAGE 17 /* set when VM_HUGEPAGE is set on vma */
437 438
438#define MMF_INIT_MASK (MMF_DUMPABLE_MASK | MMF_DUMP_FILTER_MASK) 439#define MMF_INIT_MASK (MMF_DUMPABLE_MASK | MMF_DUMP_FILTER_MASK)
439 440