* [PATCH] Use drm_gem_shmem_unpin() to unpin the backing pages for a shmem GEM
@ 2025-08-27 2:25 Xiaolei Wang
2025-08-27 8:07 ` Boris Brezillon
0 siblings, 1 reply; 2+ messages in thread
From: Xiaolei Wang @ 2025-08-27 2:25 UTC (permalink / raw)
To: maarten.lankhorst, mripard, tzimmermann, dmitry.baryshkov,
airlied, simona, dmitry.osipenko, boris.brezillon
Cc: dri-devel, linux-kernel
Although drm_gem_shmem_free() will decrease the use count
on the backing pages and free backing pages for a GEM object,
the pages_pin_count count is not decremented, which results
in a warning. Therefore, use drm_gem_shmem_unpin() to unpin
the backing pages for a shmem GEM.
WARNING: CPU: 2 PID: 1106 at drivers/gpu/drm/drm_gem_shmem_helper.c:180 drm_gem_shmem_free+0x4d0/0x6f0
Call trace:
drm_gem_shmem_free+0x4d0/0x6f0 (P)
drm_gem_shmem_free_wrapper+0x10/0x1c
__kunit_action_free+0x50/0x70
kunit_remove_resource+0x144/0x1e4
kunit_cleanup+0x64/0xfc
kunit_try_run_case_cleanup+0xa0/0xd4
kunit_generic_run_threadfn_adapter+0x80/0xec
kthread+0x3b8/0x6c0
ret_from_fork+0x10/0x20
Fixes: 93032ae634d4 ("drm/test: add a test suite for GEM objects backed by shmem")
Signed-off-by: Xiaolei Wang <xiaolei.wang@windriver.com>
---
drivers/gpu/drm/tests/drm_gem_shmem_test.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/drivers/gpu/drm/tests/drm_gem_shmem_test.c b/drivers/gpu/drm/tests/drm_gem_shmem_test.c
index 68f2c3162354..e0a9f3a917ed 100644
--- a/drivers/gpu/drm/tests/drm_gem_shmem_test.c
+++ b/drivers/gpu/drm/tests/drm_gem_shmem_test.c
@@ -227,6 +227,7 @@ static void drm_gem_shmem_test_get_pages_sgt(struct kunit *test)
len += sg->length;
}
+ drm_gem_shmem_unpin(shmem);
KUNIT_EXPECT_GE(test, len, TEST_SIZE);
}
--
2.43.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] Use drm_gem_shmem_unpin() to unpin the backing pages for a shmem GEM
2025-08-27 2:25 [PATCH] Use drm_gem_shmem_unpin() to unpin the backing pages for a shmem GEM Xiaolei Wang
@ 2025-08-27 8:07 ` Boris Brezillon
0 siblings, 0 replies; 2+ messages in thread
From: Boris Brezillon @ 2025-08-27 8:07 UTC (permalink / raw)
To: Xiaolei Wang
Cc: maarten.lankhorst, mripard, tzimmermann, dmitry.baryshkov,
airlied, simona, dmitry.osipenko, dri-devel, linux-kernel
On Wed, 27 Aug 2025 10:25:16 +0800
Xiaolei Wang <xiaolei.wang@windriver.com> wrote:
> Although drm_gem_shmem_free() will decrease the use count
> on the backing pages and free backing pages for a GEM object,
> the pages_pin_count count is not decremented, which results
> in a warning. Therefore, use drm_gem_shmem_unpin() to unpin
> the backing pages for a shmem GEM.
With the subject prefixed with "drm/gem-shmem: " this is
Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com>
>
> WARNING: CPU: 2 PID: 1106 at drivers/gpu/drm/drm_gem_shmem_helper.c:180 drm_gem_shmem_free+0x4d0/0x6f0
> Call trace:
> drm_gem_shmem_free+0x4d0/0x6f0 (P)
> drm_gem_shmem_free_wrapper+0x10/0x1c
> __kunit_action_free+0x50/0x70
> kunit_remove_resource+0x144/0x1e4
> kunit_cleanup+0x64/0xfc
> kunit_try_run_case_cleanup+0xa0/0xd4
> kunit_generic_run_threadfn_adapter+0x80/0xec
> kthread+0x3b8/0x6c0
> ret_from_fork+0x10/0x20
>
> Fixes: 93032ae634d4 ("drm/test: add a test suite for GEM objects backed by shmem")
> Signed-off-by: Xiaolei Wang <xiaolei.wang@windriver.com>
> ---
> drivers/gpu/drm/tests/drm_gem_shmem_test.c | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/drivers/gpu/drm/tests/drm_gem_shmem_test.c b/drivers/gpu/drm/tests/drm_gem_shmem_test.c
> index 68f2c3162354..e0a9f3a917ed 100644
> --- a/drivers/gpu/drm/tests/drm_gem_shmem_test.c
> +++ b/drivers/gpu/drm/tests/drm_gem_shmem_test.c
> @@ -227,6 +227,7 @@ static void drm_gem_shmem_test_get_pages_sgt(struct kunit *test)
> len += sg->length;
> }
>
> + drm_gem_shmem_unpin(shmem);
> KUNIT_EXPECT_GE(test, len, TEST_SIZE);
> }
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-08-27 8:08 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-27 2:25 [PATCH] Use drm_gem_shmem_unpin() to unpin the backing pages for a shmem GEM Xiaolei Wang
2025-08-27 8:07 ` Boris Brezillon
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).