mirror of https://gitee.com/openkylin/linux.git
crypto: lib/sha256 - Don't clear temporary variables
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>
This commit is contained in:
parent
458c0480dc
commit
7a4295f6c9
|
@ -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;
|
state[4] += e; state[5] += f; state[6] += g; state[7] += h;
|
||||||
|
|
||||||
/* clear any sensitive info... */
|
/* clear any sensitive info... */
|
||||||
a = b = c = d = e = f = g = h = t1 = t2 = 0;
|
|
||||||
memzero_explicit(W, 64 * sizeof(u32));
|
memzero_explicit(W, 64 * sizeof(u32));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue