crypto: virtio - deal with unsupported input sizes

Return -EINVAL for input sizes that are not a multiple of the AES
block size, since they are not supported by our CBC chaining mode.

While at it, remove the pr_err() that reports unsupported key sizes
being used: we shouldn't spam the kernel log with that.

Fixes: dbaf0624ff ("crypto: add virtio-crypto driver")
Cc: "Michael S. Tsirkin" <mst@redhat.com>
Cc: Jason Wang <jasowang@redhat.com>
Cc: Gonglei <arei.gonglei@huawei.com>
Cc: virtualization@lists.linux-foundation.org
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
Ard Biesheuvel 2019-11-09 18:09:27 +01:00 committed by Herbert Xu
parent 500e6807ce
commit 19c5da7d4a
1 changed files with 10 additions and 2 deletions

View File

@ -105,8 +105,6 @@ virtio_crypto_alg_validate_key(int key_len, uint32_t *alg)
*alg = VIRTIO_CRYPTO_CIPHER_AES_CBC; *alg = VIRTIO_CRYPTO_CIPHER_AES_CBC;
break; break;
default: default:
pr_err("virtio_crypto: Unsupported key length: %d\n",
key_len);
return -EINVAL; return -EINVAL;
} }
return 0; return 0;
@ -489,6 +487,11 @@ static int virtio_crypto_ablkcipher_encrypt(struct ablkcipher_request *req)
/* Use the first data virtqueue as default */ /* Use the first data virtqueue as default */
struct data_queue *data_vq = &vcrypto->data_vq[0]; struct data_queue *data_vq = &vcrypto->data_vq[0];
if (!req->nbytes)
return 0;
if (req->nbytes % AES_BLOCK_SIZE)
return -EINVAL;
vc_req->dataq = data_vq; vc_req->dataq = data_vq;
vc_req->alg_cb = virtio_crypto_dataq_sym_callback; vc_req->alg_cb = virtio_crypto_dataq_sym_callback;
vc_sym_req->ablkcipher_ctx = ctx; vc_sym_req->ablkcipher_ctx = ctx;
@ -509,6 +512,11 @@ static int virtio_crypto_ablkcipher_decrypt(struct ablkcipher_request *req)
/* Use the first data virtqueue as default */ /* Use the first data virtqueue as default */
struct data_queue *data_vq = &vcrypto->data_vq[0]; struct data_queue *data_vq = &vcrypto->data_vq[0];
if (!req->nbytes)
return 0;
if (req->nbytes % AES_BLOCK_SIZE)
return -EINVAL;
vc_req->dataq = data_vq; vc_req->dataq = data_vq;
vc_req->alg_cb = virtio_crypto_dataq_sym_callback; vc_req->alg_cb = virtio_crypto_dataq_sym_callback;
vc_sym_req->ablkcipher_ctx = ctx; vc_sym_req->ablkcipher_ctx = ctx;