summaryrefslogtreecommitdiff
path: root/BFS/support/timer.h
blob: 63b5567e83b45e66baee224131740aeeb91d43a4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31

#ifndef _TIMER_H_
#define _TIMER_H_

#include <stdio.h>
#include <sys/time.h>

typedef struct Timer {
	struct timeval startTime[8];
	struct timeval stopTime[8];
	double time[8];
} Timer;

static void startTimer(Timer *timer, int i, int rep)
{
	if (rep == 0) {
		timer->time[i] = 0.0;
	}
	gettimeofday(&timer->startTime[i], NULL);
}

static void stopTimer(Timer *timer, int i)
{
	gettimeofday(&timer->stopTime[i], NULL);
	timer->time[i] +=
	    (timer->stopTime[i].tv_sec -
	     timer->startTime[i].tv_sec) * 1000000.0 +
	    (timer->stopTime[i].tv_usec - timer->startTime[i].tv_usec);
}

#endif