summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/k_server_port.cpp
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2021-04-22 06:53:56 +0200
committerbunnei <bunneidev@gmail.com>2021-05-06 01:40:52 +0200
commit7a068641006da739d6af5681a022018785379365 (patch)
treeaee13360312f8fb9ab9b64310cc478fcc6a5efb1 /src/core/hle/kernel/k_server_port.cpp
parenthle: kernel: Migrate KClientPort to KAutoObject. (diff)
downloadyuzu-7a068641006da739d6af5681a022018785379365.tar
yuzu-7a068641006da739d6af5681a022018785379365.tar.gz
yuzu-7a068641006da739d6af5681a022018785379365.tar.bz2
yuzu-7a068641006da739d6af5681a022018785379365.tar.lz
yuzu-7a068641006da739d6af5681a022018785379365.tar.xz
yuzu-7a068641006da739d6af5681a022018785379365.tar.zst
yuzu-7a068641006da739d6af5681a022018785379365.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/kernel/k_server_port.cpp (renamed from src/core/hle/kernel/server_port.cpp)30
1 files changed, 20 insertions, 10 deletions
diff --git a/src/core/hle/kernel/server_port.cpp b/src/core/hle/kernel/k_server_port.cpp
index addaaa5cf..2c51d66db 100644
--- a/src/core/hle/kernel/server_port.cpp
+++ b/src/core/hle/kernel/k_server_port.cpp
@@ -5,18 +5,23 @@
#include <tuple>
#include "common/assert.h"
#include "core/hle/kernel/k_client_port.h"
+#include "core/hle/kernel/k_server_port.h"
#include "core/hle/kernel/k_server_session.h"
#include "core/hle/kernel/k_thread.h"
#include "core/hle/kernel/object.h"
-#include "core/hle/kernel/server_port.h"
#include "core/hle/kernel/svc_results.h"
namespace Kernel {
-ServerPort::ServerPort(KernelCore& kernel) : KSynchronizationObject{kernel} {}
-ServerPort::~ServerPort() = default;
+KServerPort::KServerPort(KernelCore& kernel) : KSynchronizationObject{kernel} {}
+KServerPort::~KServerPort() = default;
-ResultVal<KServerSession*> ServerPort::Accept() {
+void KServerPort::Initialize(std::string&& name_) {
+ // Set member variables.
+ name = std::move(name_);
+}
+
+ResultVal<KServerSession*> KServerPort::Accept() {
if (pending_sessions.empty()) {
return ResultNotFound;
}
@@ -26,30 +31,35 @@ ResultVal<KServerSession*> ServerPort::Accept() {
return MakeResult(session);
}
-void ServerPort::AppendPendingSession(KServerSession* pending_session) {
+void KServerPort::AppendPendingSession(KServerSession* pending_session) {
pending_sessions.push_back(std::move(pending_session));
if (pending_sessions.size() == 1) {
NotifyAvailable();
}
}
-bool ServerPort::IsSignaled() const {
+void KServerPort::Destroy() {}
+
+bool KServerPort::IsSignaled() const {
return !pending_sessions.empty();
}
-ServerPort::PortPair ServerPort::CreatePortPair(KernelCore& kernel, u32 max_sessions,
- std::string name) {
- std::shared_ptr<ServerPort> server_port = std::make_shared<ServerPort>(kernel);
+KServerPort::PortPair KServerPort::CreatePortPair(KernelCore& kernel, u32 max_sessions,
+ std::string name) {
+ KServerPort* server_port = new KServerPort(kernel);
KClientPort* client_port = new KClientPort(kernel);
+ KAutoObject::Create(server_port);
KAutoObject::Create(client_port);
+ server_port->Initialize(name + "_Server");
client_port->Initialize(max_sessions, name + "_Client");
+
client_port->server_port = server_port;
server_port->name = name + "_Server";
- return std::make_pair(std::move(server_port), client_port);
+ return std::make_pair(server_port, client_port);
}
} // namespace Kernel