ARM64 backend, part 10 / 11: filetest support for VCode tests.
This patch adds support for filetests with the `vcode` type. This allows test cases to feed CLIF into the new backend, produce VCode output with machine instructions, and then perform matching against the pretty-printed text representation of the VCode. Tests for the new ARM64 backend using this infrastructure will come in a followup patch.
This commit is contained in:
1
Cargo.lock
generated
1
Cargo.lock
generated
@@ -433,6 +433,7 @@ dependencies = [
|
|||||||
"memmap",
|
"memmap",
|
||||||
"num_cpus",
|
"num_cpus",
|
||||||
"region",
|
"region",
|
||||||
|
"target-lexicon",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
|||||||
@@ -22,3 +22,4 @@ memmap = "0.7.0"
|
|||||||
num_cpus = "1.8.0"
|
num_cpus = "1.8.0"
|
||||||
region = "2.1.2"
|
region = "2.1.2"
|
||||||
byteorder = { version = "1.3.2", default-features = false }
|
byteorder = { version = "1.3.2", default-features = false }
|
||||||
|
target-lexicon = "0.10"
|
||||||
|
|||||||
@@ -56,6 +56,7 @@ mod test_shrink;
|
|||||||
mod test_simple_gvn;
|
mod test_simple_gvn;
|
||||||
mod test_simple_preopt;
|
mod test_simple_preopt;
|
||||||
mod test_unwind;
|
mod test_unwind;
|
||||||
|
mod test_vcode;
|
||||||
mod test_verifier;
|
mod test_verifier;
|
||||||
|
|
||||||
/// The result of running the test in a file.
|
/// The result of running the test in a file.
|
||||||
@@ -134,6 +135,7 @@ fn new_subtest(parsed: &TestCommand) -> subtest::SubtestResult<Box<dyn subtest::
|
|||||||
"run" => test_run::subtest(parsed),
|
"run" => test_run::subtest(parsed),
|
||||||
"shrink" => test_shrink::subtest(parsed),
|
"shrink" => test_shrink::subtest(parsed),
|
||||||
"simple-gvn" => test_simple_gvn::subtest(parsed),
|
"simple-gvn" => test_simple_gvn::subtest(parsed),
|
||||||
|
"vcode" => test_vcode::subtest(parsed),
|
||||||
"verifier" => test_verifier::subtest(parsed),
|
"verifier" => test_verifier::subtest(parsed),
|
||||||
"preopt" => test_preopt::subtest(parsed),
|
"preopt" => test_preopt::subtest(parsed),
|
||||||
"safepoint" => test_safepoint::subtest(parsed),
|
"safepoint" => test_safepoint::subtest(parsed),
|
||||||
|
|||||||
71
cranelift/filetests/src/test_vcode.rs
Normal file
71
cranelift/filetests/src/test_vcode.rs
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
use crate::subtest::{run_filecheck, Context, SubTest, SubtestResult};
|
||||||
|
use cranelift_codegen::ir::Function;
|
||||||
|
use cranelift_codegen::isa::lookup;
|
||||||
|
use cranelift_codegen::settings;
|
||||||
|
use cranelift_codegen::Context as CodegenContext;
|
||||||
|
use cranelift_reader::{TestCommand, TestOption};
|
||||||
|
use target_lexicon::Triple;
|
||||||
|
|
||||||
|
use log::info;
|
||||||
|
use std::borrow::Cow;
|
||||||
|
use std::str::FromStr;
|
||||||
|
use std::string::String;
|
||||||
|
|
||||||
|
struct TestVCode {
|
||||||
|
arch: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn subtest(parsed: &TestCommand) -> SubtestResult<Box<dyn SubTest>> {
|
||||||
|
assert_eq!(parsed.command, "vcode");
|
||||||
|
|
||||||
|
let mut arch = "arm64".to_string();
|
||||||
|
for option in &parsed.options {
|
||||||
|
match option {
|
||||||
|
TestOption::Value(k, v) if k == &"arch" => {
|
||||||
|
arch = v.to_string();
|
||||||
|
}
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Box::new(TestVCode { arch }))
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SubTest for TestVCode {
|
||||||
|
fn name(&self) -> &'static str {
|
||||||
|
"vcode"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_mutating(&self) -> bool {
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
fn needs_isa(&self) -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
fn run(&self, func: Cow<Function>, context: &Context) -> SubtestResult<()> {
|
||||||
|
let func = func.into_owned();
|
||||||
|
|
||||||
|
let triple =
|
||||||
|
Triple::from_str(&self.arch).map_err(|_| format!("Unknown arch: '{}'", self.arch))?;
|
||||||
|
|
||||||
|
let mut isa = lookup(triple)
|
||||||
|
.map_err(|_| format!("Could not look up backend for arch '{}'", self.arch))?
|
||||||
|
.finish(settings::Flags::new(settings::builder()));
|
||||||
|
|
||||||
|
let mut codectx = CodegenContext::for_function(func);
|
||||||
|
codectx.set_disasm(true);
|
||||||
|
|
||||||
|
codectx
|
||||||
|
.compile(&mut *isa)
|
||||||
|
.map_err(|e| format!("Could not compile with arch '{}': {:?}", self.arch, e))?;
|
||||||
|
|
||||||
|
let result = codectx.mach_compile_result.take().unwrap();
|
||||||
|
let text = result.disasm.unwrap();
|
||||||
|
|
||||||
|
info!("text input to filecheck is:\n{}\n", text);
|
||||||
|
|
||||||
|
run_filecheck(&text, context)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user