| /linux/drivers/iommu/iommufd/ |
| H A D | viommu.c | 8 struct iommufd_viommu *viommu = in iommufd_viommu_destroy() local 11 if (viommu->ops && viommu->ops->destroy) in iommufd_viommu_destroy() 12 viommu->ops->destroy(viommu); in iommufd_viommu_destroy() 13 refcount_dec(&viommu->hwpt->common.obj.users); in iommufd_viommu_destroy() 14 xa_destroy(&viommu->vdevs); in iommufd_viommu_destroy() 26 struct iommufd_viommu *viommu; in iommufd_viommu_alloc_ioctl() local 53 * vIOMMU structure size in iommufd_viommu_alloc_ioctl() 55 if (WARN_ON_ONCE(viommu_size < sizeof(*viommu))) { in iommufd_viommu_alloc_ioctl() 71 viommu = (struct iommufd_viommu *)_iommufd_object_alloc_ucmd( in iommufd_viommu_alloc_ioctl() 73 if (IS_ERR(viommu)) { in iommufd_viommu_alloc_ioctl() [all …]
|
| H A D | driver.c | 92 /* Caller should xa_lock(&viommu->vdevs) to protect the return value */ 93 struct device *iommufd_viommu_find_dev(struct iommufd_viommu *viommu, in iommufd_viommu_find_dev() argument 98 lockdep_assert_held(&viommu->vdevs.xa_lock); in iommufd_viommu_find_dev() 100 vdev = xa_load(&viommu->vdevs, vdev_id); in iommufd_viommu_find_dev() 105 /* Return -ENOENT if device is not associated to the vIOMMU */ 106 int iommufd_viommu_get_vdev_id(struct iommufd_viommu *viommu, in iommufd_viommu_get_vdev_id() argument 116 xa_lock(&viommu->vdevs); in iommufd_viommu_get_vdev_id() 117 xa_for_each(&viommu->vdevs, index, vdev) { in iommufd_viommu_get_vdev_id() 124 xa_unlock(&viommu->vdevs); in iommufd_viommu_get_vdev_id() 133 int iommufd_viommu_report_event(struct iommufd_viommu *viommu, in iommufd_viommu_report_event() argument [all …]
|
| H A D | main.c | 434 struct iommu_viommu_alloc viommu; member
|
| /linux/drivers/iommu/ |
| H A D | virtio-iommu.c | 65 struct viommu_dev *viommu; member 77 struct viommu_dev *viommu; member 137 static off_t viommu_get_write_desc_offset(struct viommu_dev *viommu, in viommu_get_write_desc_offset() argument 144 return len - viommu->probe_size - tail_size; in viommu_get_write_desc_offset() 155 static int __viommu_sync_req(struct viommu_dev *viommu) in __viommu_sync_req() argument 160 struct virtqueue *vq = viommu->vqs[VIOMMU_REQUEST_VQ]; in __viommu_sync_req() 162 assert_spin_locked(&viommu->request_lock); in __viommu_sync_req() 166 while (!list_empty(&viommu->requests)) { in __viommu_sync_req() 188 static int viommu_sync_req(struct viommu_dev *viommu) in viommu_sync_req() argument 193 spin_lock_irqsave(&viommu->request_lock, flags); in viommu_sync_req() [all …]
|
| /linux/drivers/acpi/ |
| H A D | viot.c | 48 struct viot_iommu *viommu; member 77 static int __init viot_get_pci_iommu_fwnode(struct viot_iommu *viommu, in viot_get_pci_iommu_fwnode() argument 103 viommu->fwnode = dev_fwnode(&pdev->dev); in viot_get_pci_iommu_fwnode() 108 static int __init viot_get_mmio_iommu_fwnode(struct viot_iommu *viommu, in viot_get_mmio_iommu_fwnode() argument 123 viommu->fwnode = &adev->fwnode; in viot_get_mmio_iommu_fwnode() 130 struct viot_iommu *viommu; in viot_get_iommu() local 138 list_for_each_entry(viommu, &viot_iommus, list) in viot_get_iommu() 139 if (viommu->offset == offset) in viot_get_iommu() 140 return viommu; in viot_get_iommu() 145 viommu = kzalloc_obj(*viommu); in viot_get_iommu() [all …]
|
| /linux/Documentation/userspace-api/ |
| H A D | iommufd.rst | 85 Such a vIOMMU object generally has the access to a nesting parent pagetable 86 to support some HW-accelerated virtualization features. So, a vIOMMU object 88 encapsulate that HWPT_PAGING object. Therefore, a vIOMMU object can be used 93 The name "vIOMMU" isn't necessarily identical to a virtualized IOMMU in a 97 vIOMMU objects created for individual slices of different physical IOMMUs. 98 In other words, a vIOMMU object is always a representation of one physical 103 backed by corresponding vIOMMU objects, in which case a guest OS would do 108 information or attributes (related to the vIOMMU) in a VM. An immediate vDATA 109 example can be the virtual ID of the device on a vIOMMU, which is a unique ID 110 that VMM assigns to the device for a translation channel/port of the vIOMMU, [all …]
|
| /linux/drivers/iommu/amd/ |
| H A D | iommufd.c | 40 int amd_iommufd_viommu_init(struct iommufd_viommu *viommu, struct iommu_domain *parent, in amd_iommufd_viommu_init() argument 45 struct amd_iommu_viommu *aviommu = container_of(viommu, struct amd_iommu_viommu, core); in amd_iommufd_viommu_init() 50 viommu->ops = &amd_viommu_ops; in amd_iommufd_viommu_init() 59 static void amd_iommufd_viommu_destroy(struct iommufd_viommu *viommu) in amd_iommufd_viommu_destroy() argument 62 struct amd_iommu_viommu *aviommu = container_of(viommu, struct amd_iommu_viommu, core); in amd_iommufd_viommu_destroy() 73 * struct iommufd_viommu_ops - vIOMMU specific operations
|
| H A D | nested.c | 94 amd_iommu_alloc_domain_nested(struct iommufd_viommu *viommu, u32 flags, in amd_iommu_alloc_domain_nested() argument 100 struct amd_iommu_viommu *aviommu = container_of(viommu, struct amd_iommu_viommu, core); in amd_iommu_alloc_domain_nested() 122 ndom->viommu = aviommu; in amd_iommu_alloc_domain_nested() 133 * cache tags of (DomID, PASID). Within a single viommu, the nest parent domain in amd_iommu_alloc_domain_nested() 135 * to a single hDomID. This is done using an xarray in the vIOMMU to in amd_iommu_alloc_domain_nested() 199 if (WARN_ON(!ndom->viommu || !ndom->viommu->parent)) in set_dte_nested() 202 parent = ndom->viommu->parent; in set_dte_nested() 262 struct amd_iommu_viommu *aviommu = ndom->viommu; in nested_domain_free()
|
| H A D | amd_iommu_types.h | 511 struct protection_domain *parent; /* nest parent domain for this viommu */ 515 * Per-vIOMMU guest domain ID to host domain ID mapping. 537 struct iommu_hwpt_amd_guest gdte; /* Guest vIOMMU DTE */ 538 struct amd_iommu_viommu *viommu; /* AMD hw-viommu this nested domain belong to */ member
|
| H A D | amd_iommu.h | 226 amd_iommu_alloc_domain_nested(struct iommufd_viommu *viommu, u32 flags,
|
| H A D | iommu.c | 1787 * When NpCache is on, we infer that we run in a VM and use a vIOMMU. in amd_iommu_domain_flush_pages()
|
| /linux/drivers/iommu/arm/arm-smmu-v3/ |
| H A D | arm-smmu-v3-iommufd.c | 243 arm_vsmmu_alloc_domain_nested(struct iommufd_viommu *viommu, u32 flags, in arm_vsmmu_alloc_domain_nested() argument 246 struct arm_vsmmu *vsmmu = container_of(viommu, struct arm_vsmmu, core); in arm_vsmmu_alloc_domain_nested() 353 int arm_vsmmu_cache_invalidate(struct iommufd_viommu *viommu, in arm_vsmmu_cache_invalidate() argument 356 struct arm_vsmmu *vsmmu = container_of(viommu, struct arm_vsmmu, core); in arm_vsmmu_cache_invalidate() 445 int arm_vsmmu_init(struct iommufd_viommu *viommu, in arm_vsmmu_init() argument 449 struct arm_vsmmu *vsmmu = container_of(viommu, struct arm_vsmmu, core); in arm_vsmmu_init() 451 container_of(viommu->iommu_dev, struct arm_smmu_device, iommu); in arm_vsmmu_init() 462 if (viommu->type == IOMMU_VIOMMU_TYPE_ARM_SMMUV3) { in arm_vsmmu_init() 463 viommu->ops = &arm_vsmmu_ops; in arm_vsmmu_init()
|
| /linux/Documentation/devicetree/bindings/virtio/ |
| H A D | mmio.yaml | 56 iommus = <&viommu 23>; 59 viommu: iommu@3100 {
|
| /linux/include/linux/ |
| H A D | iommu.h | 643 * @get_viommu_size: Get the size of a driver-level vIOMMU structure for a given 645 * if vIOMMU isn't supported accordingly. It is required for 647 * driver-level vIOMMU structure related to the core one 649 * IOMMU instance @viommu->iommu_dev, as the set of virtualization 652 * set @viommu->ops pointing to its own viommu_ops 705 int (*viommu_init)(struct iommufd_viommu *viommu,
|
| H A D | dma-mapping.h | 100 * to the vIOMMU when it sets up the IOPTE. For MMIO use together with
|
| /linux/tools/testing/selftests/iommu/ |
| H A D | iommufd.c | 2813 unsigned int viommu; in FIXTURE_SETUP() 2823 if (variant->viommu) { in FIXTURE_TEARDOWN() 2836 /* Allocate a vIOMMU taking refcount of the parent hwpt */ 2856 .viommu = 0, in TEST_F() 2861 .viommu = 1, in TEST_F() 2887 /* Negative test -- unsupported viommu type */ in TEST_F() 3352 /* Allocate a regular nested hwpt based on viommu */ in TEST_F() 2786 unsigned int viommu; FIXTURE_VARIANT() local
|
| H A D | iommufd_utils.h | 353 #define test_cmd_viommu_invalidate(viommu, reqs, lreq, nreqs) \ argument 356 _test_cmd_viommu_invalidate(self->fd, viommu, reqs, \
|