forked from mit-plv/koika
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfetch_instr.v
41 lines (35 loc) · 1.44 KB
/
fetch_instr.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
/*! Verilog implementation of external functions for the function_call example -*- mode: verilog -*- !*/
bit[31:0] instructions[8] = '{
32'b11011000001011000000011111001101,
32'b01101011101010101001010001010101,
32'b10000010111000101110011001100010,
32'b01111010000000100100001000000100,
32'b11101000011110100001011000010011,
32'b10000001001100110010100001110110,
32'b01001000001001101000011001110011,
32'b11000001011111000110001001111001
};
module fetch_instr(input wire CLK, input wire RST_N,
input wire[2:0] arg,
output wire[31:0] out);
assign out = instructions[arg];
endmodule
/* An alternative approach would be to use a C function to implement this
external method; in that case you'd use the following declaration:
import "DPI-C" function bit[31:0] c_fetch_instr(input bit[2:0] arg);
and then
assign out = c_fetch_instr(arg);
And on the C side you'd use this:
static constexpr svBitVecVal instructions[8] = {
0b11011000001011000000011111001101,
0b01101011101010101001010001010101,
0b10000010111000101110011001100010,
0b01111010000000100100001000000100,
0b11101000011110100001011000010011,
0b10000001001100110010100001110110,
0b01001000001001101000011001110011,
0b11000001011111000110001001111001
};
extern "C" svBitVecVal c_fetch_instr(const svBitVecVal* input) {
return instructions[*input];
} */