comparison profile.c @ 0:435ac1cdb64e

create task dandy directry.
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Sat, 11 Dec 2010 21:25:28 +0900
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:435ac1cdb64e
1 #include<stdio.h>
2 #include<stdlib.h>
3 #include<string.h>
4 #include<sys/time.h>
5 #include<unistd.h>
6 #include"profile.h"
7
8 static unsigned long timeprof_overhead;
9
10 #define timeprof_get_time(t) {\
11 struct timeval t0;\
12 gettimeofday(&t0,NULL);\
13 (t).sec=t0.tv_sec;\
14 (t).usec=t0.tv_usec;}
15
16 void timeprof_begin(Timeprof t)
17 {
18 timeprof_get_time(t->begin);
19 }
20
21 int timeprof_end(Timeprof t)
22 {
23 unsigned int etime;
24 timeprof_get_time(t->end);
25 if (t->begin.usec > t->end.usec) {
26 t->end.usec += 1000000;
27 t->end.sec--;
28 }
29 etime = ((t->end.sec - t->begin.sec) * 1000000 +
30 (t->end.usec - t->begin.usec)) - timeprof_overhead;
31 if (etime > t->peak) {
32 t->peak = etime;
33 }
34 if (t->average > 0) {
35 t->average += etime;
36 t->average /= 2;
37 } else {
38 t->average = etime;
39 }
40 return etime;
41 }
42
43 void timeprof_sprint(char *s, const char *profname, Timeprof t)
44 {
45 sprintf(s, "%s: average:%dusec, peak:%dusec", profname, t->average,
46 t->peak);
47 }
48
49 void timeprof_init()
50 {
51 struct time_profile t;
52 timeprof_begin(&t);
53 timeprof_overhead = timeprof_end(&t);
54 }
55
56 Timeprof timeprof_new()
57 {
58 Timeprof t = (Timeprof) malloc(sizeof(struct time_profile));
59 memset(t, 0, sizeof(struct time_profile));
60 return t;
61 }