mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 11:56:42 +08:00 
			
		
		
		
	Merge pull request #2258 from lioncash/am
service/am: Supply remaining missing IAudioController functions
This commit is contained in:
		
						commit
						746167f11a
					
				| @ -2,10 +2,10 @@ | |||||||
| // Licensed under GPLv2 or any later version
 | // Licensed under GPLv2 or any later version
 | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
|  | #include <algorithm> | ||||||
| #include <array> | #include <array> | ||||||
| #include <cinttypes> | #include <cinttypes> | ||||||
| #include <cstring> | #include <cstring> | ||||||
| #include <stack> |  | ||||||
| #include "audio_core/audio_renderer.h" | #include "audio_core/audio_renderer.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/file_sys/savedata_factory.h" | #include "core/file_sys/savedata_factory.h" | ||||||
| @ -93,38 +93,84 @@ void IWindowController::AcquireForegroundRights(Kernel::HLERequestContext& ctx) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IAudioController::IAudioController() : ServiceFramework("IAudioController") { | IAudioController::IAudioController() : ServiceFramework("IAudioController") { | ||||||
|  |     // clang-format off
 | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {0, &IAudioController::SetExpectedMasterVolume, "SetExpectedMasterVolume"}, |         {0, &IAudioController::SetExpectedMasterVolume, "SetExpectedMasterVolume"}, | ||||||
|         {1, &IAudioController::GetMainAppletExpectedMasterVolume, |         {1, &IAudioController::GetMainAppletExpectedMasterVolume, "GetMainAppletExpectedMasterVolume"}, | ||||||
|          "GetMainAppletExpectedMasterVolume"}, |         {2, &IAudioController::GetLibraryAppletExpectedMasterVolume, "GetLibraryAppletExpectedMasterVolume"}, | ||||||
|         {2, &IAudioController::GetLibraryAppletExpectedMasterVolume, |         {3, &IAudioController::ChangeMainAppletMasterVolume, "ChangeMainAppletMasterVolume"}, | ||||||
|          "GetLibraryAppletExpectedMasterVolume"}, |         {4, &IAudioController::SetTransparentAudioRate, "SetTransparentVolumeRate"}, | ||||||
|         {3, nullptr, "ChangeMainAppletMasterVolume"}, |  | ||||||
|         {4, nullptr, "SetTransparentVolumeRate"}, |  | ||||||
|     }; |     }; | ||||||
|  |     // clang-format on
 | ||||||
|  | 
 | ||||||
|     RegisterHandlers(functions); |     RegisterHandlers(functions); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IAudioController::~IAudioController() = default; | IAudioController::~IAudioController() = default; | ||||||
| 
 | 
 | ||||||
| void IAudioController::SetExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | void IAudioController::SetExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_WARNING(Service_AM, "(STUBBED) called"); |     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}; |     IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IAudioController::GetMainAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | void IAudioController::GetMainAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_WARNING(Service_AM, "(STUBBED) called"); |     LOG_DEBUG(Service_AM, "called. main_applet_volume={}", main_applet_volume); | ||||||
|     IPC::ResponseBuilder rb{ctx, 3}; |     IPC::ResponseBuilder rb{ctx, 3}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.Push(volume); |     rb.Push(main_applet_volume); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IAudioController::GetLibraryAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | void IAudioController::GetLibraryAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_WARNING(Service_AM, "(STUBBED) called"); |     LOG_DEBUG(Service_AM, "called. library_applet_volume={}", library_applet_volume); | ||||||
|     IPC::ResponseBuilder rb{ctx, 3}; |     IPC::ResponseBuilder rb{ctx, 3}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.Push(volume); |     rb.Push(library_applet_volume); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void IAudioController::ChangeMainAppletMasterVolume(Kernel::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(RESULT_SUCCESS); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void IAudioController::SetTransparentAudioRate(Kernel::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(RESULT_SUCCESS); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IDisplayController::IDisplayController() : ServiceFramework("IDisplayController") { | IDisplayController::IDisplayController() : ServiceFramework("IDisplayController") { | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ | |||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include <chrono> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <queue> | #include <queue> | ||||||
| #include "core/hle/kernel/writable_event.h" | #include "core/hle/kernel/writable_event.h" | ||||||
| @ -81,8 +82,21 @@ private: | |||||||
|     void SetExpectedMasterVolume(Kernel::HLERequestContext& ctx); |     void SetExpectedMasterVolume(Kernel::HLERequestContext& ctx); | ||||||
|     void GetMainAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx); |     void GetMainAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx); | ||||||
|     void GetLibraryAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx); |     void GetLibraryAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx); | ||||||
|  |     void ChangeMainAppletMasterVolume(Kernel::HLERequestContext& ctx); | ||||||
|  |     void SetTransparentAudioRate(Kernel::HLERequestContext& ctx); | ||||||
| 
 | 
 | ||||||
|     u32 volume{100}; |     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}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class IDisplayController final : public ServiceFramework<IDisplayController> { | class IDisplayController final : public ServiceFramework<IDisplayController> { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user