mirror of
https://github.com/GreemDev/Ryujinx
synced 2025-01-07 19:47:06 +01:00
0746b83edf
* Rename CommandAttribute as CommandHIpcAttribute to prepare for 12.x changes * Implement inital support for TIPC and adds SM command ids * *Ipc to *ipc * Missed a ref in last commit... * CommandAttributeTIpc to CommandAttributeTipc * Addresses comment and fixes some bugs around TIPC doesn't have any padding requirements as buffer C isn't a thing Fix for RegisterService inverting two argument only on TIPC
92 lines
No EOL
3.1 KiB
C#
92 lines
No EOL
3.1 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Kernel.Memory;
|
|
using Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.LibraryAppletCreator;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy
|
|
{
|
|
class ILibraryAppletCreator : IpcService
|
|
{
|
|
public ILibraryAppletCreator() { }
|
|
|
|
[CommandHipc(0)]
|
|
// CreateLibraryApplet(u32, u32) -> object<nn::am::service::ILibraryAppletAccessor>
|
|
public ResultCode CreateLibraryApplet(ServiceCtx context)
|
|
{
|
|
AppletId appletId = (AppletId)context.RequestData.ReadInt32();
|
|
int libraryAppletMode = context.RequestData.ReadInt32();
|
|
|
|
MakeObject(context, new ILibraryAppletAccessor(appletId, context.Device.System));
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(10)]
|
|
// CreateStorage(u64) -> object<nn::am::service::IStorage>
|
|
public ResultCode CreateStorage(ServiceCtx context)
|
|
{
|
|
long size = context.RequestData.ReadInt64();
|
|
|
|
if (size <= 0)
|
|
{
|
|
return ResultCode.ObjectInvalid;
|
|
}
|
|
|
|
MakeObject(context, new IStorage(new byte[size]));
|
|
|
|
// NOTE: Returns ResultCode.MemoryAllocationFailed if IStorage is null, it doesn't occur in our case.
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(11)]
|
|
// CreateTransferMemoryStorage(b8, u64, handle<copy>) -> object<nn::am::service::IStorage>
|
|
public ResultCode CreateTransferMemoryStorage(ServiceCtx context)
|
|
{
|
|
bool isReadOnly = (context.RequestData.ReadInt64() & 1) == 0;
|
|
long size = context.RequestData.ReadInt64();
|
|
int handle = context.Request.HandleDesc.ToCopy[0];
|
|
|
|
KTransferMemory transferMem = context.Process.HandleTable.GetObject<KTransferMemory>(handle);
|
|
|
|
if (size <= 0)
|
|
{
|
|
return ResultCode.ObjectInvalid;
|
|
}
|
|
|
|
byte[] data = new byte[transferMem.Size];
|
|
|
|
transferMem.Creator.CpuMemory.Read(transferMem.Address, data);
|
|
|
|
context.Device.System.KernelContext.Syscall.CloseHandle(handle);
|
|
|
|
MakeObject(context, new IStorage(data, isReadOnly));
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(12)] // 2.0.0+
|
|
// CreateHandleStorage(u64, handle<copy>) -> object<nn::am::service::IStorage>
|
|
public ResultCode CreateHandleStorage(ServiceCtx context)
|
|
{
|
|
long size = context.RequestData.ReadInt64();
|
|
int handle = context.Request.HandleDesc.ToCopy[0];
|
|
|
|
KTransferMemory transferMem = context.Process.HandleTable.GetObject<KTransferMemory>(handle);
|
|
|
|
if (size <= 0)
|
|
{
|
|
return ResultCode.ObjectInvalid;
|
|
}
|
|
|
|
byte[] data = new byte[transferMem.Size];
|
|
|
|
transferMem.Creator.CpuMemory.Read(transferMem.Address, data);
|
|
|
|
context.Device.System.KernelContext.Syscall.CloseHandle(handle);
|
|
|
|
MakeObject(context, new IStorage(data));
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |