summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2018-02-03 18:09:33 +0100
committerbunnei <bunneidev@gmail.com>2018-02-03 18:09:33 +0100
commit72c5bfb1fad4ae396e7f169d4951cd1a61d1292d (patch)
tree98bd46b7b19cb25cf354da3736db1c7b2363771f
parentService/am: Add AppletAE service (#153) (diff)
downloadyuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar.gz
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar.bz2
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar.lz
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar.xz
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.tar.zst
yuzu-72c5bfb1fad4ae396e7f169d4951cd1a61d1292d.zip
-rw-r--r--src/core/hle/service/sm/controller.cpp13
1 files changed, 9 insertions, 4 deletions
diff --git a/src/core/hle/service/sm/controller.cpp b/src/core/hle/service/sm/controller.cpp
index a81ff9f49..e12c53442 100644
--- a/src/core/hle/service/sm/controller.cpp
+++ b/src/core/hle/service/sm/controller.cpp
@@ -4,6 +4,7 @@
#include "common/logging/log.h"
#include "core/hle/ipc_helpers.h"
+#include "core/hle/kernel/session.h"
#include "core/hle/service/sm/controller.h"
namespace Service {
@@ -21,17 +22,21 @@ void Controller::ConvertSessionToDomain(Kernel::HLERequestContext& ctx) {
}
void Controller::DuplicateSession(Kernel::HLERequestContext& ctx) {
+ // TODO(bunnei): This is just creating a new handle to the same Session. I assume this is wrong
+ // and that we probably want to actually make an entirely new Session, but we still need to
+ // verify this on hardware.
IPC::ResponseBuilder rb{ctx, 2, 0, 1, IPC::ResponseBuilder::Flags::AlwaysMoveHandles};
rb.Push(RESULT_SUCCESS);
- rb.PushMoveObjects(ctx.Session());
+ Kernel::SharedPtr<Kernel::ClientSession> session{ctx.Session()->parent->client};
+ rb.PushMoveObjects(session);
- LOG_DEBUG(Service, "called");
+ LOG_DEBUG(Service, "called, session=%u", session->GetObjectId());
}
void Controller::DuplicateSessionEx(Kernel::HLERequestContext& ctx) {
- DuplicateSession(ctx);
-
LOG_WARNING(Service, "(STUBBED) called, using DuplicateSession");
+
+ DuplicateSession(ctx);
}
void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) {