diff options
| author | Dave Airlie <[email protected]> | 2018-04-11 08:35:41 +1000 | 
|---|---|---|
| committer | Dave Airlie <[email protected]> | 2018-04-11 08:35:41 +1000 | 
| commit | 871e899db19da3dbd17a5d263b555dc5b7d8fed5 (patch) | |
| tree | 97d6232965ab5c5df6d43288a8c744eef9abd58e /drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | |
| parent | c975f17d700445051ad0f87c6822bd15816c587f (diff) | |
| parent | c60e22f7199b5fe7cee4007ccb3b27bb8a506476 (diff) | |
Merge branch 'drm-next-4.17' of git://people.freedesktop.org/~agd5f/linux into drm-next
A few fixes for 4.17:
- Fix a potential use after free in a error case
- Fix pcie lane handling in amdgpu SI dpm
- sdma pipeline sync fix
- A few vega12 cleanups and fixes
- Misc other fixes
* 'drm-next-4.17' of git://people.freedesktop.org/~agd5f/linux:
  drm/amdgpu: Fix memory leaks at amdgpu_init() error path
  drm/amdgpu: Fix PCIe lane width calculation
  drm/radeon: Fix PCIe lane width calculation
  drm/amdgpu/si: implement get/set pcie_lanes asic callback
  drm/amdgpu: Add support for SRBM selection v3
  Revert "drm/amdgpu: Don't change preferred domian when fallback GTT v5"
  drm/amd/powerply: fix power reading on Fiji
  drm/amd/powerplay: Enable ACG SS feature
  drm/amdgpu/sdma: fix mask in emit_pipeline_sync
  drm/amdgpu: Fix KIQ hang on bare metal for device unbind/bind back v2.
  drm/amd/pp: Clean header file in vega12_smumgr.c
  drm/amd/pp: Remove Dead functions on Vega12
  drm/amd/pp: silence a static checker warning
  drm/amdgpu: drop compute ring timeout setting for non-sriov only (v2)
  drm/amdgpu: fix typo of domain fallback
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_object.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 18 | 
1 files changed, 3 insertions, 15 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c index fac4b6067efd..6d08cde8443c 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c @@ -356,7 +356,6 @@ static int amdgpu_bo_do_create(struct amdgpu_device *adev, unsigned long size,  	struct amdgpu_bo *bo;  	unsigned long page_align;  	size_t acc_size; -	u32 domains;  	int r;  	page_align = roundup(byte_align, PAGE_SIZE) >> PAGE_SHIFT; @@ -418,23 +417,12 @@ static int amdgpu_bo_do_create(struct amdgpu_device *adev, unsigned long size,  #endif  	bo->tbo.bdev = &adev->mman.bdev; -	domains = bo->preferred_domains; -retry: -	amdgpu_ttm_placement_from_domain(bo, domains); +	amdgpu_ttm_placement_from_domain(bo, domain); +  	r = ttm_bo_init_reserved(&adev->mman.bdev, &bo->tbo, size, type,  				 &bo->placement, page_align, &ctx, acc_size,  				 NULL, resv, &amdgpu_ttm_bo_destroy); - -	if (unlikely(r && r != -ERESTARTSYS)) { -		if (bo->flags & AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED) { -			bo->flags &= ~AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED; -			goto retry; -		} else if (domains != bo->preferred_domains) { -			domains = bo->allowed_domains; -			goto retry; -		} -	} -	if (unlikely(r)) +	if (unlikely(r != 0))  		return r;  	if (adev->gmc.visible_vram_size < adev->gmc.real_vram_size && |