mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 08:52:25 -07:00 
			
		
		
		
	* Logger class changes only Now compile-time checking is possible with the help of Nullable Value types. * Misc formatting * Manual optimizations PrintGuestLog PrintGuestStackTrace Surfaceflinger DequeueBuffer * Reduce SendVibrationXX log level to Debug * Add Notice log level This level is always enabled and used to print system info, etc... Also, rewrite LogColor to switch expression as colors are static * Unify unhandled exception event handlers * Print enabled LogLevels during init * Re-add App Exit disposes in proper order nit: switch case spacing * Revert PrintGuestStackTrace to Info logs due to #1407 PrintGuestStackTrace is now called in some critical error handlers so revert to old behavior as KThread isn't part of Guest. * Batch replace Logger statements
		
			
				
	
	
		
			64 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Ryujinx.Common;
 | |
| 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.Bcat.ServiceCreator.Types;
 | |
| using System;
 | |
| using System.IO;
 | |
| 
 | |
| namespace Ryujinx.HLE.HOS.Services.Bcat.ServiceCreator
 | |
| {
 | |
|     class IDeliveryCacheProgressService : IpcService
 | |
|     {
 | |
|         private KEvent _event;
 | |
| 
 | |
|         public IDeliveryCacheProgressService(ServiceCtx context)
 | |
|         {
 | |
|             _event = new KEvent(context.Device.System.KernelContext);
 | |
|         }
 | |
| 
 | |
|         [Command(0)]
 | |
|         // GetEvent() -> handle<copy>
 | |
|         public ResultCode GetEvent(ServiceCtx context)
 | |
|         {
 | |
|             if (context.Process.HandleTable.GenerateHandle(_event.ReadableEvent, out int handle) != KernelResult.Success)
 | |
|             {
 | |
|                 throw new InvalidOperationException("Out of handles!");
 | |
|             }
 | |
| 
 | |
|             context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
 | |
| 
 | |
|             Logger.Stub?.PrintStub(LogClass.ServiceBcat);
 | |
| 
 | |
|             return ResultCode.Success;
 | |
|         }
 | |
| 
 | |
|         [Command(1)]
 | |
|         // GetImpl() -> buffer<nn::bcat::detail::DeliveryCacheProgressImpl, 0x1a>
 | |
|         public ResultCode GetImpl(ServiceCtx context)
 | |
|         {
 | |
|             DeliveryCacheProgressImpl deliveryCacheProgress = new DeliveryCacheProgressImpl
 | |
|             {
 | |
|                 State  = DeliveryCacheProgressImpl.Status.Done,
 | |
|                 Result = 0
 | |
|             };
 | |
| 
 | |
|             WriteDeliveryCacheProgressImpl(context, context.Request.RecvListBuff[0], deliveryCacheProgress);
 | |
| 
 | |
|             Logger.Stub?.PrintStub(LogClass.ServiceBcat);
 | |
| 
 | |
|             return ResultCode.Success;
 | |
|         }
 | |
| 
 | |
|         private void WriteDeliveryCacheProgressImpl(ServiceCtx context, IpcRecvListBuffDesc ipcDesc, DeliveryCacheProgressImpl deliveryCacheProgress)
 | |
|         {
 | |
|             using (MemoryStream memory = new MemoryStream((int)ipcDesc.Size))
 | |
|             using (BinaryWriter bufferWriter = new BinaryWriter(memory))
 | |
|             {
 | |
|                 bufferWriter.WriteStruct(deliveryCacheProgress);
 | |
|                 context.Memory.Write((ulong)ipcDesc.Position, memory.ToArray());
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| } |