// SPDX-License-Identifier: GPL-2.0-or-later #pragma once #include #include #include #include "generated/bit-length.h" #include "maple-shared.h" #include "vma_internal.h" #include "../../../mm/vma.h" /* Simple test runner. Assumes local num_[fail, tests] counters. */ #define TEST(name) \ do { \ (*num_tests)++; \ if (!test_##name()) { \ (*num_fail)++; \ fprintf(stderr, "Test " #name " FAILED\n"); \ } \ } while (0) #define ASSERT_TRUE(_expr) \ do { \ if (!(_expr)) { \ fprintf(stderr, \ "Assert FAILED at %s:%d:%s(): %s is FALSE.\n", \ __FILE__, __LINE__, __FUNCTION__, #_expr); \ return false; \ } \ } while (0) #define ASSERT_FALSE(_expr) ASSERT_TRUE(!(_expr)) #define ASSERT_EQ(_val1, _val2) ASSERT_TRUE((_val1) == (_val2)) #define ASSERT_NE(_val1, _val2) ASSERT_TRUE((_val1) != (_val2)) #define IS_SET(_val, _flags) ((_val & _flags) == _flags) extern bool fail_prealloc; /* Override vma_iter_prealloc() so we can choose to fail it. */ #define vma_iter_prealloc(vmi, vma) \ (fail_prealloc ? -ENOMEM : mas_preallocate(&(vmi)->mas, (vma), GFP_KERNEL)) #define CONFIG_DEFAULT_MMAP_MIN_ADDR 65536 extern unsigned long mmap_min_addr; extern unsigned long dac_mmap_min_addr; extern unsigned long stack_guard_gap; extern const struct vm_operations_struct vma_dummy_vm_ops; extern struct anon_vma dummy_anon_vma; extern struct task_struct __current; /* * Helper function which provides a wrapper around a merge existing VMA * operation. * * Declared in main.c as uses static VMA function. */ struct vm_area_struct *merge_existing(struct vma_merge_struct *vmg); /* * Helper function to allocate a VMA and link it to the tree. * * Declared in main.c as uses static VMA function. */ int attach_vma(struct mm_struct *mm, struct vm_area_struct *vma); /* Helper function providing a dummy vm_ops->close() method.*/ static inline void dummy_close(struct vm_area_struct *) { } /* Helper function to simply allocate a VMA. */ struct vm_area_struct *alloc_vma(struct mm_struct *mm, unsigned long start, unsigned long end, pgoff_t pgoff, vm_flags_t vm_flags); /* Helper function to detach and free a VMA. */ void detach_free_vma(struct vm_area_struct *vma); /* Helper function to allocate a VMA and link it to the tree. */ struct vm_area_struct *alloc_and_link_vma(struct mm_struct *mm, unsigned long start, unsigned long end, pgoff_t pgoff, vm_flags_t vm_flags); /* * Helper function to reset the dummy anon_vma to indicate it has not been * duplicated. */ void reset_dummy_anon_vma(void); /* * Helper function to remove all VMAs and destroy the maple tree associated with * a virtual address space. Returns a count of VMAs in the tree. */ int cleanup_mm(struct mm_struct *mm, struct vma_iterator *vmi); /* Helper function to determine if VMA has had vma_start_write() performed. */ bool vma_write_started(struct vm_area_struct *vma); void __vma_set_dummy_anon_vma(struct vm_area_struct *vma, struct anon_vma_chain *avc, struct anon_vma *anon_vma); /* Provide a simple dummy VMA/anon_vma dummy setup for testing. */ void vma_set_dummy_anon_vma(struct vm_area_struct *vma, struct anon_vma_chain *avc); /* Helper function to specify a VMA's range. */ void vma_set_range(struct vm_area_struct *vma, unsigned long start, unsigned long end, pgoff_t pgoff);