diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c index 2c8e27370284..5fb156a01774 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | |||
@@ -30,6 +30,7 @@ | |||
30 | #include <drm/drmP.h> | 30 | #include <drm/drmP.h> |
31 | #include <drm/amdgpu_drm.h> | 31 | #include <drm/amdgpu_drm.h> |
32 | #include "amdgpu.h" | 32 | #include "amdgpu.h" |
33 | #include "amdgpu_display.h" | ||
33 | 34 | ||
34 | void amdgpu_gem_object_free(struct drm_gem_object *gobj) | 35 | void amdgpu_gem_object_free(struct drm_gem_object *gobj) |
35 | { | 36 | { |
@@ -235,6 +236,13 @@ int amdgpu_gem_create_ioctl(struct drm_device *dev, void *data, | |||
235 | /* create a gem object to contain this object in */ | 236 | /* create a gem object to contain this object in */ |
236 | if (args->in.domains & (AMDGPU_GEM_DOMAIN_GDS | | 237 | if (args->in.domains & (AMDGPU_GEM_DOMAIN_GDS | |
237 | AMDGPU_GEM_DOMAIN_GWS | AMDGPU_GEM_DOMAIN_OA)) { | 238 | AMDGPU_GEM_DOMAIN_GWS | AMDGPU_GEM_DOMAIN_OA)) { |
239 | if (flags & AMDGPU_GEM_CREATE_VM_ALWAYS_VALID) { | ||
240 | /* if gds bo is created from user space, it must be | ||
241 | * passed to bo list | ||
242 | */ | ||
243 | DRM_ERROR("GDS bo cannot be per-vm-bo\n"); | ||
244 | return -EINVAL; | ||
245 | } | ||
238 | flags |= AMDGPU_GEM_CREATE_NO_CPU_ACCESS; | 246 | flags |= AMDGPU_GEM_CREATE_NO_CPU_ACCESS; |
239 | if (args->in.domains == AMDGPU_GEM_DOMAIN_GDS) | 247 | if (args->in.domains == AMDGPU_GEM_DOMAIN_GDS) |
240 | size = size << AMDGPU_GDS_SHIFT; | 248 | size = size << AMDGPU_GDS_SHIFT; |
@@ -749,15 +757,16 @@ int amdgpu_mode_dumb_create(struct drm_file *file_priv, | |||
749 | struct amdgpu_device *adev = dev->dev_private; | 757 | struct amdgpu_device *adev = dev->dev_private; |
750 | struct drm_gem_object *gobj; | 758 | struct drm_gem_object *gobj; |
751 | uint32_t handle; | 759 | uint32_t handle; |
760 | u32 domain; | ||
752 | int r; | 761 | int r; |
753 | 762 | ||
754 | args->pitch = amdgpu_align_pitch(adev, args->width, | 763 | args->pitch = amdgpu_align_pitch(adev, args->width, |
755 | DIV_ROUND_UP(args->bpp, 8), 0); | 764 | DIV_ROUND_UP(args->bpp, 8), 0); |
756 | args->size = (u64)args->pitch * args->height; | 765 | args->size = (u64)args->pitch * args->height; |
757 | args->size = ALIGN(args->size, PAGE_SIZE); | 766 | args->size = ALIGN(args->size, PAGE_SIZE); |
758 | 767 | domain = amdgpu_bo_get_preferred_pin_domain(adev, | |
759 | r = amdgpu_gem_object_create(adev, args->size, 0, | 768 | amdgpu_display_supported_domains(adev)); |
760 | AMDGPU_GEM_DOMAIN_VRAM, | 769 | r = amdgpu_gem_object_create(adev, args->size, 0, domain, |
761 | AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED, | 770 | AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED, |
762 | false, NULL, &gobj); | 771 | false, NULL, &gobj); |
763 | if (r) | 772 | if (r) |