diff options
| -rw-r--r-- | src/gallium/auxiliary/Makefile | 1 | ||||
| -rw-r--r-- | src/gallium/auxiliary/SConscript | 1 | ||||
| -rw-r--r-- | src/gallium/auxiliary/target-helpers/swrast_xlib.c | 13 | ||||
| -rw-r--r-- | src/gallium/auxiliary/target-helpers/wrap_screen.c | 65 | ||||
| -rw-r--r-- | src/gallium/auxiliary/target-helpers/wrap_screen.h | 16 | 
5 files changed, 85 insertions, 11 deletions
| diff --git a/src/gallium/auxiliary/Makefile b/src/gallium/auxiliary/Makefile index c84e8d781d..89b15d41b7 100644 --- a/src/gallium/auxiliary/Makefile +++ b/src/gallium/auxiliary/Makefile @@ -133,6 +133,7 @@ C_SOURCES = \  	vl/vl_csc.c \  	vl/vl_shader_build.c \  	target-helpers/swrast_xlib.c +	target-helpers/wrap_screen.c  GALLIVM_SOURCES = \          gallivm/lp_bld_alpha.c \ diff --git a/src/gallium/auxiliary/SConscript b/src/gallium/auxiliary/SConscript index d6185bcb5e..2be16776fb 100644 --- a/src/gallium/auxiliary/SConscript +++ b/src/gallium/auxiliary/SConscript @@ -175,6 +175,7 @@ source = [      'vl/vl_compositor.c',      'vl/vl_csc.c',      'vl/vl_shader_build.c', +    'target-helpers/wrap_screen.c',  ]  if drawllvm: diff --git a/src/gallium/auxiliary/target-helpers/swrast_xlib.c b/src/gallium/auxiliary/target-helpers/swrast_xlib.c index bf30ff68c1..3cab901272 100644 --- a/src/gallium/auxiliary/target-helpers/swrast_xlib.c +++ b/src/gallium/auxiliary/target-helpers/swrast_xlib.c @@ -37,9 +37,8 @@  #include "util/u_debug.h"  #include "softpipe/sp_public.h"  #include "llvmpipe/lp_public.h" -#include "identity/id_public.h" -#include "trace/tr_public.h"  #include "cell/ppu/cell_public.h" +#include "wrap_screen.h"  /* Helper function to build a subset of a driver stack consisting of @@ -84,15 +83,7 @@ swrast_xlib_create_screen( Display *display )     /* Inject any wrapping layers we want to here:      */ -   if (debug_get_bool_option("GALLIUM_WRAP", FALSE)) { -      screen = identity_screen_create(screen); -   } - -   if (debug_get_bool_option("GALLIUM_TRACE", FALSE)) { -      screen = trace_screen_create( screen ); -   } - -   return screen; +   return gallium_wrap_screen( screen );  fail:     if (winsys) diff --git a/src/gallium/auxiliary/target-helpers/wrap_screen.c b/src/gallium/auxiliary/target-helpers/wrap_screen.c new file mode 100644 index 0000000000..5fe3013938 --- /dev/null +++ b/src/gallium/auxiliary/target-helpers/wrap_screen.c @@ -0,0 +1,65 @@ +/************************************************************************** + *  + * Copyright 2007 Tungsten Graphics, Inc., Bismarck, ND., 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 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. + * + * The above copyright notice and this permission notice (including the + * next paragraph) shall be included in all copies or substantial portions + * of the Software. + *  + *  + **************************************************************************/ + +/* + * Authors: + *   Keith Whitwell + */ + +#include "target-helpers/wrap_screen.h" +#include "trace/tr_public.h" +#include "identity/id_public.h" +#include "util/u_debug.h" + + +/* Centralized code to inject common wrapping layers: + */ +struct pipe_screen * +gallium_wrap_screen( struct pipe_screen *screen ) +{ +   /* Screen wrapping functions are required not to fail.  If it is +    * impossible to wrap a screen, the unwrapped screen should be +    * returned instead.  Any failure condition should be returned in +    * an OUT argument. +    * +    * Otherwise it is really messy trying to clean up in this code. +    */ +   if (debug_get_bool_option("GALLIUM_WRAP", FALSE)) { +      screen = identity_screen_create(screen); +   } + +   if (debug_get_bool_option("GALLIUM_TRACE", FALSE)) { +      screen = trace_screen_create( screen ); +   } + +   return screen; +} + + + + diff --git a/src/gallium/auxiliary/target-helpers/wrap_screen.h b/src/gallium/auxiliary/target-helpers/wrap_screen.h new file mode 100644 index 0000000000..7e76beb7c5 --- /dev/null +++ b/src/gallium/auxiliary/target-helpers/wrap_screen.h @@ -0,0 +1,16 @@ +#ifndef WRAP_SCREEN_HELPER_H +#define WRAP_SCREEN_HELPER_H + +#include "pipe/p_compiler.h" + +struct pipe_screen; + +/* Centralized code to inject common wrapping layers.  Other layers + * can be introduced by specific targets, but these are the generally + * helpful ones we probably want everywhere. + */ +struct pipe_screen * +gallium_wrap_screen( struct pipe_screen *screen ); + + +#endif | 
