summaryrefslogtreecommitdiff
path: root/src/run.h
blob: 5358a49c8b3826b9276c2fb551f0537c13ef8a42 (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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/*******************************************************************************
 * Copyright (c) 2006 International Business Machines Corporation.             *
 * All rights reserved. This program and the accompanying materials            *
 * are made available under the terms of the Common Public License v1.0        *
 * which accompanies this distribution, and is available at                    *
 * http://www.opensource.org/licenses/cpl1.0.php                               *
 *                                                                             *
 * Contributors:                                                               *
 *    Douglas M. Pase - initial API and implementation                         *
 *    Tim Besard - prefetching, JIT compilation                                *
 *******************************************************************************/

//
// Configuration
//

// Include guard
#if !defined(RUN_H)
#define RUN_H

// System includes
#include <vector>


// Local includes
#include "thread.h"
#include "lock.h"
#include "chain.h"
#include "types.h"
#include "experiment.h"
#include "spinbarrier.h"


//
// Class definition
//

class Run: public Thread {
public:
	Run();
	~Run();
	int run();
	void set(Experiment &e, SpinBarrier* sbp);

	static int64 ops_per_chain() {
		return _ops_per_chain;
	}
	static std::vector<double> seconds() {
		return _seconds;
	}

private:
	Experiment* exp; // experiment data
	SpinBarrier* bp; // spin barrier used by all threads

	void mem_check(Chain *m);
	Chain* random_mem_init(Chain *m);
	Chain* forward_mem_init(Chain *m);
	Chain* reverse_mem_init(Chain *m);

	static Lock global_mutex; // global lock
	static int64 _ops_per_chain; // total number of operations per chain
	static std::vector<double> _seconds; // number of seconds for each experiment
};

#endif