11// check-pass
22#![ feature( rustc_attrs, unsized_fn_params, transparent_unions) ]
3- #![ allow( unused, improper_ctypes_definitions) ]
3+ #![ allow( unused, improper_ctypes_definitions, internal_features ) ]
44use std:: marker:: PhantomData ;
5+ use std:: mem:: ManuallyDrop ;
56use std:: num:: NonZeroI32 ;
67use std:: ptr:: NonNull ;
7- use std:: mem:: ManuallyDrop ;
8+
9+ // FIXME: a bunch of targets are broken in various ways.
10+ // Hence there are `cfg` throughout this test to disable parts of it on those targets.
11+ // sparc64: https://github.com/rust-lang/rust/issues/115336
12+ // mips64: https://github.com/rust-lang/rust/issues/115404
13+ // riscv64: https://github.com/rust-lang/rust/issues/115481
14+ // loongarch64: https://github.com/rust-lang/rust/issues/115509
15+ // arm, aarch64: https://github.com/rust-lang/rust/issues/115664
816
917macro_rules! assert_abi_compatible {
1018 ( $name: ident, $t1: ty, $t2: ty) => {
@@ -74,6 +82,7 @@ test_abi_compatible!(fn_fn, fn(), fn(i32) -> i32);
7482
7583// Some further guarantees we will likely (have to) make.
7684test_abi_compatible ! ( zst_unit, Zst , ( ) ) ;
85+ #[ cfg( not( any( target_arch = "sparc64" ) ) ) ]
7786test_abi_compatible ! ( zst_array, Zst , [ u8 ; 0 ] ) ;
7887test_abi_compatible ! ( nonzero_int, NonZeroI32 , i32 ) ;
7988
@@ -97,6 +106,7 @@ macro_rules! test_transparent {
97106 test_abi_compatible!( wrap1, $t, Wrapper1 <$t>) ;
98107 test_abi_compatible!( wrap2, $t, Wrapper2 <$t>) ;
99108 test_abi_compatible!( wrap3, $t, Wrapper3 <$t>) ;
109+ #[ cfg( not( any( target_arch = "riscv64" , target_arch = "loongarch64" ) ) ) ]
100110 test_abi_compatible!( wrap4, $t, WrapperUnion <$t>) ;
101111 }
102112 } ;
@@ -106,23 +116,39 @@ test_transparent!(simple, i32);
106116test_transparent ! ( reference, & ' static i32 ) ;
107117test_transparent ! ( zst, Zst ) ;
108118test_transparent ! ( unit, ( ) ) ;
109- test_transparent ! ( pair, ( i32 , f32 ) ) ; // mixing in some floats since they often get special treatment
110- test_transparent ! ( triple, ( i8 , i16 , f32 ) ) ; // chosen to fit into 64bit
111- test_transparent ! ( tuple, ( i32 , f32 , i64 , f64 ) ) ;
112- test_transparent ! ( empty_array, [ u32 ; 0 ] ) ;
113- test_transparent ! ( empty_1zst_array, [ u8 ; 0 ] ) ;
114- test_transparent ! ( small_array, [ i32 ; 2 ] ) ; // chosen to fit into 64bit
115- test_transparent ! ( large_array, [ i32 ; 16 ] ) ;
116119test_transparent ! ( enum_, Option <i32 >) ;
117120test_transparent ! ( enum_niched, Option <& ' static i32 >) ;
121+ #[ cfg( not( any( target_arch = "mips64" , target_arch = "sparc64" ) ) ) ]
122+ mod problematic_tuples1 {
123+ use super :: * ;
124+ // mixing in some floats since they often get special treatment
125+ test_transparent ! ( pair, ( i32 , f32 ) ) ;
126+ // chosen to fit into 64bit
127+ test_transparent ! ( triple, ( i8 , i16 , f32 ) ) ;
128+ // and also something that's larger than 2 pointers
129+ test_transparent ! ( tuple, ( i32 , f32 , i64 , f64 ) ) ;
130+ }
118131// Pure-float types that are not ScalarPair seem to be tricky.
119- // FIXME: <https://github.com/rust-lang/rust/issues/115664>
120- #[ cfg( not( any( target_arch = "arm" , target_arch = "aarch64" ) ) ) ]
121- mod tricky {
132+ #[ cfg( not( any(
133+ target_arch = "arm" ,
134+ target_arch = "aarch64" ,
135+ target_arch = "mips64" ,
136+ target_arch = "sparc64"
137+ ) ) ) ]
138+ mod problematic_tuples2 {
122139 use super :: * ;
123140 test_transparent ! ( triple_f32, ( f32 , f32 , f32 ) ) ;
124141 test_transparent ! ( triple_f64, ( f64 , f64 , f64 ) ) ;
125142}
143+ // Some targets have special rules for arrays.
144+ #[ cfg( not( any( target_arch = "mips64" , target_arch = "sparc64" ) ) ) ]
145+ mod arrays {
146+ use super :: * ;
147+ test_transparent ! ( empty_array, [ u32 ; 0 ] ) ;
148+ test_transparent ! ( empty_1zst_array, [ u8 ; 0 ] ) ;
149+ test_transparent ! ( small_array, [ i32 ; 2 ] ) ; // chosen to fit into 64bit
150+ test_transparent ! ( large_array, [ i32 ; 16 ] ) ;
151+ }
126152
127153// Some tests with unsized types (not all wrappers are compatible with that).
128154macro_rules! test_transparent_unsized {
@@ -137,9 +163,13 @@ macro_rules! test_transparent_unsized {
137163 } ;
138164}
139165
140- test_transparent_unsized ! ( str_, str ) ;
141- test_transparent_unsized ! ( slice, [ u8 ] ) ;
142- test_transparent_unsized ! ( dyn_trait, dyn std:: any:: Any ) ;
166+ #[ cfg( not( any( target_arch = "mips64" , target_arch = "sparc64" ) ) ) ]
167+ mod unsized_ {
168+ use super :: * ;
169+ test_transparent_unsized ! ( str_, str ) ;
170+ test_transparent_unsized ! ( slice, [ u8 ] ) ;
171+ test_transparent_unsized ! ( dyn_trait, dyn std:: any:: Any ) ;
172+ }
143173
144174// RFC 3391 <https://rust-lang.github.io/rfcs/3391-result_ffi_guarantees.html>.
145175macro_rules! test_nonnull {
0 commit comments