diff options
author | Subv <subv2112@gmail.com> | 2015-02-24 14:28:36 +0100 |
---|---|---|
committer | Subv <subv2112@gmail.com> | 2015-02-24 14:28:36 +0100 |
commit | ef66feaebaa5285ad475ab8bb61209fc5eac979a (patch) | |
tree | 04e4335fb7426a15c17a0342bc76d08e7993d5b2 /src/core/hle/service/y2r_u.cpp | |
parent | Merge pull request #595 from linkmauve/new-3ds-input (diff) | |
download | yuzu-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/hle/service/y2r_u.cpp')
-rw-r--r-- | src/core/hle/service/y2r_u.cpp | 19 |
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); } |