diff options
author | Robert Norton <rmn30@cam.ac.uk> | 2019-12-19 14:16:24 +0000 |
---|---|---|
committer | Robert Norton <rmn30@cam.ac.uk> | 2019-12-19 14:16:24 +0000 |
commit | 1a6d57a3cfba903808ad13ce4e45a2fecf79cac7 (patch) | |
tree | 2fd31013aa0727cff70d04a801facfd6bfd9df84 | |
parent | 1546516cc34c7b6f2665217164c68a459c4f9bcd (diff) | |
download | sail-riscv-fence_issue29.zip sail-riscv-fence_issue29.tar.gz sail-riscv-fence_issue29.tar.bz2 |
Proposed fix for #29. Ignore rs1 and rd fields of FENCE instruction and reserved values of fm.fence_issue29
-rw-r--r-- | model/riscv_analysis.sail | 8 | ||||
-rw-r--r-- | model/riscv_insts_base.sail | 22 |
2 files changed, 15 insertions, 15 deletions
diff --git a/model/riscv_analysis.sail b/model/riscv_analysis.sail index 5b55e6e..8ae9fc6 100644 --- a/model/riscv_analysis.sail +++ b/model/riscv_analysis.sail @@ -112,7 +112,7 @@ function initial_analysis (instr:ast) -> (regfps,regfps,regfps,niafps,diafp,inst if (rs1 == 0b00000) then () else iR = RFull(GPRstr(rs1)) :: iR; if (rd == 0b00000) then () else oR = RFull(GPRstr(rd)) :: oR; }, - FENCE(pred, succ) => { + FENCE(_, pred, succ, _, _) => { ik = match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => IK_barrier (Barrier_RISCV_rw_rw), @@ -131,7 +131,7 @@ function initial_analysis (instr:ast) -> (regfps,regfps,regfps,niafps,diafp,inst _ => internal_error("barrier type not implemented in initial_analysis") }; }, - FENCE_TSO(pred, succ) => { + FENCE_TSO(pred, succ, _, _) => { ik = match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => IK_barrier (Barrier_RISCV_tso), @@ -285,7 +285,7 @@ function initial_analysis (instr:ast) -> (regfps,regfps,regfps,niafps,diafp,inst if (rs1 == 0b00000) then () else iR = RFull(GPRstr(rs1)) :: iR; if (rd == 0b00000) then () else oR = RFull(GPRstr(rd)) :: oR; }, - FENCE(pred, succ) => { + FENCE(_, pred, succ, _, _) => { ik = match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => IK_barrier (Barrier_RISCV_rw_rw ()), @@ -303,7 +303,7 @@ function initial_analysis (instr:ast) -> (regfps,regfps,regfps,niafps,diafp,inst _ => internal_error("barrier type not implemented in initial_analysis") }; }, - FENCE_TSO(pred, succ) => { + FENCE_TSO(pred, succ, _, _) => { ik = match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => IK_barrier (Barrier_RISCV_tso ()), diff --git a/model/riscv_insts_base.sail b/model/riscv_insts_base.sail index bc86859..e036e7e 100644 --- a/model/riscv_insts_base.sail +++ b/model/riscv_insts_base.sail @@ -559,15 +559,15 @@ mapping clause assembly = SHIFTIWOP(shamt, rs1, rd, op) if sizeof(xlen) == 64 /* ****************************************************************** */ -union clause ast = FENCE : (bits(4), bits(4)) +union clause ast = FENCE : (bits(4), bits(4), bits(4), regidx, regidx) -mapping clause encdec = FENCE(pred, succ) - <-> 0b0000 @ pred @ succ @ 0b00000 @ 0b000 @ 0b00000 @ 0b0001111 +mapping clause encdec = FENCE(fm, pred, succ, rs1, rd) if (fm != 0b1000 /* TSO is handled below */) + <-> fm : bits(4) @ pred @ succ @ rs1 : regidx @ 0b000 @ rd : regidx @ 0b0001111 if (fm != 0b1000) /* For future versions of Sail where barriers can be parameterised */ $ifdef FEATURE_UNION_BARRIER -function clause execute (FENCE(pred, succ)) = { +function clause execute (FENCE(_, pred, succ, _, _)) = { match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => __barrier(Barrier_RISCV_rw_rw()), (_ : bits(2) @ 0b10, _ : bits(2) @ 0b11) => __barrier(Barrier_RISCV_r_rw()), @@ -635,18 +635,18 @@ mapping fence_bits : bits(4) <-> string = { i : bits(1) @ o : bits(1) @ r : bits(1) @ w : bits(1) <-> bit_maybe_i(i) ^ bit_maybe_o(o) ^ bit_maybe_r(r) ^ bit_maybe_w(w) } -mapping clause assembly = FENCE(pred, succ) +mapping clause assembly = FENCE(0b0000, pred, succ, 0b00000, 0b00000) <-> "fence" ^ spc() ^ fence_bits(pred) ^ sep() ^ fence_bits(succ) /* ****************************************************************** */ -union clause ast = FENCE_TSO : (bits(4), bits(4)) +union clause ast = FENCE_TSO : (bits(4), bits(4), regidx, regidx) -mapping clause encdec = FENCE_TSO(pred, succ) - <-> 0b1000 @ pred @ succ @ 0b00000 @ 0b000 @ 0b00000 @ 0b0001111 +mapping clause encdec = FENCE_TSO(pred, succ, rs1, rd) + <-> 0b1000 @ pred @ succ @ rs1 : regidx @ 0b000 @ rd : regidx @ 0b0001111 $ifdef FEATURE_UNION_BARRIER -function clause execute (FENCE_TSO(pred, succ)) = { +function clause execute (FENCE_TSO(pred, succ, _, _)) = { match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => __barrier(Barrier_RISCV_tso()), (_ : bits(2) @ 0b00, _ : bits(2) @ 0b00) => (), @@ -659,7 +659,7 @@ function clause execute (FENCE_TSO(pred, succ)) = { $else -function clause execute (FENCE_TSO(pred, succ)) = { +function clause execute (FENCE_TSO(pred, succ, _, _)) = { match (pred, succ) { (_ : bits(2) @ 0b11, _ : bits(2) @ 0b11) => __barrier(Barrier_RISCV_tso), (_ : bits(2) @ 0b00, _ : bits(2) @ 0b00) => (), @@ -672,7 +672,7 @@ function clause execute (FENCE_TSO(pred, succ)) = { $endif -mapping clause assembly = FENCE_TSO(pred, succ) +mapping clause assembly = FENCE_TSO(pred, succ, 0b00000, 0b00000) <-> "fence.tso" ^ spc() ^ fence_bits(pred) ^ sep() ^ fence_bits(succ) /* ****************************************************************** */ |