2018-05-07 01:16:26 +02:00
/* SPDX-License-Identifier: GPL-2.0 OR MIT */
2011-09-01 20:18:44 +00:00
/**************************************************************************
*
2018-05-07 01:16:26 +02:00
* Copyright 2011 - 2012 VMware , Inc . , Palo Alto , CA . , USA
2011-09-01 20:18:44 +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 .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifndef _VMWGFX_FENCE_H_
2016-10-25 13:00:45 +01:00
# include <linux/dma-fence.h>
2017-07-05 01:45:40 -07:00
# include <linux/dma-fence-array.h>
2014-03-26 14:07:44 +01:00
2011-09-01 20:18:44 +00:00
# define VMW_FENCE_WAIT_TIMEOUT (5*HZ)
struct vmw_private ;
struct vmw_fence_manager ;
/**
*
*
*/
2011-10-10 12:23:26 +02:00
enum vmw_action_type {
VMW_ACTION_EVENT = 0 ,
VMW_ACTION_MAX
} ;
2011-09-01 20:18:44 +00:00
struct vmw_fence_action {
struct list_head head ;
2011-10-10 12:23:26 +02:00
enum vmw_action_type type ;
2011-09-01 20:18:44 +00:00
void ( * seq_passed ) ( struct vmw_fence_action * action ) ;
void ( * cleanup ) ( struct vmw_fence_action * action ) ;
} ;
struct vmw_fence_obj {
2016-10-25 13:00:45 +01:00
struct dma_fence base ;
2011-09-01 20:18:44 +00:00
struct list_head head ;
struct list_head seq_passed_actions ;
void ( * destroy ) ( struct vmw_fence_obj * fence ) ;
} ;
extern struct vmw_fence_manager *
vmw_fence_manager_init ( struct vmw_private * dev_priv ) ;
extern void vmw_fence_manager_takedown ( struct vmw_fence_manager * fman ) ;
2014-03-26 14:07:44 +01:00
static inline void
vmw_fence_obj_unreference ( struct vmw_fence_obj * * fence_p )
{
struct vmw_fence_obj * fence = * fence_p ;
* fence_p = NULL ;
if ( fence )
2016-10-25 13:00:45 +01:00
dma_fence_put ( & fence - > base ) ;
2014-03-26 14:07:44 +01:00
}
static inline struct vmw_fence_obj *
vmw_fence_obj_reference ( struct vmw_fence_obj * fence )
{
if ( fence )
2016-10-25 13:00:45 +01:00
dma_fence_get ( & fence - > base ) ;
2014-03-26 14:07:44 +01:00
return fence ;
}
2011-09-01 20:18:44 +00:00
2011-10-10 12:23:26 +02:00
extern void vmw_fences_update ( struct vmw_fence_manager * fman ) ;
2011-09-01 20:18:44 +00:00
2014-03-26 13:06:24 +01:00
extern bool vmw_fence_obj_signaled ( struct vmw_fence_obj * fence ) ;
2011-09-01 20:18:44 +00:00
2014-03-26 13:06:24 +01:00
extern int vmw_fence_obj_wait ( struct vmw_fence_obj * fence ,
2011-09-01 20:18:44 +00:00
bool lazy ,
bool interruptible , unsigned long timeout ) ;
extern void vmw_fence_obj_flush ( struct vmw_fence_obj * fence ) ;
extern int vmw_fence_create ( struct vmw_fence_manager * fman ,
uint32_t seqno ,
struct vmw_fence_obj * * p_fence ) ;
extern int vmw_user_fence_create ( struct drm_file * file_priv ,
struct vmw_fence_manager * fman ,
uint32_t sequence ,
struct vmw_fence_obj * * p_fence ,
uint32_t * p_handle ) ;
2017-07-05 01:45:40 -07:00
extern int vmw_wait_dma_fence ( struct vmw_fence_manager * fman ,
struct dma_fence * fence ) ;
2011-09-01 20:18:44 +00:00
extern void vmw_fence_fifo_up ( struct vmw_fence_manager * fman ) ;
extern void vmw_fence_fifo_down ( struct vmw_fence_manager * fman ) ;
extern int vmw_fence_obj_wait_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_fence_obj_signaled_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
extern int vmw_fence_obj_unref_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2011-10-10 12:23:26 +02:00
extern int vmw_fence_event_ioctl ( struct drm_device * dev , void * data ,
struct drm_file * file_priv ) ;
2012-02-09 16:56:48 +01:00
extern int vmw_event_fence_action_queue ( struct drm_file * filee_priv ,
struct vmw_fence_obj * fence ,
struct drm_pending_event * event ,
uint32_t * tv_sec ,
uint32_t * tv_usec ,
bool interruptible ) ;
2011-09-01 20:18:44 +00:00
# endif /* _VMWGFX_FENCE_H_ */