]> git.cworth.org Git - apitrace/log
apitrace
12 years agod3dretrace: Dump DXGI_FORMAT_R32G32B32A32_FLOAT images in floating point.
José Fonseca [Mon, 16 Sep 2013 11:20:40 +0000 (12:20 +0100)]
d3dretrace: Dump DXGI_FORMAT_R32G32B32A32_FLOAT images in floating point.

12 years agogui: make sure that the alpha channel is initialized
Zack Rusin [Thu, 12 Sep 2013 21:41:57 +0000 (17:41 -0400)]
gui: make sure that the alpha channel is initialized

For surfaces with less than four channels we weren't
initializing the alpha channel resulting in an image
that had garbage for alpha.

12 years agogui: show the original pixel values in the surface viewer
Zack Rusin [Thu, 12 Sep 2013 21:21:51 +0000 (17:21 -0400)]
gui: show the original pixel values in the surface viewer

Image viewer now holds the original image surface which means
that even though it has to display the flattened version it
can correctly report the exact pixel value on every surface.

12 years agoglretrace: Dump depth buffers as floating point images.
José Fonseca [Thu, 12 Sep 2013 16:27:04 +0000 (17:27 +0100)]
glretrace: Dump depth buffers as floating point images.

12 years agoui: Handle float images in dumps.
José Fonseca [Thu, 12 Sep 2013 16:26:34 +0000 (17:26 +0100)]
ui: Handle float images in dumps.

12 years agoimage: Support reading PFM images.
José Fonseca [Thu, 12 Sep 2013 16:25:04 +0000 (17:25 +0100)]
image: Support reading PFM images.

12 years agoimage: Fix allocation of floating point images.
José Fonseca [Thu, 12 Sep 2013 16:21:37 +0000 (17:21 +0100)]
image: Fix allocation of floating point images.

12 years agod3dretrace: Fix MinGW build.
José Fonseca [Wed, 11 Sep 2013 17:45:43 +0000 (18:45 +0100)]
d3dretrace: Fix MinGW build.

12 years agogui: load image data via the Image class.
José Fonseca [Wed, 11 Sep 2013 17:42:07 +0000 (18:42 +0100)]
gui: load image data via the Image class.

A bit hackish.

A stepping stone to store images with Image class instead of QImage.

12 years agoimage: Add floating point support.
José Fonseca [Wed, 11 Sep 2013 17:41:00 +0000 (18:41 +0100)]
image: Add floating point support.

WIP. Not throughly tested.

12 years agoimage: Allow to read PNG from a C++ stream.
José Fonseca [Wed, 11 Sep 2013 17:16:18 +0000 (18:16 +0100)]
image: Allow to read PNG from a C++ stream.

12 years agoimage: Move helpers to respective modules.
José Fonseca [Wed, 11 Sep 2013 17:14:22 +0000 (18:14 +0100)]
image: Move helpers to respective modules.

12 years agoimage: Fix reading of PNG images with different number of channels.
José Fonseca [Wed, 11 Sep 2013 17:10:50 +0000 (18:10 +0100)]
image: Fix reading of PNG images with different number of channels.

12 years agoBuild fixes for VS2013
Nigel Stewart [Mon, 19 Aug 2013 15:58:47 +0000 (10:58 -0500)]
Build fixes for VS2013

https://github.com/p3/regal/pull/97

Signed-off-by: José Fonseca <jfonseca@vmware.com>
12 years agod3dretrace: Fix MSVC build.
José Fonseca [Wed, 11 Sep 2013 13:15:13 +0000 (14:15 +0100)]
d3dretrace: Fix MSVC build.

12 years agod3dretrace: Dump textures of all shader stages.
José Fonseca [Wed, 4 Sep 2013 09:49:32 +0000 (10:49 +0100)]
d3dretrace: Dump textures of all shader stages.

12 years agogui: Implement a new surface viewer
Zack Rusin [Wed, 11 Sep 2013 00:30:59 +0000 (20:30 -0400)]
gui: Implement a new surface viewer

Adds support for showing individual pixels and zooming in on the
image itself. All ready to be used for showing the actual original
pixel values, rather than the fake qimage pixels which it shows
right now.

12 years agoretracediff: Only diff state if specified by command line option.
José Fonseca [Thu, 22 Aug 2013 16:39:11 +0000 (17:39 +0100)]
retracediff: Only diff state if specified by command line option.

As it can be very slow.

12 years agoCheck for ARB_sampler_objects before dumping its state.
José Fonseca [Mon, 19 Aug 2013 15:42:07 +0000 (16:42 +0100)]
Check for ARB_sampler_objects before dumping its state.

Tested-by: Min-Yu Huang <min-yuhuang@vmware.com>
12 years agoTake GL_SAMPLER_BINDING in consideration.
Min-Yu Huang [Mon, 19 Aug 2013 14:41:52 +0000 (15:41 +0100)]
Take GL_SAMPLER_BINDING in consideration.

Fixed the issue that GL_SAMPLER_BINDING is only shown globally under
'Parameters' for the last activated texture unit.  We should show
GL_SAMPLER_BINDING for each texture unit.

In this change, we also introduce GL_SAMPLER under each texture unit if
the sampler is bound.

Signed-off-by: José Fonseca <jfonseca@vmware.com>
12 years agocli: Fix sed message.
José Fonseca [Thu, 25 Jul 2013 19:18:58 +0000 (20:18 +0100)]
cli: Fix sed message.

12 years agoUse EGLAttribArray all the time.
José Fonseca [Mon, 22 Jul 2013 18:26:01 +0000 (19:26 +0100)]
Use EGLAttribArray all the time.

12 years agoTrivial formatting / consistency fixes.
Andreas Hartmetz [Mon, 22 Jul 2013 17:57:50 +0000 (19:57 +0200)]
Trivial formatting / consistency fixes.

12 years agoUse the correct terminator EGL_NONE for eglChooseConfig attrib_list.
Andreas Hartmetz [Mon, 22 Jul 2013 17:56:40 +0000 (19:56 +0200)]
Use the correct terminator EGL_NONE for eglChooseConfig attrib_list.

12 years agoRe-enable rtti again.
José Fonseca [Sat, 20 Jul 2013 14:34:51 +0000 (15:34 +0100)]
Re-enable rtti again.

It causes problems with tr1/shared_ptr.h implementation on several platforms.

12 years agogltrace: Simplify AttribArray further.
José Fonseca [Sat, 20 Jul 2013 14:34:24 +0000 (15:34 +0100)]
gltrace: Simplify AttribArray further.

Make it look more like an Array.

12 years agocgltrace: Fix CGLChoosePixelFormat prototype.
José Fonseca [Sat, 20 Jul 2013 14:27:29 +0000 (15:27 +0100)]
cgltrace: Fix CGLChoosePixelFormat prototype.

And implify AttribList in the process.

12 years agoglretrace: Silence warning on wgl.
José Fonseca [Sat, 20 Jul 2013 14:06:01 +0000 (15:06 +0100)]
glretrace: Silence warning on wgl.

12 years agoBuild: Disable RTTI support at build-time to discourage the use of dynamic_cast, etc
Nigel Stewart [Fri, 19 Jul 2013 14:32:47 +0000 (09:32 -0500)]
Build: Disable RTTI support at build-time to discourage the use of dynamic_cast, etc

12 years agoglimports: Check for iOS and skip OpenGL and CGL as appropriate.
Nigel Stewart [Thu, 18 Jul 2013 00:40:25 +0000 (19:40 -0500)]
glimports: Check for iOS and skip OpenGL and CGL as appropriate.

The Regal build for iOS supporting apitrace needs this
change to avoid a compilation error.

12 years agoglretrace: GLX and WGL support for ES2/EGL traces.
Nigel Stewart [Fri, 12 Jul 2013 14:30:41 +0000 (09:30 -0500)]
glretrace: GLX and WGL support for ES2/EGL traces.

I was able to glretrace Gears for Android on x86 Linux with
NVIDIA (non-DRI supporting) driver by enabling
GLX_CONTEXT_ES2_PROFILE_BIT_EXT for the
glXCreateContextAttribsARB path.

Unfortunately eglretrace via Mesa es2/egl doesn't seem
to be compatible the NVIDIA desktop driver.

12 years agowgltrace: Simplify pixel format attrib description.
José Fonseca [Sat, 20 Jul 2013 13:54:02 +0000 (14:54 +0100)]
wgltrace: Simplify pixel format attrib description.

No point is keeping two separate tables.

12 years agoMerge branch 'attrib_list'
José Fonseca [Sat, 20 Jul 2013 13:53:14 +0000 (14:53 +0100)]
Merge branch 'attrib_list'

Conflicts:
specs/glxapi.py

12 years agowgltrace: Prevent duplicate variable declaration.
José Fonseca [Sat, 20 Jul 2013 13:05:10 +0000 (14:05 +0100)]
wgltrace: Prevent duplicate variable declaration.

12 years agoqapitrace: Add option to replay in singlethreaded mode
Peter Lohrmann [Wed, 10 Jul 2013 15:08:14 +0000 (11:08 -0400)]
qapitrace: Add option to replay in singlethreaded mode

Some traces fail to replay (hang) if glretrace does not have
--singelthread on the command line, this change makes a UI option
available.

12 years agoglstate: Try to match the number of channels in internal format.
José Fonseca [Fri, 19 Jul 2013 23:20:06 +0000 (00:20 +0100)]
glstate: Try to match the number of channels in internal format.

12 years agoglstate: Better support for integer textures dumps.
José Fonseca [Fri, 19 Jul 2013 22:30:48 +0000 (23:30 +0100)]
glstate: Better support for integer textures dumps.

12 years agoRemove the last helper for the old incomplete attrib_list support.
Andreas Hartmetz [Fri, 12 Jul 2013 09:51:45 +0000 (11:51 +0200)]
Remove the last helper for the old incomplete attrib_list support.

12 years agoWGL: Support float-based attrib_list parameters.
Andreas Hartmetz [Fri, 12 Jul 2013 09:50:39 +0000 (11:50 +0200)]
WGL: Support float-based attrib_list parameters.

Followup to making it possible in the code generator.

12 years agoAllow float-based attrib_lists as found in WGL.
Andreas Hartmetz [Fri, 12 Jul 2013 09:37:35 +0000 (11:37 +0200)]
Allow float-based attrib_lists as found in WGL.

It also turns out that no "type" member is needed in AttribArray,
so remove it.

12 years agoRemove the now unused _AttribList_size.
Andreas Hartmetz [Fri, 12 Jul 2013 09:07:41 +0000 (11:07 +0200)]
Remove the now unused _AttribList_size.

_AttribPairList_size is still used for WGL's float-based attribs.

12 years agoGLX: More consistent naming of an AttribArray.
Andreas Hartmetz [Fri, 12 Jul 2013 09:49:39 +0000 (11:49 +0200)]
GLX: More consistent naming of an AttribArray.

12 years agoUpdate GLX attrib_list support from GLX 1.3 to 1.4.
Andreas Hartmetz [Fri, 12 Jul 2013 08:46:51 +0000 (10:46 +0200)]
Update GLX attrib_list support from GLX 1.3 to 1.4.

12 years agoWarn on unknown attrib_list keys.
Andreas Hartmetz [Fri, 12 Jul 2013 08:12:11 +0000 (10:12 +0200)]
Warn on unknown attrib_list keys.

12 years agoAggregate all info on debugging into a single place.
José Fonseca [Fri, 12 Jul 2013 06:48:22 +0000 (07:48 +0100)]
Aggregate all info on debugging into a single place.

12 years agoReplace dynamic_cast with virtual functions.
Nigel Stewart [Wed, 10 Jul 2013 14:01:01 +0000 (09:01 -0500)]
Replace dynamic_cast with virtual functions.

apitrace can be built with without RTTI (runtime type information)
providing that dynamic_cast isn't used.

12 years agoMore WGL support. It's ugly and the resulting code probably doesn't compile.
Andreas Hartmetz [Tue, 9 Jul 2013 22:12:39 +0000 (00:12 +0200)]
More WGL support. It's ugly and the resulting code probably doesn't compile.

12 years agoattrib_list support for WGL function wglCreateContextAttribsARB.
Andreas Hartmetz [Tue, 9 Jul 2013 20:56:31 +0000 (22:56 +0200)]
attrib_list support for WGL function wglCreateContextAttribsARB.

12 years agoattrib_list support for glXChooseVisual, the last GLX function.
Andreas Hartmetz [Tue, 9 Jul 2013 20:54:49 +0000 (22:54 +0200)]
attrib_list support for glXChooseVisual, the last GLX function.

It is one of the two functions known to apitrace that can have
attrib_list keys not followed by a value.

12 years agoUse the right attrib_list terminator and support the remaining functions.
Andreas Hartmetz [Tue, 9 Jul 2013 20:52:46 +0000 (22:52 +0200)]
Use the right attrib_list terminator and support the remaining functions.

Remaining functions were

eglLockSurfaceKHR
eglCreateSyncKHR
eglCreateFenceSyncNV

12 years agoImprovements in AttribArray / attrib/list code generation.
Andreas Hartmetz [Tue, 9 Jul 2013 20:43:15 +0000 (22:43 +0200)]
Improvements in AttribArray / attrib/list code generation.

- Treat unknown keys the same way while counting elements and while
  processing them (they are assumed to be followed by an int value).
- Support custom terminators.
- Serialize the terminator.
- Reduce the line count of generated code a bit.
- Add forgotten begin/endElement() around writing the keys.
- Improve comment wording.

12 years agoProper AttribArray / attrib_list support for applicable CGL functions.
Andreas Hartmetz [Tue, 9 Jul 2013 20:40:44 +0000 (22:40 +0200)]
Proper AttribArray / attrib_list support for applicable CGL functions.

It's just CGLChoosePixelFormat here.

12 years agoAllow a custom terminator and support valueless keys better.
Andreas Hartmetz [Tue, 9 Jul 2013 20:38:29 +0000 (22:38 +0200)]
Allow a custom terminator and support valueless keys better.

12 years agocli/sed: Very basic stream editing of traces.
José Fonseca [Tue, 9 Jul 2013 15:35:14 +0000 (16:35 +0100)]
cli/sed: Very basic stream editing of traces.

Extremely limited, but have to start from somewhere.

12 years agocli/trim: Fix error message.
José Fonseca [Tue, 9 Jul 2013 15:28:47 +0000 (16:28 +0100)]
cli/trim: Fix error message.

12 years agod3dstate: Dump compressed D3D10/11 textures.
José Fonseca [Tue, 9 Jul 2013 12:27:00 +0000 (13:27 +0100)]
d3dstate: Dump compressed D3D10/11 textures.

12 years agodirectxtex: Fix assertion failures on MinGW.
José Fonseca [Tue, 9 Jul 2013 12:26:04 +0000 (13:26 +0100)]
directxtex: Fix assertion failures on MinGW.

12 years agod3dstate: Remove spurious statements.
José Fonseca [Tue, 9 Jul 2013 12:25:16 +0000 (13:25 +0100)]
d3dstate: Remove spurious statements.

12 years agowgltrace: Update wglapi.py from specs.
José Fonseca [Mon, 8 Jul 2013 18:40:50 +0000 (19:40 +0100)]
wgltrace: Update wglapi.py from specs.

Via the scripts in the scripts subdir.

Might not be perfect but better than nothing.

12 years agoglxtrace: Trace GLX_NV_present_video/GLX_NV_video_output/GLX_NV_video_capture calls...
José Fonseca [Mon, 8 Jul 2013 17:15:53 +0000 (18:15 +0100)]
glxtrace: Trace GLX_NV_present_video/GLX_NV_video_output/GLX_NV_video_capture calls minimally.

12 years agoSupport for Mac OS X 10.5 Leopard
Nigel Stewart [Fri, 5 Jul 2013 16:49:11 +0000 (11:49 -0500)]
Support for Mac OS X 10.5 Leopard

CGLShareGroupObj and IOSurfaceRef were added in 10.6 Snow Leopard SDK
Add workarounds to glimports.hpp to support building for pre-10.6.

12 years agogui: Allow to edit strings.
José Fonseca [Mon, 8 Jul 2013 14:40:36 +0000 (15:40 +0100)]
gui: Allow to edit strings.

Based upon the surrounding code.  There might be a better way to achieve
it, but this seems better than no support.

Issue #159.

12 years agoUse consistent cpp logic for including backtrace.h
José Fonseca [Mon, 8 Jul 2013 12:46:45 +0000 (13:46 +0100)]
Use consistent cpp logic for including backtrace.h

__linux__ -> __ELF__

12 years agoSkip apitrace from FirefoxOS if NDK is not present
Vasil Dimov [Mon, 1 Jul 2013 07:16:02 +0000 (10:16 +0300)]
Skip apitrace from FirefoxOS if NDK is not present

Skip apitrace build when compiling FirefoxOS if NDK is not present in
prebuilt/ndk/android-ndk-r7.

12 years agoResolve C4267 MS compiler warnings
Nigel Stewart [Wed, 3 Jul 2013 19:10:51 +0000 (14:10 -0500)]
Resolve C4267 MS compiler warnings

warning C4267: 'argument' : conversion from 'size_t' to 'unsigned int', possible loss of data

12 years agoDelete the file object if the trace file could not be loaded due to being an unsuppor...
Peter Lohrmann [Mon, 8 Jul 2013 12:20:31 +0000 (13:20 +0100)]
Delete the file object if the trace file could not be loaded due to being an unsupported (newer) version.

Fix small memory leak / assert if a trace file can't be loaded due to
being recorded with a newer version number than qapitrace. In this
scenario, there is no error message that gets shown in the UI, but the
title bar is updated with the trace file name, so the situation is very
confusing.

12 years agoProper AttribArray / attrib_list support for applicable GLX functions.
Andreas Hartmetz [Mon, 8 Jul 2013 10:36:11 +0000 (12:36 +0200)]
Proper AttribArray / attrib_list support for applicable GLX functions.

The functions are:

glXChooseFBConfig
glXCreateWindow
glXCreatePixmap
glXCreatePbuffer
glXChooseFBConfigSGIX
glXCreateGLXPbufferSGIX
glXBindTexImageEXT
glXBindVideoDeviceNV

12 years agoProper AttribArray / attrib_list support for applicable EGL functions.
Andreas Hartmetz [Mon, 8 Jul 2013 10:31:45 +0000 (12:31 +0200)]
Proper AttribArray / attrib_list support for applicable EGL functions.

The functions are:

eglChooseConfig
eglCreateWindowSurface
eglCreatePbufferSurface
eglCreatePixmapSurface
eglCreatePbufferFromClientBuffer
eglCreateContext
eglCreateImageKHR
eglCreateDRMImageMESA

12 years agoIntroduce AttribArray, a code generator for pseudo-type attrib_list.
Andreas Hartmetz [Sun, 7 Jul 2013 20:51:12 +0000 (22:51 +0200)]
Introduce AttribArray, a code generator for pseudo-type attrib_list.

Also use it for glXCreateConfigAttribsARB, which gives the expected
correct dumps in qapitrace and glretrace dump.
Nothing needs to change in dump code because it just reads whatever
types were written during tracing. Writing different types into
different array elements is allowed by the format, and it turns out
that even older versions of apitrace will correctly display dumps
created with this patch.

12 years agod3dretrace: Dump D3D11 textures too.
José Fonseca [Wed, 3 Jul 2013 15:02:03 +0000 (16:02 +0100)]
d3dretrace: Dump D3D11 textures too.

12 years agod3dretrace: Dump d3d10 PS resource shader views.
José Fonseca [Wed, 3 Jul 2013 14:48:30 +0000 (15:48 +0100)]
d3dretrace: Dump d3d10 PS resource shader views.

12 years agocommon: Add platform #ifdefs for non-cmake build convenience.
Nigel Stewart [Mon, 24 Jun 2013 20:40:44 +0000 (15:40 -0500)]
common: Add platform #ifdefs for non-cmake build convenience.

The cmake CMakeLists.txt file has logic for including or excluding certain
compilation units based on the platform: Windows, Linux or Mac OS X.
Other build systems are not as clever, it is convenient to also wrap
platform-specifics with #ifdef _WIN32 ... #endif to keep things simple on
the build side.

12 years agoResolve some MS compiler warnings (in picky mode)
Nigel Stewart [Tue, 2 Jul 2013 22:34:00 +0000 (23:34 +0100)]
Resolve some MS compiler warnings (in picky mode)

warning C4267: 'argument' : conversion from 'size_t' to 'DWORD', possible loss of data
warning C4244: 'return' : conversion from 'double' to 'int', possible loss of data

12 years agoRetry creating D3D10/11 devices without debug flags.
José Fonseca [Fri, 28 Jun 2013 07:43:50 +0000 (08:43 +0100)]
Retry creating D3D10/11 devices without debug flags.

12 years agoOnly unbind dumpers when objects are truly released.
José Fonseca [Thu, 27 Jun 2013 15:15:01 +0000 (16:15 +0100)]
Only unbind dumpers when objects are truly released.

12 years agod3d9trace: Improve D3D9 shader size computation.
José Fonseca [Wed, 26 Jun 2013 20:13:13 +0000 (21:13 +0100)]
d3d9trace: Improve D3D9 shader size computation.

Still not bullet proof, but better than before.

12 years agoglretrace: swizzle locations into uniform arrays.
Cass Everitt [Thu, 20 Jun 2013 00:30:32 +0000 (19:30 -0500)]
glretrace: swizzle locations into uniform arrays.

Where slot number is inferred.

Fixes issue #139.

v2: Prevent dereference of end() iterator -- Jose

12 years agoSeveral documentation fixes.
José Fonseca [Tue, 18 Jun 2013 07:30:28 +0000 (08:30 +0100)]
Several documentation fixes.

12 years agoDocument the need to keep tracing robust.
José Fonseca [Tue, 18 Jun 2013 15:29:24 +0000 (16:29 +0100)]
Document the need to keep tracing robust.

For future reference.

12 years agoos: Ensure len is properly computed on all getProcessName code paths.
José Fonseca [Mon, 17 Jun 2013 20:05:14 +0000 (21:05 +0100)]
os: Ensure len is properly computed on all getProcessName code paths.

And that truncate is always called.

Thanks to Alexander Monakov for spotting this.

12 years agoos: Improve String with more comments and checks.
José Fonseca [Mon, 17 Jun 2013 19:42:23 +0000 (20:42 +0100)]
os: Improve String with more comments and checks.

Thanks to Alexander Monakov for drawing attention to inconsistencies in
os::String::truncate(void).

12 years agoegltrace/android: Fix tracing Zygote processes
Alexander Monakov [Mon, 17 Jun 2013 16:36:06 +0000 (20:36 +0400)]
egltrace/android: Fix tracing Zygote processes

The root cause of the problem was a bug in the implementation of
getZygoteProcessName.  When the wrap.$procname approach is used, reading
/proc/cmdline produces "$procname\0/system/bin\0--application\0"... (with
embedded zero characters).

Fixed by simply not supplying length argument to the truncate call, which will
truncate to strlen().  The same bug is also present in getProcessName.

12 years agoUse rand() on windows.
José Fonseca [Sun, 16 Jun 2013 08:42:51 +0000 (09:42 +0100)]
Use rand() on windows.

12 years agoUse skiplist-based FastCallSet within trace::CallSet
Carl Worth [Mon, 11 Mar 2013 20:22:05 +0000 (13:22 -0700)]
Use skiplist-based FastCallSet within trace::CallSet

The FastCallSet supports only ranges step of 1 and freq of
FREQUENCY_ALL, so store any such ranges there, and store all other
ranges in the existing, linear list of CallRange.

For manually entered call sets on the command line, the performance
hit of the linear lookup was not generally a problem. But when taking
the (potentially huge) output of "apitrace trim --print-callset" the
performance hit made things quite painful. This makes things usable
again.

12 years agoRename trim::CallSet to trace::FastCallSet
Carl Worth [Mon, 11 Mar 2013 20:05:52 +0000 (13:05 -0700)]
Rename trim::CallSet to trace::FastCallSet

This is in preparation for being able to use this code to optimize the common
cases in trace::CallSet, (callsets without step or freq).

12 years agoExtend trim::CallSet with a new range-based add method.
Carl Worth [Mon, 11 Mar 2013 19:14:06 +0000 (12:14 -0700)]
Extend trim::CallSet with a new range-based add method.

Previously, individual calls had to be added one-at-a-time. This was
adequate for trimming functionality where one call is examined at a
time.

But I'm now wanting to use this same CallSet code to dramatically
optimize the performance of callset specifications on the apitrace
command-line, (in particular large callsets resulting from "apitrace
trim --print-callset"). In this case, we really want to add entire
call ranges rather than just one call at a time.

12 years agotrim: Use custom skiplist for required list (instead of std::set<unsigned>)
Carl Worth [Wed, 22 Aug 2012 18:59:12 +0000 (11:59 -0700)]
trim: Use custom skiplist for required list (instead of std::set<unsigned>)

The std::set<unsigned>::insert method has been dominating profile
output for trimming large traces. Meanwhile, the access patterns of
TraceAnalyzer on the required list is extremely structured; it often
adds the next sequential integer. So we can optimize this data
structure dramatically with two additions:

  1. Store ranges rather than single elements, so that the addition of
     a new number can expand an existing range rather than inserting a
     new element.

  2. Remember the most recent element looked-up so that we can check
     it first and not do any new lookup for in-order accesses.

With these two changes we get O(1) behavior for the access pattern of
adding sequential integers. For other cases we can still get
logarithmic behavior, but we can keep N dramatically smaller.

Unfortunately, we can't implement either change (that I can see) with
STL. I don't see any way to support lookup with range-based elements
in any STL data structure.

So here, I implement a skip-list based callset data structure. It
provides optimization (1) above and affords an easy implementation of
(2) as well, (though that is postponed to a later commit).

The skip-list implementation is ported from a C version which Keith
Packard and I implemented for cairo, and with the identical license as
the license of apitrace. The reference I used is the commit named
c2509f8a721ec489e1b44fa8a68be165363787a7 in the cairo repository.

In addition to changing from C to C++, I implemented range-based
elements.

12 years agoTweak the dev docs.
José Fonseca [Sun, 16 Jun 2013 08:32:59 +0000 (09:32 +0100)]
Tweak the dev docs.

12 years agoFix trim doc.
José Fonseca [Sun, 16 Jun 2013 08:20:31 +0000 (09:20 +0100)]
Fix trim doc.

12 years agoFix pre-processor logic.
Vinjn Zhang [Sat, 15 Jun 2013 10:54:16 +0000 (11:54 +0100)]
Fix pre-processor logic.

12 years agoPrevent infinite recursion with Steam's overlay.
José Fonseca [Sat, 15 Jun 2013 10:31:53 +0000 (11:31 +0100)]
Prevent infinite recursion with Steam's overlay.

12 years agoUpdate homepage link.
José Fonseca [Fri, 14 Jun 2013 22:47:06 +0000 (23:47 +0100)]
Update homepage link.

See https://github.com/blog/1452-new-github-pages-domain-github-io

12 years agoAdd note about Qt and Windows 64 bits builds.
Peter Lohrmann [Fri, 14 Jun 2013 16:11:10 +0000 (17:11 +0100)]
Add note about Qt and Windows 64 bits builds.

12 years agoCleanup known issues.
José Fonseca [Fri, 14 Jun 2013 10:14:06 +0000 (11:14 +0100)]
Cleanup known issues.

12 years agod3dretrace: Handle deferred d3d11 contexts better.
José Fonseca [Thu, 13 Jun 2013 14:51:48 +0000 (15:51 +0100)]
d3dretrace: Handle deferred d3d11 contexts better.

12 years agocli: Don't replace, but instead prepend the environment variable.
José Fonseca [Wed, 12 Jun 2013 22:28:42 +0000 (23:28 +0100)]
cli: Don't replace, but instead prepend the environment variable.

12 years agogltrace: Emit fake glViewport/glScissor calls the first time a context is bound.
José Fonseca [Wed, 12 Jun 2013 22:13:09 +0000 (23:13 +0100)]
gltrace: Emit fake glViewport/glScissor calls the first time a context is bound.

This addresses issue #59.

12 years agogltrace: Also use dlopen.hpp for glxtrace.
José Fonseca [Wed, 12 Jun 2013 22:03:57 +0000 (23:03 +0100)]
gltrace: Also use dlopen.hpp for glxtrace.

12 years agoegltrace/android: Fix tracing Zygote processes (v2)
Chad Versace [Thu, 6 Jun 2013 22:26:13 +0000 (15:26 -0700)]
egltrace/android: Fix tracing Zygote processes (v2)

Fixes egltrace.so on Android 4.2 x86.

Do not call trimDirectory() on the proc_name of Zygote processes, because
a Zyogote process name never contains a path separator. The proc_name of
a Zygote process is the application's package name (such as
com.exampe.myapp) because ActivityManager rewrites argv[0].

There exists an undiagnosed problem with trimDirectory, but I have been
unsuccessful diagnosing it. On the other hand, the call to trimDirectory
isn't needed and its removal fixes the bug's symptoms.

Signed-off-by: Chad Versace <chad.versace@linux.intel.com>
12 years agoDocument what to expect in terms of trace size and CPU overhead.
José Fonseca [Tue, 11 Jun 2013 15:11:40 +0000 (16:11 +0100)]
Document what to expect in terms of trace size and CPU overhead.

See also issue #146.