[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 4/5] amd_iommu: Send notification when invaldate interrupt
From: |
Shukla, Santosh |
Subject: |
Re: [PATCH v2 4/5] amd_iommu: Send notification when invaldate interrupt entry cache |
Date: |
Mon, 23 Sep 2024 17:33:33 +0530 |
User-agent: |
Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.6.1 |
On 9/21/2024 1:56 AM, Alejandro Jimenez wrote:
> In subject:
> s/invaldate/invalidate/
>
> On 9/16/24 10:31, Santosh Shukla wrote:
>> From: Suravee Suthikulpanit <suravee.suthikulpanit@amd.com>
>>
>> In order to support AMD IOMMU interrupt remapping emulation with PCI
>> pass-through devices, QEMU needs to notify VFIO when guest IOMMU driver
>> updates and invalidate the guest interrupt remapping table (IRT), and
>> communicate information so that the host IOMMU driver can update
>> the shadowed interrupt remapping table in the host IOMMU.
>>
>> Therefore, send notification when guet
>
> s/guet/guest
>
> Alejandro
V3. Thanks
>
> IOMMU emulates the IRT invalidation
>> commands.
>>
>> Signed-off-by: Suravee Suthikulpanit <suravee.suthikulpanit@amd.com>
>> Signed-off-by: Santosh Shukla <santosh.shukla@amd.com>
>> ---
>> hw/i386/amd_iommu.c | 12 ++++++++++++
>> 1 file changed, 12 insertions(+)
>>
>> diff --git a/hw/i386/amd_iommu.c b/hw/i386/amd_iommu.c
>> index 24fcd561345c..9095146525e6 100644
>> --- a/hw/i386/amd_iommu.c
>> +++ b/hw/i386/amd_iommu.c
>> @@ -431,6 +431,12 @@ static void amdvi_complete_ppr(AMDVIState *s, uint64_t
>> *cmd)
>> trace_amdvi_ppr_exec();
>> }
>> +static void amdvi_intremap_inval_notify_all(AMDVIState *s, bool global,
>> + uint32_t index, uint32_t mask)
>> +{
>> + x86_iommu_iec_notify_all(X86_IOMMU_DEVICE(s), global, index, mask);
>> +}
>> +
>> static void amdvi_inval_all(AMDVIState *s, uint64_t *cmd)
>> {
>> if (extract64(cmd[0], 0, 60) || cmd[1]) {
>> @@ -438,6 +444,9 @@ static void amdvi_inval_all(AMDVIState *s, uint64_t *cmd)
>> s->cmdbuf + s->cmdbuf_head);
>> }
>> + /* Notify global invalidation */
>> + amdvi_intremap_inval_notify_all(s, true, 0, 0);
>> +
>> amdvi_iotlb_reset(s);
>> trace_amdvi_all_inval();
>> }
>> @@ -486,6 +495,9 @@ static void amdvi_inval_inttable(AMDVIState *s, uint64_t
>> *cmd)
>> return;
>> }
>> + /* Notify global invalidation */
>> + amdvi_intremap_inval_notify_all(s, true, 0, 0);
>> +
>> trace_amdvi_intr_inval();
>> }
>>
- [PATCH v2 0/5] Interrupt Remap support for emulated amd viommu, Santosh Shukla, 2024/09/16
- [PATCH v2 1/5] amd_iommu: Rename variable mmio to mr_mmio, Santosh Shukla, 2024/09/16
- [PATCH v2 2/5] amd_iommu: Add support for pass though mode, Santosh Shukla, 2024/09/16
- [PATCH v2 3/5] amd_iommu: Use shared memory region for Interrupt Remapping, Santosh Shukla, 2024/09/16
- [PATCH v2 4/5] amd_iommu: Send notification when invaldate interrupt entry cache, Santosh Shukla, 2024/09/16
- [PATCH v2 5/5] amd_iommu: Check APIC ID > 255 for XTSup, Santosh Shukla, 2024/09/16
- Re: [PATCH v2 0/5] Interrupt Remap support for emulated amd viommu, Alejandro Jimenez, 2024/09/20