summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Subv2016-05-22 12:30:13 -0500
committerGravatar Subv2016-06-11 08:37:37 -0500
commit7b445ddff0be3e0210cb217c74cb34a16799ce0d (patch)
treef752a9eda53997e2268e5a5cbc534e6562c3553d /src
parentKernel: Added ClientPort and ServerPort classes. (diff)
downloadyuzu-7b445ddff0be3e0210cb217c74cb34a16799ce0d.tar.gz
yuzu-7b445ddff0be3e0210cb217c74cb34a16799ce0d.tar.xz
yuzu-7b445ddff0be3e0210cb217c74cb34a16799ce0d.zip
Kernel/SVC: Implemented svcCreatePort.
Diffstat (limited to 'src')
-rw-r--r--src/core/hle/function_wrappers.h10
-rw-r--r--src/core/hle/kernel/client_port.h2
-rw-r--r--src/core/hle/kernel/kernel.h3
-rw-r--r--src/core/hle/kernel/server_port.cpp3
-rw-r--r--src/core/hle/kernel/server_port.h5
-rw-r--r--src/core/hle/svc.cpp21
6 files changed, 41 insertions, 3 deletions
diff --git a/src/core/hle/function_wrappers.h b/src/core/hle/function_wrappers.h
index bf7f875b6..8839ce482 100644
--- a/src/core/hle/function_wrappers.h
+++ b/src/core/hle/function_wrappers.h
@@ -194,6 +194,16 @@ template<ResultCode func(Handle, u32)> void Wrap() {
194 FuncReturn(func(PARAM(0), PARAM(1)).raw); 194 FuncReturn(func(PARAM(0), PARAM(1)).raw);
195} 195}
196 196
197template<ResultCode func(Handle*, Handle*, const char*, u32)> void Wrap() {
198 Handle param_1 = 0;
199 Handle param_2 = 0;
200 u32 retval = func(&param_1, &param_2, reinterpret_cast<const char*>(Memory::GetPointer(PARAM(2))), PARAM(3)).raw;
201 // The first out parameter is moved into R2 and the second is moved into R1.
202 Core::g_app_core->SetReg(1, param_2);
203 Core::g_app_core->SetReg(2, param_1);
204 FuncReturn(retval);
205}
206
197//////////////////////////////////////////////////////////////////////////////////////////////////// 207////////////////////////////////////////////////////////////////////////////////////////////////////
198// Function wrappers that return type u32 208// Function wrappers that return type u32
199 209
diff --git a/src/core/hle/kernel/client_port.h b/src/core/hle/kernel/client_port.h
index b3d15cfc5..480b6ddae 100644
--- a/src/core/hle/kernel/client_port.h
+++ b/src/core/hle/kernel/client_port.h
@@ -12,6 +12,8 @@
12 12
13namespace Kernel { 13namespace Kernel {
14 14
15class ServerPort;
16
15class ClientPort : public Object { 17class ClientPort : public Object {
16public: 18public:
17 friend class ServerPort; 19 friend class ServerPort;
diff --git a/src/core/hle/kernel/kernel.h b/src/core/hle/kernel/kernel.h
index a53d408d4..27ba3f912 100644
--- a/src/core/hle/kernel/kernel.h
+++ b/src/core/hle/kernel/kernel.h
@@ -35,7 +35,7 @@ enum KernelHandle : Handle {
35 35
36enum class HandleType : u32 { 36enum class HandleType : u32 {
37 Unknown = 0, 37 Unknown = 0,
38 ServerPort = 1, 38
39 Session = 2, 39 Session = 2,
40 Event = 3, 40 Event = 3,
41 Mutex = 4, 41 Mutex = 4,
@@ -49,6 +49,7 @@ enum class HandleType : u32 {
49 ResourceLimit = 12, 49 ResourceLimit = 12,
50 CodeSet = 13, 50 CodeSet = 13,
51 ClientPort = 14, 51 ClientPort = 14,
52 ServerPort = 15,
52}; 53};
53 54
54enum { 55enum {
diff --git a/src/core/hle/kernel/server_port.cpp b/src/core/hle/kernel/server_port.cpp
index ca41265ff..fcc684a20 100644
--- a/src/core/hle/kernel/server_port.cpp
+++ b/src/core/hle/kernel/server_port.cpp
@@ -2,8 +2,11 @@
2// Licensed under GPLv2 or any later version 2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included. 3// Refer to the license.txt file included.
4 4
5#include <tuple>
6
5#include "common/assert.h" 7#include "common/assert.h"
6 8
9#include "core/hle/kernel/client_port.h"
7#include "core/hle/kernel/kernel.h" 10#include "core/hle/kernel/kernel.h"
8#include "core/hle/kernel/server_port.h" 11#include "core/hle/kernel/server_port.h"
9#include "core/hle/kernel/thread.h" 12#include "core/hle/kernel/thread.h"
diff --git a/src/core/hle/kernel/server_port.h b/src/core/hle/kernel/server_port.h
index e41ef8ce4..e9c972ce6 100644
--- a/src/core/hle/kernel/server_port.h
+++ b/src/core/hle/kernel/server_port.h
@@ -5,6 +5,7 @@
5#pragma once 5#pragma once
6 6
7#include <string> 7#include <string>
8#include <tuple>
8 9
9#include "common/common_types.h" 10#include "common/common_types.h"
10 11
@@ -12,10 +13,12 @@
12 13
13namespace Kernel { 14namespace Kernel {
14 15
16class ClientPort;
17
15class ServerPort final : public WaitObject { 18class ServerPort final : public WaitObject {
16public: 19public:
17 /** 20 /**
18 * Creates a pair of a ServerPort and an associated ClientPort. 21 * Creates a pair of ServerPort and an associated ClientPort.
19 * @param max_sessions Maximum number of sessions to the port 22 * @param max_sessions Maximum number of sessions to the port
20 * @param name Optional name of the ports 23 * @param name Optional name of the ports
21 * @return The created port tuple 24 * @return The created port tuple
diff --git a/src/core/hle/svc.cpp b/src/core/hle/svc.cpp
index 0ce72de87..5d71d5619 100644
--- a/src/core/hle/svc.cpp
+++ b/src/core/hle/svc.cpp
@@ -14,12 +14,14 @@
14#include "core/arm/arm_interface.h" 14#include "core/arm/arm_interface.h"
15 15
16#include "core/hle/kernel/address_arbiter.h" 16#include "core/hle/kernel/address_arbiter.h"
17#include "core/hle/kernel/client_port.h"
17#include "core/hle/kernel/event.h" 18#include "core/hle/kernel/event.h"
18#include "core/hle/kernel/memory.h" 19#include "core/hle/kernel/memory.h"
19#include "core/hle/kernel/mutex.h" 20#include "core/hle/kernel/mutex.h"
20#include "core/hle/kernel/process.h" 21#include "core/hle/kernel/process.h"
21#include "core/hle/kernel/resource_limit.h" 22#include "core/hle/kernel/resource_limit.h"
22#include "core/hle/kernel/semaphore.h" 23#include "core/hle/kernel/semaphore.h"
24#include "core/hle/kernel/server_port.h"
23#include "core/hle/kernel/shared_memory.h" 25#include "core/hle/kernel/shared_memory.h"
24#include "core/hle/kernel/thread.h" 26#include "core/hle/kernel/thread.h"
25#include "core/hle/kernel/timer.h" 27#include "core/hle/kernel/timer.h"
@@ -834,6 +836,23 @@ static ResultCode CreateMemoryBlock(Handle* out_handle, u32 addr, u32 size, u32
834 return RESULT_SUCCESS; 836 return RESULT_SUCCESS;
835} 837}
836 838
839static ResultCode CreatePort(Handle* server_port, Handle* client_port, const char* name, u32 max_sessions) {
840 // TODO(Subv): Implement named ports.
841 ASSERT_MSG(name == nullptr, "Named ports are currently unimplemented");
842
843 using Kernel::ServerPort;
844 using Kernel::ClientPort;
845 using Kernel::SharedPtr;
846
847 auto ports = ServerPort::CreatePortPair(max_sessions);
848 CASCADE_RESULT(*client_port, Kernel::g_handle_table.Create(std::move(std::get<SharedPtr<ClientPort>>(ports))));
849 // Note: The 3DS kernel also leaks the client port handle if the server port handle fails to be created.
850 CASCADE_RESULT(*server_port, Kernel::g_handle_table.Create(std::move(std::get<SharedPtr<ServerPort>>(ports))));
851
852 LOG_TRACE(Kernel_SVC, "called max_sessions=%u", max_sessions);
853 return RESULT_SUCCESS;
854}
855
837static ResultCode GetSystemInfo(s64* out, u32 type, s32 param) { 856static ResultCode GetSystemInfo(s64* out, u32 type, s32 param) {
838 using Kernel::MemoryRegion; 857 using Kernel::MemoryRegion;
839 858
@@ -1011,7 +1030,7 @@ static const FunctionDef SVC_Table[] = {
1011 {0x44, nullptr, "Unknown"}, 1030 {0x44, nullptr, "Unknown"},
1012 {0x45, nullptr, "Unknown"}, 1031 {0x45, nullptr, "Unknown"},
1013 {0x46, nullptr, "Unknown"}, 1032 {0x46, nullptr, "Unknown"},
1014 {0x47, nullptr, "CreatePort"}, 1033 {0x47, HLE::Wrap<CreatePort>, "CreatePort"},
1015 {0x48, nullptr, "CreateSessionToPort"}, 1034 {0x48, nullptr, "CreateSessionToPort"},
1016 {0x49, nullptr, "CreateSession"}, 1035 {0x49, nullptr, "CreateSession"},
1017 {0x4A, nullptr, "AcceptSession"}, 1036 {0x4A, nullptr, "AcceptSession"},