diff options
-rw-r--r-- | arch/x86/kernel/amd_iommu.c | 57 |
1 files changed, 28 insertions, 29 deletions
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c index e5bbe9a0c192..405f8dad7c77 100644 --- a/arch/x86/kernel/amd_iommu.c +++ b/arch/x86/kernel/amd_iommu.c | |||
@@ -59,7 +59,6 @@ struct iommu_cmd { | |||
59 | 59 | ||
60 | static int dma_ops_unity_map(struct dma_ops_domain *dma_dom, | 60 | static int dma_ops_unity_map(struct dma_ops_domain *dma_dom, |
61 | struct unity_map_entry *e); | 61 | struct unity_map_entry *e); |
62 | static struct dma_ops_domain *find_protection_domain(u16 devid); | ||
63 | static u64 *alloc_pte(struct protection_domain *domain, | 62 | static u64 *alloc_pte(struct protection_domain *domain, |
64 | unsigned long address, int end_lvl, | 63 | unsigned long address, int end_lvl, |
65 | u64 **pte_page, gfp_t gfp); | 64 | u64 **pte_page, gfp_t gfp); |
@@ -84,6 +83,34 @@ static inline u16 get_device_id(struct device *dev) | |||
84 | return calc_devid(pdev->bus->number, pdev->devfn); | 83 | return calc_devid(pdev->bus->number, pdev->devfn); |
85 | } | 84 | } |
86 | 85 | ||
86 | /* | ||
87 | * In this function the list of preallocated protection domains is traversed to | ||
88 | * find the domain for a specific device | ||
89 | */ | ||
90 | static struct dma_ops_domain *find_protection_domain(u16 devid) | ||
91 | { | ||
92 | struct dma_ops_domain *entry, *ret = NULL; | ||
93 | unsigned long flags; | ||
94 | u16 alias = amd_iommu_alias_table[devid]; | ||
95 | |||
96 | if (list_empty(&iommu_pd_list)) | ||
97 | return NULL; | ||
98 | |||
99 | spin_lock_irqsave(&iommu_pd_list_lock, flags); | ||
100 | |||
101 | list_for_each_entry(entry, &iommu_pd_list, list) { | ||
102 | if (entry->target_dev == devid || | ||
103 | entry->target_dev == alias) { | ||
104 | ret = entry; | ||
105 | break; | ||
106 | } | ||
107 | } | ||
108 | |||
109 | spin_unlock_irqrestore(&iommu_pd_list_lock, flags); | ||
110 | |||
111 | return ret; | ||
112 | } | ||
113 | |||
87 | #ifdef CONFIG_AMD_IOMMU_STATS | 114 | #ifdef CONFIG_AMD_IOMMU_STATS |
88 | 115 | ||
89 | /* | 116 | /* |
@@ -1456,34 +1483,6 @@ static bool check_device(struct device *dev) | |||
1456 | } | 1483 | } |
1457 | 1484 | ||
1458 | /* | 1485 | /* |
1459 | * In this function the list of preallocated protection domains is traversed to | ||
1460 | * find the domain for a specific device | ||
1461 | */ | ||
1462 | static struct dma_ops_domain *find_protection_domain(u16 devid) | ||
1463 | { | ||
1464 | struct dma_ops_domain *entry, *ret = NULL; | ||
1465 | unsigned long flags; | ||
1466 | u16 alias = amd_iommu_alias_table[devid]; | ||
1467 | |||
1468 | if (list_empty(&iommu_pd_list)) | ||
1469 | return NULL; | ||
1470 | |||
1471 | spin_lock_irqsave(&iommu_pd_list_lock, flags); | ||
1472 | |||
1473 | list_for_each_entry(entry, &iommu_pd_list, list) { | ||
1474 | if (entry->target_dev == devid || | ||
1475 | entry->target_dev == alias) { | ||
1476 | ret = entry; | ||
1477 | break; | ||
1478 | } | ||
1479 | } | ||
1480 | |||
1481 | spin_unlock_irqrestore(&iommu_pd_list_lock, flags); | ||
1482 | |||
1483 | return ret; | ||
1484 | } | ||
1485 | |||
1486 | /* | ||
1487 | * In the dma_ops path we only have the struct device. This function | 1486 | * In the dma_ops path we only have the struct device. This function |
1488 | * finds the corresponding IOMMU, the protection domain and the | 1487 | * finds the corresponding IOMMU, the protection domain and the |
1489 | * requestor id for a given device. | 1488 | * requestor id for a given device. |