2015-02-13 13:20:23 +01:00
|
|
|
/**
|
|
|
|
* \brief Add random support for CGD
|
|
|
|
* \author Sebastian Sumpf
|
|
|
|
* \date 2015-02-13
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Genode Labs GmbH
|
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
|
|
* under the terms of the GNU General Public License version 2.
|
|
|
|
*/
|
|
|
|
|
base: avoid use of deprecated base/printf.h
Besides adapting the components to the use of base/log.h, the patch
cleans up a few base headers, i.e., it removes unused includes from
root/component.h, specifically base/heap.h and
ram_session/ram_session.h. Hence, components that relied on the implicit
inclusion of those headers have to manually include those headers now.
While adjusting the log messages, I repeatedly stumbled over the problem
that printing char * arguments is ambiguous. It is unclear whether to
print the argument as pointer or null-terminated string. To overcome
this problem, the patch introduces a new type 'Cstring' that allows the
caller to express that the argument should be handled as null-terminated
string. As a nice side effect, with this type in place, the optional len
argument of the 'String' class could be removed. Instead of supplying a
pair of (char const *, size_t), the constructor accepts a 'Cstring'.
This, in turn, clears the way let the 'String' constructor use the new
output mechanism to assemble a string from multiple arguments (and
thereby getting rid of snprintf within Genode in the near future).
To enforce the explicit resolution of the char * ambiguity, the 'char *'
overload of the 'print' function is marked as deleted.
Issue #1987
2016-07-13 19:07:09 +02:00
|
|
|
#include <base/log.h>
|
2015-02-13 13:20:23 +01:00
|
|
|
#include <util/random.h>
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
namespace Jitter {
|
|
|
|
#include <jitterentropy.h>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
typedef Genode::size_t size_t;
|
|
|
|
|
|
|
|
|
|
|
|
/***********************************
|
|
|
|
** Jitter entropy for randomness **
|
|
|
|
***********************************/
|
|
|
|
|
|
|
|
struct Entropy
|
|
|
|
{
|
|
|
|
struct Jitter::rand_data *ec_stir;
|
|
|
|
|
|
|
|
Entropy()
|
|
|
|
{
|
|
|
|
Jitter::jent_entropy_init();
|
|
|
|
ec_stir = Jitter::jent_entropy_collector_alloc(0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static Entropy *e()
|
|
|
|
{
|
|
|
|
static Entropy _e;
|
|
|
|
return &_e;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t read(char *buf, size_t len)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
if ((err = Jitter::jent_read_entropy(ec_stir, buf, len) < 0)) {
|
base: avoid use of deprecated base/printf.h
Besides adapting the components to the use of base/log.h, the patch
cleans up a few base headers, i.e., it removes unused includes from
root/component.h, specifically base/heap.h and
ram_session/ram_session.h. Hence, components that relied on the implicit
inclusion of those headers have to manually include those headers now.
While adjusting the log messages, I repeatedly stumbled over the problem
that printing char * arguments is ambiguous. It is unclear whether to
print the argument as pointer or null-terminated string. To overcome
this problem, the patch introduces a new type 'Cstring' that allows the
caller to express that the argument should be handled as null-terminated
string. As a nice side effect, with this type in place, the optional len
argument of the 'String' class could be removed. Instead of supplying a
pair of (char const *, size_t), the constructor accepts a 'Cstring'.
This, in turn, clears the way let the 'String' constructor use the new
output mechanism to assemble a string from multiple arguments (and
thereby getting rid of snprintf within Genode in the near future).
To enforce the explicit resolution of the char * ambiguity, the 'char *'
overload of the 'print' function is marked as deleted.
Issue #1987
2016-07-13 19:07:09 +02:00
|
|
|
Genode::error("failed to read entropy: ", err);
|
2015-02-13 13:20:23 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-01-18 15:43:38 +01:00
|
|
|
int rumpuser_getrandom_backend(void *buf, size_t buflen, int flags, Genode::size_t *retp)
|
2015-02-13 13:20:23 +01:00
|
|
|
{
|
|
|
|
*retp = Entropy::e()->read((char *)buf, buflen);
|
|
|
|
return 0;
|
|
|
|
}
|