hle: Make Ryujinx.HLE project entirely safe (#2789)
* Remove a bit of unsafety around
* Regenerate StructArrayHelpers with a max element value of 256
* hle: remove unsafe marker from all struct that had it
* hle: make SoftwareKeyboardRenderer.TryCopyTo safe
* hle: remove unsafety in NpadDevice and remove AllowUnsafeBlocks from csproj
* Revert "Regenerate StructArrayHelpers with a max element value of 256"
This reverts commit f32a6e5be0.
* Introduce ByteArray of various size and use that instead of ArrayXXX to avoid stackoverflow in .NET runtime type resolution
* Use ByteArray more
* Add some missing spaces on Pack = 1 for various structs
* Fix broken logic for TryCopyTo
* Address gdkchan's comment
* Address gdkchan's comment
			
			
This commit is contained in:
		
							parent
							
								
									e48530e9d9
								
							
						
					
					
						commit
						f41687f4c1
					
				
					 20 changed files with 175 additions and 126 deletions
				
			
		|  | @ -66,8 +66,7 @@ namespace Ryujinx.HLE.HOS.Applets | |||
|             _device = system.Device; | ||||
|         } | ||||
| 
 | ||||
|         public ResultCode Start(AppletSession normalSession, | ||||
|                                 AppletSession interactiveSession) | ||||
|         public ResultCode Start(AppletSession normalSession, AppletSession interactiveSession) | ||||
|         { | ||||
|             lock (_lock) | ||||
|             { | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ namespace Ryujinx.HLE.HOS.Applets.SoftwareKeyboard | |||
|     /// <summary> | ||||
|     /// A structure with configuration options of the software keyboard when starting a new input request in inline mode. | ||||
|     /// </summary> | ||||
|     [StructLayout(LayoutKind.Sequential, Pack=1, CharSet = CharSet.Unicode)] | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1, CharSet = CharSet.Unicode)] | ||||
|     struct SoftwareKeyboardCalc | ||||
|     { | ||||
|         public const int InputTextLength = SoftwareKeyboardCalcEx.InputTextLength; | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ namespace Ryujinx.HLE.HOS.Applets.SoftwareKeyboard | |||
|     /// A structure with configuration options of the software keyboard when starting a new input request in inline mode. | ||||
|     /// This is the extended version of the structure with extended appear options. | ||||
|     /// </summary> | ||||
|     [StructLayout(LayoutKind.Sequential, Pack=1, CharSet = CharSet.Unicode)] | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1, CharSet = CharSet.Unicode)] | ||||
|     struct SoftwareKeyboardCalcEx | ||||
|     { | ||||
|         /// <summary> | ||||
|  |  | |||
|  | @ -1,12 +1,14 @@ | |||
| using Ryujinx.HLE.Ui; | ||||
| using Ryujinx.Memory; | ||||
| using System; | ||||
| using System.Buffers.Binary; | ||||
| using System.Diagnostics; | ||||
| using System.Drawing; | ||||
| using System.Drawing.Drawing2D; | ||||
| using System.Drawing.Imaging; | ||||
| using System.Drawing.Text; | ||||
| using System.IO; | ||||
| using System.Numerics; | ||||
| using System.Reflection; | ||||
| using System.Runtime.InteropServices; | ||||
| using System.Threading; | ||||
|  | @ -652,7 +654,7 @@ namespace Ryujinx.HLE.HOS.Applets.SoftwareKeyboard | |||
|             DrawString(graphics, ControllerToggleText, _labelsTextFont, _textNormalBrush, labelPosition); | ||||
|         } | ||||
| 
 | ||||
|         private unsafe bool TryCopyTo(IVirtualMemoryManager destination, ulong position) | ||||
|         private bool TryCopyTo(IVirtualMemoryManager destination, ulong position) | ||||
|         { | ||||
|             if (_surface == null) | ||||
|             { | ||||
|  | @ -666,23 +668,21 @@ namespace Ryujinx.HLE.HOS.Applets.SoftwareKeyboard | |||
|             Debug.Assert(surfaceData.Stride * surfaceData.Height == _surfaceInfo.Size); | ||||
| 
 | ||||
|             // Convert the pixel format used in System.Drawing to the one required by a Switch Surface. | ||||
|             int dataLength    = surfaceData.Stride * surfaceData.Height; | ||||
|             byte* dataPointer = (byte*)surfaceData.Scan0; | ||||
|             byte* dataEnd     = dataPointer + dataLength; | ||||
|             int dataLength = surfaceData.Stride * surfaceData.Height; | ||||
| 
 | ||||
|             for (; dataPointer < dataEnd; dataPointer += 4) | ||||
|             byte[] data = new byte[dataLength]; | ||||
|             Span<uint> dataConvert = MemoryMarshal.Cast<byte, uint>(data); | ||||
| 
 | ||||
|             Marshal.Copy(surfaceData.Scan0, data, 0, dataLength); | ||||
| 
 | ||||
|             for (int i = 0; i < dataConvert.Length; i++) | ||||
|             { | ||||
|                 *(uint*)dataPointer = (uint)( | ||||
|                      (*(dataPointer + 0) << 16) | | ||||
|                      (*(dataPointer + 1) << 8 ) | | ||||
|                      (*(dataPointer + 2) << 0 ) | | ||||
|                      (*(dataPointer + 3) << 24)); | ||||
|                 dataConvert[i] = BitOperations.RotateRight(BinaryPrimitives.ReverseEndianness(dataConvert[i]), 8); | ||||
|             } | ||||
| 
 | ||||
|             try | ||||
|             { | ||||
|                 Span<byte> dataSpan = new Span<byte>((void*)surfaceData.Scan0, dataLength); | ||||
|                 destination.Write(position, dataSpan); | ||||
|                 destination.Write(position, data); | ||||
|             } | ||||
|             finally | ||||
|             { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Mary
						Mary