[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v8 0/3] VT-d Device-TLB flush issue
This patches fix current timeout concern and also allow limited ATS support: 1. Reduce spin timeout to 1ms, which can be boot-time changed with 'vtd_qi_timeout'. For example: multiboot /boot/xen.gz ... vtd_qi_timeout=100 ... 2. Wrap a _sync version for all VT-d flush interfaces. For consistency, we wrap a _sync version for all VT-d flush interfaces. It simplifies caller logic and makes code more readable as well. 3. Fix vt-d Device-TLB flush timeout issue. If Device-TLB flush timed out, we would hide the target ATS device and crash the domain owning this ATS device. If impacted domain is hardware domain, just throw out a warning. The hidden device should be disallowed to be further assigned to any domain. **NOTE** This patch set should base on 2 prereq patch sets: a). Make the pcidevs_lock a recursive one. b). Check VT-d Device-TLB flush error. ---- Not covered in this series: a) Eliminate the panic() in IOMMU_WAIT_OP, used only in VT-d register read/write. Further discussion is required on whether and how to improve it. b) Handle IOTLB/Context/IEC flush timeout. --Changes in v8: *Rebase against a6f2cdb633bf519244a16674031b8034b581ba7f. #patch 1 *Add __must_check annotation. #patch 2 *It is a new patch that wraps a _sync version for all VT-d flush interfaces. #patch 3 *Add a blank line between: + pcidevs_lock(); + for_each_pdev(d, pdev) Quan Xu (3): VT-d: Reduce spin timeout to 1ms, which can be boot-time changed VT-d: Wrap a _sync version for all VT-d flush interfaces VT-d: Fix vt-d Device-TLB flush timeout issue docs/misc/xen-command-line.markdown | 7 ++ xen/drivers/passthrough/pci.c | 6 +- xen/drivers/passthrough/vtd/extern.h | 3 + xen/drivers/passthrough/vtd/qinval.c | 202 ++++++++++++++++++++++++---------- xen/drivers/passthrough/vtd/x86/ats.c | 15 +-- xen/include/xen/pci.h | 1 + 6 files changed, 165 insertions(+), 69 deletions(-) -- 1.9.1 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |