aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Horizon/Usb
diff options
context:
space:
mode:
authorAc_K <Acoustik666@gmail.com>2023-10-14 04:13:15 +0200
committerGitHub <noreply@github.com>2023-10-13 23:13:15 -0300
commit1e06b28b22848706014b18bffcec7553cdab2b2b (patch)
tree96c73f3b1aaacccf5b9ac5ffca31711cc5b71863 /src/Ryujinx.Horizon/Usb
parente768a54f17b390c3ac10904c7909e3bef020edbd (diff)
Horizon: Migrate usb and psc services (#5800)
* Horizon: Migrate Usb and Psc services * Fix formatting * Adresses feedback
Diffstat (limited to 'src/Ryujinx.Horizon/Usb')
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/ClientRootSession.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/DsRootSession.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/PdCradleManager.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/PdManager.cs9
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/PdManufactureManager.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/PmObserverService.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/PmService.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/Ipc/QdbManager.cs8
-rw-r--r--src/Ryujinx.Horizon/Usb/UsbIpcServer.cs71
-rw-r--r--src/Ryujinx.Horizon/Usb/UsbMain.cs17
10 files changed, 153 insertions, 0 deletions
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/ClientRootSession.cs b/src/Ryujinx.Horizon/Usb/Ipc/ClientRootSession.cs
new file mode 100644
index 00000000..2167ebca
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/ClientRootSession.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class ClientRootSession : IClientRootSession
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/DsRootSession.cs b/src/Ryujinx.Horizon/Usb/Ipc/DsRootSession.cs
new file mode 100644
index 00000000..8a84537f
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/DsRootSession.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class DsRootSession : IDsRootSession
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/PdCradleManager.cs b/src/Ryujinx.Horizon/Usb/Ipc/PdCradleManager.cs
new file mode 100644
index 00000000..27e1c4e3
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/PdCradleManager.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class PdCradleManager : IPdCradleManager
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/PdManager.cs b/src/Ryujinx.Horizon/Usb/Ipc/PdManager.cs
new file mode 100644
index 00000000..c501e3f2
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/PdManager.cs
@@ -0,0 +1,9 @@
+using Ryujinx.Horizon.Sdk.Sf.Hipc;
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class PdManager : IPdManager
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/PdManufactureManager.cs b/src/Ryujinx.Horizon/Usb/Ipc/PdManufactureManager.cs
new file mode 100644
index 00000000..04f78b9c
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/PdManufactureManager.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class PdManufactureManager : IPdManufactureManager
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/PmObserverService.cs b/src/Ryujinx.Horizon/Usb/Ipc/PmObserverService.cs
new file mode 100644
index 00000000..e2edf4cb
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/PmObserverService.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class PmObserverService : IPmObserverService
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/PmService.cs b/src/Ryujinx.Horizon/Usb/Ipc/PmService.cs
new file mode 100644
index 00000000..625aaa49
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/PmService.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class PmService : IPmService
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/Ipc/QdbManager.cs b/src/Ryujinx.Horizon/Usb/Ipc/QdbManager.cs
new file mode 100644
index 00000000..1421142f
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/Ipc/QdbManager.cs
@@ -0,0 +1,8 @@
+using Ryujinx.Horizon.Sdk.Usb;
+
+namespace Ryujinx.Horizon.Usb.Ipc
+{
+ partial class QdbManager : IQdbManager
+ {
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/UsbIpcServer.cs b/src/Ryujinx.Horizon/Usb/UsbIpcServer.cs
new file mode 100644
index 00000000..a9158b50
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/UsbIpcServer.cs
@@ -0,0 +1,71 @@
+using Ryujinx.Horizon.Sdk.Sf.Hipc;
+using Ryujinx.Horizon.Sdk.Sm;
+using Ryujinx.Horizon.Usb.Ipc;
+
+namespace Ryujinx.Horizon.Usb
+{
+ class UsbIpcServer
+ {
+ private const int UsbDsMaxSessionsCount = 4;
+ private const int UsbHsMaxSessionsCount = 20;
+ private const int UsbHsAMaxSessionsCount = 3;
+ private const int UsbObsvMaxSessionsCount = 2;
+ private const int UsbPdMaxSessionsCount = 6;
+ private const int UsbPdCMaxSessionsCount = 4;
+ private const int UsbPdMMaxSessionsCount = 1;
+ private const int UsbPmMaxSessionsCount = 5;
+ private const int UsbQdbMaxSessionsCount = 4;
+ private const int TotalMaxSessionsCount =
+ UsbDsMaxSessionsCount +
+ UsbHsMaxSessionsCount +
+ UsbHsAMaxSessionsCount +
+ UsbObsvMaxSessionsCount +
+ UsbPdMaxSessionsCount +
+ UsbPdCMaxSessionsCount +
+ UsbPdMMaxSessionsCount +
+ UsbPmMaxSessionsCount +
+ UsbQdbMaxSessionsCount;
+
+ private const int PointerBufferSize = 0;
+ private const int MaxDomains = 0;
+ private const int MaxDomainObjects = 0;
+ private const int MaxPortsCount = 9;
+
+ private static readonly ManagerOptions _options = new(PointerBufferSize, MaxDomains, MaxDomainObjects, false);
+
+ private SmApi _sm;
+ private ServerManager _serverManager;
+
+ public void Initialize()
+ {
+ HeapAllocator allocator = new();
+
+ _sm = new SmApi();
+ _sm.Initialize().AbortOnFailure();
+
+ _serverManager = new ServerManager(allocator, _sm, MaxPortsCount, _options, TotalMaxSessionsCount);
+
+#pragma warning disable IDE0055 // Disable formatting
+ _serverManager.RegisterObjectForServer(new DsRootSession(), ServiceName.Encode("usb:ds"), UsbDsMaxSessionsCount);
+ _serverManager.RegisterObjectForServer(new ClientRootSession(), ServiceName.Encode("usb:hs"), UsbHsMaxSessionsCount);
+ _serverManager.RegisterObjectForServer(new ClientRootSession(), ServiceName.Encode("usb:hs:a"), UsbHsAMaxSessionsCount); // 7.0.0+
+ _serverManager.RegisterObjectForServer(new PmObserverService(), ServiceName.Encode("usb:obsv"), UsbObsvMaxSessionsCount); // 8.0.0+
+ _serverManager.RegisterObjectForServer(new PdManager(), ServiceName.Encode("usb:pd"), UsbPdMaxSessionsCount);
+ _serverManager.RegisterObjectForServer(new PdCradleManager(), ServiceName.Encode("usb:pd:c"), UsbPdCMaxSessionsCount);
+ _serverManager.RegisterObjectForServer(new PdManufactureManager(), ServiceName.Encode("usb:pd:m"), UsbPdMMaxSessionsCount); // 1.0.0
+ _serverManager.RegisterObjectForServer(new PmService(), ServiceName.Encode("usb:pm"), UsbPmMaxSessionsCount);
+ _serverManager.RegisterObjectForServer(new QdbManager(), ServiceName.Encode("usb:qdb"), UsbQdbMaxSessionsCount); // 7.0.0+
+#pragma warning restore IDE0055
+ }
+
+ public void ServiceRequests()
+ {
+ _serverManager.ServiceRequests();
+ }
+
+ public void Shutdown()
+ {
+ _serverManager.Dispose();
+ }
+ }
+}
diff --git a/src/Ryujinx.Horizon/Usb/UsbMain.cs b/src/Ryujinx.Horizon/Usb/UsbMain.cs
new file mode 100644
index 00000000..c54b39a6
--- /dev/null
+++ b/src/Ryujinx.Horizon/Usb/UsbMain.cs
@@ -0,0 +1,17 @@
+namespace Ryujinx.Horizon.Usb
+{
+ class UsbMain : IService
+ {
+ public static void Main(ServiceTable serviceTable)
+ {
+ UsbIpcServer ipcServer = new();
+
+ ipcServer.Initialize();
+
+ serviceTable.SignalServiceReady();
+
+ ipcServer.ServiceRequests();
+ ipcServer.Shutdown();
+ }
+ }
+}