crypto: tcrypt - fix buflen reminder calculation
authorCristian Stoica <cristian.stoica@freescale.com>
Tue, 27 Jan 2015 09:54:27 +0000 (11:54 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 4 Feb 2015 09:59:41 +0000 (20:59 +1100)
- This fixes the intent of the code to limit the last scatterlist to
  either a full PAGE or a fraction of it, depending on the number of
  pages needed by buflen and the available space advertised by XBUFLEN.

  The original code always sets the last scatterlist to a fraction of a
  PAGE because the first 'if' is never executed.

- Rearrange the second part of the code to remove the conditional from
  the loop

Signed-off-by: Cristian Stoica <cristian.stoica@freescale.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/tcrypt.c

index 004349576ba13ab98d0e24f68c2ad94863e613c7..2b2486ad26ef22710ec552ca3135760c451a1baf 100644 (file)
@@ -250,19 +250,19 @@ static void sg_init_aead(struct scatterlist *sg, char *xbuf[XBUFSIZE],
        int np = (buflen + PAGE_SIZE - 1)/PAGE_SIZE;
        int k, rem;
 
-       np = (np > XBUFSIZE) ? XBUFSIZE : np;
-       rem = buflen % PAGE_SIZE;
        if (np > XBUFSIZE) {
                rem = PAGE_SIZE;
                np = XBUFSIZE;
+       } else {
+               rem = buflen % PAGE_SIZE;
        }
+
        sg_init_table(sg, np);
-       for (k = 0; k < np; ++k) {
-               if (k == (np-1))
-                       sg_set_buf(&sg[k], xbuf[k], rem);
-               else
-                       sg_set_buf(&sg[k], xbuf[k], PAGE_SIZE);
-       }
+       np--;
+       for (k = 0; k < np; k++)
+               sg_set_buf(&sg[k], xbuf[k], PAGE_SIZE);
+
+       sg_set_buf(&sg[k], xbuf[k], rem);
 }
 
 static void test_aead_speed(const char *algo, int enc, unsigned int secs,