2018-05-07 01:16:26 +02:00
// SPDX-License-Identifier: GPL-2.0 OR MIT
2009-12-10 00:19:58 +00:00
/**************************************************************************
*
2018-05-07 01:16:26 +02:00
* Copyright 2009 - 2011 VMware , Inc . , Palo Alto , CA . , USA
2009-12-10 00:19:58 +00:00
*
* Permission is hereby granted , free of charge , to any person obtaining a
* copy of this software and associated documentation files ( the
* " Software " ) , to deal in the Software without restriction , including
* without limitation the rights to use , copy , modify , merge , publish ,
* distribute , sub license , and / or sell copies of the Software , and to
* permit persons to whom the Software is furnished to do so , subject to
* the following conditions :
*
* The above copyright notice and this permission notice ( including the
* next paragraph ) shall be included in all copies or substantial portions
* of the Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NON - INFRINGEMENT . IN NO EVENT SHALL
* THE COPYRIGHT HOLDERS , AUTHORS AND / OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM ,
* DAMAGES OR OTHER LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR
* OTHERWISE , ARISING FROM , OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
* USE OR OTHER DEALINGS IN THE SOFTWARE .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include "vmwgfx_drv.h"
int vmw_mmap ( struct file * filp , struct vm_area_struct * vma )
{
2019-03-27 10:56:08 +01:00
static const struct vm_operations_struct vmw_vm_ops = {
. pfn_mkwrite = vmw_bo_vm_mkwrite ,
. page_mkwrite = vmw_bo_vm_mkwrite ,
. fault = vmw_bo_vm_fault ,
. open = ttm_bo_vm_open ,
. close = ttm_bo_vm_close
} ;
2019-02-07 09:59:30 +01:00
struct drm_file * file_priv = filp - > private_data ;
struct vmw_private * dev_priv = vmw_priv ( file_priv - > minor - > dev ) ;
2019-03-27 10:56:08 +01:00
int ret = ttm_bo_mmap ( filp , vma , & dev_priv - > bdev ) ;
2009-12-10 00:19:58 +00:00
2019-03-27 10:56:08 +01:00
if ( ret )
return ret ;
vma - > vm_ops = & vmw_vm_ops ;
2019-12-04 11:42:15 +01:00
/* Use VM_PFNMAP rather than VM_MIXEDMAP if not a COW mapping */
if ( ( vma - > vm_flags & ( VM_SHARED | VM_MAYWRITE ) ) ! = VM_MAYWRITE )
vma - > vm_flags = ( vma - > vm_flags & ~ VM_MIXEDMAP ) | VM_PFNMAP ;
2019-03-27 10:56:08 +01:00
return 0 ;
2009-12-10 00:19:58 +00:00
}
2018-12-12 11:52:08 +01:00
/* struct vmw_validation_mem callback */
static int vmw_vmt_reserve ( struct vmw_validation_mem * m , size_t size )
{
static struct ttm_operation_ctx ctx = { . interruptible = false ,
. no_wait_gpu = false } ;
struct vmw_private * dev_priv = container_of ( m , struct vmw_private , vvm ) ;
return ttm_mem_global_alloc ( vmw_mem_glob ( dev_priv ) , size , & ctx ) ;
}
/* struct vmw_validation_mem callback */
static void vmw_vmt_unreserve ( struct vmw_validation_mem * m , size_t size )
{
struct vmw_private * dev_priv = container_of ( m , struct vmw_private , vvm ) ;
return ttm_mem_global_free ( vmw_mem_glob ( dev_priv ) , size ) ;
}
/**
* vmw_validation_mem_init_ttm - Interface the validation memory tracker
* to ttm .
* @ dev_priv : Pointer to struct vmw_private . The reason we choose a vmw private
* rather than a struct vmw_validation_mem is to make sure assumption in the
* callbacks that struct vmw_private derives from struct vmw_validation_mem
* holds true .
* @ gran : The recommended allocation granularity
*/
void vmw_validation_mem_init_ttm ( struct vmw_private * dev_priv , size_t gran )
{
struct vmw_validation_mem * vvm = & dev_priv - > vvm ;
vvm - > reserve_mem = vmw_vmt_reserve ;
vvm - > unreserve_mem = vmw_vmt_unreserve ;
vvm - > gran = gran ;
}