diff options
| author | 2016-05-22 12:30:13 -0500 | |
|---|---|---|
| committer | 2016-06-11 08:37:37 -0500 | |
| commit | 7b445ddff0be3e0210cb217c74cb34a16799ce0d (patch) | |
| tree | f752a9eda53997e2268e5a5cbc534e6562c3553d /src | |
| parent | Kernel: Added ClientPort and ServerPort classes. (diff) | |
| download | yuzu-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.h | 10 | ||||
| -rw-r--r-- | src/core/hle/kernel/client_port.h | 2 | ||||
| -rw-r--r-- | src/core/hle/kernel/kernel.h | 3 | ||||
| -rw-r--r-- | src/core/hle/kernel/server_port.cpp | 3 | ||||
| -rw-r--r-- | src/core/hle/kernel/server_port.h | 5 | ||||
| -rw-r--r-- | src/core/hle/svc.cpp | 21 |
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 | ||
| 197 | template<ResultCode func(Handle*, Handle*, const char*, u32)> void Wrap() { | ||
| 198 | Handle param_1 = 0; | ||
| 199 | Handle param_2 = 0; | ||
| 200 | u32 retval = func(¶m_1, ¶m_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 | ||
| 13 | namespace Kernel { | 13 | namespace Kernel { |
| 14 | 14 | ||
| 15 | class ServerPort; | ||
| 16 | |||
| 15 | class ClientPort : public Object { | 17 | class ClientPort : public Object { |
| 16 | public: | 18 | public: |
| 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 | ||
| 36 | enum class HandleType : u32 { | 36 | enum 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 | ||
| 54 | enum { | 55 | enum { |
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 | ||
| 13 | namespace Kernel { | 14 | namespace Kernel { |
| 14 | 15 | ||
| 16 | class ClientPort; | ||
| 17 | |||
| 15 | class ServerPort final : public WaitObject { | 18 | class ServerPort final : public WaitObject { |
| 16 | public: | 19 | public: |
| 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 | ||
| 839 | static 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 | |||
| 837 | static ResultCode GetSystemInfo(s64* out, u32 type, s32 param) { | 856 | static 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"}, |