Hi Avi, Today's linux-next merge of the kvm tree got a conflict in include/linux/intel-iommu.h between commit b6fcb33ad6c05f152a672f7c96c1fab006527b80 ("x64, x2apic/intr-remap: routines managing Interrupt remapping table entries") from Linus' tree and commit 14f776b8e0aa6724069a35bf4e172d93be74ba90 ("VT-d: Changes to support KVM") from the kvm tree. Overlapping additions. I fixed it up (see below - which may not be correct). -- Cheers, Stephen Rothwell sfr@xxxxxxxxxxxxxxxx http://www.canb.auug.org.au/~sfr/ diff --cc include/linux/intel-iommu.h index 2142c01,5fa9d26..0000000 --- a/include/linux/intel-iommu.h +++ b/include/linux/intel-iommu.h @@@ -282,26 -332,32 +282,46 @@@ struct intel_iommu unsigned char name[7]; /* Device Name */ struct msi_msg saved_msg; struct sys_device sysdev; +#endif + struct q_inval *qi; /* Queued invalidation info */ +#ifdef CONFIG_INTR_REMAP + struct ir_table *ir_table; /* Interrupt remapping info */ +#endif }; -#ifndef CONFIG_DMAR_GFX_WA -static inline void iommu_prepare_gfx_mapping(void) +static inline void __iommu_flush_cache( + struct intel_iommu *iommu, void *addr, int size) { - return; + if (!ecap_coherent(iommu->ecap)) + clflush_cache_range(addr, size); } -#endif /* !CONFIG_DMAR_GFX_WA */ + +extern struct dmar_drhd_unit * dmar_find_matched_drhd_unit(struct pci_dev *dev); + +extern int alloc_iommu(struct dmar_drhd_unit *drhd); +extern void free_iommu(struct intel_iommu *iommu); +extern int dmar_enable_qi(struct intel_iommu *iommu); +extern void qi_global_iec(struct intel_iommu *iommu); + +extern void qi_submit_sync(struct qi_desc *desc, struct intel_iommu *iommu); + + void intel_iommu_domain_exit(struct dmar_domain *domain); + struct dmar_domain *intel_iommu_domain_alloc(struct pci_dev *pdev); + int intel_iommu_context_mapping(struct dmar_domain *domain, + struct pci_dev *pdev); + int intel_iommu_page_mapping(struct dmar_domain *domain, dma_addr_t iova, + u64 hpa, size_t size, int prot); + void intel_iommu_detach_dev(struct dmar_domain *domain, u8 bus, u8 devfn); + struct dmar_domain *intel_iommu_find_domain(struct pci_dev *pdev); + u64 intel_iommu_iova_to_pfn(struct dmar_domain *domain, u64 iova); + + #ifdef CONFIG_DMAR + int intel_iommu_found(void); + #else /* CONFIG_DMAR */ + static inline int intel_iommu_found(void) + { + return 0; + } + #endif /* CONFIG_DMAR */ + #endif -- To unsubscribe from this list: send the line "unsubscribe linux-next" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html