[PATCH v2 00/19] MT6779 IOMMU SUPPORT

From: Chao Hao
Date: Sun Jan 05 2020 - 05:46:33 EST



This patchset adds mt6779 iommu support and adjusts mtk iommu software architecture mainly.
1. Add mt6779 basic function, such as smi_larb port define, registers define and so on.
2. In addition, this patchset will adjust current mtk iommu SW architecture mainly to adapt all the mtk platforms:
Firstly, mt6779 iommu can support more HW modules, but some modules have special requirements for iova region,
for example, CCU only can access 0x4000_0000~0x47ff_ffff, VPU only can access 0x7da0_0000~0x7fbf_ffff. Current
architecture only support one iommu domain(include 0~4GB), all the modules allocate iova from 0~4GB region, so
it doesn't ensure to allocate expected iova region for special module(CCU and VPU). In order to resolve the problem,
we will create different iommu domains for special module, and every domain can include iova region which module needs.
Secondly, all the iommus share one page table for current architecture by "mtk_iommu_get_m4u_data", to make the
architecture look clearly, we will create a global page table firstly(mtk_iommu_pgtable), and all the iommus can
use it. One page table can include 4GB iova space, so multiple iommu domains are created based on the same page table.
New SW architecture diagram is as below:

iommu0 iommu1
| |
----------
|
mtk_iommu_pgtable
|
------------------------------------------
| | |
mtk_iommu_domain1 mtk_iommu_domain2 mtk_iommu_domain3
| | |
iommu_group1 iommu_group2 iommu_group3
| | |
iommu_domain1 iommu_domain2 iommu_domain3
| | |
iova region1(normal) iova region2(CCU) iova region3(VPU)

change notes:
v2:
1. Rebase on v5.5-rc1.
2. Delete M4U_PORT_UNKNOWN define because of not use it.
3. Correct coding format.
4. Rename offset=0x48 register.
5. Split "iommu/mediatek: Add mt6779 IOMMU basic support(patch v1)" to several patches(patch v2).

v1:
http://lists.infradead.org/pipermail/linux-mediatek/2019-November/024567.html


Chao Hao (19):
dt-bindings: mediatek: Add bindings for MT6779
iommu/mediatek: Add m4u1_mask to distinguish m4u_id
iommu/mediatek: Extend larb_remap to larb_remap[2]
iommu/mediatek: Rename offset=0x48 register
iommu/mediatek: Put inv_sel_reg in the plat_data for preparing add
0x2c support in mt6779
iommu/mediatek: Add new flow to get SUB_COMMON ID in translation fault
iommu/mediatek: Add REG_MMU_WR_LEN reg define prepare for mt6779
iommu/mediatek: Add mt6779 basic support
iommu/mediatek: Add mtk_iommu_pgtable structure
iommu/mediatek: Remove mtk_iommu_domain_finalise
iommu/mediatek: Remove pgtable info in mtk_iommu_domain
iommu/mediatek: Change get the way of m4u_group
iommu/mediatek: Add smi_larb info about device
iommu/mediatek: Add mtk_domain_data structure
iommu/mediatek: Remove the usage of m4u_dom variable
iommu/mediatek: Remove mtk_iommu_get_m4u_data api
iommu/mediatek: Add iova reserved function
iommu/mediatek: Change single domain to multiple domains
iommu/mediatek: Add multiple mtk_iommu_domain support for mt6779

.../bindings/iommu/mediatek,iommu.txt | 2 +
drivers/iommu/mtk_iommu.c | 493 +++++++++++++++---
drivers/iommu/mtk_iommu.h | 50 +-
include/dt-bindings/memory/mt6779-larb-port.h | 215 ++++++++
4 files changed, 683 insertions(+), 77 deletions(-)

--
2.18.0