|
|
@ -8,6 +8,24 @@ namespace Service::SPL { |
|
|
|
|
|
|
|
|
SPL::SPL(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
SPL::SPL(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
: Interface(system_, std::move(module_), "spl:") { |
|
|
: Interface(system_, std::move(module_), "spl:") { |
|
|
|
|
|
// clang-format off
|
|
|
|
|
|
static const FunctionInfo functions[] = { |
|
|
|
|
|
{0, nullptr, "GetConfig"}, |
|
|
|
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
|
|
|
{5, nullptr, "SetConfig"}, |
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GetRandomBytes"}, |
|
|
|
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
|
|
|
{24, nullptr, "SetBootReason"}, |
|
|
|
|
|
{25, nullptr, "GetBootReason"}, |
|
|
|
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SPL_MIG::SPL_MIG(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
|
|
|
: Interface(system_, std::move(module_), "spl:mig") { |
|
|
|
|
|
// clang-format off
|
|
|
static const FunctionInfo functions[] = { |
|
|
static const FunctionInfo functions[] = { |
|
|
{0, nullptr, "GetConfig"}, |
|
|
{0, nullptr, "GetConfig"}, |
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
@ -15,19 +33,67 @@ SPL::SPL(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
{5, nullptr, "SetConfig"}, |
|
|
{5, nullptr, "SetConfig"}, |
|
|
{7, &SPL::GetRandomBytes, "GetRandomBytes"}, |
|
|
|
|
|
{9, nullptr, "ImportLotusKey"}, |
|
|
|
|
|
{10, nullptr, "DecryptLotusMessage"}, |
|
|
|
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GenerateRandomBytes"}, |
|
|
|
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
|
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
|
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
|
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
|
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
|
|
|
{22, nullptr, "DeallocateAesKeyslot"}, |
|
|
|
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
|
|
|
{24, nullptr, "SetBootReason"}, |
|
|
|
|
|
{25, nullptr, "GetBootReason"}, |
|
|
|
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SPL_FS::SPL_FS(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
|
|
|
: Interface(system_, std::move(module_), "spl:fs") { |
|
|
|
|
|
// clang-format off
|
|
|
|
|
|
static const FunctionInfo functions[] = { |
|
|
|
|
|
{0, nullptr, "GetConfig"}, |
|
|
|
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
|
|
|
{2, nullptr, "GenerateAesKek"}, |
|
|
|
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
|
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
|
|
|
{5, nullptr, "SetConfig"}, |
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GenerateRandomBytes"}, |
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
{12, nullptr, "GenerateSpecificAesKey"}, |
|
|
{12, nullptr, "GenerateSpecificAesKey"}, |
|
|
{13, nullptr, "DecryptDeviceUniqueData"}, |
|
|
|
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
{17, nullptr, "ImportEsKey"}, |
|
|
|
|
|
{18, nullptr, "UnwrapTitleKey"}, |
|
|
|
|
|
{19, nullptr, "LoadTitleKey"}, |
|
|
{19, nullptr, "LoadTitleKey"}, |
|
|
{20, nullptr, "PrepareEsCommonKey"}, |
|
|
|
|
|
|
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
|
|
|
{22, nullptr, "DeallocateAesKeyslot"}, |
|
|
|
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
|
|
|
{24, nullptr, "SetBootReason"}, |
|
|
|
|
|
{25, nullptr, "GetBootReason"}, |
|
|
|
|
|
{31, nullptr, "GetPackage2Hash"}, |
|
|
|
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SPL_SSL::SPL_SSL(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
|
|
|
: Interface(system_, std::move(module_), "spl:ssl") { |
|
|
|
|
|
// clang-format off
|
|
|
|
|
|
static const FunctionInfo functions[] = { |
|
|
|
|
|
{0, nullptr, "GetConfig"}, |
|
|
|
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
|
|
|
{2, nullptr, "GenerateAesKek"}, |
|
|
|
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
|
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
|
|
|
{5, nullptr, "SetConfig"}, |
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GetRandomBytes"}, |
|
|
|
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
|
|
|
{13, nullptr, "DecryptDeviceUniqueData"}, |
|
|
|
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
|
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
|
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
{22, nullptr, "DeallocateAesKeySlot"}, |
|
|
{22, nullptr, "DeallocateAesKeySlot"}, |
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
@ -35,15 +101,83 @@ SPL::SPL(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
{25, nullptr, "GetBootReason"}, |
|
|
{25, nullptr, "GetBootReason"}, |
|
|
{26, nullptr, "DecryptAndStoreSslClientCertKey"}, |
|
|
{26, nullptr, "DecryptAndStoreSslClientCertKey"}, |
|
|
{27, nullptr, "ModularExponentiateWithSslClientCertKey"}, |
|
|
{27, nullptr, "ModularExponentiateWithSslClientCertKey"}, |
|
|
|
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SPL_ES::SPL_ES(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
|
|
|
: Interface(system_, std::move(module_), "spl:es") { |
|
|
|
|
|
// clang-format off
|
|
|
|
|
|
static const FunctionInfo functions[] = { |
|
|
|
|
|
{0, nullptr, "GetConfig"}, |
|
|
|
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
|
|
|
{2, nullptr, "GenerateAesKek"}, |
|
|
|
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
|
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
|
|
|
{5, nullptr, "SetConfig"}, |
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GenerateRandomBytes"}, |
|
|
|
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
|
|
|
{13, nullptr, "DecryptDeviceUniqueData"}, |
|
|
|
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
|
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
|
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
|
|
|
{18, nullptr, "UnwrapTitleKey"}, |
|
|
|
|
|
{20, nullptr, "PrepareEsCommonKey"}, |
|
|
|
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
|
|
|
{22, nullptr, "DeallocateAesKeyslot"}, |
|
|
|
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
|
|
|
{24, nullptr, "SetBootReason"}, |
|
|
|
|
|
{25, nullptr, "GetBootReason"}, |
|
|
{28, nullptr, "DecryptAndStoreDrmDeviceCertKey"}, |
|
|
{28, nullptr, "DecryptAndStoreDrmDeviceCertKey"}, |
|
|
{29, nullptr, "ModularExponentiateWithDrmDeviceCertKey"}, |
|
|
{29, nullptr, "ModularExponentiateWithDrmDeviceCertKey"}, |
|
|
{30, nullptr, "ReencryptDeviceUniqueData "}, |
|
|
|
|
|
{31, nullptr, "PrepareEsArchiveKey"}, // This is also GetPackage2Hash?
|
|
|
|
|
|
|
|
|
{31, nullptr, "PrepareEsArchiveKey"}, |
|
|
{32, nullptr, "LoadPreparedAesKey"}, |
|
|
{32, nullptr, "LoadPreparedAesKey"}, |
|
|
}; |
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SPL_MANU::SPL_MANU(Core::System& system_, std::shared_ptr<Module> module_) |
|
|
|
|
|
: Interface(system_, std::move(module_), "spl:manu") { |
|
|
|
|
|
// clang-format off
|
|
|
|
|
|
static const FunctionInfo functions[] = { |
|
|
|
|
|
{0, nullptr, "GetConfig"}, |
|
|
|
|
|
{1, nullptr, "ModularExponentiate"}, |
|
|
|
|
|
{2, nullptr, "GenerateAesKek"}, |
|
|
|
|
|
{3, nullptr, "LoadAesKey"}, |
|
|
|
|
|
{4, nullptr, "GenerateAesKey"}, |
|
|
|
|
|
{5, nullptr, "SetConfig"}, |
|
|
|
|
|
{7, &SPL::GetRandomBytes, "GetRandomBytes"}, |
|
|
|
|
|
{11, nullptr, "IsDevelopment"}, |
|
|
|
|
|
{13, nullptr, "DecryptDeviceUniqueData"}, |
|
|
|
|
|
{14, nullptr, "DecryptAesKey"}, |
|
|
|
|
|
{15, nullptr, "CryptAesCtr"}, |
|
|
|
|
|
{16, nullptr, "ComputeCmac"}, |
|
|
|
|
|
{21, nullptr, "AllocateAesKeyslot"}, |
|
|
|
|
|
{22, nullptr, "DeallocateAesKeySlot"}, |
|
|
|
|
|
{23, nullptr, "GetAesKeyslotAvailableEvent"}, |
|
|
|
|
|
{24, nullptr, "SetBootReason"}, |
|
|
|
|
|
{25, nullptr, "GetBootReason"}, |
|
|
|
|
|
{30, nullptr, "ReencryptDeviceUniqueData"}, |
|
|
|
|
|
}; |
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
RegisterHandlers(functions); |
|
|
RegisterHandlers(functions); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
SPL::~SPL() = default; |
|
|
SPL::~SPL() = default; |
|
|
|
|
|
|
|
|
|
|
|
SPL_MIG::~SPL_MIG() = default; |
|
|
|
|
|
|
|
|
|
|
|
SPL_FS::~SPL_FS() = default; |
|
|
|
|
|
|
|
|
|
|
|
SPL_SSL::~SPL_SSL() = default; |
|
|
|
|
|
|
|
|
|
|
|
SPL_ES::~SPL_ES() = default; |
|
|
|
|
|
|
|
|
|
|
|
SPL_MANU::~SPL_MANU() = default; |
|
|
|
|
|
|
|
|
} // namespace Service::SPL
|
|
|
} // namespace Service::SPL
|