diff options
| author | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2017-06-21 17:19:24 -0700 | 
|---|---|---|
| committer | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2017-06-22 00:39:27 -0700 | 
| commit | f94093d0fd50e547256643734b67550de538860f (patch) | |
| tree | 1baf48fb477ec6054a376c6afa1a44c700ab5772 | |
| parent | 72b69cea4bf9d01e520fb984a382de3e85af4e36 (diff) | |
Kernel: Implement CreateSession SVC
| -rw-r--r-- | src/core/hle/function_wrappers.h | 10 | ||||
| -rw-r--r-- | src/core/hle/svc.cpp | 19 | 
2 files changed, 26 insertions, 3 deletions
diff --git a/src/core/hle/function_wrappers.h b/src/core/hle/function_wrappers.h index 18b6e7017..b19b64509 100644 --- a/src/core/hle/function_wrappers.h +++ b/src/core/hle/function_wrappers.h @@ -232,6 +232,16 @@ void Wrap() {      FuncReturn(retval);  } +template <ResultCode func(Kernel::Handle*, Kernel::Handle*)> +void Wrap() { +    Kernel::Handle param_1 = 0; +    Kernel::Handle param_2 = 0; +    u32 retval = func(¶m_1, ¶m_2).raw; +    Core::CPU().SetReg(1, param_1); +    Core::CPU().SetReg(2, param_2); +    FuncReturn(retval); +} +  ////////////////////////////////////////////////////////////////////////////////////////////////////  // Function wrappers that return type u32 diff --git a/src/core/hle/svc.cpp b/src/core/hle/svc.cpp index e68b9f16a..f459b1314 100644 --- a/src/core/hle/svc.cpp +++ b/src/core/hle/svc.cpp @@ -36,8 +36,9 @@  ////////////////////////////////////////////////////////////////////////////////////////////////////  // Namespace SVC -using Kernel::SharedPtr;  using Kernel::ERR_INVALID_HANDLE; +using Kernel::Handle; +using Kernel::SharedPtr;  namespace SVC { @@ -933,7 +934,6 @@ static ResultCode CreatePort(Kernel::Handle* server_port, Kernel::Handle* client      using Kernel::ServerPort;      using Kernel::ClientPort; -    using Kernel::SharedPtr;      auto ports = ServerPort::CreatePortPair(max_sessions);      CASCADE_RESULT(*client_port, Kernel::g_handle_table.Create( @@ -947,6 +947,19 @@ static ResultCode CreatePort(Kernel::Handle* server_port, Kernel::Handle* client      return RESULT_SUCCESS;  } +static ResultCode CreateSession(Handle* server_session, Handle* client_session) { +    auto sessions = Kernel::ServerSession::CreateSessionPair(); + +    auto& server = std::get<SharedPtr<Kernel::ServerSession>>(sessions); +    CASCADE_RESULT(*server_session, Kernel::g_handle_table.Create(std::move(server))); + +    auto& client = std::get<SharedPtr<Kernel::ClientSession>>(sessions); +    CASCADE_RESULT(*client_session, Kernel::g_handle_table.Create(std::move(client))); + +    LOG_TRACE(Kernel_SVC, "called"); +    return RESULT_SUCCESS; +} +  static ResultCode GetSystemInfo(s64* out, u32 type, s32 param) {      using Kernel::MemoryRegion; @@ -1122,7 +1135,7 @@ static const FunctionDef SVC_Table[] = {      {0x46, nullptr, "Unknown"},      {0x47, HLE::Wrap<CreatePort>, "CreatePort"},      {0x48, nullptr, "CreateSessionToPort"}, -    {0x49, nullptr, "CreateSession"}, +    {0x49, HLE::Wrap<CreateSession>, "CreateSession"},      {0x4A, nullptr, "AcceptSession"},      {0x4B, nullptr, "ReplyAndReceive1"},      {0x4C, nullptr, "ReplyAndReceive2"},  | 
