|
|
|
@ -32,8 +32,8 @@ public:
|
|
|
|
|
{5, &IAudioRenderer::Start, "Start"},
|
|
|
|
|
{6, &IAudioRenderer::Stop, "Stop"},
|
|
|
|
|
{7, &IAudioRenderer::QuerySystemEvent, "QuerySystemEvent"},
|
|
|
|
|
{8, nullptr, "SetRenderingTimeLimit"},
|
|
|
|
|
{9, nullptr, "GetRenderingTimeLimit"},
|
|
|
|
|
{8, &IAudioRenderer::SetRenderingTimeLimit, "SetRenderingTimeLimit"},
|
|
|
|
|
{9, &IAudioRenderer::GetRenderingTimeLimit, "GetRenderingTimeLimit"},
|
|
|
|
|
{10, nullptr, "RequestUpdateAuto"},
|
|
|
|
|
{11, nullptr, "ExecuteAudioRendererRendering"},
|
|
|
|
|
};
|
|
|
|
@ -110,8 +110,29 @@ private:
|
|
|
|
|
LOG_WARNING(Service_Audio, "(STUBBED) called");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SetRenderingTimeLimit(Kernel::HLERequestContext& ctx) {
|
|
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
|
rendering_time_limit_percent = rp.Pop<u32>();
|
|
|
|
|
ASSERT(rendering_time_limit_percent >= 0 && rendering_time_limit_percent <= 100);
|
|
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
|
|
|
|
|
LOG_DEBUG(Service_Audio, "called. rendering_time_limit_percent={}",
|
|
|
|
|
rendering_time_limit_percent);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void GetRenderingTimeLimit(Kernel::HLERequestContext& ctx) {
|
|
|
|
|
LOG_DEBUG(Service_Audio, "called");
|
|
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
rb.Push(rendering_time_limit_percent);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Kernel::SharedPtr<Kernel::Event> system_event;
|
|
|
|
|
std::unique_ptr<AudioCore::AudioRenderer> renderer;
|
|
|
|
|
u32 rendering_time_limit_percent = 100;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class IAudioDevice final : public ServiceFramework<IAudioDevice> {
|
|
|
|
|