[Updated PATCH v2] drm: modify drm_global_item_ref to avoid two times of writing ref->object
Christian König
christian.koenig at amd.com
Wed Sep 7 08:02:47 UTC 2016
Am 07.09.2016 um 09:54 schrieb Huang Rui:
> 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.
I would certainly prefer the duplicate mutex release.
>
> @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:
BTW: I would name those labels error_free and error_unlock to make clear
that they are for error handling and what they are supposed to do.
Regards,
Christian.
> mutex_unlock(&item->mutex);
> return ret;
> ---
>
>
> Thanks,
> Rui
More information about the dri-devel
mailing list