Rollup merge of #102499 - cuviper:llvm-16-s390x, r=nikic

Adjust the s390x data layout for LLVM 16

LLVM [D131158] changed the SystemZ data layout to always set 64-bit
vector alignment, which used to be conditional on the "vector" feature.

[D131158]: https://reviews.llvm.org/D131158

r? `@nikic`
This commit is contained in:
Matthias Krüger 2022-09-30 10:22:39 +02:00 committed by GitHub
commit 588a25a6f8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 13 additions and 8 deletions

View File

@ -154,6 +154,11 @@ pub unsafe fn create_module<'ll>(
target_data_layout = target_data_layout.replace("-p10:8:8-p20:8:8", ""); target_data_layout = target_data_layout.replace("-p10:8:8-p20:8:8", "");
} }
} }
if llvm_version < (16, 0, 0) {
if sess.target.arch == "s390x" {
target_data_layout = target_data_layout.replace("-v128:64", "");
}
}
// Ensure the data-layout values hardcoded remain the defaults. // Ensure the data-layout values hardcoded remain the defaults.
if sess.target.is_builtin { if sess.target.is_builtin {

View File

@ -6,9 +6,9 @@ pub fn target() -> Target {
base.endian = Endian::Big; base.endian = Endian::Big;
// z10 is the oldest CPU supported by LLVM // z10 is the oldest CPU supported by LLVM
base.cpu = "z10".into(); base.cpu = "z10".into();
// FIXME: The data_layout string below and the ABI implementation in // FIXME: The ABI implementation in cabi_s390x.rs is for now hard-coded to assume the no-vector
// cabi_s390x.rs are for now hard-coded to assume the no-vector ABI. // ABI. Pass the -vector feature string to LLVM to respect this assumption. On LLVM < 16, we
// Pass the -vector feature string to LLVM to respect this assumption. // also strip v128 from the data_layout below to match the older LLVM's expectation.
base.features = "-vector".into(); base.features = "-vector".into();
base.max_atomic_width = Some(64); base.max_atomic_width = Some(64);
base.min_global_align = Some(16); base.min_global_align = Some(16);
@ -17,7 +17,7 @@ pub fn target() -> Target {
Target { Target {
llvm_target: "s390x-unknown-linux-gnu".into(), llvm_target: "s390x-unknown-linux-gnu".into(),
pointer_width: 64, pointer_width: 64,
data_layout: "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64".into(), data_layout: "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64".into(),
arch: "s390x".into(), arch: "s390x".into(),
options: base, options: base,
} }

View File

@ -6,9 +6,9 @@ pub fn target() -> Target {
base.endian = Endian::Big; base.endian = Endian::Big;
// z10 is the oldest CPU supported by LLVM // z10 is the oldest CPU supported by LLVM
base.cpu = "z10".into(); base.cpu = "z10".into();
// FIXME: The data_layout string below and the ABI implementation in // FIXME: The ABI implementation in cabi_s390x.rs is for now hard-coded to assume the no-vector
// cabi_s390x.rs are for now hard-coded to assume the no-vector ABI. // ABI. Pass the -vector feature string to LLVM to respect this assumption. On LLVM < 16, we
// Pass the -vector feature string to LLVM to respect this assumption. // also strip v128 from the data_layout below to match the older LLVM's expectation.
base.features = "-vector".into(); base.features = "-vector".into();
base.max_atomic_width = Some(64); base.max_atomic_width = Some(64);
base.min_global_align = Some(16); base.min_global_align = Some(16);
@ -18,7 +18,7 @@ pub fn target() -> Target {
Target { Target {
llvm_target: "s390x-unknown-linux-musl".into(), llvm_target: "s390x-unknown-linux-musl".into(),
pointer_width: 64, pointer_width: 64,
data_layout: "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64".into(), data_layout: "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64".into(),
arch: "s390x".into(), arch: "s390x".into(),
options: base, options: base,
} }