summaryrefslogtreecommitdiffstats
path: root/src/core/hle/service/es/es.cpp
diff options
context:
space:
mode:
authorZach Hilman <zachhilman@gmail.com>2019-04-10 20:06:17 +0200
committerZach Hilman <zachhilman@gmail.com>2019-07-08 03:38:33 +0200
commit35b617b57ffb46d33886304b82ae80b40d80c042 (patch)
tree4478604b297c31051e8ab833346e94641cfd0d41 /src/core/hle/service/es/es.cpp
parentes: Implement ETicket ListPersonalizedTicket (12) (diff)
downloadyuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar.gz
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar.bz2
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar.lz
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar.xz
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.tar.zst
yuzu-35b617b57ffb46d33886304b82ae80b40d80c042.zip
Diffstat (limited to 'src/core/hle/service/es/es.cpp')
-rw-r--r--src/core/hle/service/es/es.cpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/src/core/hle/service/es/es.cpp b/src/core/hle/service/es/es.cpp
index d136566fc..0125b3ba9 100644
--- a/src/core/hle/service/es/es.cpp
+++ b/src/core/hle/service/es/es.cpp
@@ -29,7 +29,7 @@ public:
{11, &ETicket::ListCommonTicket, "ListCommonTicket"},
{12, &ETicket::ListPersonalizedTicket, "ListPersonalizedTicket"},
{13, nullptr, "ListMissingPersonalizedTicket"},
- {14, nullptr, "GetCommonTicketSize"},
+ {14, &ETicket::GetCommonTicketSize, "GetCommonTicketSize"},
{15, nullptr, "GetPersonalizedTicketSize"},
{16, nullptr, "GetCommonTicketData"},
{17, nullptr, "GetPersonalizedTicketData"},
@@ -190,6 +190,22 @@ private:
rb.Push<u32>(out_entries);
}
+ void GetCommonTicketSize(Kernel::HLERequestContext& ctx) {
+ IPC::RequestParser rp{ctx};
+ const auto rights_id = rp.PopRaw<u128>();
+
+ LOG_DEBUG(Service_ETicket, "called, rights_id={:016X}{:016X}", rights_id[1], rights_id[0]);
+
+ if (!CheckRightsId(ctx, rights_id))
+ return;
+
+ const auto ticket = keys.GetCommonTickets().at(rights_id);
+
+ IPC::ResponseBuilder rb{ctx, 4};
+ rb.Push(RESULT_SUCCESS);
+ rb.Push<u64>(ticket.size());
+ }
+
};
void InstallInterfaces(SM::ServiceManager& service_manager) {