-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbenchmark.v
64 lines (64 loc) · 4.59 KB
/
benchmark.v
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
1. 32'b100000_00000_00001_00000_11000001010;//-- Addi r1 ,r0 ,1546 //r1=1546
2. 32'b000001_00000_00001_00010_00000000000;//-- Add r2 ,r0 ,r1//r2=1546
3. 32'b000011_00000_00001_00011_00000000000;//-- sub r3 ,r0 ,r1//r3=-1546
4. 32'b000101_00010_00011_0010000000000000; //--and r4,r2,r3 //r4=2
5. 32'b100001_00011_00101_0001101000110100; //--subi r5,r3,//r5=-8254
6. 32'b000110_00011_00100_0010100000000000; //--or r5,r3,r4 //r5=-1546
7. 32'b000111_00101_00000_0011000000000000; //--nor r6,r5,r0//r6=1545
8. 32'b000111_00100_00000_0101100000000000; //--nor r11,r4,r0//r11=-3
9. 32'b000011_00101_00101_0010100000000000; //--sub r5,r5,r5//r5=0
10. 32'b100000_00000_00001_0000010000000000; //--addi r1,r0,1024 //r1=1024
11. 32'b100101_00001_00010_0000000000000000;//-- st r2 ,r1 ,0 //
12. 32'b100100_00001_00101_00000_00000000000;//-- ld r5 ,r1 ,0 //r5=1546
13. 32'b101000_00101_00000_00000_00000000001;//-- Bez r5 ,1//not taken
14. 32'b001000_00101_00001_00111_00000000000;//-- xor r7 ,r5 ,r1 //r7=522
15. 32'b001000_00101_00001_00000_00000000000;//-- xor r0 ,r5 ,r1 //r0=0
16. 32'b001001_00011_00100_00111_00000000000;//-- sla r7 ,r3 ,r4//r7=-6184
17. 32'b100101_00001_00111_00000_00000010100;//-- st r7 ,r1 ,20
18. 32'b001010_00011_00100_01000_00000000000;//-- sll r8 ,r3 ,r4 //r8=-6184
19. 32'b001011_00011_00100_01001_00000000000;//-- sra r9 ,r3 ,r4 //r9=1073741437
20. 32'b001100_00011_00100_01010_00000000000;//-- srl r10 ,r3 ,r4//r10=-384
21. 32'b100101_00001_00011_00000_00000000100;//-- st r3 ,r1 ,4
22. 32'b100101_00001_00100_00000_00000001000;//-- st r4 ,r1 ,8
23. 32'b100101_00001_00101_00000_00000001100;//-- st r5 ,r1 ,12
24. 32'b100101_00001_00110_00000_00000010000;//-- st r6 ,r1 ,16
25. 32'b100100_00001_01011_00000_00000000100;//-- ld r11 ,r1 ,4//r11=-1456
26. 32'b100101_00001_01011_00000_00000011000;//-- st r11 ,r1 ,24
27. 32'b100101_00001_01001_00000_00000011100;//-- st r9 ,r1 ,28
28. 32'b100101_00001_01010_00000_00000100000;//-- st r10 ,r1 ,32
29. 32'b100101_00001_01000_00000_00000100100;//-- st r8 ,r1 ,36
30. 32'b100000_00000_00001_00000_00000000011;//-- Addi r1 ,r0 ,3 //r1=3
31. 32'b100000_00000_00100_00000_10000000000;//-- Addi r4 ,r0 ,1024 //r4=1024
32. 32'b100000_00000_00010_00000_00000000000;//-- Addi r2 ,r0 ,0 //r2=0
33. 32'b100000_00000_00011_00000_00000000001;//-- Addi r3 ,r0 ,1 //r3=1
34. 32'b100000_00000_01001_00000_00000000010;//-- Addi r9 ,r0 ,2 //r9=2
35. 32'b001010_00011_01001_01000_00000000000;//-- sll r8 ,r3 ,r9 //r8=r3*4
36. 32'b000001_00100_01000_01000_00000000000;//-- Add r8 ,r4 ,r8 //r8=1024+r3*4
37. 32'b100100_01000_00101_00000_00000000000;//-- ld r5 ,r8 ,0 //
38. 32'b100100_01000_00110_11111_11111111100;//-- ld r6 ,r8 ,-4 //
39. 32'b000011_00101_00110_01001_00000000000;//-- sub r9 ,r5 ,r6
40. 32'b100000_00000_01010_10000_00000000000;//-- Addi r10 ,r0 ,0x8000
41. 32'b100000_00000_01011_00000_00000010000;//-- Addi r11 ,r0 ,16 // r11 = 16
42. 32'b001010_01010_01011_01010_00000000000;//-- sll r10 ,r10 ,r11 // r10 = 2147483648 // TODO: wrong sign
43. 32'b000101_01001_01010_01001_00000000000;//-- And r9 ,r9 ,r10 // if(r5>r6) r9=0 else r9=-2147483648
44. 32'b101000_01001_00000_00000_00000000010;//-- Bez r9 ,2
45. 32'b100101_01000_00101_11111_11111111100;//-- st r5 ,r8 ,-4
46. 32'b100101_01000_00110_00000_00000000000;//-- st r6 ,r8 ,0
47. 32'b100000_00011_00011_00000_00000000001;//-- Addi r3 ,r3 ,1 //
48. 32'b101001_00001_00011_11111_11111110001;//-- BNE r1 ,r3 ,-15
49. 32'b100000_00010_00010_00000_00000000001;//-- Addi r2 ,r2 ,1 //2
50. 32'b101001_00001_00010_11111_11111101110;//-- BNE r1 ,r2 ,-18
51. 32'b100000_00000_00001_00000_10000000000;//-- Addi r1 ,r0 ,1024 //r1=1024
52. 32'b100100_00001_00010_00000_00000000000;//-- ld ,r2 ,r1 ,0 //r2=-1546
53. 32'b100100_00001_00011_00000_00000000100;//-- ld ,r3 ,r1 ,4 //r3=2
54. 32'b100100_00001_00100_00000_00000001000;//-- ld ,r4 ,r1 ,8 //r4=1546
55. 32'b100100_00001_00100_00000_01000001000;//-- ld ,r4 ,r1 ,520 // after SRAM r4=random number
56. 32'b100100_00001_00100_00000_10000001000;//-- ld ,r4 ,r1 ,1023 // after SRAM r4=random number
57. 32'b100100_00001_00101_00000_00000001100;//-- ld ,r5 ,r1 ,12 // r5=1546
58. 32'b100100_00001_00110_00000_00000010000;//-- ld ,r6 ,r1 ,16 //r6=1545
59. 32'b100100_00001_00111_00000_00000010100;//-- ld ,r7 ,r1 ,20 //r7=-6184
60. 32'b100100_00001_01000_00000_00000011000;//-- ld ,r8 ,r1 ,24 //r8=-1546
61. 32'b100100_00001_01001_00000_00000011100;//-- ld ,r9 ,r1 ,28 //r9=1073741437
62. 32'b100100_00001_01010_00000_00000100000;//-- ld ,r10,r1 ,32 //r10=-387
63. 32'b100100_00001_01011_00000_00000100100;//-- ld ,r11,r1 ,36 //r11=-6184 // when change report execution clock
64. 32'b101010_00000_00000_11111_11111111111;//-- JMP -1*/