summaryrefslogtreecommitdiff
path: root/src/core/hle/kernel/kernel.h
diff options
context:
space:
mode:
authorGravatar Liam2022-10-16 01:53:56 -0400
committerGravatar Liam2022-10-31 17:44:06 -0400
commit983f2b70741f17f30fe2321451f10cabecc013d2 (patch)
treec1ac3c1033fdeefaabe76590ca204c4c1b2a98cd /src/core/hle/kernel/kernel.h
parentMerge pull request #9159 from liamwhite/kbork (diff)
downloadyuzu-983f2b70741f17f30fe2321451f10cabecc013d2.tar.gz
yuzu-983f2b70741f17f30fe2321451f10cabecc013d2.tar.xz
yuzu-983f2b70741f17f30fe2321451f10cabecc013d2.zip
kernel: invert session request handling flow
Diffstat (limited to 'src/core/hle/kernel/kernel.h')
-rw-r--r--src/core/hle/kernel/kernel.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/core/hle/kernel/kernel.h b/src/core/hle/kernel/kernel.h
index 266be2bc4..670f93ee3 100644
--- a/src/core/hle/kernel/kernel.h
+++ b/src/core/hle/kernel/kernel.h
@@ -45,6 +45,7 @@ class KPort;
45class KProcess; 45class KProcess;
46class KResourceLimit; 46class KResourceLimit;
47class KScheduler; 47class KScheduler;
48class KServerPort;
48class KServerSession; 49class KServerSession;
49class KSession; 50class KSession;
50class KSessionRequest; 51class KSessionRequest;
@@ -63,6 +64,8 @@ class TimeManager;
63using ServiceInterfaceFactory = 64using ServiceInterfaceFactory =
64 std::function<KClientPort&(Service::SM::ServiceManager&, Core::System&)>; 65 std::function<KClientPort&(Service::SM::ServiceManager&, Core::System&)>;
65 66
67using ServiceInterfaceHandlerFn = std::function<void(Service::SM::ServiceManager&, KServerPort*)>;
68
66namespace Init { 69namespace Init {
67struct KSlabResourceCounts; 70struct KSlabResourceCounts;
68} 71}
@@ -192,9 +195,15 @@ public:
192 /// Registers a named HLE service, passing a factory used to open a port to that service. 195 /// Registers a named HLE service, passing a factory used to open a port to that service.
193 void RegisterNamedService(std::string name, ServiceInterfaceFactory&& factory); 196 void RegisterNamedService(std::string name, ServiceInterfaceFactory&& factory);
194 197
198 /// Registers a setup function for the named HLE service.
199 void RegisterInterfaceForNamedService(std::string name, ServiceInterfaceHandlerFn&& handler);
200
195 /// Opens a port to a service previously registered with RegisterNamedService. 201 /// Opens a port to a service previously registered with RegisterNamedService.
196 KClientPort* CreateNamedServicePort(std::string name); 202 KClientPort* CreateNamedServicePort(std::string name);
197 203
204 /// Accepts a session on a port created by CreateNamedServicePort.
205 void RegisterNamedServiceHandler(std::string name, KServerPort* server_port);
206
198 /// Registers a server session or port with the gobal emulation state, to be freed on shutdown. 207 /// Registers a server session or port with the gobal emulation state, to be freed on shutdown.
199 /// This is necessary because we do not emulate processes for HLE sessions and ports. 208 /// This is necessary because we do not emulate processes for HLE sessions and ports.
200 void RegisterServerObject(KAutoObject* server_object); 209 void RegisterServerObject(KAutoObject* server_object);