/* * QEMU page protection declarations. * * Copyright (c) 2003 Fabrice Bellard * * SPDX-License-Identifier: LGPL-2.1+ */ #ifndef USER_PAGE_PROTECTION_H #define USER_PAGE_PROTECTION_H #ifndef CONFIG_USER_ONLY #error Cannot include this header from system emulation #endif #include "exec/vaddr.h" #include "exec/translation-block.h" int page_unprotect(CPUState *cpu, tb_page_addr_t address, uintptr_t pc); int page_get_flags(vaddr address); /** * page_set_flags: * @start: first byte of range * @last: last byte of range * @flags: flags to set * Context: holding mmap lock * * Modify the flags of a page and invalidate the code if necessary. * The flag PAGE_WRITE_ORG is positioned automatically depending * on PAGE_WRITE. The mmap_lock should already be held. */ void page_set_flags(vaddr start, vaddr last, int flags); void page_reset_target_data(vaddr start, vaddr last); /** * page_check_range * @start: first byte of range * @len: length of range * @flags: flags required for each page * * Return true if every page in [@start, @start+@len) has @flags set. * Return false if any page is unmapped. Thus testing flags == 0 is * equivalent to testing for flags == PAGE_VALID. */ bool page_check_range(vaddr start, vaddr last, int flags); /** * page_check_range_empty: * @start: first byte of range * @last: last byte of range * Context: holding mmap lock * * Return true if the entire range [@start, @last] is unmapped. * The memory lock must be held so that the caller will can ensure * the result stays true until a new mapping can be installed. */ bool page_check_range_empty(vaddr start, vaddr last); /** * page_find_range_empty * @min: first byte of search range * @max: last byte of search range * @len: size of the hole required * @align: alignment of the hole required (power of 2) * * If there is a range [x, x+@len) within [@min, @max] such that * x % @align == 0, then return x. Otherwise return -1. * The memory lock must be held, as the caller will want to ensure * the returned range stays empty until a new mapping can be installed. */ vaddr page_find_range_empty(vaddr min, vaddr max, vaddr len, vaddr align); /** * page_get_target_data * @address: guest virtual address * @size: per-page size * * Return @size bytes of out-of-band data to associate * with the guest page at @address, allocating it if necessary. The * caller should already have verified that the address is valid. * The value of @size must be the same for every call. * * The memory will be freed when the guest page is deallocated, * e.g. with the munmap system call. */ __attribute__((returns_nonnull)) void *page_get_target_data(vaddr address, size_t size); typedef int (*walk_memory_regions_fn)(void *, vaddr, vaddr, int); int walk_memory_regions(void *, walk_memory_regions_fn); void page_dump(FILE *f); #endif