2009-12-06 21:46:26 +01:00
/**************************************************************************
*
* Copyright ( c ) 2006 - 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 .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* Authors : Thomas Hellstrom < thellstrom - at - vmware - dot - com >
*/
# ifndef _TTM_EXECBUF_UTIL_H_
# define _TTM_EXECBUF_UTIL_H_
2012-10-02 18:01:25 +01:00
# include <ttm/ttm_bo_api.h>
2009-12-06 21:46:26 +01:00
# include <linux/list.h>
/**
* struct ttm_validate_buffer
*
* @ head : list head for thread - private list .
* @ bo : refcounted buffer object pointer .
2014-09-04 20:01:52 +02:00
* @ shared : should the fence be added shared ?
2009-12-06 21:46:26 +01:00
*/
struct ttm_validate_buffer {
struct list_head head ;
struct ttm_buffer_object * bo ;
2014-09-04 20:01:52 +02:00
bool shared ;
2009-12-06 21:46:26 +01:00
} ;
/**
* function ttm_eu_backoff_reservation
*
2013-06-27 13:48:17 +02:00
* @ ticket : ww_acquire_ctx from reserve call
2009-12-06 21:46:26 +01:00
* @ list : thread private list of ttm_validate_buffer structs .
*
* Undoes all buffer validation reservations for bos pointed to by
* the list entries .
*/
2013-06-27 13:48:17 +02:00
extern void ttm_eu_backoff_reservation ( struct ww_acquire_ctx * ticket ,
struct list_head * list ) ;
2009-12-06 21:46:26 +01:00
/**
* function ttm_eu_reserve_buffers
*
2013-11-15 00:02:54 -08:00
* @ ticket : [ out ] ww_acquire_ctx filled in by call , or NULL if only
* non - blocking reserves should be tried .
2009-12-06 21:46:26 +01:00
* @ list : thread private list of ttm_validate_buffer structs .
2014-01-09 11:03:08 +01:00
* @ intr : should the wait be interruptible
2014-12-03 15:46:48 +01:00
* @ dups : [ out ] optional list of duplicates .
2009-12-06 21:46:26 +01:00
*
* Tries to reserve bos pointed to by the list entries for validation .
* If the function returns 0 , all buffers are marked as " unfenced " ,
* taken off the lru lists and are not synced for write CPU usage .
*
* If the function detects a deadlock due to multiple threads trying to
* reserve the same buffers in reverse order , all threads except one will
* back off and retry . This function may sleep while waiting for
* CPU write reservations to be cleared , and for other threads to
* unreserve their buffers .
*
2014-01-09 11:03:08 +01:00
* If intr is set to true , this function may return - ERESTARTSYS if the
* calling process receives a signal while waiting . In that case , no
* buffers on the list will be reserved upon return .
2009-12-06 21:46:26 +01:00
*
2014-12-03 15:46:48 +01:00
* If dups is non NULL all buffers already reserved by the current thread
* ( e . g . duplicates ) are added to this list , otherwise - EALREADY is returned
* on the first already reserved buffer and all buffers from the list are
* unreserved again .
*
2009-12-06 21:46:26 +01:00
* Buffers reserved by this function should be unreserved by
* a call to either ttm_eu_backoff_reservation ( ) or
* ttm_eu_fence_buffer_objects ( ) when command submission is complete or
* has failed .
*/
2013-06-27 13:48:17 +02:00
extern int ttm_eu_reserve_buffers ( struct ww_acquire_ctx * ticket ,
2014-12-03 15:46:48 +01:00
struct list_head * list , bool intr ,
struct list_head * dups ) ;
2009-12-06 21:46:26 +01:00
/**
* function ttm_eu_fence_buffer_objects .
*
2013-06-27 13:48:17 +02:00
* @ ticket : ww_acquire_ctx from reserve call
2009-12-06 21:46:26 +01:00
* @ list : thread private list of ttm_validate_buffer structs .
2014-04-02 17:14:48 +02:00
* @ fence : The new exclusive fence for the buffers .
2009-12-06 21:46:26 +01:00
*
* This function should be called when command submission is complete , and
* it will add a new sync object to bos pointed to by entries on @ list .
* It also unreserves all buffers , putting them on lru lists .
*
*/
2013-06-27 13:48:17 +02:00
extern void ttm_eu_fence_buffer_objects ( struct ww_acquire_ctx * ticket ,
2014-04-02 17:14:48 +02:00
struct list_head * list ,
struct fence * fence ) ;
2009-12-06 21:46:26 +01:00
# endif