diff options
| author | bors <bors@rust-lang.org> | 2020-02-29 17:14:54 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2020-02-29 17:14:54 +0000 |
| commit | 4f0edbdfe5f111c43a5e06f68186b95141d1f6c8 (patch) | |
| tree | 988048f6571e7d92bd374f2c69b3809efbfa1828 | |
| parent | e9bca510fe17354f876aa289bb39d347d7c69c69 (diff) | |
| parent | 162d72727ecfad4d75c2564f84abc73212aa7f27 (diff) | |
| download | rust-4f0edbdfe5f111c43a5e06f68186b95141d1f6c8.tar.gz rust-4f0edbdfe5f111c43a5e06f68186b95141d1f6c8.zip | |
Auto merge of #69263 - anyska:blacklist-powerpc-zst, r=nagisa
Blacklist powerpc-unknown-linux-{gnu,musl} as having non-ignored GNU C ZSTs.
Ref #64259 (this is a simpler alternative to that). See also https://github.com/rust-lang/rust/pull/64259#issuecomment-585815831.
| -rw-r--r-- | src/librustc/ty/layout.rs | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/src/librustc/ty/layout.rs b/src/librustc/ty/layout.rs index cb98ff4c9e5..b23b655db0b 100644 --- a/src/librustc/ty/layout.rs +++ b/src/librustc/ty/layout.rs @@ -2541,12 +2541,15 @@ where }; let target = &cx.tcx().sess.target.target; + let target_env_gnu_like = matches!(&target.target_env[..], "gnu" | "musl"); let win_x64_gnu = target.target_os == "windows" && target.arch == "x86_64" && target.target_env == "gnu"; - let linux_s390x = - target.target_os == "linux" && target.arch == "s390x" && target.target_env == "gnu"; - let linux_sparc64 = - target.target_os == "linux" && target.arch == "sparc64" && target.target_env == "gnu"; + let linux_s390x_gnu_like = + target.target_os == "linux" && target.arch == "s390x" && target_env_gnu_like; + let linux_sparc64_gnu_like = + target.target_os == "linux" && target.arch == "sparc64" && target_env_gnu_like; + let linux_powerpc_gnu_like = + target.target_os == "linux" && target.arch == "powerpc" && target_env_gnu_like; let rust_abi = match sig.abi { RustIntrinsic | PlatformIntrinsic | Rust | RustCall => true, _ => false, @@ -2617,9 +2620,14 @@ where if arg.layout.is_zst() { // For some forsaken reason, x86_64-pc-windows-gnu // doesn't ignore zero-sized struct arguments. - // The same is true for s390x-unknown-linux-gnu - // and sparc64-unknown-linux-gnu. - if is_return || rust_abi || (!win_x64_gnu && !linux_s390x && !linux_sparc64) { + // The same is true for {s390x,sparc64,powerpc}-unknown-linux-{gnu,musl}. + if is_return + || rust_abi + || (!win_x64_gnu + && !linux_s390x_gnu_like + && !linux_sparc64_gnu_like + && !linux_powerpc_gnu_like) + { arg.mode = PassMode::Ignore; } } |
