diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/hle/service/hid/controllers/npad.cpp | 8 | ||||
| -rw-r--r-- | src/core/hle/service/hid/controllers/npad.h | 10 | ||||
| -rw-r--r-- | src/core/hle/service/hid/hid.cpp | 135 | ||||
| -rw-r--r-- | src/core/hle/service/hid/hid.h | 15 | 
4 files changed, 141 insertions, 27 deletions
diff --git a/src/core/hle/service/hid/controllers/npad.cpp b/src/core/hle/service/hid/controllers/npad.cpp index c55d900e2..6fbee7efa 100644 --- a/src/core/hle/service/hid/controllers/npad.cpp +++ b/src/core/hle/service/hid/controllers/npad.cpp @@ -566,6 +566,14 @@ void Controller_NPad::DisconnectNPad(u32 npad_id) {      connected_controllers[NPadIdToIndex(npad_id)].is_connected = false;  } +void Controller_NPad::SetGyroscopeZeroDriftMode(GyroscopeZeroDriftMode drift_mode) { +    gyroscope_zero_drift_mode = drift_mode; +} + +Controller_NPad::GyroscopeZeroDriftMode Controller_NPad::GetGyroscopeZeroDriftMode() const { +    return gyroscope_zero_drift_mode; +} +  void Controller_NPad::StartLRAssignmentMode() {      // Nothing internally is used for lr assignment mode. Since we have the ability to set the      // controller types from boot, it doesn't really matter about showing a selection screen diff --git a/src/core/hle/service/hid/controllers/npad.h b/src/core/hle/service/hid/controllers/npad.h index 931f03430..5d4c58a43 100644 --- a/src/core/hle/service/hid/controllers/npad.h +++ b/src/core/hle/service/hid/controllers/npad.h @@ -58,6 +58,12 @@ public:      };      static_assert(sizeof(Vibration) == 0x10, "Vibration is an invalid size"); +    enum class GyroscopeZeroDriftMode : u32 { +        Loose = 0, +        Standard = 1, +        Tight = 2, +    }; +      enum class NpadHoldType : u64 {          Vertical = 0,          Horizontal = 1, @@ -117,6 +123,8 @@ public:      void ConnectNPad(u32 npad_id);      void DisconnectNPad(u32 npad_id); +    void SetGyroscopeZeroDriftMode(GyroscopeZeroDriftMode drift_mode); +    GyroscopeZeroDriftMode GetGyroscopeZeroDriftMode() const;      LedPattern GetLedPattern(u32 npad_id);      void SetVibrationEnabled(bool can_vibrate);      bool IsVibrationEnabled() const; @@ -324,8 +332,8 @@ private:      std::array<Kernel::EventPair, 10> styleset_changed_events;      Vibration last_processed_vibration{};      std::array<ControllerHolder, 10> connected_controllers{}; +    GyroscopeZeroDriftMode gyroscope_zero_drift_mode{GyroscopeZeroDriftMode::Standard};      bool can_controllers_vibrate{true}; -      std::array<ControllerPad, 10> npad_pad_states{};      bool is_in_lr_assignment_mode{false};      Core::System& system; diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp index 72a050de2..57d5edea7 100644 --- a/src/core/hle/service/hid/hid.cpp +++ b/src/core/hle/service/hid/hid.cpp @@ -185,8 +185,8 @@ Hid::Hid(Core::System& system) : ServiceFramework("hid"), system(system) {          {77, nullptr, "GetAccelerometerPlayMode"},          {78, nullptr, "ResetAccelerometerPlayMode"},          {79, &Hid::SetGyroscopeZeroDriftMode, "SetGyroscopeZeroDriftMode"}, -        {80, nullptr, "GetGyroscopeZeroDriftMode"}, -        {81, nullptr, "ResetGyroscopeZeroDriftMode"}, +        {80, &Hid::GetGyroscopeZeroDriftMode, "GetGyroscopeZeroDriftMode"}, +        {81, &Hid::ResetGyroscopeZeroDriftMode, "ResetGyroscopeZeroDriftMode"},          {82, &Hid::IsSixAxisSensorAtRest, "IsSixAxisSensorAtRest"},          {83, nullptr, "IsFirmwareUpdateAvailableForSixAxisSensor"},          {91, &Hid::ActivateGesture, "ActivateGesture"}, @@ -230,15 +230,15 @@ Hid::Hid(Core::System& system) : ServiceFramework("hid"), system(system) {          {211, nullptr, "IsVibrationDeviceMounted"},          {300, &Hid::ActivateConsoleSixAxisSensor, "ActivateConsoleSixAxisSensor"},          {301, &Hid::StartConsoleSixAxisSensor, "StartConsoleSixAxisSensor"}, -        {302, nullptr, "StopConsoleSixAxisSensor"}, -        {303, nullptr, "ActivateSevenSixAxisSensor"}, -        {304, nullptr, "StartSevenSixAxisSensor"}, +        {302, &Hid::StopConsoleSixAxisSensor, "StopConsoleSixAxisSensor"}, +        {303, &Hid::ActivateSevenSixAxisSensor, "ActivateSevenSixAxisSensor"}, +        {304, &Hid::StartSevenSixAxisSensor, "StartSevenSixAxisSensor"},          {305, &Hid::StopSevenSixAxisSensor, "StopSevenSixAxisSensor"},          {306, &Hid::InitializeSevenSixAxisSensor, "InitializeSevenSixAxisSensor"}, -        {307, nullptr, "FinalizeSevenSixAxisSensor"}, +        {307, &Hid::FinalizeSevenSixAxisSensor, "FinalizeSevenSixAxisSensor"},          {308, nullptr, "SetSevenSixAxisSensorFusionStrength"},          {309, nullptr, "GetSevenSixAxisSensorFusionStrength"}, -        {310, nullptr, "ResetSevenSixAxisSensorTimestamp"}, +        {310, &Hid::ResetSevenSixAxisSensorTimestamp, "ResetSevenSixAxisSensorTimestamp"},          {400, nullptr, "IsUsbFullKeyControllerEnabled"},          {401, nullptr, "EnableUsbFullKeyController"},          {402, nullptr, "IsUsbFullKeyControllerConnected"}, @@ -374,6 +374,15 @@ void Hid::ActivateKeyboard(Kernel::HLERequestContext& ctx) {      rb.Push(RESULT_SUCCESS);  } +void Hid::SendKeyboardLockKeyEvent(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto flags{rp.Pop<u32>()}; +    LOG_WARNING(Service_HID, "(STUBBED) called. flags={}", flags); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} +  void Hid::ActivateGesture(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx};      const auto unknown{rp.Pop<u32>()}; @@ -413,15 +422,59 @@ void Hid::StartSixAxisSensor(Kernel::HLERequestContext& ctx) {      rb.Push(RESULT_SUCCESS);  } +void Hid::StopSixAxisSensor(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto handle{rp.Pop<u32>()}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; + +    LOG_WARNING(Service_HID, "(STUBBED) called, handle={}, applet_resource_user_id={}", handle, +                applet_resource_user_id); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} +  void Hid::SetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx};      const auto handle{rp.Pop<u32>()};      const auto drift_mode{rp.Pop<u32>()};      const auto applet_resource_user_id{rp.Pop<u64>()}; -    LOG_WARNING(Service_HID, -                "(STUBBED) called, handle={}, drift_mode={}, applet_resource_user_id={}", handle, -                drift_mode, applet_resource_user_id); +    applet_resource->GetController<Controller_NPad>(HidController::NPad) +        .SetGyroscopeZeroDriftMode(Controller_NPad::GyroscopeZeroDriftMode{drift_mode}); + +    LOG_DEBUG(Service_HID, "called, handle={}, drift_mode={}, applet_resource_user_id={}", handle, +              drift_mode, applet_resource_user_id); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} + +void Hid::GetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto handle{rp.Pop<u32>()}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; + +    LOG_DEBUG(Service_HID, "called, handle={}, applet_resource_user_id={}", handle, +              applet_resource_user_id); + +    IPC::ResponseBuilder rb{ctx, 3}; +    rb.Push(RESULT_SUCCESS); +    rb.Push<u32>( +        static_cast<u32>(applet_resource->GetController<Controller_NPad>(HidController::NPad) +                             .GetGyroscopeZeroDriftMode())); +} + +void Hid::ResetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto handle{rp.Pop<u32>()}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; + +    applet_resource->GetController<Controller_NPad>(HidController::NPad) +        .SetGyroscopeZeroDriftMode(Controller_NPad::GyroscopeZeroDriftMode::Standard); + +    LOG_DEBUG(Service_HID, "called, handle={}, applet_resource_user_id={}", handle, +              applet_resource_user_id);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS); @@ -832,33 +885,35 @@ void Hid::StartConsoleSixAxisSensor(Kernel::HLERequestContext& ctx) {      rb.Push(RESULT_SUCCESS);  } -void Hid::StopSixAxisSensor(Kernel::HLERequestContext& ctx) { +void Hid::StopConsoleSixAxisSensor(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx};      const auto handle{rp.Pop<u32>()}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; -    LOG_WARNING(Service_HID, "(STUBBED) called, handle={}", handle); +    LOG_WARNING(Service_HID, "(STUBBED) called, handle={}, applet_resource_user_id={}", handle, +                applet_resource_user_id);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS);  } -void Hid::SetIsPalmaAllConnectable(Kernel::HLERequestContext& ctx) { +void Hid::ActivateSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx};      const auto applet_resource_user_id{rp.Pop<u64>()}; -    const auto unknown{rp.Pop<u32>()}; -    LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}, unknown={}", -                applet_resource_user_id, unknown); +    LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}", +                applet_resource_user_id);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS);  } -void Hid::SetPalmaBoostMode(Kernel::HLERequestContext& ctx) { +void Hid::StartSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx}; -    const auto unknown{rp.Pop<u32>()}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; -    LOG_WARNING(Service_HID, "(STUBBED) called, unknown={}", unknown); +    LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}", +                applet_resource_user_id);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS); @@ -882,10 +937,46 @@ void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {      rb.Push(RESULT_SUCCESS);  } -void Hid::SendKeyboardLockKeyEvent(Kernel::HLERequestContext& ctx) { +void Hid::FinalizeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {      IPC::RequestParser rp{ctx}; -    const auto flags{rp.Pop<u32>()}; -    LOG_WARNING(Service_HID, "(STUBBED) called. flags={}", flags); +    const auto applet_resource_user_id{rp.Pop<u64>()}; + +    LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}", +                applet_resource_user_id); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} + +void Hid::ResetSevenSixAxisSensorTimestamp(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; + +    LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}", +                applet_resource_user_id); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} + +void Hid::SetIsPalmaAllConnectable(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; +    const auto is_palma_all_connectable{rp.Pop<bool>()}; + +    LOG_WARNING(Service_HID, +                "(STUBBED) called, applet_resource_user_id={}, is_palma_all_connectable={}", +                applet_resource_user_id, is_palma_all_connectable); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(RESULT_SUCCESS); +} + +void Hid::SetPalmaBoostMode(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto palma_boost_mode{rp.Pop<bool>()}; + +    LOG_WARNING(Service_HID, "(STUBBED) called, palma_boost_mode={}", palma_boost_mode);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS); diff --git a/src/core/hle/service/hid/hid.h b/src/core/hle/service/hid/hid.h index d481a75f8..6fb048360 100644 --- a/src/core/hle/service/hid/hid.h +++ b/src/core/hle/service/hid/hid.h @@ -91,10 +91,14 @@ private:      void ActivateTouchScreen(Kernel::HLERequestContext& ctx);      void ActivateMouse(Kernel::HLERequestContext& ctx);      void ActivateKeyboard(Kernel::HLERequestContext& ctx); +    void SendKeyboardLockKeyEvent(Kernel::HLERequestContext& ctx);      void ActivateGesture(Kernel::HLERequestContext& ctx);      void ActivateNpadWithRevision(Kernel::HLERequestContext& ctx);      void StartSixAxisSensor(Kernel::HLERequestContext& ctx); +    void StopSixAxisSensor(Kernel::HLERequestContext& ctx);      void SetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx); +    void GetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx); +    void ResetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx);      void IsSixAxisSensorAtRest(Kernel::HLERequestContext& ctx);      void SetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx);      void GetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx); @@ -126,12 +130,15 @@ private:      void IsVibrationPermitted(Kernel::HLERequestContext& ctx);      void ActivateConsoleSixAxisSensor(Kernel::HLERequestContext& ctx);      void StartConsoleSixAxisSensor(Kernel::HLERequestContext& ctx); -    void StopSixAxisSensor(Kernel::HLERequestContext& ctx); -    void SetIsPalmaAllConnectable(Kernel::HLERequestContext& ctx); -    void SetPalmaBoostMode(Kernel::HLERequestContext& ctx); +    void StopConsoleSixAxisSensor(Kernel::HLERequestContext& ctx); +    void ActivateSevenSixAxisSensor(Kernel::HLERequestContext& ctx); +    void StartSevenSixAxisSensor(Kernel::HLERequestContext& ctx);      void StopSevenSixAxisSensor(Kernel::HLERequestContext& ctx);      void InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx); -    void SendKeyboardLockKeyEvent(Kernel::HLERequestContext& ctx); +    void FinalizeSevenSixAxisSensor(Kernel::HLERequestContext& ctx); +    void ResetSevenSixAxisSensorTimestamp(Kernel::HLERequestContext& ctx); +    void SetIsPalmaAllConnectable(Kernel::HLERequestContext& ctx); +    void SetPalmaBoostMode(Kernel::HLERequestContext& ctx);      std::shared_ptr<IAppletResource> applet_resource;      Core::System& system;  | 
