summaryrefslogtreecommitdiff
path: root/boilerplate
AgeCommit message (Collapse)AuthorFilesLines
2013-04-04boilerplate/gl: Disable thread awarenessMartin Robinson2-0/+5
This dramatically speeds up testing on NVidia and actually makes it possible to run traces within a reasonable amount of time. cairo-perf-trace results for: NVIDIA Corporation GeForce GTS 250/PCIe/SSE2 3.3.0 NVIDIA 310.14 Before: test min(s) median(s) stddev. count gvim 30.924 31.251 0.72% 5/6 firefox-fishbowl 168.751 201.017 12.46% 8/8 (exited early) After: test min(s) median(s) stddev. count gvim 1.294 1.325 1.79% 6/6 firefox-fishbowl 18.540 19.104 1.54% 6/6
2013-04-04boilerplate: Add a mode for running threaded perf testsMartin Robinson1-1/+6
This is useful because the GL backend runs much faster on some drivers when thread awareness is disabled.
2013-03-22boilerplate: rename xcb-render-0.0 to xcb-render-0_0Uli Schlachter1-2/+2
The test suite uses dots to separate the backend name from the content type. Thus, the backend name must not contain any dots. The xlib backend already calls its RENDER 0.0 target xlib-render-0_0 for this reason. This commit makes the xcb backend match this. Reported-by: Darxus <darxus@chaosreigns.com> Signed-off-by: Uli Schlachter <psychon@znc.in>
2013-03-22test: Fix handling of dots in CAIRO_TEST_TARGETUli Schlachter1-0/+2
Before this, the following happened: $ CAIRO_TEST_TARGET=image,xcb-render-0.0 make test Cannot find target 'image'. Known targets: image, [...] The reason for this is that _cairo_boilerplate_target_matches_name() doesn't get a null-terminated string, but instead has a pointer to the end of the string. However, strpbrk() expects a null-terminated argument and thus could return a result which points past the end of the input. This commit fixes exactly this. Reported-by: Darxus <darxus@chaosreigns.com> Signed-off-by: Uli Schlachter <psychon@znc.in>
2013-01-04boilerplate/glx: Add a target with multisampling and stencil supportMartin Robinson1-74/+96
Add a gl-window target that supports multisampling. This is useful for testing the MSAA backend on the default framebuffer.
2012-12-17boilerplate-xcb: Ignore MappingNotify eventsUli Schlachter1-2/+8
The boilerplate code makes sure that our tests didn't cause any X11 errors or X11 events, because those might confuse API users. However, when the keyboard layout changes, every connection gets a MappingNotify event. This means that the test and performance test suites failed when the keyboard layout was changed while they are running. Fix this by ignoring MappingNotifies. Reported by Arthur Huillet on IRC. Signed-off-by: Uli Schlachter <psychon@znc.in>
2012-06-29boilerplate/gl: Round fractional window sizes upChris Wilson1-9/+14
A few test cases purposely create fractional surface sizes which can not be natively supported by the raster backends such as GL. For these backends we need to consistent in creating a surface that is large enough to contain the test, so we need to use ceil() rather than implicit truncation to integers. A consequence of the misalignment between the Window size and the surface size (where one was using ceil and the other not) is that the first row of the cairo surface would not be visible on the output. Based on a patch by Chuanbo Wen to fix 5 test cases, such as group-unaligned. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-04-14Revert accidental push of ps debugging API.Chris Wilson2-13/+46
This reverts commits 6ad8c96fd81e06cea6ada4a83e7c5614f150f914, a3f97d1d2e77a0fee4ca03d5dc9968952a440561, 25abe582982caeb07d1e0af4acca53bb110a33bf I should know better by now than to push without checking for outstanding changes.
2012-04-12pdf (debug API): Export the ability to force fallbacksChris Wilson1-13/+6
We need to occasionally force fallbacks whilst testing the PDF output, so export a debug interface to do so in order to avoid poking around inside cairo internals. References: https://bugs.freedesktop.org/show_bug.cgi?id=48577 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-04-12ps (debug API): Export the ability to force fallbacksChris Wilson1-14/+6
We need to occasionally force fallbacks whilst testing the PostScript output, so export a debug interface to do so in order to avoid poking around inside cairo internals. References: https://bugs.freedesktop.org/show_bug.cgi?id=48577 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-04-12ps (API): Export the ability to set the creation date of the surfaceChris Wilson1-19/+1
A PostScript surface embeds a CreationDate comment into its document description pre-amble. Normally this is set to the time the surface is written out, except we set this to a constant value in the boilerplate for the purposes of mimicking a reference file. It may also be useful for external applications, so make it a public export. References: https://bugs.freedesktop.org/show_bug.cgi?id=48577 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-04-10Add _cairo_win32_print_gdi_error to boilerplate codeMaarten Bosmans1-2/+28
This function is not exported in libcairo, so can't be used from the library.
2012-03-19boilerplate/gl: set width and height to be at least 1Henry (Yu) Song1-0/+5
2012-02-25win32: fix compilation on cygwinAdrian Johnson1-1/+3
2012-02-23boilerplate: Use any2ppm from ANY2PPM env variableAndrea Canciani1-2/+9
If the environment variable ANY2PPM is set, use it as the path to the any2ppm program. Otherwise, default to "./any2ppm" as before. This makes it possible to set the ANY2PPM variable in the Makefile.win32 build system, which makes it possible to use the "test" target on the script backend.
2012-02-22boilerplate/xlib: Exercise the mask based compositor for xrender version 0.0Chris Wilson1-1/+72
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-02-22xlib: Replace obsolete disable-xrender with shiny new device debug interfaceChris Wilson1-46/+8
As prototyped with xcb. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2012-02-22boilerplate/xlib: The xlib-fallback should be visually identical to imageChris Wilson1-1/+1
2012-02-12qt: Fix compilation, also minor fix for building against Qt5Oleg Romashin1-2/+2
Update to latest surface backend structure, removed obsolete functions and fixed functions API in order to be compatible with backend definition. Fixed compilation with Qt5
2011-11-12boilerplate: Fix svg extensionAndrea Canciani1-4/+4
The svg backend produces .svg files. Using the appropriate extension allows the test suite to check the vector output in addition to the PNG images.
2011-11-12boilerplate: Remove unused thread id parameterAndrea Canciani21-88/+8
The thread id is not used anymore (it is always == 0), so it can be removed.
2011-11-11boilerplate: Provide close callback after opening any2ppm outputAndrea Canciani2-4/+11
cairo_boilerplate_open_any2ppm() returns a FILE* obtined from popen() or fdopen(). It should hence be closed using pclose() or fclose() respectively. Fixes the crash on every script test on MacOS X.
2011-11-09Silence some 'unused var' warningsAndrea Canciani1-2/+0
2011-10-11backends: Adds a new Cogl based backendRobert Bragg3-0/+221
This adds a new GPU accelerated backend for Cairo based on the Cogl 3D graphics API. This backend aims to support Cairo in a way that translates as naturally as possible to using a GPU, it does not strive to compete with the anti-aliasing quality of the image backend if it can't be done efficiently using the GPU - raw performance isn't the only metric of concern, so is power usage. As an overview of how the backend works: - fills are handled by tessellating paths into triangles - the backend has an extra fill_rectangle drawing operation so we have a fast-path for drawing rectangles which are so common. - strokes are also tessellated into triangles. - stroke and fill tessellations are cached to avoid the cpu overhead of tessellation and cost of upload given that its common for apps to re-draw the same path multiple times. The tessellations can survive translations and rotations increasing the probability that they can be re-used. - sources and masks are handled using multi-texturing. - clipping is handled with a scissor and the stencil buffer which we're careful to only update when they really change. - linear gradients are rendered to a 1d texture using a triangle strip + interpolating color attributes. All cairo extend modes are handled by corresponding texture sampler wrap modes without needing programmable fragment processing. - antialiasing should be handled using Cogl's multisampling API XXX: This is a work in progress!! TODO: - handle at least basic radial gradients (No need to handle full pdf semantics, since css, svg and canvas only allow radial gradients defined as one circle + a point that must lie within the first circle.) - currently we fall back to pixman for radial gradients. - support glyph rendering with a decent glyph cache design. The current plan is a per scaled-font growable cache texture + a scratch cache for one-shot/short-lived glyphs. - decide how to handle npot textures when lacking hardware support. Current plan is to add a transparent border to npot textures and use CLAMP_TO_EDGE for the default EXTEND_NONE semantics. For anything else we can allocate a shadow npot texture and scale the original to fit that so we can map extend modes to texture sampler modes.
2011-10-08xlib: Fix compilation with --disable-xlib-xrenderUli Schlachter1-0/+4
The boilerplate code tries to set PolyModePrecise on the xlib device. However, because xrender is disabled, cairo-xlib-xrender.h wasn't included and didn't include the needed xrender headers for this define. This define is copied from cairo-xlib-xrender-private.h Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-09-26boilerplate: Skip testing of null surfacesChris Wilson1-0/+9
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-09-18On OS/2, WIFSIGNALED and WTERMSIG are prototyped in sys/wait.hDave Yeo3-0/+12
boilerplate/cairo-boilerplate-pdf.c | 4 ++++ boilerplate/cairo-boilerplate-ps.c | 4 ++++ boilerplate/cairo-boilerplate-svg.c | 4 ++++ build/configure.ac.system | 2 +- 4 files changed, 13 insertions(+), 1 deletions(-) Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-09-16boilerplate-xcb: Print sequence numbersUli Schlachter1-4/+6
The boilerplate code will now also print the low 16 bits of the sequence number for errors and events. This should make it a lot easier to find errors in e.g. a long xtrace output. Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-09-16cairo-xcb: Require libxcb 1.6Uli Schlachter1-6/+0
Since commit 968eb30bba1dc94, we use xcb_discard_reply(). This function was added in libxcb 1.6. "Fixes": https://bugs.freedesktop.org/show_bug.cgi?id=40925 Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-09-16test: Use the test-traps as the reference images for xlib/xcbChris Wilson3-8/+8
The test-traps provides a reference implementation of the traps-compositor as used by xlib, so we can use it to generate the reference images as well. (Of course checking that test-traps is itself correct and only differs in the renderer! ;-) Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-09-15test: Complete set of baseline reference imagesChris Wilson1-2/+2
test-base basically implements rendering ala cairo-1.0 and so serves as a useful baseline for comparing enhancements and to regression test the core libraries.
2011-09-12Introduce a new compositor architectureChris Wilson3-123/+245
Having spent the last dev cycle looking at how we could specialize the compositors for various backends, we once again look for the commonalities in order to reduce the duplication. In part this is motivated by the idea that spans is a good interface for both the existent GL backend and pixman, and so they deserve a dedicated compositor. xcb/xlib target an identical rendering system and so they should be using the same compositor, and it should be possible to run that same compositor locally against pixman to generate reference tests. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> P.S. This brings massive upheaval (read breakage) I've tried delaying in order to fix as many things as possible but now this one patch does far, far, far too much. Apologies in advance for breaking your favourite backend, but trust me in that the end result will be much better. :)
2011-08-15Introduce cairo_mime_surface_tChris Wilson1-0/+10
The mime surface is a user-callback surface designed for interfacing cairo with an opaque data source. For instance, in a web browser, the incoming page may be laid out and rendered to a recording surface before all the image data has finished being downloaded. In this circumstance we need to pass a place holder to cairo and to supply the image data later upon demand. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-08-14script: enable by defaultChris Wilson1-1/+1
I'm willing to make this a supported backend as I find it to be an invaluable debugging tool... Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-08-14Introduce cairo_surface_observer_t for performance analysisChris Wilson1-0/+10
Another logging passthrough surface that records the style of operations performed trying to categorise what is slow/fast/important. In combination with perf/cairo-analyse-trace it is very useful for understanding what a trace does. The next steps for this tool would be to identify the slow operations that the trace does. Baby steps. This should be generally useful in similar situations outside of perf/ and should be extensible to become an online performance probe. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-08-13boilerplate: improve fidelity of surface extractionChris Wilson1-3/+15
Create an image surface of equivalent content to the original. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-07-21XCB: Store the flags per-connection onlyUli Schlachter1-29/+16
Every xcb surface had its own copy of the flags from the time that it was created. This means that, if you want to make use of cairo_xcb_device_debug_cap_xrender_version() and cairo_xcb_device_debug_cap_xshm_version(), you first had to create a dummy xcb surface, use that to get access to the cairo_device_t so that you can use these functions and only then create your real surface, because the change only affected new surfaces. This commit changes everything to use the connection's flag and removes the per-surface flags. This avoids the dummy surfaces completely. Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-07-20xcb: Take advantage of clip-boxesChris Wilson1-23/+69
A demonstration of step 2, improves performance for selected benchmarks on selected GPUs by up to 30%. firefox-fishbowl on snb {i5-2520m): 42s -> 29s. firefox-talos-gfx on snb: 7.6 -> 5.2s. firefox-fishbowl on pnv (n450): 380 -> 360s. Whist this looks like it is getting close to as good as we can achieve, we are constrained by both our API and Xrender and fishbowl is about 50% slower than peak performance (on snb). And it fixes the older performance regression in firefox-planet-gnome. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-07-14Excise xcb-drmChris Wilson1-12/+0
The experiment was at best a pyrrhic victory. Whilst it did show that you could successfully subvert cairo_xcb_surface_t and provide the rendering locally faster (than the xlib driver at that time), any performance benefits were lost in the synchronisation overheads and server-side buffer allocation. Once cairo-gl is mature, we need to look at how we can overcome these to improve client-side rendering In the meantime, cairo-xcb is no longer my playground for experimentation and is shaping up to become a stable backend... Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-07-14Excise DRM-XrChris Wilson1-12/+0
I've since incorporated (nearly) all the features from cairo-drm into xf86-video-intel, making this experiment defunct. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-07-03Xlib: Fix boilerplate to work with xlib-xcbUli Schlachter1-0/+6
Xlib boilerplate includes cairo-xlib-surface-private.h, so that it can cast the xlib cairo_surface_t to cairo_xlib_surface_t and then mess with some internals of that struct. However, xlib-xcb doesn't use that struct and thus this results in random memory corruption. "Luckily", all the fields that this messes with don't corrupt any fields in cairo_xlib_xcb_surface_t, but instead this writes past the end of the buffer that was returned from malloc. This commit just adds an #if to disable this code section since I have no idea what a proper fix would be. This means that the xlib-fallback backend doesn't actually test any fallbacks with xlib-xcb, however it never did so anyway. If you have any idea how to fix xlib-fallback with xlib-xcb, please speak up. Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-06-24xcb: Use defines instead of magic numbersUli Schlachter1-1/+2
render.h gives us nice descriptive names for the precise/imprecise poly modes. Signed-off-by: Uli Schlachter <psychon@znc.in>
2011-06-20boilerplate: Use correct flag type in DFBWindowDescriptionHaithem Rahmani1-1/+1
The window description flag macros are prefixed with DWDESC_. The issue was not noticed because DWDESC_CAPS and DSDESC_CAPS have the same value. Fixes https://bugs.freedesktop.org/show_bug.cgi?id=37049
2011-06-20build: Clean up environment variables and flags for the win32 buildAndrea Canciani1-3/+1
Avoid ovverriding LINK, as it has a special meaning for the MSVC build tools.
2011-06-20boilerplate: Silence MSVC warningsAndrea Canciani1-0/+1
On Win32 INT_MIN/MAX macros are defined in stdint.h, which makes MSVC complain about the following redefinitions: ...\stdint.h(73) : warning C4005: 'INT16_MIN' : macro redefinition ...\boilerplate\cairo-boilerplate.h(64) : see previous definition of 'INT16_MIN' ...\stdint.h(77) : warning C4005: 'INT16_MAX' : macro redefinition ...\cairo-boilerplate.h(67) : see previous definition of 'INT16_MAX' ...\stdint.h(80) : warning C4005: 'UINT16_MAX' : macro redefinition ...\boilerplate\cairo-boilerplate.h(70) : see previous definition of 'UINT16_MAX'
2011-06-14test: Fix compilation on win32Andrea Canciani5-9/+34
The Microsoft C Compiler does not accept empty-initialized arrays: cairo-boilerplate-win32-printing.c(373) : error C2059: syntax error : '}' cairo-boilerplate-win32-printing.c(374) : warning C4034: sizeof returns 0
2011-06-14boilerplate: Add generation of constructors on win32Andrea Canciani1-0/+3
cairo-boilerplate-constructors.c is one of the sources required to build the boilerplate. This file is generated by a script, invoked by the appropriate make target during the build.
2011-06-02boilerplate: Introduce create_similar hookChris Wilson14-0/+37
A deficiency of cairo-perf-trace is that it currently always uses similar surfaces for new surface which are kindly cleared by Cairo. This does not accurately reflect the captured trace and introduces large bandwidth overheads that distort the profiles. So we introduce a new boilerplate hook so that the targets can create a surface without incurring additional overheads. [Fixes the broken partial commit of bf1b08d066e.] Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2011-06-02perfChris Wilson5-6/+206
2011-06-01boilerplate/xcb: Fix silly cut'n'paste errors in previous commitChris Wilson1-3/+2
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>