Skip to content

Commit cb38e53

Browse files
authored
Unrolled build for rust-lang#121088
Rollup merge of rust-lang#121088 - nikic:evex512, r=Amanieu Implicitly enable evex512 if avx512 is enabled LLVM 18 requires the evex512 feature to allow use of zmm registers. LLVM automatically sets it when using a generic CPU, but not when `-C target-cpu` is specified. This will result either in backend legalization crashes, or code unexpectedly using ymm instead of zmm registers. For now, make sure that `avx512*` features imply `evex512`. Long term we'll probably have to deal with the AVX10 mess somehow. Fixes rust-lang#121081. r? `@Amanieu`
2 parents 62fb0db + 369fff6 commit cb38e53

File tree

2 files changed

+19
-0
lines changed

2 files changed

+19
-0
lines changed

compiler/rustc_codegen_llvm/src/llvm_util.rs

+4
Original file line numberDiff line numberDiff line change
@@ -266,6 +266,10 @@ pub fn to_llvm_features<'a>(sess: &Session, s: &'a str) -> LLVMFeature<'a> {
266266
("riscv32" | "riscv64", "fast-unaligned-access") if get_version().0 <= 17 => {
267267
LLVMFeature::new("unaligned-scalar-mem")
268268
}
269+
// For LLVM 18, enable the evex512 target feature if a avx512 target feature is enabled.
270+
("x86", s) if get_version().0 >= 18 && s.starts_with("avx512") => {
271+
LLVMFeature::with_dependency(s, TargetFeatureFoldStrength::EnableOnly("evex512"))
272+
}
269273
(_, s) => LLVMFeature::new(s),
270274
}
271275
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
// build-pass
2+
// only-x86_64
3+
// compile-flags: --crate-type=lib -C target-cpu=skylake
4+
5+
#![feature(avx512_target_feature)]
6+
#![feature(stdarch_x86_avx512)]
7+
8+
use std::arch::x86_64::*;
9+
10+
#[target_feature(enable = "avx512f")]
11+
#[no_mangle]
12+
pub unsafe fn test(res: *mut f64, p: *const f64) {
13+
let arg = _mm512_load_pd(p);
14+
_mm512_store_pd(res, _mm512_fmaddsub_pd(arg, arg, arg));
15+
}

0 commit comments

Comments
 (0)