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:
Michal Krol
2007-10-29 16:59:57 +00:00
parent ee295fccdd
commit 7de874ec2c
13 changed files with 104 additions and 65 deletions

View File

@@ -29,6 +29,7 @@
#include "i915_state.h" #include "i915_state.h"
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_util.h" #include "pipe/p_util.h"
#include "pipe/p_inlines.h"
#include "pipe/p_winsys.h" #include "pipe/p_winsys.h"

View File

@@ -29,7 +29,6 @@
#define PIPE_CONTEXT_H #define PIPE_CONTEXT_H
#include "p_state.h" #include "p_state.h"
#include "p_util.h"
struct pipe_state_cache; struct pipe_state_cache;
/** /**
@@ -246,63 +245,4 @@ struct pipe_context {
unsigned flags ); 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 */ #endif /* PIPE_CONTEXT_H */

89
src/mesa/pipe/p_inlines.h Normal file
View 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 */

View File

@@ -27,6 +27,8 @@
/* Authors: Keith Whitwell <keith@tungstengraphics.com> /* Authors: Keith Whitwell <keith@tungstengraphics.com>
*/ */
#include "pipe/p_util.h"
#include "sp_context.h" #include "sp_context.h"
#include "sp_state.h" #include "sp_state.h"

View File

@@ -26,6 +26,7 @@
**************************************************************************/ **************************************************************************/
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_util.h"
#include "sp_context.h" #include "sp_context.h"
#include "sp_state.h" #include "sp_state.h"
#include "pipe/draw/draw_context.h" #include "pipe/draw/draw_context.h"

View File

@@ -29,6 +29,7 @@
* Brian Paul * Brian Paul
*/ */
#include "pipe/p_util.h"
#include "sp_context.h" #include "sp_context.h"
#include "sp_state.h" #include "sp_state.h"
#include "sp_tile_cache.h" #include "sp_tile_cache.h"

View File

@@ -27,6 +27,7 @@
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_util.h" #include "pipe/p_util.h"
#include "pipe/p_inlines.h"
#include "pipe/p_winsys.h" #include "pipe/p_winsys.h"
#include "sp_context.h" #include "sp_context.h"
#include "sp_state.h" #include "sp_state.h"

View File

@@ -32,6 +32,7 @@
#include "pipe/p_context.h" #include "pipe/p_context.h"
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_util.h"
#include "sp_tex_layout.h" #include "sp_tex_layout.h"

View File

@@ -32,13 +32,13 @@
* Brian Paul * Brian Paul
*/ */
#include "sp_context.h" #include "sp_context.h"
#include "sp_surface.h" #include "sp_surface.h"
#include "sp_tex_sample.h" #include "sp_tex_sample.h"
#include "sp_tile_cache.h" #include "sp_tile_cache.h"
#include "pipe/p_context.h" #include "pipe/p_context.h"
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_util.h"
#include "pipe/tgsi/exec/tgsi_exec.h" #include "pipe/tgsi/exec/tgsi_exec.h"

View File

@@ -32,7 +32,8 @@
* Brian Paul * Brian Paul
*/ */
#include "pipe/p_util.h"
#include "pipe/p_inlines.h"
#include "sp_context.h" #include "sp_context.h"
#include "sp_surface.h" #include "sp_surface.h"
#include "sp_tile_cache.h" #include "sp_tile_cache.h"

View File

@@ -50,10 +50,10 @@
* Brian Paul * Brian Paul
*/ */
#include "tgsi_platform.h" #include "pipe/p_compiler.h"
#include "tgsi_core.h"
#include "pipe/p_state.h" #include "pipe/p_state.h"
#include "pipe/p_util.h"
#include "tgsi_core.h"
#define TILE_TOP_LEFT 0 #define TILE_TOP_LEFT 0
#define TILE_TOP_RIGHT 1 #define TILE_TOP_RIGHT 1

View File

@@ -48,6 +48,7 @@
#include "st_mesa_to_tgsi.h" #include "st_mesa_to_tgsi.h"
#include "pipe/p_context.h" #include "pipe/p_context.h"
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_inlines.h"
#include "pipe/p_winsys.h" #include "pipe/p_winsys.h"
#include "shader/prog_instruction.h" #include "shader/prog_instruction.h"

View File

@@ -41,6 +41,7 @@
#include "pipe/p_context.h" #include "pipe/p_context.h"
#include "pipe/p_defines.h" #include "pipe/p_defines.h"
#include "pipe/p_inlines.h"
#include "pipe/p_winsys.h" #include "pipe/p_winsys.h"
#include "st_context.h" #include "st_context.h"
#include "st_cb_fbo.h" #include "st_cb_fbo.h"