Hi, Ian
This patch should fix MSI-x device assignment issues. Some kinds of MSI-x
devcies fail to work after assignment, and various kinds of strange issues occur
with this error. And this patch should them!
Xiantao
>From e6a8ce7273c612d1b3fb30dd9109e355d4b11d74 Mon Sep 17 00:00:00 2001
From: root <root@vt-dp6.(none)>
Date: Fri, 25 Dec 2009 21:45:58 +0800
Subject: [PATCH] Fix MSI-x devices assignment.
Currenlty, assigned MSI-x devices fails to
work due to incorrect table_offset_adjust setting.
The last field msix_entryof struct pt_msix_info is
a variable-size array, so there shouldn''t be any field
after it, otherwise they maybe destroyed
when access msix_entry.
Signed-off-by: Xiantao Zhang <xiantao.zhang@xiantao.zhang@intel.com>
---
hw/pass-through.h | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/hw/pass-through.h b/hw/pass-through.h
index 324df5b..64ce4bf 100644
--- a/hw/pass-through.h
+++ b/hw/pass-through.h
@@ -189,11 +189,11 @@ struct pt_msix_info {
int bar_index;
uint64_t table_base;
uint32_t table_off;
+ uint32_t table_offset_adjust; /* page align mmap */
uint64_t mmio_base_addr;
int mmio_index;
void *phys_iomem_base;
struct msix_entry_info msix_entry[0];
- uint32_t table_offset_adjust; /* page align mmap */
};
struct pt_pm_info {
--
1.5.6.1
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xensource.com
http://lists.xensource.com/xen-devel