diff options
| -rw-r--r-- | drivers/iommu/amd_iommu.c | 2 | ||||
| -rw-r--r-- | drivers/iommu/amd_iommu_init.c | 2 | ||||
| -rw-r--r-- | drivers/iommu/amd_iommu_v2.c | 2 |
3 files changed, 4 insertions, 2 deletions
diff --git a/drivers/iommu/amd_iommu.c b/drivers/iommu/amd_iommu.c index c949520bd196..57068e8035b5 100644 --- a/drivers/iommu/amd_iommu.c +++ b/drivers/iommu/amd_iommu.c | |||
| @@ -3999,7 +3999,7 @@ static struct irq_remap_table *get_irq_table(u16 devid, bool ioapic) | |||
| 3999 | iommu_flush_dte(iommu, devid); | 3999 | iommu_flush_dte(iommu, devid); |
| 4000 | if (devid != alias) { | 4000 | if (devid != alias) { |
| 4001 | irq_lookup_table[alias] = table; | 4001 | irq_lookup_table[alias] = table; |
| 4002 | set_dte_irq_entry(devid, table); | 4002 | set_dte_irq_entry(alias, table); |
| 4003 | iommu_flush_dte(iommu, alias); | 4003 | iommu_flush_dte(iommu, alias); |
| 4004 | } | 4004 | } |
| 4005 | 4005 | ||
diff --git a/drivers/iommu/amd_iommu_init.c b/drivers/iommu/amd_iommu_init.c index b76c58dbe30c..0e08545d7298 100644 --- a/drivers/iommu/amd_iommu_init.c +++ b/drivers/iommu/amd_iommu_init.c | |||
| @@ -788,7 +788,7 @@ static void __init set_device_exclusion_range(u16 devid, struct ivmd_header *m) | |||
| 788 | * per device. But we can enable the exclusion range per | 788 | * per device. But we can enable the exclusion range per |
| 789 | * device. This is done here | 789 | * device. This is done here |
| 790 | */ | 790 | */ |
| 791 | set_dev_entry_bit(m->devid, DEV_ENTRY_EX); | 791 | set_dev_entry_bit(devid, DEV_ENTRY_EX); |
| 792 | iommu->exclusion_start = m->range_start; | 792 | iommu->exclusion_start = m->range_start; |
| 793 | iommu->exclusion_length = m->range_length; | 793 | iommu->exclusion_length = m->range_length; |
| 794 | } | 794 | } |
diff --git a/drivers/iommu/amd_iommu_v2.c b/drivers/iommu/amd_iommu_v2.c index 5208828792e6..203b2e6a91cf 100644 --- a/drivers/iommu/amd_iommu_v2.c +++ b/drivers/iommu/amd_iommu_v2.c | |||
| @@ -504,8 +504,10 @@ static void do_fault(struct work_struct *work) | |||
| 504 | 504 | ||
| 505 | write = !!(fault->flags & PPR_FAULT_WRITE); | 505 | write = !!(fault->flags & PPR_FAULT_WRITE); |
| 506 | 506 | ||
| 507 | down_read(&fault->state->mm->mmap_sem); | ||
| 507 | npages = get_user_pages(fault->state->task, fault->state->mm, | 508 | npages = get_user_pages(fault->state->task, fault->state->mm, |
| 508 | fault->address, 1, write, 0, &page, NULL); | 509 | fault->address, 1, write, 0, &page, NULL); |
| 510 | up_read(&fault->state->mm->mmap_sem); | ||
| 509 | 511 | ||
| 510 | if (npages == 1) { | 512 | if (npages == 1) { |
| 511 | put_page(page); | 513 | put_page(page); |
