aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/Utilities/StructReader.cs
diff options
context:
space:
mode:
authorMary <me@thog.eu>2021-04-24 12:16:01 +0200
committerGitHub <noreply@github.com>2021-04-24 12:16:01 +0200
commit305f06eb71a7832e6b0081a67015b66ced8a23cd (patch)
tree98bcb3ed465332a04af449cb5c74bdca7855a141 /Ryujinx.HLE/Utilities/StructReader.cs
parentc46f6879ff9171a1e024965618242e8bad373b6b (diff)
HLE: Fix integer sign inconcistency accross the codebase (#2222)
* Make all title id instances unsigned * Replace address and size with ulong instead of signed types Long overdue change. Also change some logics here and there to optimize with the new memory manager. * Address Ac_K's comments * Remove uneeded cast all around * Fixes some others misalignment
Diffstat (limited to 'Ryujinx.HLE/Utilities/StructReader.cs')
-rw-r--r--Ryujinx.HLE/Utilities/StructReader.cs26
1 files changed, 9 insertions, 17 deletions
diff --git a/Ryujinx.HLE/Utilities/StructReader.cs b/Ryujinx.HLE/Utilities/StructReader.cs
index 3bde1c77..81e758a8 100644
--- a/Ryujinx.HLE/Utilities/StructReader.cs
+++ b/Ryujinx.HLE/Utilities/StructReader.cs
@@ -1,5 +1,6 @@
using Ryujinx.Cpu;
using Ryujinx.Memory;
+using System;
using System.Runtime.InteropServices;
namespace Ryujinx.HLE.Utilities
@@ -8,39 +9,30 @@ namespace Ryujinx.HLE.Utilities
{
private IVirtualMemoryManager _memory;
- public long Position { get; private set; }
+ public ulong Position { get; private set; }
- public StructReader(IVirtualMemoryManager memory, long position)
+ public StructReader(IVirtualMemoryManager memory, ulong position)
{
_memory = memory;
Position = position;
}
- public T Read<T>() where T : struct
+ public T Read<T>() where T : unmanaged
{
T value = MemoryHelper.Read<T>(_memory, Position);
- Position += Marshal.SizeOf<T>();
+ Position += (uint)Marshal.SizeOf<T>();
return value;
}
- public T[] Read<T>(int size) where T : struct
+ public ReadOnlySpan<T> Read<T>(int size) where T : unmanaged
{
- int structSize = Marshal.SizeOf<T>();
+ ReadOnlySpan<byte> data = _memory.GetSpan(Position, size);
- int count = size / structSize;
+ Position += (uint)size;
- T[] output = new T[count];
-
- for (int index = 0; index < count; index++)
- {
- output[index] = MemoryHelper.Read<T>(_memory, Position);
-
- Position += structSize;
- }
-
- return output;
+ return MemoryMarshal.Cast<byte, T>(data);
}
}
}