c0dc0f2c3f
* Initial implementation of KProcess * Some improvements to the memory manager, implement back guest stack trace printing * Better GetInfo implementation, improve checking in some places with information from process capabilities * Allow the cpu to read/write from the correct memory locations for accesses crossing a page boundary * Change long -> ulong for address/size on memory related methods to avoid unnecessary casts * Attempt at implementing ldr:ro with new KProcess * Allow BSS with size 0 on ldr:ro * Add checking for memory block slab heap usage, return errors if full, exit gracefully * Use KMemoryBlockSize const from KMemoryManager * Allow all methods to read from non-contiguous locations * Fix for TransactParcelAuto * Address PR feedback, additionally fix some small issues related to the KIP loader and implement SVCs GetProcessId, GetProcessList, GetSystemInfo, CreatePort and ManageNamedPort * Fix wrong check for source pages count from page list on MapPhysicalMemory * Fix some issues with UnloadNro on ldr:ro
71 lines
No EOL
1.9 KiB
C#
71 lines
No EOL
1.9 KiB
C#
using System;
|
|
using System.IO;
|
|
using System.Runtime.InteropServices;
|
|
using System.Text;
|
|
|
|
namespace ChocolArm64.Memory
|
|
{
|
|
public static class MemoryHelper
|
|
{
|
|
public static void FillWithZeros(MemoryManager memory, long position, int size)
|
|
{
|
|
int size8 = size & ~(8 - 1);
|
|
|
|
for (int offs = 0; offs < size8; offs += 8)
|
|
{
|
|
memory.WriteInt64(position + offs, 0);
|
|
}
|
|
|
|
for (int offs = size8; offs < (size - size8); offs++)
|
|
{
|
|
memory.WriteByte(position + offs, 0);
|
|
}
|
|
}
|
|
|
|
public unsafe static T Read<T>(MemoryManager memory, long position) where T : struct
|
|
{
|
|
long size = Marshal.SizeOf<T>();
|
|
|
|
byte[] data = memory.ReadBytes(position, size);
|
|
|
|
fixed (byte* ptr = data)
|
|
{
|
|
return Marshal.PtrToStructure<T>((IntPtr)ptr);
|
|
}
|
|
}
|
|
|
|
public unsafe static void Write<T>(MemoryManager memory, long position, T value) where T : struct
|
|
{
|
|
long size = Marshal.SizeOf<T>();
|
|
|
|
byte[] data = new byte[size];
|
|
|
|
fixed (byte* ptr = data)
|
|
{
|
|
Marshal.StructureToPtr<T>(value, (IntPtr)ptr, false);
|
|
}
|
|
|
|
memory.WriteBytes(position, data);
|
|
}
|
|
|
|
public static string ReadAsciiString(MemoryManager memory, long position, long maxSize = -1)
|
|
{
|
|
using (MemoryStream ms = new MemoryStream())
|
|
{
|
|
for (long offs = 0; offs < maxSize || maxSize == -1; offs++)
|
|
{
|
|
byte value = (byte)memory.ReadByte(position + offs);
|
|
|
|
if (value == 0)
|
|
{
|
|
break;
|
|
}
|
|
|
|
ms.WriteByte(value);
|
|
}
|
|
|
|
return Encoding.ASCII.GetString(ms.ToArray());
|
|
}
|
|
}
|
|
}
|
|
} |