summaryrefslogtreecommitdiffstats
path: root/src/hid_core/resources/npad/npad.cpp
diff options
context:
space:
mode:
authorliamwhite <liamwhite@users.noreply.github.com>2024-02-03 17:10:14 +0100
committerGitHub <noreply@github.com>2024-02-03 17:10:14 +0100
commit25f3d358b12a7108adb8e19fb263dbcd796324a5 (patch)
treed290132490d074cec7bc61f3621a51b25ede8d24 /src/hid_core/resources/npad/npad.cpp
parentMerge pull request #12852 from Calinou/multiplayer-color-player-counts (diff)
parentservice: hid: Multiple fixes (diff)
downloadyuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar.gz
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar.bz2
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar.lz
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar.xz
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.tar.zst
yuzu-25f3d358b12a7108adb8e19fb263dbcd796324a5.zip
Diffstat (limited to '')
-rw-r--r--src/hid_core/resources/npad/npad.cpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/src/hid_core/resources/npad/npad.cpp b/src/hid_core/resources/npad/npad.cpp
index 1a58eff4a..fe3fdc5cd 100644
--- a/src/hid_core/resources/npad/npad.cpp
+++ b/src/hid_core/resources/npad/npad.cpp
@@ -102,6 +102,8 @@ Result NPad::Activate(u64 aruid) {
for (std::size_t i = 0; i < 19; ++i) {
WriteEmptyEntry(npad);
}
+
+ controller.is_active = true;
}
return ResultSuccess;
@@ -467,6 +469,13 @@ void NPad::OnUpdate(const Core::Timing::CoreTiming& core_timing) {
continue;
}
+ bool is_set{};
+ npad_resource.IsSupportedNpadStyleSet(is_set, aruid);
+ // Wait until style is defined
+ if (!is_set) {
+ continue;
+ }
+
for (std::size_t i = 0; i < controller_data[aruid_index].size(); ++i) {
auto& controller = controller_data[aruid_index][i];
controller.shared_memory =
@@ -484,6 +493,10 @@ void NPad::OnUpdate(const Core::Timing::CoreTiming& core_timing) {
continue;
}
+ if (!controller.is_active) {
+ continue;
+ }
+
RequestPadStateUpdate(aruid, controller.device->GetNpadIdType());
auto& pad_state = controller.npad_pad_state;
auto& libnx_state = controller.npad_libnx_state;
@@ -592,7 +605,9 @@ void NPad::OnUpdate(const Core::Timing::CoreTiming& core_timing) {
libnx_state.npad_buttons.raw = pad_state.npad_buttons.raw;
libnx_state.l_stick = pad_state.l_stick;
libnx_state.r_stick = pad_state.r_stick;
- npad->system_ext_lifo.WriteNextEntry(pad_state);
+ libnx_state.sampling_number =
+ npad->system_ext_lifo.ReadCurrentEntry().state.sampling_number + 1;
+ npad->system_ext_lifo.WriteNextEntry(libnx_state);
press_state |= static_cast<u64>(pad_state.npad_buttons.raw);
}
@@ -1060,6 +1075,7 @@ void NPad::UnregisterAppletResourceUserId(u64 aruid) {
// TODO: Remove this once abstract pad is emulated properly
const auto aruid_index = npad_resource.GetIndexFromAruid(aruid);
for (auto& controller : controller_data[aruid_index]) {
+ controller.is_active = false;
controller.is_connected = false;
controller.shared_memory = nullptr;
}