diff options
author | liamwhite <liamwhite@users.noreply.github.com> | 2023-02-28 01:46:10 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-28 01:46:10 +0100 |
commit | 22432668be6d34b5a5275bcc631cadf512f36bf9 (patch) | |
tree | 88aeebd3448ad8fa701914839c0b1f3c876c62ac /src/core/hle/service/hid/hid.h | |
parent | Merge pull request #9874 from german77/violet (diff) | |
parent | am: avoid direct pointer access of transfer memory objects (diff) | |
download | yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar.gz yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar.bz2 yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar.lz yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar.xz yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.tar.zst yuzu-22432668be6d34b5a5275bcc631cadf512f36bf9.zip |
Diffstat (limited to 'src/core/hle/service/hid/hid.h')
-rw-r--r-- | src/core/hle/service/hid/hid.h | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/src/core/hle/service/hid/hid.h b/src/core/hle/service/hid/hid.h index 8fc9ed88a..9ace83129 100644 --- a/src/core/hle/service/hid/hid.h +++ b/src/core/hle/service/hid/hid.h @@ -61,9 +61,15 @@ public: private: template <typename T> void MakeController(HidController controller, u8* shared_memory) { - controllers[static_cast<std::size_t>(controller)] = - std::make_unique<T>(system.HIDCore(), shared_memory); + if constexpr (std::is_constructible_v<T, Core::System&, u8*>) { + controllers[static_cast<std::size_t>(controller)] = + std::make_unique<T>(system, shared_memory); + } else { + controllers[static_cast<std::size_t>(controller)] = + std::make_unique<T>(system.HIDCore(), shared_memory); + } } + template <typename T> void MakeControllerWithServiceContext(HidController controller, u8* shared_memory) { controllers[static_cast<std::size_t>(controller)] = |