summaryrefslogtreecommitdiffstats
path: root/src/core
diff options
context:
space:
mode:
authorSubv <subv2112@gmail.com>2015-02-24 14:28:36 +0100
committerSubv <subv2112@gmail.com>2015-02-24 14:28:36 +0100
commitef66feaebaa5285ad475ab8bb61209fc5eac979a (patch)
tree04e4335fb7426a15c17a0342bc76d08e7993d5b2 /src/core
parentMerge pull request #595 from linkmauve/new-3ds-input (diff)
downloadyuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar.gz
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar.bz2
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar.lz
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar.xz
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.tar.zst
yuzu-ef66feaebaa5285ad475ab8bb61209fc5eac979a.zip
Diffstat (limited to 'src/core')
-rw-r--r--src/core/hle/service/y2r_u.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/core/hle/service/y2r_u.cpp b/src/core/hle/service/y2r_u.cpp
index a58e04d6d..6607965e1 100644
--- a/src/core/hle/service/y2r_u.cpp
+++ b/src/core/hle/service/y2r_u.cpp
@@ -11,6 +11,8 @@
namespace Y2R_U {
+static Kernel::SharedPtr<Kernel::Event> completion_event = 0;
+
/**
* Y2R_U::IsBusyConversion service function
* Outputs:
@@ -26,13 +28,26 @@ static void IsBusyConversion(Service::Interface* self) {
LOG_WARNING(Service, "(STUBBED) called");
}
+/**
+ * Y2R_U::GetTransferEndEvent service function
+ * Outputs:
+ * 1 : Result of function, 0 on success, otherwise error code
+ * 3 : The handle of the completion event
+ */
+static void GetTransferEndEvent(Service::Interface* self) {
+ u32* cmd_buff = Kernel::GetCommandBuffer();
+
+ cmd_buff[1] = RESULT_SUCCESS.raw;
+ cmd_buff[3] = Kernel::g_handle_table.Create(completion_event).MoveFrom();
+}
+
const Interface::FunctionInfo FunctionTable[] = {
{0x00010040, nullptr, "SetInputFormat"},
{0x00030040, nullptr, "SetOutputFormat"},
{0x00050040, nullptr, "SetRotation"},
{0x00070040, nullptr, "SetBlockAlignment"},
{0x000D0040, nullptr, "SetTransferEndInterrupt"},
- {0x000F0000, nullptr, "GetTransferEndEvent"},
+ {0x000F0000, GetTransferEndEvent, "GetTransferEndEvent"},
{0x00100102, nullptr, "SetSendingY"},
{0x00110102, nullptr, "SetSendingU"},
{0x00120102, nullptr, "SetSendingV"},
@@ -53,6 +68,8 @@ const Interface::FunctionInfo FunctionTable[] = {
// Interface class
Interface::Interface() {
+ completion_event = Kernel::Event::Create(RESETTYPE_ONESHOT, "Y2R:Completed");
+
Register(FunctionTable);
}