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
|
#include "mips.h"
#include "f_fibonacci.c"
int main(int argc, char *argv[])
{
const char *srcName="f_fibonacci-mips.bin";
if(argc>1){
srcName=argv[1];
}
mips_mem_h m=mips_mem_create_ram(0x20000);
mips_cpu_h c=mips_cpu_create(m);
FILE *src=fopen(srcName,"rb");
if(!src){
fprintf(stderr, "Cannot load source file '%s', try specifying the relative path to f_fibonacci-mips.bin.", srcName);
exit(1);
}
uint32_t v;
uint32_t offset=0;
while(1==fread(&v, 4, 1, src)){
if(mips_mem_write(m, offset, 4, (uint8_t*)&v)){
fprintf(stderr, "Memory error while loading binary.");
exit(1);
}
offset+=4;
}
fprintf(stderr, "Loaded %d bytes of binary at address 0.", offset);
fclose(src);
// No error checking... oh my!
uint32_t n=12; // Value we will calculate fibonacci of
uint32_t sentinelPC=0x10000000;
mips_cpu_set_register(c, 31, sentinelPC); // set return address to something invalid
mips_cpu_set_register(c, 4, n); // Set input argument
mips_cpu_set_register(c, 29, 0x1000); // Create a stack pointer
uint32_t steps=0;
while(!mips_cpu_step(c)){
fprintf(stderr, "Step %d.\n", steps);
++steps;
uint32_t pc;
mips_cpu_get_pc(c, &pc);
if(pc==sentinelPC)
break;
}
uint32_t fib_n;
mips_cpu_get_register(c, 2, &fib_n); // Get the result back
uint32_t fib_n_ref=f_fibonacci(n);
fprintf(stderr, "fib(%d) = %d, expected = %d\n", n, fib_n, fib_n_ref);
return 0;
}
|