 a33dc2f491
			
		
	
	
		a33dc2f491
		
			
		
	
	
	
	
		
			
			* 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
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Ryujinx.Common.Logging;
 | |
| using Ryujinx.Graphics.Device;
 | |
| using Ryujinx.Graphics.Gpu.Memory;
 | |
| using Ryujinx.Graphics.Nvdec.Image;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| 
 | |
| namespace Ryujinx.Graphics.Nvdec
 | |
| {
 | |
|     public class NvdecDevice : IDeviceState
 | |
|     {
 | |
|         private readonly ResourceManager _rm;
 | |
|         private readonly DeviceState<NvdecRegisters> _state;
 | |
| 
 | |
|         public event Action<FrameDecodedEventArgs> FrameDecoded;
 | |
| 
 | |
|         public NvdecDevice(MemoryManager gmm)
 | |
|         {
 | |
|             _rm = new ResourceManager(gmm, new SurfaceCache(gmm));
 | |
|             _state = new DeviceState<NvdecRegisters>(new Dictionary<string, RwCallback>
 | |
|             {
 | |
|                 { nameof(NvdecRegisters.Execute), new RwCallback(Execute, null) }
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         public int Read(int offset) => _state.Read(offset);
 | |
|         public void Write(int offset, int data) => _state.Write(offset, data);
 | |
| 
 | |
|         private void Execute(int data)
 | |
|         {
 | |
|             Decode((CodecId)_state.State.SetCodecID);
 | |
|         }
 | |
| 
 | |
|         private void Decode(CodecId codecId)
 | |
|         {
 | |
|             switch (codecId)
 | |
|             {
 | |
|                 case CodecId.H264:
 | |
|                     H264Decoder.Decode(this, _rm, ref _state.State);
 | |
|                     break;
 | |
|                 case CodecId.Vp9:
 | |
|                     Vp9Decoder.Decode(this, _rm, ref _state.State);
 | |
|                     break;
 | |
|                 default:
 | |
|                     Logger.Error?.Print(LogClass.Nvdec, $"Unsupported codec \"{codecId}\".");
 | |
|                     break;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal void OnFrameDecoded(CodecId codecId, uint lumaOffset, uint chromaOffset)
 | |
|         {
 | |
|             FrameDecoded?.Invoke(new FrameDecodedEventArgs(codecId, lumaOffset, chromaOffset));
 | |
|         }
 | |
|     }
 | |
| }
 |