IHidServer.cs 58 KB

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