]> www.infradead.org Git - users/hch/misc.git/commitdiff
crypto: lib/sha256 - Don't clear temporary variables
authorArvind Sankar <nivedita@alum.mit.edu>
Sun, 25 Oct 2020 14:31:16 +0000 (10:31 -0400)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 30 Oct 2020 06:35:03 +0000 (17:35 +1100)
The assignments to clear a through h and t1/t2 are optimized out by the
compiler because they are unused after the assignments.

Clearing individual scalar variables is unlikely to be useful, as they
may have been assigned to registers, and even if stack spilling was
required, there may be compiler-generated temporaries that are
impossible to clear in any case.

So drop the clearing of a through h and t1/t2.

Signed-off-by: Arvind Sankar <nivedita@alum.mit.edu>
Reviewed-by: Eric Biggers <ebiggers@google.com>
Acked-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
lib/crypto/sha256.c

index d43bc39ab05e01e484a7da81fe23a41007eef544..099cd11f83c1d26f219665900b90ddcb2f4196bb 100644 (file)
@@ -202,7 +202,6 @@ static void sha256_transform(u32 *state, const u8 *input)
        state[4] += e; state[5] += f; state[6] += g; state[7] += h;
 
        /* clear any sensitive info... */
-       a = b = c = d = e = f = g = h = t1 = t2 = 0;
        memzero_explicit(W, 64 * sizeof(u32));
 }