Subversion Repositories Kolibri OS

Compare Revisions

Regard whitespace Rev 4357 → Rev 4358

/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/Makefile.am
0,0 → 1,14
include $(top_srcdir)/src/gallium/Automake.inc
 
AM_CFLAGS = \
$(GALLIUM_CFLAGS) \
$(VISIBILITY_CFLAGS)
 
noinst_LTLIBRARIES = libtrace.la
 
libtrace_la_SOURCES = \
tr_context.c \
tr_dump.c \
tr_dump_state.c \
tr_screen.c \
tr_texture.c
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/Makefile.in
0,0 → 1,766
# Makefile.in generated by automake 1.14 from Makefile.am.
# @configure_input@
 
# Copyright (C) 1994-2013 Free Software Foundation, Inc.
 
# This Makefile.in is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.
 
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
# PARTICULAR PURPOSE.
 
@SET_MAKE@
 
VPATH = @srcdir@
am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)'
am__make_running_with_option = \
case $${target_option-} in \
?) ;; \
*) echo "am__make_running_with_option: internal error: invalid" \
"target option '$${target_option-}' specified" >&2; \
exit 1;; \
esac; \
has_opt=no; \
sane_makeflags=$$MAKEFLAGS; \
if $(am__is_gnu_make); then \
sane_makeflags=$$MFLAGS; \
else \
case $$MAKEFLAGS in \
*\\[\ \ ]*) \
bs=\\; \
sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
| sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
esac; \
fi; \
skip_next=no; \
strip_trailopt () \
{ \
flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
}; \
for flg in $$sane_makeflags; do \
test $$skip_next = yes && { skip_next=no; continue; }; \
case $$flg in \
*=*|--*) continue;; \
-*I) strip_trailopt 'I'; skip_next=yes;; \
-*I?*) strip_trailopt 'I';; \
-*O) strip_trailopt 'O'; skip_next=yes;; \
-*O?*) strip_trailopt 'O';; \
-*l) strip_trailopt 'l'; skip_next=yes;; \
-*l?*) strip_trailopt 'l';; \
-[dEDm]) skip_next=yes;; \
-[JT]) skip_next=yes;; \
esac; \
case $$flg in \
*$$target_option*) has_opt=yes; break;; \
esac; \
done; \
test $$has_opt = yes
am__make_dryrun = (target_option=n; $(am__make_running_with_option))
am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
pkgdatadir = $(datadir)/@PACKAGE@
pkgincludedir = $(includedir)/@PACKAGE@
pkglibdir = $(libdir)/@PACKAGE@
pkglibexecdir = $(libexecdir)/@PACKAGE@
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
install_sh_DATA = $(install_sh) -c -m 644
install_sh_PROGRAM = $(install_sh) -c
install_sh_SCRIPT = $(install_sh) -c
INSTALL_HEADER = $(INSTALL_DATA)
transform = $(program_transform_name)
NORMAL_INSTALL = :
PRE_INSTALL = :
POST_INSTALL = :
NORMAL_UNINSTALL = :
PRE_UNINSTALL = :
POST_UNINSTALL = :
build_triplet = @build@
host_triplet = @host@
target_triplet = @target@
DIST_COMMON = $(top_srcdir)/src/gallium/Automake.inc \
$(srcdir)/Makefile.in $(srcdir)/Makefile.am \
$(top_srcdir)/bin/depcomp README
subdir = src/gallium/drivers/trace
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
am__aclocal_m4_deps = $(top_srcdir)/m4/ax_prog_bison.m4 \
$(top_srcdir)/m4/ax_prog_cc_for_build.m4 \
$(top_srcdir)/m4/ax_prog_cxx_for_build.m4 \
$(top_srcdir)/m4/ax_prog_flex.m4 \
$(top_srcdir)/m4/ax_pthread.m4 \
$(top_srcdir)/m4/ax_python_module.m4 \
$(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
$(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
$(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
$(ACLOCAL_M4)
mkinstalldirs = $(install_sh) -d
CONFIG_CLEAN_FILES =
CONFIG_CLEAN_VPATH_FILES =
LTLIBRARIES = $(noinst_LTLIBRARIES)
libtrace_la_LIBADD =
am_libtrace_la_OBJECTS = tr_context.lo tr_dump.lo tr_dump_state.lo \
tr_screen.lo tr_texture.lo
libtrace_la_OBJECTS = $(am_libtrace_la_OBJECTS)
AM_V_lt = $(am__v_lt_@AM_V@)
am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
am__v_lt_0 = --silent
am__v_lt_1 =
AM_V_P = $(am__v_P_@AM_V@)
am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
am__v_P_0 = false
am__v_P_1 = :
AM_V_GEN = $(am__v_GEN_@AM_V@)
am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
am__v_GEN_0 = @echo " GEN " $@;
am__v_GEN_1 =
AM_V_at = $(am__v_at_@AM_V@)
am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
am__v_at_0 = @
am__v_at_1 =
DEFAULT_INCLUDES = -I.@am__isrc@
depcomp = $(SHELL) $(top_srcdir)/bin/depcomp
am__depfiles_maybe = depfiles
am__mv = mv -f
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
$(AM_CFLAGS) $(CFLAGS)
AM_V_CC = $(am__v_CC_@AM_V@)
am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
am__v_CC_0 = @echo " CC " $@;
am__v_CC_1 =
CCLD = $(CC)
LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
$(AM_LDFLAGS) $(LDFLAGS) -o $@
AM_V_CCLD = $(am__v_CCLD_@AM_V@)
am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
am__v_CCLD_0 = @echo " CCLD " $@;
am__v_CCLD_1 =
SOURCES = $(libtrace_la_SOURCES)
DIST_SOURCES = $(libtrace_la_SOURCES)
am__can_run_installinfo = \
case $$AM_UPDATE_INFO_DIR in \
n|no|NO) false;; \
*) (install-info --version) >/dev/null 2>&1;; \
esac
am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
# Read a list of newline-separated strings from the standard input,
# and print each of them once, without duplicates. Input order is
# *not* preserved.
am__uniquify_input = $(AWK) '\
BEGIN { nonempty = 0; } \
{ items[$$0] = 1; nonempty = 1; } \
END { if (nonempty) { for (i in items) print i; }; } \
'
# Make sure the list of sources is unique. This is necessary because,
# e.g., the same source file might be shared among _SOURCES variables
# for different programs/libraries.
am__define_uniq_tagged_files = \
list='$(am__tagged_files)'; \
unique=`for i in $$list; do \
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
done | $(am__uniquify_input)`
ETAGS = etags
CTAGS = ctags
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
ACLOCAL = @ACLOCAL@
AMTAR = @AMTAR@
AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
AR = @AR@
AUTOCONF = @AUTOCONF@
AUTOHEADER = @AUTOHEADER@
AUTOMAKE = @AUTOMAKE@
AWK = @AWK@
BUILD_EXEEXT = @BUILD_EXEEXT@
BUILD_OBJEXT = @BUILD_OBJEXT@
CC = @CC@
CCAS = @CCAS@
CCASDEPMODE = @CCASDEPMODE@
CCASFLAGS = @CCASFLAGS@
CCDEPMODE = @CCDEPMODE@
CC_FOR_BUILD = @CC_FOR_BUILD@
CFLAGS = @CFLAGS@
CFLAGS_FOR_BUILD = @CFLAGS_FOR_BUILD@
CLANG_RESOURCE_DIR = @CLANG_RESOURCE_DIR@
CLOCK_LIB = @CLOCK_LIB@
CPP = @CPP@
CPPFLAGS = @CPPFLAGS@
CPPFLAGS_FOR_BUILD = @CPPFLAGS_FOR_BUILD@
CPP_FOR_BUILD = @CPP_FOR_BUILD@
CXX = @CXX@
CXXCPP = @CXXCPP@
CXXCPPFLAGS_FOR_BUILD = @CXXCPPFLAGS_FOR_BUILD@
CXXCPP_FOR_BUILD = @CXXCPP_FOR_BUILD@
CXXDEPMODE = @CXXDEPMODE@
CXXFLAGS = @CXXFLAGS@
CXXFLAGS_FOR_BUILD = @CXXFLAGS_FOR_BUILD@
CXX_FOR_BUILD = @CXX_FOR_BUILD@
CYGPATH_W = @CYGPATH_W@
DEFINES = @DEFINES@
DEFINES_FOR_BUILD = @DEFINES_FOR_BUILD@
DEFS = @DEFS@
DEPDIR = @DEPDIR@
DLLTOOL = @DLLTOOL@
DLOPEN_LIBS = @DLOPEN_LIBS@
DRI2PROTO_CFLAGS = @DRI2PROTO_CFLAGS@
DRI2PROTO_LIBS = @DRI2PROTO_LIBS@
DRIGL_CFLAGS = @DRIGL_CFLAGS@
DRIGL_LIBS = @DRIGL_LIBS@
DRI_DRIVER_INSTALL_DIR = @DRI_DRIVER_INSTALL_DIR@
DRI_DRIVER_SEARCH_DIR = @DRI_DRIVER_SEARCH_DIR@
DRI_LIB_DEPS = @DRI_LIB_DEPS@
DRI_PC_REQ_PRIV = @DRI_PC_REQ_PRIV@
DSYMUTIL = @DSYMUTIL@
DUMPBIN = @DUMPBIN@
ECHO_C = @ECHO_C@
ECHO_N = @ECHO_N@
ECHO_T = @ECHO_T@
EGL_CFLAGS = @EGL_CFLAGS@
EGL_CLIENT_APIS = @EGL_CLIENT_APIS@
EGL_DRIVER_INSTALL_DIR = @EGL_DRIVER_INSTALL_DIR@
EGL_LIB_DEPS = @EGL_LIB_DEPS@
EGL_LIB_GLOB = @EGL_LIB_GLOB@
EGL_LIB_NAME = @EGL_LIB_NAME@
EGL_NATIVE_PLATFORM = @EGL_NATIVE_PLATFORM@
EGL_PLATFORMS = @EGL_PLATFORMS@
EGREP = @EGREP@
ELF_LIB = @ELF_LIB@
EXEEXT = @EXEEXT@
EXPAT_INCLUDES = @EXPAT_INCLUDES@
FGREP = @FGREP@
FREEDRENO_CFLAGS = @FREEDRENO_CFLAGS@
FREEDRENO_LIBS = @FREEDRENO_LIBS@
GALLIUM_DRI_LIB_DEPS = @GALLIUM_DRI_LIB_DEPS@
GALLIUM_PIPE_LOADER_DEFINES = @GALLIUM_PIPE_LOADER_DEFINES@
GALLIUM_PIPE_LOADER_LIBS = @GALLIUM_PIPE_LOADER_LIBS@
GALLIUM_PIPE_LOADER_XCB_CFLAGS = @GALLIUM_PIPE_LOADER_XCB_CFLAGS@
GALLIUM_PIPE_LOADER_XCB_LIBS = @GALLIUM_PIPE_LOADER_XCB_LIBS@
GBM_PC_LIB_PRIV = @GBM_PC_LIB_PRIV@
GBM_PC_REQ_PRIV = @GBM_PC_REQ_PRIV@
GLAPI_LIB_GLOB = @GLAPI_LIB_GLOB@
GLAPI_LIB_NAME = @GLAPI_LIB_NAME@
GLESv1_CM_LIB_DEPS = @GLESv1_CM_LIB_DEPS@
GLESv1_CM_LIB_GLOB = @GLESv1_CM_LIB_GLOB@
GLESv1_CM_LIB_NAME = @GLESv1_CM_LIB_NAME@
GLESv1_CM_PC_LIB_PRIV = @GLESv1_CM_PC_LIB_PRIV@
GLESv2_LIB_DEPS = @GLESv2_LIB_DEPS@
GLESv2_LIB_GLOB = @GLESv2_LIB_GLOB@
GLESv2_LIB_NAME = @GLESv2_LIB_NAME@
GLESv2_PC_LIB_PRIV = @GLESv2_PC_LIB_PRIV@
GLPROTO_CFLAGS = @GLPROTO_CFLAGS@
GLPROTO_LIBS = @GLPROTO_LIBS@
GLX_TLS = @GLX_TLS@
GL_LIB = @GL_LIB@
GL_LIB_DEPS = @GL_LIB_DEPS@
GL_LIB_GLOB = @GL_LIB_GLOB@
GL_LIB_NAME = @GL_LIB_NAME@
GL_PC_CFLAGS = @GL_PC_CFLAGS@
GL_PC_LIB_PRIV = @GL_PC_LIB_PRIV@
GL_PC_REQ_PRIV = @GL_PC_REQ_PRIV@
GREP = @GREP@
HAVE_XF86VIDMODE = @HAVE_XF86VIDMODE@
INDENT = @INDENT@
INDENT_FLAGS = @INDENT_FLAGS@
INSTALL = @INSTALL@
INSTALL_DATA = @INSTALL_DATA@
INSTALL_PROGRAM = @INSTALL_PROGRAM@
INSTALL_SCRIPT = @INSTALL_SCRIPT@
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
INTEL_CFLAGS = @INTEL_CFLAGS@
INTEL_LIBS = @INTEL_LIBS@
LD = @LD@
LDFLAGS = @LDFLAGS@
LDFLAGS_FOR_BUILD = @LDFLAGS_FOR_BUILD@
LEX = @LEX@
LEXLIB = @LEXLIB@
LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@
LIBCLC_INCLUDEDIR = @LIBCLC_INCLUDEDIR@
LIBCLC_LIBEXECDIR = @LIBCLC_LIBEXECDIR@
LIBDRM_CFLAGS = @LIBDRM_CFLAGS@
LIBDRM_LIBS = @LIBDRM_LIBS@
LIBDRM_XORG_CFLAGS = @LIBDRM_XORG_CFLAGS@
LIBDRM_XORG_LIBS = @LIBDRM_XORG_LIBS@
LIBKMS_XORG_CFLAGS = @LIBKMS_XORG_CFLAGS@
LIBKMS_XORG_LIBS = @LIBKMS_XORG_LIBS@
LIBOBJS = @LIBOBJS@
LIBS = @LIBS@
LIBTOOL = @LIBTOOL@
LIBUDEV_CFLAGS = @LIBUDEV_CFLAGS@
LIBUDEV_LIBS = @LIBUDEV_LIBS@
LIB_DIR = @LIB_DIR@
LIPO = @LIPO@
LLVM_BINDIR = @LLVM_BINDIR@
LLVM_CFLAGS = @LLVM_CFLAGS@
LLVM_CONFIG = @LLVM_CONFIG@
LLVM_CPPFLAGS = @LLVM_CPPFLAGS@
LLVM_CXXFLAGS = @LLVM_CXXFLAGS@
LLVM_INCLUDEDIR = @LLVM_INCLUDEDIR@
LLVM_LDFLAGS = @LLVM_LDFLAGS@
LLVM_LIBDIR = @LLVM_LIBDIR@
LLVM_LIBS = @LLVM_LIBS@
LLVM_VERSION = @LLVM_VERSION@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
MAKE = @MAKE@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
MESA_LLVM = @MESA_LLVM@
MKDIR_P = @MKDIR_P@
NM = @NM@
NMEDIT = @NMEDIT@
NOUVEAU_CFLAGS = @NOUVEAU_CFLAGS@
NOUVEAU_LIBS = @NOUVEAU_LIBS@
OBJDUMP = @OBJDUMP@
OBJEXT = @OBJEXT@
OPENCL_LIB_INSTALL_DIR = @OPENCL_LIB_INSTALL_DIR@
OSMESA_LIB = @OSMESA_LIB@
OSMESA_LIB_DEPS = @OSMESA_LIB_DEPS@
OSMESA_LIB_NAME = @OSMESA_LIB_NAME@
OSMESA_MESA_DEPS = @OSMESA_MESA_DEPS@
OSMESA_PC_LIB_PRIV = @OSMESA_PC_LIB_PRIV@
OSMESA_PC_REQ = @OSMESA_PC_REQ@
OSMESA_VERSION = @OSMESA_VERSION@
OTOOL = @OTOOL@
OTOOL64 = @OTOOL64@
PACKAGE = @PACKAGE@
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
PACKAGE_NAME = @PACKAGE_NAME@
PACKAGE_STRING = @PACKAGE_STRING@
PACKAGE_TARNAME = @PACKAGE_TARNAME@
PACKAGE_URL = @PACKAGE_URL@
PACKAGE_VERSION = @PACKAGE_VERSION@
PATH_SEPARATOR = @PATH_SEPARATOR@
PERL = @PERL@
PKG_CONFIG = @PKG_CONFIG@
PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@
PKG_CONFIG_PATH = @PKG_CONFIG_PATH@
POSIX_SHELL = @POSIX_SHELL@
PTHREAD_CC = @PTHREAD_CC@
PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
PTHREAD_LIBS = @PTHREAD_LIBS@
PYTHON2 = @PYTHON2@
RADEON_CFLAGS = @RADEON_CFLAGS@
RADEON_LIBS = @RADEON_LIBS@
RANLIB = @RANLIB@
SED = @SED@
SELINUX_LIBS = @SELINUX_LIBS@
SET_MAKE = @SET_MAKE@
SHELL = @SHELL@
STRIP = @STRIP@
VDPAU_CFLAGS = @VDPAU_CFLAGS@
VDPAU_LIBS = @VDPAU_LIBS@
VDPAU_LIB_INSTALL_DIR = @VDPAU_LIB_INSTALL_DIR@
VDPAU_MAJOR = @VDPAU_MAJOR@
VDPAU_MINOR = @VDPAU_MINOR@
VERSION = @VERSION@
VG_LIB_DEPS = @VG_LIB_DEPS@
VG_LIB_GLOB = @VG_LIB_GLOB@
VG_LIB_NAME = @VG_LIB_NAME@
VG_PC_LIB_PRIV = @VG_PC_LIB_PRIV@
VISIBILITY_CFLAGS = @VISIBILITY_CFLAGS@
VISIBILITY_CXXFLAGS = @VISIBILITY_CXXFLAGS@
WAYLAND_CFLAGS = @WAYLAND_CFLAGS@
WAYLAND_LIBS = @WAYLAND_LIBS@
WAYLAND_SCANNER = @WAYLAND_SCANNER@
X11_INCLUDES = @X11_INCLUDES@
XA_MAJOR = @XA_MAJOR@
XA_MINOR = @XA_MINOR@
XA_TINY = @XA_TINY@
XA_VERSION = @XA_VERSION@
XCB_DRI2_CFLAGS = @XCB_DRI2_CFLAGS@
XCB_DRI2_LIBS = @XCB_DRI2_LIBS@
XEXT_CFLAGS = @XEXT_CFLAGS@
XEXT_LIBS = @XEXT_LIBS@
XF86VIDMODE_CFLAGS = @XF86VIDMODE_CFLAGS@
XF86VIDMODE_LIBS = @XF86VIDMODE_LIBS@
XLIBGL_CFLAGS = @XLIBGL_CFLAGS@
XLIBGL_LIBS = @XLIBGL_LIBS@
XORG_CFLAGS = @XORG_CFLAGS@
XORG_DRIVER_INSTALL_DIR = @XORG_DRIVER_INSTALL_DIR@
XORG_LIBS = @XORG_LIBS@
XVMC_CFLAGS = @XVMC_CFLAGS@
XVMC_LIBS = @XVMC_LIBS@
XVMC_LIB_INSTALL_DIR = @XVMC_LIB_INSTALL_DIR@
XVMC_MAJOR = @XVMC_MAJOR@
XVMC_MINOR = @XVMC_MINOR@
YACC = @YACC@
YFLAGS = @YFLAGS@
abs_builddir = @abs_builddir@
abs_srcdir = @abs_srcdir@
abs_top_builddir = @abs_top_builddir@
abs_top_srcdir = @abs_top_srcdir@
ac_ct_AR = @ac_ct_AR@
ac_ct_CC = @ac_ct_CC@
ac_ct_CC_FOR_BUILD = @ac_ct_CC_FOR_BUILD@
ac_ct_CXX = @ac_ct_CXX@
ac_ct_CXX_FOR_BUILD = @ac_ct_CXX_FOR_BUILD@
ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
am__include = @am__include@
am__leading_dot = @am__leading_dot@
am__quote = @am__quote@
am__tar = @am__tar@
am__untar = @am__untar@
ax_pthread_config = @ax_pthread_config@
bindir = @bindir@
build = @build@
build_alias = @build_alias@
build_cpu = @build_cpu@
build_os = @build_os@
build_vendor = @build_vendor@
builddir = @builddir@
datadir = @datadir@
datarootdir = @datarootdir@
docdir = @docdir@
dvidir = @dvidir@
exec_prefix = @exec_prefix@
host = @host@
host_alias = @host_alias@
host_cpu = @host_cpu@
host_os = @host_os@
host_vendor = @host_vendor@
htmldir = @htmldir@
includedir = @includedir@
infodir = @infodir@
install_sh = @install_sh@
libdir = @libdir@
libexecdir = @libexecdir@
localedir = @localedir@
localstatedir = @localstatedir@
mandir = @mandir@
mkdir_p = @mkdir_p@
oldincludedir = @oldincludedir@
pdfdir = @pdfdir@
prefix = @prefix@
program_transform_name = @program_transform_name@
psdir = @psdir@
sbindir = @sbindir@
sharedstatedir = @sharedstatedir@
srcdir = @srcdir@
sysconfdir = @sysconfdir@
target = @target@
target_alias = @target_alias@
target_cpu = @target_cpu@
target_os = @target_os@
target_vendor = @target_vendor@
top_build_prefix = @top_build_prefix@
top_builddir = @top_builddir@
top_srcdir = @top_srcdir@
GALLIUM_CFLAGS = \
-I$(top_srcdir)/include \
-I$(top_srcdir)/src/gallium/include \
-I$(top_srcdir)/src/gallium/auxiliary \
$(DEFINES)
 
AM_CFLAGS = \
$(GALLIUM_CFLAGS) \
$(VISIBILITY_CFLAGS)
 
noinst_LTLIBRARIES = libtrace.la
libtrace_la_SOURCES = \
tr_context.c \
tr_dump.c \
tr_dump_state.c \
tr_screen.c \
tr_texture.c
 
all: all-am
 
.SUFFIXES:
.SUFFIXES: .c .lo .o .obj
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(top_srcdir)/src/gallium/Automake.inc $(am__configure_deps)
@for dep in $?; do \
case '$(am__configure_deps)' in \
*$$dep*) \
( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
&& { if test -f $@; then exit 0; else break; fi; }; \
exit 1;; \
esac; \
done; \
echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign src/gallium/drivers/trace/Makefile'; \
$(am__cd) $(top_srcdir) && \
$(AUTOMAKE) --foreign src/gallium/drivers/trace/Makefile
.PRECIOUS: Makefile
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
@case '$?' in \
*config.status*) \
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
*) \
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
esac;
$(top_srcdir)/src/gallium/Automake.inc:
 
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
 
$(top_srcdir)/configure: $(am__configure_deps)
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
$(am__aclocal_m4_deps):
 
clean-noinstLTLIBRARIES:
-test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES)
@list='$(noinst_LTLIBRARIES)'; \
locs=`for p in $$list; do echo $$p; done | \
sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
sort -u`; \
test -z "$$locs" || { \
echo rm -f $${locs}; \
rm -f $${locs}; \
}
 
libtrace.la: $(libtrace_la_OBJECTS) $(libtrace_la_DEPENDENCIES) $(EXTRA_libtrace_la_DEPENDENCIES)
$(AM_V_CCLD)$(LINK) $(libtrace_la_OBJECTS) $(libtrace_la_LIBADD) $(LIBS)
 
mostlyclean-compile:
-rm -f *.$(OBJEXT)
 
distclean-compile:
-rm -f *.tab.c
 
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tr_context.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tr_dump.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tr_dump_state.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tr_screen.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tr_texture.Plo@am__quote@
 
.c.o:
@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
 
.c.obj:
@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
 
.c.lo:
@am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
 
mostlyclean-libtool:
-rm -f *.lo
 
clean-libtool:
-rm -rf .libs _libs
 
ID: $(am__tagged_files)
$(am__define_uniq_tagged_files); mkid -fID $$unique
tags: tags-am
TAGS: tags
 
tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
set x; \
here=`pwd`; \
$(am__define_uniq_tagged_files); \
shift; \
if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
test -n "$$unique" || unique=$$empty_fix; \
if test $$# -gt 0; then \
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
"$$@" $$unique; \
else \
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
$$unique; \
fi; \
fi
ctags: ctags-am
 
CTAGS: ctags
ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
$(am__define_uniq_tagged_files); \
test -z "$(CTAGS_ARGS)$$unique" \
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
$$unique
 
GTAGS:
here=`$(am__cd) $(top_builddir) && pwd` \
&& $(am__cd) $(top_srcdir) \
&& gtags -i $(GTAGS_ARGS) "$$here"
cscopelist: cscopelist-am
 
cscopelist-am: $(am__tagged_files)
list='$(am__tagged_files)'; \
case "$(srcdir)" in \
[\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
*) sdir=$(subdir)/$(srcdir) ;; \
esac; \
for i in $$list; do \
if test -f "$$i"; then \
echo "$(subdir)/$$i"; \
else \
echo "$$sdir/$$i"; \
fi; \
done >> $(top_builddir)/cscope.files
 
distclean-tags:
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
 
distdir: $(DISTFILES)
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
list='$(DISTFILES)'; \
dist_files=`for file in $$list; do echo $$file; done | \
sed -e "s|^$$srcdirstrip/||;t" \
-e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
case $$dist_files in \
*/*) $(MKDIR_P) `echo "$$dist_files" | \
sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
sort -u` ;; \
esac; \
for file in $$dist_files; do \
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
if test -d $$d/$$file; then \
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
if test -d "$(distdir)/$$file"; then \
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
fi; \
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
fi; \
cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
else \
test -f "$(distdir)/$$file" \
|| cp -p $$d/$$file "$(distdir)/$$file" \
|| exit 1; \
fi; \
done
check-am: all-am
check: check-am
all-am: Makefile $(LTLIBRARIES)
installdirs:
install: install-am
install-exec: install-exec-am
install-data: install-data-am
uninstall: uninstall-am
 
install-am: all-am
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
 
installcheck: installcheck-am
install-strip:
if test -z '$(STRIP)'; then \
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
install; \
else \
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
"INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
fi
mostlyclean-generic:
 
clean-generic:
 
distclean-generic:
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
 
maintainer-clean-generic:
@echo "This command is intended for maintainers to use"
@echo "it deletes files that may require special tools to rebuild."
clean: clean-am
 
clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \
mostlyclean-am
 
distclean: distclean-am
-rm -rf ./$(DEPDIR)
-rm -f Makefile
distclean-am: clean-am distclean-compile distclean-generic \
distclean-tags
 
dvi: dvi-am
 
dvi-am:
 
html: html-am
 
html-am:
 
info: info-am
 
info-am:
 
install-data-am:
 
install-dvi: install-dvi-am
 
install-dvi-am:
 
install-exec-am:
 
install-html: install-html-am
 
install-html-am:
 
install-info: install-info-am
 
install-info-am:
 
install-man:
 
install-pdf: install-pdf-am
 
install-pdf-am:
 
install-ps: install-ps-am
 
install-ps-am:
 
installcheck-am:
 
maintainer-clean: maintainer-clean-am
-rm -rf ./$(DEPDIR)
-rm -f Makefile
maintainer-clean-am: distclean-am maintainer-clean-generic
 
mostlyclean: mostlyclean-am
 
mostlyclean-am: mostlyclean-compile mostlyclean-generic \
mostlyclean-libtool
 
pdf: pdf-am
 
pdf-am:
 
ps: ps-am
 
ps-am:
 
uninstall-am:
 
.MAKE: install-am install-strip
 
.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
clean-libtool clean-noinstLTLIBRARIES cscopelist-am ctags \
ctags-am distclean distclean-compile distclean-generic \
distclean-libtool distclean-tags distdir dvi dvi-am html \
html-am info info-am install install-am install-data \
install-data-am install-dvi install-dvi-am install-exec \
install-exec-am install-html install-html-am install-info \
install-info-am install-man install-pdf install-pdf-am \
install-ps install-ps-am install-strip installcheck \
installcheck-am installdirs maintainer-clean \
maintainer-clean-generic mostlyclean mostlyclean-compile \
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
tags tags-am uninstall uninstall-am
 
 
# Tell versions [3.59,3.63) of GNU make to not export all variables.
# Otherwise a system limit (for SysV at least) may be exceeded.
.NOEXPORT:
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/README
0,0 → 1,55
TRACE PIPE DRIVER
 
 
= About =
 
This directory contains a Gallium3D trace debugger pipe driver.
It can traces all incoming calls.
 
 
= Usage =
 
== Tracing ==
 
For tracing then do
 
GALLIUM_TRACE=tri.trace trivial/tri
 
which should create a tri.trace file, which is an XML file. You can view copying
trace.xsl to the same directory, and opening with a XSLT capable browser such as
Firefox or Internet Explorer.
 
For long traces you can use the
 
src/gallium/tools/trace/dump.py tri.trace | less -R
 
 
== Remote debugging ==
 
For remote debugging see:
 
src/gallium/drivers/rbug/README
 
 
= Integrating =
 
You can integrate the trace pipe driver either inside the state tracker or the
target. The procedure on both cases is the same. Let's assume you have a
pipe_screen obtained by the usual means (variable and function names are just
for illustration purposes):
 
real_screen = real_screen_create(...);
The trace screen is then created by doing
 
trace_screen = trace_screen_create(real_screen);
 
You can then simply use trace_screen instead of real_screen.
 
You can create as many contexts you wish from trace_screen::context_create they
are automatically wrapped by trace_screen.
 
 
--
Jose Fonseca <jfonseca@vmware.com>
Jakob Bornecrantz <jakob@vmware.com>
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/SConscript
0,0 → 1,17
Import('*')
 
env = env.Clone()
 
trace = env.ConvenienceLibrary(
target = 'trace',
source = [
'tr_context.c',
'tr_dump.c',
'tr_dump_state.c',
'tr_screen.c',
'tr_texture.c',
])
 
env.Alias('trace', trace)
 
Export('trace')
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_context.c
0,0 → 1,1639
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
#include "util/u_inlines.h"
#include "util/u_memory.h"
#include "util/u_simple_list.h"
 
#include "pipe/p_format.h"
#include "pipe/p_screen.h"
 
#include "tr_dump.h"
#include "tr_dump_state.h"
#include "tr_public.h"
#include "tr_screen.h"
#include "tr_texture.h"
#include "tr_context.h"
 
 
 
 
 
static INLINE struct pipe_resource *
trace_resource_unwrap(struct trace_context *tr_ctx,
struct pipe_resource *resource)
{
struct trace_resource *tr_res;
 
if(!resource)
return NULL;
 
tr_res = trace_resource(resource);
 
assert(tr_res->resource);
return tr_res->resource;
}
 
 
static INLINE struct pipe_surface *
trace_surface_unwrap(struct trace_context *tr_ctx,
struct pipe_surface *surface)
{
struct trace_screen *tr_scr = trace_screen(tr_ctx->base.screen);
struct trace_surface *tr_surf;
 
if(!surface)
return NULL;
 
assert(surface->texture);
if(!surface->texture)
return surface;
 
tr_surf = trace_surface(surface);
 
assert(tr_surf->surface);
assert(tr_surf->surface->texture->screen == tr_scr->screen);
(void) tr_scr;
return tr_surf->surface;
}
 
 
static INLINE void
trace_context_draw_vbo(struct pipe_context *_pipe,
const struct pipe_draw_info *info)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "draw_vbo");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(draw_info, info);
 
trace_dump_trace_flush();
 
pipe->draw_vbo(pipe, info);
 
trace_dump_call_end();
}
 
 
static INLINE struct pipe_query *
trace_context_create_query(struct pipe_context *_pipe,
unsigned query_type)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_query *result;
 
trace_dump_call_begin("pipe_context", "create_query");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, query_type);
 
result = pipe->create_query(pipe, query_type);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_destroy_query(struct pipe_context *_pipe,
struct pipe_query *query)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "destroy_query");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, query);
 
pipe->destroy_query(pipe, query);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_begin_query(struct pipe_context *_pipe,
struct pipe_query *query)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "begin_query");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, query);
 
pipe->begin_query(pipe, query);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_end_query(struct pipe_context *_pipe,
struct pipe_query *query)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "end_query");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, query);
 
pipe->end_query(pipe, query);
 
trace_dump_call_end();
}
 
 
static INLINE boolean
trace_context_get_query_result(struct pipe_context *_pipe,
struct pipe_query *query,
boolean wait,
union pipe_query_result *presult)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
uint64_t result;
boolean _result;
 
trace_dump_call_begin("pipe_context", "get_query_result");
 
trace_dump_arg(ptr, pipe);
 
_result = pipe->get_query_result(pipe, query, wait, presult);
/* XXX this depends on the query type */
result = *((uint64_t*)presult);
 
trace_dump_arg(uint, result);
trace_dump_ret(bool, _result);
 
trace_dump_call_end();
 
return _result;
}
 
 
static INLINE void *
trace_context_create_blend_state(struct pipe_context *_pipe,
const struct pipe_blend_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
void * result;
 
trace_dump_call_begin("pipe_context", "create_blend_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(blend_state, state);
 
result = pipe->create_blend_state(pipe, state);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_bind_blend_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "bind_blend_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->bind_blend_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_delete_blend_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "delete_blend_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->delete_blend_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void *
trace_context_create_sampler_state(struct pipe_context *_pipe,
const struct pipe_sampler_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
void * result;
 
trace_dump_call_begin("pipe_context", "create_sampler_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(sampler_state, state);
 
result = pipe->create_sampler_state(pipe, state);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_bind_sampler_states(struct pipe_context *_pipe,
unsigned shader,
unsigned start,
unsigned num_states,
void **states)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
/* remove this when we have pipe->bind_sampler_states(..., start, ...) */
assert(start == 0);
 
switch (shader) {
case PIPE_SHADER_VERTEX:
trace_dump_call_begin("pipe_context", "bind_vertex_sampler_states");
break;
case PIPE_SHADER_GEOMETRY:
trace_dump_call_begin("pipe_context", "bind_geometry_sampler_states");
break;
case PIPE_SHADER_FRAGMENT:
trace_dump_call_begin("pipe_context", "bind_fragment_sampler_states");
break;
default:
debug_error("Unexpected shader in trace_context_bind_sampler_states()");
}
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, num_states);
trace_dump_arg_array(ptr, states, num_states);
 
switch (shader) {
case PIPE_SHADER_VERTEX:
pipe->bind_vertex_sampler_states(pipe, num_states, states);
break;
case PIPE_SHADER_GEOMETRY:
pipe->bind_geometry_sampler_states(pipe, num_states, states);
break;
case PIPE_SHADER_FRAGMENT:
pipe->bind_fragment_sampler_states(pipe, num_states, states);
break;
default:
debug_error("Unexpected shader in trace_context_bind_sampler_states()");
}
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_bind_fragment_sampler_states(struct pipe_context *_pipe,
unsigned num,
void **states)
{
trace_context_bind_sampler_states(_pipe, PIPE_SHADER_FRAGMENT,
0, num, states);
}
 
 
static INLINE void
trace_context_bind_vertex_sampler_states(struct pipe_context *_pipe,
unsigned num,
void **states)
{
trace_context_bind_sampler_states(_pipe, PIPE_SHADER_VERTEX,
0, num, states);
}
 
 
static INLINE void
trace_context_bind_geometry_sampler_states(struct pipe_context *_pipe,
unsigned num,
void **states)
{
trace_context_bind_sampler_states(_pipe, PIPE_SHADER_GEOMETRY,
0, num, states);
}
 
 
static INLINE void
trace_context_delete_sampler_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "delete_sampler_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->delete_sampler_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void *
trace_context_create_rasterizer_state(struct pipe_context *_pipe,
const struct pipe_rasterizer_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
void * result;
 
trace_dump_call_begin("pipe_context", "create_rasterizer_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(rasterizer_state, state);
 
result = pipe->create_rasterizer_state(pipe, state);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_bind_rasterizer_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "bind_rasterizer_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->bind_rasterizer_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_delete_rasterizer_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "delete_rasterizer_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->delete_rasterizer_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void *
trace_context_create_depth_stencil_alpha_state(struct pipe_context *_pipe,
const struct pipe_depth_stencil_alpha_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
void * result;
 
trace_dump_call_begin("pipe_context", "create_depth_stencil_alpha_state");
 
result = pipe->create_depth_stencil_alpha_state(pipe, state);
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(depth_stencil_alpha_state, state);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_bind_depth_stencil_alpha_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "bind_depth_stencil_alpha_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->bind_depth_stencil_alpha_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_delete_depth_stencil_alpha_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "delete_depth_stencil_alpha_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->delete_depth_stencil_alpha_state(pipe, state);
 
trace_dump_call_end();
}
 
 
#define TRACE_SHADER_STATE(shader_type) \
static INLINE void * \
trace_context_create_##shader_type##_state(struct pipe_context *_pipe, \
const struct pipe_shader_state *state) \
{ \
struct trace_context *tr_ctx = trace_context(_pipe); \
struct pipe_context *pipe = tr_ctx->pipe; \
void * result; \
trace_dump_call_begin("pipe_context", "create_" #shader_type "_state"); \
trace_dump_arg(ptr, pipe); \
trace_dump_arg(shader_state, state); \
result = pipe->create_##shader_type##_state(pipe, state); \
trace_dump_ret(ptr, result); \
trace_dump_call_end(); \
return result; \
} \
\
static INLINE void \
trace_context_bind_##shader_type##_state(struct pipe_context *_pipe, \
void *state) \
{ \
struct trace_context *tr_ctx = trace_context(_pipe); \
struct pipe_context *pipe = tr_ctx->pipe; \
trace_dump_call_begin("pipe_context", "bind_" #shader_type "_state"); \
trace_dump_arg(ptr, pipe); \
trace_dump_arg(ptr, state); \
pipe->bind_##shader_type##_state(pipe, state); \
trace_dump_call_end(); \
} \
\
static INLINE void \
trace_context_delete_##shader_type##_state(struct pipe_context *_pipe, \
void *state) \
{ \
struct trace_context *tr_ctx = trace_context(_pipe); \
struct pipe_context *pipe = tr_ctx->pipe; \
trace_dump_call_begin("pipe_context", "delete_" #shader_type "_state"); \
trace_dump_arg(ptr, pipe); \
trace_dump_arg(ptr, state); \
pipe->delete_##shader_type##_state(pipe, state); \
trace_dump_call_end(); \
}
 
TRACE_SHADER_STATE(fs)
TRACE_SHADER_STATE(vs)
TRACE_SHADER_STATE(gs)
 
#undef TRACE_SHADER_STATE
 
 
static INLINE void *
trace_context_create_vertex_elements_state(struct pipe_context *_pipe,
unsigned num_elements,
const struct pipe_vertex_element *elements)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
void * result;
 
trace_dump_call_begin("pipe_context", "create_vertex_elements_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, num_elements);
 
trace_dump_arg_begin("elements");
trace_dump_struct_array(vertex_element, elements, num_elements);
trace_dump_arg_end();
 
result = pipe->create_vertex_elements_state(pipe, num_elements, elements);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_bind_vertex_elements_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "bind_vertex_elements_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->bind_vertex_elements_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_delete_vertex_elements_state(struct pipe_context *_pipe,
void *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "delete_vertex_elements_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, state);
 
pipe->delete_vertex_elements_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_blend_color(struct pipe_context *_pipe,
const struct pipe_blend_color *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_blend_color");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(blend_color, state);
 
pipe->set_blend_color(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_stencil_ref(struct pipe_context *_pipe,
const struct pipe_stencil_ref *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_stencil_ref");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(stencil_ref, state);
 
pipe->set_stencil_ref(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_clip_state(struct pipe_context *_pipe,
const struct pipe_clip_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_clip_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(clip_state, state);
 
pipe->set_clip_state(pipe, state);
 
trace_dump_call_end();
}
 
static INLINE void
trace_context_set_sample_mask(struct pipe_context *_pipe,
unsigned sample_mask)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_sample_mask");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, sample_mask);
 
pipe->set_sample_mask(pipe, sample_mask);
 
trace_dump_call_end();
}
 
static INLINE void
trace_context_set_constant_buffer(struct pipe_context *_pipe,
uint shader, uint index,
struct pipe_constant_buffer *constant_buffer)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_constant_buffer cb;
 
if (constant_buffer) {
cb = *constant_buffer;
cb.buffer = trace_resource_unwrap(tr_ctx, constant_buffer->buffer);
constant_buffer = &cb;
}
 
trace_dump_call_begin("pipe_context", "set_constant_buffer");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, shader);
trace_dump_arg(uint, index);
trace_dump_arg(constant_buffer, constant_buffer);
 
pipe->set_constant_buffer(pipe, shader, index, constant_buffer);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_framebuffer_state(struct pipe_context *_pipe,
const struct pipe_framebuffer_state *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_framebuffer_state unwrapped_state;
unsigned i;
 
 
/* Unwrap the input state */
memcpy(&unwrapped_state, state, sizeof(unwrapped_state));
for(i = 0; i < state->nr_cbufs; ++i)
unwrapped_state.cbufs[i] = trace_surface_unwrap(tr_ctx, state->cbufs[i]);
for(i = state->nr_cbufs; i < PIPE_MAX_COLOR_BUFS; ++i)
unwrapped_state.cbufs[i] = NULL;
unwrapped_state.zsbuf = trace_surface_unwrap(tr_ctx, state->zsbuf);
state = &unwrapped_state;
 
trace_dump_call_begin("pipe_context", "set_framebuffer_state");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(framebuffer_state, state);
 
pipe->set_framebuffer_state(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_polygon_stipple(struct pipe_context *_pipe,
const struct pipe_poly_stipple *state)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_polygon_stipple");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(poly_stipple, state);
 
pipe->set_polygon_stipple(pipe, state);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_scissor_states(struct pipe_context *_pipe,
unsigned start_slot,
unsigned num_scissors,
const struct pipe_scissor_state *states)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_scissor_states");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, start_slot);
trace_dump_arg(uint, num_scissors);
trace_dump_arg(scissor_state, states);
 
pipe->set_scissor_states(pipe, start_slot, num_scissors, states);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_viewport_states(struct pipe_context *_pipe,
unsigned start_slot,
unsigned num_viewports,
const struct pipe_viewport_state *states)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_viewport_states");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, start_slot);
trace_dump_arg(uint, num_viewports);
trace_dump_arg(viewport_state, states);
 
pipe->set_viewport_states(pipe, start_slot, num_viewports, states);
 
trace_dump_call_end();
}
 
 
static struct pipe_sampler_view *
trace_context_create_sampler_view(struct pipe_context *_pipe,
struct pipe_resource *_resource,
const struct pipe_sampler_view *templ)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_resource *resource = tr_res->resource;
struct pipe_sampler_view *result;
struct trace_sampler_view *tr_view;
 
trace_dump_call_begin("pipe_context", "create_sampler_view");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, resource);
 
trace_dump_arg_begin("templ");
trace_dump_sampler_view_template(templ, resource->target);
trace_dump_arg_end();
 
result = pipe->create_sampler_view(pipe, resource, templ);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
/*
* Wrap pipe_sampler_view
*/
tr_view = CALLOC_STRUCT(trace_sampler_view);
tr_view->base = *templ;
tr_view->base.reference.count = 1;
tr_view->base.texture = NULL;
pipe_resource_reference(&tr_view->base.texture, _resource);
tr_view->base.context = _pipe;
tr_view->sampler_view = result;
result = &tr_view->base;
 
return result;
}
 
 
static void
trace_context_sampler_view_destroy(struct pipe_context *_pipe,
struct pipe_sampler_view *_view)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct trace_sampler_view *tr_view = trace_sampler_view(_view);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_sampler_view *view = tr_view->sampler_view;
 
assert(_view->context == _pipe);
 
trace_dump_call_begin("pipe_context", "sampler_view_destroy");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, view);
 
pipe_sampler_view_reference(&tr_view->sampler_view, NULL);
 
trace_dump_call_end();
 
pipe_resource_reference(&_view->texture, NULL);
FREE(_view);
}
 
/********************************************************************
* surface
*/
 
 
static struct pipe_surface *
trace_context_create_surface(struct pipe_context *_pipe,
struct pipe_resource *_resource,
const struct pipe_surface *surf_tmpl)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_resource *resource = tr_res->resource;
struct pipe_surface *result = NULL;
 
trace_dump_call_begin("pipe_context", "create_surface");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, resource);
trace_dump_arg_begin("surf_tmpl");
trace_dump_surface_template(surf_tmpl, resource->target);
trace_dump_arg_end();
 
 
result = pipe->create_surface(pipe, resource, surf_tmpl);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
result = trace_surf_create(tr_ctx, tr_res, result);
 
return result;
}
 
 
static void
trace_context_surface_destroy(struct pipe_context *_pipe,
struct pipe_surface *_surface)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct trace_surface *tr_surf = trace_surface(_surface);
struct pipe_surface *surface = tr_surf->surface;
 
trace_dump_call_begin("pipe_context", "surface_destroy");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, surface);
 
trace_dump_call_end();
 
trace_surf_destroy(tr_surf);
}
 
 
static INLINE void
trace_context_set_sampler_views(struct pipe_context *_pipe,
unsigned shader,
unsigned start,
unsigned num,
struct pipe_sampler_view **views)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct trace_sampler_view *tr_view;
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_sampler_view *unwrapped_views[PIPE_MAX_SAMPLERS];
unsigned i;
 
/* remove this when we have pipe->set_sampler_views(..., start, ...) */
assert(start == 0);
 
for(i = 0; i < num; ++i) {
tr_view = trace_sampler_view(views[i]);
unwrapped_views[i] = tr_view ? tr_view->sampler_view : NULL;
}
views = unwrapped_views;
 
switch (shader) {
case PIPE_SHADER_VERTEX:
trace_dump_call_begin("pipe_context", "set_vertex_sampler_views");
break;
case PIPE_SHADER_GEOMETRY:
trace_dump_call_begin("pipe_context", "set_geometry_sampler_views");
break;
case PIPE_SHADER_FRAGMENT:
trace_dump_call_begin("pipe_context", "set_fragment_sampler_views");
break;
default:
debug_error("Unexpected shader in trace_context_set_sampler_views()");
}
 
trace_dump_arg(ptr, pipe);
/*trace_dump_arg(uint, shader);*/
trace_dump_arg(uint, num);
trace_dump_arg_array(ptr, views, num);
 
switch (shader) {
case PIPE_SHADER_VERTEX:
pipe->set_vertex_sampler_views(pipe, num, views);
break;
case PIPE_SHADER_GEOMETRY:
pipe->set_geometry_sampler_views(pipe, num, views);
break;
case PIPE_SHADER_FRAGMENT:
pipe->set_fragment_sampler_views(pipe, num, views);
break;
default:
debug_error("Unexpected shader in trace_context_set_sampler_views()");
}
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_fragment_sampler_views(struct pipe_context *_pipe,
unsigned num,
struct pipe_sampler_view **views)
{
trace_context_set_sampler_views(_pipe, PIPE_SHADER_FRAGMENT, 0, num, views);
}
 
 
static INLINE void
trace_context_set_vertex_sampler_views(struct pipe_context *_pipe,
unsigned num,
struct pipe_sampler_view **views)
{
trace_context_set_sampler_views(_pipe, PIPE_SHADER_VERTEX, 0, num, views);
}
 
 
static INLINE void
trace_context_set_geometry_sampler_views(struct pipe_context *_pipe,
unsigned num,
struct pipe_sampler_view **views)
{
trace_context_set_sampler_views(_pipe, PIPE_SHADER_GEOMETRY, 0, num, views);
}
 
 
static INLINE void
trace_context_set_vertex_buffers(struct pipe_context *_pipe,
unsigned start_slot, unsigned num_buffers,
const struct pipe_vertex_buffer *buffers)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
unsigned i;
 
trace_dump_call_begin("pipe_context", "set_vertex_buffers");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, start_slot);
trace_dump_arg(uint, num_buffers);
 
trace_dump_arg_begin("buffers");
trace_dump_struct_array(vertex_buffer, buffers, num_buffers);
trace_dump_arg_end();
 
if (buffers) {
struct pipe_vertex_buffer *_buffers = MALLOC(num_buffers * sizeof(*_buffers));
memcpy(_buffers, buffers, num_buffers * sizeof(*_buffers));
for (i = 0; i < num_buffers; i++)
_buffers[i].buffer = trace_resource_unwrap(tr_ctx, buffers[i].buffer);
pipe->set_vertex_buffers(pipe, start_slot, num_buffers, _buffers);
FREE(_buffers);
} else {
pipe->set_vertex_buffers(pipe, start_slot, num_buffers, NULL);
}
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_index_buffer(struct pipe_context *_pipe,
const struct pipe_index_buffer *ib)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_index_buffer");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(index_buffer, ib);
 
if (ib) {
struct pipe_index_buffer _ib;
_ib = *ib;
_ib.buffer = trace_resource_unwrap(tr_ctx, ib->buffer);
pipe->set_index_buffer(pipe, &_ib);
} else {
pipe->set_index_buffer(pipe, NULL);
}
 
trace_dump_call_end();
}
 
 
static INLINE struct pipe_stream_output_target *
trace_context_create_stream_output_target(struct pipe_context *_pipe,
struct pipe_resource *res,
unsigned buffer_offset,
unsigned buffer_size)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_stream_output_target *result;
 
res = trace_resource_unwrap(tr_ctx, res);
 
trace_dump_call_begin("pipe_context", "create_stream_output_target");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, res);
trace_dump_arg(uint, buffer_offset);
trace_dump_arg(uint, buffer_size);
 
result = pipe->create_stream_output_target(pipe,
res, buffer_offset, buffer_size);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static INLINE void
trace_context_stream_output_target_destroy(
struct pipe_context *_pipe,
struct pipe_stream_output_target *target)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "stream_output_target_destroy");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, target);
 
pipe->stream_output_target_destroy(pipe, target);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_set_stream_output_targets(struct pipe_context *_pipe,
unsigned num_targets,
struct pipe_stream_output_target **tgs,
unsigned append_bitmask)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "set_stream_output_targets");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, num_targets);
trace_dump_arg_array(ptr, tgs, num_targets);
trace_dump_arg(uint, append_bitmask);
 
pipe->set_stream_output_targets(pipe, num_targets, tgs, append_bitmask);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_resource_copy_region(struct pipe_context *_pipe,
struct pipe_resource *dst,
unsigned dst_level,
unsigned dstx, unsigned dsty, unsigned dstz,
struct pipe_resource *src,
unsigned src_level,
const struct pipe_box *src_box)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
dst = trace_resource_unwrap(tr_ctx, dst);
src = trace_resource_unwrap(tr_ctx, src);
 
trace_dump_call_begin("pipe_context", "resource_copy_region");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, dst);
trace_dump_arg(uint, dst_level);
trace_dump_arg(uint, dstx);
trace_dump_arg(uint, dsty);
trace_dump_arg(uint, dstz);
trace_dump_arg(ptr, src);
trace_dump_arg(uint, src_level);
trace_dump_arg(box, src_box);
 
pipe->resource_copy_region(pipe,
dst, dst_level, dstx, dsty, dstz,
src, src_level, src_box);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_blit(struct pipe_context *_pipe,
const struct pipe_blit_info *_info)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
struct pipe_blit_info info = *_info;
 
info.dst.resource = trace_resource_unwrap(tr_ctx, info.dst.resource);
info.src.resource = trace_resource_unwrap(tr_ctx, info.src.resource);
 
trace_dump_call_begin("pipe_context", "blit");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(blit_info, _info);
 
pipe->blit(pipe, &info);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_clear(struct pipe_context *_pipe,
unsigned buffers,
const union pipe_color_union *color,
double depth,
unsigned stencil)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "clear");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, buffers);
trace_dump_arg_begin("color");
if (color)
trace_dump_array(float, color->f, 4);
else
trace_dump_null();
trace_dump_arg_end();
trace_dump_arg(float, depth);
trace_dump_arg(uint, stencil);
 
pipe->clear(pipe, buffers, color, depth, stencil);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_clear_render_target(struct pipe_context *_pipe,
struct pipe_surface *dst,
const union pipe_color_union *color,
unsigned dstx, unsigned dsty,
unsigned width, unsigned height)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
dst = trace_surface_unwrap(tr_ctx, dst);
 
trace_dump_call_begin("pipe_context", "clear_render_target");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, dst);
trace_dump_arg_array(float, color->f, 4);
trace_dump_arg(uint, dstx);
trace_dump_arg(uint, dsty);
trace_dump_arg(uint, width);
trace_dump_arg(uint, height);
 
pipe->clear_render_target(pipe, dst, color, dstx, dsty, width, height);
 
trace_dump_call_end();
}
 
static INLINE void
trace_context_clear_depth_stencil(struct pipe_context *_pipe,
struct pipe_surface *dst,
unsigned clear_flags,
double depth,
unsigned stencil,
unsigned dstx, unsigned dsty,
unsigned width, unsigned height)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
dst = trace_surface_unwrap(tr_ctx, dst);
 
trace_dump_call_begin("pipe_context", "clear_depth_stencil");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(ptr, dst);
trace_dump_arg(uint, clear_flags);
trace_dump_arg(float, depth);
trace_dump_arg(uint, stencil);
trace_dump_arg(uint, dstx);
trace_dump_arg(uint, dsty);
trace_dump_arg(uint, width);
trace_dump_arg(uint, height);
 
pipe->clear_depth_stencil(pipe, dst, clear_flags, depth, stencil,
dstx, dsty, width, height);
 
trace_dump_call_end();
}
 
static INLINE void
trace_context_flush(struct pipe_context *_pipe,
struct pipe_fence_handle **fence,
unsigned flags)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "flush");
 
trace_dump_arg(ptr, pipe);
trace_dump_arg(uint, flags);
 
pipe->flush(pipe, fence, flags);
 
if(fence)
trace_dump_ret(ptr, *fence);
 
trace_dump_call_end();
}
 
 
static INLINE void
trace_context_destroy(struct pipe_context *_pipe)
{
struct trace_context *tr_ctx = trace_context(_pipe);
struct pipe_context *pipe = tr_ctx->pipe;
 
trace_dump_call_begin("pipe_context", "destroy");
trace_dump_arg(ptr, pipe);
trace_dump_call_end();
 
pipe->destroy(pipe);
 
FREE(tr_ctx);
}
 
 
/********************************************************************
* transfer
*/
 
 
static void *
trace_context_transfer_map(struct pipe_context *_context,
struct pipe_resource *_resource,
unsigned level,
unsigned usage,
const struct pipe_box *box,
struct pipe_transfer **transfer)
{
struct trace_context *tr_context = trace_context(_context);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_context *context = tr_context->pipe;
struct pipe_resource *texture = tr_res->resource;
struct pipe_transfer *result = NULL;
void *map;
 
assert(texture->screen == context->screen);
 
/*
* Map and transfers can't be serialized so we convert all write transfers
* to transfer_inline_write and ignore read transfers.
*/
 
map = context->transfer_map(context, texture, level, usage, box, &result);
if (!map)
return NULL;
 
*transfer = trace_transfer_create(tr_context, tr_res, result);
 
if (map) {
if(usage & PIPE_TRANSFER_WRITE) {
trace_transfer(*transfer)->map = map;
}
}
 
return *transfer ? map : NULL;
}
 
static void
trace_context_transfer_flush_region( struct pipe_context *_context,
struct pipe_transfer *_transfer,
const struct pipe_box *box)
{
struct trace_context *tr_context = trace_context(_context);
struct trace_transfer *tr_transfer = trace_transfer(_transfer);
struct pipe_context *context = tr_context->pipe;
struct pipe_transfer *transfer = tr_transfer->transfer;
 
context->transfer_flush_region(context,
transfer,
box);
}
 
static void
trace_context_transfer_unmap(struct pipe_context *_context,
struct pipe_transfer *_transfer)
{
struct trace_context *tr_ctx = trace_context(_context);
struct trace_transfer *tr_trans = trace_transfer(_transfer);
struct pipe_context *context = tr_ctx->pipe;
struct pipe_transfer *transfer = tr_trans->transfer;
 
if(tr_trans->map) {
/*
* Fake a transfer_inline_write
*/
 
struct pipe_resource *resource = transfer->resource;
unsigned level = transfer->level;
unsigned usage = transfer->usage;
const struct pipe_box *box = &transfer->box;
unsigned stride = transfer->stride;
unsigned layer_stride = transfer->layer_stride;
 
trace_dump_call_begin("pipe_context", "transfer_inline_write");
 
trace_dump_arg(ptr, context);
trace_dump_arg(ptr, resource);
trace_dump_arg(uint, level);
trace_dump_arg(uint, usage);
trace_dump_arg(box, box);
 
trace_dump_arg_begin("data");
trace_dump_box_bytes(tr_trans->map,
resource,
box,
stride,
layer_stride);
trace_dump_arg_end();
 
trace_dump_arg(uint, stride);
trace_dump_arg(uint, layer_stride);
 
trace_dump_call_end();
 
tr_trans->map = NULL;
}
 
context->transfer_unmap(context, transfer);
trace_transfer_destroy(tr_ctx, tr_trans);
}
 
 
static void
trace_context_transfer_inline_write(struct pipe_context *_context,
struct pipe_resource *_resource,
unsigned level,
unsigned usage,
const struct pipe_box *box,
const void *data,
unsigned stride,
unsigned layer_stride)
{
struct trace_context *tr_context = trace_context(_context);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_context *context = tr_context->pipe;
struct pipe_resource *resource = tr_res->resource;
 
assert(resource->screen == context->screen);
 
trace_dump_call_begin("pipe_context", "transfer_inline_write");
 
trace_dump_arg(ptr, context);
trace_dump_arg(ptr, resource);
trace_dump_arg(uint, level);
trace_dump_arg(uint, usage);
trace_dump_arg(box, box);
 
trace_dump_arg_begin("data");
trace_dump_box_bytes(data,
resource,
box,
stride,
layer_stride);
trace_dump_arg_end();
 
trace_dump_arg(uint, stride);
trace_dump_arg(uint, layer_stride);
 
trace_dump_call_end();
 
context->transfer_inline_write(context, resource,
level, usage, box, data, stride, layer_stride);
}
 
 
static void trace_context_render_condition(struct pipe_context *_context,
struct pipe_query *query,
boolean condition,
uint mode)
{
struct trace_context *tr_context = trace_context(_context);
struct pipe_context *context = tr_context->pipe;
 
trace_dump_call_begin("pipe_context", "render_condition");
 
trace_dump_arg(ptr, context);
trace_dump_arg(ptr, query);
trace_dump_arg(bool, condition);
trace_dump_arg(uint, mode);
 
trace_dump_call_end();
 
context->render_condition(context, query, condition, mode);
}
 
 
static void trace_context_texture_barrier(struct pipe_context *_context)
{
struct trace_context *tr_context = trace_context(_context);
struct pipe_context *context = tr_context->pipe;
 
trace_dump_call_begin("pipe_context", "texture_barrier");
 
trace_dump_arg(ptr, context);
 
trace_dump_call_end();
 
context->texture_barrier(context);
}
 
 
static const struct debug_named_value rbug_blocker_flags[] = {
{"before", 1, NULL},
{"after", 2, NULL},
DEBUG_NAMED_VALUE_END
};
 
struct pipe_context *
trace_context_create(struct trace_screen *tr_scr,
struct pipe_context *pipe)
{
struct trace_context *tr_ctx;
 
if(!pipe)
goto error1;
 
if(!trace_enabled())
goto error1;
 
tr_ctx = CALLOC_STRUCT(trace_context);
if(!tr_ctx)
goto error1;
 
tr_ctx->base.priv = pipe->priv; /* expose wrapped priv data */
tr_ctx->base.screen = &tr_scr->base;
 
tr_ctx->base.destroy = trace_context_destroy;
 
#define TR_CTX_INIT(_member) \
tr_ctx->base . _member = pipe -> _member ? trace_context_ ## _member : NULL
 
TR_CTX_INIT(draw_vbo);
TR_CTX_INIT(render_condition);
TR_CTX_INIT(create_query);
TR_CTX_INIT(destroy_query);
TR_CTX_INIT(begin_query);
TR_CTX_INIT(end_query);
TR_CTX_INIT(get_query_result);
TR_CTX_INIT(create_blend_state);
TR_CTX_INIT(bind_blend_state);
TR_CTX_INIT(delete_blend_state);
TR_CTX_INIT(create_sampler_state);
TR_CTX_INIT(bind_fragment_sampler_states);
TR_CTX_INIT(bind_vertex_sampler_states);
TR_CTX_INIT(bind_geometry_sampler_states);
TR_CTX_INIT(delete_sampler_state);
TR_CTX_INIT(create_rasterizer_state);
TR_CTX_INIT(bind_rasterizer_state);
TR_CTX_INIT(delete_rasterizer_state);
TR_CTX_INIT(create_depth_stencil_alpha_state);
TR_CTX_INIT(bind_depth_stencil_alpha_state);
TR_CTX_INIT(delete_depth_stencil_alpha_state);
TR_CTX_INIT(create_fs_state);
TR_CTX_INIT(bind_fs_state);
TR_CTX_INIT(delete_fs_state);
TR_CTX_INIT(create_vs_state);
TR_CTX_INIT(bind_vs_state);
TR_CTX_INIT(delete_vs_state);
TR_CTX_INIT(create_gs_state);
TR_CTX_INIT(bind_gs_state);
TR_CTX_INIT(delete_gs_state);
TR_CTX_INIT(create_vertex_elements_state);
TR_CTX_INIT(bind_vertex_elements_state);
TR_CTX_INIT(delete_vertex_elements_state);
TR_CTX_INIT(set_blend_color);
TR_CTX_INIT(set_stencil_ref);
TR_CTX_INIT(set_clip_state);
TR_CTX_INIT(set_sample_mask);
TR_CTX_INIT(set_constant_buffer);
TR_CTX_INIT(set_framebuffer_state);
TR_CTX_INIT(set_polygon_stipple);
TR_CTX_INIT(set_scissor_states);
TR_CTX_INIT(set_viewport_states);
TR_CTX_INIT(set_fragment_sampler_views);
TR_CTX_INIT(set_vertex_sampler_views);
TR_CTX_INIT(set_geometry_sampler_views);
TR_CTX_INIT(create_sampler_view);
TR_CTX_INIT(sampler_view_destroy);
TR_CTX_INIT(create_surface);
TR_CTX_INIT(surface_destroy);
TR_CTX_INIT(set_vertex_buffers);
TR_CTX_INIT(set_index_buffer);
TR_CTX_INIT(create_stream_output_target);
TR_CTX_INIT(stream_output_target_destroy);
TR_CTX_INIT(set_stream_output_targets);
TR_CTX_INIT(resource_copy_region);
TR_CTX_INIT(blit);
TR_CTX_INIT(clear);
TR_CTX_INIT(clear_render_target);
TR_CTX_INIT(clear_depth_stencil);
TR_CTX_INIT(flush);
TR_CTX_INIT(texture_barrier);
 
TR_CTX_INIT(transfer_map);
TR_CTX_INIT(transfer_unmap);
TR_CTX_INIT(transfer_flush_region);
TR_CTX_INIT(transfer_inline_write);
 
#undef TR_CTX_INIT
 
tr_ctx->pipe = pipe;
 
return &tr_ctx->base;
 
error1:
return pipe;
}
 
 
/**
* Sanity checker: check that the given context really is a
* trace context (and not the wrapped driver's context).
*/
void
trace_context_check(const struct pipe_context *pipe)
{
struct trace_context *tr_ctx = (struct trace_context *) pipe;
assert(tr_ctx->base.destroy == trace_context_destroy);
}
 
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_context.h
0,0 → 1,77
/**************************************************************************
*
* Copyright 2008 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 TR_CONTEXT_H_
#define TR_CONTEXT_H_
 
 
#include "pipe/p_compiler.h"
#include "util/u_debug.h"
#include "pipe/p_context.h"
 
#include "tr_screen.h"
 
#ifdef __cplusplus
extern "C" {
#endif
 
 
struct trace_screen;
struct trace_context
{
struct pipe_context base;
 
struct pipe_context *pipe;
};
 
 
void
trace_context_check(const struct pipe_context *pipe);
 
 
static INLINE struct trace_context *
trace_context(struct pipe_context *pipe)
{
assert(pipe);
#ifdef DEBUG
trace_context_check(pipe);
#endif
return (struct trace_context *)pipe;
}
 
 
struct pipe_context *
trace_context_create(struct trace_screen *tr_scr,
struct pipe_context *pipe);
 
 
#ifdef __cplusplus
}
#endif
 
#endif /* TR_CONTEXT_H_ */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_dump.c
0,0 → 1,666
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
 
/**
* @file
* Trace dumping functions.
*
* For now we just use standard XML for dumping the trace calls, as this is
* simple to write, parse, and visually inspect, but the actual representation
* is abstracted out of this file, so that we can switch to a binary
* representation if/when it becomes justified.
*
* @author Jose Fonseca <jrfonseca@tungstengraphics.com>
*/
 
#include "pipe/p_config.h"
 
#include <stdio.h>
#include <stdlib.h>
 
#include "pipe/p_compiler.h"
#include "os/os_thread.h"
#include "os/os_time.h"
#include "util/u_debug.h"
#include "util/u_memory.h"
#include "util/u_string.h"
#include "util/u_math.h"
#include "util/u_format.h"
 
#include "tr_dump.h"
#include "tr_screen.h"
#include "tr_texture.h"
 
 
static boolean close_stream = FALSE;
static FILE *stream = NULL;
pipe_static_mutex(call_mutex);
static long unsigned call_no = 0;
static boolean dumping = FALSE;
 
 
static INLINE void
trace_dump_write(const char *buf, size_t size)
{
if (stream) {
fwrite(buf, size, 1, stream);
}
}
 
 
static INLINE void
trace_dump_writes(const char *s)
{
trace_dump_write(s, strlen(s));
}
 
 
static INLINE void
trace_dump_writef(const char *format, ...)
{
static char buf[1024];
unsigned len;
va_list ap;
va_start(ap, format);
len = util_vsnprintf(buf, sizeof(buf), format, ap);
va_end(ap);
trace_dump_write(buf, len);
}
 
 
static INLINE void
trace_dump_escape(const char *str)
{
const unsigned char *p = (const unsigned char *)str;
unsigned char c;
while((c = *p++) != 0) {
if(c == '<')
trace_dump_writes("&lt;");
else if(c == '>')
trace_dump_writes("&gt;");
else if(c == '&')
trace_dump_writes("&amp;");
else if(c == '\'')
trace_dump_writes("&apos;");
else if(c == '\"')
trace_dump_writes("&quot;");
else if(c >= 0x20 && c <= 0x7e)
trace_dump_writef("%c", c);
else
trace_dump_writef("&#%u;", c);
}
}
 
 
static INLINE void
trace_dump_indent(unsigned level)
{
unsigned i;
for(i = 0; i < level; ++i)
trace_dump_writes("\t");
}
 
 
static INLINE void
trace_dump_newline(void)
{
trace_dump_writes("\n");
}
 
 
static INLINE void
trace_dump_tag(const char *name)
{
trace_dump_writes("<");
trace_dump_writes(name);
trace_dump_writes("/>");
}
 
 
static INLINE void
trace_dump_tag_begin(const char *name)
{
trace_dump_writes("<");
trace_dump_writes(name);
trace_dump_writes(">");
}
 
static INLINE void
trace_dump_tag_begin1(const char *name,
const char *attr1, const char *value1)
{
trace_dump_writes("<");
trace_dump_writes(name);
trace_dump_writes(" ");
trace_dump_writes(attr1);
trace_dump_writes("='");
trace_dump_escape(value1);
trace_dump_writes("'>");
}
 
 
static INLINE void
trace_dump_tag_begin2(const char *name,
const char *attr1, const char *value1,
const char *attr2, const char *value2)
{
trace_dump_writes("<");
trace_dump_writes(name);
trace_dump_writes(" ");
trace_dump_writes(attr1);
trace_dump_writes("=\'");
trace_dump_escape(value1);
trace_dump_writes("\' ");
trace_dump_writes(attr2);
trace_dump_writes("=\'");
trace_dump_escape(value2);
trace_dump_writes("\'>");
}
 
 
static INLINE void
trace_dump_tag_begin3(const char *name,
const char *attr1, const char *value1,
const char *attr2, const char *value2,
const char *attr3, const char *value3)
{
trace_dump_writes("<");
trace_dump_writes(name);
trace_dump_writes(" ");
trace_dump_writes(attr1);
trace_dump_writes("=\'");
trace_dump_escape(value1);
trace_dump_writes("\' ");
trace_dump_writes(attr2);
trace_dump_writes("=\'");
trace_dump_escape(value2);
trace_dump_writes("\' ");
trace_dump_writes(attr3);
trace_dump_writes("=\'");
trace_dump_escape(value3);
trace_dump_writes("\'>");
}
 
 
static INLINE void
trace_dump_tag_end(const char *name)
{
trace_dump_writes("</");
trace_dump_writes(name);
trace_dump_writes(">");
}
 
void
trace_dump_trace_flush(void)
{
if(stream) {
fflush(stream);
}
}
 
static void
trace_dump_trace_close(void)
{
if(stream) {
trace_dump_writes("</trace>\n");
if (close_stream) {
fclose(stream);
close_stream = FALSE;
stream = NULL;
}
call_no = 0;
}
}
 
 
static void
trace_dump_call_time(int64_t time)
{
if (stream) {
trace_dump_indent(2);
trace_dump_tag_begin("time");
trace_dump_int(time);
trace_dump_tag_end("time");
trace_dump_newline();
}
}
 
 
boolean
trace_dump_trace_begin(void)
{
const char *filename;
 
filename = debug_get_option("GALLIUM_TRACE", NULL);
if(!filename)
return FALSE;
 
if(!stream) {
 
if (strcmp(filename, "stderr") == 0) {
close_stream = FALSE;
stream = stderr;
}
else if (strcmp(filename, "stdout") == 0) {
close_stream = FALSE;
stream = stdout;
}
else {
close_stream = TRUE;
stream = fopen(filename, "wt");
if (!stream)
return FALSE;
}
 
trace_dump_writes("<?xml version='1.0' encoding='UTF-8'?>\n");
trace_dump_writes("<?xml-stylesheet type='text/xsl' href='trace.xsl'?>\n");
trace_dump_writes("<trace version='0.1'>\n");
 
/* Many applications don't exit cleanly, others may create and destroy a
* screen multiple times, so we only write </trace> tag and close at exit
* time.
*/
atexit(trace_dump_trace_close);
}
 
return TRUE;
}
 
boolean trace_dump_trace_enabled(void)
{
return stream ? TRUE : FALSE;
}
 
/*
* Call lock
*/
 
void trace_dump_call_lock(void)
{
pipe_mutex_lock(call_mutex);
}
 
void trace_dump_call_unlock(void)
{
pipe_mutex_unlock(call_mutex);
}
 
/*
* Dumping control
*/
 
void trace_dumping_start_locked(void)
{
dumping = TRUE;
}
 
void trace_dumping_stop_locked(void)
{
dumping = FALSE;
}
 
boolean trace_dumping_enabled_locked(void)
{
return dumping;
}
 
void trace_dumping_start(void)
{
pipe_mutex_lock(call_mutex);
trace_dumping_start_locked();
pipe_mutex_unlock(call_mutex);
}
 
void trace_dumping_stop(void)
{
pipe_mutex_lock(call_mutex);
trace_dumping_stop_locked();
pipe_mutex_unlock(call_mutex);
}
 
boolean trace_dumping_enabled(void)
{
boolean ret;
pipe_mutex_lock(call_mutex);
ret = trace_dumping_enabled_locked();
pipe_mutex_unlock(call_mutex);
return ret;
}
 
/*
* Dump functions
*/
 
static int64_t call_start_time = 0;
 
void trace_dump_call_begin_locked(const char *klass, const char *method)
{
if (!dumping)
return;
 
++call_no;
trace_dump_indent(1);
trace_dump_writes("<call no=\'");
trace_dump_writef("%lu", call_no);
trace_dump_writes("\' class=\'");
trace_dump_escape(klass);
trace_dump_writes("\' method=\'");
trace_dump_escape(method);
trace_dump_writes("\'>");
trace_dump_newline();
 
call_start_time = os_time_get();
}
 
void trace_dump_call_end_locked(void)
{
int64_t call_end_time;
 
if (!dumping)
return;
 
call_end_time = os_time_get();
 
trace_dump_call_time(call_end_time - call_start_time);
trace_dump_indent(1);
trace_dump_tag_end("call");
trace_dump_newline();
fflush(stream);
}
 
void trace_dump_call_begin(const char *klass, const char *method)
{
pipe_mutex_lock(call_mutex);
trace_dump_call_begin_locked(klass, method);
}
 
void trace_dump_call_end(void)
{
trace_dump_call_end_locked();
pipe_mutex_unlock(call_mutex);
}
 
void trace_dump_arg_begin(const char *name)
{
if (!dumping)
return;
 
trace_dump_indent(2);
trace_dump_tag_begin1("arg", "name", name);
}
 
void trace_dump_arg_end(void)
{
if (!dumping)
return;
 
trace_dump_tag_end("arg");
trace_dump_newline();
}
 
void trace_dump_ret_begin(void)
{
if (!dumping)
return;
 
trace_dump_indent(2);
trace_dump_tag_begin("ret");
}
 
void trace_dump_ret_end(void)
{
if (!dumping)
return;
 
trace_dump_tag_end("ret");
trace_dump_newline();
}
 
void trace_dump_bool(int value)
{
if (!dumping)
return;
 
trace_dump_writef("<bool>%c</bool>", value ? '1' : '0');
}
 
void trace_dump_int(long long int value)
{
if (!dumping)
return;
 
trace_dump_writef("<int>%lli</int>", value);
}
 
void trace_dump_uint(long long unsigned value)
{
if (!dumping)
return;
 
trace_dump_writef("<uint>%llu</uint>", value);
}
 
void trace_dump_float(double value)
{
if (!dumping)
return;
 
trace_dump_writef("<float>%g</float>", value);
}
 
void trace_dump_bytes(const void *data,
size_t size)
{
static const char hex_table[16] = "0123456789ABCDEF";
const uint8_t *p = data;
size_t i;
 
if (!dumping)
return;
 
trace_dump_writes("<bytes>");
for(i = 0; i < size; ++i) {
uint8_t byte = *p++;
char hex[2];
hex[0] = hex_table[byte >> 4];
hex[1] = hex_table[byte & 0xf];
trace_dump_write(hex, 2);
}
trace_dump_writes("</bytes>");
}
 
void trace_dump_box_bytes(const void *data,
struct pipe_resource *resource,
const struct pipe_box *box,
unsigned stride,
unsigned slice_stride)
{
size_t size;
 
/*
* Only dump buffer transfers to avoid huge files.
* TODO: Make this run-time configurable
*/
if (resource->target != PIPE_BUFFER) {
size = 0;
} else {
enum pipe_format format = resource->format;
if (slice_stride)
size = box->depth * slice_stride;
else if (stride)
size = util_format_get_nblocksy(format, box->height) * stride;
else {
size = util_format_get_nblocksx(format, box->width) * util_format_get_blocksize(format);
}
}
 
trace_dump_bytes(data, size);
}
 
void trace_dump_string(const char *str)
{
if (!dumping)
return;
 
trace_dump_writes("<string>");
trace_dump_escape(str);
trace_dump_writes("</string>");
}
 
void trace_dump_enum(const char *value)
{
if (!dumping)
return;
 
trace_dump_writes("<enum>");
trace_dump_escape(value);
trace_dump_writes("</enum>");
}
 
void trace_dump_array_begin(void)
{
if (!dumping)
return;
 
trace_dump_writes("<array>");
}
 
void trace_dump_array_end(void)
{
if (!dumping)
return;
 
trace_dump_writes("</array>");
}
 
void trace_dump_elem_begin(void)
{
if (!dumping)
return;
 
trace_dump_writes("<elem>");
}
 
void trace_dump_elem_end(void)
{
if (!dumping)
return;
 
trace_dump_writes("</elem>");
}
 
void trace_dump_struct_begin(const char *name)
{
if (!dumping)
return;
 
trace_dump_writef("<struct name='%s'>", name);
}
 
void trace_dump_struct_end(void)
{
if (!dumping)
return;
 
trace_dump_writes("</struct>");
}
 
void trace_dump_member_begin(const char *name)
{
if (!dumping)
return;
 
trace_dump_writef("<member name='%s'>", name);
}
 
void trace_dump_member_end(void)
{
if (!dumping)
return;
 
trace_dump_writes("</member>");
}
 
void trace_dump_null(void)
{
if (!dumping)
return;
 
trace_dump_writes("<null/>");
}
 
void trace_dump_ptr(const void *value)
{
if (!dumping)
return;
 
if(value)
trace_dump_writef("<ptr>0x%08lx</ptr>", (unsigned long)(uintptr_t)value);
else
trace_dump_null();
}
 
 
void trace_dump_resource_ptr(struct pipe_resource *_resource)
{
if (!dumping)
return;
 
if (_resource) {
struct trace_resource *tr_resource = trace_resource(_resource);
trace_dump_ptr(tr_resource->resource);
} else {
trace_dump_null();
}
}
 
void trace_dump_surface_ptr(struct pipe_surface *_surface)
{
if (!dumping)
return;
 
if (_surface) {
struct trace_surface *tr_surf = trace_surface(_surface);
trace_dump_ptr(tr_surf->surface);
} else {
trace_dump_null();
}
}
 
void trace_dump_transfer_ptr(struct pipe_transfer *_transfer)
{
if (!dumping)
return;
 
if (_transfer) {
struct trace_transfer *tr_tran = trace_transfer(_transfer);
trace_dump_ptr(tr_tran->transfer);
} else {
trace_dump_null();
}
}
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_dump.h
0,0 → 1,191
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
/**
* @file
* Trace data dumping primitives.
*/
 
#ifndef TR_DUMP_H
#define TR_DUMP_H
 
 
#include "pipe/p_compiler.h"
#include "pipe/p_format.h"
 
struct pipe_resource;
struct pipe_surface;
struct pipe_transfer;
struct pipe_box;
 
/*
* Low level dumping controls.
*
* Opening the trace file and checking if that is opened.
*/
boolean trace_dump_trace_begin(void);
boolean trace_dump_trace_enabled(void);
void trace_dump_trace_flush(void);
 
/*
* Lock and unlock the call mutex.
*
* It used by the none locked version of dumping control
* and begin/end call dump functions.
*
* Begin takes the lock while end unlocks it. Use the _locked
* version to avoid locking/unlocking it.
*/
void trace_dump_call_lock(void);
void trace_dump_call_unlock(void);
 
/*
* High level dumping control.
*/
void trace_dumping_start_locked(void);
void trace_dumping_stop_locked(void);
boolean trace_dumping_enabled_locked(void);
void trace_dumping_start(void);
void trace_dumping_stop(void);
boolean trace_dumping_enabled(void);
 
void trace_dump_call_begin_locked(const char *klass, const char *method);
void trace_dump_call_end_locked(void);
void trace_dump_call_begin(const char *klass, const char *method);
void trace_dump_call_end(void);
 
void trace_dump_arg_begin(const char *name);
void trace_dump_arg_end(void);
void trace_dump_ret_begin(void);
void trace_dump_ret_end(void);
void trace_dump_bool(int value);
void trace_dump_int(long long int value);
void trace_dump_uint(long long unsigned value);
void trace_dump_float(double value);
void trace_dump_bytes(const void *data, size_t size);
void trace_dump_box_bytes(const void *data,
struct pipe_resource *resource,
const struct pipe_box *box,
unsigned stride,
unsigned slice_stride);
void trace_dump_string(const char *str);
void trace_dump_enum(const char *value);
void trace_dump_array_begin(void);
void trace_dump_array_end(void);
void trace_dump_elem_begin(void);
void trace_dump_elem_end(void);
void trace_dump_struct_begin(const char *name);
void trace_dump_struct_end(void);
void trace_dump_member_begin(const char *name);
void trace_dump_member_end(void);
void trace_dump_null(void);
void trace_dump_ptr(const void *value);
/* will turn a wrapped object into the real one and dump ptr */
void trace_dump_resource_ptr(struct pipe_resource *_texture);
void trace_dump_surface_ptr(struct pipe_surface *_surface);
void trace_dump_transfer_ptr(struct pipe_transfer *_transfer);
 
/*
* Code saving macros.
*/
 
#define trace_dump_arg(_type, _arg) \
do { \
trace_dump_arg_begin(#_arg); \
trace_dump_##_type(_arg); \
trace_dump_arg_end(); \
} while(0)
 
#define trace_dump_arg_struct(_type, _arg) \
do { \
trace_dump_arg_begin(#_arg); \
trace_dump_##_type(&_arg); \
trace_dump_arg_end(); \
} while(0)
 
#define trace_dump_ret(_type, _arg) \
do { \
trace_dump_ret_begin(); \
trace_dump_##_type(_arg); \
trace_dump_ret_end(); \
} while(0)
 
#define trace_dump_array(_type, _obj, _size) \
do { \
if (_obj) { \
size_t idx; \
trace_dump_array_begin(); \
for(idx = 0; idx < (_size); ++idx) { \
trace_dump_elem_begin(); \
trace_dump_##_type((_obj)[idx]); \
trace_dump_elem_end(); \
} \
trace_dump_array_end(); \
} else { \
trace_dump_null(); \
} \
} while(0)
 
#define trace_dump_struct_array(_type, _obj, _size) \
do { \
if (_obj) { \
size_t idx; \
trace_dump_array_begin(); \
for(idx = 0; idx < (_size); ++idx) { \
trace_dump_elem_begin(); \
trace_dump_##_type(&(_obj)[idx]); \
trace_dump_elem_end(); \
} \
trace_dump_array_end(); \
} else { \
trace_dump_null(); \
} \
} while(0)
 
#define trace_dump_member(_type, _obj, _member) \
do { \
trace_dump_member_begin(#_member); \
trace_dump_##_type((_obj)->_member); \
trace_dump_member_end(); \
} while(0)
 
#define trace_dump_arg_array(_type, _arg, _size) \
do { \
trace_dump_arg_begin(#_arg); \
trace_dump_array(_type, _arg, _size); \
trace_dump_arg_end(); \
} while(0)
 
#define trace_dump_member_array(_type, _obj, _member) \
do { \
trace_dump_member_begin(#_member); \
trace_dump_array(_type, (_obj)->_member, sizeof((_obj)->_member)/sizeof((_obj)->_member[0])); \
trace_dump_member_end(); \
} while(0)
 
 
#endif /* TR_DUMP_H */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_dump_state.c
0,0 → 1,771
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
 
#include "pipe/p_compiler.h"
#include "util/u_memory.h"
#include "util/u_format.h"
#include "tgsi/tgsi_dump.h"
 
#include "tr_dump.h"
#include "tr_dump_state.h"
 
 
void trace_dump_format(enum pipe_format format)
{
if (!trace_dumping_enabled_locked())
return;
 
trace_dump_enum(util_format_name(format) );
}
 
 
void trace_dump_resource_template(const struct pipe_resource *templat)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!templat) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_resource");
 
trace_dump_member(int, templat, target);
trace_dump_member(format, templat, format);
 
trace_dump_member_begin("width");
trace_dump_uint(templat->width0);
trace_dump_member_end();
 
trace_dump_member_begin("height");
trace_dump_uint(templat->height0);
trace_dump_member_end();
 
trace_dump_member_begin("depth");
trace_dump_uint(templat->depth0);
trace_dump_member_end();
 
trace_dump_member_begin("array_size");
trace_dump_uint(templat->array_size);
trace_dump_member_end();
 
trace_dump_member(uint, templat, last_level);
trace_dump_member(uint, templat, nr_samples);
trace_dump_member(uint, templat, usage);
trace_dump_member(uint, templat, bind);
trace_dump_member(uint, templat, flags);
 
trace_dump_struct_end();
}
 
 
void trace_dump_box(const struct pipe_box *box)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!box) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_box");
 
trace_dump_member(int, box, x);
trace_dump_member(int, box, y);
trace_dump_member(int, box, z);
trace_dump_member(int, box, width);
trace_dump_member(int, box, height);
trace_dump_member(int, box, depth);
 
trace_dump_struct_end();
}
 
 
void trace_dump_rasterizer_state(const struct pipe_rasterizer_state *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_rasterizer_state");
 
trace_dump_member(bool, state, flatshade);
trace_dump_member(bool, state, light_twoside);
trace_dump_member(bool, state, clamp_vertex_color);
trace_dump_member(bool, state, clamp_fragment_color);
trace_dump_member(uint, state, front_ccw);
trace_dump_member(uint, state, cull_face);
trace_dump_member(uint, state, fill_front);
trace_dump_member(uint, state, fill_back);
trace_dump_member(bool, state, offset_point);
trace_dump_member(bool, state, offset_line);
trace_dump_member(bool, state, offset_tri);
trace_dump_member(bool, state, scissor);
trace_dump_member(bool, state, poly_smooth);
trace_dump_member(bool, state, poly_stipple_enable);
trace_dump_member(bool, state, point_smooth);
trace_dump_member(uint, state, sprite_coord_enable);
trace_dump_member(bool, state, sprite_coord_mode);
trace_dump_member(bool, state, point_quad_rasterization);
trace_dump_member(bool, state, point_size_per_vertex);
trace_dump_member(bool, state, multisample);
trace_dump_member(bool, state, line_smooth);
trace_dump_member(bool, state, line_stipple_enable);
trace_dump_member(uint, state, line_stipple_factor);
trace_dump_member(uint, state, line_stipple_pattern);
trace_dump_member(bool, state, line_last_pixel);
trace_dump_member(bool, state, flatshade_first);
trace_dump_member(bool, state, half_pixel_center);
trace_dump_member(bool, state, bottom_edge_rule);
trace_dump_member(bool, state, rasterizer_discard);
trace_dump_member(bool, state, depth_clip);
trace_dump_member(bool, state, clip_halfz);
trace_dump_member(uint, state, clip_plane_enable);
 
trace_dump_member(float, state, line_width);
trace_dump_member(float, state, point_size);
trace_dump_member(float, state, offset_units);
trace_dump_member(float, state, offset_scale);
trace_dump_member(float, state, offset_clamp);
 
trace_dump_struct_end();
}
 
 
void trace_dump_poly_stipple(const struct pipe_poly_stipple *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_poly_stipple");
 
trace_dump_member_begin("stipple");
trace_dump_array(uint,
state->stipple,
Elements(state->stipple));
trace_dump_member_end();
 
trace_dump_struct_end();
}
 
 
void trace_dump_viewport_state(const struct pipe_viewport_state *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_viewport_state");
 
trace_dump_member_array(float, state, scale);
trace_dump_member_array(float, state, translate);
 
trace_dump_struct_end();
}
 
 
void trace_dump_scissor_state(const struct pipe_scissor_state *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_scissor_state");
 
trace_dump_member(uint, state, minx);
trace_dump_member(uint, state, miny);
trace_dump_member(uint, state, maxx);
trace_dump_member(uint, state, maxy);
 
trace_dump_struct_end();
}
 
 
void trace_dump_clip_state(const struct pipe_clip_state *state)
{
unsigned i;
 
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_clip_state");
 
trace_dump_member_begin("ucp");
trace_dump_array_begin();
for(i = 0; i < PIPE_MAX_CLIP_PLANES; ++i) {
trace_dump_elem_begin();
trace_dump_array(float, state->ucp[i], 4);
trace_dump_elem_end();
}
trace_dump_array_end();
trace_dump_member_end();
 
trace_dump_struct_end();
}
 
 
void trace_dump_shader_state(const struct pipe_shader_state *state)
{
static char str[8192];
unsigned i;
 
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
tgsi_dump_str(state->tokens, 0, str, sizeof(str));
 
trace_dump_struct_begin("pipe_shader_state");
 
trace_dump_member_begin("tokens");
trace_dump_string(str);
trace_dump_member_end();
 
trace_dump_member_begin("stream_output");
trace_dump_struct_begin("pipe_stream_output_info");
trace_dump_member(uint, &state->stream_output, num_outputs);
trace_dump_member_array(uint, &state->stream_output, stride);
trace_dump_member_begin("output");
trace_dump_array_begin();
for(i = 0; i < state->stream_output.num_outputs; ++i) {
trace_dump_elem_begin();
trace_dump_struct_begin(""); /* anonymous */
trace_dump_member(uint, &state->stream_output.output[i], register_index);
trace_dump_member(uint, &state->stream_output.output[i], start_component);
trace_dump_member(uint, &state->stream_output.output[i], num_components);
trace_dump_member(uint, &state->stream_output.output[i], output_buffer);
trace_dump_member(uint, &state->stream_output.output[i], dst_offset);
trace_dump_struct_end();
trace_dump_elem_end();
}
trace_dump_array_end();
trace_dump_member_end(); // output
trace_dump_struct_end();
trace_dump_member_end(); // stream_output
 
trace_dump_struct_end();
}
 
 
void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state *state)
{
unsigned i;
 
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
 
trace_dump_member_begin("depth");
trace_dump_struct_begin("pipe_depth_state");
trace_dump_member(bool, &state->depth, enabled);
trace_dump_member(bool, &state->depth, writemask);
trace_dump_member(uint, &state->depth, func);
trace_dump_struct_end();
trace_dump_member_end();
 
trace_dump_member_begin("stencil");
trace_dump_array_begin();
for(i = 0; i < Elements(state->stencil); ++i) {
trace_dump_elem_begin();
trace_dump_struct_begin("pipe_stencil_state");
trace_dump_member(bool, &state->stencil[i], enabled);
trace_dump_member(uint, &state->stencil[i], func);
trace_dump_member(uint, &state->stencil[i], fail_op);
trace_dump_member(uint, &state->stencil[i], zpass_op);
trace_dump_member(uint, &state->stencil[i], zfail_op);
trace_dump_member(uint, &state->stencil[i], valuemask);
trace_dump_member(uint, &state->stencil[i], writemask);
trace_dump_struct_end();
trace_dump_elem_end();
}
trace_dump_array_end();
trace_dump_member_end();
 
trace_dump_member_begin("alpha");
trace_dump_struct_begin("pipe_alpha_state");
trace_dump_member(bool, &state->alpha, enabled);
trace_dump_member(uint, &state->alpha, func);
trace_dump_member(float, &state->alpha, ref_value);
trace_dump_struct_end();
trace_dump_member_end();
 
trace_dump_struct_end();
}
 
static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state *state)
{
trace_dump_struct_begin("pipe_rt_blend_state");
 
trace_dump_member(uint, state, blend_enable);
 
trace_dump_member(uint, state, rgb_func);
trace_dump_member(uint, state, rgb_src_factor);
trace_dump_member(uint, state, rgb_dst_factor);
 
trace_dump_member(uint, state, alpha_func);
trace_dump_member(uint, state, alpha_src_factor);
trace_dump_member(uint, state, alpha_dst_factor);
 
trace_dump_member(uint, state, colormask);
 
trace_dump_struct_end();
}
 
void trace_dump_blend_state(const struct pipe_blend_state *state)
{
unsigned valid_entries = 1;
 
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_blend_state");
 
trace_dump_member(bool, state, dither);
 
trace_dump_member(bool, state, logicop_enable);
trace_dump_member(uint, state, logicop_func);
 
trace_dump_member(bool, state, independent_blend_enable);
 
trace_dump_member_begin("rt");
if (state->independent_blend_enable)
valid_entries = PIPE_MAX_COLOR_BUFS;
trace_dump_struct_array(rt_blend_state, state->rt, valid_entries);
trace_dump_member_end();
 
trace_dump_struct_end();
}
 
 
void trace_dump_blend_color(const struct pipe_blend_color *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_blend_color");
 
trace_dump_member_array(float, state, color);
 
trace_dump_struct_end();
}
 
void trace_dump_stencil_ref(const struct pipe_stencil_ref *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_stencil_ref");
 
trace_dump_member_array(uint, state, ref_value);
 
trace_dump_struct_end();
}
 
void trace_dump_framebuffer_state(const struct pipe_framebuffer_state *state)
{
if (!trace_dumping_enabled_locked())
return;
 
trace_dump_struct_begin("pipe_framebuffer_state");
 
trace_dump_member(uint, state, width);
trace_dump_member(uint, state, height);
trace_dump_member(uint, state, nr_cbufs);
trace_dump_member_array(ptr, state, cbufs);
trace_dump_member(ptr, state, zsbuf);
 
trace_dump_struct_end();
}
 
 
void trace_dump_sampler_state(const struct pipe_sampler_state *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_sampler_state");
 
trace_dump_member(uint, state, wrap_s);
trace_dump_member(uint, state, wrap_t);
trace_dump_member(uint, state, wrap_r);
trace_dump_member(uint, state, min_img_filter);
trace_dump_member(uint, state, min_mip_filter);
trace_dump_member(uint, state, mag_img_filter);
trace_dump_member(uint, state, compare_mode);
trace_dump_member(uint, state, compare_func);
trace_dump_member(bool, state, normalized_coords);
trace_dump_member(uint, state, max_anisotropy);
trace_dump_member(float, state, lod_bias);
trace_dump_member(float, state, min_lod);
trace_dump_member(float, state, max_lod);
trace_dump_member_array(float, state, border_color.f);
 
trace_dump_struct_end();
}
 
 
void trace_dump_sampler_view_template(const struct pipe_sampler_view *state,
enum pipe_texture_target target)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_sampler_view");
 
trace_dump_member(format, state, format);
 
trace_dump_member_begin("u");
trace_dump_struct_begin(""); /* anonymous */
if (target == PIPE_BUFFER) {
trace_dump_member_begin("buf");
trace_dump_struct_begin(""); /* anonymous */
trace_dump_member(uint, &state->u.buf, first_element);
trace_dump_member(uint, &state->u.buf, last_element);
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* buf */
} else {
trace_dump_member_begin("tex");
trace_dump_struct_begin(""); /* anonymous */
trace_dump_member(uint, &state->u.tex, first_layer);
trace_dump_member(uint, &state->u.tex, last_layer);
trace_dump_member(uint, &state->u.tex, first_level);
trace_dump_member(uint, &state->u.tex, last_level);
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* tex */
}
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* u */
 
trace_dump_member(uint, state, swizzle_r);
trace_dump_member(uint, state, swizzle_g);
trace_dump_member(uint, state, swizzle_b);
trace_dump_member(uint, state, swizzle_a);
 
trace_dump_struct_end();
}
 
 
void trace_dump_surface_template(const struct pipe_surface *state,
enum pipe_texture_target target)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_surface");
 
trace_dump_member(format, state, format);
trace_dump_member(uint, state, width);
trace_dump_member(uint, state, height);
 
trace_dump_member_begin("u");
trace_dump_struct_begin(""); /* anonymous */
if (target == PIPE_BUFFER) {
trace_dump_member_begin("buf");
trace_dump_struct_begin(""); /* anonymous */
trace_dump_member(uint, &state->u.buf, first_element);
trace_dump_member(uint, &state->u.buf, last_element);
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* buf */
} else {
trace_dump_member_begin("tex");
trace_dump_struct_begin(""); /* anonymous */
trace_dump_member(uint, &state->u.tex, level);
trace_dump_member(uint, &state->u.tex, first_layer);
trace_dump_member(uint, &state->u.tex, last_layer);
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* tex */
}
trace_dump_struct_end(); /* anonymous */
trace_dump_member_end(); /* u */
 
trace_dump_struct_end();
}
 
 
void trace_dump_transfer(const struct pipe_transfer *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_transfer");
 
trace_dump_member(uint, state, box.x);
trace_dump_member(uint, state, box.y);
trace_dump_member(uint, state, box.z);
trace_dump_member(uint, state, box.width);
trace_dump_member(uint, state, box.height);
trace_dump_member(uint, state, box.depth);
 
trace_dump_member(uint, state, stride);
trace_dump_member(uint, state, layer_stride);
trace_dump_member(uint, state, usage);
 
trace_dump_member(ptr, state, resource);
 
trace_dump_struct_end();
}
 
 
void trace_dump_vertex_buffer(const struct pipe_vertex_buffer *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_vertex_buffer");
 
trace_dump_member(uint, state, stride);
trace_dump_member(uint, state, buffer_offset);
trace_dump_member(resource_ptr, state, buffer);
 
trace_dump_struct_end();
}
 
 
void trace_dump_index_buffer(const struct pipe_index_buffer *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_index_buffer");
 
trace_dump_member(uint, state, index_size);
trace_dump_member(uint, state, offset);
trace_dump_member(resource_ptr, state, buffer);
 
trace_dump_struct_end();
}
 
 
void trace_dump_vertex_element(const struct pipe_vertex_element *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_vertex_element");
 
trace_dump_member(uint, state, src_offset);
 
trace_dump_member(uint, state, vertex_buffer_index);
 
trace_dump_member(format, state, src_format);
 
trace_dump_struct_end();
}
 
 
void trace_dump_constant_buffer(const struct pipe_constant_buffer *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_constant_buffer");
trace_dump_member(ptr, state, buffer);
trace_dump_member(uint, state, buffer_offset);
trace_dump_member(uint, state, buffer_size);
trace_dump_struct_end();
}
 
 
void trace_dump_draw_info(const struct pipe_draw_info *state)
{
if (!trace_dumping_enabled_locked())
return;
 
if(!state) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_draw_info");
 
trace_dump_member(bool, state, indexed);
 
trace_dump_member(uint, state, mode);
trace_dump_member(uint, state, start);
trace_dump_member(uint, state, count);
 
trace_dump_member(uint, state, start_instance);
trace_dump_member(uint, state, instance_count);
 
trace_dump_member(int, state, index_bias);
trace_dump_member(uint, state, min_index);
trace_dump_member(uint, state, max_index);
 
trace_dump_member(bool, state, primitive_restart);
trace_dump_member(uint, state, restart_index);
 
trace_dump_member(ptr, state, count_from_stream_output);
 
trace_dump_struct_end();
}
 
void trace_dump_blit_info(const struct pipe_blit_info *info)
{
char mask[7];
 
if (!trace_dumping_enabled_locked())
return;
 
if (!info) {
trace_dump_null();
return;
}
 
trace_dump_struct_begin("pipe_blit_info");
 
trace_dump_member_begin("dst");
trace_dump_struct_begin("dst");
trace_dump_member(resource_ptr, &info->dst, resource);
trace_dump_member(uint, &info->dst, level);
trace_dump_member(format, &info->dst, format);
trace_dump_member_begin("box");
trace_dump_box(&info->dst.box);
trace_dump_member_end();
trace_dump_struct_end();
trace_dump_member_end();
 
trace_dump_member_begin("src");
trace_dump_struct_begin("src");
trace_dump_member(resource_ptr, &info->src, resource);
trace_dump_member(uint, &info->src, level);
trace_dump_member(format, &info->src, format);
trace_dump_member_begin("box");
trace_dump_box(&info->src.box);
trace_dump_member_end();
trace_dump_struct_end();
trace_dump_member_end();
 
mask[0] = (info->mask & PIPE_MASK_R) ? 'R' : '-';
mask[1] = (info->mask & PIPE_MASK_G) ? 'G' : '-';
mask[2] = (info->mask & PIPE_MASK_B) ? 'B' : '-';
mask[3] = (info->mask & PIPE_MASK_A) ? 'A' : '-';
mask[4] = (info->mask & PIPE_MASK_Z) ? 'Z' : '-';
mask[5] = (info->mask & PIPE_MASK_S) ? 'S' : '-';
mask[6] = 0;
 
trace_dump_member_begin("mask");
trace_dump_string(mask);
trace_dump_member_end();
trace_dump_member(uint, info, filter);
 
trace_dump_member(bool, info, scissor_enable);
trace_dump_member_begin("scissor");
trace_dump_scissor_state(&info->scissor);
trace_dump_member_end();
 
trace_dump_struct_end();
}
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_dump_state.h
0,0 → 1,89
/**************************************************************************
*
* Copyright 2008 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 TR_DUMP_STATE_H_
#define TR_DUMP_STATE_H_
 
#include "pipe/p_format.h"
#include "pipe/p_state.h"
#include "pipe/p_shader_tokens.h"
 
 
void trace_dump_format(enum pipe_format format);
 
void trace_dump_resource_template(const struct pipe_resource *templat);
 
void trace_dump_box(const struct pipe_box *box);
 
void trace_dump_rasterizer_state(const struct pipe_rasterizer_state *state);
 
void trace_dump_poly_stipple(const struct pipe_poly_stipple *state);
 
void trace_dump_viewport_state(const struct pipe_viewport_state *state);
 
void trace_dump_scissor_state(const struct pipe_scissor_state *state);
 
void trace_dump_clip_state(const struct pipe_clip_state *state);
 
void trace_dump_token(const struct tgsi_token *token);
 
void trace_dump_shader_state(const struct pipe_shader_state *state);
 
void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state *state);
 
void trace_dump_blend_state(const struct pipe_blend_state *state);
 
void trace_dump_blend_color(const struct pipe_blend_color *state);
 
void trace_dump_stencil_ref(const struct pipe_stencil_ref *state);
 
void trace_dump_framebuffer_state(const struct pipe_framebuffer_state *state);
 
void trace_dump_sampler_state(const struct pipe_sampler_state *state);
 
void trace_dump_sampler_view_template(const struct pipe_sampler_view *view,
enum pipe_texture_target target);
 
void trace_dump_surface_template(const struct pipe_surface *state,
enum pipe_texture_target target);
 
void trace_dump_transfer(const struct pipe_transfer *state);
 
void trace_dump_vertex_buffer(const struct pipe_vertex_buffer *state);
 
void trace_dump_index_buffer(const struct pipe_index_buffer *state);
 
void trace_dump_vertex_element(const struct pipe_vertex_element *state);
 
void trace_dump_constant_buffer(const struct pipe_constant_buffer *state);
 
void trace_dump_draw_info(const struct pipe_draw_info *state);
 
void trace_dump_blit_info(const struct pipe_blit_info *);
 
 
#endif /* TR_STATE_H */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_public.h
0,0 → 1,48
/**************************************************************************
*
* Copyright 2010 VMware, Inc.
* 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.
*
**************************************************************************/
 
#ifndef TR_PUBLIC_H
#define TR_PUBLIC_H
 
#ifdef __cplusplus
extern "C" {
#endif
 
struct pipe_screen;
struct pipe_context;
 
struct pipe_screen *
trace_screen_create(struct pipe_screen *screen);
 
boolean
trace_enabled(void);
 
#ifdef __cplusplus
}
#endif
 
#endif /* TR_PUBLIC_H */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_screen.c
0,0 → 1,510
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
#include "util/u_format.h"
#include "util/u_memory.h"
#include "util/u_simple_list.h"
 
#include "tr_dump.h"
#include "tr_dump_state.h"
#include "tr_texture.h"
#include "tr_context.h"
#include "tr_screen.h"
#include "tr_public.h"
 
#include "pipe/p_format.h"
 
 
static boolean trace = FALSE;
 
static const char *
trace_screen_get_name(struct pipe_screen *_screen)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
const char *result;
 
trace_dump_call_begin("pipe_screen", "get_name");
 
trace_dump_arg(ptr, screen);
 
result = screen->get_name(screen);
 
trace_dump_ret(string, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static const char *
trace_screen_get_vendor(struct pipe_screen *_screen)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
const char *result;
 
trace_dump_call_begin("pipe_screen", "get_vendor");
 
trace_dump_arg(ptr, screen);
 
result = screen->get_vendor(screen);
 
trace_dump_ret(string, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static int
trace_screen_get_param(struct pipe_screen *_screen,
enum pipe_cap param)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
int result;
 
trace_dump_call_begin("pipe_screen", "get_param");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(int, param);
 
result = screen->get_param(screen, param);
 
trace_dump_ret(int, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static int
trace_screen_get_shader_param(struct pipe_screen *_screen, unsigned shader,
enum pipe_shader_cap param)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
int result;
 
trace_dump_call_begin("pipe_screen", "get_shader_param");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(uint, shader);
trace_dump_arg(int, param);
 
result = screen->get_shader_param(screen, shader, param);
 
trace_dump_ret(int, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static float
trace_screen_get_paramf(struct pipe_screen *_screen,
enum pipe_capf param)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
float result;
 
trace_dump_call_begin("pipe_screen", "get_paramf");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(int, param);
 
result = screen->get_paramf(screen, param);
 
trace_dump_ret(float, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static boolean
trace_screen_is_format_supported(struct pipe_screen *_screen,
enum pipe_format format,
enum pipe_texture_target target,
unsigned sample_count,
unsigned tex_usage)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
boolean result;
 
trace_dump_call_begin("pipe_screen", "is_format_supported");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(format, format);
trace_dump_arg(int, target);
trace_dump_arg(uint, sample_count);
trace_dump_arg(uint, tex_usage);
 
result = screen->is_format_supported(screen, format, target, sample_count,
tex_usage);
 
trace_dump_ret(bool, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static struct pipe_context *
trace_screen_context_create(struct pipe_screen *_screen, void *priv)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
struct pipe_context *result;
 
trace_dump_call_begin("pipe_screen", "context_create");
 
trace_dump_arg(ptr, screen);
 
result = screen->context_create(screen, priv);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
result = trace_context_create(tr_scr, result);
 
return result;
}
 
 
static void
trace_screen_flush_frontbuffer(struct pipe_screen *_screen,
struct pipe_resource *_resource,
unsigned level, unsigned layer,
void *context_private)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_screen *screen = tr_scr->screen;
struct pipe_resource *resource = tr_res->resource;
 
trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(ptr, resource);
trace_dump_arg(uint, level);
trace_dump_arg(uint, layer);
/* XXX: hide, as there is nothing we can do with this
trace_dump_arg(ptr, context_private);
*/
 
screen->flush_frontbuffer(screen, resource, level, layer, context_private);
 
trace_dump_call_end();
}
 
 
/********************************************************************
* texture
*/
 
 
static struct pipe_resource *
trace_screen_resource_create(struct pipe_screen *_screen,
const struct pipe_resource *templat)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
struct pipe_resource *result;
 
trace_dump_call_begin("pipe_screen", "resource_create");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(resource_template, templat);
 
result = screen->resource_create(screen, templat);
 
trace_dump_ret(ptr, result);
 
trace_dump_call_end();
 
result = trace_resource_create(tr_scr, result);
 
return result;
}
 
static struct pipe_resource *
trace_screen_resource_from_handle(struct pipe_screen *_screen,
const struct pipe_resource *templ,
struct winsys_handle *handle)
{
struct trace_screen *tr_screen = trace_screen(_screen);
struct pipe_screen *screen = tr_screen->screen;
struct pipe_resource *result;
 
/* TODO trace call */
 
result = screen->resource_from_handle(screen, templ, handle);
 
result = trace_resource_create(trace_screen(_screen), result);
 
return result;
}
 
static boolean
trace_screen_resource_get_handle(struct pipe_screen *_screen,
struct pipe_resource *_resource,
struct winsys_handle *handle)
{
struct trace_screen *tr_screen = trace_screen(_screen);
struct trace_resource *tr_resource = trace_resource(_resource);
struct pipe_screen *screen = tr_screen->screen;
struct pipe_resource *resource = tr_resource->resource;
 
/* TODO trace call */
 
return screen->resource_get_handle(screen, resource, handle);
}
 
 
 
static void
trace_screen_resource_destroy(struct pipe_screen *_screen,
struct pipe_resource *_resource)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct trace_resource *tr_res = trace_resource(_resource);
struct pipe_screen *screen = tr_scr->screen;
struct pipe_resource *resource = tr_res->resource;
 
assert(resource->screen == screen);
 
trace_dump_call_begin("pipe_screen", "resource_destroy");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(ptr, resource);
 
trace_dump_call_end();
 
trace_resource_destroy(tr_scr, tr_res);
}
 
 
/********************************************************************
* fence
*/
 
 
static void
trace_screen_fence_reference(struct pipe_screen *_screen,
struct pipe_fence_handle **pdst,
struct pipe_fence_handle *src)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
struct pipe_fence_handle *dst;
 
assert(pdst);
dst = *pdst;
trace_dump_call_begin("pipe_screen", "fence_reference");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(ptr, dst);
trace_dump_arg(ptr, src);
 
screen->fence_reference(screen, pdst, src);
 
trace_dump_call_end();
}
 
 
static boolean
trace_screen_fence_signalled(struct pipe_screen *_screen,
struct pipe_fence_handle *fence)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
int result;
 
trace_dump_call_begin("pipe_screen", "fence_signalled");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(ptr, fence);
 
result = screen->fence_signalled(screen, fence);
 
trace_dump_ret(bool, result);
 
trace_dump_call_end();
 
return result;
}
 
 
static boolean
trace_screen_fence_finish(struct pipe_screen *_screen,
struct pipe_fence_handle *fence,
uint64_t timeout)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
int result;
 
trace_dump_call_begin("pipe_screen", "fence_finish");
 
trace_dump_arg(ptr, screen);
trace_dump_arg(ptr, fence);
trace_dump_arg(uint, timeout);
 
result = screen->fence_finish(screen, fence, timeout);
 
trace_dump_ret(bool, result);
 
trace_dump_call_end();
 
return result;
}
 
 
/********************************************************************
* screen
*/
 
static uint64_t
trace_screen_get_timestamp(struct pipe_screen *_screen)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
uint64_t result;
 
trace_dump_call_begin("pipe_screen", "get_timestamp");
trace_dump_arg(ptr, screen);
 
result = screen->get_timestamp(screen);
 
trace_dump_ret(uint, result);
trace_dump_call_end();
 
return result;
}
 
static void
trace_screen_destroy(struct pipe_screen *_screen)
{
struct trace_screen *tr_scr = trace_screen(_screen);
struct pipe_screen *screen = tr_scr->screen;
 
trace_dump_call_begin("pipe_screen", "destroy");
trace_dump_arg(ptr, screen);
trace_dump_call_end();
 
screen->destroy(screen);
 
FREE(tr_scr);
}
 
boolean
trace_enabled(void)
{
static boolean firstrun = TRUE;
 
if (!firstrun)
return trace;
firstrun = FALSE;
 
if(trace_dump_trace_begin()) {
trace_dumping_start();
trace = TRUE;
}
 
return trace;
}
 
struct pipe_screen *
trace_screen_create(struct pipe_screen *screen)
{
struct trace_screen *tr_scr;
 
if(!screen)
goto error1;
 
if (!trace_enabled())
goto error1;
 
trace_dump_call_begin("", "pipe_screen_create");
 
tr_scr = CALLOC_STRUCT(trace_screen);
if(!tr_scr)
goto error2;
 
tr_scr->base.destroy = trace_screen_destroy;
tr_scr->base.get_name = trace_screen_get_name;
tr_scr->base.get_vendor = trace_screen_get_vendor;
tr_scr->base.get_param = trace_screen_get_param;
tr_scr->base.get_shader_param = trace_screen_get_shader_param;
tr_scr->base.get_paramf = trace_screen_get_paramf;
tr_scr->base.is_format_supported = trace_screen_is_format_supported;
assert(screen->context_create);
tr_scr->base.context_create = trace_screen_context_create;
tr_scr->base.resource_create = trace_screen_resource_create;
tr_scr->base.resource_from_handle = trace_screen_resource_from_handle;
tr_scr->base.resource_get_handle = trace_screen_resource_get_handle;
tr_scr->base.resource_destroy = trace_screen_resource_destroy;
tr_scr->base.fence_reference = trace_screen_fence_reference;
tr_scr->base.fence_signalled = trace_screen_fence_signalled;
tr_scr->base.fence_finish = trace_screen_fence_finish;
tr_scr->base.flush_frontbuffer = trace_screen_flush_frontbuffer;
tr_scr->base.get_timestamp = trace_screen_get_timestamp;
 
tr_scr->screen = screen;
 
trace_dump_ret(ptr, screen);
trace_dump_call_end();
 
return &tr_scr->base;
 
error2:
trace_dump_ret(ptr, screen);
trace_dump_call_end();
error1:
return screen;
}
 
 
struct trace_screen *
trace_screen(struct pipe_screen *screen)
{
assert(screen);
assert(screen->destroy == trace_screen_destroy);
return (struct trace_screen *)screen;
}
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_screen.h
0,0 → 1,65
/**************************************************************************
*
* Copyright 2008 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 TR_SCREEN_H_
#define TR_SCREEN_H_
 
 
#include "pipe/p_screen.h"
#include "os/os_thread.h"
 
 
#ifdef __cplusplus
extern "C" {
#endif
 
 
/**
* It often happens that new data is written directly to the user buffers
* without mapping/unmapping. This flag marks user buffers, so that their
* contents can be dumped before being used by the pipe context.
*/
#define TRACE_FLAG_USER_BUFFER (1 << 31)
 
 
struct trace_screen
{
struct pipe_screen base;
 
struct pipe_screen *screen;
};
 
 
struct trace_screen *
trace_screen(struct pipe_screen *screen);
 
 
#ifdef __cplusplus
}
#endif
 
#endif /* TR_SCREEN_H_ */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_texture.c
0,0 → 1,157
/**************************************************************************
*
* Copyright 2008 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.
*
**************************************************************************/
 
#include "util/u_inlines.h"
#include "util/u_hash_table.h"
#include "util/u_memory.h"
#include "util/u_simple_list.h"
 
#include "tr_screen.h"
#include "tr_context.h"
#include "tr_texture.h"
 
 
struct pipe_resource *
trace_resource_create(struct trace_screen *tr_scr,
struct pipe_resource *texture)
{
struct trace_resource *tr_res;
 
if(!texture)
goto error;
 
assert(texture->screen == tr_scr->screen);
 
tr_res = CALLOC_STRUCT(trace_resource);
if(!tr_res)
goto error;
 
memcpy(&tr_res->base, texture, sizeof(struct pipe_resource));
 
pipe_reference_init(&tr_res->base.reference, 1);
tr_res->base.screen = &tr_scr->base;
tr_res->resource = texture;
 
return &tr_res->base;
 
error:
pipe_resource_reference(&texture, NULL);
return NULL;
}
 
 
void
trace_resource_destroy(struct trace_screen *tr_scr,
struct trace_resource *tr_res)
{
pipe_resource_reference(&tr_res->resource, NULL);
FREE(tr_res);
}
 
 
struct pipe_surface *
trace_surf_create(struct trace_context *tr_ctx,
struct trace_resource *tr_res,
struct pipe_surface *surface)
{
struct trace_surface *tr_surf;
 
if(!surface)
goto error;
 
assert(surface->texture == tr_res->resource);
 
tr_surf = CALLOC_STRUCT(trace_surface);
if(!tr_surf)
goto error;
 
memcpy(&tr_surf->base, surface, sizeof(struct pipe_surface));
tr_surf->base.context = &tr_ctx->base;
 
pipe_reference_init(&tr_surf->base.reference, 1);
tr_surf->base.texture = NULL;
pipe_resource_reference(&tr_surf->base.texture, &tr_res->base);
tr_surf->surface = surface;
 
return &tr_surf->base;
 
error:
pipe_surface_reference(&surface, NULL);
return NULL;
}
 
 
void
trace_surf_destroy(struct trace_surface *tr_surf)
{
trace_context_check(tr_surf->base.context);
pipe_resource_reference(&tr_surf->base.texture, NULL);
pipe_surface_reference(&tr_surf->surface, NULL);
FREE(tr_surf);
}
 
 
struct pipe_transfer *
trace_transfer_create(struct trace_context *tr_ctx,
struct trace_resource *tr_res,
struct pipe_transfer *transfer)
{
struct trace_transfer *tr_trans;
 
if(!transfer)
goto error;
 
assert(transfer->resource == tr_res->resource);
 
tr_trans = CALLOC_STRUCT(trace_transfer);
if(!tr_trans)
goto error;
 
memcpy(&tr_trans->base, transfer, sizeof(struct pipe_transfer));
 
tr_trans->base.resource = NULL;
tr_trans->transfer = transfer;
 
pipe_resource_reference(&tr_trans->base.resource, &tr_res->base);
assert(tr_trans->base.resource == &tr_res->base);
 
return &tr_trans->base;
 
error:
tr_ctx->pipe->transfer_unmap(tr_ctx->pipe, transfer);
return NULL;
}
 
 
void
trace_transfer_destroy(struct trace_context *tr_context,
struct trace_transfer *tr_trans)
{
pipe_resource_reference(&tr_trans->base.resource, NULL);
FREE(tr_trans);
}
 
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/tr_texture.h
0,0 → 1,153
/**************************************************************************
*
* Copyright 2008 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 TR_TEXTURE_H_
#define TR_TEXTURE_H_
 
 
#include "pipe/p_compiler.h"
#include "pipe/p_state.h"
 
#include "tr_screen.h"
 
struct trace_context;
 
 
struct tr_list
{
struct tr_list *next;
struct tr_list *prev;
};
 
 
struct trace_resource
{
struct pipe_resource base;
 
struct pipe_resource *resource;
 
struct tr_list list;
};
 
 
struct trace_surface
{
struct pipe_surface base;
 
struct pipe_surface *surface;
 
struct tr_list list;
};
 
 
struct trace_sampler_view
{
struct pipe_sampler_view base;
 
struct pipe_sampler_view *sampler_view;
};
 
 
struct trace_transfer
{
struct pipe_transfer base;
 
struct pipe_transfer *transfer;
struct pipe_context *pipe;
 
struct tr_list list;
 
void *map;
};
 
 
static INLINE struct trace_resource *
trace_resource(struct pipe_resource *texture)
{
if(!texture)
return NULL;
(void)trace_screen(texture->screen);
return (struct trace_resource *)texture;
}
 
 
static INLINE struct trace_surface *
trace_surface(struct pipe_surface *surface)
{
if(!surface)
return NULL;
(void)trace_resource(surface->texture);
return (struct trace_surface *)surface;
}
 
 
static INLINE struct trace_sampler_view *
trace_sampler_view(struct pipe_sampler_view *sampler_view)
{
if (!sampler_view)
return NULL;
return (struct trace_sampler_view *)sampler_view;
}
 
 
static INLINE struct trace_transfer *
trace_transfer(struct pipe_transfer *transfer)
{
if(!transfer)
return NULL;
(void)trace_resource(transfer->resource);
return (struct trace_transfer *)transfer;
}
 
 
struct pipe_resource *
trace_resource_create(struct trace_screen *tr_scr,
struct pipe_resource *texture);
 
void
trace_resource_destroy(struct trace_screen *tr_scr,
struct trace_resource *tr_res);
 
struct pipe_surface *
trace_surf_create(struct trace_context *tr_ctx,
struct trace_resource *tr_res,
struct pipe_surface *surface);
 
void
trace_surf_destroy(struct trace_surface *tr_surf);
 
struct pipe_transfer *
trace_transfer_create(struct trace_context *tr_ctx,
struct trace_resource *tr_res,
struct pipe_transfer *transfer);
 
void
trace_transfer_destroy(struct trace_context *tr_ctx,
struct trace_transfer *tr_trans);
 
 
#endif /* TR_TEXTURE_H_ */
/contrib/sdk/sources/Mesa/src/gallium/drivers/trace/trace.xsl
0,0 → 1,188
<?xml version="1.0"?>
 
<!--
 
Copyright 2008 Tungsten Graphics, Inc.
 
This program is free software: you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
 
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
 
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
 
!-->
 
<xsl:transform version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 
<xsl:output method="html" />
 
<xsl:strip-space elements="*" />
 
<xsl:template match="/trace">
<html>
<head>
<title>Gallium Trace</title>
</head>
<style>
body {
font-family: verdana, sans-serif;
font-size: 11px;
font-weight: normal;
text-align : left;
}
 
.fun {
font-weight: bold;
}
 
.var {
font-style: italic;
}
 
.typ {
display: none;
}
 
.lit {
color: #0000ff;
}
 
.ptr {
color: #008000;
}
</style>
<body>
<ol class="calls">
<xsl:apply-templates/>
</ol>
</body>
</html>
</xsl:template>
 
<xsl:template match="call">
<li>
<xsl:attribute name="value">
<xsl:apply-templates select="@no"/>
</xsl:attribute>
<span class="fun">
<xsl:value-of select="@class"/>
<xsl:text>::</xsl:text>
<xsl:value-of select="@method"/>
</span>
<xsl:text>(</xsl:text>
<xsl:apply-templates select="arg"/>
<xsl:text>)</xsl:text>
<xsl:apply-templates select="ret"/>
</li>
</xsl:template>
 
<xsl:template match="arg|member">
<xsl:apply-templates select="@name"/>
<xsl:text> = </xsl:text>
<xsl:apply-templates />
<xsl:if test="position() != last()">
<xsl:text>, </xsl:text>
</xsl:if>
</xsl:template>
 
<xsl:template match="ret">
<xsl:text> = </xsl:text>
<xsl:apply-templates />
</xsl:template>
 
<xsl:template match="bool|int|uint|float|enum">
<span class="lit">
<xsl:value-of select="text()"/>
</span>
</xsl:template>
 
<xsl:template match="bytes">
<span class="lit">
<xsl:text>...</xsl:text>
</span>
</xsl:template>
 
<xsl:template match="string">
<span class="lit">
<xsl:text>"</xsl:text>
<xsl:call-template name="break">
<xsl:with-param name="text" select="text()"/>
</xsl:call-template>
<xsl:text>"</xsl:text>
</span>
</xsl:template>
 
<xsl:template match="array|struct">
<xsl:text>{</xsl:text>
<xsl:apply-templates />
<xsl:text>}</xsl:text>
</xsl:template>
 
<xsl:template match="elem">
<xsl:apply-templates />
<xsl:if test="position() != last()">
<xsl:text>, </xsl:text>
</xsl:if>
</xsl:template>
 
<xsl:template match="null">
<span class="ptr">
<xsl:text>NULL</xsl:text>
</span>
</xsl:template>
 
<xsl:template match="ptr">
<span class="ptr">
<xsl:value-of select="text()"/>
</span>
</xsl:template>
 
<xsl:template match="@name">
<span class="var">
<xsl:value-of select="."/>
</span>
</xsl:template>
<xsl:template name="break">
<xsl:param name="text" select="."/>
<xsl:choose>
<xsl:when test="contains($text, '&#xa;')">
<xsl:value-of select="substring-before($text, '&#xa;')"/>
<br/>
<xsl:call-template name="break">
<xsl:with-param name="text" select="substring-after($text, '&#xa;')"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$text"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
 
<xsl:template name="replace">
<xsl:param name="text"/>
<xsl:param name="from"/>
<xsl:param name="to"/>
<xsl:choose>
<xsl:when test="contains($text,$from)">
<xsl:value-of select="concat(substring-before($text,$from),$to)"/>
<xsl:call-template name="replace">
<xsl:with-param name="text" select="substring-after($text,$from)"/>
<xsl:with-param name="from" select="$from"/>
<xsl:with-param name="to" select="$to"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$text"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
 
</xsl:transform>