service/vi: Unstub GetDisplayService
This function is also supposed to check its given policy type with the permission of the service itself. This implements the necessary machinery to unstub these functions. Policy::User seems to just be basic access (which is probably why vi:u is restricted to that policy), while the other policy seems to be for extended abilities regarding which displays can be managed and queried, so this is assumed to be for a background compositor (which I've named, appropriately, Policy::Compositor).
This commit is contained in:
parent
254b1e3df7
commit
92ea1c32d6
|
@ -34,6 +34,7 @@
|
||||||
namespace Service::VI {
|
namespace Service::VI {
|
||||||
|
|
||||||
constexpr ResultCode ERR_OPERATION_FAILED{ErrorModule::VI, 1};
|
constexpr ResultCode ERR_OPERATION_FAILED{ErrorModule::VI, 1};
|
||||||
|
constexpr ResultCode ERR_PERMISSION_DENIED{ErrorModule::VI, 5};
|
||||||
constexpr ResultCode ERR_UNSUPPORTED{ErrorModule::VI, 6};
|
constexpr ResultCode ERR_UNSUPPORTED{ErrorModule::VI, 6};
|
||||||
constexpr ResultCode ERR_NOT_FOUND{ErrorModule::VI, 7};
|
constexpr ResultCode ERR_NOT_FOUND{ErrorModule::VI, 7};
|
||||||
|
|
||||||
|
@ -1203,8 +1204,30 @@ IApplicationDisplayService::IApplicationDisplayService(
|
||||||
RegisterHandlers(functions);
|
RegisterHandlers(functions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool IsValidServiceAccess(Permission permission, Policy policy) {
|
||||||
|
if (permission == Permission::User) {
|
||||||
|
return policy == Policy::User;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (permission == Permission::System || permission == Permission::Manager) {
|
||||||
|
return policy == Policy::User || policy == Policy::Compositor;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void detail::GetDisplayServiceImpl(Kernel::HLERequestContext& ctx,
|
void detail::GetDisplayServiceImpl(Kernel::HLERequestContext& ctx,
|
||||||
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger) {
|
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger,
|
||||||
|
Permission permission) {
|
||||||
|
IPC::RequestParser rp{ctx};
|
||||||
|
const auto policy = rp.PopEnum<Policy>();
|
||||||
|
|
||||||
|
if (!IsValidServiceAccess(permission, policy)) {
|
||||||
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
|
rb.Push(ERR_PERMISSION_DENIED);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
rb.Push(RESULT_SUCCESS);
|
rb.Push(RESULT_SUCCESS);
|
||||||
rb.PushIpcInterface<IApplicationDisplayService>(std::move(nv_flinger));
|
rb.PushIpcInterface<IApplicationDisplayService>(std::move(nv_flinger));
|
||||||
|
|
|
@ -20,10 +20,6 @@ class ServiceManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace Service::VI {
|
namespace Service::VI {
|
||||||
namespace detail {
|
|
||||||
void GetDisplayServiceImpl(Kernel::HLERequestContext& ctx,
|
|
||||||
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger);
|
|
||||||
}
|
|
||||||
|
|
||||||
enum class DisplayResolution : u32 {
|
enum class DisplayResolution : u32 {
|
||||||
DockedWidth = 1920,
|
DockedWidth = 1920,
|
||||||
|
@ -32,6 +28,25 @@ enum class DisplayResolution : u32 {
|
||||||
UndockedHeight = 720,
|
UndockedHeight = 720,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// Permission level for a particular VI service instance
|
||||||
|
enum class Permission {
|
||||||
|
User,
|
||||||
|
System,
|
||||||
|
Manager,
|
||||||
|
};
|
||||||
|
|
||||||
|
/// A policy type that may be requested via GetDisplayService and
|
||||||
|
/// GetDisplayServiceWithProxyNameExchange
|
||||||
|
enum class Policy {
|
||||||
|
User,
|
||||||
|
Compositor,
|
||||||
|
};
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
void GetDisplayServiceImpl(Kernel::HLERequestContext& ctx,
|
||||||
|
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger, Permission permission);
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
/// Registers all VI services with the specified service manager.
|
/// Registers all VI services with the specified service manager.
|
||||||
void InstallInterfaces(SM::ServiceManager& service_manager,
|
void InstallInterfaces(SM::ServiceManager& service_manager,
|
||||||
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger);
|
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger);
|
||||||
|
|
|
@ -20,9 +20,9 @@ VI_M::VI_M(std::shared_ptr<NVFlinger::NVFlinger> nv_flinger)
|
||||||
VI_M::~VI_M() = default;
|
VI_M::~VI_M() = default;
|
||||||
|
|
||||||
void VI_M::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
void VI_M::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_WARNING(Service_VI, "(STUBBED) called");
|
LOG_DEBUG(Service_VI, "called");
|
||||||
|
|
||||||
detail::GetDisplayServiceImpl(ctx, nv_flinger);
|
detail::GetDisplayServiceImpl(ctx, nv_flinger, Permission::Manager);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Service::VI
|
} // namespace Service::VI
|
||||||
|
|
|
@ -20,9 +20,9 @@ VI_S::VI_S(std::shared_ptr<NVFlinger::NVFlinger> nv_flinger)
|
||||||
VI_S::~VI_S() = default;
|
VI_S::~VI_S() = default;
|
||||||
|
|
||||||
void VI_S::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
void VI_S::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_WARNING(Service_VI, "(STUBBED) called");
|
LOG_DEBUG(Service_VI, "called");
|
||||||
|
|
||||||
detail::GetDisplayServiceImpl(ctx, nv_flinger);
|
detail::GetDisplayServiceImpl(ctx, nv_flinger, Permission::System);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Service::VI
|
} // namespace Service::VI
|
||||||
|
|
|
@ -19,9 +19,9 @@ VI_U::VI_U(std::shared_ptr<NVFlinger::NVFlinger> nv_flinger)
|
||||||
VI_U::~VI_U() = default;
|
VI_U::~VI_U() = default;
|
||||||
|
|
||||||
void VI_U::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
void VI_U::GetDisplayService(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_WARNING(Service_VI, "(STUBBED) called");
|
LOG_DEBUG(Service_VI, "called");
|
||||||
|
|
||||||
detail::GetDisplayServiceImpl(ctx, nv_flinger);
|
detail::GetDisplayServiceImpl(ctx, nv_flinger, Permission::User);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Service::VI
|
} // namespace Service::VI
|
||||||
|
|
Reference in New Issue