[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 1/6] virtio: introduce virtio_map
From: |
Stefan Hajnoczi |
Subject: |
Re: [Qemu-devel] [PATCH 1/6] virtio: introduce virtio_map |
Date: |
Tue, 27 Oct 2015 16:13:12 +0000 |
User-agent: |
Mutt/1.5.24 (2015-08-30) |
On Tue, Oct 27, 2015 at 10:47:56AM +0200, Michael S. Tsirkin wrote:
> + for (i = 0; i < *num_sg; i++) {
> len = sg[i].iov_len;
> sg[i].iov_base = cpu_physical_memory_map(addr[i], &len, is_write);
> - if (sg[i].iov_base == NULL || len != sg[i].iov_len) {
> + if (!sg[i].iov_base) {
> error_report("virtio: error trying to map MMIO memory");
> exit(1);
> }
> + if (len == sg[i].iov_len) {
> + continue;
> + }
> + if (*num_sg >= max_size) {
> + error_report("virtio: memory split makes iovec too large");
> + exit(1);
> + }
> + memcpy(sg + i + 1, sg + i, sizeof(*sg) * (*num_sg - i));
> + memcpy(addr + i + 1, addr + i, sizeof(*addr) * (*num_sg - i));
These should be memmove() since memcpy() arguments are not allowed to overlap.