aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c15
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
34void amdgpu_gem_object_free(struct drm_gem_object *gobj) 35void 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)