mirror of
https://github.com/ryujinx-mirror/ryujinx.git
synced 2024-11-30 19:04:28 +01:00
00579927e4
* 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
123 lines
3.7 KiB
C#
123 lines
3.7 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Ipc;
|
|
using Ryujinx.HLE.HOS.Kernel;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
|
|
using static Ryujinx.HLE.HOS.ErrorCode;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Am
|
|
{
|
|
class ICommonStateGetter : IpcService
|
|
{
|
|
private Dictionary<int, ServiceProcessRequest> m_Commands;
|
|
|
|
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
|
|
|
|
private KEvent DisplayResolutionChangeEvent;
|
|
|
|
public ICommonStateGetter(Horizon System)
|
|
{
|
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
|
{
|
|
{ 0, GetEventHandle },
|
|
{ 1, ReceiveMessage },
|
|
{ 5, GetOperationMode },
|
|
{ 6, GetPerformanceMode },
|
|
{ 8, GetBootMode },
|
|
{ 9, GetCurrentFocusState },
|
|
{ 60, GetDefaultDisplayResolution },
|
|
{ 61, GetDefaultDisplayResolutionChangeEvent }
|
|
};
|
|
|
|
DisplayResolutionChangeEvent = new KEvent(System);
|
|
}
|
|
|
|
public long GetEventHandle(ServiceCtx Context)
|
|
{
|
|
KEvent Event = Context.Device.System.AppletState.MessageEvent;
|
|
|
|
if (Context.Process.HandleTable.GenerateHandle(Event.ReadableEvent, out int Handle) != KernelResult.Success)
|
|
{
|
|
throw new InvalidOperationException("Out of handles!");
|
|
}
|
|
|
|
Context.Response.HandleDesc = IpcHandleDesc.MakeCopy(Handle);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long ReceiveMessage(ServiceCtx Context)
|
|
{
|
|
if (!Context.Device.System.AppletState.TryDequeueMessage(out MessageInfo Message))
|
|
{
|
|
return MakeError(ErrorModule.Am, AmErr.NoMessages);
|
|
}
|
|
|
|
Context.ResponseData.Write((int)Message);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetOperationMode(ServiceCtx Context)
|
|
{
|
|
OperationMode Mode = Context.Device.System.State.DockedMode
|
|
? OperationMode.Docked
|
|
: OperationMode.Handheld;
|
|
|
|
Context.ResponseData.Write((byte)Mode);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetPerformanceMode(ServiceCtx Context)
|
|
{
|
|
Apm.PerformanceMode Mode = Context.Device.System.State.DockedMode
|
|
? Apm.PerformanceMode.Docked
|
|
: Apm.PerformanceMode.Handheld;
|
|
|
|
Context.ResponseData.Write((int)Mode);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetBootMode(ServiceCtx Context)
|
|
{
|
|
Context.ResponseData.Write((byte)0); //Unknown value.
|
|
|
|
Logger.PrintStub(LogClass.ServiceAm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetCurrentFocusState(ServiceCtx Context)
|
|
{
|
|
Context.ResponseData.Write((byte)Context.Device.System.AppletState.FocusState);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetDefaultDisplayResolution(ServiceCtx Context)
|
|
{
|
|
Context.ResponseData.Write(1280);
|
|
Context.ResponseData.Write(720);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetDefaultDisplayResolutionChangeEvent(ServiceCtx Context)
|
|
{
|
|
if (Context.Process.HandleTable.GenerateHandle(DisplayResolutionChangeEvent.ReadableEvent, out int Handle) != KernelResult.Success)
|
|
{
|
|
throw new InvalidOperationException("Out of handles!");
|
|
}
|
|
|
|
Context.Response.HandleDesc = IpcHandleDesc.MakeCopy(Handle);
|
|
|
|
Logger.PrintStub(LogClass.ServiceAm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
}
|
|
}
|