crypto_alg_mod_lookup() runs in a timeout (60s) for unknown algos. crypto_larval_error() doesn't find the larval and thus doesn't finish crypto_larval_wait, because the larval->mask has the CRYPTO_ALG_TESTED bit set, while crypto_alg_lookup() is called without that bit in the mask and the mask comparison in __crypto_alg_lookup fails. Since larvals itself never get tested, it seems ok to reset that bit. Signed-off-by: Christian Hohnstaedt <chohnstaedt@xxxxxxxxxxxxxx> --- crypto/api.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/crypto/api.c b/crypto/api.c index cd232d4..0a4012e 100644 --- a/crypto/api.c +++ b/crypto/api.c @@ -118,7 +118,7 @@ struct crypto_larval *crypto_larval_alloc(const char *name, u32 type, u32 mask) if (!larval) return ERR_PTR(-ENOMEM); - larval->mask = mask; + larval->mask = mask & ~CRYPTO_ALG_TESTED; larval->alg.cra_flags = CRYPTO_ALG_LARVAL | type; larval->alg.cra_priority = -1; larval->alg.cra_destroy = crypto_larval_destroy; -- 1.5.6.3 -- To unsubscribe from this list: send the line "unsubscribe linux-crypto" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html