iommu/vt-d: Use try_cmpxchg64() in intel_pasid_get_entry()
Use try_cmpxchg64() instead of cmpxchg64 (*ptr, old, new) != old in intel_pasid_get_entry(). cmpxchg returns success in ZF flag, so this change saves a compare after cmpxchg (and related move instruction in front of cmpxchg). Signed-off-by: Uros Bizjak <ubizjak@gmail.com> Cc: David Woodhouse <dwmw2@infradead.org> Cc: Lu Baolu <baolu.lu@linux.intel.com> Cc: Joerg Roedel <joro@8bytes.org> Cc: Will Deacon <will@kernel.org> Cc: Robin Murphy <robin.murphy@arm.com> Reviewed-by: Lu Baolu <baolu.lu@linux.intel.com> Link: https://lore.kernel.org/r/20240522082729.971123-2-ubizjak@gmail.com Signed-off-by: Joerg Roedel <jroedel@suse.de>
This commit is contained in:
parent
83a7eefedc
commit
5c555f1f1c
@ -146,6 +146,8 @@ static struct pasid_entry *intel_pasid_get_entry(struct device *dev, u32 pasid)
|
|||||||
retry:
|
retry:
|
||||||
entries = get_pasid_table_from_pde(&dir[dir_index]);
|
entries = get_pasid_table_from_pde(&dir[dir_index]);
|
||||||
if (!entries) {
|
if (!entries) {
|
||||||
|
u64 tmp;
|
||||||
|
|
||||||
entries = iommu_alloc_page_node(info->iommu->node, GFP_ATOMIC);
|
entries = iommu_alloc_page_node(info->iommu->node, GFP_ATOMIC);
|
||||||
if (!entries)
|
if (!entries)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -156,7 +158,8 @@ retry:
|
|||||||
* clear. However, this entry might be populated by others
|
* clear. However, this entry might be populated by others
|
||||||
* while we are preparing it. Use theirs with a retry.
|
* while we are preparing it. Use theirs with a retry.
|
||||||
*/
|
*/
|
||||||
if (cmpxchg64(&dir[dir_index].val, 0ULL,
|
tmp = 0ULL;
|
||||||
|
if (!try_cmpxchg64(&dir[dir_index].val, &tmp,
|
||||||
(u64)virt_to_phys(entries) | PASID_PTE_PRESENT)) {
|
(u64)virt_to_phys(entries) | PASID_PTE_PRESENT)) {
|
||||||
iommu_free_page(entries);
|
iommu_free_page(entries);
|
||||||
goto retry;
|
goto retry;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user