souper-harvest: ensure that select conditions are of type i1
This commit is contained in:
4
Cargo.lock
generated
4
Cargo.lock
generated
@@ -1989,9 +1989,9 @@ checksum = "fbee7696b84bbf3d89a1c2eccff0850e3047ed46bfcd2e92c29a2d074d57e252"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "souper-ir"
|
name = "souper-ir"
|
||||||
version = "2.0.0"
|
version = "2.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "1c7eaed476845a4755001a900e0412dabd356d312ddc35dd32ff91de266b1558"
|
checksum = "a50c18ce33988e1973003afbaa66e6a465ad7a614dc33f246879ccc209c2c044"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"id-arena",
|
"id-arena",
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ peepmatic = { path = "../peepmatic", optional = true, version = "0.68.0" }
|
|||||||
peepmatic-traits = { path = "../peepmatic/crates/traits", optional = true, version = "0.68.0" }
|
peepmatic-traits = { path = "../peepmatic/crates/traits", optional = true, version = "0.68.0" }
|
||||||
peepmatic-runtime = { path = "../peepmatic/crates/runtime", optional = true, version = "0.68.0" }
|
peepmatic-runtime = { path = "../peepmatic/crates/runtime", optional = true, version = "0.68.0" }
|
||||||
regalloc = { version = "0.0.31" }
|
regalloc = { version = "0.0.31" }
|
||||||
souper-ir = { version = "2.0.0", optional = true }
|
souper-ir = { version = "2.1.0", optional = true }
|
||||||
wast = { version = "28.0.0", optional = true }
|
wast = { version = "28.0.0", optional = true }
|
||||||
# It is a goal of the cranelift-codegen crate to have minimal external dependencies.
|
# It is a goal of the cranelift-codegen crate to have minimal external dependencies.
|
||||||
# Please don't add any unless they are essential to the task of creating binary
|
# Please don't add any unless they are essential to the task of creating binary
|
||||||
|
|||||||
@@ -392,6 +392,28 @@ fn harvest_candidate_lhs(
|
|||||||
}
|
}
|
||||||
(ir::Opcode::Select, _) => {
|
(ir::Opcode::Select, _) => {
|
||||||
let a = arg(allocs, 0);
|
let a = arg(allocs, 0);
|
||||||
|
|
||||||
|
// While Cranelift allows any width condition for
|
||||||
|
// `select`, Souper requires an `i1`.
|
||||||
|
let a = match a {
|
||||||
|
ast::Operand::Value(id) => match lhs.get_value(id).r#type {
|
||||||
|
Some(ast::Type { width: 1 }) => a,
|
||||||
|
_ => lhs
|
||||||
|
.assignment(
|
||||||
|
None,
|
||||||
|
Some(ast::Type { width: 1 }),
|
||||||
|
ast::Instruction::Trunc { a },
|
||||||
|
vec![],
|
||||||
|
)
|
||||||
|
.into(),
|
||||||
|
},
|
||||||
|
ast::Operand::Constant(ast::Constant { value, .. }) => ast::Constant {
|
||||||
|
value: (value != 0) as _,
|
||||||
|
r#type: Some(ast::Type { width: 1 }),
|
||||||
|
}
|
||||||
|
.into(),
|
||||||
|
};
|
||||||
|
|
||||||
let b = arg(allocs, 1);
|
let b = arg(allocs, 1);
|
||||||
let c = arg(allocs, 2);
|
let c = arg(allocs, 2);
|
||||||
ast::Instruction::Select { a, b, c }.into()
|
ast::Instruction::Select { a, b, c }.into()
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ description = "Converting Souper optimizations into Peepmatic DSL"
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
anyhow = "1"
|
anyhow = "1"
|
||||||
souper-ir = { version = "2.0.0", features = ["parse"] }
|
souper-ir = { version = "2.1.0", features = ["parse"] }
|
||||||
log = "0.4.8"
|
log = "0.4.8"
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
|
|||||||
Reference in New Issue
Block a user