[cairo-commit] 2 commits - perf/cairo-perf-os2.c perf/Makefile.am
util/Makefile.am
Behdad Esfahbod
behdad at kemper.freedesktop.org
Sun Apr 22 04:11:34 PDT 2007
perf/Makefile.am | 4 ++
perf/cairo-perf-os2.c | 95 ++++++++++++++++++++++++++++++++++++++++++++++++++
util/Makefile.am | 2 -
3 files changed, 100 insertions(+), 1 deletion(-)
New commits:
diff-tree 406fc63b68203e86c9236d06448e2ffa2c259669 (from 5bc1f3365d0002f2864bc30638df85c392a495f5)
Author: Behdad Esfahbod <behdad at behdad.org>
Date: Sun Apr 22 07:11:47 2007 -0400
[util] Change make target from "tools" to "util"
to match targets like "test", "perf", and "doc", that match
their directory names.
diff --git a/util/Makefile.am b/util/Makefile.am
index b37c2eb..1c0cff9 100644
--- a/util/Makefile.am
+++ b/util/Makefile.am
@@ -1,5 +1,5 @@
-tools: malloc-stats.so
+util: malloc-stats.so
%.so: %.la
$(RM) $@
diff-tree 5bc1f3365d0002f2864bc30638df85c392a495f5 (from 3b46e105bd781d7a4081068a14668334a7c82986)
Author: Peter Weilbacher <pmw at avila.aip.de>
Date: Sun Apr 22 07:11:00 2007 -0400
[perf] Add OS/2 implementation for timer routines
diff --git a/perf/Makefile.am b/perf/Makefile.am
index 86bdd26..1f8e6fc 100644
--- a/perf/Makefile.am
+++ b/perf/Makefile.am
@@ -40,8 +40,12 @@ cairo_perf_SOURCES = \
if CAIRO_HAS_WIN32_SURFACE
cairo_perf_SOURCES += cairo-perf-win32.c
else
+if CAIRO_HAS_OS2_SURFACE
+cairo_perf_SOURCES += cairo-perf-os2.c
+else
cairo_perf_SOURCES += cairo-perf-posix.c
endif
+endif
cairo_perf_diff_files_SOURCES = \
cairo-perf-diff-files.c \
diff --git a/perf/cairo-perf-os2.c b/perf/cairo-perf-os2.c
new file mode 100644
index 0000000..4cb6447
--- /dev/null
+++ b/perf/cairo-perf-os2.c
@@ -0,0 +1,95 @@
+/*
+ * Copyright (c) 2007 Netlabs
+ * Copyright (c) 2006 Mozilla Corporation
+ * Copyright (c) 2006 Red Hat, Inc.
+ *
+ * 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: Peter Weilbacher <mozilla at weilbacher.org>
+ * Vladimir Vukicevic <vladimir at pobox.com> (win32/linux code)
+ * Carl Worth <cworth at cworth.org> (win32/linux code)
+ */
+
+#define INCL_BASE
+#include <os2.h>
+
+#include "cairo-perf.h"
+
+/* timers */
+typedef struct _cairo_perf_timer
+{
+ /* make them double so that they can store the full QWORD precision */
+ double start;
+ double stop;
+} cairo_perf_timer_t;
+
+static cairo_perf_timer_t timer;
+
+static cairo_perf_timer_synchronize_t cairo_perf_timer_synchronize = NULL;
+static void *cairo_perf_timer_synchronize_closure = NULL;
+void
+cairo_perf_timer_set_synchronize (cairo_perf_timer_synchronize_t synchronize,
+ void *closure)
+{
+ cairo_perf_timer_synchronize = synchronize;
+ cairo_perf_timer_synchronize_closure = closure;
+}
+
+void
+cairo_perf_timer_start (void) {
+ QWORD time;
+
+ if (cairo_perf_timer_synchronize)
+ cairo_perf_timer_synchronize (cairo_perf_timer_synchronize_closure);
+ DosTmrQueryTime(&time);
+ timer.start = (time.ulHi*4294967296.0 + time.ulLo);
+}
+
+void
+cairo_perf_timer_stop (void) {
+ QWORD time;
+
+ if (cairo_perf_timer_synchronize)
+ cairo_perf_timer_synchronize (cairo_perf_timer_synchronize_closure);
+ DosTmrQueryTime(&time);
+ timer.stop = (time.ulHi*4294967296.0 + time.ulLo);
+}
+
+cairo_perf_ticks_t
+cairo_perf_timer_elapsed (void) {
+ ULONG freq;
+
+ DosTmrQueryFreq(&freq);
+ /* return time difference in milliseconds */
+ return (timer.stop - timer.start) / freq * 1000;
+}
+
+cairo_perf_ticks_t
+cairo_perf_ticks_per_second (void) {
+ return 1000; /* in ms */
+}
+
+
+/* yield */
+void
+cairo_perf_yield (void) {
+ /* try to deactivate this thread until the scheduler calls it again */
+ DosSleep (0);
+}
More information about the cairo-commit
mailing list