Commit d2365976 authored by Stephan Müller's avatar Stephan Müller Committed by Herbert Xu

crypto: jitter - correct health test during initialization

With the update of the permanent and intermittent health errors, the
actual indicator for the health test indicates a potential error only
for the one offending time stamp gathered in the current iteration
round. The next iteration round will "overwrite" the health test result.

Thus, the entropy collection loop in jent_gen_entropy checks for
the health test failure upon each loop iteration. However, the
initialization operation checked for the APT health test once for
an APT window which implies it would not catch most errors.

Thus, the check for all health errors is now invoked unconditionally
during each loop iteration for the startup test.

With the change, the error JENT_ERCT becomes unused as all health
errors are only reported with the JENT_HEALTH return code. This
allows the removal of the error indicator.

Fixes: 3fde2fe9 ("crypto: jitter - permanent and intermittent health errors"
)
Reported-by: default avatarJoachim Vandersmissen <git@jvdsn.com>
Signed-off-by: default avatarStephan Mueller <smueller@chronox.de>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 506579e8
...@@ -118,7 +118,6 @@ struct rand_data { ...@@ -118,7 +118,6 @@ struct rand_data {
* zero). */ * zero). */
#define JENT_ESTUCK 8 /* Too many stuck results during init. */ #define JENT_ESTUCK 8 /* Too many stuck results during init. */
#define JENT_EHEALTH 9 /* Health test failed during initialization */ #define JENT_EHEALTH 9 /* Health test failed during initialization */
#define JENT_ERCT 10 /* RCT failed during initialization */
/* /*
* The output n bits can receive more than n bits of min entropy, of course, * The output n bits can receive more than n bits of min entropy, of course,
...@@ -713,14 +712,12 @@ int jent_entropy_init(void *hash_state) ...@@ -713,14 +712,12 @@ int jent_entropy_init(void *hash_state)
if ((nonstuck % JENT_APT_WINDOW_SIZE) == 0) { if ((nonstuck % JENT_APT_WINDOW_SIZE) == 0) {
jent_apt_reset(&ec, jent_apt_reset(&ec,
delta & JENT_APT_WORD_MASK); delta & JENT_APT_WORD_MASK);
if (jent_health_failure(&ec))
return JENT_EHEALTH;
} }
} }
/* Validate RCT */ /* Validate health test result */
if (jent_rct_failure(&ec)) if (jent_health_failure(&ec))
return JENT_ERCT; return JENT_EHEALTH;
/* test whether we have an increasing timer */ /* test whether we have an increasing timer */
if (!(time2 > time)) if (!(time2 > time))
......
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