IHidServer.cs 64 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628
  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(uint NpadId) -> ulong LedPattern
  550. public ResultCode GetPlayerLedPattern(ServiceCtx context)
  551. {
  552. NpadIdType npadId = (NpadIdType)context.RequestData.ReadInt32();
  553. long ledPattern = HidUtils.GetLedPatternFromNpadId(npadId);
  554. context.ResponseData.Write(ledPattern);
  555. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, ledPattern });
  556. return ResultCode.Success;
  557. }
  558. [CommandHipc(109)] // 5.0.0+
  559. // ActivateNpadWithRevision(nn::applet::AppletResourceUserId, int Unknown)
  560. public ResultCode ActivateNpadWithRevision(ServiceCtx context)
  561. {
  562. int revision = context.RequestData.ReadInt32();
  563. long appletResourceUserId = context.RequestData.ReadInt64();
  564. // Initialize entries to avoid issues with some games.
  565. List<GamepadInput> emptyGamepadInputs = new List<GamepadInput>();
  566. List<SixAxisInput> emptySixAxisInputs = new List<SixAxisInput>();
  567. for (int player = 0; player < NpadDevices.MaxControllers; player++)
  568. {
  569. GamepadInput gamepadInput = new GamepadInput();
  570. SixAxisInput sixaxisInput = new SixAxisInput();
  571. gamepadInput.PlayerId = (PlayerIndex)player;
  572. sixaxisInput.PlayerId = (PlayerIndex)player;
  573. sixaxisInput.Orientation = new float[9];
  574. emptyGamepadInputs.Add(gamepadInput);
  575. emptySixAxisInputs.Add(sixaxisInput);
  576. }
  577. for (int entry = 0; entry < Hid.SharedMemEntryCount; entry++)
  578. {
  579. context.Device.Hid.Npads.Update(emptyGamepadInputs);
  580. context.Device.Hid.Npads.UpdateSixAxis(emptySixAxisInputs);
  581. }
  582. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, revision });
  583. return ResultCode.Success;
  584. }
  585. [CommandHipc(120)]
  586. // SetNpadJoyHoldType(nn::applet::AppletResourceUserId, long NpadJoyHoldType)
  587. public ResultCode SetNpadJoyHoldType(ServiceCtx context)
  588. {
  589. long appletResourceUserId = context.RequestData.ReadInt64();
  590. context.Device.Hid.Npads.JoyHold = (NpadJoyHoldType)context.RequestData.ReadInt64();
  591. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  592. appletResourceUserId,
  593. context.Device.Hid.Npads.JoyHold
  594. });
  595. return ResultCode.Success;
  596. }
  597. [CommandHipc(121)]
  598. // GetNpadJoyHoldType(nn::applet::AppletResourceUserId) -> long NpadJoyHoldType
  599. public ResultCode GetNpadJoyHoldType(ServiceCtx context)
  600. {
  601. long appletResourceUserId = context.RequestData.ReadInt64();
  602. context.ResponseData.Write((long)context.Device.Hid.Npads.JoyHold);
  603. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  604. appletResourceUserId,
  605. context.Device.Hid.Npads.JoyHold
  606. });
  607. return ResultCode.Success;
  608. }
  609. [CommandHipc(122)]
  610. // SetNpadJoyAssignmentModeSingleByDefault(uint HidControllerId, nn::applet::AppletResourceUserId)
  611. public ResultCode SetNpadJoyAssignmentModeSingleByDefault(ServiceCtx context)
  612. {
  613. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  614. long appletResourceUserId = context.RequestData.ReadInt64();
  615. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  616. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, _npadJoyAssignmentMode });
  617. return ResultCode.Success;
  618. }
  619. [CommandHipc(123)]
  620. // SetNpadJoyAssignmentModeSingle(uint HidControllerId, nn::applet::AppletResourceUserId, long HidNpadJoyDeviceType)
  621. public ResultCode SetNpadJoyAssignmentModeSingle(ServiceCtx context)
  622. {
  623. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  624. long appletResourceUserId = context.RequestData.ReadInt64();
  625. HidNpadJoyDeviceType hidNpadJoyDeviceType = (HidNpadJoyDeviceType)context.RequestData.ReadInt64();
  626. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  627. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, hidNpadJoyDeviceType, _npadJoyAssignmentMode });
  628. return ResultCode.Success;
  629. }
  630. [CommandHipc(124)]
  631. // SetNpadJoyAssignmentModeDual(uint HidControllerId, nn::applet::AppletResourceUserId)
  632. public ResultCode SetNpadJoyAssignmentModeDual(ServiceCtx context)
  633. {
  634. PlayerIndex hidControllerId = HidUtils.GetIndexFromNpadIdType((NpadIdType)context.RequestData.ReadInt32());
  635. long appletResourceUserId = context.RequestData.ReadInt64();
  636. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Dual;
  637. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, hidControllerId, _npadJoyAssignmentMode });
  638. return ResultCode.Success;
  639. }
  640. [CommandHipc(125)]
  641. // MergeSingleJoyAsDualJoy(uint SingleJoyId0, uint SingleJoyId1, nn::applet::AppletResourceUserId)
  642. public ResultCode MergeSingleJoyAsDualJoy(ServiceCtx context)
  643. {
  644. long singleJoyId0 = context.RequestData.ReadInt32();
  645. long singleJoyId1 = context.RequestData.ReadInt32();
  646. long appletResourceUserId = context.RequestData.ReadInt64();
  647. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, singleJoyId0, singleJoyId1 });
  648. return ResultCode.Success;
  649. }
  650. [CommandHipc(126)]
  651. // StartLrAssignmentMode(nn::applet::AppletResourceUserId)
  652. public ResultCode StartLrAssignmentMode(ServiceCtx context)
  653. {
  654. long appletResourceUserId = context.RequestData.ReadInt64();
  655. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  656. return ResultCode.Success;
  657. }
  658. [CommandHipc(127)]
  659. // StopLrAssignmentMode(nn::applet::AppletResourceUserId)
  660. public ResultCode StopLrAssignmentMode(ServiceCtx context)
  661. {
  662. long appletResourceUserId = context.RequestData.ReadInt64();
  663. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  664. return ResultCode.Success;
  665. }
  666. [CommandHipc(128)]
  667. // SetNpadHandheldActivationMode(nn::applet::AppletResourceUserId, long HidNpadHandheldActivationMode)
  668. public ResultCode SetNpadHandheldActivationMode(ServiceCtx context)
  669. {
  670. long appletResourceUserId = context.RequestData.ReadInt64();
  671. _npadHandheldActivationMode = (HidNpadHandheldActivationMode)context.RequestData.ReadInt64();
  672. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadHandheldActivationMode });
  673. return ResultCode.Success;
  674. }
  675. [CommandHipc(129)]
  676. // GetNpadHandheldActivationMode(nn::applet::AppletResourceUserId) -> long HidNpadHandheldActivationMode
  677. public ResultCode GetNpadHandheldActivationMode(ServiceCtx context)
  678. {
  679. long appletResourceUserId = context.RequestData.ReadInt64();
  680. context.ResponseData.Write((long)_npadHandheldActivationMode);
  681. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadHandheldActivationMode });
  682. return ResultCode.Success;
  683. }
  684. [CommandHipc(130)]
  685. // SwapNpadAssignment(uint OldNpadAssignment, uint NewNpadAssignment, nn::applet::AppletResourceUserId)
  686. public ResultCode SwapNpadAssignment(ServiceCtx context)
  687. {
  688. int oldNpadAssignment = context.RequestData.ReadInt32();
  689. int newNpadAssignment = context.RequestData.ReadInt32();
  690. long appletResourceUserId = context.RequestData.ReadInt64();
  691. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, oldNpadAssignment, newNpadAssignment });
  692. return ResultCode.Success;
  693. }
  694. [CommandHipc(131)]
  695. // IsUnintendedHomeButtonInputProtectionEnabled(uint Unknown0, nn::applet::AppletResourceUserId) -> bool IsEnabled
  696. public ResultCode IsUnintendedHomeButtonInputProtectionEnabled(ServiceCtx context)
  697. {
  698. uint unknown0 = context.RequestData.ReadUInt32();
  699. long appletResourceUserId = context.RequestData.ReadInt64();
  700. context.ResponseData.Write(_unintendedHomeButtonInputProtectionEnabled);
  701. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknown0, _unintendedHomeButtonInputProtectionEnabled });
  702. return ResultCode.Success;
  703. }
  704. [CommandHipc(132)]
  705. // EnableUnintendedHomeButtonInputProtection(bool Enable, uint Unknown0, nn::applet::AppletResourceUserId)
  706. public ResultCode EnableUnintendedHomeButtonInputProtection(ServiceCtx context)
  707. {
  708. _unintendedHomeButtonInputProtectionEnabled = context.RequestData.ReadBoolean();
  709. uint unknown0 = context.RequestData.ReadUInt32();
  710. long appletResourceUserId = context.RequestData.ReadInt64();
  711. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknown0, _unintendedHomeButtonInputProtectionEnabled });
  712. return ResultCode.Success;
  713. }
  714. [CommandHipc(133)] // 5.0.0+
  715. // SetNpadJoyAssignmentModeSingleWithDestination(uint HidControllerId, long HidNpadJoyDeviceType, nn::applet::AppletResourceUserId) -> bool Unknown0, uint Unknown1
  716. public ResultCode SetNpadJoyAssignmentModeSingleWithDestination(ServiceCtx context)
  717. {
  718. PlayerIndex hidControllerId = (PlayerIndex)context.RequestData.ReadInt32();
  719. HidNpadJoyDeviceType hidNpadJoyDeviceType = (HidNpadJoyDeviceType)context.RequestData.ReadInt64();
  720. long appletResourceUserId = context.RequestData.ReadInt64();
  721. _npadJoyAssignmentMode = HidNpadJoyAssignmentMode.Single;
  722. context.ResponseData.Write(0); //Unknown0
  723. context.ResponseData.Write(0); //Unknown1
  724. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  725. appletResourceUserId,
  726. hidControllerId,
  727. hidNpadJoyDeviceType,
  728. _npadJoyAssignmentMode,
  729. Unknown0 = 0,
  730. Unknown1 = 0
  731. });
  732. return ResultCode.Success;
  733. }
  734. [CommandHipc(200)]
  735. // GetVibrationDeviceInfo(nn::hid::VibrationDeviceHandle) -> nn::hid::VibrationDeviceInfo
  736. public ResultCode GetVibrationDeviceInfo(ServiceCtx context)
  737. {
  738. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  739. HidVibrationDeviceValue deviceInfo = new HidVibrationDeviceValue
  740. {
  741. DeviceType = HidVibrationDeviceType.None,
  742. Position = HidVibrationDevicePosition.None
  743. };
  744. context.ResponseData.Write((int)deviceInfo.DeviceType);
  745. context.ResponseData.Write((int)deviceInfo.Position);
  746. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { vibrationDeviceHandle, deviceInfo.DeviceType, deviceInfo.Position });
  747. return ResultCode.Success;
  748. }
  749. [CommandHipc(201)]
  750. // SendVibrationValue(nn::hid::VibrationDeviceHandle, nn::hid::VibrationValue, nn::applet::AppletResourceUserId)
  751. public ResultCode SendVibrationValue(ServiceCtx context)
  752. {
  753. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  754. _vibrationValue = new HidVibrationValue
  755. {
  756. AmplitudeLow = context.RequestData.ReadSingle(),
  757. FrequencyLow = context.RequestData.ReadSingle(),
  758. AmplitudeHigh = context.RequestData.ReadSingle(),
  759. FrequencyHigh = context.RequestData.ReadSingle()
  760. };
  761. long appletResourceUserId = context.RequestData.ReadInt64();
  762. Logger.Debug?.PrintStub(LogClass.ServiceHid, new {
  763. appletResourceUserId,
  764. vibrationDeviceHandle,
  765. _vibrationValue.AmplitudeLow,
  766. _vibrationValue.FrequencyLow,
  767. _vibrationValue.AmplitudeHigh,
  768. _vibrationValue.FrequencyHigh
  769. });
  770. return ResultCode.Success;
  771. }
  772. [CommandHipc(202)]
  773. // GetActualVibrationValue(nn::hid::VibrationDeviceHandle, nn::applet::AppletResourceUserId) -> nn::hid::VibrationValue
  774. public ResultCode GetActualVibrationValue(ServiceCtx context)
  775. {
  776. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  777. long appletResourceUserId = context.RequestData.ReadInt64();
  778. context.ResponseData.Write(_vibrationValue.AmplitudeLow);
  779. context.ResponseData.Write(_vibrationValue.FrequencyLow);
  780. context.ResponseData.Write(_vibrationValue.AmplitudeHigh);
  781. context.ResponseData.Write(_vibrationValue.FrequencyHigh);
  782. Logger.Stub?.PrintStub(LogClass.ServiceHid, new {
  783. appletResourceUserId,
  784. vibrationDeviceHandle,
  785. _vibrationValue.AmplitudeLow,
  786. _vibrationValue.FrequencyLow,
  787. _vibrationValue.AmplitudeHigh,
  788. _vibrationValue.FrequencyHigh
  789. });
  790. return ResultCode.Success;
  791. }
  792. [CommandHipc(203)]
  793. // CreateActiveVibrationDeviceList() -> object<nn::hid::IActiveVibrationDeviceList>
  794. public ResultCode CreateActiveVibrationDeviceList(ServiceCtx context)
  795. {
  796. MakeObject(context, new IActiveApplicationDeviceList());
  797. return ResultCode.Success;
  798. }
  799. [CommandHipc(204)]
  800. // PermitVibration(bool Enable)
  801. public ResultCode PermitVibration(ServiceCtx context)
  802. {
  803. _vibrationPermitted = context.RequestData.ReadBoolean();
  804. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _vibrationPermitted });
  805. return ResultCode.Success;
  806. }
  807. [CommandHipc(205)]
  808. // IsVibrationPermitted() -> bool IsEnabled
  809. public ResultCode IsVibrationPermitted(ServiceCtx context)
  810. {
  811. context.ResponseData.Write(_vibrationPermitted);
  812. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _vibrationPermitted });
  813. return ResultCode.Success;
  814. }
  815. [CommandHipc(206)]
  816. // SendVibrationValues(nn::applet::AppletResourceUserId, buffer<array<nn::hid::VibrationDeviceHandle>, type: 9>, buffer<array<nn::hid::VibrationValue>, type: 9>)
  817. public ResultCode SendVibrationValues(ServiceCtx context)
  818. {
  819. long appletResourceUserId = context.RequestData.ReadInt64();
  820. byte[] vibrationDeviceHandleBuffer = new byte[context.Request.PtrBuff[0].Size];
  821. context.Memory.Read(context.Request.PtrBuff[0].Position, vibrationDeviceHandleBuffer);
  822. byte[] vibrationValueBuffer = new byte[context.Request.PtrBuff[1].Size];
  823. context.Memory.Read(context.Request.PtrBuff[1].Position, vibrationValueBuffer);
  824. // TODO: Read all handles and values from buffer.
  825. Logger.Debug?.PrintStub(LogClass.ServiceHid, new {
  826. appletResourceUserId,
  827. VibrationDeviceHandleBufferLength = vibrationDeviceHandleBuffer.Length,
  828. VibrationValueBufferLength = vibrationValueBuffer.Length
  829. });
  830. return ResultCode.Success;
  831. }
  832. [CommandHipc(207)] // 4.0.0+
  833. // SendVibrationGcErmCommand(nn::hid::VibrationDeviceHandle, nn::hid::VibrationGcErmCommand, nn::applet::AppletResourceUserId)
  834. public ResultCode SendVibrationGcErmCommand(ServiceCtx context)
  835. {
  836. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  837. long vibrationGcErmCommand = context.RequestData.ReadInt64();
  838. long appletResourceUserId = context.RequestData.ReadInt64();
  839. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, vibrationDeviceHandle, vibrationGcErmCommand });
  840. return ResultCode.Success;
  841. }
  842. [CommandHipc(208)] // 4.0.0+
  843. // GetActualVibrationGcErmCommand(nn::hid::VibrationDeviceHandle, nn::applet::AppletResourceUserId) -> nn::hid::VibrationGcErmCommand
  844. public ResultCode GetActualVibrationGcErmCommand(ServiceCtx context)
  845. {
  846. int vibrationDeviceHandle = context.RequestData.ReadInt32();
  847. long appletResourceUserId = context.RequestData.ReadInt64();
  848. context.ResponseData.Write(_vibrationGcErmCommand);
  849. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, vibrationDeviceHandle, _vibrationGcErmCommand });
  850. return ResultCode.Success;
  851. }
  852. [CommandHipc(209)] // 4.0.0+
  853. // BeginPermitVibrationSession(nn::applet::AppletResourceUserId)
  854. public ResultCode BeginPermitVibrationSession(ServiceCtx context)
  855. {
  856. long appletResourceUserId = context.RequestData.ReadInt64();
  857. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  858. return ResultCode.Success;
  859. }
  860. [CommandHipc(210)] // 4.0.0+
  861. // EndPermitVibrationSession()
  862. public ResultCode EndPermitVibrationSession(ServiceCtx context)
  863. {
  864. Logger.Stub?.PrintStub(LogClass.ServiceHid);
  865. return ResultCode.Success;
  866. }
  867. [CommandHipc(300)]
  868. // ActivateConsoleSixAxisSensor(nn::applet::AppletResourceUserId)
  869. public ResultCode ActivateConsoleSixAxisSensor(ServiceCtx context)
  870. {
  871. long appletResourceUserId = context.RequestData.ReadInt64();
  872. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  873. return ResultCode.Success;
  874. }
  875. [CommandHipc(301)]
  876. // StartConsoleSixAxisSensor(nn::hid::ConsoleSixAxisSensorHandle, nn::applet::AppletResourceUserId)
  877. public ResultCode StartConsoleSixAxisSensor(ServiceCtx context)
  878. {
  879. int consoleSixAxisSensorHandle = context.RequestData.ReadInt32();
  880. long appletResourceUserId = context.RequestData.ReadInt64();
  881. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, consoleSixAxisSensorHandle });
  882. return ResultCode.Success;
  883. }
  884. [CommandHipc(302)]
  885. // StopConsoleSixAxisSensor(nn::hid::ConsoleSixAxisSensorHandle, nn::applet::AppletResourceUserId)
  886. public ResultCode StopConsoleSixAxisSensor(ServiceCtx context)
  887. {
  888. int consoleSixAxisSensorHandle = context.RequestData.ReadInt32();
  889. long appletResourceUserId = context.RequestData.ReadInt64();
  890. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, consoleSixAxisSensorHandle });
  891. return ResultCode.Success;
  892. }
  893. [CommandHipc(303)] // 5.0.0+
  894. // ActivateSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  895. public ResultCode ActivateSevenSixAxisSensor(ServiceCtx context)
  896. {
  897. long appletResourceUserId = context.RequestData.ReadInt64();
  898. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  899. return ResultCode.Success;
  900. }
  901. [CommandHipc(304)] // 5.0.0+
  902. // StartSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  903. public ResultCode StartSevenSixAxisSensor(ServiceCtx context)
  904. {
  905. long appletResourceUserId = context.RequestData.ReadInt64();
  906. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  907. return ResultCode.Success;
  908. }
  909. [CommandHipc(305)] // 5.0.0+
  910. // StopSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  911. public ResultCode StopSevenSixAxisSensor(ServiceCtx context)
  912. {
  913. long appletResourceUserId = context.RequestData.ReadInt64();
  914. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  915. return ResultCode.Success;
  916. }
  917. [CommandHipc(306)] // 5.0.0+
  918. // InitializeSevenSixAxisSensor(array<nn::sf::NativeHandle>, ulong Counter0, array<nn::sf::NativeHandle>, ulong Counter1, nn::applet::AppletResourceUserId)
  919. public ResultCode InitializeSevenSixAxisSensor(ServiceCtx context)
  920. {
  921. long appletResourceUserId = context.RequestData.ReadInt64();
  922. long counter0 = context.RequestData.ReadInt64();
  923. long counter1 = context.RequestData.ReadInt64();
  924. // TODO: Determine if array<nn::sf::NativeHandle> is a buffer or not...
  925. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, counter0, counter1 });
  926. return ResultCode.Success;
  927. }
  928. [CommandHipc(307)] // 5.0.0+
  929. // FinalizeSevenSixAxisSensor(nn::applet::AppletResourceUserId)
  930. public ResultCode FinalizeSevenSixAxisSensor(ServiceCtx context)
  931. {
  932. long appletResourceUserId = context.RequestData.ReadInt64();
  933. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  934. return ResultCode.Success;
  935. }
  936. [CommandHipc(308)] // 5.0.0+
  937. // SetSevenSixAxisSensorFusionStrength(float Strength, nn::applet::AppletResourceUserId)
  938. public ResultCode SetSevenSixAxisSensorFusionStrength(ServiceCtx context)
  939. {
  940. _sevenSixAxisSensorFusionStrength = context.RequestData.ReadSingle();
  941. long appletResourceUserId = context.RequestData.ReadInt64();
  942. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _sevenSixAxisSensorFusionStrength });
  943. return ResultCode.Success;
  944. }
  945. [CommandHipc(309)] // 5.0.0+
  946. // GetSevenSixAxisSensorFusionStrength(nn::applet::AppletResourceUserId) -> float Strength
  947. public ResultCode GetSevenSixAxisSensorFusionStrength(ServiceCtx context)
  948. {
  949. long appletResourceUserId = context.RequestData.ReadInt64();
  950. context.ResponseData.Write(_sevenSixAxisSensorFusionStrength);
  951. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _sevenSixAxisSensorFusionStrength });
  952. return ResultCode.Success;
  953. }
  954. [CommandHipc(310)] // 6.0.0+
  955. // ResetSevenSixAxisSensorTimestamp(pid, nn::applet::AppletResourceUserId)
  956. public ResultCode ResetSevenSixAxisSensorTimestamp(ServiceCtx context)
  957. {
  958. long appletResourceUserId = context.RequestData.ReadInt64();
  959. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId });
  960. return ResultCode.Success;
  961. }
  962. [CommandHipc(400)]
  963. // IsUsbFullKeyControllerEnabled() -> bool IsEnabled
  964. public ResultCode IsUsbFullKeyControllerEnabled(ServiceCtx context)
  965. {
  966. context.ResponseData.Write(_usbFullKeyControllerEnabled);
  967. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _usbFullKeyControllerEnabled });
  968. return ResultCode.Success;
  969. }
  970. [CommandHipc(401)]
  971. // EnableUsbFullKeyController(bool Enable)
  972. public ResultCode EnableUsbFullKeyController(ServiceCtx context)
  973. {
  974. _usbFullKeyControllerEnabled = context.RequestData.ReadBoolean();
  975. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _usbFullKeyControllerEnabled });
  976. return ResultCode.Success;
  977. }
  978. [CommandHipc(402)]
  979. // IsUsbFullKeyControllerConnected(uint Unknown0) -> bool Connected
  980. public ResultCode IsUsbFullKeyControllerConnected(ServiceCtx context)
  981. {
  982. int unknown0 = context.RequestData.ReadInt32();
  983. context.ResponseData.Write(true); //FullKeyController is always connected ?
  984. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { unknown0, Connected = true });
  985. return ResultCode.Success;
  986. }
  987. [CommandHipc(403)] // 4.0.0+
  988. // HasBattery(uint NpadId) -> bool HasBattery
  989. public ResultCode HasBattery(ServiceCtx context)
  990. {
  991. int npadId = context.RequestData.ReadInt32();
  992. context.ResponseData.Write(true); //Npad always got a battery ?
  993. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, HasBattery = true });
  994. return ResultCode.Success;
  995. }
  996. [CommandHipc(404)] // 4.0.0+
  997. // HasLeftRightBattery(uint NpadId) -> bool HasLeftBattery, bool HasRightBattery
  998. public ResultCode HasLeftRightBattery(ServiceCtx context)
  999. {
  1000. int npadId = context.RequestData.ReadInt32();
  1001. context.ResponseData.Write(true); //Npad always got a left battery ?
  1002. context.ResponseData.Write(true); //Npad always got a right battery ?
  1003. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, HasLeftBattery = true, HasRightBattery = true });
  1004. return ResultCode.Success;
  1005. }
  1006. [CommandHipc(405)] // 4.0.0+
  1007. // GetNpadInterfaceType(uint NpadId) -> uchar InterfaceType
  1008. public ResultCode GetNpadInterfaceType(ServiceCtx context)
  1009. {
  1010. int npadId = context.RequestData.ReadInt32();
  1011. context.ResponseData.Write((byte)0);
  1012. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, NpadInterfaceType = 0 });
  1013. return ResultCode.Success;
  1014. }
  1015. [CommandHipc(406)] // 4.0.0+
  1016. // GetNpadLeftRightInterfaceType(uint NpadId) -> uchar LeftInterfaceType, uchar RightInterfaceType
  1017. public ResultCode GetNpadLeftRightInterfaceType(ServiceCtx context)
  1018. {
  1019. int npadId = context.RequestData.ReadInt32();
  1020. context.ResponseData.Write((byte)0);
  1021. context.ResponseData.Write((byte)0);
  1022. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { npadId, LeftInterfaceType = 0, RightInterfaceType = 0 });
  1023. return ResultCode.Success;
  1024. }
  1025. [CommandHipc(500)] // 5.0.0+
  1026. // GetPalmaConnectionHandle(uint Unknown0, nn::applet::AppletResourceUserId) -> nn::hid::PalmaConnectionHandle
  1027. public ResultCode GetPalmaConnectionHandle(ServiceCtx context)
  1028. {
  1029. int unknown0 = context.RequestData.ReadInt32();
  1030. long appletResourceUserId = context.RequestData.ReadInt64();
  1031. int palmaConnectionHandle = 0;
  1032. context.ResponseData.Write(palmaConnectionHandle);
  1033. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId , unknown0, palmaConnectionHandle });
  1034. return ResultCode.Success;
  1035. }
  1036. [CommandHipc(501)] // 5.0.0+
  1037. // InitializePalma(nn::hid::PalmaConnectionHandle)
  1038. public ResultCode InitializePalma(ServiceCtx context)
  1039. {
  1040. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1041. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1042. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1043. return ResultCode.Success;
  1044. }
  1045. [CommandHipc(502)] // 5.0.0+
  1046. // AcquirePalmaOperationCompleteEvent(nn::hid::PalmaConnectionHandle) -> nn::sf::NativeHandle
  1047. public ResultCode AcquirePalmaOperationCompleteEvent(ServiceCtx context)
  1048. {
  1049. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1050. if (context.Process.HandleTable.GenerateHandle(_palmaOperationCompleteEvent.ReadableEvent, out int handle) != KernelResult.Success)
  1051. {
  1052. throw new InvalidOperationException("Out of handles!");
  1053. }
  1054. context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
  1055. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1056. return ResultCode.Success;
  1057. }
  1058. [CommandHipc(503)] // 5.0.0+
  1059. // GetPalmaOperationInfo(nn::hid::PalmaConnectionHandle) -> long Unknown0, buffer<Unknown>
  1060. public ResultCode GetPalmaOperationInfo(ServiceCtx context)
  1061. {
  1062. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1063. long unknown0 = 0; //Counter?
  1064. context.ResponseData.Write(unknown0);
  1065. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0 });
  1066. return ResultCode.Success;
  1067. }
  1068. [CommandHipc(504)] // 5.0.0+
  1069. // PlayPalmaActivity(nn::hid::PalmaConnectionHandle, ulong Unknown0)
  1070. public ResultCode PlayPalmaActivity(ServiceCtx context)
  1071. {
  1072. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1073. long unknown0 = context.RequestData.ReadInt64();
  1074. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0 });
  1075. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1076. return ResultCode.Success;
  1077. }
  1078. [CommandHipc(505)] // 5.0.0+
  1079. // SetPalmaFrModeType(nn::hid::PalmaConnectionHandle, ulong FrModeType)
  1080. public ResultCode SetPalmaFrModeType(ServiceCtx context)
  1081. {
  1082. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1083. long frModeType = context.RequestData.ReadInt64();
  1084. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, frModeType });
  1085. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1086. return ResultCode.Success;
  1087. }
  1088. [CommandHipc(506)] // 5.0.0+
  1089. // ReadPalmaStep(nn::hid::PalmaConnectionHandle)
  1090. public ResultCode ReadPalmaStep(ServiceCtx context)
  1091. {
  1092. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1093. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1094. return ResultCode.Success;
  1095. }
  1096. [CommandHipc(507)] // 5.0.0+
  1097. // EnablePalmaStep(nn::hid::PalmaConnectionHandle, bool Enable)
  1098. public ResultCode EnablePalmaStep(ServiceCtx context)
  1099. {
  1100. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1101. bool enabledPalmaStep = context.RequestData.ReadBoolean();
  1102. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, enabledPalmaStep });
  1103. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1104. return ResultCode.Success;
  1105. }
  1106. [CommandHipc(508)] // 5.0.0+
  1107. // ResetPalmaStep(nn::hid::PalmaConnectionHandle)
  1108. public ResultCode ResetPalmaStep(ServiceCtx context)
  1109. {
  1110. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1111. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1112. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1113. return ResultCode.Success;
  1114. }
  1115. [CommandHipc(509)] // 5.0.0+
  1116. // ReadPalmaApplicationSection(nn::hid::PalmaConnectionHandle, ulong Unknown0, ulong Unknown1)
  1117. public ResultCode ReadPalmaApplicationSection(ServiceCtx context)
  1118. {
  1119. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1120. long unknown0 = context.RequestData.ReadInt64();
  1121. long unknown1 = context.RequestData.ReadInt64();
  1122. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0, unknown1 });
  1123. return ResultCode.Success;
  1124. }
  1125. [CommandHipc(510)] // 5.0.0+
  1126. // WritePalmaApplicationSection(nn::hid::PalmaConnectionHandle, ulong Unknown0, ulong Unknown1, nn::hid::PalmaApplicationSectionAccessBuffer)
  1127. public ResultCode WritePalmaApplicationSection(ServiceCtx context)
  1128. {
  1129. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1130. long unknown0 = context.RequestData.ReadInt64();
  1131. long unknown1 = context.RequestData.ReadInt64();
  1132. // nn::hid::PalmaApplicationSectionAccessBuffer cast is unknown
  1133. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle, unknown0, unknown1 });
  1134. _palmaOperationCompleteEvent.ReadableEvent.Signal();
  1135. return ResultCode.Success;
  1136. }
  1137. [CommandHipc(511)] // 5.0.0+
  1138. // ReadPalmaUniqueCode(nn::hid::PalmaConnectionHandle)
  1139. public ResultCode ReadPalmaUniqueCode(ServiceCtx context)
  1140. {
  1141. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1142. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1143. return ResultCode.Success;
  1144. }
  1145. [CommandHipc(512)] // 5.0.0+
  1146. // SetPalmaUniqueCodeInvalid(nn::hid::PalmaConnectionHandle)
  1147. public ResultCode SetPalmaUniqueCodeInvalid(ServiceCtx context)
  1148. {
  1149. int palmaConnectionHandle = context.RequestData.ReadInt32();
  1150. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { palmaConnectionHandle });
  1151. return ResultCode.Success;
  1152. }
  1153. [CommandHipc(522)] // 5.1.0+
  1154. // SetIsPalmaAllConnectable(nn::applet::AppletResourceUserId, bool, pid)
  1155. public ResultCode SetIsPalmaAllConnectable(ServiceCtx context)
  1156. {
  1157. long appletResourceUserId = context.RequestData.ReadInt64();
  1158. long unknownBool = context.RequestData.ReadInt64();
  1159. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, unknownBool });
  1160. return ResultCode.Success;
  1161. }
  1162. [CommandHipc(525)] // 5.1.0+
  1163. // SetPalmaBoostMode(bool)
  1164. public ResultCode SetPalmaBoostMode(ServiceCtx context)
  1165. {
  1166. // NOTE: Stubbed in system module.
  1167. return ResultCode.Success;
  1168. }
  1169. [CommandHipc(1000)]
  1170. // SetNpadCommunicationMode(long CommunicationMode, nn::applet::AppletResourceUserId)
  1171. public ResultCode SetNpadCommunicationMode(ServiceCtx context)
  1172. {
  1173. _npadCommunicationMode = context.RequestData.ReadInt64();
  1174. long appletResourceUserId = context.RequestData.ReadInt64();
  1175. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, _npadCommunicationMode });
  1176. return ResultCode.Success;
  1177. }
  1178. [CommandHipc(1001)]
  1179. // GetNpadCommunicationMode() -> long CommunicationMode
  1180. public ResultCode GetNpadCommunicationMode(ServiceCtx context)
  1181. {
  1182. context.ResponseData.Write(_npadCommunicationMode);
  1183. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { _npadCommunicationMode });
  1184. return ResultCode.Success;
  1185. }
  1186. [CommandHipc(1002)] // 9.0.0+
  1187. // SetTouchScreenConfiguration(nn::hid::TouchScreenConfigurationForNx, nn::applet::AppletResourceUserId)
  1188. public ResultCode SetTouchScreenConfiguration(ServiceCtx context)
  1189. {
  1190. long touchScreenConfigurationForNx = context.RequestData.ReadInt64();
  1191. long appletResourceUserId = context.RequestData.ReadInt64();
  1192. Logger.Stub?.PrintStub(LogClass.ServiceHid, new { appletResourceUserId, touchScreenConfigurationForNx });
  1193. return ResultCode.Success;
  1194. }
  1195. }
  1196. }