mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-10 20:15:13 +00:00
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
147 lines
4.6 KiB
C#
147 lines
4.6 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Ipc;
|
|
using Ryujinx.HLE.HOS.Kernel.Common;
|
|
using Ryujinx.HLE.HOS.Kernel.Threading;
|
|
using Ryujinx.HLE.HOS.Services.Apm;
|
|
using System;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy
|
|
{
|
|
class ICommonStateGetter : IpcService
|
|
{
|
|
private CpuBoostMode _cpuBoostMode = CpuBoostMode.Disabled;
|
|
private bool _vrModeEnabled = false;
|
|
|
|
public ICommonStateGetter() { }
|
|
|
|
[Command(0)]
|
|
// GetEventHandle() -> handle<copy>
|
|
public ResultCode 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 ResultCode.Success;
|
|
}
|
|
|
|
[Command(1)]
|
|
// ReceiveMessage() -> nn::am::AppletMessage
|
|
public ResultCode ReceiveMessage(ServiceCtx context)
|
|
{
|
|
if (!context.Device.System.AppletState.TryDequeueMessage(out MessageInfo message))
|
|
{
|
|
return ResultCode.NoMessages;
|
|
}
|
|
|
|
context.ResponseData.Write((int)message);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(5)]
|
|
// GetOperationMode() -> u8
|
|
public ResultCode GetOperationMode(ServiceCtx context)
|
|
{
|
|
OperationMode mode = context.Device.System.State.DockedMode
|
|
? OperationMode.Docked
|
|
: OperationMode.Handheld;
|
|
|
|
context.ResponseData.Write((byte)mode);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(6)]
|
|
// GetPerformanceMode() -> u32
|
|
public ResultCode GetPerformanceMode(ServiceCtx context)
|
|
{
|
|
PerformanceMode mode = context.Device.System.State.DockedMode
|
|
? PerformanceMode.Docked
|
|
: PerformanceMode.Handheld;
|
|
|
|
context.ResponseData.Write((int)mode);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(8)]
|
|
// GetBootMode() -> u8
|
|
public ResultCode GetBootMode(ServiceCtx context)
|
|
{
|
|
context.ResponseData.Write((byte)0); //Unknown value.
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceAm);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(9)]
|
|
// GetCurrentFocusState() -> u8
|
|
public ResultCode GetCurrentFocusState(ServiceCtx context)
|
|
{
|
|
context.ResponseData.Write((byte)context.Device.System.AppletState.FocusState);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(50)] // 3.0.0+
|
|
// IsVrModeEnabled() -> b8
|
|
public ResultCode IsVrModeEnabled(ServiceCtx context)
|
|
{
|
|
context.ResponseData.Write(_vrModeEnabled);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(60)] // 3.0.0+
|
|
// GetDefaultDisplayResolution() -> (u32, u32)
|
|
public ResultCode GetDefaultDisplayResolution(ServiceCtx context)
|
|
{
|
|
context.ResponseData.Write(1280);
|
|
context.ResponseData.Write(720);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(61)] // 3.0.0+
|
|
// GetDefaultDisplayResolutionChangeEvent() -> handle<copy>
|
|
public ResultCode GetDefaultDisplayResolutionChangeEvent(ServiceCtx context)
|
|
{
|
|
if (context.Process.HandleTable.GenerateHandle(context.Device.System.DisplayResolutionChangeEvent.ReadableEvent, out int handle) != KernelResult.Success)
|
|
{
|
|
throw new InvalidOperationException("Out of handles!");
|
|
}
|
|
|
|
context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceAm);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(66)] // 6.0.0+
|
|
// SetCpuBoostMode(u32 cpu_boost_mode)
|
|
public ResultCode SetCpuBoostMode(ServiceCtx context)
|
|
{
|
|
uint cpuBoostMode = context.RequestData.ReadUInt32();
|
|
|
|
if (cpuBoostMode > 1)
|
|
{
|
|
return ResultCode.InvalidParameters;
|
|
}
|
|
|
|
_cpuBoostMode = (CpuBoostMode)cpuBoostMode;
|
|
|
|
// NOTE: There is a condition variable after the assignment, probably waiting something with apm:sys service (SetCpuBoostMode call?).
|
|
// Since we will probably never support CPU boost things, it's not needed to implement more.
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |