mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
am: rewrite IAudioController
This commit is contained in:
parent
6fd6c65fd4
commit
590e86792c
8 changed files with 111 additions and 132 deletions
|
@ -429,8 +429,6 @@ add_library(core STATIC
|
||||||
hle/service/am/application_creator.h
|
hle/service/am/application_creator.h
|
||||||
hle/service/am/application_functions.cpp
|
hle/service/am/application_functions.cpp
|
||||||
hle/service/am/application_functions.h
|
hle/service/am/application_functions.h
|
||||||
hle/service/am/audio_controller.cpp
|
|
||||||
hle/service/am/audio_controller.h
|
|
||||||
hle/service/am/common_state_getter.cpp
|
hle/service/am/common_state_getter.cpp
|
||||||
hle/service/am/common_state_getter.h
|
hle/service/am/common_state_getter.h
|
||||||
hle/service/am/debug_functions.cpp
|
hle/service/am/debug_functions.cpp
|
||||||
|
@ -471,6 +469,8 @@ add_library(core STATIC
|
||||||
hle/service/am/service/application_proxy_service.h
|
hle/service/am/service/application_proxy_service.h
|
||||||
hle/service/am/service/application_proxy.cpp
|
hle/service/am/service/application_proxy.cpp
|
||||||
hle/service/am/service/application_proxy.h
|
hle/service/am/service/application_proxy.h
|
||||||
|
hle/service/am/service/audio_controller.cpp
|
||||||
|
hle/service/am/service/audio_controller.h
|
||||||
hle/service/am/service/library_applet_proxy.cpp
|
hle/service/am/service/library_applet_proxy.cpp
|
||||||
hle/service/am/service/library_applet_proxy.h
|
hle/service/am/service/library_applet_proxy.h
|
||||||
hle/service/am/service/system_applet_proxy.cpp
|
hle/service/am/service/system_applet_proxy.cpp
|
||||||
|
|
|
@ -1,91 +0,0 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
||||||
|
|
||||||
#include "core/hle/service/am/audio_controller.h"
|
|
||||||
#include "core/hle/service/ipc_helpers.h"
|
|
||||||
|
|
||||||
namespace Service::AM {
|
|
||||||
|
|
||||||
IAudioController::IAudioController(Core::System& system_)
|
|
||||||
: ServiceFramework{system_, "IAudioController"} {
|
|
||||||
// clang-format off
|
|
||||||
static const FunctionInfo functions[] = {
|
|
||||||
{0, &IAudioController::SetExpectedMasterVolume, "SetExpectedMasterVolume"},
|
|
||||||
{1, &IAudioController::GetMainAppletExpectedMasterVolume, "GetMainAppletExpectedMasterVolume"},
|
|
||||||
{2, &IAudioController::GetLibraryAppletExpectedMasterVolume, "GetLibraryAppletExpectedMasterVolume"},
|
|
||||||
{3, &IAudioController::ChangeMainAppletMasterVolume, "ChangeMainAppletMasterVolume"},
|
|
||||||
{4, &IAudioController::SetTransparentAudioRate, "SetTransparentVolumeRate"},
|
|
||||||
};
|
|
||||||
// clang-format on
|
|
||||||
|
|
||||||
RegisterHandlers(functions);
|
|
||||||
}
|
|
||||||
|
|
||||||
IAudioController::~IAudioController() = default;
|
|
||||||
|
|
||||||
void IAudioController::SetExpectedMasterVolume(HLERequestContext& ctx) {
|
|
||||||
IPC::RequestParser rp{ctx};
|
|
||||||
const float main_applet_volume_tmp = rp.Pop<float>();
|
|
||||||
const float library_applet_volume_tmp = rp.Pop<float>();
|
|
||||||
|
|
||||||
LOG_DEBUG(Service_AM, "called. main_applet_volume={}, library_applet_volume={}",
|
|
||||||
main_applet_volume_tmp, library_applet_volume_tmp);
|
|
||||||
|
|
||||||
// Ensure the volume values remain within the 0-100% range
|
|
||||||
main_applet_volume = std::clamp(main_applet_volume_tmp, min_allowed_volume, max_allowed_volume);
|
|
||||||
library_applet_volume =
|
|
||||||
std::clamp(library_applet_volume_tmp, min_allowed_volume, max_allowed_volume);
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
}
|
|
||||||
|
|
||||||
void IAudioController::GetMainAppletExpectedMasterVolume(HLERequestContext& ctx) {
|
|
||||||
LOG_DEBUG(Service_AM, "called. main_applet_volume={}", main_applet_volume);
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
rb.Push(main_applet_volume);
|
|
||||||
}
|
|
||||||
|
|
||||||
void IAudioController::GetLibraryAppletExpectedMasterVolume(HLERequestContext& ctx) {
|
|
||||||
LOG_DEBUG(Service_AM, "called. library_applet_volume={}", library_applet_volume);
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
rb.Push(library_applet_volume);
|
|
||||||
}
|
|
||||||
|
|
||||||
void IAudioController::ChangeMainAppletMasterVolume(HLERequestContext& ctx) {
|
|
||||||
struct Parameters {
|
|
||||||
float volume;
|
|
||||||
s64 fade_time_ns;
|
|
||||||
};
|
|
||||||
static_assert(sizeof(Parameters) == 16);
|
|
||||||
|
|
||||||
IPC::RequestParser rp{ctx};
|
|
||||||
const auto parameters = rp.PopRaw<Parameters>();
|
|
||||||
|
|
||||||
LOG_DEBUG(Service_AM, "called. volume={}, fade_time_ns={}", parameters.volume,
|
|
||||||
parameters.fade_time_ns);
|
|
||||||
|
|
||||||
main_applet_volume = std::clamp(parameters.volume, min_allowed_volume, max_allowed_volume);
|
|
||||||
fade_time_ns = std::chrono::nanoseconds{parameters.fade_time_ns};
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
}
|
|
||||||
|
|
||||||
void IAudioController::SetTransparentAudioRate(HLERequestContext& ctx) {
|
|
||||||
IPC::RequestParser rp{ctx};
|
|
||||||
const float transparent_volume_rate_tmp = rp.Pop<float>();
|
|
||||||
|
|
||||||
LOG_DEBUG(Service_AM, "called. transparent_volume_rate={}", transparent_volume_rate_tmp);
|
|
||||||
|
|
||||||
// Clamp volume range to 0-100%.
|
|
||||||
transparent_volume_rate =
|
|
||||||
std::clamp(transparent_volume_rate_tmp, min_allowed_volume, max_allowed_volume);
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Service::AM
|
|
|
@ -1,36 +0,0 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include "core/hle/service/service.h"
|
|
||||||
|
|
||||||
namespace Service::AM {
|
|
||||||
|
|
||||||
class IAudioController final : public ServiceFramework<IAudioController> {
|
|
||||||
public:
|
|
||||||
explicit IAudioController(Core::System& system_);
|
|
||||||
~IAudioController() override;
|
|
||||||
|
|
||||||
private:
|
|
||||||
void SetExpectedMasterVolume(HLERequestContext& ctx);
|
|
||||||
void GetMainAppletExpectedMasterVolume(HLERequestContext& ctx);
|
|
||||||
void GetLibraryAppletExpectedMasterVolume(HLERequestContext& ctx);
|
|
||||||
void ChangeMainAppletMasterVolume(HLERequestContext& ctx);
|
|
||||||
void SetTransparentAudioRate(HLERequestContext& ctx);
|
|
||||||
|
|
||||||
static constexpr float min_allowed_volume = 0.0f;
|
|
||||||
static constexpr float max_allowed_volume = 1.0f;
|
|
||||||
|
|
||||||
float main_applet_volume{0.25f};
|
|
||||||
float library_applet_volume{max_allowed_volume};
|
|
||||||
float transparent_volume_rate{min_allowed_volume};
|
|
||||||
|
|
||||||
// Volume transition fade time in nanoseconds.
|
|
||||||
// e.g. If the main applet volume was 0% and was changed to 50%
|
|
||||||
// with a fade of 50ns, then over the course of 50ns,
|
|
||||||
// the volume will gradually fade up to 50%
|
|
||||||
std::chrono::nanoseconds fade_time_ns{0};
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace Service::AM
|
|
|
@ -3,7 +3,6 @@
|
||||||
|
|
||||||
#include "core/hle/service/am/applet_common_functions.h"
|
#include "core/hle/service/am/applet_common_functions.h"
|
||||||
#include "core/hle/service/am/application_functions.h"
|
#include "core/hle/service/am/application_functions.h"
|
||||||
#include "core/hle/service/am/audio_controller.h"
|
|
||||||
#include "core/hle/service/am/common_state_getter.h"
|
#include "core/hle/service/am/common_state_getter.h"
|
||||||
#include "core/hle/service/am/debug_functions.h"
|
#include "core/hle/service/am/debug_functions.h"
|
||||||
#include "core/hle/service/am/display_controller.h"
|
#include "core/hle/service/am/display_controller.h"
|
||||||
|
@ -12,6 +11,7 @@
|
||||||
#include "core/hle/service/am/process_winding_controller.h"
|
#include "core/hle/service/am/process_winding_controller.h"
|
||||||
#include "core/hle/service/am/self_controller.h"
|
#include "core/hle/service/am/self_controller.h"
|
||||||
#include "core/hle/service/am/service/application_proxy.h"
|
#include "core/hle/service/am/service/application_proxy.h"
|
||||||
|
#include "core/hle/service/am/service/audio_controller.h"
|
||||||
#include "core/hle/service/am/window_controller.h"
|
#include "core/hle/service/am/window_controller.h"
|
||||||
#include "core/hle/service/cmif_serialization.h"
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
|
|
||||||
|
|
69
src/core/hle/service/am/service/audio_controller.cpp
Normal file
69
src/core/hle/service/am/service/audio_controller.cpp
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#include "core/hle/service/am/service/audio_controller.h"
|
||||||
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
|
|
||||||
|
namespace Service::AM {
|
||||||
|
|
||||||
|
IAudioController::IAudioController(Core::System& system_)
|
||||||
|
: ServiceFramework{system_, "IAudioController"} {
|
||||||
|
// clang-format off
|
||||||
|
static const FunctionInfo functions[] = {
|
||||||
|
{0, D<&IAudioController::SetExpectedMasterVolume>, "SetExpectedMasterVolume"},
|
||||||
|
{1, D<&IAudioController::GetMainAppletExpectedMasterVolume>, "GetMainAppletExpectedMasterVolume"},
|
||||||
|
{2, D<&IAudioController::GetLibraryAppletExpectedMasterVolume>, "GetLibraryAppletExpectedMasterVolume"},
|
||||||
|
{3, D<&IAudioController::ChangeMainAppletMasterVolume>, "ChangeMainAppletMasterVolume"},
|
||||||
|
{4, D<&IAudioController::SetTransparentVolumeRate>, "SetTransparentVolumeRate"},
|
||||||
|
};
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
RegisterHandlers(functions);
|
||||||
|
}
|
||||||
|
|
||||||
|
IAudioController::~IAudioController() = default;
|
||||||
|
|
||||||
|
Result IAudioController::SetExpectedMasterVolume(f32 main_applet_volume,
|
||||||
|
f32 library_applet_volume) {
|
||||||
|
LOG_DEBUG(Service_AM, "called. main_applet_volume={}, library_applet_volume={}",
|
||||||
|
main_applet_volume, library_applet_volume);
|
||||||
|
|
||||||
|
// Ensure the volume values remain within the 0-100% range
|
||||||
|
m_main_applet_volume = std::clamp(main_applet_volume, MinAllowedVolume, MaxAllowedVolume);
|
||||||
|
m_library_applet_volume = std::clamp(library_applet_volume, MinAllowedVolume, MaxAllowedVolume);
|
||||||
|
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result IAudioController::GetMainAppletExpectedMasterVolume(Out<f32> out_main_applet_volume) {
|
||||||
|
LOG_DEBUG(Service_AM, "called. main_applet_volume={}", m_main_applet_volume);
|
||||||
|
*out_main_applet_volume = m_main_applet_volume;
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result IAudioController::GetLibraryAppletExpectedMasterVolume(Out<f32> out_library_applet_volume) {
|
||||||
|
LOG_DEBUG(Service_AM, "called. library_applet_volume={}", m_library_applet_volume);
|
||||||
|
*out_library_applet_volume = m_library_applet_volume;
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result IAudioController::ChangeMainAppletMasterVolume(f32 volume, s64 fade_time_ns) {
|
||||||
|
LOG_DEBUG(Service_AM, "called. volume={}, fade_time_ns={}", volume, fade_time_ns);
|
||||||
|
|
||||||
|
m_main_applet_volume = std::clamp(volume, MinAllowedVolume, MaxAllowedVolume);
|
||||||
|
m_fade_time_ns = std::chrono::nanoseconds{fade_time_ns};
|
||||||
|
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result IAudioController::SetTransparentVolumeRate(f32 transparent_volume_rate) {
|
||||||
|
LOG_DEBUG(Service_AM, "called. transparent_volume_rate={}", transparent_volume_rate);
|
||||||
|
|
||||||
|
// Clamp volume range to 0-100%.
|
||||||
|
m_transparent_volume_rate =
|
||||||
|
std::clamp(transparent_volume_rate, MinAllowedVolume, MaxAllowedVolume);
|
||||||
|
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::AM
|
37
src/core/hle/service/am/service/audio_controller.h
Normal file
37
src/core/hle/service/am/service/audio_controller.h
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "core/hle/service/cmif_types.h"
|
||||||
|
#include "core/hle/service/service.h"
|
||||||
|
|
||||||
|
namespace Service::AM {
|
||||||
|
|
||||||
|
class IAudioController final : public ServiceFramework<IAudioController> {
|
||||||
|
public:
|
||||||
|
explicit IAudioController(Core::System& system_);
|
||||||
|
~IAudioController() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Result SetExpectedMasterVolume(f32 main_applet_volume, f32 library_applet_volume);
|
||||||
|
Result GetMainAppletExpectedMasterVolume(Out<f32> out_main_applet_volume);
|
||||||
|
Result GetLibraryAppletExpectedMasterVolume(Out<f32> out_library_applet_volume);
|
||||||
|
Result ChangeMainAppletMasterVolume(f32 volume, s64 fade_time_ns);
|
||||||
|
Result SetTransparentVolumeRate(f32 transparent_volume_rate);
|
||||||
|
|
||||||
|
static constexpr float MinAllowedVolume = 0.0f;
|
||||||
|
static constexpr float MaxAllowedVolume = 1.0f;
|
||||||
|
|
||||||
|
float m_main_applet_volume{0.25f};
|
||||||
|
float m_library_applet_volume{MaxAllowedVolume};
|
||||||
|
float m_transparent_volume_rate{MinAllowedVolume};
|
||||||
|
|
||||||
|
// Volume transition fade time in nanoseconds.
|
||||||
|
// e.g. If the main applet volume was 0% and was changed to 50%
|
||||||
|
// with a fade of 50ns, then over the course of 50ns,
|
||||||
|
// the volume will gradually fade up to 50%
|
||||||
|
std::chrono::nanoseconds m_fade_time_ns{0};
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Service::AM
|
|
@ -2,7 +2,6 @@
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
#include "core/hle/service/am/applet_common_functions.h"
|
#include "core/hle/service/am/applet_common_functions.h"
|
||||||
#include "core/hle/service/am/audio_controller.h"
|
|
||||||
#include "core/hle/service/am/common_state_getter.h"
|
#include "core/hle/service/am/common_state_getter.h"
|
||||||
#include "core/hle/service/am/debug_functions.h"
|
#include "core/hle/service/am/debug_functions.h"
|
||||||
#include "core/hle/service/am/display_controller.h"
|
#include "core/hle/service/am/display_controller.h"
|
||||||
|
@ -12,6 +11,7 @@
|
||||||
#include "core/hle/service/am/library_applet_self_accessor.h"
|
#include "core/hle/service/am/library_applet_self_accessor.h"
|
||||||
#include "core/hle/service/am/process_winding_controller.h"
|
#include "core/hle/service/am/process_winding_controller.h"
|
||||||
#include "core/hle/service/am/self_controller.h"
|
#include "core/hle/service/am/self_controller.h"
|
||||||
|
#include "core/hle/service/am/service/audio_controller.h"
|
||||||
#include "core/hle/service/am/service/library_applet_proxy.h"
|
#include "core/hle/service/am/service/library_applet_proxy.h"
|
||||||
#include "core/hle/service/am/window_controller.h"
|
#include "core/hle/service/am/window_controller.h"
|
||||||
#include "core/hle/service/cmif_serialization.h"
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
|
|
|
@ -3,7 +3,6 @@
|
||||||
|
|
||||||
#include "core/hle/service/am/applet_common_functions.h"
|
#include "core/hle/service/am/applet_common_functions.h"
|
||||||
#include "core/hle/service/am/application_creator.h"
|
#include "core/hle/service/am/application_creator.h"
|
||||||
#include "core/hle/service/am/audio_controller.h"
|
|
||||||
#include "core/hle/service/am/common_state_getter.h"
|
#include "core/hle/service/am/common_state_getter.h"
|
||||||
#include "core/hle/service/am/debug_functions.h"
|
#include "core/hle/service/am/debug_functions.h"
|
||||||
#include "core/hle/service/am/display_controller.h"
|
#include "core/hle/service/am/display_controller.h"
|
||||||
|
@ -13,6 +12,7 @@
|
||||||
#include "core/hle/service/am/library_applet_self_accessor.h"
|
#include "core/hle/service/am/library_applet_self_accessor.h"
|
||||||
#include "core/hle/service/am/process_winding_controller.h"
|
#include "core/hle/service/am/process_winding_controller.h"
|
||||||
#include "core/hle/service/am/self_controller.h"
|
#include "core/hle/service/am/self_controller.h"
|
||||||
|
#include "core/hle/service/am/service/audio_controller.h"
|
||||||
#include "core/hle/service/am/service/system_applet_proxy.h"
|
#include "core/hle/service/am/service/system_applet_proxy.h"
|
||||||
#include "core/hle/service/am/window_controller.h"
|
#include "core/hle/service/am/window_controller.h"
|
||||||
#include "core/hle/service/cmif_serialization.h"
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
|
|
Loading…
Reference in a new issue