Pablo Greco 2fb6d1
From eaf7ea1fc339e1ff348ed941ed2e8c4d66f3e458 Mon Sep 17 00:00:00 2001
Pablo Greco 2fb6d1
From: Josh Stone <jistone@redhat.com>
Pablo Greco 2fb6d1
Date: Thu, 18 Feb 2021 19:14:58 -0800
Pablo Greco 2fb6d1
Subject: [PATCH] Revert "Auto merge of #79547 - erikdesjardins:byval,
Pablo Greco 2fb6d1
 r=nagisa"
Pablo Greco 2fb6d1
Pablo Greco 2fb6d1
This reverts commit a094ff9590b83c8f94d898f92c2964a5803ded06, reversing
Pablo Greco 2fb6d1
changes made to d37afad0cc87bf709ad10c85319296ac53030f03.
Pablo Greco 2fb6d1
---
Pablo Greco 2fb6d1
 compiler/rustc_middle/src/ty/layout.rs               | 12 ++++++------
Pablo Greco 2fb6d1
 ...return-value-in-reg.rs => return-value-in-reg.rs} |  4 ++--
Pablo Greco 2fb6d1
 src/test/codegen/union-abi.rs                        | 11 +++--------
Pablo Greco 2fb6d1
 3 files changed, 11 insertions(+), 16 deletions(-)
Pablo Greco 2fb6d1
 rename src/test/codegen/{arg-return-value-in-reg.rs => return-value-in-reg.rs} (74%)
Pablo Greco 2fb6d1
Pablo Greco 2fb6d1
diff --git a/compiler/rustc_middle/src/ty/layout.rs b/compiler/rustc_middle/src/ty/layout.rs
Pablo Greco 2fb6d1
index b545b92c9252..545f6aee1a21 100644
Pablo Greco 2fb6d1
--- a/compiler/rustc_middle/src/ty/layout.rs
Pablo Greco 2fb6d1
+++ b/compiler/rustc_middle/src/ty/layout.rs
Pablo Greco 2fb6d1
@@ -2849,7 +2849,7 @@ fn adjust_for_abi(&mut self, cx: &C, abi: SpecAbi) {
Pablo Greco 2fb6d1
             || abi == SpecAbi::RustIntrinsic
Pablo Greco 2fb6d1
             || abi == SpecAbi::PlatformIntrinsic
Pablo Greco 2fb6d1
         {
Pablo Greco 2fb6d1
-            let fixup = |arg: &mut ArgAbi<'tcx, Ty<'tcx>>| {
Pablo Greco 2fb6d1
+            let fixup = |arg: &mut ArgAbi<'tcx, Ty<'tcx>>, is_ret: bool| {
Pablo Greco 2fb6d1
                 if arg.is_ignore() {
Pablo Greco 2fb6d1
                     return;
Pablo Greco 2fb6d1
                 }
Pablo Greco 2fb6d1
@@ -2887,9 +2887,9 @@ fn adjust_for_abi(&mut self, cx: &C, abi: SpecAbi) {
Pablo Greco 2fb6d1
                     _ => return,
Pablo Greco 2fb6d1
                 }
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
-                // Pass and return structures up to 2 pointers in size by value, matching `ScalarPair`.
Pablo Greco 2fb6d1
-                // LLVM will usually pass these in 2 registers, which is more efficient than by-ref.
Pablo Greco 2fb6d1
-                let max_by_val_size = Pointer.size(cx) * 2;
Pablo Greco 2fb6d1
+                // Return structures up to 2 pointers in size by value, matching `ScalarPair`. LLVM
Pablo Greco 2fb6d1
+                // will usually return these in 2 registers, which is more efficient than by-ref.
Pablo Greco 2fb6d1
+                let max_by_val_size = if is_ret { Pointer.size(cx) * 2 } else { Pointer.size(cx) };
Pablo Greco 2fb6d1
                 let size = arg.layout.size;
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
                 if arg.layout.is_unsized() || size > max_by_val_size {
Pablo Greco 2fb6d1
@@ -2901,9 +2901,9 @@ fn adjust_for_abi(&mut self, cx: &C, abi: SpecAbi) {
Pablo Greco 2fb6d1
                     arg.cast_to(Reg { kind: RegKind::Integer, size });
Pablo Greco 2fb6d1
                 }
Pablo Greco 2fb6d1
             };
Pablo Greco 2fb6d1
-            fixup(&mut self.ret);
Pablo Greco 2fb6d1
+            fixup(&mut self.ret, true);
Pablo Greco 2fb6d1
             for arg in &mut self.args {
Pablo Greco 2fb6d1
-                fixup(arg);
Pablo Greco 2fb6d1
+                fixup(arg, false);
Pablo Greco 2fb6d1
             }
Pablo Greco 2fb6d1
             return;
Pablo Greco 2fb6d1
         }
Pablo Greco 2fb6d1
diff --git a/src/test/codegen/arg-return-value-in-reg.rs b/src/test/codegen/return-value-in-reg.rs
Pablo Greco 2fb6d1
similarity index 74%
Pablo Greco 2fb6d1
rename from src/test/codegen/arg-return-value-in-reg.rs
Pablo Greco 2fb6d1
rename to src/test/codegen/return-value-in-reg.rs
Pablo Greco 2fb6d1
index a69291d47821..4bc0136c5e32 100644
Pablo Greco 2fb6d1
--- a/src/test/codegen/arg-return-value-in-reg.rs
Pablo Greco 2fb6d1
+++ b/src/test/codegen/return-value-in-reg.rs
Pablo Greco 2fb6d1
@@ -1,4 +1,4 @@
Pablo Greco 2fb6d1
-//! Check that types of up to 128 bits are passed and returned by-value instead of via pointer.
Pablo Greco 2fb6d1
+//! This test checks that types of up to 128 bits are returned by-value instead of via out-pointer.
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
 // compile-flags: -C no-prepopulate-passes -O
Pablo Greco 2fb6d1
 // only-x86_64
Pablo Greco 2fb6d1
@@ -11,7 +11,7 @@ pub struct S {
Pablo Greco 2fb6d1
     c: u32,
Pablo Greco 2fb6d1
 }
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
-// CHECK: define i128 @modify(i128{{( %0)?}})
Pablo Greco 2fb6d1
+// CHECK: define i128 @modify(%S* noalias nocapture dereferenceable(16) %s)
Pablo Greco 2fb6d1
 #[no_mangle]
Pablo Greco 2fb6d1
 pub fn modify(s: S) -> S {
Pablo Greco 2fb6d1
     S { a: s.a + s.a, b: s.b + s.b, c: s.c + s.c }
Pablo Greco 2fb6d1
diff --git a/src/test/codegen/union-abi.rs b/src/test/codegen/union-abi.rs
Pablo Greco 2fb6d1
index f282fd237054..afea01e9a2d0 100644
Pablo Greco 2fb6d1
--- a/src/test/codegen/union-abi.rs
Pablo Greco 2fb6d1
+++ b/src/test/codegen/union-abi.rs
Pablo Greco 2fb6d1
@@ -63,16 +63,11 @@ pub union UnionU128{a:u128}
Pablo Greco 2fb6d1
 #[no_mangle]
Pablo Greco 2fb6d1
 pub fn test_UnionU128(_: UnionU128) -> UnionU128 { loop {} }
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
-pub union UnionU128x2{a:(u128, u128)}
Pablo Greco 2fb6d1
-// CHECK: define void @test_UnionU128x2(i128 %_1.0, i128 %_1.1)
Pablo Greco 2fb6d1
-#[no_mangle]
Pablo Greco 2fb6d1
-pub fn test_UnionU128x2(_: UnionU128x2) { loop {} }
Pablo Greco 2fb6d1
-
Pablo Greco 2fb6d1
 #[repr(C)]
Pablo Greco 2fb6d1
-pub union CUnionU128x2{a:(u128, u128)}
Pablo Greco 2fb6d1
-// CHECK: define void @test_CUnionU128x2(%CUnionU128x2* {{.*}} %_1)
Pablo Greco 2fb6d1
+pub union CUnionU128{a:u128}
Pablo Greco 2fb6d1
+// CHECK: define void @test_CUnionU128(%CUnionU128* {{.*}} %_1)
Pablo Greco 2fb6d1
 #[no_mangle]
Pablo Greco 2fb6d1
-pub fn test_CUnionU128x2(_: CUnionU128x2) { loop {} }
Pablo Greco 2fb6d1
+pub fn test_CUnionU128(_: CUnionU128) { loop {} }
Pablo Greco 2fb6d1
 
Pablo Greco 2fb6d1
 pub union UnionBool { b:bool }
Pablo Greco 2fb6d1
 // CHECK: define zeroext i1 @test_UnionBool(i8 %b)
Pablo Greco 2fb6d1
-- 
Pablo Greco 2fb6d1
2.29.2
Pablo Greco 2fb6d1