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:
		
							parent
							
								
									1758424208
								
							
						
					
					
						commit
						f77694e4f7
					
				
					 126 changed files with 2176 additions and 2092 deletions
				
			
		|  | @ -37,7 +37,7 @@ namespace Ryujinx.HLE.HOS.Services.Bcat.ServiceCreator | |||
| 
 | ||||
|             Result result = _base.Read(out int entriesRead, MemoryMarshal.Cast<byte, DeliveryCacheDirectoryEntry>(data)); | ||||
| 
 | ||||
|             context.Memory.WriteBytes(position, data); | ||||
|             context.Memory.Write((ulong)position, data); | ||||
| 
 | ||||
|             context.ResponseData.Write(entriesRead); | ||||
| 
 | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ namespace Ryujinx.HLE.HOS.Services.Bcat.ServiceCreator | |||
| 
 | ||||
|             Result result = _base.Read(out long bytesRead, offset, data); | ||||
| 
 | ||||
|             context.Memory.WriteBytes(position, data); | ||||
|             context.Memory.Write((ulong)position, data); | ||||
| 
 | ||||
|             context.ResponseData.Write(bytesRead); | ||||
| 
 | ||||
|  |  | |||
|  | @ -57,7 +57,7 @@ namespace Ryujinx.HLE.HOS.Services.Bcat.ServiceCreator | |||
|             using (BinaryWriter bufferWriter = new BinaryWriter(memory)) | ||||
|             { | ||||
|                 bufferWriter.WriteStruct(deliveryCacheProgress); | ||||
|                 context.Memory.WriteBytes(ipcDesc.Position, memory.ToArray()); | ||||
|                 context.Memory.Write((ulong)ipcDesc.Position, memory.ToArray()); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -53,7 +53,7 @@ namespace Ryujinx.HLE.HOS.Services.Bcat.ServiceCreator | |||
| 
 | ||||
|             Result result = _base.EnumerateDeliveryCacheDirectory(out int count, MemoryMarshal.Cast<byte, DirectoryName>(data)); | ||||
| 
 | ||||
|             context.Memory.WriteBytes(position, data); | ||||
|             context.Memory.Write((ulong)position, data); | ||||
| 
 | ||||
|             context.ResponseData.Write(count); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 gdkchan
						gdkchan