diff options
author | Gonglei <arei.gonglei@huawei.com> | 2016-12-22 11:37:03 +0800 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2017-01-10 07:02:52 +0200 |
commit | c159a4d1d0434fcf670f8684273bce0eca117a27 (patch) | |
tree | ad5d593195dd54537c3e0d80b37e4bb3e277edac /hw/virtio/virtio-crypto.c | |
parent | 2e41dfe152331c4f5a8e6ccdb80bfc0d07422e82 (diff) | |
download | qemu-c159a4d1d0434fcf670f8684273bce0eca117a27.zip qemu-c159a4d1d0434fcf670f8684273bce0eca117a27.tar.gz qemu-c159a4d1d0434fcf670f8684273bce0eca117a27.tar.bz2 |
virtio-crypto: use the correct length for cipher operation
In some modes of cipher algorithms, the length of destination data
maybe larger then source data, such as ciphertext stealing (CTS).
For symmetric algorithms, the length of ciphertext is definitly
equal to the plaintext for each crypto operation. So we should
use the src_len instead of dst_len avoid to pass the incorrect
cryptographical results to the frontend driver.
Signed-off-by: Gonglei <arei.gonglei@huawei.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'hw/virtio/virtio-crypto.c')
-rw-r--r-- | hw/virtio/virtio-crypto.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/hw/virtio/virtio-crypto.c b/hw/virtio/virtio-crypto.c index c23e1ad..f872c87 100644 --- a/hw/virtio/virtio-crypto.c +++ b/hw/virtio/virtio-crypto.c @@ -355,7 +355,7 @@ virtio_crypto_sym_input_data_helper(VirtIODevice *vdev, return; } - len = sym_op_info->dst_len; + len = sym_op_info->src_len; /* Save the cipher result */ s = iov_from_buf(req->in_iov, req->in_num, 0, sym_op_info->dst, len); if (s != len) { |