mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-15 06:41:56 -08:00
40d1acd198
* vi: Unify resolutions values and accurate implementation of them. To continue what was made in #2618, I've REd `vi` service a bit. Now values and checks related to displays are more accurate. - `am` GetDefaultDisplayResolution / GetDefaultDisplayResolutionChangeEvent have more informations on what the service does. - `vi:u/vi:m/vi:s` GetDisplayService are now accurate. - `IApplicationDisplay` GetRelayService, GetSystemDisplayService, GetManagerDisplayService, GetIndirectDisplayTransactionService, ListDisplays, OpenDisplay, OpenDefaultDisplay, CloseDisplay, GetDisplayResolution are now properly implemented. - Some other calls are cleaned or have extra checks accordingly to RE. Additionnaly, `IFriendService` have some wrong aligned things, and `pm:info` service placeholder was missing. * just use _openedDisplayInfo.Remove() * use context.Memory.Fill() * fix some casting * remove unneeded comment * cleanup * uses TryAdd * displayId > ulong * GetDisplayResolution > ulong * UL
82 lines
2.7 KiB
C#
82 lines
2.7 KiB
C#
using Ryujinx.Common.Logging;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Vi.RootService.ApplicationDisplayService
|
|
{
|
|
class IManagerDisplayService : IpcService
|
|
{
|
|
private IApplicationDisplayService _applicationDisplayService;
|
|
|
|
public IManagerDisplayService(IApplicationDisplayService applicationDisplayService)
|
|
{
|
|
_applicationDisplayService = applicationDisplayService;
|
|
}
|
|
|
|
[CommandHipc(1102)]
|
|
// GetDisplayResolution(u64 display_id) -> (u64 width, u64 height)
|
|
public ResultCode GetDisplayResolution(ServiceCtx context)
|
|
{
|
|
ulong displayId = context.RequestData.ReadUInt64();
|
|
|
|
(ulong width, ulong height) = AndroidSurfaceComposerClient.GetDisplayInfo(context, displayId);
|
|
|
|
context.ResponseData.Write(width);
|
|
context.ResponseData.Write(height);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(2010)]
|
|
// CreateManagedLayer(u32, u64, nn::applet::AppletResourceUserId) -> u64
|
|
public ResultCode CreateManagedLayer(ServiceCtx context)
|
|
{
|
|
long layerFlags = context.RequestData.ReadInt64();
|
|
long displayId = context.RequestData.ReadInt64();
|
|
long appletResourceUserId = context.RequestData.ReadInt64();
|
|
|
|
long pid = context.Device.System.AppletState.AppletResourceUserIds.GetData<long>((int)appletResourceUserId);
|
|
|
|
context.Device.System.SurfaceFlinger.CreateLayer(pid, out long layerId);
|
|
context.Device.System.SurfaceFlinger.SetRenderLayer(layerId);
|
|
|
|
context.ResponseData.Write(layerId);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(2011)]
|
|
// DestroyManagedLayer(u64)
|
|
public ResultCode DestroyManagedLayer(ServiceCtx context)
|
|
{
|
|
long layerId = context.RequestData.ReadInt64();
|
|
|
|
context.Device.System.SurfaceFlinger.CloseLayer(layerId);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(2012)] // 7.0.0+
|
|
// CreateStrayLayer(u32, u64) -> (u64, u64, buffer<bytes, 6>)
|
|
public ResultCode CreateStrayLayer(ServiceCtx context)
|
|
{
|
|
return _applicationDisplayService.CreateStrayLayer(context);
|
|
}
|
|
|
|
[CommandHipc(6000)]
|
|
// AddToLayerStack(u32, u64)
|
|
public ResultCode AddToLayerStack(ServiceCtx context)
|
|
{
|
|
Logger.Stub?.PrintStub(LogClass.ServiceVi);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandHipc(6002)]
|
|
// SetLayerVisibility(b8, u64)
|
|
public ResultCode SetLayerVisibility(ServiceCtx context)
|
|
{
|
|
Logger.Stub?.PrintStub(LogClass.ServiceVi);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |