-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathXCoreVBranchImmediate.core_desc
34 lines (33 loc) · 1.33 KB
/
XCoreVBranchImmediate.core_desc
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
import "../rv_base/RISCVBase.core_desc"
InstructionSet XCoreVBranchImmediate extends RISCVBase {
instructions {
CV_BEQIMM [[no_cont]] [[cond]] {
encoding: imm[12:12] ::imm[10:5] :: simm5[4:0] :: rs1[4:0] :: 3'b110 :: imm[4:1] :: imm[11:11] :: 7'b0001011;
assembly: {"cv.beqimm", "{name(rs1)}, {simm5:#0x}, {imm:#0x}"};
behavior: {
if (X[rs1 % RFS] == (signed)simm5) {
if(imm % INSTR_ALIGNMENT) {
raise(0, 0);
} else {
PC = PC + (signed)imm;
}
}
}
}
CV_BNEIMM [[no_cont]] [[cond]] {
encoding: imm[12:12] ::imm[10:5] :: simm5[4:0] :: rs1[4:0] :: 3'b111 :: imm[4:1] :: imm[11:11] :: 7'b0001011;
assembly: {"cv.bneimm", "{name(rs1)}, {simm5:#0x}, {imm:#0x}"};
// operands: signed<5> simm5, signed<13> imm, unsigned<5> rs1;
// constraints: { field in [1, 2, 4, 8] && imm % INSTR_ALIGNMENT == 0; }
behavior: {
if (X[rs1 % RFS] != (signed)simm5) {
if(imm % INSTR_ALIGNMENT) {
raise(0, 0);
} else {
PC = PC + (signed)imm;
}
}
}
}
}
}