summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/server_session.h
diff options
context:
space:
mode:
authorSubv <subv2112@gmail.com>2017-01-05 05:23:17 +0100
committerSubv <subv2112@gmail.com>2017-05-15 18:22:15 +0200
commitddfabf31330c0c8e0558a714b6d7e1f1948b73ed (patch)
tree62c525537f603fe85f494f9fb6e622ffcd2afda9 /src/core/hle/kernel/server_session.h
parentMerge pull request #2659 from MerryMage/dsp_dsp-correction (diff)
downloadyuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar.gz
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar.bz2
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar.lz
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar.xz
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.tar.zst
yuzu-ddfabf31330c0c8e0558a714b6d7e1f1948b73ed.zip
Diffstat (limited to 'src/core/hle/kernel/server_session.h')
-rw-r--r--src/core/hle/kernel/server_session.h12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/core/hle/kernel/server_session.h b/src/core/hle/kernel/server_session.h
index 761fc4781..c907d487c 100644
--- a/src/core/hle/kernel/server_session.h
+++ b/src/core/hle/kernel/server_session.h
@@ -9,6 +9,7 @@
#include "common/assert.h"
#include "common/common_types.h"
#include "core/hle/kernel/kernel.h"
+#include "core/hle/kernel/session.h"
#include "core/hle/kernel/thread.h"
#include "core/hle/result.h"
#include "core/hle/service/service.h"
@@ -17,6 +18,8 @@
namespace Kernel {
class ClientSession;
+class ClientPort;
+class ServerSession;
/**
* Kernel object representing the server endpoint of an IPC session. Sessions are the basic CTR-OS
@@ -47,11 +50,13 @@ public:
* Creates a pair of ServerSession and an associated ClientSession.
* @param name Optional name of the ports.
* @param hle_handler Optional HLE handler for this server session.
+ * @param client_port Optional The ClientPort that spawned this session.
* @return The created session tuple
*/
static SessionPair CreateSessionPair(
const std::string& name = "Unknown",
- std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr);
+ std::shared_ptr<Service::SessionRequestHandler> hle_handler = nullptr,
+ SharedPtr<ClientPort> client_port = nullptr);
/**
* Handle a sync request from the emulated application.
@@ -63,8 +68,9 @@ public:
void Acquire(Thread* thread) override;
- std::string name; ///< The name of this session (optional)
- bool signaled; ///< Whether there's new data available to this ServerSession
+ std::string name; ///< The name of this session (optional)
+ bool signaled; ///< Whether there's new data available to this ServerSession
+ std::shared_ptr<Session> parent; ///< The parent session, which links to the client endpoint.
std::shared_ptr<Service::SessionRequestHandler>
hle_handler; ///< This session's HLE request handler (optional)