diff options
author | Mathias Krause <minipli@googlemail.com> | 2011-07-08 05:21:21 -0400 |
---|---|---|
committer | Herbert Xu <herbert@gondor.apana.org.au> | 2011-07-08 05:21:21 -0400 |
commit | 625426633d7786f26a33123a9d12bec476bcc3cd (patch) | |
tree | 9c773150e6cb1a7cf2e807431a679a80fc6dc69d | |
parent | e3b4f515c43553a9950017d8d052541ccb8081fa (diff) |
crypto: gf128mul - fix call to memset()
In gf128mul_lle() and gf128mul_bbe() r isn't completely initialized with
zero because the size argument passed to memset() is the size of the
pointer, not the structure it points to.
Luckily there are no in-kernel users of those functions so the ABI
change implied by this fix should break no existing code.
Based on a patch by the PaX Team.
Signed-off-by: Mathias Krause <minipli@googlemail.com>
Cc: PaX Team <pageexec@freemail.hu>
Acked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
-rw-r--r-- | crypto/gf128mul.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/crypto/gf128mul.c b/crypto/gf128mul.c index df35e4ccd07e..5276607c72d0 100644 --- a/crypto/gf128mul.c +++ b/crypto/gf128mul.c | |||
@@ -182,7 +182,7 @@ void gf128mul_lle(be128 *r, const be128 *b) | |||
182 | for (i = 0; i < 7; ++i) | 182 | for (i = 0; i < 7; ++i) |
183 | gf128mul_x_lle(&p[i + 1], &p[i]); | 183 | gf128mul_x_lle(&p[i + 1], &p[i]); |
184 | 184 | ||
185 | memset(r, 0, sizeof(r)); | 185 | memset(r, 0, sizeof(*r)); |
186 | for (i = 0;;) { | 186 | for (i = 0;;) { |
187 | u8 ch = ((u8 *)b)[15 - i]; | 187 | u8 ch = ((u8 *)b)[15 - i]; |
188 | 188 | ||
@@ -220,7 +220,7 @@ void gf128mul_bbe(be128 *r, const be128 *b) | |||
220 | for (i = 0; i < 7; ++i) | 220 | for (i = 0; i < 7; ++i) |
221 | gf128mul_x_bbe(&p[i + 1], &p[i]); | 221 | gf128mul_x_bbe(&p[i + 1], &p[i]); |
222 | 222 | ||
223 | memset(r, 0, sizeof(r)); | 223 | memset(r, 0, sizeof(*r)); |
224 | for (i = 0;;) { | 224 | for (i = 0;;) { |
225 | u8 ch = ((u8 *)b)[i]; | 225 | u8 ch = ((u8 *)b)[i]; |
226 | 226 | ||