|
|
|
@ -6,6 +6,7 @@
|
|
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
|
#include <memory>
|
|
|
|
|
#include <tuple>
|
|
|
|
|
#include <vector>
|
|
|
|
|
#include "common/common_types.h"
|
|
|
|
|
#include "core/hle/result.h"
|
|
|
|
@ -256,6 +257,16 @@ struct PageInfo {
|
|
|
|
|
* also backed by a single host memory allocation.
|
|
|
|
|
*/
|
|
|
|
|
struct VirtualMemoryArea {
|
|
|
|
|
/// Gets the starting (base) address of this VMA.
|
|
|
|
|
VAddr StartAddress() const {
|
|
|
|
|
return base;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Gets the ending address of this VMA.
|
|
|
|
|
VAddr EndAddress() const {
|
|
|
|
|
return base + size - 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Virtual base address of the region.
|
|
|
|
|
VAddr base = 0;
|
|
|
|
|
/// Size of the region.
|
|
|
|
@ -517,6 +528,35 @@ private:
|
|
|
|
|
/// Clears out the page table
|
|
|
|
|
void ClearPageTable();
|
|
|
|
|
|
|
|
|
|
using CheckResults = ResultVal<std::tuple<MemoryState, VMAPermission, MemoryAttribute>>;
|
|
|
|
|
|
|
|
|
|
/// Checks if an address range adheres to the specified states provided.
|
|
|
|
|
///
|
|
|
|
|
/// @param address The starting address of the address range.
|
|
|
|
|
/// @param size The size of the address range.
|
|
|
|
|
/// @param state_mask The memory state mask.
|
|
|
|
|
/// @param state The state to compare the individual VMA states against,
|
|
|
|
|
/// which is done in the form of: (vma.state & state_mask) != state.
|
|
|
|
|
/// @param permission_mask The memory permissions mask.
|
|
|
|
|
/// @param permissions The permission to compare the individual VMA permissions against,
|
|
|
|
|
/// which is done in the form of:
|
|
|
|
|
/// (vma.permission & permission_mask) != permission.
|
|
|
|
|
/// @param attribute_mask The memory attribute mask.
|
|
|
|
|
/// @param attribute The memory attributes to compare the individual VMA attributes
|
|
|
|
|
/// against, which is done in the form of:
|
|
|
|
|
/// (vma.attributes & attribute_mask) != attribute.
|
|
|
|
|
/// @param ignore_mask The memory attributes to ignore during the check.
|
|
|
|
|
///
|
|
|
|
|
/// @returns If successful, returns a tuple containing the memory attributes
|
|
|
|
|
/// (with ignored bits specified by ignore_mask unset), memory permissions, and
|
|
|
|
|
/// memory state across the memory range.
|
|
|
|
|
/// @returns If not successful, returns ERR_INVALID_ADDRESS_STATE.
|
|
|
|
|
///
|
|
|
|
|
CheckResults CheckRangeState(VAddr address, u64 size, MemoryState state_mask, MemoryState state,
|
|
|
|
|
VMAPermission permission_mask, VMAPermission permissions,
|
|
|
|
|
MemoryAttribute attribute_mask, MemoryAttribute attribute,
|
|
|
|
|
MemoryAttribute ignore_mask) const;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* A map covering the entirety of the managed address space, keyed by the `base` field of each
|
|
|
|
|
* VMA. It must always be modified by splitting or merging VMAs, so that the invariant
|
|
|
|
|