Skip to content

Commit bbf85fe

Browse files
hegdevasantjoergroedel
authored andcommitted
iommu/amd: Refactor device iotlb invalidation code
build_inv_iotlb_pages() and build_inv_iotlb_pasid() pretty much duplicates the code. Enhance build_inv_iotlb_pages() to invalidate guest IOTLB as well. And remove build_inv_iotlb_pasid() function. Suggested-by: Kishon Vijay Abraham I <kvijayab@amd.com> Signed-off-by: Vasant Hegde <vasant.hegde@amd.com> Reviewed-by: Suravee Suthikulpanit <suravee.suthikulpanit@amd.com> Reviewed-by: Jason Gunthorpe <jgg@nvidia.com> Link: https://lore.kernel.org/r/20231122090215.6191-7-vasant.hegde@amd.com Signed-off-by: Joerg Roedel <jroedel@suse.de>
1 parent 4f0a600 commit bbf85fe

1 file changed

Lines changed: 12 additions & 21 deletions

File tree

drivers/iommu/amd/iommu.c

Lines changed: 12 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -1144,34 +1144,24 @@ static void build_inv_iommu_pages(struct iommu_cmd *cmd, u64 address,
11441144
}
11451145

11461146
static void build_inv_iotlb_pages(struct iommu_cmd *cmd, u16 devid, int qdep,
1147-
u64 address, size_t size)
1147+
u64 address, size_t size,
1148+
ioasid_t pasid, bool gn)
11481149
{
11491150
u64 inv_address = build_inv_address(address, size);
11501151

11511152
memset(cmd, 0, sizeof(*cmd));
1153+
11521154
cmd->data[0] = devid;
11531155
cmd->data[0] |= (qdep & 0xff) << 24;
11541156
cmd->data[1] = devid;
11551157
cmd->data[2] = lower_32_bits(inv_address);
11561158
cmd->data[3] = upper_32_bits(inv_address);
1157-
CMD_SET_TYPE(cmd, CMD_INV_IOTLB_PAGES);
1158-
}
1159-
1160-
static void build_inv_iotlb_pasid(struct iommu_cmd *cmd, u16 devid, u32 pasid,
1161-
int qdep, u64 address, size_t size)
1162-
{
1163-
u64 inv_address = build_inv_address(address, size);
1164-
1165-
memset(cmd, 0, sizeof(*cmd));
1159+
if (gn) {
1160+
cmd->data[0] |= ((pasid >> 8) & 0xff) << 16;
1161+
cmd->data[1] |= (pasid & 0xff) << 16;
1162+
cmd->data[2] |= CMD_INV_IOMMU_PAGES_GN_MASK;
1163+
}
11661164

1167-
cmd->data[0] = devid;
1168-
cmd->data[0] |= ((pasid >> 8) & 0xff) << 16;
1169-
cmd->data[0] |= (qdep & 0xff) << 24;
1170-
cmd->data[1] = devid;
1171-
cmd->data[1] |= (pasid & 0xff) << 16;
1172-
cmd->data[2] = lower_32_bits(inv_address);
1173-
cmd->data[2] |= CMD_INV_IOMMU_PAGES_GN_MASK;
1174-
cmd->data[3] = upper_32_bits(inv_address);
11751165
CMD_SET_TYPE(cmd, CMD_INV_IOTLB_PAGES);
11761166
}
11771167

@@ -1404,7 +1394,8 @@ static int device_flush_iotlb(struct iommu_dev_data *dev_data,
14041394
if (!iommu)
14051395
return -EINVAL;
14061396

1407-
build_inv_iotlb_pages(&cmd, dev_data->devid, qdep, address, size);
1397+
build_inv_iotlb_pages(&cmd, dev_data->devid, qdep, address,
1398+
size, IOMMU_NO_PASID, false);
14081399

14091400
return iommu_queue_command(iommu, &cmd);
14101401
}
@@ -2687,8 +2678,8 @@ static int __flush_pasid(struct protection_domain *domain, u32 pasid,
26872678
iommu = rlookup_amd_iommu(dev_data->dev);
26882679
if (!iommu)
26892680
continue;
2690-
build_inv_iotlb_pasid(&cmd, dev_data->devid, pasid,
2691-
qdep, address, size);
2681+
build_inv_iotlb_pages(&cmd, dev_data->devid, qdep,
2682+
address, size, pasid, true);
26922683

26932684
ret = iommu_queue_command(iommu, &cmd);
26942685
if (ret != 0)

0 commit comments

Comments
 (0)