2014-10-30 01:38:33 +00:00
|
|
|
// Copyright 2014 Citra Emulator Project
|
2014-12-17 05:38:14 +00:00
|
|
|
// Licensed under GPLv2 or any later version
|
2014-10-30 01:38:33 +00:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2015-11-22 20:57:06 +00:00
|
|
|
#include <random>
|
|
|
|
|
2016-02-02 06:17:41 +00:00
|
|
|
#include "common/common_types.h"
|
2014-10-30 01:38:33 +00:00
|
|
|
#include "core/hle/service/ssl_c.h"
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Namespace SSL_C
|
|
|
|
|
|
|
|
namespace SSL_C {
|
|
|
|
|
2015-11-22 20:57:06 +00:00
|
|
|
// TODO: Implement a proper CSPRNG in the future when actual security is needed
|
|
|
|
static std::mt19937 rand_gen;
|
|
|
|
|
|
|
|
static void Initialize(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
// Seed random number generator when the SSL service is initialized
|
|
|
|
std::random_device rand_device;
|
|
|
|
rand_gen.seed(rand_device());
|
|
|
|
|
|
|
|
// Stub, return success
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void GenerateRandomData(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 size = cmd_buff[1];
|
|
|
|
VAddr address = cmd_buff[3];
|
|
|
|
u8* output_buff = Memory::GetPointer(address);
|
|
|
|
|
|
|
|
// Fill the output buffer with random data.
|
|
|
|
u32 data = 0;
|
|
|
|
u32 i = 0;
|
|
|
|
while (i < size) {
|
|
|
|
if ((i % 4) == 0) {
|
|
|
|
// The random number generator returns 4 bytes worth of data, so generate new random data when i == 0 and when i is divisible by 4
|
|
|
|
data = rand_gen();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (size > 4) {
|
|
|
|
// Use up the entire 4 bytes of the random data for as long as possible
|
|
|
|
*(u32*)(output_buff + i) = data;
|
|
|
|
i += 4;
|
|
|
|
} else if (size == 2) {
|
|
|
|
*(u16*)(output_buff + i) = (u16)(data & 0xffff);
|
|
|
|
i += 2;
|
|
|
|
} else {
|
|
|
|
*(u8*)(output_buff + i) = (u8)(data & 0xff);
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Stub, return success
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
}
|
|
|
|
|
2014-10-30 01:38:33 +00:00
|
|
|
const Interface::FunctionInfo FunctionTable[] = {
|
2015-11-22 20:57:06 +00:00
|
|
|
{0x00010002, Initialize, "Initialize"},
|
2014-10-30 01:38:33 +00:00
|
|
|
{0x000200C2, nullptr, "CreateContext"},
|
2015-12-30 14:30:57 +00:00
|
|
|
{0x00030000, nullptr, "CreateRootCertChain"},
|
|
|
|
{0x00040040, nullptr, "DestroyRootCertChain"},
|
2014-10-30 01:38:33 +00:00
|
|
|
{0x00050082, nullptr, "AddTrustedRootCA"},
|
2015-12-30 14:30:57 +00:00
|
|
|
{0x00060080, nullptr, "RootCertChainAddDefaultCert"},
|
2015-11-22 20:57:06 +00:00
|
|
|
{0x00110042, GenerateRandomData, "GenerateRandomData"},
|
2014-10-30 01:38:33 +00:00
|
|
|
{0x00150082, nullptr, "Read"},
|
|
|
|
{0x00170082, nullptr, "Write"},
|
2015-12-30 14:30:57 +00:00
|
|
|
{0x00180080, nullptr, "ContextSetRootCertChain"},
|
2014-10-30 01:38:33 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Interface class
|
|
|
|
|
|
|
|
Interface::Interface() {
|
2015-01-30 18:56:49 +00:00
|
|
|
Register(FunctionTable);
|
2014-10-30 01:38:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|