-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcache_simulator.c
More file actions
87 lines (71 loc) · 1.68 KB
/
cache_simulator.c
File metadata and controls
87 lines (71 loc) · 1.68 KB
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
/*
* main.c
*
* Created on: 25/12/2013
* Author: diego
*/
#include "sim_cache.h"
#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
int main()
{
unsigned int i, j;
unsigned long int cs, ls, a, n, dA, dB, dC, ws;
/*
* Example of simulation with:
* Cache size = 65536 bytes
* Line size = 32 bytes
* Associativity = 4
* Nº elements = 500
* A matrix address = 1024
* B matrix address = 10000000
* C matrix address = 100000000
* Word size = 4 bytes (float)
*/
cs = 65536;
ls = 64;
a = 4;
n = 500;
dA = 1024;
dB = 10000000;
dC = 100000000;
ws = 4;
/*
* C = A + B; Row major access
*/
config_sim(cs, ls, a);
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
sim_access(dA+ (i * n + j) * ws);
sim_access(dB+ (i * n + j) * ws);
sim_access(dC+ (i * n + j) * ws);
}
}
end_sim();
printf("****************\n");
printf("Row major access\n");
printf("****************\n");
printf("Total access = %d\n", Access());
printf("Total misses = %d\n", Misses());
printf("Miss rate = %4.2lf%%\n", (double)Misses()/(double)Access()*100);
/*
* C = A + B; Column major access
*/
config_sim(cs, ls, a);
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
sim_access(dA+ (j * n + i) * ws);
sim_access(dB+ (j * n + i) * ws);
sim_access(dC+ (j * n + i) * ws);
}
}
end_sim();
printf("\n*******************\n");
printf("Column major access\n");
printf("*******************\n");
printf("Total access = %d\n", Access());
printf("Total misses = %d\n", Misses());
printf("Miss rate = %4.2lf%%\n", (double)Misses()/(double)Access()*100);
return 0;
}