* re: drm/exynos: merge exynos_drm_buf.c to exynos_drm_gem.c
@ 2015-08-19 8:35 Dan Carpenter
2015-08-19 9:25 ` Joonyoung Shim
0 siblings, 1 reply; 2+ messages in thread
From: Dan Carpenter @ 2015-08-19 8:35 UTC (permalink / raw)
To: jy0922.shim; +Cc: linux-samsung-soc
Hello Joonyoung Shim,
The patch 2a8cb4894540: "drm/exynos: merge exynos_drm_buf.c to
exynos_drm_gem.c" from Aug 16, 2015, leads to the following static
checker warning:
drivers/gpu/drm/exynos/exynos_drm_gem.c:610 exynos_drm_gem_prime_import_sg_table()
error: 'exynos_gem_obj' dereferencing possible ERR_PTR()
drivers/gpu/drm/exynos/exynos_drm_gem.c
562 struct drm_gem_object *
563 exynos_drm_gem_prime_import_sg_table(struct drm_device *dev,
564 struct dma_buf_attachment *attach,
565 struct sg_table *sgt)
566 {
567 struct exynos_drm_gem_obj *exynos_gem_obj;
568 int npages;
569 int ret;
570
571 exynos_gem_obj = exynos_drm_gem_init(dev, attach->dmabuf->size);
572 if (IS_ERR(exynos_gem_obj)) {
573 ret = PTR_ERR(exynos_gem_obj);
exynos_gem_obj is an ERR_PTR.
574 goto err;
575 }
576
577 exynos_gem_obj->dma_addr = sg_dma_address(sgt->sgl);
603
604 return &exynos_gem_obj->base;
605
606 err_free_large:
607 drm_free_large(exynos_gem_obj->pages);
608 err:
609 drm_gem_object_release(&exynos_gem_obj->base);
610 kfree(exynos_gem_obj);
So both the drm_gem_object_release() and kfree() will crash. Do we
really need both? I feel like there should be a single free function
which undoes the exynos_drm_gem_init() function. Also the
exynos_drm_gem_init() has no documentation about how it is supposed to
be freed.
611 return ERR_PTR(ret);
612 }
regards,
dan carpenter
^ permalink raw reply [flat|nested] 2+ messages in thread* Re: drm/exynos: merge exynos_drm_buf.c to exynos_drm_gem.c
2015-08-19 8:35 drm/exynos: merge exynos_drm_buf.c to exynos_drm_gem.c Dan Carpenter
@ 2015-08-19 9:25 ` Joonyoung Shim
0 siblings, 0 replies; 2+ messages in thread
From: Joonyoung Shim @ 2015-08-19 9:25 UTC (permalink / raw)
To: Dan Carpenter; +Cc: linux-samsung-soc
Hi,
On 08/19/2015 05:35 PM, Dan Carpenter wrote:
> Hello Joonyoung Shim,
>
> The patch 2a8cb4894540: "drm/exynos: merge exynos_drm_buf.c to
> exynos_drm_gem.c" from Aug 16, 2015, leads to the following static
> checker warning:
>
> drivers/gpu/drm/exynos/exynos_drm_gem.c:610 exynos_drm_gem_prime_import_sg_table()
> error: 'exynos_gem_obj' dereferencing possible ERR_PTR()
>
Thanks for reporting.
> drivers/gpu/drm/exynos/exynos_drm_gem.c
> 562 struct drm_gem_object *
> 563 exynos_drm_gem_prime_import_sg_table(struct drm_device *dev,
> 564 struct dma_buf_attachment *attach,
> 565 struct sg_table *sgt)
> 566 {
> 567 struct exynos_drm_gem_obj *exynos_gem_obj;
> 568 int npages;
> 569 int ret;
> 570
> 571 exynos_gem_obj = exynos_drm_gem_init(dev, attach->dmabuf->size);
> 572 if (IS_ERR(exynos_gem_obj)) {
> 573 ret = PTR_ERR(exynos_gem_obj);
>
> exynos_gem_obj is an ERR_PTR.
>
> 574 goto err;
My fault, just should return exynos_gem_obj.
> 575 }
> 576
> 577 exynos_gem_obj->dma_addr = sg_dma_address(sgt->sgl);
>
> 603
> 604 return &exynos_gem_obj->base;
> 605
> 606 err_free_large:
> 607 drm_free_large(exynos_gem_obj->pages);
> 608 err:
> 609 drm_gem_object_release(&exynos_gem_obj->base);
> 610 kfree(exynos_gem_obj);
>
> So both the drm_gem_object_release() and kfree() will crash. Do we
> really need both? I feel like there should be a single free function
> which undoes the exynos_drm_gem_init() function. Also the
> exynos_drm_gem_init() has no documentation about how it is supposed to
> be freed.
drm_gem_object_release() and kfree() are functions that undo
exynos_drm_gem_init(). I think there does not have to be a single free
function certainly.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2015-08-19 9:25 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-08-19 8:35 drm/exynos: merge exynos_drm_buf.c to exynos_drm_gem.c Dan Carpenter
2015-08-19 9:25 ` Joonyoung Shim
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.