mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-24 17:30:31 -07:00 
			
		
		
		
	Implement a new physical memory manager and replace DeviceMemory (#856)
* Implement a new physical memory manager and replace DeviceMemory * Proper generic constraints * Fix debug build * Add memory tests * New CPU memory manager and general code cleanup * Remove host memory management from CPU project, use Ryujinx.Memory instead * Fix tests * Document exceptions on MemoryBlock * Fix leak on unix memory allocation * Proper disposal of some objects on tests * Fix JitCache not being set as initialized * GetRef without checks for 8-bits and 16-bits CAS * Add MemoryBlock destructor * Throw in separate method to improve codegen * Address PR feedback * QueryModified improvements * Fix memory write tracking not marking all pages as modified in some cases * Simplify MarkRegionAsModified * Remove XML doc for ghost param * Add back optimization to avoid useless buffer updates * Add Ryujinx.Cpu project, move MemoryManager there and remove MemoryBlockWrapper * Some nits * Do not perform address translation when size is 0 * Address PR feedback and format NativeInterface class * Remove ghost parameter description * Update Ryujinx.Cpu to .NET Core 3.1 * Address PR feedback * Fix build * Return a well defined value for GetPhysicalAddress with invalid VA, and do not return unmapped ranges as modified * Typo
This commit is contained in:
		| @@ -9,6 +9,7 @@ using System.Collections.Concurrent; | ||||
| using System.Threading; | ||||
|  | ||||
| using static ARMeilleure.IntermediateRepresentation.OperandHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.OperationHelper; | ||||
|  | ||||
| namespace ARMeilleure.Translation | ||||
| { | ||||
| @@ -18,30 +19,31 @@ namespace ARMeilleure.Translation | ||||
|  | ||||
|         private const bool AlwaysTranslateFunctions = true; // If false, only translates a single block for lowCq. | ||||
|  | ||||
|         private MemoryManager _memory; | ||||
|         private readonly IMemoryManager _memory; | ||||
|  | ||||
|         private ConcurrentDictionary<ulong, TranslatedFunction> _funcs; | ||||
|         private readonly ConcurrentDictionary<ulong, TranslatedFunction> _funcs; | ||||
|  | ||||
|         private JumpTable _jumpTable; | ||||
|         private readonly JumpTable _jumpTable; | ||||
|  | ||||
|         private PriorityQueue<RejitRequest> _backgroundQueue; | ||||
|         private readonly PriorityQueue<RejitRequest> _backgroundQueue; | ||||
|  | ||||
|         private AutoResetEvent _backgroundTranslatorEvent; | ||||
|         private readonly AutoResetEvent _backgroundTranslatorEvent; | ||||
|  | ||||
|         private volatile int _threadCount; | ||||
|  | ||||
|         public Translator(MemoryManager memory) | ||||
|         public Translator(IJitMemoryAllocator allocator, IMemoryManager memory) | ||||
|         { | ||||
|             _memory = memory; | ||||
|  | ||||
|             _funcs = new ConcurrentDictionary<ulong, TranslatedFunction>(); | ||||
|  | ||||
|             _jumpTable = JumpTable.Instance; | ||||
|             _jumpTable = new JumpTable(allocator); | ||||
|  | ||||
|             _backgroundQueue = new PriorityQueue<RejitRequest>(2); | ||||
|  | ||||
|             _backgroundTranslatorEvent = new AutoResetEvent(false); | ||||
|  | ||||
|             JitCache.Initialize(allocator); | ||||
|             DirectCallStubs.InitializeStubs(); | ||||
|         } | ||||
|  | ||||
| @@ -146,8 +148,8 @@ namespace ARMeilleure.Translation | ||||
|         { | ||||
|             ArmEmitterContext context = new ArmEmitterContext(_memory, _jumpTable, (long)address, highCq, Aarch32Mode.User); | ||||
|  | ||||
|             OperandHelper.PrepareOperandPool(highCq); | ||||
|             OperationHelper.PrepareOperationPool(highCq); | ||||
|             PrepareOperandPool(highCq); | ||||
|             PrepareOperationPool(highCq); | ||||
|  | ||||
|             Logger.StartPass(PassName.Decoding); | ||||
|  | ||||
| @@ -178,14 +180,12 @@ namespace ARMeilleure.Translation | ||||
|  | ||||
|             OperandType[] argTypes = new OperandType[] { OperandType.I64 }; | ||||
|  | ||||
|             CompilerOptions options = highCq | ||||
|                 ? CompilerOptions.HighCq | ||||
|                 : CompilerOptions.None; | ||||
|             CompilerOptions options = highCq ? CompilerOptions.HighCq : CompilerOptions.None; | ||||
|  | ||||
|             GuestFunction func = Compiler.Compile<GuestFunction>(cfg, argTypes, OperandType.I64, options); | ||||
|  | ||||
|             OperandHelper.ResetOperandPool(highCq); | ||||
|             OperationHelper.ResetOperationPool(highCq); | ||||
|             ResetOperandPool(highCq); | ||||
|             ResetOperationPool(highCq); | ||||
|  | ||||
|             return new TranslatedFunction(func, rejit: !highCq); | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user