|
|
|
@ -2,6 +2,8 @@ |
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <random>
|
|
|
|
|
|
|
|
#include "core/hle/hle.h"
|
|
|
|
#include "core/hle/service/ssl_c.h"
|
|
|
|
|
|
|
|
@ -10,11 +12,58 @@ |
|
|
|
|
|
|
|
namespace SSL_C { |
|
|
|
|
|
|
|
// 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; |
|
|
|
} |
|
|
|
|
|
|
|
const Interface::FunctionInfo FunctionTable[] = { |
|
|
|
{0x00010002, nullptr, "Initialize"}, |
|
|
|
{0x00010002, Initialize, "Initialize"}, |
|
|
|
{0x000200C2, nullptr, "CreateContext"}, |
|
|
|
{0x00050082, nullptr, "AddTrustedRootCA"}, |
|
|
|
{0x00110042, nullptr, "GenerateRandomData"}, |
|
|
|
{0x00110042, GenerateRandomData, "GenerateRandomData"}, |
|
|
|
{0x00150082, nullptr, "Read"}, |
|
|
|
{0x00170082, nullptr, "Write"}, |
|
|
|
}; |
|
|
|
|