提交 82ca8912 编写于 作者: A Alex Williamson

vfio-pci: Add extra debugging

Often when debugging it's useful to be able to disable bypass paths
so no interactions with the device are missed.  Add some extra debug
options to do this.  Also add device info on read/write BAR accesses,
which is useful when debugging more than one assigned device.  A
couple DPRINTFs also had redundant "vfio:" prefixes.
Signed-off-by: NAlex Williamson <alex.williamson@redhat.com>
上级 7076eabc
...@@ -48,6 +48,10 @@ ...@@ -48,6 +48,10 @@
do { } while (0) do { } while (0)
#endif #endif
/* Extra debugging, trap acceleration paths for more logging */
#define VFIO_ALLOW_MMAP 1
#define VFIO_ALLOW_KVM_INTX 1
struct VFIODevice; struct VFIODevice;
typedef struct VFIOQuirk { typedef struct VFIOQuirk {
...@@ -305,7 +309,7 @@ static void vfio_enable_intx_kvm(VFIODevice *vdev) ...@@ -305,7 +309,7 @@ static void vfio_enable_intx_kvm(VFIODevice *vdev)
int ret, argsz; int ret, argsz;
int32_t *pfd; int32_t *pfd;
if (!kvm_irqfds_enabled() || if (!VFIO_ALLOW_KVM_INTX || !kvm_irqfds_enabled() ||
vdev->intx.route.mode != PCI_INTX_ENABLED || vdev->intx.route.mode != PCI_INTX_ENABLED ||
!kvm_check_extension(kvm_state, KVM_CAP_IRQFD_RESAMPLE)) { !kvm_check_extension(kvm_state, KVM_CAP_IRQFD_RESAMPLE)) {
return; return;
...@@ -925,8 +929,16 @@ static void vfio_bar_write(void *opaque, hwaddr addr, ...@@ -925,8 +929,16 @@ static void vfio_bar_write(void *opaque, hwaddr addr,
__func__, addr, data, size); __func__, addr, data, size);
} }
DPRINTF("%s(BAR%d+0x%"HWADDR_PRIx", 0x%"PRIx64", %d)\n", #ifdef DEBUG_VFIO
__func__, bar->nr, addr, data, size); {
VFIODevice *vdev = container_of(bar, VFIODevice, bars[bar->nr]);
DPRINTF("%s(%04x:%02x:%02x.%x:BAR%d+0x%"HWADDR_PRIx", 0x%"PRIx64
", %d)\n", __func__, vdev->host.domain, vdev->host.bus,
vdev->host.slot, vdev->host.function, bar->nr, addr,
data, size);
}
#endif
/* /*
* A read or write to a BAR always signals an INTx EOI. This will * A read or write to a BAR always signals an INTx EOI. This will
...@@ -972,8 +984,16 @@ static uint64_t vfio_bar_read(void *opaque, ...@@ -972,8 +984,16 @@ static uint64_t vfio_bar_read(void *opaque,
break; break;
} }
DPRINTF("%s(BAR%d+0x%"HWADDR_PRIx", %d) = 0x%"PRIx64"\n", #ifdef DEBUG_VFIO
__func__, bar->nr, addr, size, data); {
VFIODevice *vdev = container_of(bar, VFIODevice, bars[bar->nr]);
DPRINTF("%s(%04x:%02x:%02x.%x:BAR%d+0x%"HWADDR_PRIx
", %d) = 0x%"PRIx64"\n", __func__, vdev->host.domain,
vdev->host.bus, vdev->host.slot, vdev->host.function,
bar->nr, addr, size, data);
}
#endif
/* Same as write above */ /* Same as write above */
vfio_eoi(container_of(bar, VFIODevice, bars[bar->nr])); vfio_eoi(container_of(bar, VFIODevice, bars[bar->nr]));
...@@ -1917,7 +1937,7 @@ static void vfio_listener_region_add(MemoryListener *listener, ...@@ -1917,7 +1937,7 @@ static void vfio_listener_region_add(MemoryListener *listener,
int ret; int ret;
if (vfio_listener_skipped_section(section)) { if (vfio_listener_skipped_section(section)) {
DPRINTF("vfio: SKIPPING region_add %"HWADDR_PRIx" - %"PRIx64"\n", DPRINTF("SKIPPING region_add %"HWADDR_PRIx" - %"PRIx64"\n",
section->offset_within_address_space, section->offset_within_address_space,
section->offset_within_address_space + section->size - 1); section->offset_within_address_space + section->size - 1);
return; return;
...@@ -1941,7 +1961,7 @@ static void vfio_listener_region_add(MemoryListener *listener, ...@@ -1941,7 +1961,7 @@ static void vfio_listener_region_add(MemoryListener *listener,
section->offset_within_region + section->offset_within_region +
(iova - section->offset_within_address_space); (iova - section->offset_within_address_space);
DPRINTF("vfio: region_add %"HWADDR_PRIx" - %"HWADDR_PRIx" [%p]\n", DPRINTF("region_add %"HWADDR_PRIx" - %"HWADDR_PRIx" [%p]\n",
iova, end - 1, vaddr); iova, end - 1, vaddr);
ret = vfio_dma_map(container, iova, end - iova, vaddr, section->readonly); ret = vfio_dma_map(container, iova, end - iova, vaddr, section->readonly);
...@@ -1961,7 +1981,7 @@ static void vfio_listener_region_del(MemoryListener *listener, ...@@ -1961,7 +1981,7 @@ static void vfio_listener_region_del(MemoryListener *listener,
int ret; int ret;
if (vfio_listener_skipped_section(section)) { if (vfio_listener_skipped_section(section)) {
DPRINTF("vfio: SKIPPING region_del %"HWADDR_PRIx" - %"PRIx64"\n", DPRINTF("SKIPPING region_del %"HWADDR_PRIx" - %"PRIx64"\n",
section->offset_within_address_space, section->offset_within_address_space,
section->offset_within_address_space + section->size - 1); section->offset_within_address_space + section->size - 1);
return; return;
...@@ -1981,7 +2001,7 @@ static void vfio_listener_region_del(MemoryListener *listener, ...@@ -1981,7 +2001,7 @@ static void vfio_listener_region_del(MemoryListener *listener,
return; return;
} }
DPRINTF("vfio: region_del %"HWADDR_PRIx" - %"HWADDR_PRIx"\n", DPRINTF("region_del %"HWADDR_PRIx" - %"HWADDR_PRIx"\n",
iova, end - 1); iova, end - 1);
ret = vfio_dma_unmap(container, iova, end - iova); ret = vfio_dma_unmap(container, iova, end - iova);
...@@ -2184,7 +2204,7 @@ static int vfio_mmap_bar(VFIOBAR *bar, MemoryRegion *mem, MemoryRegion *submem, ...@@ -2184,7 +2204,7 @@ static int vfio_mmap_bar(VFIOBAR *bar, MemoryRegion *mem, MemoryRegion *submem,
{ {
int ret = 0; int ret = 0;
if (size && bar->flags & VFIO_REGION_INFO_FLAG_MMAP) { if (VFIO_ALLOW_MMAP && size && bar->flags & VFIO_REGION_INFO_FLAG_MMAP) {
int prot = 0; int prot = 0;
if (bar->flags & VFIO_REGION_INFO_FLAG_READ) { if (bar->flags & VFIO_REGION_INFO_FLAG_READ) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册