From: Baolu Lu <baolu.lu@linux.intel.com>
To: Jason Gunthorpe <jgg@ziepe.ca>
Cc: baolu.lu@linux.intel.com, Kevin Tian <kevin.tian@intel.com>,
Joerg Roedel <joro@8bytes.org>, Will Deacon <will@kernel.org>,
Robin Murphy <robin.murphy@arm.com>,
Jean-Philippe Brucker <jean-philippe@linaro.org>,
Nicolin Chen <nicolinc@nvidia.com>, Yi Liu <yi.l.liu@intel.com>,
Jacob Pan <jacob.jun.pan@linux.intel.com>,
Joel Granados <j.granados@samsung.com>,
iommu@lists.linux.dev, virtualization@lists.linux-foundation.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH v7 04/10] iommu: Extend domain attach group with handle support
Date: Sat, 29 Jun 2024 11:58:01 +0800 [thread overview]
Message-ID: <4bda68fb-0aa4-4160-8e8a-7024938ea525@linux.intel.com> (raw)
In-Reply-To: <Zn8luxc+RLBOIIX0@ziepe.ca>
On 2024/6/29 5:06, Jason Gunthorpe wrote:
> On Sun, Jun 16, 2024 at 02:11:49PM +0800, Lu Baolu wrote:
>
>> +int iommu_replace_group_handle(struct iommu_group *group,
>> + struct iommu_domain *new_domain,
>> + struct iommu_attach_handle *handle)
>> +{
>> + struct iommu_domain *old_domain = group->domain;
>> + void *curr;
>> + int ret;
>> +
>> + if (!new_domain)
>> + return -EINVAL;
>> +
>> + mutex_lock(&group->mutex);
>> + ret = __iommu_group_set_domain(group, new_domain);
>> + if (ret)
>> + goto err_unlock;
>> + xa_erase(&group->pasid_array, IOMMU_NO_PASID);
>> + if (handle) {
>> + curr = xa_store(&group->pasid_array, IOMMU_NO_PASID, handle, GFP_KERNEL);
>> + if (xa_err(curr)) {
>> + ret = xa_err(curr);
>> + goto err_restore;
> But this error unwind doesn't work because the xa_erase() already
> happened and there may have been a handle there that we don't put
> back.
Yes, you are right.
>
> Something like this - store to a reserved entry cannot fail:
This code looks good to me. Thanks!
Best regards,
baolu
next prev parent reply other threads:[~2024-06-29 3:58 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-16 6:11 [PATCH v7 00/10] IOMMUFD: Deliver IO page faults to user space Lu Baolu
2024-06-16 6:11 ` [PATCH v7 01/10] iommu: Introduce domain attachment handle Lu Baolu
2024-06-28 20:46 ` Jason Gunthorpe
2024-06-16 6:11 ` [PATCH v7 02/10] iommu: Remove sva handle list Lu Baolu
2024-06-28 21:15 ` Jason Gunthorpe
2024-06-16 6:11 ` [PATCH v7 03/10] iommu: Add attach handle to struct iopf_group Lu Baolu
2024-06-17 7:41 ` Tian, Kevin
2024-06-18 1:35 ` Baolu Lu
2024-06-28 20:48 ` Jason Gunthorpe
2024-06-16 6:11 ` [PATCH v7 04/10] iommu: Extend domain attach group with handle support Lu Baolu
2024-06-28 21:06 ` Jason Gunthorpe
2024-06-29 3:58 ` Baolu Lu [this message]
2024-06-16 6:11 ` [PATCH v7 05/10] iommufd: Add fault and response message definitions Lu Baolu
2024-06-16 6:11 ` [PATCH v7 06/10] iommufd: Add iommufd fault object Lu Baolu
2024-06-28 22:14 ` Jason Gunthorpe
2024-06-16 6:11 ` [PATCH v7 07/10] iommufd: Fault-capable hwpt attach/detach/replace Lu Baolu
2024-06-28 21:17 ` Jason Gunthorpe
2024-07-01 5:55 ` Baolu Lu
2024-07-09 17:36 ` Jason Gunthorpe
2024-07-10 0:32 ` Tian, Kevin
2024-07-10 8:36 ` Baolu Lu
2024-06-16 6:11 ` [PATCH v7 08/10] iommufd: Associate fault object with iommufd_hw_pgtable Lu Baolu
2024-06-28 22:13 ` Jason Gunthorpe
2024-07-01 5:26 ` Baolu Lu
2024-06-16 6:11 ` [PATCH v7 09/10] iommufd/selftest: Add IOPF support for mock device Lu Baolu
2024-06-16 6:11 ` [PATCH v7 10/10] iommufd/selftest: Add coverage for IOPF test Lu Baolu
2024-06-17 7:46 ` [PATCH v7 00/10] IOMMUFD: Deliver IO page faults to user space Tian, Kevin
2024-06-28 22:14 ` Jason Gunthorpe
2024-07-02 6:42 ` Baolu Lu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4bda68fb-0aa4-4160-8e8a-7024938ea525@linux.intel.com \
--to=baolu.lu@linux.intel.com \
--cc=iommu@lists.linux.dev \
--cc=j.granados@samsung.com \
--cc=jacob.jun.pan@linux.intel.com \
--cc=jean-philippe@linaro.org \
--cc=jgg@ziepe.ca \
--cc=joro@8bytes.org \
--cc=kevin.tian@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=nicolinc@nvidia.com \
--cc=robin.murphy@arm.com \
--cc=virtualization@lists.linux-foundation.org \
--cc=will@kernel.org \
--cc=yi.l.liu@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.