summaryrefslogtreecommitdiff
path: root/src/core/hle
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/hle')
-rw-r--r--src/core/hle/service/audio/audren_u.cpp53
-rw-r--r--src/core/hle/service/audio/audren_u.h2
-rw-r--r--src/core/hle/service/hid/hid.cpp8
-rw-r--r--src/core/hle/service/ns/pl_u.cpp10
-rw-r--r--src/core/hle/service/ns/pl_u.h1
5 files changed, 66 insertions, 8 deletions
diff --git a/src/core/hle/service/audio/audren_u.cpp b/src/core/hle/service/audio/audren_u.cpp
index 1cbca6c4b..f52cd7d90 100644
--- a/src/core/hle/service/audio/audren_u.cpp
+++ b/src/core/hle/service/audio/audren_u.cpp
@@ -151,12 +151,52 @@ private:
151 Kernel::SharedPtr<Kernel::Event> system_event; 151 Kernel::SharedPtr<Kernel::Event> system_event;
152}; 152};
153 153
154class IAudioDevice final : public ServiceFramework<IAudioDevice> {
155public:
156 IAudioDevice() : ServiceFramework("IAudioDevice") {
157 static const FunctionInfo functions[] = {
158 {0x0, &IAudioDevice::ListAudioDeviceName, "ListAudioDeviceName"},
159 {0x1, &IAudioDevice::SetAudioDeviceOutputVolume, "SetAudioDeviceOutputVolume"}};
160 RegisterHandlers(functions);
161
162 buffer_event =
163 Kernel::Event::Create(Kernel::ResetType::OneShot, "IAudioOutBufferReleasedEvent");
164 }
165
166private:
167 void ListAudioDeviceName(Kernel::HLERequestContext& ctx) {
168 LOG_WARNING(Service_Audio, "(STUBBED) called");
169 IPC::RequestParser rp{ctx};
170
171 const std::string audio_interface = "AudioInterface";
172 ctx.WriteBuffer(audio_interface.c_str(), audio_interface.size());
173
174 IPC::ResponseBuilder rb = rp.MakeBuilder(3, 0, 0);
175 rb.Push(RESULT_SUCCESS);
176 rb.Push<u32>(1);
177 }
178
179 void SetAudioDeviceOutputVolume(Kernel::HLERequestContext& ctx) {
180 LOG_WARNING(Service_Audio, "(STUBBED) called");
181
182 IPC::RequestParser rp{ctx};
183 f32 volume = static_cast<f32>(rp.Pop<u32>());
184
185 auto file_buffer = ctx.ReadBuffer();
186 auto end = std::find(file_buffer.begin(), file_buffer.end(), '\0');
187
188 IPC::ResponseBuilder rb = rp.MakeBuilder(2, 0, 0);
189 rb.Push(RESULT_SUCCESS);
190 }
191
192 Kernel::SharedPtr<Kernel::Event> buffer_event;
193};
194
154AudRenU::AudRenU() : ServiceFramework("audren:u") { 195AudRenU::AudRenU() : ServiceFramework("audren:u") {
155 static const FunctionInfo functions[] = { 196 static const FunctionInfo functions[] = {
156 {0, &AudRenU::OpenAudioRenderer, "OpenAudioRenderer"}, 197 {0, &AudRenU::OpenAudioRenderer, "OpenAudioRenderer"},
157 {1, &AudRenU::GetAudioRendererWorkBufferSize, "GetAudioRendererWorkBufferSize"}, 198 {1, &AudRenU::GetAudioRendererWorkBufferSize, "GetAudioRendererWorkBufferSize"},
158 {2, &AudRenU::GetAudioRenderersProcessMasterVolume, "GetAudioRenderersProcessMasterVolume"}, 199 {2, &AudRenU::GetAudioDevice, "GetAudioDevice"},
159 {3, nullptr, "SetAudioRenderersProcessMasterVolume"},
160 }; 200 };
161 RegisterHandlers(functions); 201 RegisterHandlers(functions);
162} 202}
@@ -179,12 +219,13 @@ void AudRenU::GetAudioRendererWorkBufferSize(Kernel::HLERequestContext& ctx) {
179 LOG_WARNING(Service_Audio, "(STUBBED) called"); 219 LOG_WARNING(Service_Audio, "(STUBBED) called");
180} 220}
181 221
182void AudRenU::GetAudioRenderersProcessMasterVolume(Kernel::HLERequestContext& ctx) { 222void AudRenU::GetAudioDevice(Kernel::HLERequestContext& ctx) {
183 IPC::ResponseBuilder rb{ctx, 3}; 223 IPC::ResponseBuilder rb{ctx, 2, 0, 1};
184 224
185 rb.Push(RESULT_SUCCESS); 225 rb.Push(RESULT_SUCCESS);
186 rb.Push<u32>(100); 226 rb.PushIpcInterface<Audio::IAudioDevice>();
187 LOG_WARNING(Service_Audio, "(STUBBED) called"); 227
228 LOG_DEBUG(Service_Audio, "called");
188} 229}
189 230
190} // namespace Audio 231} // namespace Audio
diff --git a/src/core/hle/service/audio/audren_u.h b/src/core/hle/service/audio/audren_u.h
index 939d353a9..f59d1627d 100644
--- a/src/core/hle/service/audio/audren_u.h
+++ b/src/core/hle/service/audio/audren_u.h
@@ -21,7 +21,7 @@ public:
21private: 21private:
22 void OpenAudioRenderer(Kernel::HLERequestContext& ctx); 22 void OpenAudioRenderer(Kernel::HLERequestContext& ctx);
23 void GetAudioRendererWorkBufferSize(Kernel::HLERequestContext& ctx); 23 void GetAudioRendererWorkBufferSize(Kernel::HLERequestContext& ctx);
24 void GetAudioRenderersProcessMasterVolume(Kernel::HLERequestContext& ctx); 24 void GetAudioDevice(Kernel::HLERequestContext& ctx);
25}; 25};
26 26
27} // namespace Audio 27} // namespace Audio
diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp
index 7e04ad8d4..a0b8c6243 100644
--- a/src/core/hle/service/hid/hid.cpp
+++ b/src/core/hle/service/hid/hid.cpp
@@ -193,7 +193,7 @@ public:
193 {121, &Hid::GetNpadJoyHoldType, "GetNpadJoyHoldType"}, 193 {121, &Hid::GetNpadJoyHoldType, "GetNpadJoyHoldType"},
194 {122, &Hid::SetNpadJoyAssignmentModeSingleByDefault, 194 {122, &Hid::SetNpadJoyAssignmentModeSingleByDefault,
195 "SetNpadJoyAssignmentModeSingleByDefault"}, 195 "SetNpadJoyAssignmentModeSingleByDefault"},
196 {124, nullptr, "SetNpadJoyAssignmentModeDual"}, 196 {124, &Hid::SetNpadJoyAssignmentModeDual, "SetNpadJoyAssignmentModeDual"},
197 {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"}, 197 {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"},
198 {200, &Hid::GetVibrationDeviceInfo, "GetVibrationDeviceInfo"}, 198 {200, &Hid::GetVibrationDeviceInfo, "GetVibrationDeviceInfo"},
199 {201, &Hid::SendVibrationValue, "SendVibrationValue"}, 199 {201, &Hid::SendVibrationValue, "SendVibrationValue"},
@@ -315,6 +315,12 @@ private:
315 LOG_WARNING(Service_HID, "(STUBBED) called"); 315 LOG_WARNING(Service_HID, "(STUBBED) called");
316 } 316 }
317 317
318 void SetNpadJoyAssignmentModeDual(Kernel::HLERequestContext& ctx) {
319 IPC::ResponseBuilder rb{ctx, 2};
320 rb.Push(RESULT_SUCCESS);
321 LOG_WARNING(Service_HID, "(STUBBED) called");
322 }
323
318 void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { 324 void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) {
319 IPC::ResponseBuilder rb{ctx, 2}; 325 IPC::ResponseBuilder rb{ctx, 2};
320 rb.Push(RESULT_SUCCESS); 326 rb.Push(RESULT_SUCCESS);
diff --git a/src/core/hle/service/ns/pl_u.cpp b/src/core/hle/service/ns/pl_u.cpp
index 695e295ca..ef3c7799a 100644
--- a/src/core/hle/service/ns/pl_u.cpp
+++ b/src/core/hle/service/ns/pl_u.cpp
@@ -33,6 +33,7 @@ enum class LoadState : u32 {
33 33
34PL_U::PL_U() : ServiceFramework("pl:u") { 34PL_U::PL_U() : ServiceFramework("pl:u") {
35 static const FunctionInfo functions[] = { 35 static const FunctionInfo functions[] = {
36 {0, &PL_U::RequestLoad, "RequestLoad"},
36 {1, &PL_U::GetLoadState, "GetLoadState"}, 37 {1, &PL_U::GetLoadState, "GetLoadState"},
37 {2, &PL_U::GetSize, "GetSize"}, 38 {2, &PL_U::GetSize, "GetSize"},
38 {3, &PL_U::GetSharedMemoryAddressOffset, "GetSharedMemoryAddressOffset"}, 39 {3, &PL_U::GetSharedMemoryAddressOffset, "GetSharedMemoryAddressOffset"},
@@ -54,6 +55,15 @@ PL_U::PL_U() : ServiceFramework("pl:u") {
54 } 55 }
55} 56}
56 57
58void PL_U::RequestLoad(Kernel::HLERequestContext& ctx) {
59 IPC::RequestParser rp{ctx};
60 const u32 shared_font_type{rp.Pop<u32>()};
61
62 LOG_DEBUG(Service_NS, "called, shared_font_type=%d", shared_font_type);
63 IPC::ResponseBuilder rb{ctx, 2};
64 rb.Push(RESULT_SUCCESS);
65}
66
57void PL_U::GetLoadState(Kernel::HLERequestContext& ctx) { 67void PL_U::GetLoadState(Kernel::HLERequestContext& ctx) {
58 IPC::RequestParser rp{ctx}; 68 IPC::RequestParser rp{ctx};
59 const u32 font_id{rp.Pop<u32>()}; 69 const u32 font_id{rp.Pop<u32>()};
diff --git a/src/core/hle/service/ns/pl_u.h b/src/core/hle/service/ns/pl_u.h
index 7a4766338..360482d13 100644
--- a/src/core/hle/service/ns/pl_u.h
+++ b/src/core/hle/service/ns/pl_u.h
@@ -17,6 +17,7 @@ public:
17 ~PL_U() = default; 17 ~PL_U() = default;
18 18
19private: 19private:
20 void RequestLoad(Kernel::HLERequestContext& ctx);
20 void GetLoadState(Kernel::HLERequestContext& ctx); 21 void GetLoadState(Kernel::HLERequestContext& ctx);
21 void GetSize(Kernel::HLERequestContext& ctx); 22 void GetSize(Kernel::HLERequestContext& ctx);
22 void GetSharedMemoryAddressOffset(Kernel::HLERequestContext& ctx); 23 void GetSharedMemoryAddressOffset(Kernel::HLERequestContext& ctx);