random: added a bus interface for RNG modules.
* Yarrow RNG is the default RNG module.
This commit is contained in:
parent
8f7f28a7c3
commit
f73fb1051d
@ -32,7 +32,8 @@
|
||||
|
||||
|
||||
static mutex sRandomLock;
|
||||
static device_manager_info* sDeviceManager;
|
||||
static random_sim_interface *sRandomModule;
|
||||
device_manager_info* gDeviceManager;
|
||||
|
||||
|
||||
typedef struct {
|
||||
@ -47,14 +48,13 @@ static status_t
|
||||
random_init_device(void* _info, void** _cookie)
|
||||
{
|
||||
mutex_init(&sRandomLock, "/dev/random lock");
|
||||
return gYarrowRandomModule->init();
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
random_uninit_device(void* _cookie)
|
||||
{
|
||||
gYarrowRandomModule->uninit();
|
||||
mutex_destroy(&sRandomLock);
|
||||
}
|
||||
|
||||
@ -73,7 +73,7 @@ random_read(void *cookie, off_t position, void *_buffer, size_t *_numBytes)
|
||||
TRACE("read(%Ld,, %ld)\n", position, *_numBytes);
|
||||
|
||||
MutexLocker locker(&sRandomLock);
|
||||
return gYarrowRandomModule->read(_buffer, _numBytes);
|
||||
return sRandomModule->read(_buffer, _numBytes);
|
||||
}
|
||||
|
||||
|
||||
@ -82,7 +82,7 @@ random_write(void *cookie, off_t position, const void *buffer, size_t *_numBytes
|
||||
{
|
||||
TRACE("write(%Ld,, %ld)\n", position, *_numBytes);
|
||||
MutexLocker locker(&sRandomLock);
|
||||
return gYarrowRandomModule->write(buffer, _numBytes);
|
||||
return sRandomModule->write(buffer, _numBytes);
|
||||
}
|
||||
|
||||
|
||||
@ -152,7 +152,7 @@ random_supports_device(device_node *parent)
|
||||
const char *bus;
|
||||
|
||||
// make sure parent is really device root
|
||||
if (sDeviceManager->get_attr_string(parent, B_DEVICE_BUS, &bus, false))
|
||||
if (gDeviceManager->get_attr_string(parent, B_DEVICE_BUS, &bus, false))
|
||||
return -1;
|
||||
|
||||
if (strcmp(bus, "root"))
|
||||
@ -174,7 +174,7 @@ random_register_device(device_node *node)
|
||||
{ NULL }
|
||||
};
|
||||
|
||||
return sDeviceManager->register_node(node, RANDOM_DRIVER_MODULE_NAME,
|
||||
return gDeviceManager->register_node(node, RANDOM_DRIVER_MODULE_NAME,
|
||||
attrs, NULL, NULL);
|
||||
}
|
||||
|
||||
@ -212,25 +212,57 @@ random_register_child_devices(void* _cookie)
|
||||
{
|
||||
CALLED();
|
||||
random_driver_info* info = (random_driver_info*)_cookie;
|
||||
status_t status = sDeviceManager->publish_device(info->node, "random",
|
||||
status_t status = gDeviceManager->publish_device(info->node, "random",
|
||||
RANDOM_DEVICE_MODULE_NAME);
|
||||
if (status == B_OK) {
|
||||
sDeviceManager->publish_device(info->node, "urandom",
|
||||
gDeviceManager->publish_device(info->node, "urandom",
|
||||
RANDOM_DEVICE_MODULE_NAME);
|
||||
}
|
||||
|
||||
// add the default Yarrow RNG
|
||||
device_attr attrs[] = {
|
||||
{ B_DEVICE_PRETTY_NAME, B_STRING_TYPE,
|
||||
{ string: "Yarrow RNG" }},
|
||||
{ B_DEVICE_FIXED_CHILD, B_STRING_TYPE,
|
||||
{ string: RANDOM_FOR_CONTROLLER_MODULE_NAME }},
|
||||
{ NULL }
|
||||
};
|
||||
|
||||
device_node* node;
|
||||
return gDeviceManager->register_node(info->node,
|
||||
YARROW_RNG_SIM_MODULE_NAME, attrs, NULL, &node);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
status_t
|
||||
random_added_device(device_node *node)
|
||||
{
|
||||
CALLED();
|
||||
|
||||
void *cookie;
|
||||
|
||||
status_t status = gDeviceManager->get_driver(node,
|
||||
(driver_module_info **)&sRandomModule, &cookie);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
module_dependency module_dependencies[] = {
|
||||
{B_DEVICE_MANAGER_MODULE_NAME, (module_info**)&sDeviceManager},
|
||||
{B_DEVICE_MANAGER_MODULE_NAME, (module_info**)&gDeviceManager},
|
||||
{}
|
||||
};
|
||||
|
||||
|
||||
struct device_module_info sRandomDevice = {
|
||||
{
|
||||
RANDOM_DEVICE_MODULE_NAME,
|
||||
@ -254,6 +286,7 @@ struct device_module_info sRandomDevice = {
|
||||
random_deselect,
|
||||
};
|
||||
|
||||
|
||||
struct driver_module_info sRandomDriver = {
|
||||
{
|
||||
RANDOM_DRIVER_MODULE_NAME,
|
||||
@ -270,8 +303,28 @@ struct driver_module_info sRandomDriver = {
|
||||
NULL, // removed
|
||||
};
|
||||
|
||||
|
||||
random_for_controller_interface sRandomForControllerModule = {
|
||||
{
|
||||
{
|
||||
RANDOM_FOR_CONTROLLER_MODULE_NAME,
|
||||
0,
|
||||
NULL
|
||||
},
|
||||
|
||||
NULL, // supported devices
|
||||
random_added_device,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
module_info* modules[] = {
|
||||
(module_info*)&sRandomDriver,
|
||||
(module_info*)&sRandomDevice,
|
||||
(module_info*)&sRandomForControllerModule,
|
||||
(module_info*)&gYarrowRandomModule,
|
||||
NULL
|
||||
};
|
||||
|
@ -9,12 +9,25 @@
|
||||
#define _RANDOM_H
|
||||
|
||||
|
||||
#include <device_manager.h>
|
||||
|
||||
|
||||
typedef struct {
|
||||
driver_module_info info;
|
||||
} random_for_controller_interface;
|
||||
|
||||
|
||||
#define RANDOM_FOR_CONTROLLER_MODULE_NAME "bus_managers/random/controller/driver_v1"
|
||||
|
||||
// Bus manager interface used by Random controller drivers.
|
||||
typedef struct random_module_info {
|
||||
driver_module_info info;
|
||||
|
||||
status_t (*init)();
|
||||
void (*uninit)();
|
||||
status_t (*read)(void *_buffer, size_t *_numBytes);
|
||||
status_t (*write)(const void *_buffer, size_t *_numBytes);
|
||||
} random_module_info;
|
||||
} random_sim_interface;
|
||||
|
||||
|
||||
#endif /* _RANDOM_H */
|
||||
|
@ -12,6 +12,15 @@
|
||||
#include <thread.h>
|
||||
|
||||
|
||||
//#define TRACE_DRIVER
|
||||
#ifdef TRACE_DRIVER
|
||||
# define TRACE(x...) dprintf("random: " x)
|
||||
#else
|
||||
# define TRACE(x...) ;
|
||||
#endif
|
||||
#define CALLED() TRACE("CALLED %s\n", __PRETTY_FUNCTION__)
|
||||
|
||||
|
||||
#define rotr32(x, n) ((((uint32)(x)) >> ((int) ((n) & 31))) | (((uint32)(x)) << ((int) ((32 - ((n) & 31))))))
|
||||
#define rotl32(x, n) ((((uint32)(x)) << ((int) ((n) & 31))) | (((uint32)(x)) >> ((int) ((32 - ((n) & 31))))))
|
||||
|
||||
@ -335,12 +344,53 @@ yarrow_rng_write(const void *buffer, size_t *_numBytes)
|
||||
}
|
||||
|
||||
|
||||
random_module_info sYarrowRandomModule = {
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
static status_t
|
||||
yarrow_init_bus(device_node* node, void** bus_cookie)
|
||||
{
|
||||
CALLED();
|
||||
return yarrow_rng_init();
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
yarrow_uninit_bus(void* bus_cookie)
|
||||
{
|
||||
CALLED();
|
||||
yarrow_rng_uninit();
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
yarrow_bus_removed(void* bus_cookie)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
random_module_info gYarrowRandomModule = {
|
||||
{
|
||||
{
|
||||
YARROW_RNG_SIM_MODULE_NAME,
|
||||
0,
|
||||
NULL
|
||||
},
|
||||
|
||||
NULL, // supports_device,
|
||||
NULL, // register_device,
|
||||
yarrow_init_bus,
|
||||
yarrow_uninit_bus,
|
||||
NULL, // register child devices
|
||||
NULL, // rescan
|
||||
yarrow_bus_removed,
|
||||
},
|
||||
yarrow_rng_init,
|
||||
yarrow_rng_uninit,
|
||||
yarrow_rng_read,
|
||||
yarrow_rng_write
|
||||
};
|
||||
|
||||
|
||||
random_module_info *gYarrowRandomModule = &sYarrowRandomModule;
|
||||
|
@ -14,12 +14,15 @@
|
||||
#include "random.h"
|
||||
|
||||
|
||||
#define YARROW_RNG_SIM_MODULE_NAME "bus_managers/random/yarrow_rng/device/v1"
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
|
||||
extern random_module_info* gYarrowRandomModule;
|
||||
extern random_module_info gYarrowRandomModule;
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
Loading…
Reference in New Issue
Block a user