-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathc4-l3-exc-mesi.cpp
58 lines (49 loc) · 1.9 KB
/
c4-l3-exc-mesi.cpp
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
#include "cache/memory.hpp"
#include "util/cache_type.hpp"
#include "util/regression.hpp"
#define PAddrN 1024
#define SAddrN 256
#define NCore 4
#define TestN ((PAddrN + SAddrN) * NCore * 2)
#define L1IW 4
#define L1WN 4
#define L2IW 5
#define L2WN 8
#define L3IW 5
#define L3WN 11
#define L3DW 5
int main() {
using policy_l3 = ExclusiveMESIPolicy<false, true, policy_memory, true>;
using policy_l2 = MSIPolicy<false, false, policy_l3>;
using policy_l1d = MSIPolicy<true, false, policy_l2>;
using policy_l1i = MSIPolicy<true, true, policy_l2>;
auto l1d = cache_gen_l1<L1IW, L1WN, Data64B, MetadataBroadcastBase, ReplaceLRU, MSIPolicy, policy_l1d, false, void, true>(NCore, "l1d");
auto core_data = get_l1_core_interface(l1d);
auto l1i = cache_gen_l1<L1IW, L1WN, Data64B, MetadataBroadcastBase, ReplaceLRU, MSIPolicy, policy_l1i, true, void, true>(NCore, "l1i");
auto core_inst = get_l1_core_interface(l1i);
auto l2 = cache_gen_inc<L2IW, L2WN, Data64B, MetadataBroadcastBase, ReplaceSRRIP, MSIPolicy, policy_l2, false, void, true>(NCore, "l2");
auto l3 = cache_gen_exc<L3IW, L3WN, L3DW, Data64B, MetadataDirectoryBase, ReplaceSRRIP, ReplaceLRU, ExclusiveMESIPolicy, policy_l3, true, void, true>(1, "l3")[0];
auto mem = new SimpleMemoryModel<Data64B,void,true>("mem");
SimpleTracer tracer(true);
for(int i=0; i<NCore; i++) {
l1i[i]->outer->connect(l2[i]->inner);
l1d[i]->outer->connect(l2[i]->inner);
l1i[i]->attach_monitor(&tracer);
l1d[i]->attach_monitor(&tracer);
l2[i]->outer->connect(l3->inner);
l2[i]->attach_monitor(&tracer);
}
l3->outer->connect(mem);
l3->attach_monitor(&tracer);
mem->attach_monitor(&tracer);
tracer.start();
RegressionGen<NCore, true, true, PAddrN, SAddrN, Data64B> tgen;
auto rv = tgen.run(TestN, core_inst, core_data);
tracer.stop();
delete_caches(l1d);
delete_caches(l1i);
delete_caches(l2);
delete l3;
delete mem;
return rv;
}