Merge branches 'arm/exynos', 'arm/omap', 'arm/rockchip', 'arm/mediatek', 'arm/smmu...
authorJoerg Roedel <jroedel@suse.de>
Thu, 4 May 2017 16:06:17 +0000 (18:06 +0200)
committerJoerg Roedel <jroedel@suse.de>
Thu, 4 May 2017 16:06:17 +0000 (18:06 +0200)
16 files changed:
1  2  3  4  5  6  7  8  9 
Documentation/admin-guide/kernel-parameters.txt
MAINTAINERS
arch/arm/mm/dma-mapping.c
arch/arm64/mm/dma-mapping.c
drivers/acpi/glue.c
drivers/acpi/scan.c
drivers/iommu/arm-smmu-v3.c
drivers/iommu/arm-smmu.c
drivers/iommu/exynos-iommu.c
drivers/iommu/intel-iommu.c
drivers/iommu/iommu.c
drivers/iommu/iova.c
drivers/iommu/rockchip-iommu.c
include/asm-generic/vmlinux.lds.h
include/linux/dma-iommu.h
include/linux/iommu.h

diff --cc MAINTAINERS
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index abf6496843a617070289377ffad3fd1e119b0aa6,b493c99e17f74de338805167c3ddb104e3354b62,b493c99e17f74de338805167c3ddb104e3354b62,b493c99e17f74de338805167c3ddb104e3354b62,a36e80abf08466f1f8c25a016a991ad28f6372ec,7f522504a876fe935697dd570ac8e99ed9f44816,abf6496843a617070289377ffad3fd1e119b0aa6,b493c99e17f74de338805167c3ddb104e3354b62,abf6496843a617070289377ffad3fd1e119b0aa6..7ec30b08b3bdc285872e0139997a300497450f98
@@@@@@@@@@ -569,49 -569,49 -569,49 -569,49 -573,67 -569,49 -569,49 -569,49 -569,49 +573,67 @@@@@@@@@@ static void __arm_smmu_free_bitmap(unsi
         }
         
         /* Wait for any pending TLB invalidations to complete */
---- ----static void __arm_smmu_tlb_sync(struct arm_smmu_device *smmu)
++++ ++++static void __arm_smmu_tlb_sync(struct arm_smmu_device *smmu,
++++ ++++                               void __iomem *sync, void __iomem *status)
         {
---- ----       int count = 0;
---- ----       void __iomem *gr0_base = ARM_SMMU_GR0(smmu);
---- ----
---- ----       writel_relaxed(0, gr0_base + ARM_SMMU_GR0_sTLBGSYNC);
---- ----       while (readl_relaxed(gr0_base + ARM_SMMU_GR0_sTLBGSTATUS)
---- ----              & sTLBGSTATUS_GSACTIVE) {
---- ----               cpu_relax();
---- ----               if (++count == TLB_LOOP_TIMEOUT) {
---- ----                       dev_err_ratelimited(smmu->dev,
---- ----                       "TLB sync timed out -- SMMU may be deadlocked\n");
---- ----                       return;
++++ ++++       unsigned int spin_cnt, delay;
++++ ++++
++++ ++++       writel_relaxed(0, sync);
++++ ++++       for (delay = 1; delay < TLB_LOOP_TIMEOUT; delay *= 2) {
++++ ++++               for (spin_cnt = TLB_SPIN_COUNT; spin_cnt > 0; spin_cnt--) {
++++ ++++                       if (!(readl_relaxed(status) & sTLBGSTATUS_GSACTIVE))
++++ ++++                               return;
++++ ++++                       cpu_relax();
                        }
---- ----               udelay(1);
++++ ++++               udelay(delay);
                }
----  ---static void arm_smmu_tlb_sync(void *cookie)
++++ ++++       dev_err_ratelimited(smmu->dev,
++++ ++++                           "TLB sync timed out -- SMMU may be deadlocked\n");
     +   }
     +   
----  ---       __arm_smmu_tlb_sync(smmu_domain->smmu);
++++ ++++static void arm_smmu_tlb_sync_global(struct arm_smmu_device *smmu)
++++ ++++{
++++ ++++       void __iomem *base = ARM_SMMU_GR0(smmu);
++++ ++++
++++ ++++       __arm_smmu_tlb_sync(smmu, base + ARM_SMMU_GR0_sTLBGSYNC,
++++ ++++                           base + ARM_SMMU_GR0_sTLBGSTATUS);
++++ ++++}
++++ ++++
++++ ++++static void arm_smmu_tlb_sync_context(void *cookie)
     +   {
     +          struct arm_smmu_domain *smmu_domain = cookie;
++++ ++++       struct arm_smmu_device *smmu = smmu_domain->smmu;
++++ ++++       void __iomem *base = ARM_SMMU_CB(smmu, smmu_domain->cfg.cbndx);
++++ ++++
++++ ++++       __arm_smmu_tlb_sync(smmu, base + ARM_SMMU_CB_TLBSYNC,
++++ ++++                           base + ARM_SMMU_CB_TLBSTATUS);
         }
         
----  ---static void arm_smmu_tlb_inv_context(void *cookie)
     -   static void arm_smmu_tlb_sync(void *cookie)
++++ ++++static void arm_smmu_tlb_sync_vmid(void *cookie)
++++  +++{
++++  +++       struct arm_smmu_domain *smmu_domain = cookie;
     -          __arm_smmu_tlb_sync(smmu_domain->smmu);
++++ ++++
++++ ++++       arm_smmu_tlb_sync_global(smmu_domain->smmu);
++++  +++}
++++  +++
     -   static void arm_smmu_tlb_inv_context(void *cookie)
++++ ++++static void arm_smmu_tlb_inv_context_s1(void *cookie)
         {
                struct arm_smmu_domain *smmu_domain = cookie;
                struct arm_smmu_cfg *cfg = &smmu_domain->cfg;
---- ----       struct arm_smmu_device *smmu = smmu_domain->smmu;
---- ----       bool stage1 = cfg->cbar != CBAR_TYPE_S2_TRANS;
---- ----       void __iomem *base;
++++ ++++       void __iomem *base = ARM_SMMU_CB(smmu_domain->smmu, cfg->cbndx);
         
---- ----       if (stage1) {
---- ----               base = ARM_SMMU_CB_BASE(smmu) + ARM_SMMU_CB(smmu, cfg->cbndx);
---- ----               writel_relaxed(ARM_SMMU_CB_ASID(smmu, cfg),
---- ----                              base + ARM_SMMU_CB_S1_TLBIASID);
---- ----       } else {
---- ----               base = ARM_SMMU_GR0(smmu);
---- ----               writel_relaxed(ARM_SMMU_CB_VMID(smmu, cfg),
---- ----                              base + ARM_SMMU_GR0_TLBIVMID);
---- ----       }
++++ ++++       writel_relaxed(cfg->asid, base + ARM_SMMU_CB_S1_TLBIASID);
++++ ++++       arm_smmu_tlb_sync_context(cookie);
++++ ++++}
++++  +++
     -          __arm_smmu_tlb_sync(smmu);
++++ ++++static void arm_smmu_tlb_inv_context_s2(void *cookie)
++++ ++++{
++++ ++++       struct arm_smmu_domain *smmu_domain = cookie;
++++ ++++       struct arm_smmu_device *smmu = smmu_domain->smmu;
++++ ++++       void __iomem *base = ARM_SMMU_GR0(smmu);
     +   
----  ---       __arm_smmu_tlb_sync(smmu);
++++ ++++       writel_relaxed(smmu_domain->cfg.vmid, base + ARM_SMMU_GR0_TLBIVMID);
++++ ++++       arm_smmu_tlb_sync_global(smmu);
         }
         
         static void arm_smmu_tlb_inv_range_nosync(unsigned long iova, size_t size,
@@@@@@@@@@ -2180,22 -2180,22 -2180,22 -2180,22 -2260,22 -2199,31 -2180,22 -2180,22 -2180,22 +2279,31 @@@@@@@@@@ static int arm_smmu_device_probe(struc
                arm_smmu_device_reset(smmu);
                arm_smmu_test_smr_masks(smmu);
         
----- ---       /* Oh, for a proper bus abstraction */
----- ---       if (!iommu_present(&platform_bus_type))
----- ---               bus_set_iommu(&platform_bus_type, &arm_smmu_ops);
----- ---#ifdef CONFIG_ARM_AMBA
----- ---       if (!iommu_present(&amba_bustype))
----- ---               bus_set_iommu(&amba_bustype, &arm_smmu_ops);
----- ---#endif
----- ---#ifdef CONFIG_PCI
----- ---       if (!iommu_present(&pci_bus_type)) {
----- ---               pci_request_acs();
----- ---               bus_set_iommu(&pci_bus_type, &arm_smmu_ops);
----- ---       }
----- ---#endif
+++++ +++       /*
+++++ +++        * For ACPI and generic DT bindings, an SMMU will be probed before
+++++ +++        * any device which might need it, so we want the bus ops in place
+++++ +++        * ready to handle default domain setup as soon as any SMMU exists.
+++++ +++        */
+++++ +++       if (!using_legacy_binding)
+++++ +++               arm_smmu_bus_init();
+++++ +++
++++  +++       return 0;
++++  +++}
++++  +++
+++++ +++/*
+++++ +++ * With the legacy DT binding in play, though, we have no guarantees about
+++++ +++ * probe order, but then we're also not doing default domains, so we can
+++++ +++ * delay setting bus ops until we're sure every possible SMMU is ready,
+++++ +++ * and that way ensure that no add_device() calls get missed.
+++++ +++ */
+++++ +++static int arm_smmu_legacy_bus_init(void)
+++++ +++{
+++++ +++       if (using_legacy_binding)
+++++ +++               arm_smmu_bus_init();
    +           return 0;
    +    }
+++++ +++device_initcall_sync(arm_smmu_legacy_bus_init);
    +    
         static int arm_smmu_device_remove(struct platform_device *pdev)
         {
                struct arm_smmu_device *smmu = platform_get_drvdata(pdev);
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index 0968d13b388591ae02b37f9dda0fe7a498cc7475,7cdfe167074f873a71dd51e04da3304864d2f063,0968d13b388591ae02b37f9dda0fe7a498cc7475,0968d13b388591ae02b37f9dda0fe7a498cc7475,7cdfe167074f873a71dd51e04da3304864d2f063,9faa26c41c146015a56b419ae2ced050535e7c5c,0968d13b388591ae02b37f9dda0fe7a498cc7475,143db9c523e25f38488bd43302b82f316e3124a9,0968d13b388591ae02b37f9dda0fe7a498cc7475..d7d0a451508b7d57e6513206f41038d807cb1aec
          */
         #ifndef RO_AFTER_INIT_DATA
         #define RO_AFTER_INIT_DATA                                             \
- -- -- -       __start_data_ro_after_init = .;                                 \
 -  -           __start_ro_after_init = .;                                      \
+++++++ +       VMLINUX_SYMBOL(__start_ro_after_init) = .;                      \
                *(.data..ro_after_init)                                         \
- -- -- -       __end_data_ro_after_init = .;
 -  -           __end_ro_after_init = .;
+++++++ +       VMLINUX_SYMBOL(__end_ro_after_init) = .;
         #endif
         
         /*
Simple merge
Simple merge