提交 082eb10b 编写于 作者: S Stephan Mueller 提交者: Herbert Xu

crypto: drbg - fix drbg_generate return val check

The drbg_generate returns 0 in success case. That means that
drbg_generate_long will always only generate drbg_max_request_bytes at
most. Longer requests will be truncated to drbg_max_request_bytes.
Reported-by: NHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: NStephan Mueller <smueller@chronox.de>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
上级 04a34d46
...@@ -1442,19 +1442,19 @@ static int drbg_generate_long(struct drbg_state *drbg, ...@@ -1442,19 +1442,19 @@ static int drbg_generate_long(struct drbg_state *drbg,
unsigned char *buf, unsigned int buflen, unsigned char *buf, unsigned int buflen,
struct drbg_string *addtl) struct drbg_string *addtl)
{ {
int len = 0; unsigned int len = 0;
unsigned int slice = 0; unsigned int slice = 0;
do { do {
int tmplen = 0; int err = 0;
unsigned int chunk = 0; unsigned int chunk = 0;
slice = ((buflen - len) / drbg_max_request_bytes(drbg)); slice = ((buflen - len) / drbg_max_request_bytes(drbg));
chunk = slice ? drbg_max_request_bytes(drbg) : (buflen - len); chunk = slice ? drbg_max_request_bytes(drbg) : (buflen - len);
tmplen = drbg_generate(drbg, buf + len, chunk, addtl); err = drbg_generate(drbg, buf + len, chunk, addtl);
if (0 >= tmplen) if (0 > err)
return tmplen; return err;
len += tmplen; len += chunk;
} while (slice > 0 && (len < buflen)); } while (slice > 0 && (len < buflen));
return len; return 0;
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册