1 /* 2 * Copyright 2007 Red Hat, Inc. 3 * 4 * Permission to use, copy, modify, distribute, and sell this software and its 5 * documentation for any purpose is hereby granted without fee, provided that 6 * the above copyright notice appear in all copies and that both that 7 * copyright notice and this permission notice appear in supporting 8 * documentation, and that the name of Red Hat not be used in advertising or 9 * publicity pertaining to distribution of the software without specific, 10 * written prior permission. Red Hat makes no representations about the 11 * suitability of this software for any purpose. It is provided "as is" 12 * without express or implied warranty. 13 * 14 * RED HAT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL RED HAT 16 * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 17 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 18 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 19 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 20 */ 21 22 #ifdef HAVE_CONFIG_H 23 #include <config.h> 24 #endif 25 26 #include <stdlib.h> 27 #include <stdio.h> 28 #include "pixman-private.h" 29 30 #ifdef PIXMAN_TIMERS 31 32 static pixman_timer_t *timers; 33 34 static void 35 dump_timers (void) 36 { 37 pixman_timer_t *timer; 38 39 for (timer = timers; timer != NULL; timer = timer->next) 40 { 41 printf ("%s: total: %llu n: %llu avg: %f\n", 42 timer->name, 43 timer->total, 44 timer->n_times, 45 timer->total / (double)timer->n_times); 46 } 47 } 48 49 void 50 pixman_timer_register (pixman_timer_t *timer) 51 { 52 static int initialized; 53 54 int atexit (void (*function)(void)); 55 56 if (!initialized) 57 { 58 atexit (dump_timers); 59 initialized = 1; 60 } 61 62 timer->next = timers; 63 timers = timer; 64 } 65 66 #endif 67