about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-11-05 20:06:13 +0000
committerbors <bors@rust-lang.org>2015-11-05 20:06:13 +0000
commit96c95f160fd23c0bb815cefc9f2228d677b7f34a (patch)
tree35f45f945adad44e1d672f356bcfa204f8630f7c
parent3a0409d29129d7128a55c93239d81a00d121a200 (diff)
parent3235b22ee38d159ab443785c806901a25682743c (diff)
downloadrust-96c95f160fd23c0bb815cefc9f2228d677b7f34a.tar.gz
rust-96c95f160fd23c0bb815cefc9f2228d677b7f34a.zip
Auto merge of #29583 - dotdash:mir_small_agg, r=nikomatsakis
Fix handling of small aggregate function arguments and assignments of temporaries to lvalues.
-rw-r--r--src/librustc_trans/trans/mir/mod.rs4
-rw-r--r--src/librustc_trans/trans/mir/operand.rs19
-rw-r--r--src/test/run-pass/mir_small_agg_arg.rs19
3 files changed, 26 insertions, 16 deletions
diff --git a/src/librustc_trans/trans/mir/mod.rs b/src/librustc_trans/trans/mir/mod.rs
index 3b018cc1321..75fb88ab5ee 100644
--- a/src/librustc_trans/trans/mir/mod.rs
+++ b/src/librustc_trans/trans/mir/mod.rs
@@ -169,7 +169,7 @@ fn arg_value_refs<'bcx, 'tcx>(bcx: Block<'bcx, 'tcx>,
                idx += 2;
                let lltemp = base::alloc_ty(bcx, arg_ty, &format!("arg{}", arg_index));
                build::Store(bcx, lldata, expr::get_dataptr(bcx, lltemp));
-               build::Store(bcx, llextra, expr::get_dataptr(bcx, lltemp));
+               build::Store(bcx, llextra, expr::get_meta(bcx, lltemp));
                lltemp
            } else {
                // otherwise, arg is passed by value, so make a
@@ -177,7 +177,7 @@ fn arg_value_refs<'bcx, 'tcx>(bcx: Block<'bcx, 'tcx>,
                let llarg = llvm::get_param(fcx.llfn, idx);
                idx += 1;
                let lltemp = base::alloc_ty(bcx, arg_ty, &format!("arg{}", arg_index));
-               build::Store(bcx, llarg, lltemp);
+               base::store_ty(bcx, llarg, lltemp, arg_ty);
                lltemp
            };
            LvalueRef::new(llval, LvalueTy::from_ty(arg_ty))
diff --git a/src/librustc_trans/trans/mir/operand.rs b/src/librustc_trans/trans/mir/operand.rs
index a0308032ac0..fb529d8975e 100644
--- a/src/librustc_trans/trans/mir/operand.rs
+++ b/src/librustc_trans/trans/mir/operand.rs
@@ -92,19 +92,10 @@ impl<'bcx, 'tcx> MirContext<'bcx, 'tcx> {
                bcx.val_to_string(lldest),
                operand);
 
-        match *operand {
-            mir::Operand::Consume(ref lvalue) => {
-                let tr_lvalue = self.trans_lvalue(bcx, lvalue);
-                let lvalue_ty = tr_lvalue.ty.to_ty(bcx.tcx());
-                debug!("trans_operand_into: tr_lvalue={} @ {:?}",
-                       bcx.val_to_string(tr_lvalue.llval),
-                       lvalue_ty);
-                base::memcpy_ty(bcx, lldest, tr_lvalue.llval, lvalue_ty);
-            }
-
-            mir::Operand::Constant(..) => {
-                unimplemented!()
-            }
-        }
+        let o = self.trans_operand(bcx, operand);
+        match datum::appropriate_rvalue_mode(bcx.ccx(), o.ty) {
+            datum::ByValue => base::store_ty(bcx, o.llval, lldest, o.ty),
+            datum::ByRef => base::memcpy_ty(bcx, lldest, o.llval, o.ty),
+        };
     }
 }
diff --git a/src/test/run-pass/mir_small_agg_arg.rs b/src/test/run-pass/mir_small_agg_arg.rs
new file mode 100644
index 00000000000..8a0cb046b7a
--- /dev/null
+++ b/src/test/run-pass/mir_small_agg_arg.rs
@@ -0,0 +1,19 @@
+// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+#![feature(rustc_attrs)]
+
+#[rustc_mir]
+fn foo((x, y): (i8, i8)) {
+}
+
+fn main() {
+    foo((0, 1));
+}