IPC refactor part 3+4: New server HIPC message processor (#4188)
* IPC refactor part 3 + 4: New server HIPC message processor with source generator based serialization * Make types match on calls to AlignUp/AlignDown * Formatting * Address some PR feedback * Move BitfieldExtensions to Ryujinx.Common.Utilities and consolidate implementations * Rename Reader/Writer to SpanReader/SpanWriter and move to Ryujinx.Common.Memory * Implement EventType * Address more PR feedback * Log request processing errors since they are not normal * Rename waitable to multiwait and add missing lock * PR feedback * Ac_K PR feedback
This commit is contained in:
		
							parent
							
								
									c6a139a6e7
								
							
						
					
					
						commit
						08831eecf7
					
				
					 213 changed files with 9762 additions and 1010 deletions
				
			
		|  | @ -2,8 +2,8 @@ | |||
| using Ryujinx.HLE.HOS.Applets; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Threading; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| 
 | ||||
| namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.LibraryAppletCreator | ||||
|  | @ -68,7 +68,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Lib | |||
|         { | ||||
|             if (_stateChangedEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_stateChangedEvent.ReadableEvent, out _stateChangedEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_stateChangedEvent.ReadableEvent, out _stateChangedEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -178,7 +178,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Lib | |||
|         { | ||||
|             if (_normalOutDataEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_normalOutDataEvent.ReadableEvent, out _normalOutDataEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_normalOutDataEvent.ReadableEvent, out _normalOutDataEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -195,7 +195,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Lib | |||
|         { | ||||
|             if (_interactiveOutDataEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_interactiveOutDataEvent.ReadableEvent, out _interactiveOutDataEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_interactiveOutDataEvent.ReadableEvent, out _interactiveOutDataEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  |  | |||
|  | @ -1,10 +1,10 @@ | |||
| using Ryujinx.Common.Logging; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Threading; | ||||
| using Ryujinx.HLE.HOS.Services.Settings.Types; | ||||
| using Ryujinx.HLE.HOS.Services.Vi.RootService.ApplicationDisplayService; | ||||
| using Ryujinx.HLE.HOS.SystemState; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| 
 | ||||
| namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy | ||||
|  | @ -38,7 +38,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
| 
 | ||||
|             if (_messageEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(messageEvent.ReadableEvent, out _messageEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(messageEvent.ReadableEvent, out _messageEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -211,7 +211,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
|             // NOTE: Original service calls IOperationModeManager::GetDefaultDisplayResolutionChangeEvent of omm service. | ||||
|             if (_displayResolutionChangedEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(context.Device.System.DisplayResolutionChangeEvent.ReadableEvent, out _displayResolutionChangedEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(context.Device.System.DisplayResolutionChangeEvent.ReadableEvent, out _displayResolutionChangedEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| using Ryujinx.Common.Logging; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Memory; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| 
 | ||||
| namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy | ||||
|  | @ -66,7 +66,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
|                 return ResultCode.BufferAlreadyAcquired; | ||||
|             } | ||||
| 
 | ||||
|             if (context.Process.HandleTable.GenerateHandle(_transferMem, out int handle) != KernelResult.Success) | ||||
|             if (context.Process.HandleTable.GenerateHandle(_transferMem, out int handle) != Result.Success) | ||||
|             { | ||||
|                 throw new InvalidOperationException("Out of handles!"); | ||||
|             } | ||||
|  | @ -89,7 +89,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
|                 return ResultCode.BufferAlreadyAcquired; | ||||
|             } | ||||
| 
 | ||||
|             if (context.Process.HandleTable.GenerateHandle(_transferMem, out int handle) != KernelResult.Success) | ||||
|             if (context.Process.HandleTable.GenerateHandle(_transferMem, out int handle) != Result.Success) | ||||
|             { | ||||
|                 throw new InvalidOperationException("Out of handles!"); | ||||
|             } | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| using Ryujinx.Common.Logging; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Threading; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| 
 | ||||
| namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy | ||||
|  | @ -32,7 +32,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
|         { | ||||
|             if (_channelEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_channelEvent.ReadableEvent, out _channelEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_channelEvent.ReadableEvent, out _channelEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  |  | |||
|  | @ -1,8 +1,8 @@ | |||
| using Ryujinx.Common.Logging; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Threading; | ||||
| using Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy.Types; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| 
 | ||||
| namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy | ||||
|  | @ -111,7 +111,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
| 
 | ||||
|             if (_libraryAppletLaunchableEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_libraryAppletLaunchableEvent.ReadableEvent, out _libraryAppletLaunchableEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_libraryAppletLaunchableEvent.ReadableEvent, out _libraryAppletLaunchableEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -378,7 +378,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.Sys | |||
| 
 | ||||
|                 _accumulatedSuspendedTickChangedEvent.ReadableEvent.Signal(); | ||||
| 
 | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_accumulatedSuspendedTickChangedEvent.ReadableEvent, out _accumulatedSuspendedTickChangedEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_accumulatedSuspendedTickChangedEvent.ReadableEvent, out _accumulatedSuspendedTickChangedEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  |  | |||
|  | @ -1,4 +1,3 @@ | |||
| using LibHac; | ||||
| using LibHac.Account; | ||||
| using LibHac.Common; | ||||
| using LibHac.Fs; | ||||
|  | @ -9,13 +8,13 @@ using Ryujinx.Common; | |||
| using Ryujinx.Common.Logging; | ||||
| using Ryujinx.HLE.Exceptions; | ||||
| using Ryujinx.HLE.HOS.Ipc; | ||||
| using Ryujinx.HLE.HOS.Kernel.Common; | ||||
| using Ryujinx.HLE.HOS.Kernel.Memory; | ||||
| using Ryujinx.HLE.HOS.Kernel.Threading; | ||||
| using Ryujinx.HLE.HOS.Services.Am.AppletAE.Storage; | ||||
| using Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.ApplicationProxy.Types; | ||||
| using Ryujinx.HLE.HOS.Services.Sdb.Pdm.QueryService; | ||||
| using Ryujinx.HLE.HOS.SystemState; | ||||
| using Ryujinx.Horizon.Common; | ||||
| using System; | ||||
| using System.Numerics; | ||||
| using System.Threading; | ||||
|  | @ -43,7 +42,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
| 
 | ||||
|         private int _jitLoaded; | ||||
| 
 | ||||
|         private HorizonClient _horizon; | ||||
|         private LibHac.HorizonClient _horizon; | ||||
| 
 | ||||
|         public IApplicationFunctions(Horizon system) | ||||
|         { | ||||
|  | @ -136,8 +135,8 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|                     "No control file was found for this game. Using a dummy one instead. This may cause inaccuracies in some games."); | ||||
|             } | ||||
| 
 | ||||
|             HorizonClient hos = context.Device.System.LibHacHorizonManager.AmClient; | ||||
|             Result result = hos.Fs.EnsureApplicationSaveData(out long requiredSize, applicationId, in control, in userId); | ||||
|             LibHac.HorizonClient hos = context.Device.System.LibHacHorizonManager.AmClient; | ||||
|             LibHac.Result result = hos.Fs.EnsureApplicationSaveData(out long requiredSize, applicationId, in control, in userId); | ||||
| 
 | ||||
|             context.ResponseData.Write(requiredSize); | ||||
| 
 | ||||
|  | @ -185,7 +184,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|         // SetTerminateResult(u32) | ||||
|         public ResultCode SetTerminateResult(ServiceCtx context) | ||||
|         { | ||||
|             Result result = new Result(context.RequestData.ReadUInt32()); | ||||
|             LibHac.Result result = new LibHac.Result(context.RequestData.ReadUInt32()); | ||||
| 
 | ||||
|             Logger.Info?.Print(LogClass.ServiceAm, $"Result = 0x{result.Value:x8} ({result.ToStringWithName()})."); | ||||
| 
 | ||||
|  | @ -256,7 +255,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
| 
 | ||||
|             BlitStruct<ApplicationControlProperty> controlHolder = context.Device.Application.ControlData; | ||||
| 
 | ||||
|             Result result = _horizon.Fs.CreateApplicationCacheStorage(out long requiredSize, | ||||
|             LibHac.Result result = _horizon.Fs.CreateApplicationCacheStorage(out long requiredSize, | ||||
|                 out CacheStorageTargetMedia storageTarget, applicationId, in controlHolder.Value, index, saveSize, | ||||
|                 journalSize); | ||||
| 
 | ||||
|  | @ -584,7 +583,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|         { | ||||
|             if (_gpuErrorDetectedSystemEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_gpuErrorDetectedSystemEvent.ReadableEvent, out _gpuErrorDetectedSystemEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_gpuErrorDetectedSystemEvent.ReadableEvent, out _gpuErrorDetectedSystemEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -605,7 +604,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|         { | ||||
|             if (_friendInvitationStorageChannelEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_friendInvitationStorageChannelEvent.ReadableEvent, out _friendInvitationStorageChannelEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_friendInvitationStorageChannelEvent.ReadableEvent, out _friendInvitationStorageChannelEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -636,7 +635,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|         { | ||||
|             if (_notificationStorageChannelEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_notificationStorageChannelEvent.ReadableEvent, out _notificationStorageChannelEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_notificationStorageChannelEvent.ReadableEvent, out _notificationStorageChannelEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  | @ -653,7 +652,7 @@ namespace Ryujinx.HLE.HOS.Services.Am.AppletOE.ApplicationProxyService.Applicati | |||
|         { | ||||
|             if (_healthWarningDisappearedSystemEventHandle == 0) | ||||
|             { | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_healthWarningDisappearedSystemEvent.ReadableEvent, out _healthWarningDisappearedSystemEventHandle) != KernelResult.Success) | ||||
|                 if (context.Process.HandleTable.GenerateHandle(_healthWarningDisappearedSystemEvent.ReadableEvent, out _healthWarningDisappearedSystemEventHandle) != Result.Success) | ||||
|                 { | ||||
|                     throw new InvalidOperationException("Out of handles!"); | ||||
|                 } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 gdkchan
						gdkchan