2009-12-10 00:19:58 +00:00
/**************************************************************************
*
* Copyright © 2009 VMware , Inc . , Palo Alto , CA . , USA
* All Rights Reserved .
*
* 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 .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifndef _VMWGFX_DRV_H_
# define _VMWGFX_DRV_H_
# include "vmwgfx_reg.h"
2012-10-02 18:01:07 +01:00
# include <drm/drmP.h>
# include <drm/vmwgfx_drm.h>
# include <drm/drm_hashtab.h>
# include <linux/suspend.h>
# include <drm/ttm/ttm_bo_driver.h>
# include <drm/ttm/ttm_object.h>
# include <drm/ttm/ttm_lock.h>
# include <drm/ttm/ttm_execbuf_util.h>
# include <drm/ttm/ttm_module.h>
2011-09-01 20:18:44 +00:00
# include "vmwgfx_fence.h"
2009-12-10 00:19:58 +00:00
2012-02-09 16:56:49 +01:00
# define VMWGFX_DRIVER_DATE "20120209"
2011-09-01 20:18:45 +00:00
# define VMWGFX_DRIVER_MAJOR 2
2012-02-09 16:56:49 +01:00
# define VMWGFX_DRIVER_MINOR 4
2010-02-09 19:41:55 +00:00
# define VMWGFX_DRIVER_PATCHLEVEL 0
2009-12-10 00:19:58 +00:00
# define VMWGFX_FILE_PAGE_OFFSET 0x00100000
# define VMWGFX_FIFO_STATIC_SIZE (1024*1024)
# define VMWGFX_MAX_RELOCATIONS 2048
2011-08-31 07:42:54 +00:00
# define VMWGFX_MAX_VALIDATIONS 2048
2010-06-01 11:38:17 +02:00
# define VMWGFX_MAX_DISPLAYS 16
2011-08-31 07:42:54 +00:00
# define VMWGFX_CMD_BOUNCE_INIT_SIZE 32768
2009-12-10 00:19:58 +00:00
2012-11-21 10:49:52 +01:00
/*
* Perhaps we should have sysfs entries for these .
*/
# define VMWGFX_NUM_GB_CONTEXT 256
# define VMWGFX_NUM_GB_SHADER 20000
# define VMWGFX_NUM_GB_SURFACE 32768
# define VMWGFX_NUM_MOB (VMWGFX_NUM_GB_CONTEXT +\
VMWGFX_NUM_GB_SHADER + \
VMWGFX_NUM_GB_SURFACE )
2010-10-26 21:21:47 +02:00
# define VMW_PL_GMR TTM_PL_PRIV0
# define VMW_PL_FLAG_GMR TTM_PL_FLAG_PRIV0
2012-11-21 11:06:22 +01:00
# define VMW_PL_MOB TTM_PL_PRIV1
# define VMW_PL_FLAG_MOB TTM_PL_FLAG_PRIV1
2010-10-26 21:21:47 +02:00
2011-09-01 20:18:44 +00:00
# define VMW_RES_CONTEXT ttm_driver_type0
# define VMW_RES_SURFACE ttm_driver_type1
# define VMW_RES_STREAM ttm_driver_type2
# define VMW_RES_FENCE ttm_driver_type3
2009-12-10 00:19:58 +00:00
struct vmw_fpriv {
struct drm_master * locked_master ;
struct ttm_object_file * tfile ;
2012-02-09 16:56:42 +01:00
struct list_head fence_events ;
2009-12-10 00:19:58 +00:00
} ;
struct vmw_dma_buffer {
struct ttm_buffer_object base ;
2012-11-20 12:19:35 +00:00
struct list_head res_list ;
2009-12-10 00:19:58 +00:00
} ;
2012-11-20 12:19:35 +00:00
/**
* struct vmw_validate_buffer - Carries validation info about buffers .
*
* @ base : Validation info for TTM .
* @ hash : Hash entry for quick lookup of the TTM buffer object .
*
* This structure contains also driver private validation info
* on top of the info needed by TTM .
*/
struct vmw_validate_buffer {
struct ttm_validate_buffer base ;
struct drm_hash_item hash ;
2012-11-21 11:19:53 +01:00
bool validate_as_mob ;
2012-11-20 12:19:35 +00:00
} ;
struct vmw_res_func ;
2009-12-10 00:19:58 +00:00
struct vmw_resource {
struct kref kref ;
struct vmw_private * dev_priv ;
int id ;
bool avail ;
2012-11-20 12:19:35 +00:00
unsigned long backup_size ;
bool res_dirty ; /* Protected by backup buffer reserved */
bool backup_dirty ; /* Protected by backup buffer reserved */
struct vmw_dma_buffer * backup ;
unsigned long backup_offset ;
const struct vmw_res_func * func ;
struct list_head lru_head ; /* Protected by the resource lock */
struct list_head mob_head ; /* Protected by @backup reserved */
2009-12-10 00:19:58 +00:00
void ( * res_free ) ( struct vmw_resource * res ) ;
2012-11-20 12:19:35 +00:00
void ( * hw_destroy ) ( struct vmw_resource * res ) ;
} ;
enum vmw_res_type {
vmw_res_context ,
vmw_res_surface ,
vmw_res_stream ,
vmw_res_max
2009-12-10 00:19:58 +00:00
} ;
struct vmw_cursor_snooper {
struct drm_crtc * crtc ;
size_t age ;
uint32_t * image ;
} ;
2011-10-04 20:13:26 +02:00
struct vmw_framebuffer ;
2011-10-04 20:13:33 +02:00
struct vmw_surface_offset ;
2011-10-04 20:13:26 +02:00
2009-12-10 00:19:58 +00:00
struct vmw_surface {
struct vmw_resource res ;
uint32_t flags ;
uint32_t format ;
uint32_t mip_levels [ DRM_VMW_MAX_SURFACE_FACES ] ;
2012-11-20 12:19:35 +00:00
struct drm_vmw_size base_size ;
2009-12-10 00:19:58 +00:00
struct drm_vmw_size * sizes ;
uint32_t num_sizes ;
2010-01-30 03:38:08 +00:00
bool scanout ;
2009-12-10 00:19:58 +00:00
/* TODO so far just a extra pointer */
struct vmw_cursor_snooper snooper ;
2011-10-04 20:13:33 +02:00
struct vmw_surface_offset * offsets ;
2012-11-20 12:19:35 +00:00
SVGA3dTextureFilter autogen_filter ;
uint32_t multisample_count ;
2009-12-10 00:19:58 +00:00
} ;
2011-09-01 20:18:42 +00:00
struct vmw_marker_queue {
2010-05-28 11:21:57 +02:00
struct list_head head ;
struct timespec lag ;
struct timespec lag_time ;
spinlock_t lock ;
} ;
2009-12-10 00:19:58 +00:00
struct vmw_fifo_state {
unsigned long reserved_size ;
__le32 * dynamic_buffer ;
__le32 * static_buffer ;
unsigned long static_buffer_size ;
bool using_bounce_buffer ;
uint32_t capabilities ;
2010-02-08 09:57:25 +00:00
struct mutex fifo_mutex ;
2009-12-10 00:19:58 +00:00
struct rw_semaphore rwsem ;
2011-09-01 20:18:42 +00:00
struct vmw_marker_queue marker_queue ;
2009-12-10 00:19:58 +00:00
} ;
struct vmw_relocation {
SVGAGuestPtr * location ;
uint32_t index ;
} ;
2012-11-20 12:19:35 +00:00
/**
* struct vmw_res_cache_entry - resource information cache entry
*
* @ valid : Whether the entry is valid , which also implies that the execbuf
* code holds a reference to the resource , and it ' s placed on the
* validation list .
* @ handle : User - space handle of a resource .
* @ res : Non - ref - counted pointer to the resource .
*
* Used to avoid frequent repeated user - space handle lookups of the
* same resource .
*/
struct vmw_res_cache_entry {
bool valid ;
uint32_t handle ;
struct vmw_resource * res ;
struct vmw_resource_val_node * node ;
} ;
2013-10-24 01:49:26 -07:00
/**
* enum vmw_dma_map_mode - indicate how to perform TTM page dma mappings .
*/
enum vmw_dma_map_mode {
vmw_dma_phys , /* Use physical page addresses */
vmw_dma_alloc_coherent , /* Use TTM coherent pages */
vmw_dma_map_populate , /* Unmap from DMA just after unpopulate */
vmw_dma_map_bind , /* Unmap from DMA just before unbind */
vmw_dma_map_max
} ;
/**
* struct vmw_sg_table - Scatter / gather table for binding , with additional
* device - specific information .
*
* @ sgt : Pointer to a struct sg_table with binding information
* @ num_regions : Number of regions with device - address contigous pages
*/
struct vmw_sg_table {
enum vmw_dma_map_mode mode ;
struct page * * pages ;
const dma_addr_t * addrs ;
struct sg_table * sgt ;
unsigned long num_regions ;
unsigned long num_pages ;
} ;
/**
* struct vmw_piter - Page iterator that iterates over a list of pages
* and DMA addresses that could be either a scatter - gather list or
* arrays
*
* @ pages : Array of page pointers to the pages .
* @ addrs : DMA addresses to the pages if coherent pages are used .
* @ iter : Scatter - gather page iterator . Current position in SG list .
* @ i : Current position in arrays .
* @ num_pages : Number of pages total .
* @ next : Function to advance the iterator . Returns false if past the list
* of pages , true otherwise .
* @ dma_address : Function to return the DMA address of the current page .
*/
struct vmw_piter {
struct page * * pages ;
const dma_addr_t * addrs ;
struct sg_page_iter iter ;
unsigned long i ;
unsigned long num_pages ;
bool ( * next ) ( struct vmw_piter * ) ;
dma_addr_t ( * dma_address ) ( struct vmw_piter * ) ;
struct page * ( * page ) ( struct vmw_piter * ) ;
} ;
2009-12-10 00:19:58 +00:00
struct vmw_sw_context {
2012-11-20 12:19:35 +00:00
struct drm_open_hash res_ht ;
bool res_ht_initialized ;
2011-10-04 20:13:17 +02:00
bool kernel ; /**< is the called made from the kernel */
2009-12-10 00:19:58 +00:00
struct ttm_object_file * tfile ;
struct list_head validate_nodes ;
struct vmw_relocation relocs [ VMWGFX_MAX_RELOCATIONS ] ;
uint32_t cur_reloc ;
2012-11-20 12:19:35 +00:00
struct vmw_validate_buffer val_bufs [ VMWGFX_MAX_VALIDATIONS ] ;
2009-12-10 00:19:58 +00:00
uint32_t cur_val_buf ;
2011-08-31 07:42:54 +00:00
uint32_t * cmd_bounce ;
uint32_t cmd_bounce_size ;
2011-10-04 20:13:31 +02:00
struct list_head resource_list ;
2011-10-04 20:13:30 +02:00
uint32_t fence_flags ;
struct ttm_buffer_object * cur_query_bo ;
2012-11-20 12:19:35 +00:00
struct list_head res_relocations ;
uint32_t * buf_start ;
struct vmw_res_cache_entry res_cache [ vmw_res_max ] ;
struct vmw_resource * last_query_ctx ;
bool needs_post_query_barrier ;
struct vmw_resource * error_resource ;
2009-12-10 00:19:58 +00:00
} ;
struct vmw_legacy_display ;
struct vmw_overlay ;
struct vmw_master {
struct ttm_lock lock ;
2010-10-05 12:43:03 +02:00
struct mutex fb_surf_mutex ;
struct list_head fb_surf ;
2009-12-10 00:19:58 +00:00
} ;
2010-06-01 11:38:17 +02:00
struct vmw_vga_topology_state {
uint32_t width ;
uint32_t height ;
uint32_t primary ;
uint32_t pos_x ;
uint32_t pos_y ;
} ;
2009-12-10 00:19:58 +00:00
struct vmw_private {
struct ttm_bo_device bdev ;
struct ttm_bo_global_ref bo_global_ref ;
2010-03-09 10:56:52 +10:00
struct drm_global_reference mem_global_ref ;
2009-12-10 00:19:58 +00:00
struct vmw_fifo_state fifo ;
struct drm_device * dev ;
unsigned long vmw_chipset ;
unsigned int io_start ;
uint32_t vram_start ;
uint32_t vram_size ;
2012-11-21 10:32:36 +01:00
uint32_t prim_bb_mem ;
2009-12-10 00:19:58 +00:00
uint32_t mmio_start ;
uint32_t mmio_size ;
uint32_t fb_max_width ;
uint32_t fb_max_height ;
2012-02-09 16:56:46 +01:00
uint32_t initial_width ;
uint32_t initial_height ;
2009-12-10 00:19:58 +00:00
__le32 __iomem * mmio_virt ;
int mmio_mtrr ;
uint32_t capabilities ;
uint32_t max_gmr_ids ;
2011-08-31 07:42:53 +00:00
uint32_t max_gmr_pages ;
2012-11-21 11:06:22 +01:00
uint32_t max_mob_pages ;
2011-08-31 07:42:53 +00:00
uint32_t memory_size ;
2010-10-26 21:21:47 +02:00
bool has_gmr ;
2012-11-21 10:49:52 +01:00
bool has_mob ;
2009-12-10 00:19:58 +00:00
struct mutex hw_mutex ;
/*
* VGA registers .
*/
2010-06-01 11:38:17 +02:00
struct vmw_vga_topology_state vga_save [ VMWGFX_MAX_DISPLAYS ] ;
2009-12-10 00:19:58 +00:00
uint32_t vga_width ;
uint32_t vga_height ;
uint32_t vga_bpp ;
2010-06-01 11:38:17 +02:00
uint32_t vga_bpl ;
2010-05-28 11:21:59 +02:00
uint32_t vga_pitchlock ;
2009-12-10 00:19:58 +00:00
2010-06-01 11:38:17 +02:00
uint32_t num_displays ;
2009-12-10 00:19:58 +00:00
/*
* Framebuffer info .
*/
void * fb_info ;
struct vmw_legacy_display * ldu_priv ;
2011-10-04 20:13:22 +02:00
struct vmw_screen_object_display * sou_priv ;
2009-12-10 00:19:58 +00:00
struct vmw_overlay * overlay_priv ;
/*
* Context and surface management .
*/
rwlock_t resource_lock ;
2012-11-20 12:19:35 +00:00
struct idr res_idr [ vmw_res_max ] ;
2009-12-10 00:19:58 +00:00
/*
* Block lastclose from racing with firstopen .
*/
struct mutex init_mutex ;
/*
* A resource manager for kernel - only surfaces and
* contexts .
*/
struct ttm_object_device * tdev ;
/*
* Fencing and IRQs .
*/
2011-09-01 20:18:42 +00:00
atomic_t marker_seq ;
2009-12-10 00:19:58 +00:00
wait_queue_head_t fence_queue ;
wait_queue_head_t fifo_queue ;
2011-09-01 20:18:43 +00:00
int fence_queue_waiters ; /* Protected by hw_mutex */
2011-10-10 12:23:26 +02:00
int goal_queue_waiters ; /* Protected by hw_mutex */
2009-12-10 00:19:58 +00:00
atomic_t fifo_queue_waiters ;
2011-09-01 20:18:42 +00:00
uint32_t last_read_seqno ;
2009-12-10 00:19:58 +00:00
spinlock_t irq_lock ;
2011-09-01 20:18:44 +00:00
struct vmw_fence_manager * fman ;
2011-10-10 12:23:26 +02:00
uint32_t irq_mask ;
2009-12-10 00:19:58 +00:00
/*
* Device state
*/
uint32_t traces_state ;
uint32_t enable_state ;
uint32_t config_done_state ;
/**
* Execbuf
*/
/**
* Protected by the cmdbuf mutex .
*/
struct vmw_sw_context ctx ;
struct mutex cmdbuf_mutex ;
/**
* Operating mode .
*/
bool stealth ;
2010-10-01 10:21:48 +02:00
bool enable_fb ;
2009-12-10 00:19:58 +00:00
/**
* Master management .
*/
struct vmw_master * active_master ;
struct vmw_master fbdev_master ;
2010-01-13 22:28:43 +01:00
struct notifier_block pm_nb ;
2010-10-05 12:43:00 +02:00
bool suspended ;
2010-10-01 10:21:48 +02:00
struct mutex release_mutex ;
uint32_t num_3d_resources ;
2011-10-04 20:13:30 +02:00
/*
* Query processing . These members
* are protected by the cmdbuf mutex .
*/
struct ttm_buffer_object * dummy_query_bo ;
struct ttm_buffer_object * pinned_bo ;
uint32_t query_cid ;
2012-11-20 12:19:35 +00:00
uint32_t query_cid_valid ;
2011-10-04 20:13:30 +02:00
bool dummy_query_bo_pinned ;
2011-10-04 20:13:33 +02:00
/*
* Surface swapping . The " surface_lru " list is protected by the
* resource lock in order to be able to destroy a surface and take
* it off the lru atomically . " used_memory_size " is currently
* protected by the cmdbuf mutex for simplicity .
*/
2012-11-20 12:19:35 +00:00
struct list_head res_lru [ vmw_res_max ] ;
2011-10-04 20:13:33 +02:00
uint32_t used_memory_size ;
2013-10-24 01:49:26 -07:00
/*
* DMA mapping stuff .
*/
enum vmw_dma_map_mode map_mode ;
2012-11-21 10:49:52 +01:00
/*
* Guest Backed stuff
*/
struct ttm_buffer_object * otable_bo ;
struct vmw_otable * otables ;
2009-12-10 00:19:58 +00:00
} ;
2012-11-20 12:19:35 +00:00
static inline struct vmw_surface * vmw_res_to_srf ( struct vmw_resource * res )
{
return container_of ( res , struct vmw_surface , res ) ;
}
2009-12-10 00:19:58 +00:00
static inline struct vmw_private * vmw_priv ( struct drm_device * dev )
{
return ( struct vmw_private * ) dev - > dev_private ;
}
static inline struct vmw_fpriv * vmw_fpriv ( struct drm_file * file_priv )
{
return ( struct vmw_fpriv * ) file_priv - > driver_priv ;
}
static inline struct vmw_master * vmw_master ( struct drm_master * master )
{
return ( struct vmw_master * ) master - > driver_priv ;
}
static inline void vmw_write ( struct vmw_private * dev_priv ,
unsigned int offset , uint32_t value )
{
outl ( offset , dev_priv - > io_start + VMWGFX_INDEX_PORT ) ;
outl ( value , dev_priv - > io_start + VMWGFX_VALUE_PORT ) ;
}
static inline uint32_t vmw_read ( struct vmw_private * dev_priv ,
unsigned int offset )
{
uint32_t val ;
outl ( offset , dev_priv - > io_start + VMWGFX_INDEX_PORT ) ;
val = inl ( dev_priv - > io_start + VMWGFX_VALUE_PORT ) ;
return val ;
}
2011-08-31 07:42:52 +00:00
int vmw_3d_resource_inc ( struct vmw_private * dev_priv , bool unhide_svga ) ;
void vmw_3d_resource_dec ( struct vmw_private * dev_priv , bool hide_svga ) ;
2010-10-01 10:21:48 +02:00
2009-12-10 00:19:58 +00:00
/**
* GMR utilities - vmwgfx_gmr . c
*/
extern int vmw_gmr_bind ( struct vmw_private * dev_priv ,
2013-10-24 01:49:26 -07:00
const struct vmw_sg_table * vsgt ,
2010-10-26 21:21:47 +02:00
unsigned long num_pages ,
int gmr_id ) ;
2009-12-10 00:19:58 +00:00
extern void vmw_gmr_unbind ( struct vmw_private * dev_priv , int gmr_id ) ;
/**
* Resource utilities - vmwgfx_resource . c
*/
2012-11-20 12:19:35 +00:00
struct vmw_user_resource_conv ;
extern const struct vmw_user_resource_conv * user_surface_converter ;
extern const struct vmw_user_resource_conv * user_context_converter ;
2009-12-10 00:19:58 +00:00
extern struct vmw_resource * vmw_context_alloc ( struct vmw_private * dev_priv ) ;
extern void vmw_resource_unreference ( struct vmw_resource * * p_res ) ;
extern struct vmw_resource * vmw_resource_reference ( struct vmw_resource * res ) ;
2012-11-20 12:19:35 +00:00
extern int vmw_resource_validate ( struct vmw_resource * res ) ;
extern int vmw_resource_reserve ( struct vmw_resource * res , bool no_backup ) ;
extern bool vmw_resource_needs_backup ( const struct vmw_resource * res ) ;
2009-12-10 00:19:58 +00:00
extern int vmw_context_destroy_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_context_define_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_context_check ( struct vmw_private * dev_priv ,
struct ttm_object_file * tfile ,
2011-08-31 07:42:54 +00:00
int id ,
struct vmw_resource * * p_res ) ;
2011-11-28 13:19:11 +01:00
extern int vmw_user_lookup_handle ( struct vmw_private * dev_priv ,
struct ttm_object_file * tfile ,
uint32_t handle ,
struct vmw_surface * * out_surf ,
struct vmw_dma_buffer * * out_buf ) ;
2012-11-20 12:19:35 +00:00
extern int vmw_user_resource_lookup_handle (
struct vmw_private * dev_priv ,
struct ttm_object_file * tfile ,
uint32_t handle ,
const struct vmw_user_resource_conv * converter ,
struct vmw_resource * * p_res ) ;
2009-12-10 00:19:58 +00:00
extern void vmw_surface_res_free ( struct vmw_resource * res ) ;
extern int vmw_surface_destroy_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_surface_define_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_surface_reference_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_surface_check ( struct vmw_private * dev_priv ,
struct ttm_object_file * tfile ,
2009-12-22 16:53:41 +01:00
uint32_t handle , int * id ) ;
2011-10-04 20:13:33 +02:00
extern int vmw_surface_validate ( struct vmw_private * dev_priv ,
struct vmw_surface * srf ) ;
2009-12-10 00:19:58 +00:00
extern void vmw_dmabuf_bo_free ( struct ttm_buffer_object * bo ) ;
extern int vmw_dmabuf_init ( struct vmw_private * dev_priv ,
struct vmw_dma_buffer * vmw_bo ,
size_t size , struct ttm_placement * placement ,
bool interuptable ,
void ( * bo_free ) ( struct ttm_buffer_object * bo ) ) ;
2012-11-21 16:04:18 +01:00
extern int vmw_user_dmabuf_verify_access ( struct ttm_buffer_object * bo ,
struct ttm_object_file * tfile ) ;
2009-12-10 00:19:58 +00:00
extern int vmw_dmabuf_alloc_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_dmabuf_unref_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern uint32_t vmw_dmabuf_validate_node ( struct ttm_buffer_object * bo ,
uint32_t cur_validate_node ) ;
extern void vmw_dmabuf_validate_clear ( struct ttm_buffer_object * bo ) ;
extern int vmw_user_dmabuf_lookup ( struct ttm_object_file * tfile ,
uint32_t id , struct vmw_dma_buffer * * out ) ;
extern int vmw_stream_claim_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_stream_unref_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_user_stream_lookup ( struct vmw_private * dev_priv ,
struct ttm_object_file * tfile ,
uint32_t * inout_id ,
struct vmw_resource * * out ) ;
2012-11-20 12:19:35 +00:00
extern void vmw_resource_unreserve ( struct vmw_resource * res ,
struct vmw_dma_buffer * new_backup ,
unsigned long new_backup_offset ) ;
extern void vmw_resource_move_notify ( struct ttm_buffer_object * bo ,
struct ttm_mem_reg * mem ) ;
extern void vmw_fence_single_bo ( struct ttm_buffer_object * bo ,
struct vmw_fence_obj * fence ) ;
extern void vmw_resource_evict_all ( struct vmw_private * dev_priv ) ;
2009-12-10 00:19:58 +00:00
2011-10-04 20:13:21 +02:00
/**
* DMA buffer helper routines - vmwgfx_dmabuf . c
*/
extern int vmw_dmabuf_to_placement ( struct vmw_private * vmw_priv ,
struct vmw_dma_buffer * bo ,
struct ttm_placement * placement ,
bool interruptible ) ;
extern int vmw_dmabuf_to_vram ( struct vmw_private * dev_priv ,
struct vmw_dma_buffer * buf ,
bool pin , bool interruptible ) ;
extern int vmw_dmabuf_to_vram_or_gmr ( struct vmw_private * dev_priv ,
struct vmw_dma_buffer * buf ,
bool pin , bool interruptible ) ;
extern int vmw_dmabuf_to_start_of_vram ( struct vmw_private * vmw_priv ,
struct vmw_dma_buffer * bo ,
bool pin , bool interruptible ) ;
extern int vmw_dmabuf_unpin ( struct vmw_private * vmw_priv ,
struct vmw_dma_buffer * bo ,
bool interruptible ) ;
2011-10-04 20:13:28 +02:00
extern void vmw_bo_get_guest_ptr ( const struct ttm_buffer_object * buf ,
SVGAGuestPtr * ptr ) ;
2011-10-04 20:13:30 +02:00
extern void vmw_bo_pin ( struct ttm_buffer_object * bo , bool pin ) ;
2009-12-10 00:19:58 +00:00
/**
* Misc Ioctl functionality - vmwgfx_ioctl . c
*/
extern int vmw_getparam_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2011-09-01 20:18:41 +00:00
extern int vmw_get_cap_3d_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2011-10-04 20:13:26 +02:00
extern int vmw_present_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_present_readback_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2011-10-10 12:23:27 +02:00
extern unsigned int vmw_fops_poll ( struct file * filp ,
struct poll_table_struct * wait ) ;
extern ssize_t vmw_fops_read ( struct file * filp , char __user * buffer ,
size_t count , loff_t * offset ) ;
2009-12-10 00:19:58 +00:00
/**
* Fifo utilities - vmwgfx_fifo . c
*/
extern int vmw_fifo_init ( struct vmw_private * dev_priv ,
struct vmw_fifo_state * fifo ) ;
extern void vmw_fifo_release ( struct vmw_private * dev_priv ,
struct vmw_fifo_state * fifo ) ;
extern void * vmw_fifo_reserve ( struct vmw_private * dev_priv , uint32_t bytes ) ;
extern void vmw_fifo_commit ( struct vmw_private * dev_priv , uint32_t bytes ) ;
extern int vmw_fifo_send_fence ( struct vmw_private * dev_priv ,
2011-09-01 20:18:42 +00:00
uint32_t * seqno ) ;
2009-12-10 00:19:58 +00:00
extern void vmw_fifo_ping_host ( struct vmw_private * dev_priv , uint32_t reason ) ;
2010-01-30 03:38:06 +00:00
extern bool vmw_fifo_have_3d ( struct vmw_private * dev_priv ) ;
2010-05-28 11:21:59 +02:00
extern bool vmw_fifo_have_pitchlock ( struct vmw_private * dev_priv ) ;
2011-10-04 20:13:30 +02:00
extern int vmw_fifo_emit_dummy_query ( struct vmw_private * dev_priv ,
uint32_t cid ) ;
2009-12-10 00:19:58 +00:00
/**
* TTM glue - vmwgfx_ttm_glue . c
*/
extern int vmw_ttm_global_init ( struct vmw_private * dev_priv ) ;
extern void vmw_ttm_global_release ( struct vmw_private * dev_priv ) ;
extern int vmw_mmap ( struct file * filp , struct vm_area_struct * vma ) ;
/**
* TTM buffer object driver - vmwgfx_buffer . c
*/
2013-11-28 01:46:56 -08:00
extern const size_t vmw_tt_size ;
2009-12-10 00:19:58 +00:00
extern struct ttm_placement vmw_vram_placement ;
extern struct ttm_placement vmw_vram_ne_placement ;
2010-01-16 16:05:05 +01:00
extern struct ttm_placement vmw_vram_sys_placement ;
2010-10-26 21:21:47 +02:00
extern struct ttm_placement vmw_vram_gmr_placement ;
2011-10-04 20:13:21 +02:00
extern struct ttm_placement vmw_vram_gmr_ne_placement ;
2009-12-10 00:19:58 +00:00
extern struct ttm_placement vmw_sys_placement ;
2012-11-21 10:49:52 +01:00
extern struct ttm_placement vmw_sys_ne_placement ;
2011-10-04 20:13:21 +02:00
extern struct ttm_placement vmw_evictable_placement ;
2011-10-04 20:13:33 +02:00
extern struct ttm_placement vmw_srf_placement ;
2012-11-21 11:19:53 +01:00
extern struct ttm_placement vmw_mob_placement ;
2009-12-10 00:19:58 +00:00
extern struct ttm_bo_driver vmw_bo_driver ;
extern int vmw_dma_quiescent ( struct drm_device * dev ) ;
2013-10-24 01:49:26 -07:00
extern void vmw_piter_start ( struct vmw_piter * viter ,
const struct vmw_sg_table * vsgt ,
unsigned long p_offs ) ;
/**
* vmw_piter_next - Advance the iterator one page .
*
* @ viter : Pointer to the iterator to advance .
*
* Returns false if past the list of pages , true otherwise .
*/
static inline bool vmw_piter_next ( struct vmw_piter * viter )
{
return viter - > next ( viter ) ;
}
/**
* vmw_piter_dma_addr - Return the DMA address of the current page .
*
* @ viter : Pointer to the iterator
*
* Returns the DMA address of the page pointed to by @ viter .
*/
static inline dma_addr_t vmw_piter_dma_addr ( struct vmw_piter * viter )
{
return viter - > dma_address ( viter ) ;
}
/**
* vmw_piter_page - Return a pointer to the current page .
*
* @ viter : Pointer to the iterator
*
* Returns the DMA address of the page pointed to by @ viter .
*/
static inline struct page * vmw_piter_page ( struct vmw_piter * viter )
{
return viter - > page ( viter ) ;
}
2009-12-10 00:19:58 +00:00
/**
* Command submission - vmwgfx_execbuf . c
*/
extern int vmw_execbuf_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2011-10-04 20:13:17 +02:00
extern int vmw_execbuf_process ( struct drm_file * file_priv ,
struct vmw_private * dev_priv ,
void __user * user_commands ,
void * kernel_commands ,
uint32_t command_size ,
uint64_t throttle_us ,
struct drm_vmw_fence_rep __user
2012-02-09 16:56:43 +01:00
* user_fence_rep ,
struct vmw_fence_obj * * out_fence ) ;
2012-11-20 12:19:35 +00:00
extern void __vmw_execbuf_release_pinned_bo ( struct vmw_private * dev_priv ,
struct vmw_fence_obj * fence ) ;
extern void vmw_execbuf_release_pinned_bo ( struct vmw_private * dev_priv ) ;
2011-10-04 20:13:30 +02:00
2011-10-04 20:13:33 +02:00
extern int vmw_execbuf_fence_commands ( struct drm_file * file_priv ,
struct vmw_private * dev_priv ,
struct vmw_fence_obj * * p_fence ,
uint32_t * p_handle ) ;
2011-10-10 12:23:26 +02:00
extern void vmw_execbuf_copy_fence_user ( struct vmw_private * dev_priv ,
struct vmw_fpriv * vmw_fp ,
int ret ,
struct drm_vmw_fence_rep __user
* user_fence_rep ,
struct vmw_fence_obj * fence ,
uint32_t fence_handle ) ;
2011-10-04 20:13:33 +02:00
2009-12-10 00:19:58 +00:00
/**
* IRQs and wating - vmwgfx_irq . c
*/
2013-12-11 11:34:42 +01:00
extern irqreturn_t vmw_irq_handler ( int irq , void * arg ) ;
2011-09-01 20:18:42 +00:00
extern int vmw_wait_seqno ( struct vmw_private * dev_priv , bool lazy ,
uint32_t seqno , bool interruptible ,
unsigned long timeout ) ;
2009-12-10 00:19:58 +00:00
extern void vmw_irq_preinstall ( struct drm_device * dev ) ;
extern int vmw_irq_postinstall ( struct drm_device * dev ) ;
extern void vmw_irq_uninstall ( struct drm_device * dev ) ;
2011-09-01 20:18:42 +00:00
extern bool vmw_seqno_passed ( struct vmw_private * dev_priv ,
uint32_t seqno ) ;
2009-12-10 00:19:58 +00:00
extern int vmw_fallback_wait ( struct vmw_private * dev_priv ,
bool lazy ,
bool fifo_idle ,
2011-09-01 20:18:42 +00:00
uint32_t seqno ,
2009-12-10 00:19:58 +00:00
bool interruptible ,
unsigned long timeout ) ;
2011-09-01 20:18:42 +00:00
extern void vmw_update_seqno ( struct vmw_private * dev_priv ,
2010-05-28 11:21:57 +02:00
struct vmw_fifo_state * fifo_state ) ;
2011-09-01 20:18:44 +00:00
extern void vmw_seqno_waiter_add ( struct vmw_private * dev_priv ) ;
extern void vmw_seqno_waiter_remove ( struct vmw_private * dev_priv ) ;
2011-10-10 12:23:26 +02:00
extern void vmw_goal_waiter_add ( struct vmw_private * dev_priv ) ;
extern void vmw_goal_waiter_remove ( struct vmw_private * dev_priv ) ;
2010-05-28 11:21:57 +02:00
/**
2011-09-01 20:18:42 +00:00
* Rudimentary fence - like objects currently used only for throttling -
* vmwgfx_marker . c
2010-05-28 11:21:57 +02:00
*/
2011-09-01 20:18:42 +00:00
extern void vmw_marker_queue_init ( struct vmw_marker_queue * queue ) ;
extern void vmw_marker_queue_takedown ( struct vmw_marker_queue * queue ) ;
extern int vmw_marker_push ( struct vmw_marker_queue * queue ,
uint32_t seqno ) ;
extern int vmw_marker_pull ( struct vmw_marker_queue * queue ,
uint32_t signaled_seqno ) ;
2010-05-28 11:21:57 +02:00
extern int vmw_wait_lag ( struct vmw_private * dev_priv ,
2011-09-01 20:18:42 +00:00
struct vmw_marker_queue * queue , uint32_t us ) ;
2009-12-10 00:19:58 +00:00
/**
* Kernel framebuffer - vmwgfx_fb . c
*/
int vmw_fb_init ( struct vmw_private * vmw_priv ) ;
int vmw_fb_close ( struct vmw_private * dev_priv ) ;
int vmw_fb_off ( struct vmw_private * vmw_priv ) ;
int vmw_fb_on ( struct vmw_private * vmw_priv ) ;
/**
* Kernel modesetting - vmwgfx_kms . c
*/
int vmw_kms_init ( struct vmw_private * dev_priv ) ;
int vmw_kms_close ( struct vmw_private * dev_priv ) ;
int vmw_kms_save_vga ( struct vmw_private * vmw_priv ) ;
int vmw_kms_restore_vga ( struct vmw_private * vmw_priv ) ;
int vmw_kms_cursor_bypass_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
void vmw_kms_cursor_post_execbuf ( struct vmw_private * dev_priv ) ;
void vmw_kms_cursor_snoop ( struct vmw_surface * srf ,
struct ttm_object_file * tfile ,
struct ttm_buffer_object * bo ,
SVGA3dCmdHeader * header ) ;
2011-08-31 07:42:50 +00:00
int vmw_kms_write_svga ( struct vmw_private * vmw_priv ,
unsigned width , unsigned height , unsigned pitch ,
unsigned bpp , unsigned depth ) ;
2010-10-05 12:43:03 +02:00
void vmw_kms_idle_workqueues ( struct vmw_master * vmaster ) ;
2010-10-05 12:43:04 +02:00
bool vmw_kms_validate_mode_vram ( struct vmw_private * dev_priv ,
uint32_t pitch ,
uint32_t height ) ;
2010-10-01 10:21:49 +02:00
u32 vmw_get_vblank_counter ( struct drm_device * dev , int crtc ) ;
2011-10-17 11:59:45 +02:00
int vmw_enable_vblank ( struct drm_device * dev , int crtc ) ;
void vmw_disable_vblank ( struct drm_device * dev , int crtc ) ;
2011-10-04 20:13:26 +02:00
int vmw_kms_present ( struct vmw_private * dev_priv ,
struct drm_file * file_priv ,
struct vmw_framebuffer * vfb ,
struct vmw_surface * surface ,
uint32_t sid , int32_t destX , int32_t destY ,
struct drm_vmw_rect * clips ,
uint32_t num_clips ) ;
int vmw_kms_readback ( struct vmw_private * dev_priv ,
struct drm_file * file_priv ,
struct vmw_framebuffer * vfb ,
struct drm_vmw_fence_rep __user * user_fence_rep ,
struct drm_vmw_rect * clips ,
uint32_t num_clips ) ;
2011-10-25 23:35:53 +02:00
int vmw_kms_update_layout_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2009-12-10 00:19:58 +00:00
2012-08-28 01:53:54 +00:00
int vmw_dumb_create ( struct drm_file * file_priv ,
struct drm_device * dev ,
struct drm_mode_create_dumb * args ) ;
int vmw_dumb_map_offset ( struct drm_file * file_priv ,
struct drm_device * dev , uint32_t handle ,
uint64_t * offset ) ;
int vmw_dumb_destroy ( struct drm_file * file_priv ,
struct drm_device * dev ,
uint32_t handle ) ;
2009-12-10 00:19:58 +00:00
/**
* Overlay control - vmwgfx_overlay . c
*/
int vmw_overlay_init ( struct vmw_private * dev_priv ) ;
int vmw_overlay_close ( struct vmw_private * dev_priv ) ;
int vmw_overlay_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
int vmw_overlay_stop_all ( struct vmw_private * dev_priv ) ;
int vmw_overlay_resume_all ( struct vmw_private * dev_priv ) ;
int vmw_overlay_pause_all ( struct vmw_private * dev_priv ) ;
int vmw_overlay_claim ( struct vmw_private * dev_priv , uint32_t * out ) ;
int vmw_overlay_unref ( struct vmw_private * dev_priv , uint32_t stream_id ) ;
int vmw_overlay_num_overlays ( struct vmw_private * dev_priv ) ;
int vmw_overlay_num_free_overlays ( struct vmw_private * dev_priv ) ;
2010-10-26 21:21:47 +02:00
/**
* GMR Id manager
*/
extern const struct ttm_mem_type_manager_func vmw_gmrid_manager_func ;
2013-11-13 01:50:46 -08:00
/**
* Prime - vmwgfx_prime . c
*/
extern const struct dma_buf_ops vmw_prime_dmabuf_ops ;
extern int vmw_prime_fd_to_handle ( struct drm_device * dev ,
struct drm_file * file_priv ,
int fd , u32 * handle ) ;
extern int vmw_prime_handle_to_fd ( struct drm_device * dev ,
struct drm_file * file_priv ,
uint32_t handle , uint32_t flags ,
int * prime_fd ) ;
2012-11-21 10:49:52 +01:00
/*
* MemoryOBject management - vmwgfx_mob . c
*/
struct vmw_mob ;
extern int vmw_mob_bind ( struct vmw_private * dev_priv , struct vmw_mob * mob ,
struct page * * data_pages , unsigned long num_data_pages ,
int32_t mob_id ) ;
extern void vmw_mob_unbind ( struct vmw_private * dev_priv ,
struct vmw_mob * mob ) ;
extern void vmw_mob_destroy ( struct vmw_mob * mob ) ;
extern struct vmw_mob * vmw_mob_create ( unsigned long data_pages ) ;
extern int vmw_otables_setup ( struct vmw_private * dev_priv ) ;
extern void vmw_otables_takedown ( struct vmw_private * dev_priv ) ;
2013-11-13 01:50:46 -08:00
2009-12-10 00:19:58 +00:00
/**
* Inline helper functions
*/
static inline void vmw_surface_unreference ( struct vmw_surface * * srf )
{
struct vmw_surface * tmp_srf = * srf ;
struct vmw_resource * res = & tmp_srf - > res ;
* srf = NULL ;
vmw_resource_unreference ( & res ) ;
}
static inline struct vmw_surface * vmw_surface_reference ( struct vmw_surface * srf )
{
( void ) vmw_resource_reference ( & srf - > res ) ;
return srf ;
}
static inline void vmw_dmabuf_unreference ( struct vmw_dma_buffer * * buf )
{
struct vmw_dma_buffer * tmp_buf = * buf ;
2012-11-09 12:26:15 +00:00
2009-12-10 00:19:58 +00:00
* buf = NULL ;
2012-11-09 12:26:15 +00:00
if ( tmp_buf ! = NULL ) {
struct ttm_buffer_object * bo = & tmp_buf - > base ;
2009-12-10 00:19:58 +00:00
2012-11-09 12:26:15 +00:00
ttm_bo_unref ( & bo ) ;
}
2009-12-10 00:19:58 +00:00
}
static inline struct vmw_dma_buffer * vmw_dmabuf_reference ( struct vmw_dma_buffer * buf )
{
if ( ttm_bo_reference ( & buf - > base ) )
return buf ;
return NULL ;
}
2011-09-01 20:18:44 +00:00
static inline struct ttm_mem_global * vmw_mem_glob ( struct vmw_private * dev_priv )
{
return ( struct ttm_mem_global * ) dev_priv - > mem_global_ref . object ;
}
2009-12-10 00:19:58 +00:00
# endif