]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
intel_iommu: fix FRCD construction macro
authorClément Mathieu--Drif <clement.mathieu--drif@eviden.com>
Tue, 9 Jul 2024 14:26:08 +0000 (14:26 +0000)
committerMichael Tokarev <mjt@tls.msk.ru>
Wed, 24 Jul 2024 04:42:15 +0000 (07:42 +0300)
The constant must be unsigned, otherwise the two's complement
overrides the other fields when a PASID is present.

Fixes: 1b2b12376c8a ("intel-iommu: PASID support")
Signed-off-by: Clément Mathieu--Drif <clement.mathieu--drif@eviden.com>
Reviewed-by: Yi Liu <yi.l.liu@intel.com>
Reviewed-by: Zhenzhong Duan <zhenzhong.duan@intel.com>
Reviewed-by: Minwoo Im <minwoo.im@samsung.com>
Message-Id: <20240709142557.317271-2-clement.mathieu--drif@eviden.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
(cherry picked from commit a3c8d7e38550c3d5a46e6fa94ffadfa625a4861d)
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
(Mjt: context fix)

hw/i386/intel_iommu_internal.h

index e4d43ce48c7aedca110a6af2ea6648bda03aa453..830e319e342dbfbdd62b975a7df3e64d3bf3f83e 100644 (file)
 /* For the low 64-bit of 128-bit */
 #define VTD_FRCD_FI(val)        ((val) & ~0xfffULL)
 #define VTD_FRCD_PV(val)        (((val) & 0xffffULL) << 40)
-#define VTD_FRCD_PP(val)        (((val) & 0x1) << 31)
+#define VTD_FRCD_PP(val)        (((val) & 0x1ULL) << 31)
 
 /* DMA Remapping Fault Conditions */
 typedef enum VTDFaultReason {