cranelift: Remove redundant branch and select instructions (#5097)
As discussed in the 2022/10/19 meeting, this PR removes many of the branch and select instructions that used iflags, in favor if using brz/brnz and select in their place. Additionally, it reworks selectif_spectre_guard to take an i8 input instead of an iflags input. For reference, the removed instructions are: br_icmp, brif, brff, trueif, trueff, and selectif.
This commit is contained in:
@@ -99,15 +99,11 @@ fn compute_addr(
|
||||
};
|
||||
|
||||
let element_addr = if let Some((index, bound)) = spectre_oob_cmp {
|
||||
let flags = pos.ins().ifcmp(index, bound);
|
||||
let cond = pos
|
||||
.ins()
|
||||
.icmp(IntCC::UnsignedGreaterThanOrEqual, index, bound);
|
||||
// If out-of-bounds, choose the table base on the misspeculation path.
|
||||
pos.ins().selectif_spectre_guard(
|
||||
addr_ty,
|
||||
IntCC::UnsignedGreaterThanOrEqual,
|
||||
flags,
|
||||
base,
|
||||
element_addr,
|
||||
)
|
||||
pos.ins().select_spectre_guard(cond, base, element_addr)
|
||||
} else {
|
||||
element_addr
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user