summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorGravatar bunnei2016-06-11 22:46:35 -0400
committerGravatar GitHub2016-06-11 22:46:35 -0400
commit78f2b85fe6df35e3501f6dbd81ceea536fcdb8a1 (patch)
tree73078fff8f77a252dcc51ec39e84b5606ad30133 /src/core
parentMerge pull request #1899 from wwylele/hid-cmath (diff)
parentKernel/SVC: Implemented svcCreatePort. (diff)
downloadyuzu-78f2b85fe6df35e3501f6dbd81ceea536fcdb8a1.tar.gz
yuzu-78f2b85fe6df35e3501f6dbd81ceea536fcdb8a1.tar.xz
yuzu-78f2b85fe6df35e3501f6dbd81ceea536fcdb8a1.zip
Merge pull request #1842 from Subv/ports
Kernel: Added ClientPort and ServerPort classes, along with svcCreatePort.
Diffstat (limited to 'src/core')
-rw-r--r--src/core/CMakeLists.txt4
-rw-r--r--src/core/hle/function_wrappers.h10
-rw-r--r--src/core/hle/kernel/client_port.cpp16
-rw-r--r--src/core/hle/kernel/client_port.h36
-rw-r--r--src/core/hle/kernel/kernel.h7
-rw-r--r--src/core/hle/kernel/server_port.cpp41
-rw-r--r--src/core/hle/kernel/server_port.h46
-rw-r--r--src/core/hle/svc.cpp21
8 files changed, 178 insertions, 3 deletions
diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt
index e9b04098b..7d267fdcf 100644
--- a/src/core/CMakeLists.txt
+++ b/src/core/CMakeLists.txt
@@ -29,6 +29,7 @@ set(SRCS
29 hle/applets/mii_selector.cpp 29 hle/applets/mii_selector.cpp
30 hle/applets/swkbd.cpp 30 hle/applets/swkbd.cpp
31 hle/kernel/address_arbiter.cpp 31 hle/kernel/address_arbiter.cpp
32 hle/kernel/client_port.cpp
32 hle/kernel/event.cpp 33 hle/kernel/event.cpp
33 hle/kernel/kernel.cpp 34 hle/kernel/kernel.cpp
34 hle/kernel/memory.cpp 35 hle/kernel/memory.cpp
@@ -36,6 +37,7 @@ set(SRCS
36 hle/kernel/process.cpp 37 hle/kernel/process.cpp
37 hle/kernel/resource_limit.cpp 38 hle/kernel/resource_limit.cpp
38 hle/kernel/semaphore.cpp 39 hle/kernel/semaphore.cpp
40 hle/kernel/server_port.cpp
39 hle/kernel/session.cpp 41 hle/kernel/session.cpp
40 hle/kernel/shared_memory.cpp 42 hle/kernel/shared_memory.cpp
41 hle/kernel/thread.cpp 43 hle/kernel/thread.cpp
@@ -167,6 +169,7 @@ set(HEADERS
167 hle/applets/mii_selector.h 169 hle/applets/mii_selector.h
168 hle/applets/swkbd.h 170 hle/applets/swkbd.h
169 hle/kernel/address_arbiter.h 171 hle/kernel/address_arbiter.h
172 hle/kernel/client_port.h
170 hle/kernel/event.h 173 hle/kernel/event.h
171 hle/kernel/kernel.h 174 hle/kernel/kernel.h
172 hle/kernel/memory.h 175 hle/kernel/memory.h
@@ -174,6 +177,7 @@ set(HEADERS
174 hle/kernel/process.h 177 hle/kernel/process.h
175 hle/kernel/resource_limit.h 178 hle/kernel/resource_limit.h
176 hle/kernel/semaphore.h 179 hle/kernel/semaphore.h
180 hle/kernel/server_port.h
177 hle/kernel/session.h 181 hle/kernel/session.h
178 hle/kernel/shared_memory.h 182 hle/kernel/shared_memory.h
179 hle/kernel/thread.h 183 hle/kernel/thread.h
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.cpp b/src/core/hle/kernel/client_port.cpp
new file mode 100644
index 000000000..444ce8d45
--- /dev/null
+++ b/src/core/hle/kernel/client_port.cpp
@@ -0,0 +1,16 @@
1// Copyright 2016 Citra Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#include "common/assert.h"
6
7#include "core/hle/kernel/client_port.h"
8#include "core/hle/kernel/kernel.h"
9#include "core/hle/kernel/server_port.h"
10
11namespace Kernel {
12
13ClientPort::ClientPort() {}
14ClientPort::~ClientPort() {}
15
16} // namespace
diff --git a/src/core/hle/kernel/client_port.h b/src/core/hle/kernel/client_port.h
new file mode 100644
index 000000000..480b6ddae
--- /dev/null
+++ b/src/core/hle/kernel/client_port.h
@@ -0,0 +1,36 @@
1// Copyright 2016 Citra Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#pragma once
6
7#include <string>
8
9#include "common/common_types.h"
10
11#include "core/hle/kernel/kernel.h"
12
13namespace Kernel {
14
15class ServerPort;
16
17class ClientPort : public Object {
18public:
19 friend class ServerPort;
20 std::string GetTypeName() const override { return "ClientPort"; }
21 std::string GetName() const override { return name; }
22
23 static const HandleType HANDLE_TYPE = HandleType::ClientPort;
24 HandleType GetHandleType() const override { return HANDLE_TYPE; }
25
26 SharedPtr<ServerPort> server_port; ///< ServerPort associated with this client port.
27 u32 max_sessions; ///< Maximum number of simultaneous sessions the port can have
28 u32 active_sessions; ///< Number of currently open sessions to this port
29 std::string name; ///< Name of client port (optional)
30
31protected:
32 ClientPort();
33 ~ClientPort() override;
34};
35
36} // namespace
diff --git a/src/core/hle/kernel/kernel.h b/src/core/hle/kernel/kernel.h
index 4d4276f7a..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 Port = 1, 38
39 Session = 2, 39 Session = 2,
40 Event = 3, 40 Event = 3,
41 Mutex = 4, 41 Mutex = 4,
@@ -48,6 +48,8 @@ enum class HandleType : u32 {
48 Timer = 11, 48 Timer = 11,
49 ResourceLimit = 12, 49 ResourceLimit = 12,
50 CodeSet = 13, 50 CodeSet = 13,
51 ClientPort = 14,
52 ServerPort = 15,
51}; 53};
52 54
53enum { 55enum {
@@ -72,6 +74,7 @@ public:
72 bool IsWaitable() const { 74 bool IsWaitable() const {
73 switch (GetHandleType()) { 75 switch (GetHandleType()) {
74 case HandleType::Session: 76 case HandleType::Session:
77 case HandleType::ServerPort:
75 case HandleType::Event: 78 case HandleType::Event:
76 case HandleType::Mutex: 79 case HandleType::Mutex:
77 case HandleType::Thread: 80 case HandleType::Thread:
@@ -80,13 +83,13 @@ public:
80 return true; 83 return true;
81 84
82 case HandleType::Unknown: 85 case HandleType::Unknown:
83 case HandleType::Port:
84 case HandleType::SharedMemory: 86 case HandleType::SharedMemory:
85 case HandleType::Redirection: 87 case HandleType::Redirection:
86 case HandleType::Process: 88 case HandleType::Process:
87 case HandleType::AddressArbiter: 89 case HandleType::AddressArbiter:
88 case HandleType::ResourceLimit: 90 case HandleType::ResourceLimit:
89 case HandleType::CodeSet: 91 case HandleType::CodeSet:
92 case HandleType::ClientPort:
90 return false; 93 return false;
91 } 94 }
92 } 95 }
diff --git a/src/core/hle/kernel/server_port.cpp b/src/core/hle/kernel/server_port.cpp
new file mode 100644
index 000000000..fcc684a20
--- /dev/null
+++ b/src/core/hle/kernel/server_port.cpp
@@ -0,0 +1,41 @@
1// Copyright 2016 Citra Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#include <tuple>
6
7#include "common/assert.h"
8
9#include "core/hle/kernel/client_port.h"
10#include "core/hle/kernel/kernel.h"
11#include "core/hle/kernel/server_port.h"
12#include "core/hle/kernel/thread.h"
13
14namespace Kernel {
15
16ServerPort::ServerPort() {}
17ServerPort::~ServerPort() {}
18
19bool ServerPort::ShouldWait() {
20 // If there are no pending sessions, we wait until a new one is added.
21 return pending_sessions.size() == 0;
22}
23
24void ServerPort::Acquire() {
25 ASSERT_MSG(!ShouldWait(), "object unavailable!");
26}
27
28std::tuple<SharedPtr<ServerPort>, SharedPtr<ClientPort>> ServerPort::CreatePortPair(u32 max_sessions, std::string name) {
29 SharedPtr<ServerPort> server_port(new ServerPort);
30 SharedPtr<ClientPort> client_port(new ClientPort);
31
32 server_port->name = name + "_Server";
33 client_port->name = name + "_Client";
34 client_port->server_port = server_port;
35 client_port->max_sessions = max_sessions;
36 client_port->active_sessions = 0;
37
38 return std::make_tuple(std::move(server_port), std::move(client_port));
39}
40
41} // namespace
diff --git a/src/core/hle/kernel/server_port.h b/src/core/hle/kernel/server_port.h
new file mode 100644
index 000000000..e9c972ce6
--- /dev/null
+++ b/src/core/hle/kernel/server_port.h
@@ -0,0 +1,46 @@
1// Copyright 2016 Citra Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#pragma once
6
7#include <string>
8#include <tuple>
9
10#include "common/common_types.h"
11
12#include "core/hle/kernel/kernel.h"
13
14namespace Kernel {
15
16class ClientPort;
17
18class ServerPort final : public WaitObject {
19public:
20 /**
21 * Creates a pair of ServerPort and an associated ClientPort.
22 * @param max_sessions Maximum number of sessions to the port
23 * @param name Optional name of the ports
24 * @return The created port tuple
25 */
26 static std::tuple<SharedPtr<ServerPort>, SharedPtr<ClientPort>> CreatePortPair(u32 max_sessions, std::string name = "UnknownPort");
27
28 std::string GetTypeName() const override { return "ServerPort"; }
29 std::string GetName() const override { return name; }
30
31 static const HandleType HANDLE_TYPE = HandleType::ServerPort;
32 HandleType GetHandleType() const override { return HANDLE_TYPE; }
33
34 std::string name; ///< Name of port (optional)
35
36 std::vector<SharedPtr<WaitObject>> pending_sessions; ///< ServerSessions waiting to be accepted by the port
37
38 bool ShouldWait() override;
39 void Acquire() override;
40
41private:
42 ServerPort();
43 ~ServerPort() override;
44};
45
46} // namespace
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"},