diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | 14 | 
1 files changed, 12 insertions, 2 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c index b3404c43a911..cb07cc3b06ed 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c @@ -255,6 +255,15 @@ static int amdgpu_gem_object_mmap(struct drm_gem_object *obj, struct vm_area_str  	if (bo->flags & AMDGPU_GEM_CREATE_NO_CPU_ACCESS)  		return -EPERM; +	/* Workaround for Thunk bug creating PROT_NONE,MAP_PRIVATE mappings +	 * for debugger access to invisible VRAM. Should have used MAP_SHARED +	 * instead. Clearing VM_MAYWRITE prevents the mapping from ever +	 * becoming writable and makes is_cow_mapping(vm_flags) false. +	 */ +	if (is_cow_mapping(vma->vm_flags) && +	    !(vma->vm_flags & (VM_READ | VM_WRITE | VM_EXEC))) +		vma->vm_flags &= ~VM_MAYWRITE; +  	return drm_gem_ttm_mmap(obj, vma);  } @@ -829,7 +838,8 @@ int amdgpu_gem_op_ioctl(struct drm_device *dev, void *data,  		break;  	}  	case AMDGPU_GEM_OP_SET_PLACEMENT: -		if (robj->prime_shared_count && (args->value & AMDGPU_GEM_DOMAIN_VRAM)) { +		if (robj->tbo.base.import_attach && +		    args->value & AMDGPU_GEM_DOMAIN_VRAM) {  			r = -EINVAL;  			amdgpu_bo_unreserve(robj);  			break; @@ -894,7 +904,7 @@ int amdgpu_mode_dumb_create(struct drm_file *file_priv,  					 DIV_ROUND_UP(args->bpp, 8), 0);  	args->size = (u64)args->pitch * args->height;  	args->size = ALIGN(args->size, PAGE_SIZE); -	domain = amdgpu_bo_get_preferred_pin_domain(adev, +	domain = amdgpu_bo_get_preferred_domain(adev,  				amdgpu_display_supported_domains(adev, flags));  	r = amdgpu_gem_object_create(adev, args->size, 0, domain, flags,  				     ttm_bo_type_device, NULL, &gobj);  |