Skip to content

Commit 2026453

Browse files
committed
Add specific target option for returning struct as an integer.
1 parent 34b45c1 commit 2026453

File tree

6 files changed

+10
-9
lines changed

6 files changed

+10
-9
lines changed

src/librustc_back/target/apple_base.rs

+1
Original file line numberDiff line numberDiff line change
@@ -46,6 +46,7 @@ pub fn opts() -> TargetOptions {
4646
pre_link_args: LinkArgs::new(),
4747
exe_allocation_crate: super::maybe_jemalloc(),
4848
has_elf_tls: version >= (10, 7),
49+
abi_return_struct_as_int: true,
4950
.. Default::default()
5051
}
5152
}

src/librustc_back/target/mod.rs

+5-6
Original file line numberDiff line numberDiff line change
@@ -343,9 +343,8 @@ pub struct TargetOptions {
343343
pub staticlib_suffix: String,
344344
/// OS family to use for conditional compilation. Valid options: "unix", "windows".
345345
pub target_family: Option<String>,
346-
/// Whether the target toolchain is like OpenBSD's.
347-
/// Only useful for compiling against OpenBSD, for configuring abi when returning a struct.
348-
pub is_like_openbsd: bool,
346+
/// Whether the target toolchain's ABI supports returning small structs as an integer.
347+
pub abi_return_struct_as_int: bool,
349348
/// Whether the target toolchain is like macOS's. Only useful for compiling against iOS/macOS,
350349
/// in particular running dsymutil and some other stuff like `-dead_strip`. Defaults to false.
351350
pub is_like_osx: bool,
@@ -501,7 +500,7 @@ impl Default for TargetOptions {
501500
staticlib_prefix: "lib".to_string(),
502501
staticlib_suffix: ".a".to_string(),
503502
target_family: None,
504-
is_like_openbsd: false,
503+
abi_return_struct_as_int: false,
505504
is_like_osx: false,
506505
is_like_solaris: false,
507506
is_like_windows: false,
@@ -756,7 +755,7 @@ impl Target {
756755
key!(staticlib_prefix);
757756
key!(staticlib_suffix);
758757
key!(target_family, optional);
759-
key!(is_like_openbsd, bool);
758+
key!(abi_return_struct_as_int, bool);
760759
key!(is_like_osx, bool);
761760
key!(is_like_solaris, bool);
762761
key!(is_like_windows, bool);
@@ -954,7 +953,7 @@ impl ToJson for Target {
954953
target_option_val!(staticlib_prefix);
955954
target_option_val!(staticlib_suffix);
956955
target_option_val!(target_family);
957-
target_option_val!(is_like_openbsd);
956+
target_option_val!(abi_return_struct_as_int);
958957
target_option_val!(is_like_osx);
959958
target_option_val!(is_like_solaris);
960959
target_option_val!(is_like_windows);

src/librustc_back/target/openbsd_base.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ pub fn opts() -> TargetOptions {
3131
target_family: Some("unix".to_string()),
3232
linker_is_gnu: true,
3333
has_rpath: true,
34-
is_like_openbsd: true,
34+
abi_return_struct_as_int: true,
3535
pre_link_args: args,
3636
position_independent_executables: true,
3737
eliminate_frame_pointer: false, // FIXME 43575

src/librustc_back/target/windows_base.rs

+1
Original file line numberDiff line numberDiff line change
@@ -101,6 +101,7 @@ pub fn opts() -> TargetOptions {
101101
"rsend.o".to_string()
102102
],
103103
custom_unwind_resume: true,
104+
abi_return_struct_as_int: true,
104105

105106
.. Default::default()
106107
}

src/librustc_back/target/windows_msvc_base.rs

+1
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@ pub fn opts() -> TargetOptions {
3434
pre_link_args: args,
3535
crt_static_allows_dylibs: true,
3636
crt_static_respected: true,
37+
abi_return_struct_as_int: true,
3738

3839
.. Default::default()
3940
}

src/librustc_trans/cabi_x86.rs

+1-2
Original file line numberDiff line numberDiff line change
@@ -52,8 +52,7 @@ pub fn compute_abi_info<'a, 'tcx>(cx: &CodegenCx<'a, 'tcx>,
5252
// http://www.angelcode.com/dev/callconv/callconv.html
5353
// Clang's ABI handling is in lib/CodeGen/TargetInfo.cpp
5454
let t = &cx.sess().target.target;
55-
if t.options.is_like_osx || t.options.is_like_windows
56-
|| t.options.is_like_openbsd {
55+
if t.options.abi_return_struct_as_int {
5756
// According to Clang, everyone but MSVC returns single-element
5857
// float aggregates directly in a floating-point register.
5958
if !t.options.is_like_msvc && is_single_fp_element(cx, fty.ret.layout) {

0 commit comments

Comments
 (0)