forked from jatindev2016/Cache-Coherence-Protocols
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLLC.h
107 lines (96 loc) · 1.9 KB
/
LLC.h
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#include<iostream>
using namespace std;
#define L3_ID 1
#define L3_SETS 2048
#define L3_WAYS 16
class LLC
{
public:
unsigned long long tags[L3_SETS][L3_WAYS];
unsigned long long int timeStamp[L3_SETS][L3_WAYS];
unsigned long long hitCount, missCount;
LLC(){
hitCount = 0;
missCount = 0;
reset();
}
void reset()
{
//clearing L3 cache
for(int i=0;i<L3_SETS;i++)
{
for(int j=0;j<L3_WAYS;j++)
{
tags[i][j]=0;
}
}
//clearing L3 Timestamp
for(int i=0;i<L3_SETS;i++)
{
for(int j=0;j<L3_WAYS;j++)
{
timeStamp[i][j]=0;
}
}
}
void print()
{
printf("--------------L3_DATA-----------\n");
for(int i=0;i<L3_SETS;i++)
{
for(int j=0;j<L3_WAYS;j++)
{
printf("%lld\t|",tags[i][j]);
}
printf("\n");
}
printf("--------------L3_Timestamp-----------\n");
for(int i=0;i<L3_SETS;i++)
{
for(int j=0;j<L3_WAYS;j++)
{
printf("%lld\t|",timeStamp[i][j]);
}
printf("\n");
}
}
int find_victim(int set)
{
int i,min=timeStamp[set][0],way=0;
for(i=1;i<L3_WAYS;i++)
{
if(timeStamp[set][i]<=min)
{
min=timeStamp[set][i];
way=i;
}
}
return way;
}
void update_timestamp(int set,int way,int opr, unsigned long long * timeStampCntr)
{
(*timeStampCntr)++;
//opr 0 mean invalidate
if(opr==0)
timeStamp[set][way] = 0;
else
//update timestamp
timeStamp[set][way] = *timeStampCntr;
}
int search(int set,int tag)
{
for(int i=0;i<L3_WAYS;i++)
{
if((tags[set][i]==tag) && (timeStamp[set][i]!=0))
return i;
}
return -1;
}
int insert(int set,int tag, unsigned long long * timeStampCntr)
{
//way return the position to be evict, then insert data at way and update LRU table
int way =find_victim(set);
tags[set][way]=tag;
update_timestamp(set, way, 1, timeStampCntr);
}
};