All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2] accel/qaic: fix GEM object refcount leak in qaic_attach_slice_bo_ioctl
@ 2026-06-28 11:51 WenTao Liang
  2026-06-28 11:59 ` sashiko-bot
  0 siblings, 1 reply; 2+ messages in thread
From: WenTao Liang @ 2026-06-28 11:51 UTC (permalink / raw)
  To: dri-devel
  Cc: linux-arm-msm, jeff.hugo, carl.vanderlip, ogabbay, linux-kernel,
	stable, WenTao Liang, Greg KH

drm_gem_object_lookup() acquires a GEM object reference on success. All
error paths correctly release it via put_bo, but the success path returns
without calling drm_gem_object_put(obj). Since list_add_tail does not
transfer ownership, the GEM object reference is permanently leaked on
each successful call.

Suggested-by: Greg KH <gregkh@linuxfoundation.org>
Fixes: 75af0a585af9 ("accel/qaic: Grab ch_lock during QAIC_ATTACH_SLICE_BO")
Cc: stable@vger.kernel.org
Signed-off-by: WenTao Liang <vulab@iscas.ac.cn>
---
Changes in v2:
- Fix patch format based on reviewer feedback
---
 drivers/accel/qaic/qaic_data.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/drivers/accel/qaic/qaic_data.c b/drivers/accel/qaic/qaic_data.c
index 1e4c579d2725..b17df7bf565d 100644
--- a/drivers/accel/qaic/qaic_data.c
+++ b/drivers/accel/qaic/qaic_data.c
@@ -1084,6 +1084,7 @@ int qaic_attach_slice_bo_ioctl(struct drm_device *dev, void *data, struct drm_fi
 
 	bo->sliced = true;
 	list_add_tail(&bo->bo_list, &bo->dbc->bo_lists);
+	drm_gem_object_put(obj);
 	srcu_read_unlock(&dbc->ch_lock, rcu_id);
 	mutex_unlock(&bo->lock);
 	kfree(slice_ent);
-- 
2.39.5 (Apple Git-154)


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH v2] accel/qaic: fix GEM object refcount leak in qaic_attach_slice_bo_ioctl
  2026-06-28 11:51 [PATCH v2] accel/qaic: fix GEM object refcount leak in qaic_attach_slice_bo_ioctl WenTao Liang
@ 2026-06-28 11:59 ` sashiko-bot
  0 siblings, 0 replies; 2+ messages in thread
From: sashiko-bot @ 2026-06-28 11:59 UTC (permalink / raw)
  To: WenTao Liang; +Cc: dri-devel

Thank you for your contribution! Sashiko AI review found 2 potential issue(s) to consider:

New issues:
- [Critical] The patch incorrectly adds `drm_gem_object_put(obj)` to the success path of `qaic_attach_slice_bo_ioctl`, dropping a reference that is supposed to be owned by the `dbc->bo_lists` list, introducing immediate Use-After-Free and Double-Free vulnerabilities.

Pre-existing issues:
- [High] Concurrent modifications to the `dbc->bo_lists` list are not protected by mutual exclusion, leading to linked list corruption.
--

commit bc2c1f25fbb00a819fac019aaf005f851bd75d49
Author: WenTao Liang <vulab@iscas.ac.cn>

accel/qaic: fix GEM object refcount leak in qaic_attach_slice_bo_ioctl

This commit attempts to fix a perceived GEM object reference leak by adding
a drm_gem_object_put() call in the success path of
qaic_attach_slice_bo_ioctl().

> diff --git a/drivers/accel/qaic/qaic_data.c b/drivers/accel/qaic/qaic_data.c
> index ef0351b6dc9b5..46842d4a0848e 100644
> --- a/drivers/accel/qaic/qaic_data.c
> +++ b/drivers/accel/qaic/qaic_data.c
[ ... ]
> @@ -1084,6 +1084,7 @@ int qaic_attach_slice_bo_ioctl(struct drm_device *dev, void *data, struct drm_fi
>  
>  	bo->sliced = true;
>  	list_add_tail(&bo->bo_list, &bo->dbc->bo_lists);

[Severity: High]
This is a pre-existing issue, but does this list_add_tail() race with other
concurrent list modifications?

The dbc->ch_lock only provides a shared read lock via srcu_read_lock(), and
bo->lock is a per-BO mutex. If userspace issues concurrent ioctls on the
same DBC with different BOs, wouldn't they simultaneously modify
dbc->bo_lists without mutual exclusion?

> +	drm_gem_object_put(obj);

[Severity: Critical]
Does adding this put call introduce a use-after-free?

The original code appears to transfer the GEM reference to the
dbc->bo_lists linked list on success, with detach_slice_bo() releasing it
later via drm_gem_object_put(&bo->base):

detach_slice_bo() {
    ...
    list_del(&bo->bo_list);
    drm_gem_object_put(&bo->base);
    ...
}

If we drop the reference early here, couldn't the BO be freed while still
linked in dbc->bo_lists, leading to list corruption during later operations?

Additionally, if this put drops the final reference, won't the subsequent
mutex_unlock(&bo->lock) operate on a destroyed mutex?

>  	srcu_read_unlock(&dbc->ch_lock, rcu_id);
>  	mutex_unlock(&bo->lock);
>  	kfree(slice_ent);

-- 
Sashiko AI review · https://sashiko.dev/#/patchset/20260628115119.44215-1-vulab@iscas.ac.cn?part=1

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2026-06-28 11:59 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-06-28 11:51 [PATCH v2] accel/qaic: fix GEM object refcount leak in qaic_attach_slice_bo_ioctl WenTao Liang
2026-06-28 11:59 ` sashiko-bot

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.