Path: blob/21.2-virgl/src/gallium/auxiliary/pipebuffer/pb_buffer_fenced.h
4565 views
/**************************************************************************1*2* Copyright 2007 VMware, Inc.3* All Rights Reserved.4*5* Permission is hereby granted, free of charge, to any person obtaining a6* copy of this software and associated documentation files (the7* "Software"), to deal in the Software without restriction, including8* without limitation the rights to use, copy, modify, merge, publish,9* distribute, sub license, and/or sell copies of the Software, and to10* permit persons to whom the Software is furnished to do so, subject to11* the following conditions:12*13* The above copyright notice and this permission notice (including the14* next paragraph) shall be included in all copies or substantial portions15* of the Software.16*17* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS18* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF19* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.20* IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR21* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,22* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE23* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.24*25**************************************************************************/2627/**28* \file29* Buffer fencing.30*31* "Fenced buffers" is actually a misnomer. They should be referred as32* "fenceable buffers", i.e, buffers that can be fenced, but I couldn't find33* the word "fenceable" in the dictionary.34*35* A "fenced buffer" is a decorator around a normal buffer, which adds two36* special properties:37* - the ability for the destruction to be delayed by a fence;38* - reference counting.39*40* Usually DMA buffers have a life-time that will extend the life-time of its41* handle. The end-of-life is dictated by the fence signalling.42*43* Between the handle's destruction, and the fence signalling, the buffer is44* stored in a fenced buffer list.45*46* \author Jose Fonseca <[email protected]>47*/4849#ifndef PB_BUFFER_FENCED_H_50#define PB_BUFFER_FENCED_H_515253#include "util/u_debug.h"545556#ifdef __cplusplus57extern "C" {58#endif596061struct pipe_fence_handle;626364/**65* List of buffers which are awaiting fence signalling.66*/67struct fenced_buffer_list;686970struct pb_fence_ops71{72void (*destroy)( struct pb_fence_ops *ops );7374/** Set ptr = fence, with reference counting */75void (*fence_reference)( struct pb_fence_ops *ops,76struct pipe_fence_handle **ptr,77struct pipe_fence_handle *fence );7879/**80* Checks whether the fence has been signalled.81* \param flags driver-specific meaning82* \return zero on success.83*/84int (*fence_signalled)( struct pb_fence_ops *ops,85struct pipe_fence_handle *fence,86unsigned flag );8788/**89* Wait for the fence to finish.90* \param flags driver-specific meaning91* \return zero on success.92*/93int (*fence_finish)( struct pb_fence_ops *ops,94struct pipe_fence_handle *fence,95unsigned flag );96};979899#ifdef __cplusplus100}101#endif102103#endif /*PB_BUFFER_FENCED_H_*/104105106