diff options
author | Hiroshi DOYU <hdoyu@nvidia.com> | 2012-03-15 12:10:17 +0200 |
---|---|---|
committer | Varun Colbert <vcolbert@nvidia.com> | 2012-08-01 17:48:22 -0700 |
commit | b8f610d8a591d0287d8a996915b3dfae6d8672da (patch) | |
tree | 514c00049e91f7872e2d097e0a5fe2ec7b1a300a | |
parent | b147a3da3e867fc4279fec7fa59655f1eebbe6d6 (diff) |
iommu/tegra: smmu: Introduce TEGRA_IOMMU_SMMU_LINEAR
IOVA liner mapping for RAM can be removed with this config
disabled. This CONFIG_TEGRA_IOMMU_SMMU_LINEAR will be removed
eventually. All IOMMU'able drivers should support DMA API correctly
during transition period. phys_to_virt() won't be used with IOMMU'able
H/W.
Change-Id: I0d6f86cf9974a3d2e9ef1c5286461f2ea2cd1918
Signed-off-by: Hiroshi DOYU <hdoyu@nvidia.com>
Reviewed-on: http://git-master/r/118708
Reviewed-by: Varun Colbert <vcolbert@nvidia.com>
Tested-by: Varun Colbert <vcolbert@nvidia.com>
-rw-r--r-- | drivers/iommu/Kconfig | 11 | ||||
-rw-r--r-- | drivers/iommu/tegra-smmu.c | 11 |
2 files changed, 20 insertions, 2 deletions
diff --git a/drivers/iommu/Kconfig b/drivers/iommu/Kconfig index 3bd9fff5c589..b736809102df 100644 --- a/drivers/iommu/Kconfig +++ b/drivers/iommu/Kconfig @@ -162,4 +162,15 @@ config TEGRA_IOMMU_SMMU space through the SMMU (System Memory Management Unit) hardware included on Tegra SoCs. +config TEGRA_IOMMU_SMMU_LINEAR + bool "Physical RAM IOVA Liner Mapping Support" + depends on TEGRA_IOMMU_SMMU + default y + help + Enables support for linear mapping between physical address + and IO virtual address for RAM. With this enabled, H/W can + expect virt_to_phys() to work even if it's behined the + IOMMU'able bus. Otherwise DMA API should be used correctly + in device drivers. + endif # IOMMU_SUPPORT diff --git a/drivers/iommu/tegra-smmu.c b/drivers/iommu/tegra-smmu.c index 915763c748f1..780a77b8a219 100644 --- a/drivers/iommu/tegra-smmu.c +++ b/drivers/iommu/tegra-smmu.c @@ -183,10 +183,17 @@ enum { #define _PDE_ATTR (_READABLE | _WRITABLE | _NONSECURE) #define _PDE_ATTR_N (_PDE_ATTR | _PDE_NEXT) -#define _PDE_VACANT(pdn) (((pdn) << 10) | _PDE_ATTR) +#define _PDE_VACANT(pdn) (0) #define _PTE_ATTR (_READABLE | _WRITABLE | _NONSECURE) -#define _PTE_VACANT(addr) (((addr) >> SMMU_PAGE_SHIFT) | _PTE_ATTR) +#define _PTE_VACANT(addr) (0) + +#ifdef CONFIG_TEGRA_IOMMU_SMMU_LINEAR +#undef _PDE_VACANT(pdn) +#undef _PTE_VACANT(addr) +#define _PDE_VACANT(pdn) (((pdn) << 10) | _PDE_ATTR) +#define _PTE_VACANT(addr) (((addr) >> SMMU_PAGE_SHIFT) | _PTE_ATTR) +#endif #define SMMU_MK_PDIR(page, attr) \ ((page_to_phys(page) >> SMMU_PDIR_SHIFT) | (attr)) |