diff options
| -rw-r--r-- | MAINTAINERS | 7 | ||||
| -rw-r--r-- | drivers/iommu/arm-smmu.c | 13 | ||||
| -rw-r--r-- | include/linux/intel-iommu.h | 2 |
3 files changed, 15 insertions, 7 deletions
diff --git a/MAINTAINERS b/MAINTAINERS index 5678de36d9b3..8a0cbf3cf2c8 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -4476,6 +4476,13 @@ L: linux-serial@vger.kernel.org | |||
| 4476 | S: Maintained | 4476 | S: Maintained |
| 4477 | F: drivers/tty/serial/ioc3_serial.c | 4477 | F: drivers/tty/serial/ioc3_serial.c |
| 4478 | 4478 | ||
| 4479 | IOMMU DRIVERS | ||
| 4480 | M: Joerg Roedel <joro@8bytes.org> | ||
| 4481 | L: iommu@lists.linux-foundation.org | ||
| 4482 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/joro/iommu.git | ||
| 4483 | S: Maintained | ||
| 4484 | F: drivers/iommu/ | ||
| 4485 | |||
| 4479 | IP MASQUERADING | 4486 | IP MASQUERADING |
| 4480 | M: Juanjo Ciarlante <jjciarla@raiz.uncu.edu.ar> | 4487 | M: Juanjo Ciarlante <jjciarla@raiz.uncu.edu.ar> |
| 4481 | S: Maintained | 4488 | S: Maintained |
diff --git a/drivers/iommu/arm-smmu.c b/drivers/iommu/arm-smmu.c index f417e89e1e7e..181c9ba929cd 100644 --- a/drivers/iommu/arm-smmu.c +++ b/drivers/iommu/arm-smmu.c | |||
| @@ -377,6 +377,7 @@ struct arm_smmu_cfg { | |||
| 377 | u32 cbar; | 377 | u32 cbar; |
| 378 | pgd_t *pgd; | 378 | pgd_t *pgd; |
| 379 | }; | 379 | }; |
| 380 | #define INVALID_IRPTNDX 0xff | ||
| 380 | 381 | ||
| 381 | #define ARM_SMMU_CB_ASID(cfg) ((cfg)->cbndx) | 382 | #define ARM_SMMU_CB_ASID(cfg) ((cfg)->cbndx) |
| 382 | #define ARM_SMMU_CB_VMID(cfg) ((cfg)->cbndx + 1) | 383 | #define ARM_SMMU_CB_VMID(cfg) ((cfg)->cbndx + 1) |
| @@ -840,7 +841,7 @@ static int arm_smmu_init_domain_context(struct iommu_domain *domain, | |||
| 840 | if (IS_ERR_VALUE(ret)) { | 841 | if (IS_ERR_VALUE(ret)) { |
| 841 | dev_err(smmu->dev, "failed to request context IRQ %d (%u)\n", | 842 | dev_err(smmu->dev, "failed to request context IRQ %d (%u)\n", |
| 842 | root_cfg->irptndx, irq); | 843 | root_cfg->irptndx, irq); |
| 843 | root_cfg->irptndx = -1; | 844 | root_cfg->irptndx = INVALID_IRPTNDX; |
| 844 | goto out_free_context; | 845 | goto out_free_context; |
| 845 | } | 846 | } |
| 846 | 847 | ||
| @@ -869,7 +870,7 @@ static void arm_smmu_destroy_domain_context(struct iommu_domain *domain) | |||
| 869 | writel_relaxed(0, cb_base + ARM_SMMU_CB_SCTLR); | 870 | writel_relaxed(0, cb_base + ARM_SMMU_CB_SCTLR); |
| 870 | arm_smmu_tlb_inv_context(root_cfg); | 871 | arm_smmu_tlb_inv_context(root_cfg); |
| 871 | 872 | ||
| 872 | if (root_cfg->irptndx != -1) { | 873 | if (root_cfg->irptndx != INVALID_IRPTNDX) { |
| 873 | irq = smmu->irqs[smmu->num_global_irqs + root_cfg->irptndx]; | 874 | irq = smmu->irqs[smmu->num_global_irqs + root_cfg->irptndx]; |
| 874 | free_irq(irq, domain); | 875 | free_irq(irq, domain); |
| 875 | } | 876 | } |
| @@ -1857,8 +1858,6 @@ static int arm_smmu_device_dt_probe(struct platform_device *pdev) | |||
| 1857 | goto out_put_parent; | 1858 | goto out_put_parent; |
| 1858 | } | 1859 | } |
| 1859 | 1860 | ||
| 1860 | arm_smmu_device_reset(smmu); | ||
| 1861 | |||
| 1862 | for (i = 0; i < smmu->num_global_irqs; ++i) { | 1861 | for (i = 0; i < smmu->num_global_irqs; ++i) { |
| 1863 | err = request_irq(smmu->irqs[i], | 1862 | err = request_irq(smmu->irqs[i], |
| 1864 | arm_smmu_global_fault, | 1863 | arm_smmu_global_fault, |
| @@ -1876,6 +1875,8 @@ static int arm_smmu_device_dt_probe(struct platform_device *pdev) | |||
| 1876 | spin_lock(&arm_smmu_devices_lock); | 1875 | spin_lock(&arm_smmu_devices_lock); |
| 1877 | list_add(&smmu->list, &arm_smmu_devices); | 1876 | list_add(&smmu->list, &arm_smmu_devices); |
| 1878 | spin_unlock(&arm_smmu_devices_lock); | 1877 | spin_unlock(&arm_smmu_devices_lock); |
| 1878 | |||
| 1879 | arm_smmu_device_reset(smmu); | ||
| 1879 | return 0; | 1880 | return 0; |
| 1880 | 1881 | ||
| 1881 | out_free_irqs: | 1882 | out_free_irqs: |
| @@ -1966,10 +1967,10 @@ static int __init arm_smmu_init(void) | |||
| 1966 | return ret; | 1967 | return ret; |
| 1967 | 1968 | ||
| 1968 | /* Oh, for a proper bus abstraction */ | 1969 | /* Oh, for a proper bus abstraction */ |
| 1969 | if (!iommu_present(&platform_bus_type)); | 1970 | if (!iommu_present(&platform_bus_type)) |
| 1970 | bus_set_iommu(&platform_bus_type, &arm_smmu_ops); | 1971 | bus_set_iommu(&platform_bus_type, &arm_smmu_ops); |
| 1971 | 1972 | ||
| 1972 | if (!iommu_present(&amba_bustype)); | 1973 | if (!iommu_present(&amba_bustype)) |
| 1973 | bus_set_iommu(&amba_bustype, &arm_smmu_ops); | 1974 | bus_set_iommu(&amba_bustype, &arm_smmu_ops); |
| 1974 | 1975 | ||
| 1975 | return 0; | 1976 | return 0; |
diff --git a/include/linux/intel-iommu.h b/include/linux/intel-iommu.h index 78e2ada50cd5..d380c5e68008 100644 --- a/include/linux/intel-iommu.h +++ b/include/linux/intel-iommu.h | |||
| @@ -55,7 +55,7 @@ | |||
| 55 | #define DMAR_IQT_REG 0x88 /* Invalidation queue tail register */ | 55 | #define DMAR_IQT_REG 0x88 /* Invalidation queue tail register */ |
| 56 | #define DMAR_IQ_SHIFT 4 /* Invalidation queue head/tail shift */ | 56 | #define DMAR_IQ_SHIFT 4 /* Invalidation queue head/tail shift */ |
| 57 | #define DMAR_IQA_REG 0x90 /* Invalidation queue addr register */ | 57 | #define DMAR_IQA_REG 0x90 /* Invalidation queue addr register */ |
| 58 | #define DMAR_ICS_REG 0x98 /* Invalidation complete status register */ | 58 | #define DMAR_ICS_REG 0x9c /* Invalidation complete status register */ |
| 59 | #define DMAR_IRTA_REG 0xb8 /* Interrupt remapping table addr register */ | 59 | #define DMAR_IRTA_REG 0xb8 /* Interrupt remapping table addr register */ |
| 60 | 60 | ||
| 61 | #define OFFSET_STRIDE (9) | 61 | #define OFFSET_STRIDE (9) |
