perf: Fix build on win32

The performance tools build system for Win32 hasn't been maintained
for some time.  The makefiles are now structured as in other
directories (Makefile.sources used by both Makefile.am and
Makefile.win32) and some additional code hides os-specific parts.
This commit is contained in:
Andrea Canciani 2011-06-21 18:12:29 +02:00
parent 33403cfb37
commit 463a8b67a3
13 changed files with 360 additions and 130 deletions

View file

@ -9,5 +9,8 @@ all: cairo
cairo: inform
@$(MAKE) -C src -f Makefile.win32
perf: inform
@$(MAKE) -C perf -f Makefile.win32 perf
test: inform
@$(MAKE) -C test -f Makefile.win32 test

View file

@ -815,6 +815,7 @@ src/Makefile
test/Makefile
test/pdiff/Makefile
perf/Makefile
perf/micro/Makefile
util/Makefile
util/cairo-fdr/Makefile
util/cairo-gobject/Makefile

View file

@ -1,5 +1,7 @@
include $(top_srcdir)/build/Makefile.am.common
include $(top_srcdir)/perf/Makefile.sources
AM_CPPFLAGS = \
-I$(srcdir) \
-I$(top_srcdir)/boilerplate \
@ -22,105 +24,46 @@ EXTRA_LTLIBRARIES += libcairoperf.la
LDADD = libcairoperf.la \
$(top_builddir)/boilerplate/libcairoboilerplate.la \
$(top_builddir)/src/libcairo.la \
$(CAIROPERF_LIBS)
$(top_builddir)/src/libcairo.la
cairo_perf_micro_SOURCES = \
cairo-perf-micro.c \
cairo-perf.h \
micro/cairo-perf-cover.c \
micro/box-outline.c \
micro/composite-checker.c \
micro/fill.c \
micro/long-lines.c \
micro/mosaic.c \
micro/mosaic.h \
micro/paint.c \
micro/paint-with-alpha.c \
micro/mask.c \
micro/pattern_create_radial.c \
micro/rectangles.c \
micro/rounded-rectangles.c \
micro/stroke.c \
micro/subimage_copy.c \
micro/tessellate.c \
micro/text.c \
micro/glyphs.c \
micro/twin.c \
micro/unaligned-clip.c \
micro/wave.c \
micro/world-map.c \
micro/world-map.h \
micro/zrusin.c \
micro/zrusin-another.h \
micro/long-dashed-lines.c \
micro/dragon.c \
micro/pythagoras-tree.c \
micro/intersections.c \
micro/spiral.c
if CAIRO_HAS_WIN32_SURFACE
cairo_perf_micro_SOURCES += cairo-perf-win32.c
else
if CAIRO_HAS_OS2_SURFACE
cairo_perf_micro_SOURCES += cairo-perf-os2.c
else
cairo_perf_micro_SOURCES += cairo-perf-posix.c
endif
endif
cairo_perf_micro_LDADD = $(LDADD)
cairo_perf_micro_SOURCES = $(cairo_perf_micro_sources)
cairo_perf_micro_LDADD = \
$(top_builddir)/perf/micro/libcairo-perf-micro.la \
$(LDADD)
cairo_perf_micro_DEPENDENCIES = \
$(top_builddir)/boilerplate/libcairoboilerplate.la \
$(top_builddir)/src/libcairo.la \
libcairoperf.la
$(top_builddir)/perf/micro/libcairo-perf-micro.la \
$(LDADD)
libcairoperf_la_SOURCES = \
cairo-perf-report.c \
cairo-stats.c \
cairo-stats.h
$(libcairoperf_sources) \
$(libcairoperf_headers)
libcairoperf_la_LIBADD = $(CAIROPERF_LIBS)
cairo_perf_trace_SOURCES = \
cairo-perf-trace.c \
../src/cairo-error.c \
../src/cairo-hash.c
if CAIRO_HAS_WIN32_SURFACE
cairo_perf_trace_SOURCES += cairo-perf-win32.c
else
if CAIRO_HAS_OS2_SURFACE
cairo_perf_trace_SOURCES += cairo-perf-os2.c
else
cairo_perf_trace_SOURCES += cairo-perf-posix.c
endif
endif
cairo_perf_trace_SOURCES = \
$(cairo_perf_trace_sources) \
$(cairo_perf_trace_external_sources)
cairo_perf_trace_LDADD = \
$(top_builddir)/util/cairo-script/libcairo-script-interpreter.la \
$(LDADD)
cairo_perf_trace_DEPENDENCIES = \
$(top_builddir)/util/cairo-script/libcairo-script-interpreter.la \
$(top_builddir)/boilerplate/libcairoboilerplate.la \
$(top_builddir)/src/libcairo.la \
libcairoperf.la
$(LDADD)
cairo_perf_diff_files_SOURCES = \
cairo-perf-diff-files.c
cairo_perf_print_SOURCES = \
cairo-perf-print.c
cairo_perf_chart_SOURCES = \
cairo-perf-chart.c
cairo_perf_compare_backends_SOURCES = \
cairo-perf-compare-backends.c
cairo_perf_diff_files_SOURCES = $(cairo_perf_diff_files_sources)
cairo_perf_print_SOURCES = $(cairo_perf_print_sources)
cairo_perf_chart_SOURCES = $(cairo_perf_chart_sources)
cairo_perf_compare_backends_SOURCES = $(cairo_perf_compare_backends_sources)
cairo_perf_graph_files_SOURCES = \
cairo-perf-graph.h \
cairo-perf-graph-files.c \
cairo-perf-graph-widget.c
$(cairo_perf_graph_files_sources) \
$(cairo_perf_graph_files_headers)
cairo_perf_graph_files_CFLAGS = @gtk_CFLAGS@
cairo_perf_graph_files_LDADD = @gtk_LIBS@ $(LDADD)
# Install rules to rebuild the libraries and add explicit dependencies
$(top_builddir)/perf/micro/libcairo-perf-micro.la:
cd $(top_builddir)/perf/micro && $(MAKE) $(AM_MAKEFLAGS) libcairo-perf-micro.la
$(top_builddir)/boilerplate/libcairoboilerplate.la: $(top_builddir)/src/libcairo.la
cd $(top_builddir)/boilerplate && $(MAKE) $(AM_MAKEFLAGS) libcairoboilerplate.la

35
perf/Makefile.sources Normal file
View file

@ -0,0 +1,35 @@
libcairoperf_sources = \
cairo-perf-os2.c \
cairo-perf-posix.c \
cairo-perf-report.c \
cairo-perf-win32.c \
cairo-stats.c \
$(NULL)
libcairoperf_headers = \
cairo-perf.h \
cairo-stats.h \
$(NULL)
cairo_perf_trace_sources = cairo-perf-trace.c
cairo_perf_trace_external_sources = \
../src/cairo-error.c \
../src/cairo-hash.c \
$(NULL)
cairo_perf_micro_sources = cairo-perf-micro.c
cairo_perf_diff_files_sources = cairo-perf-diff-files.c
cairo_perf_print_sources = cairo-perf-print.c
cairo_perf_chart_sources = cairo-perf-chart.c
cairo_perf_compare_backends_sources = cairo-perf-compare-backends.c
cairo_perf_graph_files_sources = \
cairo-perf-graph-files.c \
cairo-perf-graph-widget.c \
$(NULL)
cairo_perf_graph_files_headers = cairo-perf-graph.h

View file

@ -1,44 +1,78 @@
top_srcdir = ..
include $(top_srcdir)/build/Makefile.win32.common
include $(top_srcdir)/perf/Makefile.sources
LDFLAGS += ../src/$(CFG)/cairo-static.lib $(PIXMAN_LIBS) ../boilerplate/$(CFG)/boiler.lib $(EXE_LDFLAGS)
CFLAGS += -I$(top_srcdir)/boilerplate -I$(top_srcdir)/util/cairo-script/
PERF_SOURCES = \
box-outline.c \
cairo-perf-win32.c \
cairo-perf-cover.c \
cairo-perf.c \
cairo-stats.c \
fill.c \
long-dashed-lines.c \
long-lines.c \
mosaic.c \
paint.c \
paint-with-alpha.c \
pattern_create_radial.c \
rectangles.c \
stroke.c \
subimage_copy.c \
tessellate.c \
text.c \
unaligned-clip.c \
world-map.c \
zrusin.c \
# extend-pad.c \
PERF_LIBS = \
$(CFG)/libcairoperf.lib \
$(top_builddir)/boilerplate/$(CFG)/boiler.lib \
$(top_builddir)/src/$(CFG)/cairo-static.lib \
$(NULL)
PERF_EXES = \
$(CFG)/cairo-perf-trace.exe \
$(CFG)/cairo-perf-micro.exe \
$(CFG)/cairo-perf-diff-files.exe \
$(CFG)/cairo-perf-print.exe \
$(CFG)/cairo-perf-chart.exe \
$(CFG)/cairo-perf-compare-backends.exe \
$(NULL)
all: inform $(PERF_EXES)
perf: inform $(CFG)/cairo-perf-micro.exe
./$(CFG)/cairo-perf-micro.exe
libcairoperf_OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(libcairoperf_sources))
$(CFG)/libcairoperf.lib: $(libcairoperf_OBJECTS)
@$(AR) $(CAIRO_ARFLAGS) -OUT:$@ $(libcairoperf_OBJECTS)
cairo_perf_trace_OBJECTS = \
$(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_trace_sources)) \
$(top_builddir)/util/cairo-script/$(CFG)/libcairo-script-interpreter.lib \
$(NULL)
OBJECTS = $(patsubst %.c, $(CFG)/%.obj, $(PERF_SOURCES))
cairo_perf_micro_OBJECTS = \
$(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_micro_sources)) \
./micro/$(CFG)/libcairo-perf-micro.lib \
$(NULL)
all: inform $(CFG)/cairo-perf.exe
cairo_perf_diff_files_OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_diff_files_sources))
cairo_perf_print_OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_print_sources))
cairo_perf_chart_OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_chart_sources))
cairo_perf_compare_backends_OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(cairo_perf_compare_backends_sources))
$(CFG)/cairo-perf.exe: $(OBJECTS)
@mkdir -p $(CFG)
@$(CC) $(CFLAGS) -Fe"$@" $^ -link $(LDFLAGS)
cairo-perf-diff-files:
@mkdir -p $(CFG)
@$(CC) $(CFLAGS) -Fe"$@" cairo-perf-diff-files.c cairo-perf-report.c cairo-stats.c -link $(LDFLAGS)
$(CFG)/cairo-perf-trace.exe: $(cairo_perf_trace_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_trace_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
cairo-perf-graph-files:
@mkdir -p $(CFG)
@$(CC) $(CFLAGS) -Fe"$@" cairo-perf-graph-files.c cairo-perf-report.c cairo-stats.c -link $(LDFLAGS)
$(CFG)/cairo-perf-micro.exe: $(cairo_perf_micro_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_micro_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
$(CFG)/cairo-perf-diff-files.exe: $(cairo_perf_diff_files_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_diff_files_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
$(CFG)/cairo-perf-print.exe: $(cairo_perf_print_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_print_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
$(CFG)/cairo-perf-chart.exe: $(cairo_perf_chart_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_chart_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
$(CFG)/cairo-perf-compare-backends.exe: $(cairo_perf_compare_backends_OBJECTS) $(PERF_LIBS)
@$(LD) $(CAIRO_LDFLAGS) -OUT:$@ $(cairo_perf_compare_backends_OBJECTS) $(PERF_LIBS) $(CAIRO_LIBS)
./micro/$(CFG)/libcairo-perf-micro.lib:
$(MAKE) -C micro -f Makefile.win32
$(top_builddir)/src/$(CFG)/cairo-static.lib:
$(MAKE) -C $(top_srcdir)/src -f Makefile.win32
$(top_builddir)/boilerplate/$(CFG)/boiler.lib:
$(MAKE) -C $(top_srcdir)/boilerplate -f Makefile.win32
$(top_builddir)/util/cairo-script/$(CFG)/libcairo-script-interpreter.lib:
$(MAKE) -C $(top_srcdir)/util/cairo-script -f Makefile.win32

View file

@ -27,11 +27,13 @@
* Carl Worth <cworth@cworth.org> (win32/linux code)
*/
#include "cairo-perf.h"
#if CAIRO_HAS_OS2_SURFACE
#define INCL_BASE
#include <os2.h>
#include "cairo-perf.h"
/* timers */
typedef struct _cairo_perf_timer
{
@ -93,3 +95,5 @@ cairo_perf_yield (void) {
/* try to deactivate this thread until the scheduler calls it again */
DosSleep (0);
}
#endif /* CAIRO_HAS_OS2_SURFACE */

View file

@ -55,6 +55,10 @@
#define _XOPEN_SOURCE 600 /* for round() */
#include "cairo-perf.h"
#if !CAIRO_HAS_OS2_SURFACE && !CAIRO_HAS_WIN32_SURFACE
#include "config.h"
#include <signal.h>
@ -65,8 +69,6 @@
#include <sched.h>
#endif
#include "cairo-perf.h"
/* timers */
#if defined(HAVE_CLOCK_GETTIME)
@ -251,3 +253,5 @@ cairo_perf_yield (void)
sched_yield ();
#endif
}
#endif /* !CAIRO_HAS_OS2_SURFACE && !CAIRO_HAS_WIN32_SURFACE */

View file

@ -51,8 +51,44 @@
#include <sys/types.h>
#include <sys/stat.h>
#ifdef _MSC_VER
#include "dirent-win32.h"
typedef SSIZE_T ssize_t;
static char *
basename_no_ext (char *path)
{
static char name[_MAX_FNAME + 1];
_splitpath (path, NULL, NULL, name, NULL);
name[_MAX_FNAME] = '\0';
return name;
}
#else
#include <dirent.h>
static char *
basename_no_ext (char *path)
{
char *dot, *name;
name = basename (path);
dot = strchr (name, '.');
if (dot)
*dot = '\0';
return name;
}
#endif
#if HAVE_UNISTD_H
#include <unistd.h>
#endif
@ -319,18 +355,19 @@ execute (cairo_perf_t *perf,
cairo_perf_ticks_t *times;
cairo_stats_t stats = {0.0, 0.0};
int low_std_dev_count;
char *trace_cpy, *name, *dot;
char *trace_cpy, *name;
const cairo_script_interpreter_hooks_t hooks = {
.closure = args,
.surface_create = _similar_surface_create,
.context_create = _context_create
args,
_similar_surface_create,
NULL, /* surface_destroy */
_context_create,
NULL, /* context_destroy */
NULL, /* show_page */
NULL /* copy_page */
};
trace_cpy = xstrdup (trace);
name = basename (trace_cpy);
dot = strchr (name, '.');
if (dot)
*dot = '\0';
name = basename_no_ext (trace_cpy);
if (perf->list_only) {
printf ("%s\n", name);

View file

@ -25,13 +25,15 @@
* Carl Worth <cworth@cworth.org>
*/
#include "cairo-perf.h"
#if CAIRO_HAS_WIN32_SURFACE
#define USE_WINAPI
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include "cairo-perf.h"
/* timers */
typedef struct _cairo_perf_timer
@ -87,3 +89,5 @@ void
cairo_perf_yield (void) {
SleepEx(0, TRUE);
}
#endif /* CAIRO_HAS_WIN32_SURFACE */

102
perf/dirent-win32.h Normal file
View file

@ -0,0 +1,102 @@
/* -*- Mode: c; c-basic-offset: 4; indent-tabs-mode: t; tab-width: 8; -*- */
/*
* Copyright 2011 Andrea Canciani
*
* Permission to use, copy, modify, distribute, and sell this software
* and its documentation for any purpose is hereby granted without
* fee, provided that the above copyright notice appear in all copies
* and that both that copyright notice and this permission notice
* appear in supporting documentation, and that the name of
* the authors not be used in advertising or publicity pertaining to
* distribution of the software without specific, written prior
* permission. The authors make no representations about the
* suitability of this software for any purpose. It is provided "as
* is" without express or implied warranty.
*
* THE AUTHORS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS, IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL,
* INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
* IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
* Authors: Andrea Canciani <ranma42@gmail.com>
*/
#include "cairo-compiler-private.h"
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#define stat _stat
#define S_ISDIR(s) ((s) & _S_IFDIR)
struct dirent {
ino_t d_ino;
char d_name[FILENAME_MAX + 1];
};
typedef struct _DIR {
HANDLE handle;
cairo_bool_t has_next;
WIN32_FIND_DATA data;
struct dirent de;
} DIR;
static DIR *
opendir(const char *dirname)
{
DIR *dirp;
dirp = malloc (sizeof (*dirp));
if (unlikely (dirp == NULL))
return NULL;
dirp->handle = FindFirstFile(dirname, &dirp->data);
if (unlikely (dirp->handle == INVALID_HANDLE_VALUE)) {
free (dirp);
return NULL;
}
memcpy (dirp->de.d_name, dirp->data.cFileName,
sizeof (dirp->data.cFileName));
dirp->de.d_name[FILENAME_MAX] = '\0';
dirp->has_next = TRUE;
return dirp;
}
static int
closedir(DIR *dirp)
{
int ret;
ret = ! FindClose (dirp->handle);
free (dirp);
/* TODO: set errno */
return ret;
}
static struct dirent *
readdir(DIR *dirp)
{
if (! dirp->has_next)
return NULL;
/* COMPILE_TIME_ASSERT (FILENAME_MAX == sizeof (dirp->data.cFileName)); */
memcpy (dirp->de.d_name, dirp->data.cFileName,
sizeof (dirp->data.cFileName));
dirp->de.d_name[FILENAME_MAX] = '\0';
dirp->has_next = FindNextFile (dirp->handle, &dirp->data);
return &dirp->de;
}

16
perf/micro/Makefile.am Normal file
View file

@ -0,0 +1,16 @@
include $(top_srcdir)/build/Makefile.am.common
include $(top_srcdir)/perf/micro/Makefile.sources
noinst_LTLIBRARIES = libcairo-perf-micro.la
libcairo_perf_micro_la_SOURCES = \
$(libcairo_perf_micro_sources) \
$(libcairo_perf_micro_headers)
AM_CPPFLAGS = \
-I$(srcdir) \
-I$(top_srcdir)/boilerplate \
-I$(top_srcdir)/src \
-I$(top_srcdir)/perf \
-I$(top_builddir)/src \
$(CAIRO_CFLAGS)

View file

@ -0,0 +1,35 @@
libcairo_perf_micro_sources = \
cairo-perf-cover.c \
box-outline.c \
composite-checker.c \
fill.c \
long-lines.c \
mosaic.c \
paint.c \
paint-with-alpha.c \
mask.c \
pattern_create_radial.c \
rectangles.c \
rounded-rectangles.c \
stroke.c \
subimage_copy.c \
tessellate.c \
text.c \
glyphs.c \
twin.c \
unaligned-clip.c \
wave.c \
world-map.c \
zrusin.c \
long-dashed-lines.c \
dragon.c \
pythagoras-tree.c \
intersections.c \
spiral.c \
$(NULL)
libcairo_perf_micro_headers = \
mosaic.h \
world-map.h \
zrusin-another.h \
$(NULL)

12
perf/micro/Makefile.win32 Normal file
View file

@ -0,0 +1,12 @@
top_srcdir = ../..
include $(top_srcdir)/build/Makefile.win32.common
include $(top_srcdir)/perf/micro/Makefile.sources
CFLAGS += -I$(top_srcdir)/perf -I$(top_srcdir)/boilerplate/
OBJECTS = $(patsubst %.c, $(CFG)/%-static.obj, $(libcairo_perf_micro_sources))
all: inform $(CFG)/libcairo-perf-micro.lib
$(CFG)/libcairo-perf-micro.lib: $(OBJECTS)
@$(AR) $(CAIRO_ARFLAGS) -OUT:$@ $(OBJECTS)