/* SPDX-License-Identifier: GPL-2.0+ */ #pragma once /* * Contains declarations that exist in the kernel which have been CUSTOMISED for * testing purposes to faciliate userland VMA testing. */ #ifdef CONFIG_MMU extern unsigned long mmap_min_addr; extern unsigned long dac_mmap_min_addr; #else #define mmap_min_addr 0UL #define dac_mmap_min_addr 0UL #endif #define TASK_SIZE ((1ul << 47)-PAGE_SIZE) /* * The shared stubs do not implement this, it amounts to an fprintf(STDERR,...) * either way :) */ #define pr_warn_once pr_err struct anon_vma { struct anon_vma *root; struct rb_root_cached rb_root; /* Test fields. */ bool was_cloned; bool was_unlinked; }; static inline void unlink_anon_vmas(struct vm_area_struct *vma) { /* For testing purposes, indicate that the anon_vma was unlinked. */ vma->anon_vma->was_unlinked = true; } static inline void vma_start_write(struct vm_area_struct *vma) { /* Used to indicate to tests that a write operation has begun. */ vma->vm_lock_seq++; } static inline __must_check int vma_start_write_killable(struct vm_area_struct *vma) { /* Used to indicate to tests that a write operation has begun. */ vma->vm_lock_seq++; return 0; } static inline int anon_vma_clone(struct vm_area_struct *dst, struct vm_area_struct *src, enum vma_operation operation) { /* For testing purposes. We indicate that an anon_vma has been cloned. */ if (src->anon_vma != NULL) { dst->anon_vma = src->anon_vma; dst->anon_vma->was_cloned = true; } return 0; } static inline int __anon_vma_prepare(struct vm_area_struct *vma) { struct anon_vma *anon_vma = calloc(1, sizeof(struct anon_vma)); if (!anon_vma) return -ENOMEM; anon_vma->root = anon_vma; vma->anon_vma = anon_vma; return 0; } static inline int anon_vma_prepare(struct vm_area_struct *vma) { if (likely(vma->anon_vma)) return 0; return __anon_vma_prepare(vma); } static inline void vma_lock_init(struct vm_area_struct *vma, bool reset_refcnt) { if (reset_refcnt) refcount_set(&vma->vm_refcnt, 0); } static inline unsigned long vma_kernel_pagesize(struct vm_area_struct *vma) { return PAGE_SIZE; }