mirror of
https://github.com/yuzu-emu/yuzu-android
synced 2024-12-27 23:31:22 -08:00
es: Implement ETicket GetPersonalizedTicketData (17)
Copies the raw personal ticket data into the buffer provided.
This commit is contained in:
parent
c6a32dc077
commit
b294b13584
@ -32,7 +32,7 @@ public:
|
|||||||
{14, &ETicket::GetCommonTicketSize, "GetCommonTicketSize"},
|
{14, &ETicket::GetCommonTicketSize, "GetCommonTicketSize"},
|
||||||
{15, &ETicket::GetPersonalizedTicketSize, "GetPersonalizedTicketSize"},
|
{15, &ETicket::GetPersonalizedTicketSize, "GetPersonalizedTicketSize"},
|
||||||
{16, &ETicket::GetCommonTicketData, "GetCommonTicketData"},
|
{16, &ETicket::GetCommonTicketData, "GetCommonTicketData"},
|
||||||
{17, nullptr, "GetPersonalizedTicketData"},
|
{17, &ETicket::GetPersonalizedTicketData, "GetPersonalizedTicketData"},
|
||||||
{18, nullptr, "OwnTicket"},
|
{18, nullptr, "OwnTicket"},
|
||||||
{19, nullptr, "GetTicketInfo"},
|
{19, nullptr, "GetTicketInfo"},
|
||||||
{20, nullptr, "ListLightTicketInfo"},
|
{20, nullptr, "ListLightTicketInfo"},
|
||||||
@ -241,6 +241,26 @@ private:
|
|||||||
rb.Push<u64>(write_size);
|
rb.Push<u64>(write_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GetPersonalizedTicketData(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.GetPersonalizedTickets().at(rights_id);
|
||||||
|
|
||||||
|
const auto write_size = std::min(ticket.size(), ctx.GetWriteBufferSize());
|
||||||
|
ctx.WriteBuffer(ticket.data(), write_size);
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 4};
|
||||||
|
rb.Push(RESULT_SUCCESS);
|
||||||
|
rb.Push<u64>(write_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
Core::Crypto::KeyManager keys;
|
||||||
};
|
};
|
||||||
|
|
||||||
void InstallInterfaces(SM::ServiceManager& service_manager) {
|
void InstallInterfaces(SM::ServiceManager& service_manager) {
|
||||||
|
Loading…
Reference in New Issue
Block a user