service: hid: Don't try to vibrate if device isn't initialized

This commit is contained in:
Narr the Reg 2024-01-25 23:46:00 -06:00
parent e04368ad7c
commit f2012e5aff
3 changed files with 9 additions and 0 deletions

View file

@ -373,6 +373,10 @@ Result ResourceManager::SendVibrationValue(u64 aruid,
device = GetNSVibrationDevice(handle);
}
if (device != nullptr) {
// Prevent sending vibrations to an inactive vibration handle
if (!device->IsActive()) {
return ResultSuccess;
}
result = device->SendVibrationValue(value);
}
return result;

View file

@ -23,6 +23,10 @@ Result NpadVibrationBase::Deactivate() {
return ResultSuccess;
}
bool NpadVibrationBase::IsActive() const {
return ref_counter > 0;
}
bool NpadVibrationBase::IsVibrationMounted() const {
return is_mounted;
}

View file

@ -21,6 +21,7 @@ public:
virtual Result Activate();
virtual Result Deactivate();
bool IsActive() const;
bool IsVibrationMounted() const;
protected: