Make it compile under linux.
Move pipe_region/surface_reference functions to pipe/p_inlines.h. Remove #include "p_util.h" from pipe/p_context.h.
This commit is contained in:
@@ -29,6 +29,7 @@
|
||||
#include "i915_state.h"
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_util.h"
|
||||
#include "pipe/p_inlines.h"
|
||||
#include "pipe/p_winsys.h"
|
||||
|
||||
|
||||
|
@@ -29,7 +29,6 @@
|
||||
#define PIPE_CONTEXT_H
|
||||
|
||||
#include "p_state.h"
|
||||
#include "p_util.h"
|
||||
|
||||
struct pipe_state_cache;
|
||||
/**
|
||||
@@ -246,63 +245,4 @@ struct pipe_context {
|
||||
unsigned flags );
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Set 'ptr' to point to 'region' and update reference counting.
|
||||
* The old thing pointed to, if any, will be unreferenced first.
|
||||
* 'region' may be NULL.
|
||||
*/
|
||||
static INLINE void
|
||||
pipe_region_reference(struct pipe_region **ptr, struct pipe_region *region)
|
||||
{
|
||||
assert(ptr);
|
||||
if (*ptr) {
|
||||
/* unreference the old thing */
|
||||
struct pipe_region *oldReg = *ptr;
|
||||
assert(oldReg->refcount > 0);
|
||||
oldReg->refcount--;
|
||||
if (oldReg->refcount == 0) {
|
||||
/* free the old region */
|
||||
assert(oldReg->map_refcount == 0);
|
||||
/* XXX dereference the region->buffer */
|
||||
FREE( oldReg );
|
||||
}
|
||||
*ptr = NULL;
|
||||
}
|
||||
if (region) {
|
||||
/* reference the new thing */
|
||||
region->refcount++;
|
||||
*ptr = region;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* \sa pipe_region_reference
|
||||
*/
|
||||
static INLINE void
|
||||
pipe_surface_reference(struct pipe_surface **ptr, struct pipe_surface *surf)
|
||||
{
|
||||
assert(ptr);
|
||||
if (*ptr) {
|
||||
/* unreference the old thing */
|
||||
struct pipe_surface *oldSurf = *ptr;
|
||||
assert(oldSurf->refcount > 0);
|
||||
oldSurf->refcount--;
|
||||
if (oldSurf->refcount == 0) {
|
||||
/* free the old region */
|
||||
pipe_region_reference(&oldSurf->region, NULL);
|
||||
FREE( oldSurf );
|
||||
}
|
||||
*ptr = NULL;
|
||||
}
|
||||
if (surf) {
|
||||
/* reference the new thing */
|
||||
surf->refcount++;
|
||||
*ptr = surf;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#endif /* PIPE_CONTEXT_H */
|
||||
|
||||
|
89
src/mesa/pipe/p_inlines.h
Normal file
89
src/mesa/pipe/p_inlines.h
Normal file
@@ -0,0 +1,89 @@
|
||||
/**************************************************************************
|
||||
*
|
||||
* Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas.
|
||||
* 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 TUNGSTEN GRAPHICS 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 P_INLINES_H
|
||||
#define P_INLINES_H
|
||||
|
||||
#include "p_context.h"
|
||||
//#include "p_util.h"
|
||||
|
||||
/**
|
||||
* Set 'ptr' to point to 'region' and update reference counting.
|
||||
* The old thing pointed to, if any, will be unreferenced first.
|
||||
* 'region' may be NULL.
|
||||
*/
|
||||
static INLINE void
|
||||
pipe_region_reference(struct pipe_region **ptr, struct pipe_region *region)
|
||||
{
|
||||
assert(ptr);
|
||||
if (*ptr) {
|
||||
/* unreference the old thing */
|
||||
struct pipe_region *oldReg = *ptr;
|
||||
assert(oldReg->refcount > 0);
|
||||
oldReg->refcount--;
|
||||
if (oldReg->refcount == 0) {
|
||||
/* free the old region */
|
||||
assert(oldReg->map_refcount == 0);
|
||||
/* XXX dereference the region->buffer */
|
||||
FREE( oldReg );
|
||||
}
|
||||
*ptr = NULL;
|
||||
}
|
||||
if (region) {
|
||||
/* reference the new thing */
|
||||
region->refcount++;
|
||||
*ptr = region;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* \sa pipe_region_reference
|
||||
*/
|
||||
static INLINE void
|
||||
pipe_surface_reference(struct pipe_surface **ptr, struct pipe_surface *surf)
|
||||
{
|
||||
assert(ptr);
|
||||
if (*ptr) {
|
||||
/* unreference the old thing */
|
||||
struct pipe_surface *oldSurf = *ptr;
|
||||
assert(oldSurf->refcount > 0);
|
||||
oldSurf->refcount--;
|
||||
if (oldSurf->refcount == 0) {
|
||||
/* free the old region */
|
||||
pipe_region_reference(&oldSurf->region, NULL);
|
||||
FREE( oldSurf );
|
||||
}
|
||||
*ptr = NULL;
|
||||
}
|
||||
if (surf) {
|
||||
/* reference the new thing */
|
||||
surf->refcount++;
|
||||
*ptr = surf;
|
||||
}
|
||||
}
|
||||
|
||||
#endif /* P_INLINES_H */
|
@@ -27,6 +27,8 @@
|
||||
|
||||
/* Authors: Keith Whitwell <keith@tungstengraphics.com>
|
||||
*/
|
||||
|
||||
#include "pipe/p_util.h"
|
||||
#include "sp_context.h"
|
||||
#include "sp_state.h"
|
||||
|
||||
|
@@ -26,6 +26,7 @@
|
||||
**************************************************************************/
|
||||
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_util.h"
|
||||
#include "sp_context.h"
|
||||
#include "sp_state.h"
|
||||
#include "pipe/draw/draw_context.h"
|
||||
|
@@ -29,6 +29,7 @@
|
||||
* Brian Paul
|
||||
*/
|
||||
|
||||
#include "pipe/p_util.h"
|
||||
#include "sp_context.h"
|
||||
#include "sp_state.h"
|
||||
#include "sp_tile_cache.h"
|
||||
|
@@ -27,6 +27,7 @@
|
||||
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_util.h"
|
||||
#include "pipe/p_inlines.h"
|
||||
#include "pipe/p_winsys.h"
|
||||
#include "sp_context.h"
|
||||
#include "sp_state.h"
|
||||
|
@@ -32,6 +32,7 @@
|
||||
|
||||
#include "pipe/p_context.h"
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_util.h"
|
||||
#include "sp_tex_layout.h"
|
||||
|
||||
|
||||
|
@@ -32,13 +32,13 @@
|
||||
* Brian Paul
|
||||
*/
|
||||
|
||||
|
||||
#include "sp_context.h"
|
||||
#include "sp_surface.h"
|
||||
#include "sp_tex_sample.h"
|
||||
#include "sp_tile_cache.h"
|
||||
#include "pipe/p_context.h"
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_util.h"
|
||||
#include "pipe/tgsi/exec/tgsi_exec.h"
|
||||
|
||||
|
||||
|
@@ -32,7 +32,8 @@
|
||||
* Brian Paul
|
||||
*/
|
||||
|
||||
|
||||
#include "pipe/p_util.h"
|
||||
#include "pipe/p_inlines.h"
|
||||
#include "sp_context.h"
|
||||
#include "sp_surface.h"
|
||||
#include "sp_tile_cache.h"
|
||||
|
@@ -50,10 +50,10 @@
|
||||
* Brian Paul
|
||||
*/
|
||||
|
||||
#include "tgsi_platform.h"
|
||||
#include "tgsi_core.h"
|
||||
#include "pipe/p_compiler.h"
|
||||
#include "pipe/p_state.h"
|
||||
|
||||
#include "pipe/p_util.h"
|
||||
#include "tgsi_core.h"
|
||||
|
||||
#define TILE_TOP_LEFT 0
|
||||
#define TILE_TOP_RIGHT 1
|
||||
|
@@ -48,6 +48,7 @@
|
||||
#include "st_mesa_to_tgsi.h"
|
||||
#include "pipe/p_context.h"
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_inlines.h"
|
||||
#include "pipe/p_winsys.h"
|
||||
#include "shader/prog_instruction.h"
|
||||
|
||||
|
@@ -41,6 +41,7 @@
|
||||
|
||||
#include "pipe/p_context.h"
|
||||
#include "pipe/p_defines.h"
|
||||
#include "pipe/p_inlines.h"
|
||||
#include "pipe/p_winsys.h"
|
||||
#include "st_context.h"
|
||||
#include "st_cb_fbo.h"
|
||||
|
Reference in New Issue
Block a user