| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | #include <atomic>
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | #include "core/core_timing.h"
 | 
					
						
							|  |  |  | #include "core/frontend/input.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | #include "core/hle/ipc_helpers.h"
 | 
					
						
							|  |  |  | #include "core/hle/kernel/client_port.h"
 | 
					
						
							|  |  |  | #include "core/hle/kernel/client_session.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  | #include "core/hle/kernel/event.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | #include "core/hle/kernel/shared_memory.h"
 | 
					
						
							| 
									
										
										
										
											2016-09-20 23:52:38 -07:00
										 |  |  | #include "core/hle/service/hid/hid.h"
 | 
					
						
							| 
									
										
										
										
											2016-09-21 00:21:23 +09:00
										 |  |  | #include "core/hle/service/service.h"
 | 
					
						
							| 
									
										
										
										
											2015-03-09 00:14:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | namespace Service::HID { | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | // Updating period for each HID device.
 | 
					
						
							|  |  |  | // TODO(shinyquagsire23): These need better values.
 | 
					
						
							| 
									
										
										
										
											2018-07-15 13:47:41 -06:00
										 |  |  | constexpr u64 pad_update_ticks = CoreTiming::BASE_CLOCK_RATE / 100; | 
					
						
							|  |  |  | constexpr u64 accelerometer_update_ticks = CoreTiming::BASE_CLOCK_RATE / 100; | 
					
						
							|  |  |  | constexpr u64 gyroscope_update_ticks = CoreTiming::BASE_CLOCK_RATE / 100; | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | class IAppletResource final : public ServiceFramework<IAppletResource> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     IAppletResource() : ServiceFramework("IAppletResource") { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &IAppletResource::GetSharedMemoryHandle, "GetSharedMemoryHandle"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |         shared_mem = Kernel::SharedMemory::Create( | 
					
						
							|  |  |  |             nullptr, 0x40000, Kernel::MemoryPermission::ReadWrite, Kernel::MemoryPermission::Read, | 
					
						
							|  |  |  |             0, Kernel::MemoryRegion::BASE, "HID:SharedMemory"); | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Register update callbacks
 | 
					
						
							|  |  |  |         pad_update_event = CoreTiming::RegisterEvent( | 
					
						
							|  |  |  |             "HID::UpdatePadCallback", | 
					
						
							|  |  |  |             [this](u64 userdata, int cycles_late) { UpdatePadCallback(userdata, cycles_late); }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TODO(shinyquagsire23): Other update callbacks? (accel, gyro?)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         CoreTiming::ScheduleEvent(pad_update_ticks, pad_update_event); | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-04 10:34:25 -05:00
										 |  |  |     ~IAppletResource() { | 
					
						
							|  |  |  |         CoreTiming::UnscheduleEvent(pad_update_event, 0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | private: | 
					
						
							|  |  |  |     void GetSharedMemoryHandle(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-01-23 19:52:18 -05:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushCopyObjects(shared_mem); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_HID, "called"); | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  |     void LoadInputDevices() { | 
					
						
							|  |  |  |         std::transform(Settings::values.buttons.begin() + Settings::NativeButton::BUTTON_HID_BEGIN, | 
					
						
							|  |  |  |                        Settings::values.buttons.begin() + Settings::NativeButton::BUTTON_HID_END, | 
					
						
							|  |  |  |                        buttons.begin(), Input::CreateDevice<Input::ButtonDevice>); | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |         std::transform(Settings::values.analogs.begin() + Settings::NativeAnalog::STICK_HID_BEGIN, | 
					
						
							|  |  |  |                        Settings::values.analogs.begin() + Settings::NativeAnalog::STICK_HID_END, | 
					
						
							|  |  |  |                        sticks.begin(), Input::CreateDevice<Input::AnalogDevice>); | 
					
						
							|  |  |  |         // TODO(shinyquagsire23): gyro, touch, mouse, keyboard
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void UpdatePadCallback(u64 userdata, int cycles_late) { | 
					
						
							| 
									
										
										
										
											2018-04-01 00:12:07 -04:00
										 |  |  |         SharedMemory mem{}; | 
					
						
							|  |  |  |         std::memcpy(&mem, shared_mem->GetPointer(), sizeof(SharedMemory)); | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (is_device_reload_pending.exchange(false)) | 
					
						
							|  |  |  |             LoadInputDevices(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-16 03:14:27 -07:00
										 |  |  |         // Set up controllers as neon red+blue Joy-Con attached to console
 | 
					
						
							| 
									
										
										
										
											2018-04-01 00:12:07 -04:00
										 |  |  |         ControllerHeader& controller_header = mem.controllers[Controller_Handheld].header; | 
					
						
							| 
									
										
										
										
											2018-07-10 22:53:39 -04:00
										 |  |  |         controller_header.type = ControllerType_Handheld; | 
					
						
							| 
									
										
										
										
											2018-01-16 19:22:12 -07:00
										 |  |  |         controller_header.single_colors_descriptor = ColorDesc_ColorsNonexistent; | 
					
						
							|  |  |  |         controller_header.right_color_body = JOYCON_BODY_NEON_RED; | 
					
						
							|  |  |  |         controller_header.right_color_buttons = JOYCON_BUTTONS_NEON_RED; | 
					
						
							|  |  |  |         controller_header.left_color_body = JOYCON_BODY_NEON_BLUE; | 
					
						
							|  |  |  |         controller_header.left_color_buttons = JOYCON_BUTTONS_NEON_BLUE; | 
					
						
							| 
									
										
										
										
											2018-01-16 03:14:27 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |         for (size_t controller = 0; controller < mem.controllers.size(); controller++) { | 
					
						
							| 
									
										
										
										
											2018-06-13 20:03:12 -04:00
										 |  |  |             for (int index = 0; index < HID_NUM_LAYOUTS; index++) { | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |                 ControllerLayout& layout = mem.controllers[controller].layouts[index]; | 
					
						
							|  |  |  |                 layout.header.num_entries = HID_NUM_ENTRIES; | 
					
						
							|  |  |  |                 layout.header.max_entry_index = HID_NUM_ENTRIES - 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // HID shared memory stores the state of the past 17 samples in a circlular buffer,
 | 
					
						
							|  |  |  |                 // each with a timestamp in number of samples since boot.
 | 
					
						
							| 
									
										
										
										
											2018-07-10 22:53:39 -04:00
										 |  |  |                 const ControllerInputEntry& last_entry = layout.entries[layout.header.latest_entry]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |                 layout.header.timestamp_ticks = CoreTiming::GetTicks(); | 
					
						
							|  |  |  |                 layout.header.latest_entry = (layout.header.latest_entry + 1) % HID_NUM_ENTRIES; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 ControllerInputEntry& entry = layout.entries[layout.header.latest_entry]; | 
					
						
							| 
									
										
										
										
											2018-07-10 22:53:39 -04:00
										 |  |  |                 entry.timestamp = last_entry.timestamp + 1; | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |                 // TODO(shinyquagsire23): Is this always identical to timestamp?
 | 
					
						
							| 
									
										
										
										
											2018-07-10 22:53:39 -04:00
										 |  |  |                 entry.timestamp_2 = entry.timestamp; | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // TODO(shinyquagsire23): More than just handheld input
 | 
					
						
							|  |  |  |                 if (controller != Controller_Handheld) | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-11 19:41:29 -06:00
										 |  |  |                 entry.connection_state = ConnectionState_Connected | ConnectionState_Wired; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |                 // TODO(shinyquagsire23): Set up some LUTs for each layout mapping in the future?
 | 
					
						
							|  |  |  |                 // For now everything is just the default handheld layout, but split Joy-Con will
 | 
					
						
							|  |  |  |                 // rotate the face buttons and directions for certain layouts.
 | 
					
						
							|  |  |  |                 ControllerPadState& state = entry.buttons; | 
					
						
							|  |  |  |                 using namespace Settings::NativeButton; | 
					
						
							|  |  |  |                 state.a.Assign(buttons[A - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.b.Assign(buttons[B - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.x.Assign(buttons[X - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.y.Assign(buttons[Y - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.lstick.Assign(buttons[LStick - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.rstick.Assign(buttons[RStick - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.l.Assign(buttons[L - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.r.Assign(buttons[R - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.zl.Assign(buttons[ZL - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.zr.Assign(buttons[ZR - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.plus.Assign(buttons[Plus - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.minus.Assign(buttons[Minus - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 state.dleft.Assign(buttons[DLeft - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.dup.Assign(buttons[DUp - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.dright.Assign(buttons[DRight - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.ddown.Assign(buttons[DDown - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 state.lstick_left.Assign(buttons[LStick_Left - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.lstick_up.Assign(buttons[LStick_Up - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.lstick_right.Assign(buttons[LStick_Right - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.lstick_down.Assign(buttons[LStick_Down - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 state.rstick_left.Assign(buttons[RStick_Left - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.rstick_up.Assign(buttons[RStick_Up - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.rstick_right.Assign(buttons[RStick_Right - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.rstick_down.Assign(buttons[RStick_Down - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 state.sl.Assign(buttons[SL - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  |                 state.sr.Assign(buttons[SR - BUTTON_HID_BEGIN]->GetStatus()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const auto [stick_l_x_f, stick_l_y_f] = sticks[Joystick_Left]->GetStatus(); | 
					
						
							|  |  |  |                 const auto [stick_r_x_f, stick_r_y_f] = sticks[Joystick_Right]->GetStatus(); | 
					
						
							|  |  |  |                 entry.joystick_left_x = static_cast<s32>(stick_l_x_f * HID_JOYSTICK_MAX); | 
					
						
							|  |  |  |                 entry.joystick_left_y = static_cast<s32>(stick_l_y_f * HID_JOYSTICK_MAX); | 
					
						
							|  |  |  |                 entry.joystick_right_x = static_cast<s32>(stick_r_x_f * HID_JOYSTICK_MAX); | 
					
						
							|  |  |  |                 entry.joystick_right_y = static_cast<s32>(stick_r_y_f * HID_JOYSTICK_MAX); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-01-16 03:14:27 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-01 00:12:07 -04:00
										 |  |  |         // TODO(bunnei): Properly implement the touch screen, the below will just write empty data
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         TouchScreen& touchscreen = mem.touchscreen; | 
					
						
							|  |  |  |         const u64 last_entry = touchscreen.header.latest_entry; | 
					
						
							|  |  |  |         const u64 curr_entry = (last_entry + 1) % touchscreen.entries.size(); | 
					
						
							|  |  |  |         const u64 timestamp = CoreTiming::GetTicks(); | 
					
						
							|  |  |  |         const u64 sample_counter = touchscreen.entries[last_entry].header.timestamp + 1; | 
					
						
							|  |  |  |         touchscreen.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |         touchscreen.header.num_entries = touchscreen.entries.size(); | 
					
						
							|  |  |  |         touchscreen.header.latest_entry = curr_entry; | 
					
						
							|  |  |  |         touchscreen.header.max_entry_index = touchscreen.entries.size(); | 
					
						
							|  |  |  |         touchscreen.header.timestamp = timestamp; | 
					
						
							|  |  |  |         touchscreen.entries[curr_entry].header.timestamp = sample_counter; | 
					
						
							|  |  |  |         touchscreen.entries[curr_entry].header.num_touches = 0; | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |         // TODO(shinyquagsire23): Properly implement mouse
 | 
					
						
							|  |  |  |         Mouse& mouse = mem.mouse; | 
					
						
							|  |  |  |         const u64 last_mouse_entry = mouse.header.latest_entry; | 
					
						
							|  |  |  |         const u64 curr_mouse_entry = (mouse.header.latest_entry + 1) % mouse.entries.size(); | 
					
						
							|  |  |  |         const u64 mouse_sample_counter = mouse.entries[last_mouse_entry].timestamp + 1; | 
					
						
							|  |  |  |         mouse.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |         mouse.header.num_entries = mouse.entries.size(); | 
					
						
							|  |  |  |         mouse.header.max_entry_index = mouse.entries.size(); | 
					
						
							|  |  |  |         mouse.header.latest_entry = curr_mouse_entry; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mouse.entries[curr_mouse_entry].timestamp = mouse_sample_counter; | 
					
						
							|  |  |  |         mouse.entries[curr_mouse_entry].timestamp_2 = mouse_sample_counter; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TODO(shinyquagsire23): Properly implement keyboard
 | 
					
						
							|  |  |  |         Keyboard& keyboard = mem.keyboard; | 
					
						
							|  |  |  |         const u64 last_keyboard_entry = keyboard.header.latest_entry; | 
					
						
							|  |  |  |         const u64 curr_keyboard_entry = | 
					
						
							|  |  |  |             (keyboard.header.latest_entry + 1) % keyboard.entries.size(); | 
					
						
							|  |  |  |         const u64 keyboard_sample_counter = keyboard.entries[last_keyboard_entry].timestamp + 1; | 
					
						
							|  |  |  |         keyboard.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |         keyboard.header.num_entries = keyboard.entries.size(); | 
					
						
							|  |  |  |         keyboard.header.latest_entry = last_keyboard_entry; | 
					
						
							|  |  |  |         keyboard.header.max_entry_index = keyboard.entries.size(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         keyboard.entries[curr_keyboard_entry].timestamp = keyboard_sample_counter; | 
					
						
							|  |  |  |         keyboard.entries[curr_keyboard_entry].timestamp_2 = keyboard_sample_counter; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TODO(shinyquagsire23): Figure out what any of these are
 | 
					
						
							|  |  |  |         for (size_t i = 0; i < mem.unk_input_1.size(); i++) { | 
					
						
							|  |  |  |             UnkInput1& input = mem.unk_input_1[i]; | 
					
						
							|  |  |  |             const u64 last_input_entry = input.header.latest_entry; | 
					
						
							|  |  |  |             const u64 curr_input_entry = (input.header.latest_entry + 1) % input.entries.size(); | 
					
						
							|  |  |  |             const u64 input_sample_counter = input.entries[last_input_entry].timestamp + 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             input.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |             input.header.num_entries = input.entries.size(); | 
					
						
							|  |  |  |             input.header.latest_entry = last_input_entry; | 
					
						
							|  |  |  |             input.header.max_entry_index = input.entries.size(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             input.entries[curr_input_entry].timestamp = input_sample_counter; | 
					
						
							|  |  |  |             input.entries[curr_input_entry].timestamp_2 = input_sample_counter; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (size_t i = 0; i < mem.unk_input_2.size(); i++) { | 
					
						
							|  |  |  |             UnkInput2& input = mem.unk_input_2[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             input.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |             input.header.num_entries = 17; | 
					
						
							|  |  |  |             input.header.latest_entry = 0; | 
					
						
							|  |  |  |             input.header.max_entry_index = 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         UnkInput3& input = mem.unk_input_3; | 
					
						
							|  |  |  |         const u64 last_input_entry = input.header.latest_entry; | 
					
						
							|  |  |  |         const u64 curr_input_entry = (input.header.latest_entry + 1) % input.entries.size(); | 
					
						
							|  |  |  |         const u64 input_sample_counter = input.entries[last_input_entry].timestamp + 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         input.header.timestamp_ticks = timestamp; | 
					
						
							|  |  |  |         input.header.num_entries = input.entries.size(); | 
					
						
							|  |  |  |         input.header.latest_entry = last_input_entry; | 
					
						
							|  |  |  |         input.header.max_entry_index = input.entries.size(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         input.entries[curr_input_entry].timestamp = input_sample_counter; | 
					
						
							|  |  |  |         input.entries[curr_input_entry].timestamp_2 = input_sample_counter; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  |         // TODO(shinyquagsire23): Signal events
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-01 00:12:07 -04:00
										 |  |  |         std::memcpy(shared_mem->GetPointer(), &mem, sizeof(SharedMemory)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  |         // Reschedule recurrent event
 | 
					
						
							|  |  |  |         CoreTiming::ScheduleEvent(pad_update_ticks - cycles_late, pad_update_event); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     // Handle to shared memory region designated to HID service
 | 
					
						
							|  |  |  |     Kernel::SharedPtr<Kernel::SharedMemory> shared_mem; | 
					
						
							| 
									
										
										
										
											2018-01-15 02:21:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // CoreTiming update events
 | 
					
						
							|  |  |  |     CoreTiming::EventType* pad_update_event; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Stored input state info
 | 
					
						
							|  |  |  |     std::atomic<bool> is_device_reload_pending{true}; | 
					
						
							|  |  |  |     std::array<std::unique_ptr<Input::ButtonDevice>, Settings::NativeButton::NUM_BUTTONS_HID> | 
					
						
							|  |  |  |         buttons; | 
					
						
							| 
									
										
										
										
											2018-05-07 09:06:02 -06:00
										 |  |  |     std::array<std::unique_ptr<Input::AnalogDevice>, Settings::NativeAnalog::NUM_STICKS_HID> sticks; | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  | class IActiveVibrationDeviceList final : public ServiceFramework<IActiveVibrationDeviceList> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     IActiveVibrationDeviceList() : ServiceFramework("IActiveVibrationDeviceList") { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &IActiveVibrationDeviceList::ActivateVibrationDevice, "ActivateVibrationDevice"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     void ActivateVibrationDevice(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | class Hid final : public ServiceFramework<Hid> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     Hid() : ServiceFramework("hid") { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |             {0, &Hid::CreateAppletResource, "CreateAppletResource"}, | 
					
						
							|  |  |  |             {1, &Hid::ActivateDebugPad, "ActivateDebugPad"}, | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |             {11, &Hid::ActivateTouchScreen, "ActivateTouchScreen"}, | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |             {21, &Hid::ActivateMouse, "ActivateMouse"}, | 
					
						
							|  |  |  |             {31, &Hid::ActivateKeyboard, "ActivateKeyboard"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {40, nullptr, "AcquireXpadIdEventHandle"}, | 
					
						
							|  |  |  |             {41, nullptr, "ReleaseXpadIdEventHandle"}, | 
					
						
							|  |  |  |             {51, nullptr, "ActivateXpad"}, | 
					
						
							|  |  |  |             {55, nullptr, "GetXpadIds"}, | 
					
						
							|  |  |  |             {56, nullptr, "ActivateJoyXpad"}, | 
					
						
							|  |  |  |             {58, nullptr, "GetJoyXpadLifoHandle"}, | 
					
						
							|  |  |  |             {59, nullptr, "GetJoyXpadIds"}, | 
					
						
							|  |  |  |             {60, nullptr, "ActivateSixAxisSensor"}, | 
					
						
							|  |  |  |             {61, nullptr, "DeactivateSixAxisSensor"}, | 
					
						
							|  |  |  |             {62, nullptr, "GetSixAxisSensorLifoHandle"}, | 
					
						
							|  |  |  |             {63, nullptr, "ActivateJoySixAxisSensor"}, | 
					
						
							|  |  |  |             {64, nullptr, "DeactivateJoySixAxisSensor"}, | 
					
						
							|  |  |  |             {65, nullptr, "GetJoySixAxisSensorLifoHandle"}, | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |             {66, &Hid::StartSixAxisSensor, "StartSixAxisSensor"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {67, nullptr, "StopSixAxisSensor"}, | 
					
						
							|  |  |  |             {68, nullptr, "IsSixAxisSensorFusionEnabled"}, | 
					
						
							|  |  |  |             {69, nullptr, "EnableSixAxisSensorFusion"}, | 
					
						
							|  |  |  |             {70, nullptr, "SetSixAxisSensorFusionParameters"}, | 
					
						
							|  |  |  |             {71, nullptr, "GetSixAxisSensorFusionParameters"}, | 
					
						
							|  |  |  |             {72, nullptr, "ResetSixAxisSensorFusionParameters"}, | 
					
						
							|  |  |  |             {73, nullptr, "SetAccelerometerParameters"}, | 
					
						
							|  |  |  |             {74, nullptr, "GetAccelerometerParameters"}, | 
					
						
							|  |  |  |             {75, nullptr, "ResetAccelerometerParameters"}, | 
					
						
							|  |  |  |             {76, nullptr, "SetAccelerometerPlayMode"}, | 
					
						
							|  |  |  |             {77, nullptr, "GetAccelerometerPlayMode"}, | 
					
						
							|  |  |  |             {78, nullptr, "ResetAccelerometerPlayMode"}, | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |             {79, &Hid::SetGyroscopeZeroDriftMode, "SetGyroscopeZeroDriftMode"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {80, nullptr, "GetGyroscopeZeroDriftMode"}, | 
					
						
							|  |  |  |             {81, nullptr, "ResetGyroscopeZeroDriftMode"}, | 
					
						
							|  |  |  |             {82, nullptr, "IsSixAxisSensorAtRest"}, | 
					
						
							|  |  |  |             {91, nullptr, "ActivateGesture"}, | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |             {100, &Hid::SetSupportedNpadStyleSet, "SetSupportedNpadStyleSet"}, | 
					
						
							| 
									
										
										
										
											2018-03-31 16:05:45 -04:00
										 |  |  |             {101, &Hid::GetSupportedNpadStyleSet, "GetSupportedNpadStyleSet"}, | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |             {102, &Hid::SetSupportedNpadIdType, "SetSupportedNpadIdType"}, | 
					
						
							|  |  |  |             {103, &Hid::ActivateNpad, "ActivateNpad"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {104, nullptr, "DeactivateNpad"}, | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |             {106, &Hid::AcquireNpadStyleSetUpdateEventHandle, | 
					
						
							|  |  |  |              "AcquireNpadStyleSetUpdateEventHandle"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {107, nullptr, "DisconnectNpad"}, | 
					
						
							| 
									
										
										
										
											2018-04-13 17:05:03 +03:00
										 |  |  |             {108, &Hid::GetPlayerLedPattern, "GetPlayerLedPattern"}, | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |             {120, &Hid::SetNpadJoyHoldType, "SetNpadJoyHoldType"}, | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |             {121, &Hid::GetNpadJoyHoldType, "GetNpadJoyHoldType"}, | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |             {122, &Hid::SetNpadJoyAssignmentModeSingleByDefault, | 
					
						
							|  |  |  |              "SetNpadJoyAssignmentModeSingleByDefault"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {123, nullptr, "SetNpadJoyAssignmentModeSingleByDefault"}, | 
					
						
							| 
									
										
										
										
											2018-03-25 03:14:57 -04:00
										 |  |  |             {124, &Hid::SetNpadJoyAssignmentModeDual, "SetNpadJoyAssignmentModeDual"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {125, nullptr, "MergeSingleJoyAsDualJoy"}, | 
					
						
							|  |  |  |             {126, nullptr, "StartLrAssignmentMode"}, | 
					
						
							|  |  |  |             {127, nullptr, "StopLrAssignmentMode"}, | 
					
						
							| 
									
										
										
										
											2018-02-06 10:26:33 +03:00
										 |  |  |             {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {129, nullptr, "GetNpadHandheldActivationMode"}, | 
					
						
							|  |  |  |             {130, nullptr, "SwapNpadAssignment"}, | 
					
						
							|  |  |  |             {131, nullptr, "IsUnintendedHomeButtonInputProtectionEnabled"}, | 
					
						
							|  |  |  |             {132, nullptr, "EnableUnintendedHomeButtonInputProtection"}, | 
					
						
							| 
									
										
										
										
											2018-05-30 20:09:21 +02:00
										 |  |  |             {133, nullptr, "SetNpadJoyAssignmentModeSingleWithDestination"}, | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  |             {200, &Hid::GetVibrationDeviceInfo, "GetVibrationDeviceInfo"}, | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |             {201, &Hid::SendVibrationValue, "SendVibrationValue"}, | 
					
						
							|  |  |  |             {202, &Hid::GetActualVibrationValue, "GetActualVibrationValue"}, | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  |             {203, &Hid::CreateActiveVibrationDeviceList, "CreateActiveVibrationDeviceList"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {204, nullptr, "PermitVibration"}, | 
					
						
							|  |  |  |             {205, nullptr, "IsVibrationPermitted"}, | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  |             {206, &Hid::SendVibrationValues, "SendVibrationValues"}, | 
					
						
							| 
									
										
										
										
											2018-05-30 20:09:21 +02:00
										 |  |  |             {207, nullptr, "SendVibrationGcErmCommand"}, | 
					
						
							|  |  |  |             {208, nullptr, "GetActualVibrationGcErmCommand"}, | 
					
						
							|  |  |  |             {209, nullptr, "BeginPermitVibrationSession"}, | 
					
						
							|  |  |  |             {210, nullptr, "EndPermitVibrationSession"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {300, nullptr, "ActivateConsoleSixAxisSensor"}, | 
					
						
							|  |  |  |             {301, nullptr, "StartConsoleSixAxisSensor"}, | 
					
						
							|  |  |  |             {302, nullptr, "StopConsoleSixAxisSensor"}, | 
					
						
							| 
									
										
										
										
											2018-05-30 20:09:21 +02:00
										 |  |  |             {303, nullptr, "ActivateSevenSixAxisSensor"}, | 
					
						
							|  |  |  |             {304, nullptr, "StartSevenSixAxisSensor"}, | 
					
						
							|  |  |  |             {305, nullptr, "StopSevenSixAxisSensor"}, | 
					
						
							|  |  |  |             {306, nullptr, "InitializeSevenSixAxisSensor"}, | 
					
						
							|  |  |  |             {307, nullptr, "FinalizeSevenSixAxisSensor"}, | 
					
						
							|  |  |  |             {308, nullptr, "SetSevenSixAxisSensorFusionStrength"}, | 
					
						
							|  |  |  |             {309, nullptr, "GetSevenSixAxisSensorFusionStrength"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {400, nullptr, "IsUsbFullKeyControllerEnabled"}, | 
					
						
							|  |  |  |             {401, nullptr, "EnableUsbFullKeyController"}, | 
					
						
							|  |  |  |             {402, nullptr, "IsUsbFullKeyControllerConnected"}, | 
					
						
							| 
									
										
										
										
											2018-05-30 20:09:21 +02:00
										 |  |  |             {403, nullptr, "HasBattery"}, | 
					
						
							|  |  |  |             {404, nullptr, "HasLeftRightBattery"}, | 
					
						
							|  |  |  |             {405, nullptr, "GetNpadInterfaceType"}, | 
					
						
							|  |  |  |             {406, nullptr, "GetNpadLeftRightInterfaceType"}, | 
					
						
							|  |  |  |             {500, nullptr, "GetPalmaConnectionHandle"}, | 
					
						
							|  |  |  |             {501, nullptr, "InitializePalma"}, | 
					
						
							|  |  |  |             {502, nullptr, "AcquirePalmaOperationCompleteEvent"}, | 
					
						
							|  |  |  |             {503, nullptr, "GetPalmaOperationInfo"}, | 
					
						
							|  |  |  |             {504, nullptr, "PlayPalmaActivity"}, | 
					
						
							|  |  |  |             {505, nullptr, "SetPalmaFrModeType"}, | 
					
						
							|  |  |  |             {506, nullptr, "ReadPalmaStep"}, | 
					
						
							|  |  |  |             {507, nullptr, "EnablePalmaStep"}, | 
					
						
							|  |  |  |             {508, nullptr, "SuspendPalmaStep"}, | 
					
						
							|  |  |  |             {509, nullptr, "ResetPalmaStep"}, | 
					
						
							|  |  |  |             {510, nullptr, "ReadPalmaApplicationSection"}, | 
					
						
							|  |  |  |             {511, nullptr, "WritePalmaApplicationSection"}, | 
					
						
							|  |  |  |             {512, nullptr, "ReadPalmaUniqueCode"}, | 
					
						
							|  |  |  |             {513, nullptr, "SetPalmaUniqueCodeInvalid"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:17:22 +03:00
										 |  |  |             {1000, nullptr, "SetNpadCommunicationMode"}, | 
					
						
							|  |  |  |             {1001, nullptr, "GetNpadCommunicationMode"}, | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         event = Kernel::Event::Create(Kernel::ResetType::OneShot, "hid:EventHandle"); | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     } | 
					
						
							|  |  |  |     ~Hid() = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-01-22 17:41:31 -05:00
										 |  |  |     std::shared_ptr<IAppletResource> applet_resource; | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |     u32 joy_hold_type{0}; | 
					
						
							|  |  |  |     Kernel::SharedPtr<Kernel::Event> event; | 
					
						
							| 
									
										
										
										
											2018-01-22 17:27:55 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     void CreateAppletResource(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-01-22 17:41:31 -05:00
										 |  |  |         if (applet_resource == nullptr) { | 
					
						
							|  |  |  |             applet_resource = std::make_shared<IAppletResource>(); | 
					
						
							| 
									
										
										
										
											2018-01-22 17:27:55 -03:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-23 19:52:18 -05:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2018-01-22 17:41:31 -05:00
										 |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-01-23 19:43:59 -05:00
										 |  |  |         rb.PushIpcInterface<IAppletResource>(applet_resource); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_HID, "called"); | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     void ActivateDebugPad(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |     void ActivateTouchScreen(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     void ActivateMouse(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void ActivateKeyboard(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     void StartSixAxisSensor(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     void SetGyroscopeZeroDriftMode(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     void SetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-31 16:05:45 -04:00
										 |  |  |     void GetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push<u32>(0); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-03-31 16:05:45 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     void SetSupportedNpadIdType(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void ActivateNpad(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 22:24:20 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |     void AcquireNpadStyleSetUpdateEventHandle(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushCopyObjects(event); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-13 17:05:03 +03:00
										 |  |  |     void GetPlayerLedPattern(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-04-13 17:05:03 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |     void SetNpadJoyHoldType(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-05 21:53:11 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |     void GetNpadJoyHoldType(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push(joy_hold_type); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     void SetNpadJoyAssignmentModeSingleByDefault(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SendVibrationValue(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void GetActualVibrationValue(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-15 17:22:11 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-25 03:14:57 -04:00
										 |  |  |     void SetNpadJoyAssignmentModeDual(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-03-25 03:14:57 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-06 10:26:33 +03:00
										 |  |  |     void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-06 10:26:33 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  |     void GetVibrationDeviceInfo(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push<u64>(0); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  |     void CreateActiveVibrationDeviceList(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushIpcInterface<IActiveVibrationDeviceList>(); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_HID, "called"); | 
					
						
							| 
									
										
										
										
											2018-02-04 17:06:14 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void SendVibrationValues(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_HID, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-13 19:05:06 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-12 21:21:49 -04:00
										 |  |  | void ReloadInputDevices() {} | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 21:24:50 -05:00
										 |  |  | void InstallInterfaces(SM::ServiceManager& service_manager) { | 
					
						
							|  |  |  |     std::make_shared<Hid>()->InstallAsService(service_manager); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | } // namespace Service::HID
 |