1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #ifndef _LINUX_SCHED_COREDUMP_H 3*4882a593Smuzhiyun #define _LINUX_SCHED_COREDUMP_H 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #include <linux/mm_types.h> 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #define SUID_DUMP_DISABLE 0 /* No setuid dumping */ 8*4882a593Smuzhiyun #define SUID_DUMP_USER 1 /* Dump as user of process */ 9*4882a593Smuzhiyun #define SUID_DUMP_ROOT 2 /* Dump as root */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun /* mm flags */ 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /* for SUID_DUMP_* above */ 14*4882a593Smuzhiyun #define MMF_DUMPABLE_BITS 2 15*4882a593Smuzhiyun #define MMF_DUMPABLE_MASK ((1 << MMF_DUMPABLE_BITS) - 1) 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun extern void set_dumpable(struct mm_struct *mm, int value); 18*4882a593Smuzhiyun /* 19*4882a593Smuzhiyun * This returns the actual value of the suid_dumpable flag. For things 20*4882a593Smuzhiyun * that are using this for checking for privilege transitions, it must 21*4882a593Smuzhiyun * test against SUID_DUMP_USER rather than treating it as a boolean 22*4882a593Smuzhiyun * value. 23*4882a593Smuzhiyun */ __get_dumpable(unsigned long mm_flags)24*4882a593Smuzhiyunstatic inline int __get_dumpable(unsigned long mm_flags) 25*4882a593Smuzhiyun { 26*4882a593Smuzhiyun return mm_flags & MMF_DUMPABLE_MASK; 27*4882a593Smuzhiyun } 28*4882a593Smuzhiyun get_dumpable(struct mm_struct * mm)29*4882a593Smuzhiyunstatic inline int get_dumpable(struct mm_struct *mm) 30*4882a593Smuzhiyun { 31*4882a593Smuzhiyun return __get_dumpable(mm->flags); 32*4882a593Smuzhiyun } 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun /* coredump filter bits */ 35*4882a593Smuzhiyun #define MMF_DUMP_ANON_PRIVATE 2 36*4882a593Smuzhiyun #define MMF_DUMP_ANON_SHARED 3 37*4882a593Smuzhiyun #define MMF_DUMP_MAPPED_PRIVATE 4 38*4882a593Smuzhiyun #define MMF_DUMP_MAPPED_SHARED 5 39*4882a593Smuzhiyun #define MMF_DUMP_ELF_HEADERS 6 40*4882a593Smuzhiyun #define MMF_DUMP_HUGETLB_PRIVATE 7 41*4882a593Smuzhiyun #define MMF_DUMP_HUGETLB_SHARED 8 42*4882a593Smuzhiyun #define MMF_DUMP_DAX_PRIVATE 9 43*4882a593Smuzhiyun #define MMF_DUMP_DAX_SHARED 10 44*4882a593Smuzhiyun 45*4882a593Smuzhiyun #define MMF_DUMP_FILTER_SHIFT MMF_DUMPABLE_BITS 46*4882a593Smuzhiyun #define MMF_DUMP_FILTER_BITS 9 47*4882a593Smuzhiyun #define MMF_DUMP_FILTER_MASK \ 48*4882a593Smuzhiyun (((1 << MMF_DUMP_FILTER_BITS) - 1) << MMF_DUMP_FILTER_SHIFT) 49*4882a593Smuzhiyun #define MMF_DUMP_FILTER_DEFAULT \ 50*4882a593Smuzhiyun ((1 << MMF_DUMP_ANON_PRIVATE) | (1 << MMF_DUMP_ANON_SHARED) |\ 51*4882a593Smuzhiyun (1 << MMF_DUMP_HUGETLB_PRIVATE) | MMF_DUMP_MASK_DEFAULT_ELF) 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun #ifdef CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS 54*4882a593Smuzhiyun # define MMF_DUMP_MASK_DEFAULT_ELF (1 << MMF_DUMP_ELF_HEADERS) 55*4882a593Smuzhiyun #else 56*4882a593Smuzhiyun # define MMF_DUMP_MASK_DEFAULT_ELF 0 57*4882a593Smuzhiyun #endif 58*4882a593Smuzhiyun /* leave room for more dump flags */ 59*4882a593Smuzhiyun #define MMF_VM_MERGEABLE 16 /* KSM may merge identical pages */ 60*4882a593Smuzhiyun #define MMF_VM_HUGEPAGE 17 /* set when VM_HUGEPAGE is set on vma */ 61*4882a593Smuzhiyun /* 62*4882a593Smuzhiyun * This one-shot flag is dropped due to necessity of changing exe once again 63*4882a593Smuzhiyun * on NFS restore 64*4882a593Smuzhiyun */ 65*4882a593Smuzhiyun //#define MMF_EXE_FILE_CHANGED 18 /* see prctl_set_mm_exe_file() */ 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun #define MMF_HAS_UPROBES 19 /* has uprobes */ 68*4882a593Smuzhiyun #define MMF_RECALC_UPROBES 20 /* MMF_HAS_UPROBES can be wrong */ 69*4882a593Smuzhiyun #define MMF_OOM_SKIP 21 /* mm is of no interest for the OOM killer */ 70*4882a593Smuzhiyun #define MMF_UNSTABLE 22 /* mm is unstable for copy_from_user */ 71*4882a593Smuzhiyun #define MMF_HUGE_ZERO_PAGE 23 /* mm has ever used the global huge zero page */ 72*4882a593Smuzhiyun #define MMF_DISABLE_THP 24 /* disable THP for all VMAs */ 73*4882a593Smuzhiyun #define MMF_OOM_VICTIM 25 /* mm is the oom victim */ 74*4882a593Smuzhiyun #define MMF_OOM_REAP_QUEUED 26 /* mm was queued for oom_reaper */ 75*4882a593Smuzhiyun #define MMF_MULTIPROCESS 27 /* mm is shared between processes */ 76*4882a593Smuzhiyun #define MMF_DISABLE_THP_MASK (1 << MMF_DISABLE_THP) 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun #define MMF_INIT_MASK (MMF_DUMPABLE_MASK | MMF_DUMP_FILTER_MASK |\ 79*4882a593Smuzhiyun MMF_DISABLE_THP_MASK) 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun #endif /* _LINUX_SCHED_COREDUMP_H */ 82