diff --git a/crates/stdarch-test/src/disassembly.rs b/crates/stdarch-test/src/disassembly.rs index a7b46a73fc..6a3ca06cb6 100644 --- a/crates/stdarch-test/src/disassembly.rs +++ b/crates/stdarch-test/src/disassembly.rs @@ -140,7 +140,7 @@ fn parse(output: &str) -> HashSet { .filter(|&x| !x.is_empty()) .skip(1) .map(str::to_lowercase) - .skip_while(|s| *s == "lock") // skip x86-specific prefix + .skip_while(|s| matches!(&**s, "lock" | "vex")) // skip x86-specific prefix .collect::>() } else { // objdump with --no-show-raw-insn @@ -150,8 +150,8 @@ fn parse(output: &str) -> HashSet { instruction .split_whitespace() .skip(1) - .skip_while(|s| *s == "lock" || *s == "{evex}") // skip x86-specific prefix - .map(std::string::ToString::to_string) + .skip_while(|s| matches!(*s, "lock" | "{evex}" | "{vex}")) // skip x86-specific prefix + .map(ToString::to_string) .collect::>() }; diff --git a/crates/stdarch-test/src/lib.rs b/crates/stdarch-test/src/lib.rs index 3248de8f3a..796afa2c43 100644 --- a/crates/stdarch-test/src/lib.rs +++ b/crates/stdarch-test/src/lib.rs @@ -21,7 +21,7 @@ cfg_if! { use wasm::disassemble_myself; } else { mod disassembly; - use crate::disassembly::disassemble_myself; + use disassembly::disassemble_myself; } } @@ -84,7 +84,12 @@ pub fn assert(shim_addr: usize, fnname: &str, expected: &str) { // 2. It is a mark, indicating that the instruction will be // compiled into other instructions - mainly because of llvm // optimization. - let found = expected == "nop" || instrs.iter().any(|s| s.contains(expected)); + let expected = if expected == "unknown" { + "" // Workaround for rust-lang/stdarch#1674, todo: remove when the issue is fixed + } else { + expected + }; + let found = expected == "nop" || instrs.iter().any(|s| s.starts_with(expected)); // Look for subroutine call instructions in the disassembly to detect whether // inlining failed: all intrinsics are `#[inline(always)]`, so calling one