about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-10-15 00:14:17 +0000
committerbors <bors@rust-lang.org>2015-10-15 00:14:17 +0000
commiteafe106ef3dcf35b05edc2fb7c835ea83431fd34 (patch)
treed8bc39880722125515d0409ca2640b1c0aecb1de /src
parentd20fe128a3101b03a3e933625706c407804af1b7 (diff)
parent95721d3b136c1459f309cd107e43c4edc474c052 (diff)
downloadrust-eafe106ef3dcf35b05edc2fb7c835ea83431fd34.tar.gz
rust-eafe106ef3dcf35b05edc2fb7c835ea83431fd34.zip
Auto merge of #29012 - tari:issue-28676, r=luqmana
Fixes #28676.

There doesn't seem to be a good way to add a test for this, but I tested the repro in #28676 and confirmed it now yields the correct result.
Diffstat (limited to 'src')
-rw-r--r--src/librustc_trans/trans/cabi_x86_win64.rs2
-rw-r--r--src/rt/rust_test_helpers.c4
-rw-r--r--src/test/run-pass/issue-28676.rs40
3 files changed, 45 insertions, 1 deletions
diff --git a/src/librustc_trans/trans/cabi_x86_win64.rs b/src/librustc_trans/trans/cabi_x86_win64.rs
index 0a39150dbd3..120c8dc0384 100644
--- a/src/librustc_trans/trans/cabi_x86_win64.rs
+++ b/src/librustc_trans/trans/cabi_x86_win64.rs
@@ -46,7 +46,7 @@ pub fn compute_abi_info(ccx: &CrateContext,
                     2 => ArgType::direct(t, Some(Type::i16(ccx)), None, None),
                     4 => ArgType::direct(t, Some(Type::i32(ccx)), None, None),
                     8 => ArgType::direct(t, Some(Type::i64(ccx)), None, None),
-                    _ => ArgType::indirect(t, Some(Attribute::ByVal))
+                    _ => ArgType::indirect(t, None)
                 }
             }
             _ => {
diff --git a/src/rt/rust_test_helpers.c b/src/rt/rust_test_helpers.c
index 8824cef2a81..f7895d694c8 100644
--- a/src/rt/rust_test_helpers.c
+++ b/src/rt/rust_test_helpers.c
@@ -218,3 +218,7 @@ uint64_t get_y(struct S s) {
 uint64_t get_z(struct S s) {
     return s.z;
 }
+
+uint64_t get_c_many_params(void *a, void *b, void *c, void *d, struct quad f) {
+    return f.c;
+}
diff --git a/src/test/run-pass/issue-28676.rs b/src/test/run-pass/issue-28676.rs
new file mode 100644
index 00000000000..b8d43c392dd
--- /dev/null
+++ b/src/test/run-pass/issue-28676.rs
@@ -0,0 +1,40 @@
+// Copyright 2012-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.
+//
+
+#[derive(Copy, Clone)]
+pub struct Quad { a: u64, b: u64, c: u64, d: u64 }
+
+mod rustrt {
+    use super::Quad;
+
+    #[link(name = "rust_test_helpers")]
+    extern {
+        pub fn get_c_many_params(_: *const (), _: *const (),
+                                 _: *const (), _: *const (), f: Quad) -> u64;
+    }
+}
+
+fn test() {
+    unsafe {
+        let null = std::ptr::null();
+        let q = Quad {
+            a: 1,
+            b: 2,
+            c: 3,
+            d: 4
+        };
+        assert_eq!(rustrt::get_c_many_params(null, null, null, null, q), q.c);
+    }
+}
+
+pub fn main() {
+    test();
+}