[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH ats_vtd 16/22] intel_iommu: fill the PASID field when creating an
From: |
CLEMENT MATHIEU--DRIF |
Subject: |
[PATCH ats_vtd 16/22] intel_iommu: fill the PASID field when creating an instance of IOMMUTLBEntry |
Date: |
Tue, 21 May 2024 13:11:49 +0000 |
Signed-off-by: Clément Mathieu--Drif <clement.mathieu--drif@eviden.com>
---
hw/i386/intel_iommu.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/hw/i386/intel_iommu.c b/hw/i386/intel_iommu.c
index a42938aacd..f08c3e8f00 100644
--- a/hw/i386/intel_iommu.c
+++ b/hw/i386/intel_iommu.c
@@ -2187,6 +2187,9 @@ static bool vtd_do_iommu_translate(VTDAddressSpace
*vtd_as, PCIBus *bus,
vtd_iommu_lock(s);
+ /* fill the pasid before getting rid2pasid */
+ entry->pasid = pasid;
+
cc_entry = &vtd_as->context_cache_entry;
/* Try to fetch pte form IOTLB, we don't need RID2PASID logic */
@@ -2304,6 +2307,7 @@ out:
entry->translated_addr = vtd_get_pte_addr(pte, s->aw_bits) & page_mask;
entry->addr_mask = ~page_mask;
entry->perm = access_flags;
+ /* pasid already set */
return true;
error:
@@ -2312,6 +2316,7 @@ error:
entry->translated_addr = 0;
entry->addr_mask = 0;
entry->perm = IOMMU_NONE;
+ entry->pasid = PCI_NO_PASID;
return false;
}
@@ -3673,6 +3678,7 @@ static void vtd_piotlb_page_invalidate(IntelIOMMUState
*s, uint16_t domain_id,
event.entry.target_as = &address_space_memory;
event.entry.iova = addr;
event.entry.perm = IOMMU_NONE;
+ event.entry.pasid = pasid;
event.entry.addr_mask = size - 1;
event.entry.translated_addr = 0;
memory_region_notify_iommu(&vtd_as->iommu, 0, event);
@@ -4320,6 +4326,7 @@ static void do_invalidate_device_tlb(VTDAddressSpace
*vtd_dev_as,
event.entry.iova = addr;
event.entry.perm = IOMMU_NONE;
event.entry.translated_addr = 0;
+ event.entry.pasid = vtd_dev_as->pasid;
memory_region_notify_iommu(&vtd_dev_as->iommu, 0, event);
}
@@ -4896,6 +4903,7 @@ static IOMMUTLBEntry
vtd_iommu_translate(IOMMUMemoryRegion *iommu, hwaddr addr,
IOMMUTLBEntry iotlb = {
/* We'll fill in the rest later. */
.target_as = &address_space_memory,
+ .pasid = vtd_as->pasid,
};
bool success;
@@ -4908,6 +4916,7 @@ static IOMMUTLBEntry
vtd_iommu_translate(IOMMUMemoryRegion *iommu, hwaddr addr,
iotlb.translated_addr = addr & VTD_PAGE_MASK_4K;
iotlb.addr_mask = ~VTD_PAGE_MASK_4K;
iotlb.perm = IOMMU_RW;
+ iotlb.pasid = PCI_NO_PASID;
success = true;
}
--
2.44.0
- [PATCH ats_vtd 20/22] pci: add a pci-level API for ATS, (continued)
- [PATCH ats_vtd 20/22] pci: add a pci-level API for ATS, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 10/22] pci: add IOMMU operations to get address spaces and memory regions with PASID, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 11/22] memory: store user data pointer in the IOMMU notifiers, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 12/22] pci: add a pci-level initialization function for iommu notifiers, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 04/22] intel_iommu: do not consider wait_desc as an invalid descriptor, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 18/22] atc: add unit tests, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 14/22] intel_iommu: implement the get_memory_region_pasid iommu operation, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 09/22] pci: cache the bus mastering status in the device, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 02/22] intel_iommu: make types match, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 03/22] intel_iommu: return page walk level even when the translation fails, CLEMENT MATHIEU--DRIF, 2024/05/21
- [PATCH ats_vtd 16/22] intel_iommu: fill the PASID field when creating an instance of IOMMUTLBEntry,
CLEMENT MATHIEU--DRIF <=
- [PATCH ats_vtd 21/22] intel_iommu: set the address mask even when a translation fails, CLEMENT MATHIEU--DRIF, 2024/05/21