Commit 9c87b2ae authored by François Michel's avatar François Michel Committed by Jakub Kicinski

netem: use a seeded PRNG for generating random losses

Use prandom_u32_state() instead of get_random_u32() to generate
the random loss events of netem. The state of the prng is part
of the prng attribute of struct netem_sched_data.
Signed-off-by: default avatarFrançois Michel <francois.michel@uclouvain.be>
Reviewed-by: default avatarSimon Horman <horms@kernel.org>
Acked-by: default avatarStephen Hemminger <stephen@networkplumber.org>
Link: https://lore.kernel.org/r/20230815092348.1449179-3-francois.michel@uclouvain.beSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 4072d97d
...@@ -206,7 +206,7 @@ static u32 get_crandom(struct crndstate *state) ...@@ -206,7 +206,7 @@ static u32 get_crandom(struct crndstate *state)
static bool loss_4state(struct netem_sched_data *q) static bool loss_4state(struct netem_sched_data *q)
{ {
struct clgstate *clg = &q->clg; struct clgstate *clg = &q->clg;
u32 rnd = get_random_u32(); u32 rnd = prandom_u32_state(&q->prng.prng_state);
/* /*
* Makes a comparison between rnd and the transition * Makes a comparison between rnd and the transition
...@@ -271,18 +271,19 @@ static bool loss_4state(struct netem_sched_data *q) ...@@ -271,18 +271,19 @@ static bool loss_4state(struct netem_sched_data *q)
static bool loss_gilb_ell(struct netem_sched_data *q) static bool loss_gilb_ell(struct netem_sched_data *q)
{ {
struct clgstate *clg = &q->clg; struct clgstate *clg = &q->clg;
struct rnd_state *s = &q->prng.prng_state;
switch (clg->state) { switch (clg->state) {
case GOOD_STATE: case GOOD_STATE:
if (get_random_u32() < clg->a1) if (prandom_u32_state(s) < clg->a1)
clg->state = BAD_STATE; clg->state = BAD_STATE;
if (get_random_u32() < clg->a4) if (prandom_u32_state(s) < clg->a4)
return true; return true;
break; break;
case BAD_STATE: case BAD_STATE:
if (get_random_u32() < clg->a2) if (prandom_u32_state(s) < clg->a2)
clg->state = GOOD_STATE; clg->state = GOOD_STATE;
if (get_random_u32() > clg->a3) if (prandom_u32_state(s) > clg->a3)
return true; return true;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment