aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
diff options
context:
space:
mode:
authorDave Airlie <airlied@redhat.com>2018-06-14 21:32:23 -0400
committerDave Airlie <airlied@redhat.com>2018-06-14 21:32:29 -0400
commitdaf0678c2036c918f01e4aa6035629d2debc2f30 (patch)
tree8a6ddd16c351bdf69487e5ca396333447796da8c /drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
parent33ce21d6a2491ef9adb8dc395e3f5bbbfcdc95b5 (diff)
parent5c16f36f6f003b4415237acca59384a074cd8030 (diff)
Merge branch 'drm-next-4.18' of git://people.freedesktop.org/~agd5f/linux into drm-next
Fixes for 4.18. Highlights: - Fixes for gfxoff on Raven - Remove an ATPX quirk now that the root cause is fixed - Runtime PM fixes - Vega20 register header update - Wattman fixes - Misc bug fixes Signed-off-by: Dave Airlie <airlied@redhat.com> Link: https://patchwork.freedesktop.org/patch/msgid/20180614141428.2909-1-alexander.deucher@amd.com
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)