IHidServer.cs 66 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668
  1. using Ryujinx.Common.Logging;
  2. using Ryujinx.HLE.HOS.Ipc;
  3. using Ryujinx.HLE.HOS.Kernel.Common;
  4. using Ryujinx.HLE.HOS.Kernel.Threading;
  5. using Ryujinx.HLE.HOS.Services.Hid.HidServer;
  6. using Ryujinx.HLE.HOS.Services.Hid.Types;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Runtime.InteropServices;
  10. namespace Ryujinx.HLE.HOS.Services.Hid
  11. {
  12. [Service("hid")]
  13. class IHidServer : IpcService
  14. {
  15. private KEvent _xpadIdEvent;
  16. private KEvent _palmaOperationCompleteEvent;
  17. private int _xpadIdEventHandle;
  18. private bool _sixAxisSensorFusionEnabled;
  19. private bool _unintendedHomeButtonInputProtectionEnabled;
  20. private bool _vibrationPermitted;
  21. private bool _usbFullKeyControllerEnabled;
  22. private bool _isFirmwareUpdateAvailableForSixAxisSensor;
  23. private HidNpadJoyAssignmentMode _npadJoyAssignmentMode;
  24. private HidNpadHandheldActivationMode _npadHandheldActivationMode;
  25. private HidGyroscopeZeroDriftMode _gyroscopeZeroDriftMode;
  26. private long _npadCommunicationMode;
  27. private uint _accelerometerPlayMode;
  28. #pragma warning disable CS0649
  29. private long _vibrationGcErmCommand;
  30. #pragma warning restore CS0649
  31. private float _sevenSixAxisSensorFusionStrength;
  32. private HidSensorFusionParameters _sensorFusionParams;
  33. private HidAccelerometerParameters _accelerometerParams;
  34. private HidVibrationValue _vibrationValue;
  35. public IHidServer(ServiceCtx context) : base(context.Device.System.HidServer)
  36. {
  37. _xpadIdEvent = new KEvent(context.Device.System.KernelContext);
  38. _palmaOperationCompleteEvent = new KEvent(context.Device.System.KernelContext);
  39. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Dual;
  40. _npadHandheldActivationMode = HidNpadHandheldActivationMode.Dual;
  41. _gyroscopeZeroDriftMode = HidGyroscopeZeroDriftMode.Standard;
  42. _isFirmwareUpdateAvailableForSixAxisSensor = false;
  43. _sensorFusionParams = new HidSensorFusionParameters();
  44. _accelerometerParams = new HidAccelerometerParameters();
  45. _vibrationValue = new HidVibrationValue();
  46. // TODO: signal event at right place
  47. _xpadIdEvent.ReadableEvent.Signal();
  48. }
  49. [CommandHipc(0)]
  50. // CreateAppletResource(nn::applet::AppletResourceUserId) -> object<nn::hid::IAppletResource>
  51. public ResultCode CreateAppletResource(ServiceCtx context)
  52. {
  53. long appletResourceUserId = context.RequestData.ReadInt64();
  54. MakeObject(context, new IAppletResource(context.Device.System.HidSharedMem));
  55. return ResultCode.Success;
  56. }
  57. [CommandHipc(1)]
  58. // ActivateDebugPad(nn::applet::AppletResourceUserId)
  59. public ResultCode ActivateDebugPad(ServiceCtx context)
  60. {
  61. long appletResourceUserId = context.RequestData.ReadInt64();
  62. // Initialize entries to avoid issues with some games.
  63. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  64. {
  65. context.Device.Hid.DebugPad.Update();
  66. }
  67. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  68. return ResultCode.Success;
  69. }
  70. [CommandHipc(11)]
  71. // ActivateTouchScreen(nn::applet::AppletResourceUserId)
  72. public ResultCode ActivateTouchScreen(ServiceCtx context)
  73. {
  74. long appletResourceUserId = context.RequestData.ReadInt64();
  75. context.Device.Hid.Touchscreen.Active = true;
  76. // Initialize entries to avoid issues with some games.
  77. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  78. {
  79. context.Device.Hid.Touchscreen.Update();
  80. }
  81. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  82. return ResultCode.Success;
  83. }
  84. [CommandHipc(21)]
  85. // ActivateMouse(nn::applet::AppletResourceUserId)
  86. public ResultCode ActivateMouse(ServiceCtx context)
  87. {
  88. long appletResourceUserId = context.RequestData.ReadInt64();
  89. context.Device.Hid.Mouse.Active = true;
  90. // Initialize entries to avoid issues with some games.
  91. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  92. {
  93. context.Device.Hid.Mouse.Update(0, 0);
  94. }
  95. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  96. return ResultCode.Success;
  97. }
  98. [CommandHipc(31)]
  99. // ActivateKeyboard(nn::applet::AppletResourceUserId)
  100. public ResultCode ActivateKeyboard(ServiceCtx context)
  101. {
  102. long appletResourceUserId = context.RequestData.ReadInt64();
  103. context.Device.Hid.Keyboard.Active = true;
  104. // Initialize entries to avoid issues with some games.
  105. KeyboardInput emptyInput = new KeyboardInput();
  106. emptyInput.Keys = new ulong[4];
  107. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  108. {
  109. context.Device.Hid.Keyboard.Update(emptyInput);
  110. }
  111. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  112. return ResultCode.Success;
  113. }
  114. [CommandHipc(32)]
  115. // SendKeyboardLockKeyEvent(uint flags, pid)
  116. public ResultCode SendKeyboardLockKeyEvent(ServiceCtx context)
  117. {
  118. uint flags = context.RequestData.ReadUInt32();
  119. // NOTE: This signal the keyboard driver about lock events.
  120. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { flags });
  121. return ResultCode.Success;
  122. }
  123. [CommandHipc(40)]
  124. // AcquireXpadIdEventHandle(ulong XpadId) -> nn::sf::NativeHandle
  125. public ResultCode AcquireXpadIdEventHandle(ServiceCtx context)
  126. {
  127. long xpadId = context.RequestData.ReadInt64();
  128. if (context.Process.HandleTable.GenerateHandle(_xpadIdEvent.ReadableEvent, out _xpadIdEventHandle) != KernelResult.Success)
  129. {
  130. throw new InvalidOperationException("Out of handles!");
  131. }
  132. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(_xpadIdEventHandle);
  133. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { xpadId });
  134. return ResultCode.Success;
  135. }
  136. [CommandHipc(41)]
  137. // ReleaseXpadIdEventHandle(ulong XpadId)
  138. public ResultCode ReleaseXpadIdEventHandle(ServiceCtx context)
  139. {
  140. long xpadId = context.RequestData.ReadInt64();
  141. context.Process.HandleTable.CloseHandle(_xpadIdEventHandle);
  142. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { xpadId });
  143. return ResultCode.Success;
  144. }
  145. [CommandHipc(51)]
  146. // ActivateXpad(nn::hid::BasicXpadId, nn::applet::AppletResourceUserId)
  147. public ResultCode ActivateXpad(ServiceCtx context)
  148. {
  149. int basicXpadId = context.RequestData.ReadInt32();
  150. long appletResourceUserId = context.RequestData.ReadInt64();
  151. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, basicXpadId });
  152. return ResultCode.Success;
  153. }
  154. [CommandHipc(55)]
  155. // GetXpadIds() -> long IdsCount, buffer<array<nn::hid::BasicXpadId>, type: 0xa>
  156. public ResultCode GetXpadIds(ServiceCtx context)
  157. {
  158. // There is any Xpad, so we return 0 and write nothing inside the type-0xa buffer.
  159. context.ResponseData.Write(0L);
  160. Logger.Stub?.PrintStub(LogClass.ServiceHid);
  161. return ResultCode.Success;
  162. }
  163. [CommandHipc(56)]
  164. // ActivateJoyXpad(nn::hid::JoyXpadId)
  165. public ResultCode ActivateJoyXpad(ServiceCtx context)
  166. {
  167. int joyXpadId = context.RequestData.ReadInt32();
  168. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { joyXpadId });
  169. return ResultCode.Success;
  170. }
  171. [CommandHipc(58)]
  172. // GetJoyXpadLifoHandle(nn::hid::JoyXpadId) -> nn::sf::NativeHandle
  173. public ResultCode GetJoyXpadLifoHandle(ServiceCtx context)
  174. {
  175. int joyXpadId = context.RequestData.ReadInt32();
  176. int handle = 0;
  177. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  178. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { joyXpadId });
  179. return ResultCode.Success;
  180. }
  181. [CommandHipc(59)]
  182. // GetJoyXpadIds() -> long IdsCount, buffer<array<nn::hid::JoyXpadId>, type: 0xa>
  183. public ResultCode GetJoyXpadIds(ServiceCtx context)
  184. {
  185. // There is any JoyXpad, so we return 0 and write nothing inside the type-0xa buffer.
  186. context.ResponseData.Write(0L);
  187. Logger.Stub?.PrintStub(LogClass.ServiceHid);
  188. return ResultCode.Success;
  189. }
  190. [CommandHipc(60)]
  191. // ActivateSixAxisSensor(nn::hid::BasicXpadId)
  192. public ResultCode ActivateSixAxisSensor(ServiceCtx context)
  193. {
  194. int basicXpadId = context.RequestData.ReadInt32();
  195. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { basicXpadId });
  196. return ResultCode.Success;
  197. }
  198. [CommandHipc(61)]
  199. // DeactivateSixAxisSensor(nn::hid::BasicXpadId)
  200. public ResultCode DeactivateSixAxisSensor(ServiceCtx context)
  201. {
  202. int basicXpadId = context.RequestData.ReadInt32();
  203. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { basicXpadId });
  204. return ResultCode.Success;
  205. }
  206. [CommandHipc(62)]
  207. // GetSixAxisSensorLifoHandle(nn::hid::BasicXpadId) -> nn::sf::NativeHandle
  208. public ResultCode GetSixAxisSensorLifoHandle(ServiceCtx context)
  209. {
  210. int basicXpadId = context.RequestData.ReadInt32();
  211. int handle = 0;
  212. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  213. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { basicXpadId });
  214. return ResultCode.Success;
  215. }
  216. [CommandHipc(63)]
  217. // ActivateJoySixAxisSensor(nn::hid::JoyXpadId)
  218. public ResultCode ActivateJoySixAxisSensor(ServiceCtx context)
  219. {
  220. int joyXpadId = context.RequestData.ReadInt32();
  221. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { joyXpadId });
  222. return ResultCode.Success;
  223. }
  224. [CommandHipc(64)]
  225. // DeactivateJoySixAxisSensor(nn::hid::JoyXpadId)
  226. public ResultCode DeactivateJoySixAxisSensor(ServiceCtx context)
  227. {
  228. int joyXpadId = context.RequestData.ReadInt32();
  229. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { joyXpadId });
  230. return ResultCode.Success;
  231. }
  232. [CommandHipc(65)]
  233. // GetJoySixAxisSensorLifoHandle(nn::hid::JoyXpadId) -> nn::sf::NativeHandle
  234. public ResultCode GetJoySixAxisSensorLifoHandle(ServiceCtx context)
  235. {
  236. int joyXpadId = context.RequestData.ReadInt32();
  237. int handle = 0;
  238. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  239. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { joyXpadId });
  240. return ResultCode.Success;
  241. }
  242. [CommandHipc(66)]
  243. // StartSixAxisSensor(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  244. public ResultCode StartSixAxisSensor(ServiceCtx context)
  245. {
  246. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  247. long appletResourceUserId = context.RequestData.ReadInt64();
  248. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle });
  249. return ResultCode.Success;
  250. }
  251. [CommandHipc(67)]
  252. // StopSixAxisSensor(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  253. public ResultCode StopSixAxisSensor(ServiceCtx context)
  254. {
  255. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  256. long appletResourceUserId = context.RequestData.ReadInt64();
  257. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle });
  258. return ResultCode.Success;
  259. }
  260. [CommandHipc(68)]
  261. // IsSixAxisSensorFusionEnabled(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId) -> bool IsEnabled
  262. public ResultCode IsSixAxisSensorFusionEnabled(ServiceCtx context)
  263. {
  264. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  265. long appletResourceUserId = context.RequestData.ReadInt64();
  266. context.ResponseData.Write(_sixAxisSensorFusionEnabled);
  267. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _sixAxisSensorFusionEnabled });
  268. return ResultCode.Success;
  269. }
  270. [CommandHipc(69)]
  271. // EnableSixAxisSensorFusion(bool Enabled, nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  272. public ResultCode EnableSixAxisSensorFusion(ServiceCtx context)
  273. {
  274. _sixAxisSensorFusionEnabled = context.RequestData.ReadBoolean();
  275. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  276. long appletResourceUserId = context.RequestData.ReadInt64();
  277. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _sixAxisSensorFusionEnabled });
  278. return ResultCode.Success;
  279. }
  280. [CommandHipc(70)]
  281. // SetSixAxisSensorFusionParameters(nn::hid::SixAxisSensorHandle, float RevisePower, float ReviseRange, nn::applet::AppletResourceUserId)
  282. public ResultCode SetSixAxisSensorFusionParameters(ServiceCtx context)
  283. {
  284. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  285. _sensorFusionParams = new HidSensorFusionParameters
  286. {
  287. RevisePower = context.RequestData.ReadInt32(),
  288. ReviseRange = context.RequestData.ReadInt32()
  289. };
  290. long appletResourceUserId = context.RequestData.ReadInt64();
  291. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _sensorFusionParams.RevisePower, _sensorFusionParams.ReviseRange });
  292. return ResultCode.Success;
  293. }
  294. [CommandHipc(71)]
  295. // GetSixAxisSensorFusionParameters(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId) -> float RevisePower, float ReviseRange)
  296. public ResultCode GetSixAxisSensorFusionParameters(ServiceCtx context)
  297. {
  298. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  299. long appletResourceUserId = context.RequestData.ReadInt64();
  300. context.ResponseData.Write(_sensorFusionParams.RevisePower);
  301. context.ResponseData.Write(_sensorFusionParams.ReviseRange);
  302. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _sensorFusionParams.RevisePower, _sensorFusionParams.ReviseRange });
  303. return ResultCode.Success;
  304. }
  305. [CommandHipc(72)]
  306. // ResetSixAxisSensorFusionParameters(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  307. public ResultCode ResetSixAxisSensorFusionParameters(ServiceCtx context)
  308. {
  309. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  310. long appletResourceUserId = context.RequestData.ReadInt64();
  311. _sensorFusionParams.RevisePower = 0;
  312. _sensorFusionParams.ReviseRange = 0;
  313. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _sensorFusionParams.RevisePower, _sensorFusionParams.ReviseRange });
  314. return ResultCode.Success;
  315. }
  316. [CommandHipc(73)]
  317. // SetAccelerometerParameters(nn::hid::SixAxisSensorHandle, float X, float Y, nn::applet::AppletResourceUserId)
  318. public ResultCode SetAccelerometerParameters(ServiceCtx context)
  319. {
  320. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  321. _accelerometerParams = new HidAccelerometerParameters
  322. {
  323. X = context.RequestData.ReadInt32(),
  324. Y = context.RequestData.ReadInt32()
  325. };
  326. long appletResourceUserId = context.RequestData.ReadInt64();
  327. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerParams.X, _accelerometerParams.Y });
  328. return ResultCode.Success;
  329. }
  330. [CommandHipc(74)]
  331. // GetAccelerometerParameters(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId) -> float X, float Y
  332. public ResultCode GetAccelerometerParameters(ServiceCtx context)
  333. {
  334. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  335. long appletResourceUserId = context.RequestData.ReadInt64();
  336. context.ResponseData.Write(_accelerometerParams.X);
  337. context.ResponseData.Write(_accelerometerParams.Y);
  338. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerParams.X, _accelerometerParams.Y });
  339. return ResultCode.Success;
  340. }
  341. [CommandHipc(75)]
  342. // ResetAccelerometerParameters(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  343. public ResultCode ResetAccelerometerParameters(ServiceCtx context)
  344. {
  345. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  346. long appletResourceUserId = context.RequestData.ReadInt64();
  347. _accelerometerParams.X = 0;
  348. _accelerometerParams.Y = 0;
  349. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerParams.X, _accelerometerParams.Y });
  350. return ResultCode.Success;
  351. }
  352. [CommandHipc(76)]
  353. // SetAccelerometerPlayMode(nn::hid::SixAxisSensorHandle, uint PlayMode, nn::applet::AppletResourceUserId)
  354. public ResultCode SetAccelerometerPlayMode(ServiceCtx context)
  355. {
  356. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  357. _accelerometerPlayMode = context.RequestData.ReadUInt32();
  358. long appletResourceUserId = context.RequestData.ReadInt64();
  359. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerPlayMode });
  360. return ResultCode.Success;
  361. }
  362. [CommandHipc(77)]
  363. // GetAccelerometerPlayMode(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId) -> uint PlayMode
  364. public ResultCode GetAccelerometerPlayMode(ServiceCtx context)
  365. {
  366. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  367. long appletResourceUserId = context.RequestData.ReadInt64();
  368. context.ResponseData.Write(_accelerometerPlayMode);
  369. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerPlayMode });
  370. return ResultCode.Success;
  371. }
  372. [CommandHipc(78)]
  373. // ResetAccelerometerPlayMode(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  374. public ResultCode ResetAccelerometerPlayMode(ServiceCtx context)
  375. {
  376. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  377. long appletResourceUserId = context.RequestData.ReadInt64();
  378. _accelerometerPlayMode = 0;
  379. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _accelerometerPlayMode });
  380. return ResultCode.Success;
  381. }
  382. [CommandHipc(79)]
  383. // SetGyroscopeZeroDriftMode(nn::hid::SixAxisSensorHandle, uint GyroscopeZeroDriftMode, nn::applet::AppletResourceUserId)
  384. public ResultCode SetGyroscopeZeroDriftMode(ServiceCtx context)
  385. {
  386. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  387. _gyroscopeZeroDriftMode = (HidGyroscopeZeroDriftMode)context.RequestData.ReadInt32();
  388. long appletResourceUserId = context.RequestData.ReadInt64();
  389. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _gyroscopeZeroDriftMode });
  390. return ResultCode.Success;
  391. }
  392. [CommandHipc(80)]
  393. // GetGyroscopeZeroDriftMode(nn::applet::AppletResourceUserId, nn::hid::SixAxisSensorHandle) -> int GyroscopeZeroDriftMode
  394. public ResultCode GetGyroscopeZeroDriftMode(ServiceCtx context)
  395. {
  396. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  397. long appletResourceUserId = context.RequestData.ReadInt64();
  398. context.ResponseData.Write((int)_gyroscopeZeroDriftMode);
  399. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _gyroscopeZeroDriftMode });
  400. return ResultCode.Success;
  401. }
  402. [CommandHipc(81)]
  403. // ResetGyroscopeZeroDriftMode(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId)
  404. public ResultCode ResetGyroscopeZeroDriftMode(ServiceCtx context)
  405. {
  406. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  407. long appletResourceUserId = context.RequestData.ReadInt64();
  408. _gyroscopeZeroDriftMode = HidGyroscopeZeroDriftMode.Standard;
  409. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _gyroscopeZeroDriftMode });
  410. return ResultCode.Success;
  411. }
  412. [CommandHipc(82)]
  413. // IsSixAxisSensorAtRest(nn::hid::SixAxisSensorHandle, nn::applet::AppletResourceUserId) -> bool IsAsRest
  414. public ResultCode IsSixAxisSensorAtRest(ServiceCtx context)
  415. {
  416. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  417. long appletResourceUserId = context.RequestData.ReadInt64();
  418. bool isAtRest = true;
  419. context.ResponseData.Write(isAtRest);
  420. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, isAtRest });
  421. return ResultCode.Success;
  422. }
  423. [CommandHipc(83)] // 6.0.0+
  424. // IsFirmwareUpdateAvailableForSixAxisSensor(nn::hid::AppletResourceUserId, nn::hid::SixAxisSensorHandle, pid) -> bool UpdateAvailable
  425. public ResultCode IsFirmwareUpdateAvailableForSixAxisSensor(ServiceCtx context)
  426. {
  427. int sixAxisSensorHandle = context.RequestData.ReadInt32();
  428. context.RequestData.BaseStream.Position += 4;
  429. long appletResourceUserId = context.RequestData.ReadInt64();
  430. context.ResponseData.Write(_isFirmwareUpdateAvailableForSixAxisSensor);
  431. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, sixAxisSensorHandle, _isFirmwareUpdateAvailableForSixAxisSensor });
  432. return ResultCode.Success;
  433. }
  434. [CommandHipc(91)]
  435. // ActivateGesture(nn::applet::AppletResourceUserId, int Unknown0)
  436. public ResultCode ActivateGesture(ServiceCtx context)
  437. {
  438. long appletResourceUserId = context.RequestData.ReadInt64();
  439. int unknown0 = context.RequestData.ReadInt32();
  440. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknown0 });
  441. return ResultCode.Success;
  442. }
  443. [CommandHipc(100)]
  444. // SetSupportedNpadStyleSet(nn::applet::AppletResourceUserId, nn::hid::NpadStyleTag)
  445. public ResultCode SetSupportedNpadStyleSet(ServiceCtx context)
  446. {
  447. ControllerType type = (ControllerType)context.RequestData.ReadInt32();
  448. long appletResourceUserId = context.RequestData.ReadInt64();
  449. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  450. appletResourceUserId,
  451. type
  452. });
  453. context.Device.Hid.Npads.SupportedStyleSets = type;
  454. return ResultCode.Success;
  455. }
  456. [CommandHipc(101)]
  457. // GetSupportedNpadStyleSet(nn::applet::AppletResourceUserId) -> uint nn::hid::NpadStyleTag
  458. public ResultCode GetSupportedNpadStyleSet(ServiceCtx context)
  459. {
  460. long appletResourceUserId = context.RequestData.ReadInt64();
  461. context.ResponseData.Write((int)context.Device.Hid.Npads.SupportedStyleSets);
  462. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  463. appletResourceUserId,
  464. context.Device.Hid.Npads.SupportedStyleSets
  465. });
  466. return ResultCode.Success;
  467. }
  468. [CommandHipc(102)]
  469. // SetSupportedNpadIdType(nn::applet::AppletResourceUserId, array<NpadIdType, 9>)
  470. public ResultCode SetSupportedNpadIdType(ServiceCtx context)
  471. {
  472. long appletResourceUserId = context.RequestData.ReadInt64();
  473. ulong arrayPosition = context.Request.PtrBuff[0].Position;
  474. ulong arraySize = context.Request.PtrBuff[0].Size;
  475. ReadOnlySpan<NpadIdType> supportedPlayerIds = MemoryMarshal.Cast<byte, NpadIdType>(context.Memory.GetSpan(arrayPosition, (int)arraySize));
  476. context.Device.Hid.Npads.ClearSupportedPlayers();
  477. for (int i = 0; i < supportedPlayerIds.Length; ++i)
  478. {
  479. if (supportedPlayerIds[i] >= 0)
  480. {
  481. context.Device.Hid.Npads.SetSupportedPlayer(HidUtils.GetIndexFromNpadIdType(supportedPlayerIds[i]));
  482. }
  483. }
  484. Logger.Stub?.PrintStub(LogClass.ServiceHid, $"{supportedPlayerIds.Length} " + string.Join(",", supportedPlayerIds.ToArray()));
  485. return ResultCode.Success;
  486. }
  487. [CommandHipc(103)]
  488. // ActivateNpad(nn::applet::AppletResourceUserId)
  489. public ResultCode ActivateNpad(ServiceCtx context)
  490. {
  491. long appletResourceUserId = context.RequestData.ReadInt64();
  492. context.Device.Hid.Npads.Active = true;
  493. // Initialize entries to avoid issues with some games.
  494. List<GamepadInput> emptyGamepadInputs = new List<GamepadInput>();
  495. List<SixAxisInput> emptySixAxisInputs = new List<SixAxisInput>();
  496. for (int player = 0; player < NpadDevices.MaxControllers; player++)
  497. {
  498. GamepadInput gamepadInput = new GamepadInput();
  499. SixAxisInput sixaxisInput = new SixAxisInput();
  500. gamepadInput.PlayerId = (PlayerIndex)player;
  501. sixaxisInput.PlayerId = (PlayerIndex)player;
  502. sixaxisInput.Orientation = new float[9];
  503. emptyGamepadInputs.Add(gamepadInput);
  504. emptySixAxisInputs.Add(sixaxisInput);
  505. }
  506. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  507. {
  508. context.Device.Hid.Npads.Update(emptyGamepadInputs);
  509. context.Device.Hid.Npads.UpdateSixAxis(emptySixAxisInputs);
  510. }
  511. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  512. return ResultCode.Success;
  513. }
  514. [CommandHipc(104)]
  515. // DeactivateNpad(nn::applet::AppletResourceUserId)
  516. public ResultCode DeactivateNpad(ServiceCtx context)
  517. {
  518. long appletResourceUserId = context.RequestData.ReadInt64();
  519. context.Device.Hid.Npads.Active = false;
  520. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  521. return ResultCode.Success;
  522. }
  523. [CommandHipc(106)]
  524. // AcquireNpadStyleSetUpdateEventHandle(nn::applet::AppletResourceUserId, uint, ulong) -> nn::sf::NativeHandle
  525. public ResultCode AcquireNpadStyleSetUpdateEventHandle(ServiceCtx context)
  526. {
  527. PlayerIndex npadId = HidUtils.GetIndexFromNpadIdType((NpadIdType)context.RequestData.ReadInt32());
  528. long appletResourceUserId = context.RequestData.ReadInt64();
  529. long npadStyleSet = context.RequestData.ReadInt64();
  530. KEvent evnt = context.Device.Hid.Npads.GetStyleSetUpdateEvent(npadId);
  531. if (context.Process.HandleTable.GenerateHandle(evnt.ReadableEvent, out int handle) != KernelResult.Success)
  532. {
  533. throw new InvalidOperationException("Out of handles!");
  534. }
  535. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  536. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, npadId, npadStyleSet });
  537. return ResultCode.Success;
  538. }
  539. [CommandHipc(107)]
  540. // DisconnectNpad(nn::applet::AppletResourceUserId, uint NpadIdType)
  541. public ResultCode DisconnectNpad(ServiceCtx context)
  542. {
  543. NpadIdType npadIdType = (NpadIdType)context.RequestData.ReadInt32();
  544. long appletResourceUserId = context.RequestData.ReadInt64();
  545. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, npadIdType });
  546. return ResultCode.Success;
  547. }
  548. [CommandHipc(108)]
  549. // GetPlayerLedPattern(u32 npad_id) -> u64 led_pattern
  550. public ResultCode GetPlayerLedPattern(ServiceCtx context)
  551. {
  552. NpadIdType npadId = (NpadIdType)context.RequestData.ReadUInt32();
  553. ulong ledPattern = npadId switch
  554. {
  555. NpadIdType.Player1 => 0b0001,
  556. NpadIdType.Player2 => 0b0011,
  557. NpadIdType.Player3 => 0b0111,
  558. NpadIdType.Player4 => 0b1111,
  559. NpadIdType.Player5 => 0b1001,
  560. NpadIdType.Player6 => 0b0101,
  561. NpadIdType.Player7 => 0b1101,
  562. NpadIdType.Player8 => 0b0110,
  563. NpadIdType.Unknown => 0b0000,
  564. NpadIdType.Handheld => 0b0000,
  565. _ => throw new ArgumentOutOfRangeException(nameof(npadId))
  566. };
  567. context.ResponseData.Write(ledPattern);
  568. return ResultCode.Success;
  569. }
  570. [CommandHipc(109)] // 5.0.0+
  571. // ActivateNpadWithRevision(nn::applet::AppletResourceUserId, int revision)
  572. public ResultCode ActivateNpadWithRevision(ServiceCtx context)
  573. {
  574. int revision = context.RequestData.ReadInt32();
  575. long appletResourceUserId = context.RequestData.ReadInt64();
  576. // Initialize entries to avoid issues with some games.
  577. List<GamepadInput> emptyGamepadInputs = new List<GamepadInput>();
  578. List<SixAxisInput> emptySixAxisInputs = new List<SixAxisInput>();
  579. for (int player = 0; player < NpadDevices.MaxControllers; player++)
  580. {
  581. GamepadInput gamepadInput = new GamepadInput();
  582. SixAxisInput sixaxisInput = new SixAxisInput();
  583. gamepadInput.PlayerId = (PlayerIndex)player;
  584. sixaxisInput.PlayerId = (PlayerIndex)player;
  585. sixaxisInput.Orientation = new float[9];
  586. emptyGamepadInputs.Add(gamepadInput);
  587. emptySixAxisInputs.Add(sixaxisInput);
  588. }
  589. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  590. {
  591. context.Device.Hid.Npads.Update(emptyGamepadInputs);
  592. context.Device.Hid.Npads.UpdateSixAxis(emptySixAxisInputs);
  593. }
  594. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, revision });
  595. return ResultCode.Success;
  596. }
  597. [CommandHipc(120)]
  598. // SetNpadJoyHoldType(nn::applet::AppletResourceUserId, ulong NpadJoyHoldType)
  599. public ResultCode SetNpadJoyHoldType(ServiceCtx context)
  600. {
  601. long appletResourceUserId = context.RequestData.ReadInt64();
  602. NpadJoyHoldType npadJoyHoldType = (NpadJoyHoldType)context.RequestData.ReadUInt64();
  603. if (npadJoyHoldType > NpadJoyHoldType.Horizontal)
  604. {
  605. throw new ArgumentOutOfRangeException(nameof(npadJoyHoldType));
  606. }
  607. foreach (PlayerIndex playerIndex in context.Device.Hid.Npads.GetSupportedPlayers())
  608. {
  609. if (HidUtils.GetNpadIdTypeFromIndex(playerIndex) > NpadIdType.Handheld)
  610. {
  611. return ResultCode.InvalidNpadIdType;
  612. }
  613. }
  614. context.Device.Hid.Npads.JoyHold = npadJoyHoldType;
  615. return ResultCode.Success;
  616. }
  617. [CommandHipc(121)]
  618. // GetNpadJoyHoldType(nn::applet::AppletResourceUserId) -> ulong NpadJoyHoldType
  619. public ResultCode GetNpadJoyHoldType(ServiceCtx context)
  620. {
  621. long appletResourceUserId = context.RequestData.ReadInt64();
  622. foreach (PlayerIndex playerIndex in context.Device.Hid.Npads.GetSupportedPlayers())
  623. {
  624. if (HidUtils.GetNpadIdTypeFromIndex(playerIndex) > NpadIdType.Handheld)
  625. {
  626. return ResultCode.InvalidNpadIdType;
  627. }
  628. }
  629. context.ResponseData.Write((ulong)context.Device.Hid.Npads.JoyHold);
  630. return ResultCode.Success;
  631. }
  632. [CommandHipc(122)]
  633. // SetNpadJoyAssignmentModeSingleByDefault(uint HidControllerId, nn::applet::AppletResourceUserId)
  634. public ResultCode SetNpadJoyAssignmentModeSingleByDefault(ServiceCtx context)
  635. {
  636. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  637. long appletResourceUserId = context.RequestData.ReadInt64();
  638. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  639. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, _npadJoyAssignmentMode });
  640. return ResultCode.Success;
  641. }
  642. [CommandHipc(123)]
  643. // SetNpadJoyAssignmentModeSingle(uint HidControllerId, nn::applet::AppletResourceUserId, long HidNpadJoyDeviceType)
  644. public ResultCode SetNpadJoyAssignmentModeSingle(ServiceCtx context)
  645. {
  646. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  647. long appletResourceUserId = context.RequestData.ReadInt64();
  648. HidNpadJoyDeviceType hidNpadJoyDeviceType = (HidNpadJoyDeviceType)context.RequestData.ReadInt64();
  649. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  650. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, hidNpadJoyDeviceType, _npadJoyAssignmentMode });
  651. return ResultCode.Success;
  652. }
  653. [CommandHipc(124)]
  654. // SetNpadJoyAssignmentModeDual(uint HidControllerId, nn::applet::AppletResourceUserId)
  655. public ResultCode SetNpadJoyAssignmentModeDual(ServiceCtx context)
  656. {
  657. PlayerIndex hidControllerId = HidUtils.GetIndexFromNpadIdType((NpadIdType)context.RequestData.ReadInt32());
  658. long appletResourceUserId = context.RequestData.ReadInt64();
  659. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Dual;
  660. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, _npadJoyAssignmentMode });
  661. return ResultCode.Success;
  662. }
  663. [CommandHipc(125)]
  664. // MergeSingleJoyAsDualJoy(uint SingleJoyId0, uint SingleJoyId1, nn::applet::AppletResourceUserId)
  665. public ResultCode MergeSingleJoyAsDualJoy(ServiceCtx context)
  666. {
  667. long singleJoyId0 = context.RequestData.ReadInt32();
  668. long singleJoyId1 = context.RequestData.ReadInt32();
  669. long appletResourceUserId = context.RequestData.ReadInt64();
  670. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, singleJoyId0, singleJoyId1 });
  671. return ResultCode.Success;
  672. }
  673. [CommandHipc(126)]
  674. // StartLrAssignmentMode(nn::applet::AppletResourceUserId)
  675. public ResultCode StartLrAssignmentMode(ServiceCtx context)
  676. {
  677. long appletResourceUserId = context.RequestData.ReadInt64();
  678. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  679. return ResultCode.Success;
  680. }
  681. [CommandHipc(127)]
  682. // StopLrAssignmentMode(nn::applet::AppletResourceUserId)
  683. public ResultCode StopLrAssignmentMode(ServiceCtx context)
  684. {
  685. long appletResourceUserId = context.RequestData.ReadInt64();
  686. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  687. return ResultCode.Success;
  688. }
  689. [CommandHipc(128)]
  690. // SetNpadHandheldActivationMode(nn::applet::AppletResourceUserId, long HidNpadHandheldActivationMode)
  691. public ResultCode SetNpadHandheldActivationMode(ServiceCtx context)
  692. {
  693. long appletResourceUserId = context.RequestData.ReadInt64();
  694. _npadHandheldActivationMode = (HidNpadHandheldActivationMode)context.RequestData.ReadInt64();
  695. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadHandheldActivationMode });
  696. return ResultCode.Success;
  697. }
  698. [CommandHipc(129)]
  699. // GetNpadHandheldActivationMode(nn::applet::AppletResourceUserId) -> long HidNpadHandheldActivationMode
  700. public ResultCode GetNpadHandheldActivationMode(ServiceCtx context)
  701. {
  702. long appletResourceUserId = context.RequestData.ReadInt64();
  703. context.ResponseData.Write((long)_npadHandheldActivationMode);
  704. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadHandheldActivationMode });
  705. return ResultCode.Success;
  706. }
  707. [CommandHipc(130)]
  708. // SwapNpadAssignment(uint OldNpadAssignment, uint NewNpadAssignment, nn::applet::AppletResourceUserId)
  709. public ResultCode SwapNpadAssignment(ServiceCtx context)
  710. {
  711. int oldNpadAssignment = context.RequestData.ReadInt32();
  712. int newNpadAssignment = context.RequestData.ReadInt32();
  713. long appletResourceUserId = context.RequestData.ReadInt64();
  714. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, oldNpadAssignment, newNpadAssignment });
  715. return ResultCode.Success;
  716. }
  717. [CommandHipc(131)]
  718. // IsUnintendedHomeButtonInputProtectionEnabled(uint Unknown0, nn::applet::AppletResourceUserId) -> bool IsEnabled
  719. public ResultCode IsUnintendedHomeButtonInputProtectionEnabled(ServiceCtx context)
  720. {
  721. uint unknown0 = context.RequestData.ReadUInt32();
  722. long appletResourceUserId = context.RequestData.ReadInt64();
  723. context.ResponseData.Write(_unintendedHomeButtonInputProtectionEnabled);
  724. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknown0, _unintendedHomeButtonInputProtectionEnabled });
  725. return ResultCode.Success;
  726. }
  727. [CommandHipc(132)]
  728. // EnableUnintendedHomeButtonInputProtection(bool Enable, uint Unknown0, nn::applet::AppletResourceUserId)
  729. public ResultCode EnableUnintendedHomeButtonInputProtection(ServiceCtx context)
  730. {
  731. _unintendedHomeButtonInputProtectionEnabled = context.RequestData.ReadBoolean();
  732. uint unknown0 = context.RequestData.ReadUInt32();
  733. long appletResourceUserId = context.RequestData.ReadInt64();
  734. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknown0, _unintendedHomeButtonInputProtectionEnabled });
  735. return ResultCode.Success;
  736. }
  737. [CommandHipc(133)] // 5.0.0+
  738. // SetNpadJoyAssignmentModeSingleWithDestination(uint HidControllerId, long HidNpadJoyDeviceType, nn::applet::AppletResourceUserId) -> bool Unknown0, uint Unknown1
  739. public ResultCode SetNpadJoyAssignmentModeSingleWithDestination(ServiceCtx context)
  740. {
  741. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  742. HidNpadJoyDeviceType hidNpadJoyDeviceType = (HidNpadJoyDeviceType)context.RequestData.ReadInt64();
  743. long appletResourceUserId = context.RequestData.ReadInt64();
  744. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  745. context.ResponseData.Write(0); //Unknown0
  746. context.ResponseData.Write(0); //Unknown1
  747. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  748. appletResourceUserId,
  749. hidControllerId,
  750. hidNpadJoyDeviceType,
  751. _npadJoyAssignmentMode,
  752. Unknown0 = 0,
  753. Unknown1 = 0
  754. });
  755. return ResultCode.Success;
  756. }
  757. [CommandHipc(200)]
  758. // GetVibrationDeviceInfo(nn::hid::VibrationDeviceHandle) -> nn::hid::VibrationDeviceInfo
  759. public ResultCode GetVibrationDeviceInfo(ServiceCtx context)
  760. {
  761. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  762. HidVibrationDeviceValue deviceInfo = new HidVibrationDeviceValue
  763. {
  764. DeviceType = HidVibrationDeviceType.None,
  765. Position = HidVibrationDevicePosition.None
  766. };
  767. context.ResponseData.Write((int)deviceInfo.DeviceType);
  768. context.ResponseData.Write((int)deviceInfo.Position);
  769. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { vibrationDeviceHandle, deviceInfo.DeviceType, deviceInfo.Position });
  770. return ResultCode.Success;
  771. }
  772. [CommandHipc(201)]
  773. // SendVibrationValue(nn::hid::VibrationDeviceHandle, nn::hid::VibrationValue, nn::applet::AppletResourceUserId)
  774. public ResultCode SendVibrationValue(ServiceCtx context)
  775. {
  776. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  777. _vibrationValue = new HidVibrationValue
  778. {
  779. AmplitudeLow = context.RequestData.ReadSingle(),
  780. FrequencyLow = context.RequestData.ReadSingle(),
  781. AmplitudeHigh = context.RequestData.ReadSingle(),
  782. FrequencyHigh = context.RequestData.ReadSingle()
  783. };
  784. long appletResourceUserId = context.RequestData.ReadInt64();
  785. Logger.Debug?.PrintStub(LogClass.ServiceHid, new {
  786. appletResourceUserId,
  787. vibrationDeviceHandle,
  788. _vibrationValue.AmplitudeLow,
  789. _vibrationValue.FrequencyLow,
  790. _vibrationValue.AmplitudeHigh,
  791. _vibrationValue.FrequencyHigh
  792. });
  793. return ResultCode.Success;
  794. }
  795. [CommandHipc(202)]
  796. // GetActualVibrationValue(nn::hid::VibrationDeviceHandle, nn::applet::AppletResourceUserId) -> nn::hid::VibrationValue
  797. public ResultCode GetActualVibrationValue(ServiceCtx context)
  798. {
  799. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  800. long appletResourceUserId = context.RequestData.ReadInt64();
  801. context.ResponseData.Write(_vibrationValue.AmplitudeLow);
  802. context.ResponseData.Write(_vibrationValue.FrequencyLow);
  803. context.ResponseData.Write(_vibrationValue.AmplitudeHigh);
  804. context.ResponseData.Write(_vibrationValue.FrequencyHigh);
  805. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  806. appletResourceUserId,
  807. vibrationDeviceHandle,
  808. _vibrationValue.AmplitudeLow,
  809. _vibrationValue.FrequencyLow,
  810. _vibrationValue.AmplitudeHigh,
  811. _vibrationValue.FrequencyHigh
  812. });
  813. return ResultCode.Success;
  814. }
  815. [CommandHipc(203)]
  816. // CreateActiveVibrationDeviceList() -> object<nn::hid::IActiveVibrationDeviceList>
  817. public ResultCode CreateActiveVibrationDeviceList(ServiceCtx context)
  818. {
  819. MakeObject(context, new IActiveApplicationDeviceList());
  820. return ResultCode.Success;
  821. }
  822. [CommandHipc(204)]
  823. // PermitVibration(bool Enable)
  824. public ResultCode PermitVibration(ServiceCtx context)
  825. {
  826. _vibrationPermitted = context.RequestData.ReadBoolean();
  827. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _vibrationPermitted });
  828. return ResultCode.Success;
  829. }
  830. [CommandHipc(205)]
  831. // IsVibrationPermitted() -> bool IsEnabled
  832. public ResultCode IsVibrationPermitted(ServiceCtx context)
  833. {
  834. context.ResponseData.Write(_vibrationPermitted);
  835. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _vibrationPermitted });
  836. return ResultCode.Success;
  837. }
  838. [CommandHipc(206)]
  839. // SendVibrationValues(nn::applet::AppletResourceUserId, buffer<array<nn::hid::VibrationDeviceHandle>, type: 9>, buffer<array<nn::hid::VibrationValue>, type: 9>)
  840. public ResultCode SendVibrationValues(ServiceCtx context)
  841. {
  842. long appletResourceUserId = context.RequestData.ReadInt64();
  843. byte[] vibrationDeviceHandleBuffer = new byte[context.Request.PtrBuff[0].Size];
  844. context.Memory.Read(context.Request.PtrBuff[0].Position, vibrationDeviceHandleBuffer);
  845. byte[] vibrationValueBuffer = new byte[context.Request.PtrBuff[1].Size];
  846. context.Memory.Read(context.Request.PtrBuff[1].Position, vibrationValueBuffer);
  847. // TODO: Read all handles and values from buffer.
  848. Logger.Debug?.PrintStub(LogClass.ServiceHid, new {
  849. appletResourceUserId,
  850. VibrationDeviceHandleBufferLength = vibrationDeviceHandleBuffer.Length,
  851. VibrationValueBufferLength = vibrationValueBuffer.Length
  852. });
  853. return ResultCode.Success;
  854. }
  855. [CommandHipc(207)] // 4.0.0+
  856. // SendVibrationGcErmCommand(nn::hid::VibrationDeviceHandle, nn::hid::VibrationGcErmCommand, nn::applet::AppletResourceUserId)
  857. public ResultCode SendVibrationGcErmCommand(ServiceCtx context)
  858. {
  859. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  860. long vibrationGcErmCommand = context.RequestData.ReadInt64();
  861. long appletResourceUserId = context.RequestData.ReadInt64();
  862. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, vibrationDeviceHandle, vibrationGcErmCommand });
  863. return ResultCode.Success;
  864. }
  865. [CommandHipc(208)] // 4.0.0+
  866. // GetActualVibrationGcErmCommand(nn::hid::VibrationDeviceHandle, nn::applet::AppletResourceUserId) -> nn::hid::VibrationGcErmCommand
  867. public ResultCode GetActualVibrationGcErmCommand(ServiceCtx context)
  868. {
  869. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  870. long appletResourceUserId = context.RequestData.ReadInt64();
  871. context.ResponseData.Write(_vibrationGcErmCommand);
  872. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, vibrationDeviceHandle, _vibrationGcErmCommand });
  873. return ResultCode.Success;
  874. }
  875. [CommandHipc(209)] // 4.0.0+
  876. // BeginPermitVibrationSession(nn::applet::AppletResourceUserId)
  877. public ResultCode BeginPermitVibrationSession(ServiceCtx context)
  878. {
  879. long appletResourceUserId = context.RequestData.ReadInt64();
  880. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  881. return ResultCode.Success;
  882. }
  883. [CommandHipc(210)] // 4.0.0+
  884. // EndPermitVibrationSession()
  885. public ResultCode EndPermitVibrationSession(ServiceCtx context)
  886. {
  887. Logger.Stub?.PrintStub(LogClass.ServiceHid);
  888. return ResultCode.Success;
  889. }
  890. [CommandHipc(211)] // 7.0.0+
  891. // IsVibrationDeviceMounted(nn::hid::VibrationDeviceHandle, nn::applet::AppletResourceUserId)
  892. public ResultCode IsVibrationDeviceMounted(ServiceCtx context)
  893. {
  894. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  895. long appletResourceUserId = context.RequestData.ReadInt64();
  896. // NOTE: Service use vibrationDeviceHandle to get the PlayerIndex.
  897. // And return false if (npadIdType >= (NpadIdType)8 && npadIdType != NpadIdType.Handheld && npadIdType != NpadIdType.Unknown)
  898. context.ResponseData.Write(true);
  899. return ResultCode.Success;
  900. }
  901. [CommandHipc(300)]
  902. // ActivateConsoleSixAxisSensor(nn::applet::AppletResourceUserId)
  903. public ResultCode ActivateConsoleSixAxisSensor(ServiceCtx context)
  904. {
  905. long appletResourceUserId = context.RequestData.ReadInt64();
  906. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  907. return ResultCode.Success;
  908. }
  909. [CommandHipc(301)]
  910. // StartConsoleSixAxisSensor(nn::hid::ConsoleSixAxisSensorHandle, nn::applet::AppletResourceUserId)
  911. public ResultCode StartConsoleSixAxisSensor(ServiceCtx context)
  912. {
  913. int consoleSixAxisSensorHandle = context.RequestData.ReadInt32();
  914. long appletResourceUserId = context.RequestData.ReadInt64();
  915. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, consoleSixAxisSensorHandle });
  916. return ResultCode.Success;
  917. }
  918. [CommandHipc(302)]
  919. // StopConsoleSixAxisSensor(nn::hid::ConsoleSixAxisSensorHandle, nn::applet::AppletResourceUserId)
  920. public ResultCode StopConsoleSixAxisSensor(ServiceCtx context)
  921. {
  922. int consoleSixAxisSensorHandle = context.RequestData.ReadInt32();
  923. long appletResourceUserId = context.RequestData.ReadInt64();
  924. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, consoleSixAxisSensorHandle });
  925. return ResultCode.Success;
  926. }
  927. [CommandHipc(303)] // 5.0.0+
  928. // ActivateSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  929. public ResultCode ActivateSevenSixAxisSensor(ServiceCtx context)
  930. {
  931. long appletResourceUserId = context.RequestData.ReadInt64();
  932. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  933. return ResultCode.Success;
  934. }
  935. [CommandHipc(304)] // 5.0.0+
  936. // StartSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  937. public ResultCode StartSevenSixAxisSensor(ServiceCtx context)
  938. {
  939. long appletResourceUserId = context.RequestData.ReadInt64();
  940. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  941. return ResultCode.Success;
  942. }
  943. [CommandHipc(305)] // 5.0.0+
  944. // StopSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  945. public ResultCode StopSevenSixAxisSensor(ServiceCtx context)
  946. {
  947. long appletResourceUserId = context.RequestData.ReadInt64();
  948. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  949. return ResultCode.Success;
  950. }
  951. [CommandHipc(306)] // 5.0.0+
  952. // InitializeSevenSixAxisSensor(array<nn::sf::NativeHandle>, ulong Counter0, array<nn::sf::NativeHandle>, ulong Counter1, nn::applet::AppletResourceUserId)
  953. public ResultCode InitializeSevenSixAxisSensor(ServiceCtx context)
  954. {
  955. long appletResourceUserId = context.RequestData.ReadInt64();
  956. long counter0 = context.RequestData.ReadInt64();
  957. long counter1 = context.RequestData.ReadInt64();
  958. // TODO: Determine if array<nn::sf::NativeHandle> is a buffer or not...
  959. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, counter0, counter1 });
  960. return ResultCode.Success;
  961. }
  962. [CommandHipc(307)] // 5.0.0+
  963. // FinalizeSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  964. public ResultCode FinalizeSevenSixAxisSensor(ServiceCtx context)
  965. {
  966. long appletResourceUserId = context.RequestData.ReadInt64();
  967. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  968. return ResultCode.Success;
  969. }
  970. [CommandHipc(308)] // 5.0.0+
  971. // SetSevenSixAxisSensorFusionStrength(float Strength, nn::applet::AppletResourceUserId)
  972. public ResultCode SetSevenSixAxisSensorFusionStrength(ServiceCtx context)
  973. {
  974. _sevenSixAxisSensorFusionStrength = context.RequestData.ReadSingle();
  975. long appletResourceUserId = context.RequestData.ReadInt64();
  976. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _sevenSixAxisSensorFusionStrength });
  977. return ResultCode.Success;
  978. }
  979. [CommandHipc(309)] // 5.0.0+
  980. // GetSevenSixAxisSensorFusionStrength(nn::applet::AppletResourceUserId) -> float Strength
  981. public ResultCode GetSevenSixAxisSensorFusionStrength(ServiceCtx context)
  982. {
  983. long appletResourceUserId = context.RequestData.ReadInt64();
  984. context.ResponseData.Write(_sevenSixAxisSensorFusionStrength);
  985. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _sevenSixAxisSensorFusionStrength });
  986. return ResultCode.Success;
  987. }
  988. [CommandHipc(310)] // 6.0.0+
  989. // ResetSevenSixAxisSensorTimestamp(pid, nn::applet::AppletResourceUserId)
  990. public ResultCode ResetSevenSixAxisSensorTimestamp(ServiceCtx context)
  991. {
  992. long appletResourceUserId = context.RequestData.ReadInt64();
  993. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  994. return ResultCode.Success;
  995. }
  996. [CommandHipc(400)]
  997. // IsUsbFullKeyControllerEnabled() -> bool IsEnabled
  998. public ResultCode IsUsbFullKeyControllerEnabled(ServiceCtx context)
  999. {
  1000. context.ResponseData.Write(_usbFullKeyControllerEnabled);
  1001. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _usbFullKeyControllerEnabled });
  1002. return ResultCode.Success;
  1003. }
  1004. [CommandHipc(401)]
  1005. // EnableUsbFullKeyController(bool Enable)
  1006. public ResultCode EnableUsbFullKeyController(ServiceCtx context)
  1007. {
  1008. _usbFullKeyControllerEnabled = context.RequestData.ReadBoolean();
  1009. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _usbFullKeyControllerEnabled });
  1010. return ResultCode.Success;
  1011. }
  1012. [CommandHipc(402)]
  1013. // IsUsbFullKeyControllerConnected(uint Unknown0) -> bool Connected
  1014. public ResultCode IsUsbFullKeyControllerConnected(ServiceCtx context)
  1015. {
  1016. int unknown0 = context.RequestData.ReadInt32();
  1017. context.ResponseData.Write(true); //FullKeyController is always connected ?
  1018. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { unknown0, Connected = true });
  1019. return ResultCode.Success;
  1020. }
  1021. [CommandHipc(403)] // 4.0.0+
  1022. // HasBattery(uint NpadId) -> bool HasBattery
  1023. public ResultCode HasBattery(ServiceCtx context)
  1024. {
  1025. int npadId = context.RequestData.ReadInt32();
  1026. context.ResponseData.Write(true); //Npad always got a battery ?
  1027. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, HasBattery = true });
  1028. return ResultCode.Success;
  1029. }
  1030. [CommandHipc(404)] // 4.0.0+
  1031. // HasLeftRightBattery(uint NpadId) -> bool HasLeftBattery, bool HasRightBattery
  1032. public ResultCode HasLeftRightBattery(ServiceCtx context)
  1033. {
  1034. int npadId = context.RequestData.ReadInt32();
  1035. context.ResponseData.Write(true); //Npad always got a left battery ?
  1036. context.ResponseData.Write(true); //Npad always got a right battery ?
  1037. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, HasLeftBattery = true, HasRightBattery = true });
  1038. return ResultCode.Success;
  1039. }
  1040. [CommandHipc(405)] // 4.0.0+
  1041. // GetNpadInterfaceType(uint NpadId) -> uchar InterfaceType
  1042. public ResultCode GetNpadInterfaceType(ServiceCtx context)
  1043. {
  1044. int npadId = context.RequestData.ReadInt32();
  1045. context.ResponseData.Write((byte)0);
  1046. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, NpadInterfaceType = 0 });
  1047. return ResultCode.Success;
  1048. }
  1049. [CommandHipc(406)] // 4.0.0+
  1050. // GetNpadLeftRightInterfaceType(uint NpadId) -> uchar LeftInterfaceType, uchar RightInterfaceType
  1051. public ResultCode GetNpadLeftRightInterfaceType(ServiceCtx context)
  1052. {
  1053. int npadId = context.RequestData.ReadInt32();
  1054. context.ResponseData.Write((byte)0);
  1055. context.ResponseData.Write((byte)0);
  1056. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, LeftInterfaceType = 0, RightInterfaceType = 0 });
  1057. return ResultCode.Success;
  1058. }
  1059. [CommandHipc(500)] // 5.0.0+
  1060. // GetPalmaConnectionHandle(uint Unknown0, nn::applet::AppletResourceUserId) -> nn::hid::PalmaConnectionHandle
  1061. public ResultCode GetPalmaConnectionHandle(ServiceCtx context)
  1062. {
  1063. int unknown0 = context.RequestData.ReadInt32();
  1064. long appletResourceUserId = context.RequestData.ReadInt64();
  1065. int palmaConnectionHandle = 0;
  1066. context.ResponseData.Write(palmaConnectionHandle);
  1067. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId , unknown0, palmaConnectionHandle });
  1068. return ResultCode.Success;
  1069. }
  1070. [CommandHipc(501)] // 5.0.0+
  1071. // InitializePalma(nn::hid::PalmaConnectionHandle)
  1072. public ResultCode InitializePalma(ServiceCtx context)
  1073. {
  1074. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1075. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1076. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1077. return ResultCode.Success;
  1078. }
  1079. [CommandHipc(502)] // 5.0.0+
  1080. // AcquirePalmaOperationCompleteEvent(nn::hid::PalmaConnectionHandle) -> nn::sf::NativeHandle
  1081. public ResultCode AcquirePalmaOperationCompleteEvent(ServiceCtx context)
  1082. {
  1083. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1084. if (context.Process.HandleTable.GenerateHandle(_palmaOperationCompleteEvent.ReadableEvent, out int handle) != KernelResult.Success)
  1085. {
  1086. throw new InvalidOperationException("Out of handles!");
  1087. }
  1088. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  1089. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1090. return ResultCode.Success;
  1091. }
  1092. [CommandHipc(503)] // 5.0.0+
  1093. // GetPalmaOperationInfo(nn::hid::PalmaConnectionHandle) -> long Unknown0, buffer<Unknown>
  1094. public ResultCode GetPalmaOperationInfo(ServiceCtx context)
  1095. {
  1096. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1097. long unknown0 = 0; //Counter?
  1098. context.ResponseData.Write(unknown0);
  1099. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0 });
  1100. return ResultCode.Success;
  1101. }
  1102. [CommandHipc(504)] // 5.0.0+
  1103. // PlayPalmaActivity(nn::hid::PalmaConnectionHandle, ulong Unknown0)
  1104. public ResultCode PlayPalmaActivity(ServiceCtx context)
  1105. {
  1106. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1107. long unknown0 = context.RequestData.ReadInt64();
  1108. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0 });
  1109. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1110. return ResultCode.Success;
  1111. }
  1112. [CommandHipc(505)] // 5.0.0+
  1113. // SetPalmaFrModeType(nn::hid::PalmaConnectionHandle, ulong FrModeType)
  1114. public ResultCode SetPalmaFrModeType(ServiceCtx context)
  1115. {
  1116. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1117. long frModeType = context.RequestData.ReadInt64();
  1118. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, frModeType });
  1119. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1120. return ResultCode.Success;
  1121. }
  1122. [CommandHipc(506)] // 5.0.0+
  1123. // ReadPalmaStep(nn::hid::PalmaConnectionHandle)
  1124. public ResultCode ReadPalmaStep(ServiceCtx context)
  1125. {
  1126. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1127. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1128. return ResultCode.Success;
  1129. }
  1130. [CommandHipc(507)] // 5.0.0+
  1131. // EnablePalmaStep(nn::hid::PalmaConnectionHandle, bool Enable)
  1132. public ResultCode EnablePalmaStep(ServiceCtx context)
  1133. {
  1134. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1135. bool enabledPalmaStep = context.RequestData.ReadBoolean();
  1136. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, enabledPalmaStep });
  1137. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1138. return ResultCode.Success;
  1139. }
  1140. [CommandHipc(508)] // 5.0.0+
  1141. // ResetPalmaStep(nn::hid::PalmaConnectionHandle)
  1142. public ResultCode ResetPalmaStep(ServiceCtx context)
  1143. {
  1144. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1145. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1146. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1147. return ResultCode.Success;
  1148. }
  1149. [CommandHipc(509)] // 5.0.0+
  1150. // ReadPalmaApplicationSection(nn::hid::PalmaConnectionHandle, ulong Unknown0, ulong Unknown1)
  1151. public ResultCode ReadPalmaApplicationSection(ServiceCtx context)
  1152. {
  1153. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1154. long unknown0 = context.RequestData.ReadInt64();
  1155. long unknown1 = context.RequestData.ReadInt64();
  1156. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0, unknown1 });
  1157. return ResultCode.Success;
  1158. }
  1159. [CommandHipc(510)] // 5.0.0+
  1160. // WritePalmaApplicationSection(nn::hid::PalmaConnectionHandle, ulong Unknown0, ulong Unknown1, nn::hid::PalmaApplicationSectionAccessBuffer)
  1161. public ResultCode WritePalmaApplicationSection(ServiceCtx context)
  1162. {
  1163. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1164. long unknown0 = context.RequestData.ReadInt64();
  1165. long unknown1 = context.RequestData.ReadInt64();
  1166. // nn::hid::PalmaApplicationSectionAccessBuffer cast is unknown
  1167. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0, unknown1 });
  1168. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1169. return ResultCode.Success;
  1170. }
  1171. [CommandHipc(511)] // 5.0.0+
  1172. // ReadPalmaUniqueCode(nn::hid::PalmaConnectionHandle)
  1173. public ResultCode ReadPalmaUniqueCode(ServiceCtx context)
  1174. {
  1175. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1176. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1177. return ResultCode.Success;
  1178. }
  1179. [CommandHipc(512)] // 5.0.0+
  1180. // SetPalmaUniqueCodeInvalid(nn::hid::PalmaConnectionHandle)
  1181. public ResultCode SetPalmaUniqueCodeInvalid(ServiceCtx context)
  1182. {
  1183. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1184. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1185. return ResultCode.Success;
  1186. }
  1187. [CommandHipc(522)] // 5.1.0+
  1188. // SetIsPalmaAllConnectable(nn::applet::AppletResourceUserId, bool, pid)
  1189. public ResultCode SetIsPalmaAllConnectable(ServiceCtx context)
  1190. {
  1191. long appletResourceUserId = context.RequestData.ReadInt64();
  1192. long unknownBool = context.RequestData.ReadInt64();
  1193. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknownBool });
  1194. return ResultCode.Success;
  1195. }
  1196. [CommandHipc(525)] // 5.1.0+
  1197. // SetPalmaBoostMode(bool)
  1198. public ResultCode SetPalmaBoostMode(ServiceCtx context)
  1199. {
  1200. // NOTE: Stubbed in system module.
  1201. return ResultCode.Success;
  1202. }
  1203. [CommandHipc(1000)]
  1204. // SetNpadCommunicationMode(long CommunicationMode, nn::applet::AppletResourceUserId)
  1205. public ResultCode SetNpadCommunicationMode(ServiceCtx context)
  1206. {
  1207. _npadCommunicationMode = context.RequestData.ReadInt64();
  1208. long appletResourceUserId = context.RequestData.ReadInt64();
  1209. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadCommunicationMode });
  1210. return ResultCode.Success;
  1211. }
  1212. [CommandHipc(1001)]
  1213. // GetNpadCommunicationMode() -> long CommunicationMode
  1214. public ResultCode GetNpadCommunicationMode(ServiceCtx context)
  1215. {
  1216. context.ResponseData.Write(_npadCommunicationMode);
  1217. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _npadCommunicationMode });
  1218. return ResultCode.Success;
  1219. }
  1220. [CommandHipc(1002)] // 9.0.0+
  1221. // SetTouchScreenConfiguration(nn::hid::TouchScreenConfigurationForNx, nn::applet::AppletResourceUserId)
  1222. public ResultCode SetTouchScreenConfiguration(ServiceCtx context)
  1223. {
  1224. long touchScreenConfigurationForNx = context.RequestData.ReadInt64();
  1225. long appletResourceUserId = context.RequestData.ReadInt64();
  1226. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, touchScreenConfigurationForNx });
  1227. return ResultCode.Success;
  1228. }
  1229. }
  1230. }