summaryrefslogtreecommitdiff
path: root/crypto/cfb.c
diff options
context:
space:
mode:
authorDmitry Eremin-Solenikov <dbaryshkov@gmail.com>2018-10-20 02:01:52 +0300
committerHerbert Xu <herbert@gondor.apana.org.au>2018-11-09 17:40:59 +0800
commitd6c50eff9e2820242b6885adc7cac770f93c02f7 (patch)
treec4ceed0cad6aae7849b1b860972884ea414d0db4 /crypto/cfb.c
parent7ca2159d683b6082b3d177cb3ea4bb340b567718 (diff)
downloadlinux-crypto-d6c50eff9e2820242b6885adc7cac770f93c02f7.tar.gz
linux-crypto-d6c50eff9e2820242b6885adc7cac770f93c02f7.zip
crypto: cfb - fix decryption
crypto_cfb_decrypt_segment() incorrectly XOR'ed generated keystream with IV, rather than with data stream, resulting in incorrect decryption. Test vectors will be added in the next patch. Signed-off-by: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com> Cc: stable@vger.kernel.org Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/cfb.c')
-rw-r--r--crypto/cfb.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/crypto/cfb.c b/crypto/cfb.c
index a0d68c09..fd4e8500 100644
--- a/crypto/cfb.c
+++ b/crypto/cfb.c
@@ -144,7 +144,7 @@ static int crypto_cfb_decrypt_segment(struct skcipher_walk *walk,
do {
crypto_cfb_encrypt_one(tfm, iv, dst);
- crypto_xor(dst, iv, bsize);
+ crypto_xor(dst, src, bsize);
iv = src;
src += bsize;