/linux/arch/sparc/kernel/ |
H A D | iommu.c | 2 /* iommu.c: Generic sparc64 IOMMU support. 15 #include <linux/iommu-helper.h> 17 #include <asm/iommu-common.h> 23 #include <asm/iommu.h> 49 /* Must be invoked under the IOMMU lock. */ 52 struct iommu *iommu = container_of(iommu_map_table, struct iommu, tbl); in iommu_flushall() local 53 if (iommu->iommu_flushinv) { in iommu_flushall() 54 iommu_write(iommu->iommu_flushinv, ~(u64)0); in iommu_flushall() 59 tag = iommu->iommu_tags; in iommu_flushall() 66 (void) iommu_read(iommu->write_complete_reg); in iommu_flushall() [all …]
|
H A D | iommu-common.c | 3 * IOMMU mmap management and range allocation functions. 4 * Based almost entirely upon the powerpc iommu allocator. 10 #include <linux/iommu-helper.h> 13 #include <asm/iommu-common.h> 19 static inline bool need_flush(struct iommu_map_table *iommu) in need_flush() argument 21 return ((iommu->flags & IOMMU_NEED_FLUSH) != 0); in need_flush() 24 static inline void set_flush(struct iommu_map_table *iommu) in set_flush() argument 26 iommu->flags |= IOMMU_NEED_FLUSH; in set_flush() 29 static inline void clear_flush(struct iommu_map_table *iommu) in clear_flush() argument 31 iommu->flags &= ~IOMMU_NEED_FLUSH; in clear_flush() [all …]
|
/linux/drivers/iommu/ |
H A D | sun50i-iommu.c | 14 #include <linux/iommu.h> 29 #include "iommu-pages.h" 101 struct iommu_device iommu; member 103 /* Lock to modify the IOMMU registers */ 125 struct sun50i_iommu *iommu; member 138 static u32 iommu_read(struct sun50i_iommu *iommu, u32 offset) in iommu_read() argument 140 return readl(iommu->base + offset); in iommu_read() 143 static void iommu_write(struct sun50i_iommu *iommu, u32 offset, u32 value) in iommu_write() argument 145 writel(value, iommu->base + offset); in iommu_write() 149 * The Allwinner H6 IOMMU uses a 2-level page table. [all …]
|
H A D | msm_iommu.c | 18 #include <linux/iommu.h> 54 static int __enable_clocks(struct msm_iommu_dev *iommu) in __enable_clocks() argument 58 ret = clk_enable(iommu->pclk); in __enable_clocks() 62 if (iommu->clk) { in __enable_clocks() 63 ret = clk_enable(iommu->clk); in __enable_clocks() 65 clk_disable(iommu->pclk); in __enable_clocks() 71 static void __disable_clocks(struct msm_iommu_dev *iommu) in __disable_clocks() argument 73 if (iommu->clk) in __disable_clocks() 74 clk_disable(iommu->clk); in __disable_clocks() 75 clk_disable(iommu->pclk); in __disable_clocks() [all …]
|
H A D | rockchip-iommu.c | 3 * IOMMU API for Rockchip 17 #include <linux/iommu.h> 29 #include "iommu-pages.h" 94 /* list of clocks required by IOMMU */ 115 struct iommu_device iommu; member 117 struct iommu_domain *domain; /* domain to which iommu is attached */ 121 struct device_link *link; /* runtime PM link from IOMMU to master */ 122 struct rk_iommu *iommu; member 143 * The Rockchip rk3288 iommu uses a 2-level page table. 152 * Each iommu device has a MMU_DTE_ADDR register that contains the physical [all …]
|
H A D | iommu-sysfs.c | 3 * IOMMU sysfs class support 10 #include <linux/iommu.h> 16 * As devices are added to the IOMMU, we'll add links to the group. 38 .name = "iommu", 50 * Init the struct device for the IOMMU. IOMMU specific attributes can 52 * IOMMU type. 54 int iommu_device_sysfs_add(struct iommu_device *iommu, in iommu_device_sysfs_add() argument 62 iommu->dev = kzalloc(sizeof(*iommu->dev), GFP_KERNEL); in iommu_device_sysfs_add() 63 if (!iommu->dev) in iommu_device_sysfs_add() 66 device_initialize(iommu->dev); in iommu_device_sysfs_add() [all …]
|
H A D | Kconfig | 15 bool "IOMMU Hardware Support" 26 menu "Generic IOMMU Pagetable Support" 60 for 64KB pages/16MB supersections if indicated by the IOMMU driver. 86 bool "Export IOMMU internals in DebugFS" 89 Allows exposure of IOMMU device internals. This option enables 90 the use of debugfs by IOMMU drivers as required. Devices can, 91 at initialization time, cause the IOMMU code to create a top-level 92 debug/iommu directory, and then populate a subdirectory with 96 prompt "IOMMU default domain type" 101 Choose the type of IOMMU domain used to manage DMA API usage by [all …]
|
/linux/Documentation/devicetree/bindings/pci/ |
H A D | pci-iommu.txt | 2 relationship between PCI(e) devices and IOMMU(s). 17 Requester ID. While a given PCI device can only master through one IOMMU, a 18 root complex may split masters across a set of IOMMUs (e.g. with one IOMMU per 22 and a mechanism is required to map from a PCI device to its IOMMU and sideband 25 For generic IOMMU bindings, see 26 Documentation/devicetree/bindings/iommu/iommu.txt. 35 - iommu-map: Maps a Requester ID to an IOMMU and associated IOMMU specifier 39 (rid-base,iommu,iommu-base,length). 42 the listed IOMMU, with the IOMMU specifier (r - rid-base + iommu-base). 44 - iommu-map-mask: A mask to be applied to each Requester ID prior to being [all …]
|
/linux/drivers/iommu/intel/ |
H A D | svm.c | 22 #include "iommu.h" 25 #include "../iommu-pages.h" 30 int intel_svm_enable_prq(struct intel_iommu *iommu) in intel_svm_enable_prq() argument 35 iommu->prq = iommu_alloc_pages_node(iommu->node, GFP_KERNEL, PRQ_ORDER); in intel_svm_enable_prq() 36 if (!iommu->prq) { in intel_svm_enable_prq() 37 pr_warn("IOMMU: %s: Failed to allocate page request queue\n", in intel_svm_enable_prq() 38 iommu->name); in intel_svm_enable_prq() 42 irq = dmar_alloc_hwirq(IOMMU_IRQ_ID_OFFSET_PRQ + iommu->seq_id, iommu->node, iommu); in intel_svm_enable_prq() 44 pr_err("IOMMU: %s: Failed to create IRQ vector for page request queue\n", in intel_svm_enable_prq() 45 iommu->name); in intel_svm_enable_prq() [all …]
|
H A D | irq_remapping.c | 24 #include "iommu.h" 26 #include "../iommu-pages.h" 35 struct intel_iommu *iommu; member 42 struct intel_iommu *iommu; member 49 struct intel_iommu *iommu; member 77 * ->iommu->register_lock 86 static void iommu_disable_irq_remapping(struct intel_iommu *iommu); 90 static bool ir_pre_enabled(struct intel_iommu *iommu) in ir_pre_enabled() argument 92 return (iommu->flags & VTD_FLAG_IRQ_REMAP_PRE_ENABLED); in ir_pre_enabled() 95 static void clear_ir_pre_enabled(struct intel_iommu *iommu) in clear_ir_pre_enabled() argument [all …]
|
H A D | cap_audit.c | 3 * cap_audit.c - audit iommu capabilities for boot time and hot plug 13 #include "iommu.h" 74 static int cap_audit_hotplug(struct intel_iommu *iommu, enum cap_audit_type type) in cap_audit_hotplug() argument 81 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, pi_support, CAP_PI_MASK); in cap_audit_hotplug() 82 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, ecap, eim_support, ECAP_EIM_MASK); in cap_audit_hotplug() 86 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, fl5lp_support, CAP_FL5LP_MASK); in cap_audit_hotplug() 87 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, fl1gp_support, CAP_FL1GP_MASK); in cap_audit_hotplug() 88 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, read_drain, CAP_RD_MASK); in cap_audit_hotplug() 89 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, write_drain, CAP_WD_MASK); in cap_audit_hotplug() 90 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, pgsel_inv, CAP_PSI_MASK); in cap_audit_hotplug() [all …]
|
H A D | pasid.c | 15 #include <linux/iommu.h> 21 #include "iommu.h" 23 #include "../iommu-pages.h" 26 * Intel IOMMU system wide PASID name space: 63 dir = iommu_alloc_pages_node(info->iommu->node, GFP_KERNEL, order); in intel_pasid_alloc_table() 74 if (!ecap_coherent(info->iommu->ecap)) in intel_pasid_alloc_table() 151 entries = iommu_alloc_page_node(info->iommu->node, GFP_ATOMIC); in intel_pasid_get_entry() 167 if (!ecap_coherent(info->iommu->ecap)) { in intel_pasid_get_entry() 195 pasid_cache_invalidation_with_pasid(struct intel_iommu *iommu, in pasid_cache_invalidation_with_pasid() argument 206 qi_submit_sync(iommu, &desc, 1, 0); in pasid_cache_invalidation_with_pasid() [all …]
|
H A D | iommu.c | 27 #include "iommu.h" 28 #include "../dma-iommu.h" 30 #include "../iommu-pages.h" 120 * Looks up an IOMMU-probed device using its source ID. 126 * released by the iommu subsystem after being returned. The caller 130 struct device *device_rbtree_find(struct intel_iommu *iommu, u16 rid) in device_rbtree_find() argument 136 spin_lock_irqsave(&iommu->device_rbtree_lock, flags); in device_rbtree_find() 137 node = rb_find(&rid, &iommu->device_rbtree, device_rid_cmp_key); in device_rbtree_find() 140 spin_unlock_irqrestore(&iommu->device_rbtree_lock, flags); in device_rbtree_find() 145 static int device_rbtree_insert(struct intel_iommu *iommu, in device_rbtree_insert() argument [all …]
|
H A D | dmar.c | 28 #include <linux/iommu.h> 33 #include "iommu.h" 35 #include "../iommu-pages.h" 68 static void free_iommu(struct intel_iommu *iommu); 462 if (dmaru->iommu) in dmar_free_drhd() 463 free_iommu(dmaru->iommu); in dmar_free_drhd() 502 drhd->iommu->node = node; in dmar_parse_one_rhsa() 767 pr_warn("No IOMMU scope found for ANDD enumeration ID %d (%s)\n", in dmar_acpi_insert_dev_scope() 940 x86_init.iommu.iommu_init = intel_iommu_init; in detect_intel_iommu() 953 static void unmap_iommu(struct intel_iommu *iommu) in unmap_iommu() argument [all …]
|
H A D | cache.c | 13 #include <linux/iommu.h> 18 #include "iommu.h" 24 struct intel_iommu *iommu, struct device *dev, in cache_tage_match() argument 34 return tag->iommu == iommu; in cache_tage_match() 48 struct intel_iommu *iommu = info->iommu; in cache_tag_assign() local 57 tag->iommu = iommu; in cache_tag_assign() 65 tag->dev = iommu->iommu.dev; in cache_tag_assign() 69 if (cache_tage_match(temp, did, iommu, dev, pasid, type)) { in cache_tag_assign() 90 struct intel_iommu *iommu = info->iommu; in cache_tag_unassign() local 96 if (cache_tage_match(tag, did, iommu, dev, pasid, type)) { in cache_tag_unassign() [all …]
|
H A D | debugfs.c | 17 #include "iommu.h" 116 struct intel_iommu *iommu; in iommu_regset_show() local 122 for_each_active_iommu(iommu, drhd) { in iommu_regset_show() 124 seq_puts(m, "IOMMU: Invalid base address\n"); in iommu_regset_show() 129 seq_printf(m, "IOMMU: %s Register Base Address: %llx\n", in iommu_regset_show() 130 iommu->name, drhd->reg_base_addr); in iommu_regset_show() 136 raw_spin_lock_irqsave(&iommu->register_lock, flag); in iommu_regset_show() 138 value = dmar_readl(iommu->reg + iommu_regs_32[i].offset); in iommu_regset_show() 144 value = dmar_readq(iommu->reg + iommu_regs_64[i].offset); in iommu_regset_show() 149 raw_spin_unlock_irqrestore(&iommu->register_lock, flag); in iommu_regset_show() [all …]
|
/linux/drivers/iommu/amd/ |
H A D | init.c | 20 #include <linux/amd-iommu.h> 26 #include <asm/iommu.h> 39 #include "../iommu-pages.h" 99 * structure describing one IOMMU in the ACPI table. Typically followed by one 119 * A device entry describing which devices a specific IOMMU translates and 137 * An AMD IOMMU memory definition structure. It defines things like exclusion 198 * AMD IOMMU allows up to 2^16 different protection domains. This is a bitmap 238 bool translation_pre_enabled(struct amd_iommu *iommu) in translation_pre_enabled() argument 240 return (iommu->flags & AMD_IOMMU_FLAG_TRANS_PRE_ENABLED); in translation_pre_enabled() 243 static void clear_translation_pre_enabled(struct amd_iommu *iommu) in clear_translation_pre_enabled() argument [all …]
|
H A D | iommu.c | 21 #include <linux/iommu-helper.h> 23 #include <linux/amd-iommu.h> 37 #include <asm/iommu.h> 43 #include "../dma-iommu.h" 45 #include "../iommu-pages.h" 67 * general struct to manage commands send to an IOMMU 77 static void set_dte_entry(struct amd_iommu *iommu, 138 struct dev_table_entry *get_dev_table(struct amd_iommu *iommu) in get_dev_table() argument 141 struct amd_iommu_pci_seg *pci_seg = iommu->pci_seg; in get_dev_table() 167 /* Writes the specific IOMMU for a device into the PCI segment rlookup table */ [all …]
|
/linux/Documentation/devicetree/bindings/iommu/ |
H A D | iommu.txt | 5 IOMMU device node: 8 An IOMMU can provide the following services: 19 through the IOMMU and faulting when encountering accesses to unmapped 29 IOMMUs can be single-master or multiple-master. Single-master IOMMU devices 31 master IOMMU devices can translate accesses from more than one master. 33 The device tree node of the IOMMU device's parent bus must contain a valid 35 IOMMU maps to memory. An empty "dma-ranges" property means that there is a 36 1:1 mapping from IOMMU to memory. 40 - #iommu-cells: The number of cells in an IOMMU specifier needed to encode an 43 The meaning of the IOMMU specifier is defined by the device tree binding of [all …]
|
H A D | qcom,iommu.yaml | 4 $id: http://devicetree.org/schemas/iommu/qcom,iommu.yaml# 7 title: Qualcomm Technologies legacy IOMMU implementations 14 a similar looking IOMMU, but without access to the global register space 23 - qcom,msm8916-iommu 24 - qcom,msm8953-iommu 25 - const: qcom,msm-iommu-v1 28 - qcom,msm8953-iommu 29 - qcom,msm8976-iommu 30 - const: qcom,msm-iommu-v2 34 - description: Clock required for IOMMU register group access [all …]
|
H A D | ti,omap-iommu.txt | 1 OMAP2+ IOMMU 5 "ti,omap2-iommu" for OMAP2/OMAP3 IOMMU instances 6 "ti,omap4-iommu" for OMAP4/OMAP5 IOMMU instances 7 "ti,dra7-dsp-iommu" for DRA7xx DSP IOMMU instances 8 "ti,dra7-iommu" for DRA7xx IOMMU instances 9 - ti,hwmods : Name of the hwmod associated with the IOMMU instance 11 - interrupts : Interrupt specifier for the IOMMU instance 12 - #iommu-cells : Should be 0. OMAP IOMMUs are all "single-master" devices, 16 Documentation/devicetree/bindings/iommu/iommu.txt 21 - ti,iommu-bus-err-back : Indicates the IOMMU instance supports throwing [all …]
|
/linux/drivers/vfio/ |
H A D | vfio_iommu_type1.c | 3 * VFIO: IOMMU DMA mapping support for Type1 IOMMU 12 * We arbitrarily define a Type1 IOMMU as one matching the below code. 13 * It could be called the x86 IOMMU as it's designed for AMD-Vi & Intel 15 * implementing a similar IOMMU could make use of this. We expect the 16 * IOMMU to support the IOMMU API and have few to no restrictions around 17 * the IOVA range that can be mapped. The Type1 IOMMU is currently 19 * userspace pages pinned into memory. We also assume devices and IOMMU 20 * domains are PCI based as the IOMMU API is still centered around a 28 #include <linux/iommu.h> 44 #define DRIVER_DESC "Type1 IOMMU driver for VFIO" [all …]
|
/linux/arch/powerpc/platforms/cell/ |
H A D | iommu.c | 3 * IOMMU implementation for Cell Broadband Processor Architecture 24 #include <asm/iommu.h> 95 /* IOMMU sizing */ 104 struct cbe_iommu *iommu; member 131 static void invalidate_tce_cache(struct cbe_iommu *iommu, unsigned long *pte, in invalidate_tce_cache() argument 138 reg = iommu->xlate_regs + IOC_IOPT_CacheInvd; in invalidate_tce_cache() 195 invalidate_tce_cache(window->iommu, io_pte, npages); in tce_build_cell() 218 __pa(window->iommu->pad_page) | in tce_free_cell() 229 invalidate_tce_cache(window->iommu, io_pte, npages); in tce_free_cell() 235 struct cbe_iommu *iommu = data; in ioc_interrupt() local [all …]
|
/linux/Documentation/ABI/testing/ |
H A D | debugfs-intel-iommu | 1 What: /sys/kernel/debug/iommu/intel/iommu_regset 5 This file dumps all the register contents for each IOMMU device. 11 $ sudo cat /sys/kernel/debug/iommu/intel/iommu_regset 13 IOMMU: dmar0 Register Base Address: 26be37000 24 IOMMU: dmar1 Register Base Address: fed90000 35 IOMMU: dmar2 Register Base Address: fed91000 46 What: /sys/kernel/debug/iommu/intel/ir_translation_struct 57 $ sudo cat /sys/kernel/debug/iommu/intel/ir_translation_struct 59 Remapped Interrupt supported on IOMMU: dmar0 66 Remapped Interrupt supported on IOMMU: dmar1 [all …]
|
/linux/arch/sparc/mm/ |
H A D | iommu.c | 3 * iommu.c: IOMMU specific routines for memory management. 26 #include <asm/iommu.h> 60 struct iommu_struct *iommu; in sbus_iommu_init() local 67 iommu = kmalloc(sizeof(struct iommu_struct), GFP_KERNEL); in sbus_iommu_init() 68 if (!iommu) { in sbus_iommu_init() 69 prom_printf("Unable to allocate iommu structure\n"); in sbus_iommu_init() 73 iommu->regs = of_ioremap(&op->resource[0], 0, PAGE_SIZE * 3, in sbus_iommu_init() 75 if (!iommu->regs) { in sbus_iommu_init() 76 prom_printf("Cannot map IOMMU registers\n"); in sbus_iommu_init() 80 control = sbus_readl(&iommu->regs->control); in sbus_iommu_init() [all …]
|