2023-03-13 07:52:02

by Chunyan Zhang

[permalink] [raw]
Subject: [PATCH V3 0/2] Add reattaching support and fix memory leak issue

V3:
* Split into two patches;
* Added support reattching an existing domain;
* Release DMA buffer only when domain freed.

V2: https://lkml.org/lkml/2023/3/7/1717
* Added some comment in sprd_iommu_attach_device() for the reason
of calling sprd_iommu_cleanup().

V1: https://lkml.org/lkml/2023/2/10/198

Chunyan Zhang (2):
iommu: sprd: release dma buffer to avoid memory leak
iommu: sprd: Add support for reattaching an existing domain

drivers/iommu/sprd-iommu.c | 54 +++++++++++++++++++++++++++++---------
1 file changed, 41 insertions(+), 13 deletions(-)

--
2.25.1



2023-03-13 07:52:05

by Chunyan Zhang

[permalink] [raw]
Subject: [PATCH V3 2/2] iommu: sprd: Add support for reattaching an existing domain

This IOMMU driver should allow a domain to be attached more than once.

If IOMMU is reattaching to the same domain which is attached, there's
nothing to be done.

If reattching to a previously-used domain, do not alloc DMA buffer
again which stores address mapping table to avoid memory leak.

Signed-off-by: Chunyan Zhang <[email protected]>
---
drivers/iommu/sprd-iommu.c | 25 +++++++++++++++++++------
1 file changed, 19 insertions(+), 6 deletions(-)

diff --git a/drivers/iommu/sprd-iommu.c b/drivers/iommu/sprd-iommu.c
index 7df1f730c778..3513b2b108bf 100644
--- a/drivers/iommu/sprd-iommu.c
+++ b/drivers/iommu/sprd-iommu.c
@@ -62,6 +62,7 @@ enum sprd_iommu_version {
* @eb: gate clock which controls IOMMU access
*/
struct sprd_iommu_device {
+ struct sprd_iommu_domain *dom;
enum sprd_iommu_version ver;
u32 *prot_page_va;
dma_addr_t prot_page_pa;
@@ -252,15 +253,27 @@ static int sprd_iommu_attach_device(struct iommu_domain *domain,
struct sprd_iommu_domain *dom = to_sprd_domain(domain);
size_t pgt_size = sprd_iommu_pgt_size(domain);

- if (dom->sdev)
- return -EINVAL;
+ /* The device is attached to this domain */
+ if (sdev->dom == dom)
+ return 0;

- dom->pgt_va = dma_alloc_coherent(sdev->dev, pgt_size, &dom->pgt_pa, GFP_KERNEL);
- if (!dom->pgt_va)
- return -ENOMEM;
+ /* The first time that domain is attaching to a device */
+ if (!dom->pgt_va) {
+ dom->pgt_va = dma_alloc_coherent(sdev->dev, pgt_size, &dom->pgt_pa, GFP_KERNEL);
+ if (!dom->pgt_va)
+ return -ENOMEM;
+
+ dom->sdev = sdev;
+ }

- dom->sdev = sdev;
+ sdev->dom = dom;

+ /*
+ * One sprd IOMMU serves one client device only, disabled it before
+ * configure mapping table to avoid access conflict in case other
+ * mapping table is stored in.
+ */
+ sprd_iommu_hw_en(sdev, false);
sprd_iommu_first_ppn(dom);
sprd_iommu_first_vpn(dom);
sprd_iommu_vpn_range(dom);
--
2.25.1


2023-03-27 02:49:19

by Chunyan Zhang

[permalink] [raw]
Subject: Re: [PATCH V3 0/2] Add reattaching support and fix memory leak issue

Hi Joerg,

On Mon, 13 Mar 2023 at 15:51, Chunyan Zhang <[email protected]> wrote:
>
> V3:
> * Split into two patches;
> * Added support reattching an existing domain;
> * Release DMA buffer only when domain freed.
>
> V2: https://lkml.org/lkml/2023/3/7/1717
> * Added some comment in sprd_iommu_attach_device() for the reason
> of calling sprd_iommu_cleanup().
>
> V1: https://lkml.org/lkml/2023/2/10/198
>
> Chunyan Zhang (2):
> iommu: sprd: release dma buffer to avoid memory leak
> iommu: sprd: Add support for reattaching an existing domain

Not sure if you received this patchset, since I received a rejection
letter from mail.8bytes.org.

If you didn't receive it, I can resend it with another email address.

Otherwise, would you please pick up this series if there are no more comments.

Thanks,
Chunyan


>
> drivers/iommu/sprd-iommu.c | 54 +++++++++++++++++++++++++++++---------
> 1 file changed, 41 insertions(+), 13 deletions(-)
>
> --
> 2.25.1
>

2023-03-27 08:08:48

by Joerg Roedel

[permalink] [raw]
Subject: Re: [PATCH V3 0/2] Add reattaching support and fix memory leak issue


Hi Chunyan,

On Mon, Mar 27, 2023 at 10:47:18AM +0800, Chunyan Zhang wrote:
> Not sure if you received this patchset, since I received a rejection
> letter from mail.8bytes.org.
>
> If you didn't receive it, I can resend it with another email address.
>
> Otherwise, would you please pick up this series if there are no more comments.

I didn't receive it, can you please send me the error message you got
from my mail server?

Regards,

Joerg

2023-03-28 03:10:00

by Chunyan Zhang

[permalink] [raw]
Subject: Re: [PATCH V3 0/2] Add reattaching support and fix memory leak issue

On Mon, 27 Mar 2023 at 16:01, Joerg Roedel <[email protected]> wrote:
>
>
> Hi Chunyan,
>
> On Mon, Mar 27, 2023 at 10:47:18AM +0800, Chunyan Zhang wrote:
> > Not sure if you received this patchset, since I received a rejection
> > letter from mail.8bytes.org.
> >
> > If you didn't receive it, I can resend it with another email address.
> >
> > Otherwise, would you please pick up this series if there are no more comments.
>
> I didn't receive it, can you please send me the error message you got
> from my mail server?

Have sent it to you.

>
> Regards,
>
> Joerg

2023-03-28 13:25:32

by Joerg Roedel

[permalink] [raw]
Subject: Re: [PATCH V3 0/2] Add reattaching support and fix memory leak issue

On Tue, Mar 28, 2023 at 10:57:30AM +0800, Chunyan Zhang wrote:
> Have sent it to you.

I see, can you please re-send the patch-set to me from a properly
configures email domain?

Regards,

Joerg