[Updated PATCH v2] drm: modify drm_global_item_ref to avoid two times of writing ref->object
Huang Rui
ray.huang at amd.com
Wed Sep 7 07:54:35 UTC 2016
On Wed, Sep 07, 2016 at 09:12:29AM +0200, Christian König wrote:
> Am 07.09.2016 um 07:24 schrieb Huang Rui:
> >In previous drm_global_item_ref, there are two times of writing
> >ref->object if item->refcount is 0. So this patch does a minor update
> >to put alloc and init ref firstly, and then to modify the item of glob
> >array. Use "else" to avoid two times of writing ref->object. It can
> >make the code logic more clearly.
> >
> >Signed-off-by: Huang Rui <ray.huang at amd.com>
>
> Well when you update your patch, even when it's just fixing a small
> typo, please increase the version number.
>
> That makes it much easier to track the different instances of a patch.
>
OK.
> A few additional notes below.
>
> >---
> >
> >Changes from V1 -> V2:
> >- Add kfree exceptional handle to avoid memory leak.
> >- Improve code style.
> >
> >---
> > drivers/gpu/drm/drm_global.c | 23 +++++++++++++----------
> > 1 file changed, 13 insertions(+), 10 deletions(-)
> >
> >diff --git a/drivers/gpu/drm/drm_global.c b/drivers/gpu/drm/drm_global.c
> >index 3d2e91c..b181e81 100644
> >--- a/drivers/gpu/drm/drm_global.c
> >+++ b/drivers/gpu/drm/drm_global.c
> >@@ -65,30 +65,33 @@ void drm_global_release(void)
> > int drm_global_item_ref(struct drm_global_reference *ref)
> > {
> >- int ret;
> >+ int ret = 0;
> > struct drm_global_item *item = &glob[ref->global_type];
> > mutex_lock(&item->mutex);
> > if (item->refcount == 0) {
> >- item->object = kzalloc(ref->size, GFP_KERNEL);
> >- if (unlikely(item->object == NULL)) {
> >+ ref->object = kzalloc(ref->size, GFP_KERNEL);
> >+ if (unlikely(ref->object == NULL)) {
> > ret = -ENOMEM;
> >- goto out_err;
> >+ goto out;
> > }
> >-
> >- ref->object = item->object;
> > ret = ref->init(ref);
> > if (unlikely(ret != 0))
> > goto out_err;
> >+ item->object = ref->object;
> >+ } else {
> >+ ref->object = item->object;
> > }
> >+
> > ++item->refcount;
> >- ref->object = item->object;
> >- mutex_unlock(&item->mutex);
> >- return 0;
> >+ goto out;
>
> A goto in the not error path is a bit unusual. Since out_err is only
> used once couldn't you just move the code into the if and then goto
> to out as well?
>
> Alternative you could just duplicate the mutex release in the
> non-error path.
>
Actually, I also have a little concern with "goto" in non-error path. But
as Sean's suggestion, use "goto" can avoid a duplicate mutex release, you
know.
@Sean, if you don't have concern with adding a mutex release below, I will
update it in V3.
---
++item->refcount;
mutex_unlock(&item->mutex);
return 0;
out_err:
kfree(ref->object);
ref->object = NULL;
out:
mutex_unlock(&item->mutex);
return ret;
---
Thanks,
Rui
More information about the dri-devel
mailing list