mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2026-05-05 09:57:21 +02:00
bd44d91d0c
Convert the test code to utilise vma_flags_t as opposed to the deprecate vm_flags_t as much as possible. As part of this change, add VMA_STICKY_FLAGS and VMA_SPECIAL_FLAGS as early versions of what these defines will look like in the kernel logic once this logic is implemented. Link: https://lkml.kernel.org/r/df90efe29300bd899989f695be4ae3adc901a828.1774034900.git.ljs@kernel.org Signed-off-by: Lorenzo Stoakes (Oracle) <ljs@kernel.org> Cc: Albert Ou <aou@eecs.berkeley.edu> Cc: Alexander Gordeev <agordeev@linux.ibm.com> Cc: Alexandre Ghiti <alex@ghiti.fr> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Anton Ivanov <anton.ivanov@cambridgegreys.com> Cc: "Borislav Petkov (AMD)" <bp@alien8.de> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Chengming Zhou <chengming.zhou@linux.dev> Cc: Christian Borntraeger <borntraeger@linux.ibm.com> Cc: Christian Brauner <brauner@kernel.org> Cc: David Hildenbrand <david@kernel.org> Cc: Dinh Nguyen <dinguyen@kernel.org> Cc: Heiko Carstens <hca@linux.ibm.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Huacai Chen <chenhuacai@kernel.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jan Kara <jack@suse.cz> Cc: Jann Horn <jannh@google.com> Cc: Johannes Berg <johannes@sipsolutions.net> Cc: Kees Cook <kees@kernel.org> Cc: Liam Howlett <liam.howlett@oracle.com> Cc: Madhavan Srinivasan <maddy@linux.ibm.com> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Michal Hocko <mhocko@suse.com> Cc: Mike Rapoport <rppt@kernel.org> Cc: Nicholas Piggin <npiggin@gmail.com> Cc: Ondrej Mosnacek <omosnace@redhat.com> Cc: Palmer Dabbelt <palmer@dabbelt.com> Cc: Paul Moore <paul@paul-moore.com> Cc: Pedro Falcato <pfalcato@suse.de> Cc: Richard Weinberger <richard@nod.at> Cc: Russell King <linux@armlinux.org.uk> Cc: Stephen Smalley <stephen.smalley.work@gmail.com> Cc: Suren Baghdasaryan <surenb@google.com> Cc: Sven Schnelle <svens@linux.ibm.com> Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de> Cc: Vasily Gorbik <gor@linux.ibm.com> Cc: Vineet Gupta <vgupta@kernel.org> Cc: Vlastimil Babka (SUSE) <vbabka@kernel.org> Cc: WANG Xuerui <kernel@xen0n.name> Cc: Will Deacon <will@kernel.org> Cc: xu xin <xu.xin16@zte.com.cn> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
133 lines
3.9 KiB
C
133 lines
3.9 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#pragma once
|
|
|
|
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
#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 ASSERT_FLAGS_SAME_MASK(_flags, _flags_other) \
|
|
ASSERT_TRUE(vma_flags_same_mask((_flags), (_flags_other)))
|
|
|
|
#define ASSERT_FLAGS_NOT_SAME_MASK(_flags, _flags_other) \
|
|
ASSERT_FALSE(vma_flags_same_mask((_flags), (_flags_other)))
|
|
|
|
#define ASSERT_FLAGS_SAME(_flags, ...) \
|
|
ASSERT_TRUE(vma_flags_same(_flags, __VA_ARGS__))
|
|
|
|
#define ASSERT_FLAGS_NOT_SAME(_flags, ...) \
|
|
ASSERT_FALSE(vma_flags_same(_flags, __VA_ARGS__))
|
|
|
|
#define ASSERT_FLAGS_EMPTY(_flags) \
|
|
ASSERT_TRUE(vma_flags_empty(_flags))
|
|
|
|
#define ASSERT_FLAGS_NONEMPTY(_flags) \
|
|
ASSERT_FALSE(vma_flags_empty(_flags))
|
|
|
|
#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, vma_flags_t vma_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, vma_flags_t vma_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);
|