Home
last modified time | relevance | path

Searched refs:iommu (Results 1 – 25 of 364) sorted by relevance

12345678910>>...15

/linux/drivers/iommu/amd/
H A Dinit.c293 iommu->index, iommu->pci_seg->id, in get_global_efr()
1631 if (iommu->iommu.dev) { in free_sysfs()
1632 iommu_device_unregister(&iommu->iommu); in free_sysfs()
1633 iommu_device_sysfs_remove(&iommu->iommu); in free_sysfs()
1746 amd_iommus[iommu->index] = iommu; in init_iommu_one()
1845 iommu->pci_seg->rlookup_table[iommu->devid] = NULL; in init_iommu_one_late()
2049 BUG_ON(iommu->iommu.max_pasids & ~PASID_MASK); in iommu_init_pci()
2107 iommu->stored_l2[i] = iommu_read_l2(iommu, i); in iommu_init_pci()
2113 ret = iommu_device_sysfs_add(&iommu->iommu, &iommu->dev->dev, in iommu_init_pci()
2688 iommu_write_l2(iommu, i, iommu->stored_l2[i]); in iommu_apply_resume_quirks()
[all …]
H A Dppr.c22 iommu->ppr_log = iommu_alloc_4k_pages(iommu, GFP_KERNEL | __GFP_ZERO, in amd_iommu_alloc_ppr_log()
31 if (iommu->ppr_log == NULL) in amd_iommu_enable_ppr_log()
83 struct device *dev = iommu->iommu.dev; in ppr_is_valid()
166 if (iommu->ppr_log == NULL) in amd_iommu_poll_ppr_log()
222 if (iommu->iopf_queue) in amd_iommu_iopf_init()
225 snprintf(iommu->iopfq_name, sizeof(iommu->iopfq_name), "amdvi-%#x", in amd_iommu_iopf_init()
226 PCI_SEG_DEVID_TO_SBDF(iommu->pci_seg->id, iommu->devid)); in amd_iommu_iopf_init()
228 iommu->iopf_queue = iopf_queue_alloc(iommu->iopfq_name); in amd_iommu_iopf_init()
229 if (!iommu->iopf_queue) in amd_iommu_iopf_init()
239 iommu->iopf_queue = NULL; in amd_iommu_iopf_uninit()
[all …]
H A Diommu.c725 struct device *dev = iommu->iommu.dev; in iommu_print_event()
1186 iommu->cmd_buf_head = readl(iommu->mmio_base + in __iommu_queue_command_sync()
2177 if (!iommu->iommu.ops) in amd_iommu_probe_device()
2181 return &iommu->iommu; in amd_iommu_probe_device()
2190 iommu_dev = &iommu->iommu; in amd_iommu_probe_device()
3375 struct amd_iommu *iommu = data->iommu; in irq_remapping_prepare_irte() local
3508 data->iommu = iommu; in irq_remapping_alloc()
3562 struct amd_iommu *iommu = data->iommu; in irq_remapping_activate() local
3579 struct amd_iommu *iommu = data->iommu; in irq_remapping_deactivate() local
3604 return iommu && iommu->ir_domain == d; in irq_remapping_select()
[all …]
H A Damd_iommu.h24 void amd_iommu_restart_ga_log(struct amd_iommu *iommu);
25 void amd_iommu_restart_ppr_log(struct amd_iommu *iommu);
27 void iommu_feature_enable(struct amd_iommu *iommu, u8 bit);
28 void *__init iommu_alloc_4k_pages(struct amd_iommu *iommu,
32 void amd_iommu_debugfs_setup(struct amd_iommu *iommu);
62 int amd_iommu_iopf_init(struct amd_iommu *iommu);
63 void amd_iommu_iopf_uninit(struct amd_iommu *iommu);
66 int amd_iommu_iopf_add_device(struct amd_iommu *iommu,
79 void amd_iommu_enable_ppr_log(struct amd_iommu *iommu);
80 void amd_iommu_poll_ppr_log(struct amd_iommu *iommu);
[all …]
/linux/drivers/iommu/
H A Dsun50i-iommu.c294 struct sun50i_iommu *iommu = sun50i_domain->iommu; in sun50i_table_flush() local
387 struct sun50i_iommu *iommu = sun50i_domain->iommu; in sun50i_iommu_flush_iotlb_all() local
398 if (!iommu) in sun50i_iommu_flush_iotlb_all()
410 struct sun50i_iommu *iommu = sun50i_domain->iommu; in sun50i_iommu_iotlb_sync_map() local
558 struct sun50i_iommu *iommu = sun50i_domain->iommu; in sun50i_dte_get_page_table() local
599 struct sun50i_iommu *iommu = sun50i_domain->iommu; in sun50i_iommu_map() local
716 sun50i_domain->iommu = iommu; in sun50i_iommu_attach_domain()
794 if (!iommu) in sun50i_iommu_attach_device()
819 return &iommu->iommu; in sun50i_iommu_probe_device()
1047 iommu_device_unregister(&iommu->iommu); in sun50i_iommu_probe()
[all …]
H A Dmsm_iommu.c73 if (iommu->clk) in __disable_clocks()
388 if (!iommu) in msm_iommu_probe_device()
391 return &iommu->iommu; in msm_iommu_probe_device()
722 if (!iommu) in msm_iommu_probe()
728 iommu->pclk = devm_clk_get(iommu->dev, "smmu_pclk"); in msm_iommu_probe()
738 iommu->clk = devm_clk_get(iommu->dev, "iommu_clk"); in msm_iommu_probe()
752 iommu->base = devm_ioremap_resource(iommu->dev, r); in msm_iommu_probe()
772 msm_iommu_reset(iommu->base, iommu->ncb); in msm_iommu_probe()
791 iommu); in msm_iommu_probe()
799 ret = iommu_device_sysfs_add(&iommu->iommu, iommu->dev, NULL, in msm_iommu_probe()
[all …]
H A Drockchip-iommu.c624 report_iommu_fault(iommu->domain, iommu->dev, iova, in rk_iommu_irq()
643 clk_bulk_disable(iommu->num_clocks, iommu->clocks); in rk_iommu_irq()
700 clk_bulk_disable(iommu->num_clocks, iommu->clocks); in rk_iommu_zap_iova()
922 clk_bulk_disable(iommu->num_clocks, iommu->clocks); in rk_iommu_disable()
956 clk_bulk_disable(iommu->num_clocks, iommu->clocks); in rk_iommu_enable()
970 if (!iommu) in rk_iommu_identity_attach()
1134 return &iommu->iommu; in rk_iommu_probe_device()
1235 iommu->clocks = devm_kcalloc(iommu->dev, iommu->num_clocks, in rk_iommu_probe()
1248 err = devm_clk_bulk_get(iommu->dev, iommu->num_clocks, iommu->clocks); in rk_iommu_probe()
1296 iommu_device_sysfs_remove(&iommu->iommu); in rk_iommu_probe()
[all …]
H A Diommu-sysfs.c62 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()
68 iommu->dev->class = &iommu_class; in iommu_device_sysfs_add()
69 iommu->dev->parent = parent; in iommu_device_sysfs_add()
70 iommu->dev->groups = groups; in iommu_device_sysfs_add()
78 ret = device_add(iommu->dev); in iommu_device_sysfs_add()
82 dev_set_drvdata(iommu->dev, iommu); in iommu_device_sysfs_add()
87 put_device(iommu->dev); in iommu_device_sysfs_add()
95 device_unregister(iommu->dev); in iommu_device_sysfs_remove()
[all …]
H A DMakefile3 obj-$(CONFIG_IOMMU_API) += iommu.o
4 obj-$(CONFIG_IOMMU_API) += iommu-traces.o
5 obj-$(CONFIG_IOMMU_API) += iommu-sysfs.o
6 obj-$(CONFIG_IOMMU_DEBUGFS) += iommu-debugfs.o
7 obj-$(CONFIG_IOMMU_DMA) += dma-iommu.o
19 obj-$(CONFIG_OMAP_IOMMU) += omap-iommu.o
22 obj-$(CONFIG_SUN50I_IOMMU) += sun50i-iommu.o
24 obj-$(CONFIG_EXYNOS_IOMMU) += exynos-iommu.o
26 obj-$(CONFIG_S390_IOMMU) += s390-iommu.o
29 obj-$(CONFIG_IOMMU_SVA) += iommu-sva.o
[all …]
/linux/arch/sparc/kernel/
H A Diommu.c157 struct iommu *iommu, in alloc_npages() argument
202 struct iommu *iommu; in dma_4u_alloc_coherent() local
221 iommu = dev->archdata.iommu; in dma_4u_alloc_coherent()
250 struct iommu *iommu; in dma_4u_free_coherent() local
268 struct iommu *iommu; in dma_4u_map_page() local
390 struct iommu *iommu; in dma_4u_unmap_page() local
443 struct iommu *iommu; in dma_4u_map_sg() local
612 struct iommu *iommu; in dma_4u_unmap_sg() local
661 struct iommu *iommu; in dma_4u_sync_single_for_cpu() local
699 struct iommu *iommu; in dma_4u_sync_sg_for_cpu() local
[all …]
H A Diommu-common.c66 iommu->nr_pools = npools; in iommu_tbl_pool_init()
78 iommu->poolsize = num_entries/iommu->nr_pools; in iommu_tbl_pool_init()
80 iommu->poolsize = (num_entries * 3 / 4)/iommu->nr_pools; in iommu_tbl_pool_init()
152 shift = iommu->table_map_base >> iommu->table_shift; in iommu_tbl_range_alloc()
176 boundary_size = iommu->poolsize * iommu->nr_pools; in iommu_tbl_range_alloc()
179 iommu->table_shift); in iommu_tbl_range_alloc()
187 set_flush(iommu); in iommu_tbl_range_alloc()
196 set_flush(iommu); in iommu_tbl_range_alloc()
205 if (iommu->lazy_flush && in iommu_tbl_range_alloc()
207 clear_flush(iommu); in iommu_tbl_range_alloc()
[all …]
H A Dsbus.c63 struct iommu *iommu = dev->archdata.iommu; in sbus_set_sbus64() local
213 struct iommu *iommu = op->dev.archdata.iommu; in sbus_build_irq() local
275 struct iommu *iommu = op->dev.archdata.iommu; in sysio_ue_handler() local
349 struct iommu *iommu = op->dev.archdata.iommu; in sysio_ce_handler() local
428 struct iommu *iommu = op->dev.archdata.iommu; in sysio_sbus_error_handler() local
497 struct iommu *iommu = op->dev.archdata.iommu; in sysio_register_error_handlers() local
545 struct iommu *iommu; in sbus_iommu_init() local
559 iommu = kzalloc(sizeof(*iommu), GFP_ATOMIC); in sbus_iommu_init()
564 op->dev.archdata.iommu = iommu; in sbus_iommu_init()
572 iommu->iommu_tags = iommu->iommu_control + in sbus_iommu_init()
[all …]
/linux/drivers/iommu/intel/
H A Dirq_remapping.c138 irq_iommu->iommu = iommu; in alloc_irte()
175 iommu = irq_iommu->iommu; in modify_irte()
242 iommu = irq_iommu->iommu; in clear_entries()
637 if (iommu && iommu->ir_table) { in intel_teardown_irq_remapping()
866 if (ir_hpet[count].iommu == iommu && in ir_parse_one_hpet_scope()
877 ir_hpet[free].iommu = iommu; in ir_parse_one_hpet_scope()
911 if (ir_ioapic[count].iommu == iommu && in ir_parse_one_ioapic_scope()
924 ir_ioapic[free].iommu = iommu; in ir_parse_one_ioapic_scope()
961 if (ir_hpet[i].iommu == iommu) in ir_remove_ioapic_hpet_scope()
965 if (ir_ioapic[i].iommu == iommu) in ir_remove_ioapic_hpet_scope()
[all …]
H A Dpasid.c262 iommu->flush.flush_iotlb(iommu, did, 0, 0, DMA_TLB_DSI_FLUSH); in intel_pasid_tear_down_entry()
492 iommu->flush.flush_iotlb(iommu, did, 0, 0, DMA_TLB_DSI_FLUSH); in intel_pasid_setup_dirty_tracking()
618 iommu->name); in intel_pasid_setup_nested()
682 struct intel_iommu *iommu = info->iommu; in device_pasid_table_teardown() local
711 iommu->flush.flush_context(iommu, 0, PCI_DEVID(bus, devfn), in device_pasid_table_teardown()
760 struct intel_iommu *iommu = info->iommu; in context_entry_set_pasid_table() local
786 struct intel_iommu *iommu = info->iommu; in device_pasid_table_setup() local
814 iommu->flush.flush_context(iommu, 0, in device_pasid_table_setup()
819 iommu->flush.flush_iotlb(iommu, 0, 0, 0, DMA_TLB_GLOBAL_FLUSH); in device_pasid_table_setup()
840 iommu->flush.flush_context(iommu, 0, in device_pasid_table_setup()
[all …]
H A Dsvm.c36 if (!iommu->prq) { 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()
51 snprintf(iommu->iopfq_name, sizeof(iommu->iopfq_name), in intel_svm_enable_prq()
61 snprintf(iommu->prq_name, sizeof(iommu->prq_name), "dmar%d-prq", iommu->seq_id); in intel_svm_enable_prq()
64 iommu->prq_name, iommu); in intel_svm_enable_prq()
83 iommu->pr_irq = 0; in intel_svm_enable_prq()
98 free_irq(iommu->pr_irq, iommu); in intel_svm_finish_prq()
201 struct intel_iommu *iommu = info->iommu; in intel_svm_set_dev_pasid() local
310 iommu = info->iommu; in intel_drain_pasid_prq()
[all …]
H A Ddmar.c975 if (!request_mem_region(iommu->reg_phys, iommu->reg_size, iommu->name)) { in map_iommu()
981 iommu->reg = ioremap(iommu->reg_phys, iommu->reg_size); in map_iommu()
1011 iommu->reg = ioremap(iommu->reg_phys, iommu->reg_size); in map_iommu()
1130 iommu->iommu.max_pasids = 2UL << ecap_pss(iommu->ecap); in alloc_iommu()
1151 drhd->iommu = iommu; in alloc_iommu()
1157 iommu_device_sysfs_remove(&iommu->iommu); in alloc_iommu()
1172 iommu_device_unregister(&iommu->iommu); in free_iommu()
1180 free_irq(iommu->pr_irq, iommu); in free_iommu()
1184 free_irq(iommu->irq, iommu); in free_iommu()
2112 irq = dmar_alloc_hwirq(iommu->seq_id, iommu->node, iommu); in dmar_set_interrupt()
[all …]
H A Diommu.c162 struct intel_iommu *iommu = info->iommu; in device_rbtree_remove() local
598 if (!iommu || iommu->drhd->ignored) in iommu_is_dummy()
1585 info->iommu = iommu; in domain_attach_iommu()
1749 iommu->flush.flush_context(iommu, 0, in domain_context_mapping_one()
1976 iommu->flush.flush_context(iommu, in domain_context_clear_one()
1982 iommu->flush.flush_iotlb(iommu, in domain_context_clear_one()
4010 if (!iommu || !iommu->iommu.ops) in intel_iommu_probe_device()
4028 info->iommu = iommu; in intel_iommu_probe_device()
4084 return &iommu->iommu; in intel_iommu_probe_device()
4189 iommu = info->iommu; in intel_iommu_enable_sva()
[all …]
H A Dcap_audit.c91 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, zlr, CAP_ZLR_MASK); in cap_audit_hotplug()
93 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, phmr, CAP_PHMR_MASK); in cap_audit_hotplug()
94 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, plmr, CAP_PLMR_MASK); in cap_audit_hotplug()
96 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, cap, afl, CAP_AFL_MASK); in cap_audit_hotplug()
116 CHECK_FEATURE_MISMATCH_HOTPLUG(iommu, ecap, qis, ECAP_QI_MASK); in cap_audit_hotplug()
152 if (!iommu) { in cap_audit_static()
155 iommu = i; in cap_audit_static()
160 check_dmar_capabilities(iommu, i); in cap_audit_static()
162 check_irq_capabilities(iommu, i); in cap_audit_static()
183 return cap_audit_static(iommu, type); in intel_cap_audit()
[all …]
H A Ddebugfs.c116 struct intel_iommu *iommu; in iommu_regset_show() local
267 spin_lock(&iommu->lock); in root_tbl_walk()
293 iommu->name); in dmar_translation_struct_show()
296 root_tbl_walk(m, iommu); in dmar_translation_struct_show()
372 iommu->name); in domain_translation_struct_show()
389 spin_lock(&iommu->lock); in domain_translation_struct_show()
519 qi = iommu->qi; in invalidation_queue_show()
520 shift = qi_shift(iommu); in invalidation_queue_show()
610 iommu->name); in ir_translation_struct_show()
630 iommu->name); in ir_translation_struct_show()
[all …]
H A Dcache.c34 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()
90 struct intel_iommu *iommu = info->iommu; in cache_tag_unassign() local
167 struct intel_iommu *iommu = info->iommu; in domain_get_id_for_dev() local
272 struct intel_iommu *iommu = tag->iommu; in cache_tag_flush_range() local
289 iommu->flush.flush_iotlb(iommu, tag->domain_id, in cache_tag_flush_range()
340 struct intel_iommu *iommu = tag->iommu; in cache_tag_flush_all() local
351 iommu->flush.flush_iotlb(iommu, tag->domain_id, in cache_tag_flush_all()
[all …]
/linux/drivers/vfio/
H A Dvfio_iommu_type1.c801 if (!iommu->v2) in vfio_iommu_type1_pin_pages()
1120 iommu->dma_avail++; in vfio_remove_dma()
2540 iommu = kzalloc(sizeof(*iommu), GFP_KERNEL); in vfio_iommu_type1_open()
2541 if (!iommu) in vfio_iommu_type1_open()
2551 iommu->v2 = true; in vfio_iommu_type1_open()
2554 kfree(iommu); in vfio_iommu_type1_open()
2568 return iommu; in vfio_iommu_type1_open()
2608 kfree(iommu); in vfio_iommu_type1_release()
2652 return iommu && !vfio_iommu_has_emulated(iommu); in vfio_iommu_type1_check_extension()
2654 if (!iommu) in vfio_iommu_type1_check_extension()
[all …]
/linux/Documentation/devicetree/bindings/pci/
H A Dpci-iommu.txt26 Documentation/devicetree/bindings/iommu/iommu.txt.
39 (rid-base,iommu,iommu-base,length).
55 iommu: iommu@a {
70 iommu-map = <0x0 &iommu 0x0 0x10000>;
82 iommu: iommu@a {
97 iommu-map = <0x0 &iommu 0x0 0x10000>;
110 iommu: iommu@a {
125 iommu-map = <0x0000 &iommu 0x8000 0x8000>,
138 iommu_a: iommu@a {
144 iommu_b: iommu@b {
[all …]
/linux/arch/powerpc/platforms/cell/
H A Diommu.c347 __func__, iommu->nid, iommu->stab, ptab, in cell_iommu_alloc_ptab()
389 iommu->cmd_regs = iommu->xlate_regs + IOC_IOCmd_Offset; in cell_iommu_enable_hardware()
405 ret = request_irq(virq, ioc_interrupt, 0, iommu->name, iommu); in cell_iommu_enable_hardware()
422 iommu->ptab = cell_iommu_alloc_ptab(iommu, base, size, 0, 0, in cell_iommu_setup_hardware()
463 window->iommu = iommu; in cell_iommu_setup_window()
535 if (iommu == NULL || list_empty(&iommu->windows)) { in cell_get_iommu_table()
637 snprintf(iommu->name, sizeof(iommu->name), "iommu%d", i); in cell_iommu_alloc()
640 return iommu; in cell_iommu_alloc()
650 if (!iommu) in cell_iommu_init_one()
978 BUG_ON(!iommu); in cell_iommu_fixed_mapping_init()
[all …]
/linux/arch/sparc/mm/
H A Diommu.c60 struct iommu_struct *iommu; in sbus_iommu_init() local
68 if (!iommu) { in sbus_iommu_init()
75 if (!iommu->regs) { in sbus_iommu_init()
87 iommu_invalidate(iommu->regs); in sbus_iommu_init()
88 iommu->start = IOMMU_START; in sbus_iommu_init()
89 iommu->end = 0xffffffff; in sbus_iommu_init()
132 op->dev.archdata.iommu = iommu; in sbus_iommu_init()
187 struct iommu_struct *iommu = dev->archdata.iommu; in __sbus_iommu_map_page() local
283 struct iommu_struct *iommu = dev->archdata.iommu; in sbus_iommu_unmap_page() local
316 struct iommu_struct *iommu = dev->archdata.iommu; in sbus_iommu_alloc() local
[all …]
/linux/Documentation/devicetree/bindings/iommu/
H A Dqcom,iommu.yaml4 $id: http://devicetree.org/schemas/iommu/qcom,iommu.yaml#
23 - qcom,msm8916-iommu
24 - qcom,msm8953-iommu
49 qcom,iommu-secure-id:
60 '#iommu-cells':
64 "^iommu-ctx@[0-9a-f]+$":
98 - '#iommu-cells'
107 apps_iommu: iommu@1e20000 {
108 compatible = "qcom,msm8916-iommu", "qcom,msm-iommu-v1";
116 #iommu-cells = <1>;
[all …]

12345678910>>...15