diff options
| author | Christian König <deathsimple@vodafone.de> | 2012-10-23 09:53:19 -0400 |
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2012-10-24 11:41:56 -0400 |
| commit | 0fe7158c8a61ffdd71789de054fbee257c34d054 (patch) | |
| tree | 9c8c93dc152b668131916dfa21e5e19f76b6e2e6 /drivers/gpu | |
| parent | 6c0d112f1fb4abba724065daa8ffbc9f0e171dc1 (diff) | |
drm/radeon: move the retry to gem_object_create
When internal users want VRAM we shouldn't return GART memory instead.
Signed-off-by: Christian König <deathsimple@vodafone.de>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu')
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_gem.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_object.c | 10 |
2 files changed, 7 insertions, 11 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_gem.c b/drivers/gpu/drm/radeon/radeon_gem.c index dfee7bb03ab0..fe5c1f6b7957 100644 --- a/drivers/gpu/drm/radeon/radeon_gem.c +++ b/drivers/gpu/drm/radeon/radeon_gem.c | |||
| @@ -70,11 +70,17 @@ int radeon_gem_object_create(struct radeon_device *rdev, int size, | |||
| 70 | return -ENOMEM; | 70 | return -ENOMEM; |
| 71 | } | 71 | } |
| 72 | 72 | ||
| 73 | retry: | ||
| 73 | r = radeon_bo_create(rdev, size, alignment, kernel, initial_domain, NULL, &robj); | 74 | r = radeon_bo_create(rdev, size, alignment, kernel, initial_domain, NULL, &robj); |
| 74 | if (r) { | 75 | if (r) { |
| 75 | if (r != -ERESTARTSYS) | 76 | if (r != -ERESTARTSYS) { |
| 77 | if (initial_domain == RADEON_GEM_DOMAIN_VRAM) { | ||
| 78 | initial_domain |= RADEON_GEM_DOMAIN_GTT; | ||
| 79 | goto retry; | ||
| 80 | } | ||
| 76 | DRM_ERROR("Failed to allocate GEM object (%d, %d, %u, %d)\n", | 81 | DRM_ERROR("Failed to allocate GEM object (%d, %d, %u, %d)\n", |
| 77 | size, initial_domain, alignment, r); | 82 | size, initial_domain, alignment, r); |
| 83 | } | ||
| 78 | return r; | 84 | return r; |
| 79 | } | 85 | } |
| 80 | *obj = &robj->gem_base; | 86 | *obj = &robj->gem_base; |
diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c index f404944931f5..b91118ccef86 100644 --- a/drivers/gpu/drm/radeon/radeon_object.c +++ b/drivers/gpu/drm/radeon/radeon_object.c | |||
| @@ -123,7 +123,6 @@ int radeon_bo_create(struct radeon_device *rdev, | |||
| 123 | acc_size = ttm_bo_dma_acc_size(&rdev->mman.bdev, size, | 123 | acc_size = ttm_bo_dma_acc_size(&rdev->mman.bdev, size, |
| 124 | sizeof(struct radeon_bo)); | 124 | sizeof(struct radeon_bo)); |
| 125 | 125 | ||
| 126 | retry: | ||
| 127 | bo = kzalloc(sizeof(struct radeon_bo), GFP_KERNEL); | 126 | bo = kzalloc(sizeof(struct radeon_bo), GFP_KERNEL); |
| 128 | if (bo == NULL) | 127 | if (bo == NULL) |
| 129 | return -ENOMEM; | 128 | return -ENOMEM; |
| @@ -145,15 +144,6 @@ retry: | |||
| 145 | acc_size, sg, &radeon_ttm_bo_destroy); | 144 | acc_size, sg, &radeon_ttm_bo_destroy); |
| 146 | up_read(&rdev->pm.mclk_lock); | 145 | up_read(&rdev->pm.mclk_lock); |
| 147 | if (unlikely(r != 0)) { | 146 | if (unlikely(r != 0)) { |
| 148 | if (r != -ERESTARTSYS) { | ||
| 149 | if (domain == RADEON_GEM_DOMAIN_VRAM) { | ||
| 150 | domain |= RADEON_GEM_DOMAIN_GTT; | ||
| 151 | goto retry; | ||
| 152 | } | ||
| 153 | dev_err(rdev->dev, | ||
| 154 | "object_init failed for (%lu, 0x%08X)\n", | ||
| 155 | size, domain); | ||
| 156 | } | ||
| 157 | return r; | 147 | return r; |
| 158 | } | 148 | } |
| 159 | *bo_ptr = bo; | 149 | *bo_ptr = bo; |
