Yarrow tweaks; separate the fast and slow reseed tasks so that they don't

stomp on each other; provide constant names (as enums) for the harvester
to use (makes it more self-documenting).
This commit is contained in:
markm 2000-07-09 11:52:12 +00:00
parent be58a54d86
commit 89ca691934
5 changed files with 29 additions and 22 deletions

View File

@ -47,17 +47,20 @@
static void generator_gate(void);
static void reseed(int);
static void random_harvest_internal(struct timespec *nanotime, u_int64_t entropy, u_int bits, u_int frac, u_int source);
static void random_harvest_internal(struct timespec *nanotime, u_int64_t entropy, u_int bits, u_int frac, enum esource source);
/* Structure holding the entropy state */
struct random_state random_state;
/* When enough entropy has been harvested, asynchronously "stir" it in */
static struct task regate_task;
static struct task regate_task[2];
static struct context {
struct context {
u_int pool;
} context = { 0 };
} context[2] = {
{ 0 },
{ 1 }
};
static void
regate(void *context, int pending)
@ -80,7 +83,8 @@ random_init(void)
random_state.pool[1].thresh = 160;
random_state.slowoverthresh = 2;
random_state.which = FAST;
TASK_INIT(&regate_task, 0, &regate, (void *)&context);
TASK_INIT(&regate_task[FAST], FAST, &regate, (void *)&context[FAST]);
TASK_INIT(&regate_task[SLOW], SLOW, &regate, (void *)&context[SLOW]);
random_init_harvester(random_harvest_internal);
}
@ -286,7 +290,7 @@ generator_gate(void)
static void
random_harvest_internal(struct timespec *nanotime, u_int64_t entropy,
u_int bits, u_int frac, u_int origin)
u_int bits, u_int frac, enum esource origin)
{
u_int insert;
int which; /* fast or slow */
@ -324,16 +328,15 @@ random_harvest_internal(struct timespec *nanotime, u_int64_t entropy,
source->bits += source->frac / 1024;
source->frac %= 1024;
}
context.pool = which;
if (source->bits >= pool->thresh) {
/* XXX Needs to be multiply queued? */
taskqueue_enqueue(taskqueue_swi, &regate_task);
/* XXX Slowoverthresh nees to be considered */
taskqueue_enqueue(taskqueue_swi, &regate_task[which]);
}
/* bump the insertion point */
source->current = insert;
/* toggle the pool for next time */
/* toggle the pool for next insertion */
random_state.which = !random_state.which;
}

View File

@ -41,7 +41,7 @@
void random_init(void);
void random_deinit(void);
void random_init_harvester(void (*)(struct timespec *, u_int64_t, u_int, u_int, u_int));
void random_init_harvester(void (*)(struct timespec *, u_int64_t, u_int, u_int, enum esource));
void random_deinit_harvester(void);
/* This is the beasite that needs protecting. It contains all of the

View File

@ -47,17 +47,20 @@
static void generator_gate(void);
static void reseed(int);
static void random_harvest_internal(struct timespec *nanotime, u_int64_t entropy, u_int bits, u_int frac, u_int source);
static void random_harvest_internal(struct timespec *nanotime, u_int64_t entropy, u_int bits, u_int frac, enum esource source);
/* Structure holding the entropy state */
struct random_state random_state;
/* When enough entropy has been harvested, asynchronously "stir" it in */
static struct task regate_task;
static struct task regate_task[2];
static struct context {
struct context {
u_int pool;
} context = { 0 };
} context[2] = {
{ 0 },
{ 1 }
};
static void
regate(void *context, int pending)
@ -80,7 +83,8 @@ random_init(void)
random_state.pool[1].thresh = 160;
random_state.slowoverthresh = 2;
random_state.which = FAST;
TASK_INIT(&regate_task, 0, &regate, (void *)&context);
TASK_INIT(&regate_task[FAST], FAST, &regate, (void *)&context[FAST]);
TASK_INIT(&regate_task[SLOW], SLOW, &regate, (void *)&context[SLOW]);
random_init_harvester(random_harvest_internal);
}
@ -286,7 +290,7 @@ generator_gate(void)
static void
random_harvest_internal(struct timespec *nanotime, u_int64_t entropy,
u_int bits, u_int frac, u_int origin)
u_int bits, u_int frac, enum esource origin)
{
u_int insert;
int which; /* fast or slow */
@ -324,16 +328,15 @@ random_harvest_internal(struct timespec *nanotime, u_int64_t entropy,
source->bits += source->frac / 1024;
source->frac %= 1024;
}
context.pool = which;
if (source->bits >= pool->thresh) {
/* XXX Needs to be multiply queued? */
taskqueue_enqueue(taskqueue_swi, &regate_task);
/* XXX Slowoverthresh nees to be considered */
taskqueue_enqueue(taskqueue_swi, &regate_task[which]);
}
/* bump the insertion point */
source->current = insert;
/* toggle the pool for next time */
/* toggle the pool for next insertion */
random_state.which = !random_state.which;
}

View File

@ -41,7 +41,7 @@
void random_init(void);
void random_deinit(void);
void random_init_harvester(void (*)(struct timespec *, u_int64_t, u_int, u_int, u_int));
void random_init_harvester(void (*)(struct timespec *, u_int64_t, u_int, u_int, enum esource));
void random_deinit_harvester(void);
/* This is the beasite that needs protecting. It contains all of the

View File

@ -34,6 +34,7 @@
u_int read_random(char *, u_int);
void write_random(char *, u_int);
enum esource { RANDOM_KEYBOARD, RANDOM_MOUSE };
void random_harvest(u_int64_t, u_int, u_int, u_int);
#endif