util/vfio-helpers: Pass page protections to qemu_vfio_pci_map_bar()

Pages are currently mapped READ/WRITE. To be able to use different
protections, add a new argument to qemu_vfio_pci_map_bar().

Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Message-Id: <20200922083821.578519-2-philmd@redhat.com>
This commit is contained in:
Philippe Mathieu-Daudé 2020-09-22 10:38:16 +02:00 committed by Stefan Hajnoczi
parent 469e72ab7d
commit b02c01a513
3 changed files with 5 additions and 4 deletions

View File

@ -712,7 +712,8 @@ static int nvme_init(BlockDriverState *bs, const char *device, int namespace,
goto out; goto out;
} }
s->regs = qemu_vfio_pci_map_bar(s->vfio, 0, 0, NVME_BAR_SIZE, errp); s->regs = qemu_vfio_pci_map_bar(s->vfio, 0, 0, NVME_BAR_SIZE,
PROT_READ | PROT_WRITE, errp);
if (!s->regs) { if (!s->regs) {
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;

View File

@ -22,7 +22,7 @@ int qemu_vfio_dma_map(QEMUVFIOState *s, void *host, size_t size,
int qemu_vfio_dma_reset_temporary(QEMUVFIOState *s); int qemu_vfio_dma_reset_temporary(QEMUVFIOState *s);
void qemu_vfio_dma_unmap(QEMUVFIOState *s, void *host); void qemu_vfio_dma_unmap(QEMUVFIOState *s, void *host);
void *qemu_vfio_pci_map_bar(QEMUVFIOState *s, int index, void *qemu_vfio_pci_map_bar(QEMUVFIOState *s, int index,
uint64_t offset, uint64_t size, uint64_t offset, uint64_t size, int prot,
Error **errp); Error **errp);
void qemu_vfio_pci_unmap_bar(QEMUVFIOState *s, int index, void *bar, void qemu_vfio_pci_unmap_bar(QEMUVFIOState *s, int index, void *bar,
uint64_t offset, uint64_t size); uint64_t offset, uint64_t size);

View File

@ -146,13 +146,13 @@ static int qemu_vfio_pci_init_bar(QEMUVFIOState *s, int index, Error **errp)
* Map a PCI bar area. * Map a PCI bar area.
*/ */
void *qemu_vfio_pci_map_bar(QEMUVFIOState *s, int index, void *qemu_vfio_pci_map_bar(QEMUVFIOState *s, int index,
uint64_t offset, uint64_t size, uint64_t offset, uint64_t size, int prot,
Error **errp) Error **errp)
{ {
void *p; void *p;
assert_bar_index_valid(s, index); assert_bar_index_valid(s, index);
p = mmap(NULL, MIN(size, s->bar_region_info[index].size - offset), p = mmap(NULL, MIN(size, s->bar_region_info[index].size - offset),
PROT_READ | PROT_WRITE, MAP_SHARED, prot, MAP_SHARED,
s->device, s->bar_region_info[index].offset + offset); s->device, s->bar_region_info[index].offset + offset);
if (p == MAP_FAILED) { if (p == MAP_FAILED) {
error_setg_errno(errp, errno, "Failed to map BAR region"); error_setg_errno(errp, errno, "Failed to map BAR region");