diff options
| author | Jean-Philippe Brucker <jean-philippe@linaro.org> | 2021-01-22 16:10:56 +0100 | 
|---|---|---|
| committer | Will Deacon <will@kernel.org> | 2021-01-22 15:44:32 +0000 | 
| commit | 9111aebf770d6a6c9fcfd6301da4a0025f2d610f (patch) | |
| tree | 63506115873570e9f7afea2b183fbcde607767cf /lib/dynamic_debug.c | |
| parent | 51d113c3be09ff5b916576b1109daf413549cacc (diff) | |
iommu/arm-smmu-v3: Add support for VHE
ARMv8.1 extensions added Virtualization Host Extensions (VHE), which allow
to run a host kernel at EL2. When using normal DMA, Device and CPU address
spaces are dissociated, and do not need to implement the same
capabilities, so VHE hasn't been used in the SMMU until now.
With shared address spaces however, ASIDs are shared between MMU and SMMU,
and broadcast TLB invalidations issued by a CPU are taken into account by
the SMMU. TLB entries on both sides need to have identical exception level
in order to be cleared with a single invalidation.
When the CPU is using VHE, enable VHE in the SMMU for all STEs. Normal DMA
mappings will need to use TLBI_EL2 commands instead of TLBI_NH, but
shouldn't be otherwise affected by this change.
Acked-by: Will Deacon <will@kernel.org>
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Signed-off-by: Jean-Philippe Brucker <jean-philippe@linaro.org>
Link: https://lore.kernel.org/r/20210122151054.2833521-4-jean-philippe@linaro.org
Signed-off-by: Will Deacon <will@kernel.org>
Diffstat (limited to 'lib/dynamic_debug.c')
0 files changed, 0 insertions, 0 deletions
