summaryrefslogtreecommitdiffstats
path: root/src/core/hle/svc.cpp
diff options
context:
space:
mode:
authorYuri Kunde Schlesner <yuriks@yuriks.net>2017-06-23 08:57:05 +0200
committerYuri Kunde Schlesner <yuriks@yuriks.net>2017-06-23 20:26:37 +0200
commite192d417ecc24648106cf3d088bd715525f83e5e (patch)
treed4f4be2c9ed527b9f4df3a74e686a2722e5e05be /src/core/hle/svc.cpp
parentKernel: Fix SVC wrapper for CreatePort (diff)
downloadyuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar.gz
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar.bz2
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar.lz
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar.xz
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.tar.zst
yuzu-e192d417ecc24648106cf3d088bd715525f83e5e.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/svc.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/core/hle/svc.cpp b/src/core/hle/svc.cpp
index 2e11d41ce..c05401143 100644
--- a/src/core/hle/svc.cpp
+++ b/src/core/hle/svc.cpp
@@ -971,6 +971,17 @@ static ResultCode CreateSession(Handle* server_session, Handle* client_session)
return RESULT_SUCCESS;
}
+static ResultCode AcceptSession(Handle* out_server_session, Handle server_port_handle) {
+ using Kernel::ServerPort;
+ SharedPtr<ServerPort> server_port = Kernel::g_handle_table.Get<ServerPort>(server_port_handle);
+ if (server_port == nullptr)
+ return ERR_INVALID_HANDLE;
+
+ CASCADE_RESULT(auto session, server_port->Accept());
+ CASCADE_RESULT(*out_server_session, Kernel::g_handle_table.Create(std::move(session)));
+ return RESULT_SUCCESS;
+}
+
static ResultCode GetSystemInfo(s64* out, u32 type, s32 param) {
using Kernel::MemoryRegion;
@@ -1147,7 +1158,7 @@ static const FunctionDef SVC_Table[] = {
{0x47, HLE::Wrap<CreatePort>, "CreatePort"},
{0x48, HLE::Wrap<CreateSessionToPort>, "CreateSessionToPort"},
{0x49, HLE::Wrap<CreateSession>, "CreateSession"},
- {0x4A, nullptr, "AcceptSession"},
+ {0x4A, HLE::Wrap<AcceptSession>, "AcceptSession"},
{0x4B, nullptr, "ReplyAndReceive1"},
{0x4C, nullptr, "ReplyAndReceive2"},
{0x4D, nullptr, "ReplyAndReceive3"},