drm/ttm: Be consistent on ttm_bo_init() failures
Call destroy() on _all_ ttm_bo_init() failures, and make sure that behavior is documented in the function description. Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
2b66b50b12
commit
7dfbbdcffe
|
@ -1144,6 +1144,10 @@ int ttm_bo_init(struct ttm_bo_device *bdev,
|
||||||
num_pages = (size + PAGE_SIZE - 1) >> PAGE_SHIFT;
|
num_pages = (size + PAGE_SIZE - 1) >> PAGE_SHIFT;
|
||||||
if (num_pages == 0) {
|
if (num_pages == 0) {
|
||||||
printk(KERN_ERR TTM_PFX "Illegal buffer object size.\n");
|
printk(KERN_ERR TTM_PFX "Illegal buffer object size.\n");
|
||||||
|
if (destroy)
|
||||||
|
(*destroy)(bo);
|
||||||
|
else
|
||||||
|
kfree(bo);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
bo->destroy = destroy;
|
bo->destroy = destroy;
|
||||||
|
|
|
@ -432,6 +432,10 @@ extern void ttm_bo_synccpu_write_release(struct ttm_buffer_object *bo);
|
||||||
* together with the @destroy function,
|
* together with the @destroy function,
|
||||||
* enables driver-specific objects derived from a ttm_buffer_object.
|
* enables driver-specific objects derived from a ttm_buffer_object.
|
||||||
* On successful return, the object kref and list_kref are set to 1.
|
* On successful return, the object kref and list_kref are set to 1.
|
||||||
|
* If a failure occurs, the function will call the @destroy function, or
|
||||||
|
* kfree() if @destroy is NULL. Thus, after a failure, dereferencing @bo is
|
||||||
|
* illegal and will likely cause memory corruption.
|
||||||
|
*
|
||||||
* Returns
|
* Returns
|
||||||
* -ENOMEM: Out of memory.
|
* -ENOMEM: Out of memory.
|
||||||
* -EINVAL: Invalid placement flags.
|
* -EINVAL: Invalid placement flags.
|
||||||
|
|
Loading…
Reference in New Issue