mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-15 02:05:16 +08:00
drm/amdgpu: improve amdgpu_bo_create_kernel
Make allocating the new BO optional. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
ed5b89c69c
commit
53766e5ada
@ -239,16 +239,21 @@ int amdgpu_bo_create_kernel(struct amdgpu_device *adev,
|
||||
u32 domain, struct amdgpu_bo **bo_ptr,
|
||||
u64 *gpu_addr, void **cpu_addr)
|
||||
{
|
||||
bool free = false;
|
||||
int r;
|
||||
|
||||
if (!*bo_ptr) {
|
||||
r = amdgpu_bo_create(adev, size, align, true, domain,
|
||||
AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED |
|
||||
AMDGPU_GEM_CREATE_VRAM_CONTIGUOUS,
|
||||
NULL, NULL, bo_ptr);
|
||||
if (r) {
|
||||
dev_err(adev->dev, "(%d) failed to allocate kernel bo\n", r);
|
||||
dev_err(adev->dev, "(%d) failed to allocate kernel bo\n",
|
||||
r);
|
||||
return r;
|
||||
}
|
||||
free = true;
|
||||
}
|
||||
|
||||
r = amdgpu_bo_reserve(*bo_ptr, false);
|
||||
if (r) {
|
||||
@ -278,6 +283,7 @@ error_unreserve:
|
||||
amdgpu_bo_unreserve(*bo_ptr);
|
||||
|
||||
error_free:
|
||||
if (free)
|
||||
amdgpu_bo_unref(bo_ptr);
|
||||
|
||||
return r;
|
||||
|
Loading…
Reference in New Issue
Block a user