forked from YosysHQ/riscv-formal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinsn_c_addi4spn.v
57 lines (51 loc) · 2.27 KB
/
insn_c_addi4spn.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
// DO NOT EDIT -- auto-generated from riscv-formal/insns/generate.py
module rvfi_insn_c_addi4spn (
input rvfi_valid,
input [`RISCV_FORMAL_ILEN - 1 : 0] rvfi_insn,
input [`RISCV_FORMAL_XLEN - 1 : 0] rvfi_pc_rdata,
input [`RISCV_FORMAL_XLEN - 1 : 0] rvfi_rs1_rdata,
input [`RISCV_FORMAL_XLEN - 1 : 0] rvfi_rs2_rdata,
input [`RISCV_FORMAL_XLEN - 1 : 0] rvfi_mem_rdata,
`ifdef RISCV_FORMAL_CSR_MISA
input [`RISCV_FORMAL_XLEN - 1 : 0] rvfi_csr_misa_rdata,
output [`RISCV_FORMAL_XLEN - 1 : 0] spec_csr_misa_rmask,
`endif
output spec_valid,
output spec_trap,
output [ 4 : 0] spec_rs1_addr,
output [ 4 : 0] spec_rs2_addr,
output [ 4 : 0] spec_rd_addr,
output [`RISCV_FORMAL_XLEN - 1 : 0] spec_rd_wdata,
output [`RISCV_FORMAL_XLEN - 1 : 0] spec_pc_wdata,
output [`RISCV_FORMAL_XLEN - 1 : 0] spec_mem_addr,
output [`RISCV_FORMAL_XLEN/8 - 1 : 0] spec_mem_rmask,
output [`RISCV_FORMAL_XLEN/8 - 1 : 0] spec_mem_wmask,
output [`RISCV_FORMAL_XLEN - 1 : 0] spec_mem_wdata
);
// CIW-type instruction format
wire [`RISCV_FORMAL_ILEN-1:0] insn_padding = rvfi_insn >> 16;
wire [`RISCV_FORMAL_XLEN-1:0] insn_imm = {rvfi_insn[10:7], rvfi_insn[12:11], rvfi_insn[5], rvfi_insn[6], 2'b00};
wire [2:0] insn_funct3 = rvfi_insn[15:13];
wire [4:0] insn_rd = {1'b1, rvfi_insn[4:2]};
wire [1:0] insn_opcode = rvfi_insn[1:0];
`ifdef RISCV_FORMAL_CSR_MISA
wire misa_ok = (rvfi_csr_misa_rdata & `RISCV_FORMAL_XLEN'h 4) == `RISCV_FORMAL_XLEN'h 4;
assign spec_csr_misa_rmask = `RISCV_FORMAL_XLEN'h 4;
`else
wire misa_ok = 1;
`endif
// C_ADDI4SPN instruction
wire [`RISCV_FORMAL_XLEN-1:0] result = rvfi_rs1_rdata + insn_imm;
assign spec_valid = rvfi_valid && !insn_padding && insn_funct3 == 3'b 000 && insn_opcode == 2'b 00 && insn_imm;
assign spec_rs1_addr = 2;
assign spec_rd_addr = insn_rd;
assign spec_rd_wdata = spec_rd_addr ? result : 0;
assign spec_pc_wdata = rvfi_pc_rdata + 2;
// default assignments
assign spec_rs2_addr = 0;
assign spec_trap = !misa_ok;
assign spec_mem_addr = 0;
assign spec_mem_rmask = 0;
assign spec_mem_wmask = 0;
assign spec_mem_wdata = 0;
endmodule