Skip to content

Commit 3426cb3

Browse files
committed
Merge git://git.infradead.org/iommu-2.6 into iommu/fixes
2 parents aca1bc4 + 5ae0566 commit 3426cb3

File tree

2 files changed

+9
-4
lines changed

2 files changed

+9
-4
lines changed

drivers/iommu/dmar.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -152,7 +152,8 @@ dmar_alloc_pci_notify_info(struct pci_dev *dev, unsigned long event)
152152
info->seg = pci_domain_nr(dev->bus);
153153
info->level = level;
154154
if (event == BUS_NOTIFY_ADD_DEVICE) {
155-
for (tmp = dev, level--; tmp; tmp = tmp->bus->self) {
155+
for (tmp = dev; tmp; tmp = tmp->bus->self) {
156+
level--;
156157
info->path[level].device = PCI_SLOT(tmp->devfn);
157158
info->path[level].function = PCI_FUNC(tmp->devfn);
158159
if (pci_is_root_bus(tmp->bus))

drivers/iommu/intel-iommu.c

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1009,11 +1009,13 @@ static struct page *dma_pte_list_pagetables(struct dmar_domain *domain,
10091009
if (level == 1)
10101010
return freelist;
10111011

1012-
for (pte = page_address(pg); !first_pte_in_page(pte); pte++) {
1012+
pte = page_address(pg);
1013+
do {
10131014
if (dma_pte_present(pte) && !dma_pte_superpage(pte))
10141015
freelist = dma_pte_list_pagetables(domain, level - 1,
10151016
pte, freelist);
1016-
}
1017+
pte++;
1018+
} while (!first_pte_in_page(pte));
10171019

10181020
return freelist;
10191021
}
@@ -2235,7 +2237,9 @@ static struct dmar_domain *get_domain_for_dev(struct device *dev, int gaw)
22352237
bridge_devfn = dev_tmp->devfn;
22362238
}
22372239
spin_lock_irqsave(&device_domain_lock, flags);
2238-
info = dmar_search_domain_by_dev_info(segment, bus, devfn);
2240+
info = dmar_search_domain_by_dev_info(segment,
2241+
bridge_bus,
2242+
bridge_devfn);
22392243
if (info) {
22402244
iommu = info->iommu;
22412245
domain = info->domain;

0 commit comments

Comments
 (0)