using Ryujinx.Memory.Range;
using System;
using System.Collections.Generic;
namespace Ryujinx.Memory.Tests
{
public class MockVirtualMemoryManager : IVirtualMemoryManager
public bool Supports4KBPages => true;
public bool NoMappings = false;
public event Action<ulong, ulong, MemoryPermission> OnProtect;
public MockVirtualMemoryManager(ulong size, int pageSize)
}
public void Map(ulong va, ulong pa, ulong size, MemoryMapFlags flags)
throw new NotImplementedException();
public void MapForeign(ulong va, nuint hostAddress, ulong size)
public void Unmap(ulong va, ulong size)
public T Read<T>(ulong va) where T : unmanaged
public void Read(ulong va, Span<byte> data)
public void Write<T>(ulong va, T value) where T : unmanaged
public void Write(ulong va, ReadOnlySpan<byte> data)
public bool WriteWithRedundancyCheck(ulong va, ReadOnlySpan<byte> data)
public ReadOnlySpan<byte> GetSpan(ulong va, int size, bool tracked = false)
public WritableRegion GetWritableRegion(ulong va, int size, bool tracked = false)
public ref T GetRef<T>(ulong va) where T : unmanaged
IEnumerable<HostMemoryRange> IVirtualMemoryManager.GetHostRegions(ulong va, ulong size)
IEnumerable<MemoryRange> IVirtualMemoryManager.GetPhysicalRegions(ulong va, ulong size)
return NoMappings ? new MemoryRange[0] : new MemoryRange[] { new MemoryRange(va, size) };
public bool IsMapped(ulong va)
return true;
public bool IsRangeMapped(ulong va, ulong size)
public ulong GetPhysicalAddress(ulong va)
public void SignalMemoryTracking(ulong va, ulong size, bool write, bool precise = false)
public void TrackingReprotect(ulong va, ulong size, MemoryPermission protection)
OnProtect?.Invoke(va, size, protection);