forked from Mirror/Ryujinx
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
59 lines
No EOL
2.1 KiB
C#
59 lines
No EOL
2.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() { }
|
|
|
|
[Command(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;
|
|
}
|
|
|
|
[Command(10)]
|
|
// CreateStorage(u64) -> object<nn::am::service::IStorage>
|
|
public ResultCode CreateStorage(ServiceCtx context)
|
|
{
|
|
long size = context.RequestData.ReadInt64();
|
|
|
|
MakeObject(context, new IStorage(new byte[size]));
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(11)]
|
|
// CreateTransferMemoryStorage(b8, u64, handle<copy>) -> object<nn::am::service::IStorage>
|
|
public ResultCode CreateTransferMemoryStorage(ServiceCtx context)
|
|
{
|
|
bool unknown = context.RequestData.ReadBoolean();
|
|
long size = context.RequestData.ReadInt64();
|
|
int handle = context.Request.HandleDesc.ToCopy[0];
|
|
|
|
KTransferMemory transferMem = context.Process.HandleTable.GetObject<KTransferMemory>(handle);
|
|
|
|
if (transferMem == null)
|
|
{
|
|
Logger.Warning?.Print(LogClass.ServiceAm, $"Invalid TransferMemory Handle: {handle:X}");
|
|
|
|
return ResultCode.Success; // TODO: Find correct error code
|
|
}
|
|
|
|
var data = new byte[transferMem.Size];
|
|
context.Memory.Read(transferMem.Address, data);
|
|
|
|
MakeObject(context, new IStorage(data));
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |