crypto: xts - Only add ecb if it is not already there
[ Upstream commit 270b6f13454cb7f2f7058c50df64df409c5dcf55 ]
Only add ecb to the cipher name if it isn't already ecb.
Also use memcmp instead of strncmp since these strings are all
stored in an array of length CRYPTO_MAX_ALG_NAME.
Fixes: f1c131b454
("crypto: xts - Convert to skcipher")
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
ba2af6855c
commit
04a39a3c7d
@@ -363,7 +363,7 @@ static int xts_create(struct crypto_template *tmpl, struct rtattr **tb)
|
|||||||
|
|
||||||
err = crypto_grab_skcipher(&ctx->spawn, skcipher_crypto_instance(inst),
|
err = crypto_grab_skcipher(&ctx->spawn, skcipher_crypto_instance(inst),
|
||||||
cipher_name, 0, mask);
|
cipher_name, 0, mask);
|
||||||
if (err == -ENOENT) {
|
if (err == -ENOENT && memcmp(cipher_name, "ecb(", 4)) {
|
||||||
err = -ENAMETOOLONG;
|
err = -ENAMETOOLONG;
|
||||||
if (snprintf(name, CRYPTO_MAX_ALG_NAME, "ecb(%s)",
|
if (snprintf(name, CRYPTO_MAX_ALG_NAME, "ecb(%s)",
|
||||||
cipher_name) >= CRYPTO_MAX_ALG_NAME)
|
cipher_name) >= CRYPTO_MAX_ALG_NAME)
|
||||||
@@ -397,7 +397,7 @@ static int xts_create(struct crypto_template *tmpl, struct rtattr **tb)
|
|||||||
/* Alas we screwed up the naming so we have to mangle the
|
/* Alas we screwed up the naming so we have to mangle the
|
||||||
* cipher name.
|
* cipher name.
|
||||||
*/
|
*/
|
||||||
if (!strncmp(cipher_name, "ecb(", 4)) {
|
if (!memcmp(cipher_name, "ecb(", 4)) {
|
||||||
int len;
|
int len;
|
||||||
|
|
||||||
len = strscpy(name, cipher_name + 4, sizeof(name));
|
len = strscpy(name, cipher_name + 4, sizeof(name));
|
||||||
|
Reference in New Issue
Block a user