forked from eden-emu/eden
		
	Merge pull request #4683 from Morph1984/NpadHandheldActivationMode-impl
hid: Implement Get/SetNpadHandheldActivationMode
This commit is contained in:
		
						commit
						24b421b14c
					
				
					 3 changed files with 28 additions and 5 deletions
				
			
		|  | @ -593,6 +593,14 @@ Controller_NPad::NpadHoldType Controller_NPad::GetHoldType() const { | ||||||
|     return hold_type; |     return hold_type; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void Controller_NPad::SetNpadHandheldActivationMode(NpadHandheldActivationMode activation_mode) { | ||||||
|  |     handheld_activation_mode = activation_mode; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | Controller_NPad::NpadHandheldActivationMode Controller_NPad::GetNpadHandheldActivationMode() const { | ||||||
|  |     return handheld_activation_mode; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void Controller_NPad::SetNpadMode(u32 npad_id, NPadAssignments assignment_mode) { | void Controller_NPad::SetNpadMode(u32 npad_id, NPadAssignments assignment_mode) { | ||||||
|     const std::size_t npad_index = NPadIdToIndex(npad_id); |     const std::size_t npad_index = NPadIdToIndex(npad_id); | ||||||
|     ASSERT(npad_index < shared_memory_entries.size()); |     ASSERT(npad_index < shared_memory_entries.size()); | ||||||
|  |  | ||||||
|  | @ -74,6 +74,12 @@ public: | ||||||
|         Single = 1, |         Single = 1, | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  |     enum class NpadHandheldActivationMode : u64 { | ||||||
|  |         Dual = 0, | ||||||
|  |         Single = 1, | ||||||
|  |         None = 2, | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     enum class NPadControllerType { |     enum class NPadControllerType { | ||||||
|         None, |         None, | ||||||
|         ProController, |         ProController, | ||||||
|  | @ -110,6 +116,9 @@ public: | ||||||
|     void SetHoldType(NpadHoldType joy_hold_type); |     void SetHoldType(NpadHoldType joy_hold_type); | ||||||
|     NpadHoldType GetHoldType() const; |     NpadHoldType GetHoldType() const; | ||||||
| 
 | 
 | ||||||
|  |     void SetNpadHandheldActivationMode(NpadHandheldActivationMode activation_mode); | ||||||
|  |     NpadHandheldActivationMode GetNpadHandheldActivationMode() const; | ||||||
|  | 
 | ||||||
|     void SetNpadMode(u32 npad_id, NPadAssignments assignment_mode); |     void SetNpadMode(u32 npad_id, NPadAssignments assignment_mode); | ||||||
| 
 | 
 | ||||||
|     void VibrateController(const std::vector<u32>& controller_ids, |     void VibrateController(const std::vector<u32>& controller_ids, | ||||||
|  | @ -369,6 +378,7 @@ private: | ||||||
|     MotionArray motions; |     MotionArray motions; | ||||||
|     std::vector<u32> supported_npad_id_types{}; |     std::vector<u32> supported_npad_id_types{}; | ||||||
|     NpadHoldType hold_type{NpadHoldType::Vertical}; |     NpadHoldType hold_type{NpadHoldType::Vertical}; | ||||||
|  |     NpadHandheldActivationMode handheld_activation_mode{NpadHandheldActivationMode::Dual}; | ||||||
|     // Each controller should have their own styleset changed event
 |     // Each controller should have their own styleset changed event
 | ||||||
|     std::array<Kernel::EventPair, 10> styleset_changed_events; |     std::array<Kernel::EventPair, 10> styleset_changed_events; | ||||||
|     Vibration last_processed_vibration{}; |     Vibration last_processed_vibration{}; | ||||||
|  |  | ||||||
|  | @ -739,8 +739,11 @@ void Hid::SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { | ||||||
|     const auto applet_resource_user_id{rp.Pop<u64>()}; |     const auto applet_resource_user_id{rp.Pop<u64>()}; | ||||||
|     const auto mode{rp.Pop<u64>()}; |     const auto mode{rp.Pop<u64>()}; | ||||||
| 
 | 
 | ||||||
|     LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}, mode={}", |     LOG_DEBUG(Service_HID, "called, applet_resource_user_id={}, mode={}", applet_resource_user_id, | ||||||
|                 applet_resource_user_id, mode); |               mode); | ||||||
|  | 
 | ||||||
|  |     applet_resource->GetController<Controller_NPad>(HidController::NPad) | ||||||
|  |         .SetNpadHandheldActivationMode(Controller_NPad::NpadHandheldActivationMode{mode}); | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2}; |     IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|  | @ -750,11 +753,13 @@ void Hid::GetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { | ||||||
|     IPC::RequestParser rp{ctx}; |     IPC::RequestParser rp{ctx}; | ||||||
|     const auto applet_resource_user_id{rp.Pop<u64>()}; |     const auto applet_resource_user_id{rp.Pop<u64>()}; | ||||||
| 
 | 
 | ||||||
|     LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}", |     LOG_DEBUG(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id); | ||||||
|                 applet_resource_user_id); |  | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2}; |     IPC::ResponseBuilder rb{ctx, 4}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|  |     rb.Push<u64>( | ||||||
|  |         static_cast<u64>(applet_resource->GetController<Controller_NPad>(HidController::NPad) | ||||||
|  |                              .GetNpadHandheldActivationMode())); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Hid::SwapNpadAssignment(Kernel::HLERequestContext& ctx) { | void Hid::SwapNpadAssignment(Kernel::HLERequestContext& ctx) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei