mirror of
				https://git.suyu.dev/suyu/suyu
				synced 2025-11-04 00:49:02 -06:00 
			
		
		
		
	Merge pull request #13135 from german77/hid-interface
service: hid: Migrate HidServer to new IPC
This commit is contained in:
		@@ -668,6 +668,10 @@ add_library(core STATIC
 | 
			
		||||
    hle/service/glue/time/worker.h
 | 
			
		||||
    hle/service/grc/grc.cpp
 | 
			
		||||
    hle/service/grc/grc.h
 | 
			
		||||
    hle/service/hid/active_vibration_device_list.cpp
 | 
			
		||||
    hle/service/hid/active_vibration_device_list.h
 | 
			
		||||
    hle/service/hid/applet_resource.cpp
 | 
			
		||||
    hle/service/hid/applet_resource.h
 | 
			
		||||
    hle/service/hid/hid.cpp
 | 
			
		||||
    hle/service/hid/hid.h
 | 
			
		||||
    hle/service/hid/hid_debug_server.cpp
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										53
									
								
								src/core/hle/service/hid/active_vibration_device_list.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/core/hle/service/hid/active_vibration_device_list.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,53 @@
 | 
			
		||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-or-later
 | 
			
		||||
 | 
			
		||||
#include "common/logging/log.h"
 | 
			
		||||
#include "core/hle/service/cmif_serialization.h"
 | 
			
		||||
#include "core/hle/service/hid/active_vibration_device_list.h"
 | 
			
		||||
#include "hid_core/hid_result.h"
 | 
			
		||||
#include "hid_core/hid_util.h"
 | 
			
		||||
#include "hid_core/resource_manager.h"
 | 
			
		||||
#include "hid_core/resources/vibration/vibration_device.h"
 | 
			
		||||
 | 
			
		||||
namespace Service::HID {
 | 
			
		||||
 | 
			
		||||
IActiveVibrationDeviceList::IActiveVibrationDeviceList(Core::System& system_,
 | 
			
		||||
                                                       std::shared_ptr<ResourceManager> resource)
 | 
			
		||||
    : ServiceFramework{system_, "IActiveVibrationDeviceList"}, resource_manager(resource) {
 | 
			
		||||
    // clang-format off
 | 
			
		||||
        static const FunctionInfo functions[] = {
 | 
			
		||||
            {0, C<&IActiveVibrationDeviceList::ActivateVibrationDevice>, "ActivateVibrationDevice"},
 | 
			
		||||
        };
 | 
			
		||||
    // clang-format on
 | 
			
		||||
 | 
			
		||||
    RegisterHandlers(functions);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IActiveVibrationDeviceList::~IActiveVibrationDeviceList() = default;
 | 
			
		||||
 | 
			
		||||
Result IActiveVibrationDeviceList::ActivateVibrationDevice(
 | 
			
		||||
    Core::HID::VibrationDeviceHandle vibration_device_handle) {
 | 
			
		||||
    LOG_DEBUG(Service_HID, "called, npad_type={}, npad_id={}, device_index={}",
 | 
			
		||||
              vibration_device_handle.npad_type, vibration_device_handle.npad_id,
 | 
			
		||||
              vibration_device_handle.device_index);
 | 
			
		||||
 | 
			
		||||
    std::scoped_lock lock{mutex};
 | 
			
		||||
 | 
			
		||||
    R_TRY(IsVibrationHandleValid(vibration_device_handle));
 | 
			
		||||
 | 
			
		||||
    for (std::size_t i = 0; i < list_size; i++) {
 | 
			
		||||
        if (vibration_device_handle.device_index == vibration_device_list[i].device_index &&
 | 
			
		||||
            vibration_device_handle.npad_id == vibration_device_list[i].npad_id &&
 | 
			
		||||
            vibration_device_handle.npad_type == vibration_device_list[i].npad_type) {
 | 
			
		||||
            R_SUCCEED();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    R_UNLESS(list_size < MaxVibrationDevicesHandles, ResultVibrationDeviceIndexOutOfRange);
 | 
			
		||||
    R_TRY(resource_manager->GetVibrationDevice(vibration_device_handle)->Activate());
 | 
			
		||||
 | 
			
		||||
    vibration_device_list[list_size++] = vibration_device_handle;
 | 
			
		||||
    R_SUCCEED();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
							
								
								
									
										39
									
								
								src/core/hle/service/hid/active_vibration_device_list.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								src/core/hle/service/hid/active_vibration_device_list.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-or-later
 | 
			
		||||
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <array>
 | 
			
		||||
#include <memory>
 | 
			
		||||
#include <mutex>
 | 
			
		||||
 | 
			
		||||
#include "core/hle/service/cmif_types.h"
 | 
			
		||||
#include "core/hle/service/service.h"
 | 
			
		||||
#include "hid_core/hid_types.h"
 | 
			
		||||
 | 
			
		||||
namespace Core {
 | 
			
		||||
class System;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Service::HID {
 | 
			
		||||
class ResourceManager;
 | 
			
		||||
 | 
			
		||||
class IActiveVibrationDeviceList final : public ServiceFramework<IActiveVibrationDeviceList> {
 | 
			
		||||
public:
 | 
			
		||||
    explicit IActiveVibrationDeviceList(Core::System& system_,
 | 
			
		||||
                                        std::shared_ptr<ResourceManager> resource);
 | 
			
		||||
    ~IActiveVibrationDeviceList() override;
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
    static constexpr std::size_t MaxVibrationDevicesHandles{0x100};
 | 
			
		||||
 | 
			
		||||
    Result ActivateVibrationDevice(Core::HID::VibrationDeviceHandle vibration_device_handle);
 | 
			
		||||
 | 
			
		||||
    mutable std::mutex mutex;
 | 
			
		||||
    std::size_t list_size{};
 | 
			
		||||
    std::array<Core::HID::VibrationDeviceHandle, MaxVibrationDevicesHandles>
 | 
			
		||||
        vibration_device_list{};
 | 
			
		||||
    std::shared_ptr<ResourceManager> resource_manager;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
							
								
								
									
										34
									
								
								src/core/hle/service/hid/applet_resource.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/core/hle/service/hid/applet_resource.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-or-later
 | 
			
		||||
 | 
			
		||||
#include "common/logging/log.h"
 | 
			
		||||
#include "core/hle/kernel/k_shared_memory.h"
 | 
			
		||||
#include "core/hle/service/cmif_serialization.h"
 | 
			
		||||
#include "core/hle/service/hid/applet_resource.h"
 | 
			
		||||
#include "hid_core/resource_manager.h"
 | 
			
		||||
 | 
			
		||||
namespace Service::HID {
 | 
			
		||||
 | 
			
		||||
IAppletResource::IAppletResource(Core::System& system_, std::shared_ptr<ResourceManager> resource,
 | 
			
		||||
                                 u64 applet_resource_user_id)
 | 
			
		||||
    : ServiceFramework{system_, "IAppletResource"}, aruid{applet_resource_user_id},
 | 
			
		||||
      resource_manager{resource} {
 | 
			
		||||
    static const FunctionInfo functions[] = {
 | 
			
		||||
        {0, C<&IAppletResource::GetSharedMemoryHandle>, "GetSharedMemoryHandle"},
 | 
			
		||||
    };
 | 
			
		||||
    RegisterHandlers(functions);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IAppletResource::~IAppletResource() {
 | 
			
		||||
    resource_manager->FreeAppletResourceId(aruid);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Result IAppletResource::GetSharedMemoryHandle(
 | 
			
		||||
    OutCopyHandle<Kernel::KSharedMemory> out_shared_memory_handle) {
 | 
			
		||||
    const auto result = resource_manager->GetSharedMemoryHandle(out_shared_memory_handle, aruid);
 | 
			
		||||
 | 
			
		||||
    LOG_DEBUG(Service_HID, "called, applet_resource_user_id={}, result=0x{:X}", aruid, result.raw);
 | 
			
		||||
    R_RETURN(result);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
							
								
								
									
										36
									
								
								src/core/hle/service/hid/applet_resource.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/core/hle/service/hid/applet_resource.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,36 @@
 | 
			
		||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-or-later
 | 
			
		||||
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <memory>
 | 
			
		||||
 | 
			
		||||
#include "common/common_types.h"
 | 
			
		||||
#include "core/hle/service/cmif_types.h"
 | 
			
		||||
#include "core/hle/service/service.h"
 | 
			
		||||
 | 
			
		||||
namespace Core {
 | 
			
		||||
class System;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Kernel {
 | 
			
		||||
class KSharedMemory;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Service::HID {
 | 
			
		||||
class ResourceManager;
 | 
			
		||||
 | 
			
		||||
class IAppletResource final : public ServiceFramework<IAppletResource> {
 | 
			
		||||
public:
 | 
			
		||||
    explicit IAppletResource(Core::System& system_, std::shared_ptr<ResourceManager> resource,
 | 
			
		||||
                             u64 applet_resource_user_id);
 | 
			
		||||
    ~IAppletResource() override;
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
    Result GetSharedMemoryHandle(OutCopyHandle<Kernel::KSharedMemory> out_shared_memory_handle);
 | 
			
		||||
 | 
			
		||||
    u64 aruid{};
 | 
			
		||||
    std::shared_ptr<ResourceManager> resource_manager;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -6,12 +6,20 @@
 | 
			
		||||
#include "core/hle/service/cmif_types.h"
 | 
			
		||||
#include "core/hle/service/service.h"
 | 
			
		||||
#include "hid_core/hid_types.h"
 | 
			
		||||
#include "hid_core/resources/npad/npad_types.h"
 | 
			
		||||
#include "hid_core/resources/palma/palma.h"
 | 
			
		||||
 | 
			
		||||
namespace Core {
 | 
			
		||||
class System;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Kernel {
 | 
			
		||||
class KReadableEvent;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Service::HID {
 | 
			
		||||
class IActiveVibrationDeviceList;
 | 
			
		||||
class IAppletResource;
 | 
			
		||||
class ResourceManager;
 | 
			
		||||
class HidFirmwareSettings;
 | 
			
		||||
 | 
			
		||||
@@ -24,128 +32,232 @@ public:
 | 
			
		||||
    std::shared_ptr<ResourceManager> GetResourceManager();
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
    void CreateAppletResource(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateDebugPad(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateTouchScreen(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateMouse(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateKeyboard(HLERequestContext& ctx);
 | 
			
		||||
    void SendKeyboardLockKeyEvent(HLERequestContext& ctx);
 | 
			
		||||
    void AcquireXpadIdEventHandle(HLERequestContext& ctx);
 | 
			
		||||
    void ReleaseXpadIdEventHandle(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateXpad(HLERequestContext& ctx);
 | 
			
		||||
    void GetXpadIds(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateJoyXpad(HLERequestContext& ctx);
 | 
			
		||||
    void GetJoyXpadLifoHandle(HLERequestContext& ctx);
 | 
			
		||||
    void GetJoyXpadIds(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void DeactivateSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void GetSixAxisSensorLifoHandle(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateJoySixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void DeactivateJoySixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void GetJoySixAxisSensorLifoHandle(HLERequestContext& ctx);
 | 
			
		||||
    void StartSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void StopSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void IsSixAxisSensorFusionEnabled(HLERequestContext& ctx);
 | 
			
		||||
    void EnableSixAxisSensorFusion(HLERequestContext& ctx);
 | 
			
		||||
    void SetSixAxisSensorFusionParameters(HLERequestContext& ctx);
 | 
			
		||||
    void GetSixAxisSensorFusionParameters(HLERequestContext& ctx);
 | 
			
		||||
    void ResetSixAxisSensorFusionParameters(HLERequestContext& ctx);
 | 
			
		||||
    void SetGyroscopeZeroDriftMode(HLERequestContext& ctx);
 | 
			
		||||
    void GetGyroscopeZeroDriftMode(HLERequestContext& ctx);
 | 
			
		||||
    void ResetGyroscopeZeroDriftMode(HLERequestContext& ctx);
 | 
			
		||||
    void IsSixAxisSensorAtRest(HLERequestContext& ctx);
 | 
			
		||||
    void IsFirmwareUpdateAvailableForSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void EnableSixAxisSensorUnalteredPassthrough(HLERequestContext& ctx);
 | 
			
		||||
    void IsSixAxisSensorUnalteredPassthroughEnabled(HLERequestContext& ctx);
 | 
			
		||||
    void LoadSixAxisSensorCalibrationParameter(HLERequestContext& ctx);
 | 
			
		||||
    void GetSixAxisSensorIcInformation(HLERequestContext& ctx);
 | 
			
		||||
    void ResetIsSixAxisSensorDeviceNewlyAssigned(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateGesture(HLERequestContext& ctx);
 | 
			
		||||
    void SetSupportedNpadStyleSet(HLERequestContext& ctx);
 | 
			
		||||
    void GetSupportedNpadStyleSet(HLERequestContext& ctx);
 | 
			
		||||
    void SetSupportedNpadIdType(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateNpad(HLERequestContext& ctx);
 | 
			
		||||
    void DeactivateNpad(HLERequestContext& ctx);
 | 
			
		||||
    void AcquireNpadStyleSetUpdateEventHandle(HLERequestContext& ctx);
 | 
			
		||||
    void DisconnectNpad(HLERequestContext& ctx);
 | 
			
		||||
    Result CreateAppletResource(OutInterface<IAppletResource> out_applet_resource,
 | 
			
		||||
                                ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateDebugPad(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateTouchScreen(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateMouse(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateKeyboard(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SendKeyboardLockKeyEvent(u32 flags);
 | 
			
		||||
    Result AcquireXpadIdEventHandle(OutCopyHandle<Kernel::KReadableEvent> out_event,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ReleaseXpadIdEventHandle(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateXpad(u32 basic_xpad_id, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetXpadIds(Out<u64> out_count, OutArray<u32, BufferAttr_HipcPointer> out_basic_pad_ids);
 | 
			
		||||
    Result ActivateJoyXpad(u32 joy_xpad_id);
 | 
			
		||||
    Result GetJoyXpadLifoHandle(OutCopyHandle<Kernel::KSharedMemory> out_shared_memory_handle,
 | 
			
		||||
                                u32 joy_xpad_id);
 | 
			
		||||
    Result GetJoyXpadIds(Out<s64> out_basic_xpad_id_count);
 | 
			
		||||
    Result ActivateSixAxisSensor(u32 joy_xpad_id);
 | 
			
		||||
    Result DeactivateSixAxisSensor(u32 joy_xpad_id);
 | 
			
		||||
    Result GetSixAxisSensorLifoHandle(OutCopyHandle<Kernel::KSharedMemory> out_shared_memory_handle,
 | 
			
		||||
                                      u32 joy_xpad_id);
 | 
			
		||||
    Result ActivateJoySixAxisSensor(u32 joy_xpad_id);
 | 
			
		||||
    Result DeactivateJoySixAxisSensor(u32 joy_xpad_id);
 | 
			
		||||
    Result GetJoySixAxisSensorLifoHandle(
 | 
			
		||||
        OutCopyHandle<Kernel::KSharedMemory> out_shared_memory_handle, u32 joy_xpad_id);
 | 
			
		||||
    Result StartSixAxisSensor(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                              ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StopSixAxisSensor(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                             ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsSixAxisSensorFusionEnabled(Out<bool> out_is_enabled,
 | 
			
		||||
                                        Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                        ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result EnableSixAxisSensorFusion(bool is_enabled, Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetSixAxisSensorFusionParameters(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                            Core::HID::SixAxisSensorFusionParameters sixaxis_fusion,
 | 
			
		||||
                                            ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetSixAxisSensorFusionParameters(
 | 
			
		||||
        Out<Core::HID::SixAxisSensorFusionParameters> out_fusion_parameters,
 | 
			
		||||
        Core::HID::SixAxisSensorHandle sixaxis_handle, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ResetSixAxisSensorFusionParameters(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                              ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetGyroscopeZeroDriftMode(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                     Core::HID::GyroscopeZeroDriftMode drift_mode,
 | 
			
		||||
                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetGyroscopeZeroDriftMode(Out<Core::HID::GyroscopeZeroDriftMode> out_drift_mode,
 | 
			
		||||
                                     Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ResetGyroscopeZeroDriftMode(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                       ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsSixAxisSensorAtRest(Out<bool> out_is_at_rest,
 | 
			
		||||
                                 Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                 ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsFirmwareUpdateAvailableForSixAxisSensor(Out<bool> out_is_firmware_available,
 | 
			
		||||
                                                     Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result EnableSixAxisSensorUnalteredPassthrough(bool is_enabled,
 | 
			
		||||
                                                   Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                                   ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsSixAxisSensorUnalteredPassthroughEnabled(Out<bool> out_is_enabled,
 | 
			
		||||
                                                      Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                                      ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result LoadSixAxisSensorCalibrationParameter(
 | 
			
		||||
        OutLargeData<Core::HID::SixAxisSensorCalibrationParameter, BufferAttr_HipcMapAlias>
 | 
			
		||||
            out_calibration,
 | 
			
		||||
        Core::HID::SixAxisSensorHandle sixaxis_handle, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetSixAxisSensorIcInformation(
 | 
			
		||||
        OutLargeData<Core::HID::SixAxisSensorIcInformation, BufferAttr_HipcPointer>
 | 
			
		||||
            out_ic_information,
 | 
			
		||||
        Core::HID::SixAxisSensorHandle sixaxis_handle, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ResetIsSixAxisSensorDeviceNewlyAssigned(Core::HID::SixAxisSensorHandle sixaxis_handle,
 | 
			
		||||
                                                   ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateGesture(u32 basic_gesture_id, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetSupportedNpadStyleSet(Core::HID::NpadStyleSet supported_style_set,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetSupportedNpadStyleSet(Out<Core::HID::NpadStyleSet> out_supported_style_set,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetSupportedNpadIdType(
 | 
			
		||||
        ClientAppletResourceUserId aruid,
 | 
			
		||||
        InArray<Core::HID::NpadIdType, BufferAttr_HipcPointer> supported_npad_list);
 | 
			
		||||
    Result ActivateNpad(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result DeactivateNpad(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result AcquireNpadStyleSetUpdateEventHandle(OutCopyHandle<Kernel::KReadableEvent> out_event,
 | 
			
		||||
                                                Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                                ClientAppletResourceUserId aruid, u64 unknown);
 | 
			
		||||
    Result DisconnectNpad(Core::HID::NpadIdType npad_id, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetPlayerLedPattern(Out<Core::HID::LedPattern> out_led_pattern,
 | 
			
		||||
                               Core::HID::NpadIdType npad_id);
 | 
			
		||||
    void ActivateNpadWithRevision(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadJoyHoldType(HLERequestContext& ctx);
 | 
			
		||||
    void GetNpadJoyHoldType(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadJoyAssignmentModeSingleByDefault(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadJoyAssignmentModeSingle(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadJoyAssignmentModeDual(HLERequestContext& ctx);
 | 
			
		||||
    void MergeSingleJoyAsDualJoy(HLERequestContext& ctx);
 | 
			
		||||
    void StartLrAssignmentMode(HLERequestContext& ctx);
 | 
			
		||||
    void StopLrAssignmentMode(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadHandheldActivationMode(HLERequestContext& ctx);
 | 
			
		||||
    void GetNpadHandheldActivationMode(HLERequestContext& ctx);
 | 
			
		||||
    void SwapNpadAssignment(HLERequestContext& ctx);
 | 
			
		||||
    void IsUnintendedHomeButtonInputProtectionEnabled(HLERequestContext& ctx);
 | 
			
		||||
    void EnableUnintendedHomeButtonInputProtection(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadJoyAssignmentModeSingleWithDestination(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadAnalogStickUseCenterClamp(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadCaptureButtonAssignment(HLERequestContext& ctx);
 | 
			
		||||
    void ClearNpadCaptureButtonAssignment(HLERequestContext& ctx);
 | 
			
		||||
    void GetVibrationDeviceInfo(HLERequestContext& ctx);
 | 
			
		||||
    void SendVibrationValue(HLERequestContext& ctx);
 | 
			
		||||
    void GetActualVibrationValue(HLERequestContext& ctx);
 | 
			
		||||
    void CreateActiveVibrationDeviceList(HLERequestContext& ctx);
 | 
			
		||||
    void PermitVibration(HLERequestContext& ctx);
 | 
			
		||||
    void IsVibrationPermitted(HLERequestContext& ctx);
 | 
			
		||||
    void SendVibrationValues(HLERequestContext& ctx);
 | 
			
		||||
    void SendVibrationGcErmCommand(HLERequestContext& ctx);
 | 
			
		||||
    void GetActualVibrationGcErmCommand(HLERequestContext& ctx);
 | 
			
		||||
    void BeginPermitVibrationSession(HLERequestContext& ctx);
 | 
			
		||||
    void EndPermitVibrationSession(HLERequestContext& ctx);
 | 
			
		||||
    void IsVibrationDeviceMounted(HLERequestContext& ctx);
 | 
			
		||||
    void SendVibrationValueInBool(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateConsoleSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void StartConsoleSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void StopConsoleSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void ActivateSevenSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void StartSevenSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void StopSevenSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void InitializeSevenSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void FinalizeSevenSixAxisSensor(HLERequestContext& ctx);
 | 
			
		||||
    void ResetSevenSixAxisSensorTimestamp(HLERequestContext& ctx);
 | 
			
		||||
    void IsUsbFullKeyControllerEnabled(HLERequestContext& ctx);
 | 
			
		||||
    void GetPalmaConnectionHandle(HLERequestContext& ctx);
 | 
			
		||||
    void InitializePalma(HLERequestContext& ctx);
 | 
			
		||||
    void AcquirePalmaOperationCompleteEvent(HLERequestContext& ctx);
 | 
			
		||||
    void GetPalmaOperationInfo(HLERequestContext& ctx);
 | 
			
		||||
    void PlayPalmaActivity(HLERequestContext& ctx);
 | 
			
		||||
    void SetPalmaFrModeType(HLERequestContext& ctx);
 | 
			
		||||
    void ReadPalmaStep(HLERequestContext& ctx);
 | 
			
		||||
    void EnablePalmaStep(HLERequestContext& ctx);
 | 
			
		||||
    void ResetPalmaStep(HLERequestContext& ctx);
 | 
			
		||||
    void ReadPalmaApplicationSection(HLERequestContext& ctx);
 | 
			
		||||
    void WritePalmaApplicationSection(HLERequestContext& ctx);
 | 
			
		||||
    void ReadPalmaUniqueCode(HLERequestContext& ctx);
 | 
			
		||||
    void SetPalmaUniqueCodeInvalid(HLERequestContext& ctx);
 | 
			
		||||
    void WritePalmaActivityEntry(HLERequestContext& ctx);
 | 
			
		||||
    void WritePalmaRgbLedPatternEntry(HLERequestContext& ctx);
 | 
			
		||||
    void WritePalmaWaveEntry(HLERequestContext& ctx);
 | 
			
		||||
    void SetPalmaDataBaseIdentificationVersion(HLERequestContext& ctx);
 | 
			
		||||
    void GetPalmaDataBaseIdentificationVersion(HLERequestContext& ctx);
 | 
			
		||||
    void SuspendPalmaFeature(HLERequestContext& ctx);
 | 
			
		||||
    void GetPalmaOperationResult(HLERequestContext& ctx);
 | 
			
		||||
    void ReadPalmaPlayLog(HLERequestContext& ctx);
 | 
			
		||||
    void ResetPalmaPlayLog(HLERequestContext& ctx);
 | 
			
		||||
    void SetIsPalmaAllConnectable(HLERequestContext& ctx);
 | 
			
		||||
    void SetIsPalmaPairedConnectable(HLERequestContext& ctx);
 | 
			
		||||
    void PairPalma(HLERequestContext& ctx);
 | 
			
		||||
    void SetPalmaBoostMode(HLERequestContext& ctx);
 | 
			
		||||
    void CancelWritePalmaWaveEntry(HLERequestContext& ctx);
 | 
			
		||||
    void EnablePalmaBoostMode(HLERequestContext& ctx);
 | 
			
		||||
    void GetPalmaBluetoothAddress(HLERequestContext& ctx);
 | 
			
		||||
    void SetDisallowedPalmaConnection(HLERequestContext& ctx);
 | 
			
		||||
    void SetNpadCommunicationMode(HLERequestContext& ctx);
 | 
			
		||||
    void GetNpadCommunicationMode(HLERequestContext& ctx);
 | 
			
		||||
    void SetTouchScreenConfiguration(HLERequestContext& ctx);
 | 
			
		||||
    void IsFirmwareUpdateNeededForNotification(HLERequestContext& ctx);
 | 
			
		||||
    void SetTouchScreenResolution(HLERequestContext& ctx);
 | 
			
		||||
    Result ActivateNpadWithRevision(NpadRevision revision, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadJoyHoldType(ClientAppletResourceUserId aruid, NpadJoyHoldType hold_type);
 | 
			
		||||
    Result GetNpadJoyHoldType(Out<NpadJoyHoldType> out_hold_type, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadJoyAssignmentModeSingleByDefault(Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                                   ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadJoyAssignmentModeSingle(Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                          ClientAppletResourceUserId aruid,
 | 
			
		||||
                                          NpadJoyDeviceType npad_joy_device_type);
 | 
			
		||||
    Result SetNpadJoyAssignmentModeDual(Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                        ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result MergeSingleJoyAsDualJoy(Core::HID::NpadIdType npad_id_1, Core::HID::NpadIdType npad_id_2,
 | 
			
		||||
                                   ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StartLrAssignmentMode(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StopLrAssignmentMode(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadHandheldActivationMode(ClientAppletResourceUserId aruid,
 | 
			
		||||
                                         NpadHandheldActivationMode activation_mode);
 | 
			
		||||
    Result GetNpadHandheldActivationMode(Out<NpadHandheldActivationMode> out_activation_mode,
 | 
			
		||||
                                         ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SwapNpadAssignment(Core::HID::NpadIdType npad_id_1, Core::HID::NpadIdType npad_id_2,
 | 
			
		||||
                              ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsUnintendedHomeButtonInputProtectionEnabled(Out<bool> out_is_enabled,
 | 
			
		||||
                                                        Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                                        ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result EnableUnintendedHomeButtonInputProtection(bool is_enabled, Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadJoyAssignmentModeSingleWithDestination(Out<bool> out_is_reassigned,
 | 
			
		||||
                                                         Out<Core::HID::NpadIdType> out_new_npad_id,
 | 
			
		||||
                                                         Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                                         ClientAppletResourceUserId aruid,
 | 
			
		||||
                                                         NpadJoyDeviceType npad_joy_device_type);
 | 
			
		||||
    Result SetNpadAnalogStickUseCenterClamp(bool use_center_clamp,
 | 
			
		||||
                                            ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetNpadCaptureButtonAssignment(Core::HID::NpadStyleSet npad_styleset,
 | 
			
		||||
                                          ClientAppletResourceUserId aruid,
 | 
			
		||||
                                          Core::HID::NpadButton button);
 | 
			
		||||
    Result ClearNpadCaptureButtonAssignment(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetVibrationDeviceInfo(Out<Core::HID::VibrationDeviceInfo> out_vibration_device_info,
 | 
			
		||||
                                  Core::HID::VibrationDeviceHandle vibration_device_handle);
 | 
			
		||||
    Result SendVibrationValue(Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                              Core::HID::VibrationValue vibration_value,
 | 
			
		||||
                              ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetActualVibrationValue(Out<Core::HID::VibrationValue> out_vibration_value,
 | 
			
		||||
                                   Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                                   ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result CreateActiveVibrationDeviceList(OutInterface<IActiveVibrationDeviceList> out_interface);
 | 
			
		||||
    Result PermitVibration(bool can_vibrate);
 | 
			
		||||
    Result IsVibrationPermitted(Out<bool> out_is_permitted);
 | 
			
		||||
    Result SendVibrationValues(
 | 
			
		||||
        ClientAppletResourceUserId aruid,
 | 
			
		||||
        InArray<Core::HID::VibrationDeviceHandle, BufferAttr_HipcPointer> vibration_handles,
 | 
			
		||||
        InArray<Core::HID::VibrationValue, BufferAttr_HipcPointer> vibration_values);
 | 
			
		||||
    Result SendVibrationGcErmCommand(Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                                     ClientAppletResourceUserId aruid,
 | 
			
		||||
                                     Core::HID::VibrationGcErmCommand gc_erm_command);
 | 
			
		||||
    Result GetActualVibrationGcErmCommand(Out<Core::HID::VibrationGcErmCommand> out_gc_erm_command,
 | 
			
		||||
                                          Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                                          ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result BeginPermitVibrationSession(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result EndPermitVibrationSession(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsVibrationDeviceMounted(Out<bool> out_is_mounted,
 | 
			
		||||
                                    Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SendVibrationValueInBool(bool is_vibrating,
 | 
			
		||||
                                    Core::HID::VibrationDeviceHandle vibration_device_handle,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateConsoleSixAxisSensor(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StartConsoleSixAxisSensor(Core::HID::ConsoleSixAxisSensorHandle console_sixaxis_handle,
 | 
			
		||||
                                     ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StopConsoleSixAxisSensor(Core::HID::ConsoleSixAxisSensorHandle console_sixaxis_handle,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ActivateSevenSixAxisSensor(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StartSevenSixAxisSensor(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result StopSevenSixAxisSensor(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result InitializeSevenSixAxisSensor(ClientAppletResourceUserId aruid, u64 t_mem_1_size,
 | 
			
		||||
                                        u64 t_mem_2_size,
 | 
			
		||||
                                        InCopyHandle<Kernel::KTransferMemory> t_mem_1,
 | 
			
		||||
                                        InCopyHandle<Kernel::KTransferMemory> t_mem_2);
 | 
			
		||||
    Result FinalizeSevenSixAxisSensor(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result ResetSevenSixAxisSensorTimestamp(ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsUsbFullKeyControllerEnabled(Out<bool> out_is_enabled,
 | 
			
		||||
                                         ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetPalmaConnectionHandle(Out<Palma::PalmaConnectionHandle> out_handle,
 | 
			
		||||
                                    Core::HID::NpadIdType npad_id,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result InitializePalma(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result AcquirePalmaOperationCompleteEvent(OutCopyHandle<Kernel::KReadableEvent> out_event,
 | 
			
		||||
                                              Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result GetPalmaOperationInfo(Out<Palma::PalmaOperationType> out_operation_type,
 | 
			
		||||
                                 Palma::PalmaConnectionHandle connection_handle,
 | 
			
		||||
                                 OutBuffer<BufferAttr_HipcMapAlias> out_data);
 | 
			
		||||
    Result PlayPalmaActivity(Palma::PalmaConnectionHandle connection_handle, u64 palma_activity);
 | 
			
		||||
    Result SetPalmaFrModeType(Palma::PalmaConnectionHandle connection_handle,
 | 
			
		||||
                              Palma::PalmaFrModeType fr_mode);
 | 
			
		||||
    Result ReadPalmaStep(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result EnablePalmaStep(bool is_enabled, Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result ResetPalmaStep(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result ReadPalmaApplicationSection(Palma::PalmaConnectionHandle connection_handle, u64 offset,
 | 
			
		||||
                                       u64 size);
 | 
			
		||||
    Result WritePalmaApplicationSection(
 | 
			
		||||
        Palma::PalmaConnectionHandle connection_handle, u64 offset, u64 size,
 | 
			
		||||
        InLargeData<Palma::PalmaApplicationSection, BufferAttr_HipcPointer> data);
 | 
			
		||||
    Result ReadPalmaUniqueCode(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result SetPalmaUniqueCodeInvalid(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result WritePalmaActivityEntry(Palma::PalmaConnectionHandle connection_handle,
 | 
			
		||||
                                   Palma::PalmaActivityEntry activity_entry);
 | 
			
		||||
    Result WritePalmaRgbLedPatternEntry(Palma::PalmaConnectionHandle connection_handle, u64 unknown,
 | 
			
		||||
                                        InBuffer<BufferAttr_HipcMapAlias> led_pattern);
 | 
			
		||||
    Result WritePalmaWaveEntry(Palma::PalmaConnectionHandle connection_handle,
 | 
			
		||||
                               Palma::PalmaWaveSet wave_set, u64 unknown, u64 t_mem_size, u64 size,
 | 
			
		||||
                               InCopyHandle<Kernel::KTransferMemory> t_mem);
 | 
			
		||||
    Result SetPalmaDataBaseIdentificationVersion(s32 database_id_version,
 | 
			
		||||
                                                 Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result GetPalmaDataBaseIdentificationVersion(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result SuspendPalmaFeature(Palma::PalmaFeature feature,
 | 
			
		||||
                               Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result GetPalmaOperationResult(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result ReadPalmaPlayLog(u16 unknown, Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result ResetPalmaPlayLog(u16 unknown, Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result SetIsPalmaAllConnectable(bool is_palma_all_connectable, ClientAppletResourceUserId arui);
 | 
			
		||||
    Result SetIsPalmaPairedConnectable(bool is_palma_paired_connectable,
 | 
			
		||||
                                       ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result PairPalma(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result SetPalmaBoostMode(bool is_enabled);
 | 
			
		||||
    Result CancelWritePalmaWaveEntry(Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result EnablePalmaBoostMode(bool is_enabled, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result GetPalmaBluetoothAddress(Out<Palma::Address> out_bt_address,
 | 
			
		||||
                                    Palma::PalmaConnectionHandle connection_handle);
 | 
			
		||||
    Result SetDisallowedPalmaConnection(
 | 
			
		||||
        ClientAppletResourceUserId aruid,
 | 
			
		||||
        InArray<Palma::Address, BufferAttr_HipcPointer> disallowed_address);
 | 
			
		||||
    Result SetNpadCommunicationMode(ClientAppletResourceUserId aruid,
 | 
			
		||||
                                    NpadCommunicationMode communication_mode);
 | 
			
		||||
    Result GetNpadCommunicationMode(Out<NpadCommunicationMode> out_communication_mode,
 | 
			
		||||
                                    ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetTouchScreenConfiguration(Core::HID::TouchScreenConfigurationForNx touchscreen_config,
 | 
			
		||||
                                       ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result IsFirmwareUpdateNeededForNotification(Out<bool> out_is_firmware_update_needed,
 | 
			
		||||
                                                 s32 unknown, ClientAppletResourceUserId aruid);
 | 
			
		||||
    Result SetTouchScreenResolution(u32 width, u32 height, ClientAppletResourceUserId aruid);
 | 
			
		||||
 | 
			
		||||
    std::shared_ptr<ResourceManager> resource_manager;
 | 
			
		||||
    std::shared_ptr<HidFirmwareSettings> firmware_settings;
 | 
			
		||||
 
 | 
			
		||||
@@ -565,36 +565,28 @@ static_assert(sizeof(SixAxisSensorProperties) == 1, "SixAxisSensorProperties is
 | 
			
		||||
 | 
			
		||||
// This is nn::hid::SixAxisSensorCalibrationParameter
 | 
			
		||||
struct SixAxisSensorCalibrationParameter {
 | 
			
		||||
    std::array<u8, 0x744> unknown_data{};
 | 
			
		||||
    std::array<u8, 0x744> unknown_data;
 | 
			
		||||
};
 | 
			
		||||
static_assert(sizeof(SixAxisSensorCalibrationParameter) == 0x744,
 | 
			
		||||
              "SixAxisSensorCalibrationParameter is an invalid size");
 | 
			
		||||
static_assert(std::is_trivial_v<SixAxisSensorCalibrationParameter>,
 | 
			
		||||
              "SixAxisSensorCalibrationParameter must be trivial.");
 | 
			
		||||
 | 
			
		||||
// This is nn::hid::SixAxisSensorIcInformation
 | 
			
		||||
struct SixAxisSensorIcInformation {
 | 
			
		||||
    f32 angular_rate{2000.0f}; // dps
 | 
			
		||||
    std::array<f32, 6> unknown_gyro_data1{
 | 
			
		||||
        -10.0f, -10.0f, -10.0f, 10.0f, 10.0f, 10.0f,
 | 
			
		||||
    }; // dps
 | 
			
		||||
    std::array<f32, 9> unknown_gyro_data2{
 | 
			
		||||
        0.95f, -0.003f, -0.003f, -0.003f, 0.95f, -0.003f, -0.003f, -0.003f, 0.95f,
 | 
			
		||||
    };
 | 
			
		||||
    std::array<f32, 9> unknown_gyro_data3{
 | 
			
		||||
        1.05f, 0.003f, 0.003f, 0.003f, 1.05f, 0.003f, 0.003f, 0.003f, 1.05f,
 | 
			
		||||
    };
 | 
			
		||||
    f32 acceleration_range{8.0f}; // g force
 | 
			
		||||
    std::array<f32, 6> unknown_accel_data1{
 | 
			
		||||
        -0.0612f, -0.0612f, -0.0612f, 0.0612f, 0.0612f, 0.0612f,
 | 
			
		||||
    }; // g force
 | 
			
		||||
    std::array<f32, 9> unknown_accel_data2{
 | 
			
		||||
        0.95f, -0.003f, -0.003f, -0.003f, 0.95f, -0.003f, -0.003f, -0.003f, 0.95f,
 | 
			
		||||
    };
 | 
			
		||||
    std::array<f32, 9> unknown_accel_data3{
 | 
			
		||||
        1.05f, 0.003f, 0.003f, 0.003f, 1.05f, 0.003f, 0.003f, 0.003f, 1.05f,
 | 
			
		||||
    };
 | 
			
		||||
    f32 angular_rate;                      // dps
 | 
			
		||||
    std::array<f32, 6> unknown_gyro_data1; // dps
 | 
			
		||||
    std::array<f32, 9> unknown_gyro_data2;
 | 
			
		||||
    std::array<f32, 9> unknown_gyro_data3;
 | 
			
		||||
    f32 acceleration_range;                 // g force
 | 
			
		||||
    std::array<f32, 6> unknown_accel_data1; // g force
 | 
			
		||||
    std::array<f32, 9> unknown_accel_data2;
 | 
			
		||||
    std::array<f32, 9> unknown_accel_data3;
 | 
			
		||||
};
 | 
			
		||||
static_assert(sizeof(SixAxisSensorIcInformation) == 0xC8,
 | 
			
		||||
              "SixAxisSensorIcInformation is an invalid size");
 | 
			
		||||
static_assert(std::is_trivial_v<SixAxisSensorIcInformation>,
 | 
			
		||||
              "SixAxisSensorIcInformation must be trivial.");
 | 
			
		||||
 | 
			
		||||
// This is nn::hid::SixAxisSensorAttribute
 | 
			
		||||
struct SixAxisSensorAttribute {
 | 
			
		||||
 
 | 
			
		||||
@@ -4,7 +4,6 @@
 | 
			
		||||
#include "common/logging/log.h"
 | 
			
		||||
#include "core/core.h"
 | 
			
		||||
#include "core/core_timing.h"
 | 
			
		||||
#include "core/hle/kernel/k_shared_memory.h"
 | 
			
		||||
#include "core/hle/service/ipc_helpers.h"
 | 
			
		||||
#include "core/hle/service/set/system_settings_server.h"
 | 
			
		||||
#include "core/hle/service/sm/sm.h"
 | 
			
		||||
@@ -501,29 +500,4 @@ void ResourceManager::UpdateMotion(std::chrono::nanoseconds ns_late) {
 | 
			
		||||
    console_six_axis->OnUpdate(core_timing);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IAppletResource::IAppletResource(Core::System& system_, std::shared_ptr<ResourceManager> resource,
 | 
			
		||||
                                 u64 applet_resource_user_id)
 | 
			
		||||
    : ServiceFramework{system_, "IAppletResource"}, aruid{applet_resource_user_id},
 | 
			
		||||
      resource_manager{resource} {
 | 
			
		||||
    static const FunctionInfo functions[] = {
 | 
			
		||||
        {0, &IAppletResource::GetSharedMemoryHandle, "GetSharedMemoryHandle"},
 | 
			
		||||
    };
 | 
			
		||||
    RegisterHandlers(functions);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IAppletResource::~IAppletResource() {
 | 
			
		||||
    resource_manager->FreeAppletResourceId(aruid);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void IAppletResource::GetSharedMemoryHandle(HLERequestContext& ctx) {
 | 
			
		||||
    Kernel::KSharedMemory* handle;
 | 
			
		||||
    const auto result = resource_manager->GetSharedMemoryHandle(&handle, aruid);
 | 
			
		||||
 | 
			
		||||
    LOG_DEBUG(Service_HID, "called, applet_resource_user_id={}, result=0x{:X}", aruid, result.raw);
 | 
			
		||||
 | 
			
		||||
    IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
			
		||||
    rb.Push(result);
 | 
			
		||||
    rb.PushCopyObjects(handle);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
 
 | 
			
		||||
@@ -174,17 +174,4 @@ private:
 | 
			
		||||
    KernelHelpers::ServiceContext service_context;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
class IAppletResource final : public ServiceFramework<IAppletResource> {
 | 
			
		||||
public:
 | 
			
		||||
    explicit IAppletResource(Core::System& system_, std::shared_ptr<ResourceManager> resource,
 | 
			
		||||
                             u64 applet_resource_user_id);
 | 
			
		||||
    ~IAppletResource() override;
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
    void GetSharedMemoryHandle(HLERequestContext& ctx);
 | 
			
		||||
 | 
			
		||||
    u64 aruid{};
 | 
			
		||||
    std::shared_ptr<ResourceManager> resource_manager;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
} // namespace Service::HID
 | 
			
		||||
 
 | 
			
		||||
@@ -56,12 +56,14 @@ Kernel::KReadableEvent& Palma::AcquirePalmaOperationCompleteEvent(
 | 
			
		||||
 | 
			
		||||
Result Palma::GetPalmaOperationInfo(const PalmaConnectionHandle& handle,
 | 
			
		||||
                                    PalmaOperationType& operation_type,
 | 
			
		||||
                                    PalmaOperationData& data) const {
 | 
			
		||||
                                    std::span<u8> out_data) const {
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation_type = operation.operation;
 | 
			
		||||
    data = operation.data;
 | 
			
		||||
    operation_type = static_cast<PalmaOperationType>(operation.operation);
 | 
			
		||||
    std::memcpy(out_data.data(), operation.data.data(),
 | 
			
		||||
                std::min(out_data.size(), operation.data.size()));
 | 
			
		||||
 | 
			
		||||
    return ResultSuccess;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -69,7 +71,7 @@ Result Palma::PlayPalmaActivity(const PalmaConnectionHandle& handle, u64 palma_a
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::PlayActivity;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::PlayActivity;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -88,7 +90,7 @@ Result Palma::ReadPalmaStep(const PalmaConnectionHandle& handle) {
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::ReadStep;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::ReadStep;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -117,7 +119,7 @@ Result Palma::ReadPalmaUniqueCode(const PalmaConnectionHandle& handle) {
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::ReadUniqueCode;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::ReadUniqueCode;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -128,7 +130,7 @@ Result Palma::SetPalmaUniqueCodeInvalid(const PalmaConnectionHandle& handle) {
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::SetUniqueCodeInvalid;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::SetUniqueCodeInvalid;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -141,7 +143,7 @@ Result Palma::WritePalmaRgbLedPatternEntry(const PalmaConnectionHandle& handle,
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::WriteRgbLedPatternEntry;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::WriteRgbLedPatternEntry;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -153,7 +155,7 @@ Result Palma::WritePalmaWaveEntry(const PalmaConnectionHandle& handle, PalmaWave
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::WriteWaveEntry;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::WriteWaveEntry;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -166,7 +168,7 @@ Result Palma::SetPalmaDataBaseIdentificationVersion(const PalmaConnectionHandle&
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    database_id_version = database_id_version_;
 | 
			
		||||
    operation.operation = PalmaOperationType::ReadDataBaseIdentificationVersion;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::ReadDataBaseIdentificationVersion;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data[0] = {};
 | 
			
		||||
    operation_complete_event->Signal();
 | 
			
		||||
@@ -177,7 +179,7 @@ Result Palma::GetPalmaDataBaseIdentificationVersion(const PalmaConnectionHandle&
 | 
			
		||||
    if (handle.npad_id != active_handle.npad_id) {
 | 
			
		||||
        return InvalidPalmaHandle;
 | 
			
		||||
    }
 | 
			
		||||
    operation.operation = PalmaOperationType::ReadDataBaseIdentificationVersion;
 | 
			
		||||
    operation.operation = PackedPalmaOperationType::ReadDataBaseIdentificationVersion;
 | 
			
		||||
    operation.result = PalmaResultSuccess;
 | 
			
		||||
    operation.data = {};
 | 
			
		||||
    operation.data[0] = static_cast<u8>(database_id_version);
 | 
			
		||||
 
 | 
			
		||||
@@ -4,6 +4,8 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <array>
 | 
			
		||||
#include <span>
 | 
			
		||||
 | 
			
		||||
#include "common/common_funcs.h"
 | 
			
		||||
#include "common/typed_address.h"
 | 
			
		||||
#include "hid_core/hid_result.h"
 | 
			
		||||
@@ -27,9 +29,31 @@ namespace Service::HID {
 | 
			
		||||
class Palma final : public ControllerBase {
 | 
			
		||||
public:
 | 
			
		||||
    using PalmaOperationData = std::array<u8, 0x140>;
 | 
			
		||||
    using PalmaApplicationSection = std::array<u8, 0x100>;
 | 
			
		||||
    using Address = std::array<u8, 0x6>;
 | 
			
		||||
 | 
			
		||||
    // This is nn::hid::PalmaOperationType
 | 
			
		||||
    enum class PalmaOperationType {
 | 
			
		||||
    enum class PalmaOperationType : u64 {
 | 
			
		||||
        PlayActivity,
 | 
			
		||||
        SetFrModeType,
 | 
			
		||||
        ReadStep,
 | 
			
		||||
        EnableStep,
 | 
			
		||||
        ResetStep,
 | 
			
		||||
        ReadApplicationSection,
 | 
			
		||||
        WriteApplicationSection,
 | 
			
		||||
        ReadUniqueCode,
 | 
			
		||||
        SetUniqueCodeInvalid,
 | 
			
		||||
        WriteActivityEntry,
 | 
			
		||||
        WriteRgbLedPatternEntry,
 | 
			
		||||
        WriteWaveEntry,
 | 
			
		||||
        ReadDataBaseIdentificationVersion,
 | 
			
		||||
        WriteDataBaseIdentificationVersion,
 | 
			
		||||
        SuspendFeature,
 | 
			
		||||
        ReadPlayLog,
 | 
			
		||||
        ResetPlayLog,
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    enum class PackedPalmaOperationType : u32 {
 | 
			
		||||
        PlayActivity,
 | 
			
		||||
        SetFrModeType,
 | 
			
		||||
        ReadStep,
 | 
			
		||||
@@ -75,7 +99,7 @@ public:
 | 
			
		||||
 | 
			
		||||
    // This is nn::hid::PalmaOperationInfo
 | 
			
		||||
    struct PalmaOperationInfo {
 | 
			
		||||
        PalmaOperationType operation{};
 | 
			
		||||
        PackedPalmaOperationType operation{};
 | 
			
		||||
        Result result{PalmaResultSuccess};
 | 
			
		||||
        PalmaOperationData data{};
 | 
			
		||||
    };
 | 
			
		||||
@@ -92,8 +116,7 @@ public:
 | 
			
		||||
    static_assert(sizeof(PalmaActivityEntry) == 0x20, "PalmaActivityEntry is an invalid size");
 | 
			
		||||
 | 
			
		||||
    struct PalmaConnectionHandle {
 | 
			
		||||
        Core::HID::NpadIdType npad_id;
 | 
			
		||||
        INSERT_PADDING_BYTES(4); // Unknown
 | 
			
		||||
        alignas(8) Core::HID::NpadIdType npad_id;
 | 
			
		||||
    };
 | 
			
		||||
    static_assert(sizeof(PalmaConnectionHandle) == 0x8,
 | 
			
		||||
                  "PalmaConnectionHandle has incorrect size.");
 | 
			
		||||
@@ -115,8 +138,7 @@ public:
 | 
			
		||||
    Kernel::KReadableEvent& AcquirePalmaOperationCompleteEvent(
 | 
			
		||||
        const PalmaConnectionHandle& handle) const;
 | 
			
		||||
    Result GetPalmaOperationInfo(const PalmaConnectionHandle& handle,
 | 
			
		||||
                                 PalmaOperationType& operation_type,
 | 
			
		||||
                                 PalmaOperationData& data) const;
 | 
			
		||||
                                 PalmaOperationType& operation_type, std::span<u8> out_data) const;
 | 
			
		||||
    Result PlayPalmaActivity(const PalmaConnectionHandle& handle, u64 palma_activity);
 | 
			
		||||
    Result SetPalmaFrModeType(const PalmaConnectionHandle& handle, PalmaFrModeType fr_mode_);
 | 
			
		||||
    Result ReadPalmaStep(const PalmaConnectionHandle& handle);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user