Commit 31267270 authored by Herbert Xu's avatar Herbert Xu

crypto: tcrypt - Fixed AEAD speed test setup

The AEAD speed test SG list setup did not correctly mark the AD,
potentially causing a crash.
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 4e4aab63
...@@ -258,12 +258,12 @@ static void sg_init_aead(struct scatterlist *sg, char *xbuf[XBUFSIZE], ...@@ -258,12 +258,12 @@ static void sg_init_aead(struct scatterlist *sg, char *xbuf[XBUFSIZE],
rem = buflen % PAGE_SIZE; rem = buflen % PAGE_SIZE;
} }
sg_init_table(sg, np); sg_init_table(sg, np + 1);
np--; np--;
for (k = 0; k < np; k++) for (k = 0; k < np; k++)
sg_set_buf(&sg[k], xbuf[k], PAGE_SIZE); sg_set_buf(&sg[k + 1], xbuf[k], PAGE_SIZE);
sg_set_buf(&sg[k], xbuf[k], rem); sg_set_buf(&sg[k + 1], xbuf[k], rem);
} }
static void test_aead_speed(const char *algo, int enc, unsigned int secs, static void test_aead_speed(const char *algo, int enc, unsigned int secs,
...@@ -337,8 +337,6 @@ static void test_aead_speed(const char *algo, int enc, unsigned int secs, ...@@ -337,8 +337,6 @@ static void test_aead_speed(const char *algo, int enc, unsigned int secs,
do { do {
assoc = axbuf[0]; assoc = axbuf[0];
memset(assoc, 0xff, aad_size); memset(assoc, 0xff, aad_size);
sg_set_buf(&sg[0], assoc, aad_size);
sg_set_buf(&sgout[0], assoc, aad_size);
if ((*keysize + *b_size) > TVMEMSIZE * PAGE_SIZE) { if ((*keysize + *b_size) > TVMEMSIZE * PAGE_SIZE) {
pr_err("template (%u) too big for tvmem (%lu)\n", pr_err("template (%u) too big for tvmem (%lu)\n",
...@@ -374,12 +372,15 @@ static void test_aead_speed(const char *algo, int enc, unsigned int secs, ...@@ -374,12 +372,15 @@ static void test_aead_speed(const char *algo, int enc, unsigned int secs,
goto out; goto out;
} }
sg_init_aead(&sg[1], xbuf, sg_init_aead(sg, xbuf,
*b_size + (enc ? authsize : 0)); *b_size + (enc ? authsize : 0));
sg_init_aead(&sgout[1], xoutbuf, sg_init_aead(sgout, xoutbuf,
*b_size + (enc ? authsize : 0)); *b_size + (enc ? authsize : 0));
sg_set_buf(&sg[0], assoc, aad_size);
sg_set_buf(&sgout[0], assoc, aad_size);
aead_request_set_crypt(req, sg, sgout, *b_size, iv); aead_request_set_crypt(req, sg, sgout, *b_size, iv);
aead_request_set_ad(req, aad_size); aead_request_set_ad(req, aad_size);
......
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