Rollup merge of #125672 - Lokathor:update-miri-result-ffi, r=RalfJung
Add more ABI test cases to miri (RFC 3391) Part of https://github.com/rust-lang/rust/issues/110503 cc `@RalfJung`
This commit is contained in:
commit
36cab1260d
2 changed files with 37 additions and 12 deletions
|
|
@ -83,12 +83,24 @@ fn main() {
|
|||
test_abi_compat(main as fn(), id::<i32> as fn(i32) -> i32);
|
||||
// - 1-ZST
|
||||
test_abi_compat((), [0u8; 0]);
|
||||
// - Guaranteed null-pointer-optimizations (RFC 3391).
|
||||
// - Guaranteed Option<X> null-pointer-optimizations (RFC 3391).
|
||||
test_abi_compat(&0u32 as *const u32, Some(&0u32));
|
||||
test_abi_compat(main as fn(), Some(main as fn()));
|
||||
test_abi_compat(0u32, Some(num::NonZero::new(1u32).unwrap()));
|
||||
test_abi_compat(&0u32 as *const u32, Some(Wrapper(&0u32)));
|
||||
test_abi_compat(0u32, Some(Wrapper(num::NonZero::new(1u32).unwrap())));
|
||||
test_abi_compat(0u32, Some(Wrapper(num::NonZeroU32::new(1u32).unwrap())));
|
||||
// - Guaranteed Result<X, ZST1> does the same as Option<X> (RFC 3391)
|
||||
test_abi_compat(&0u32 as *const u32, Result::<_, ()>::Ok(&0u32));
|
||||
test_abi_compat(main as fn(), Result::<_, ()>::Ok(main as fn()));
|
||||
test_abi_compat(0u32, Result::<_, ()>::Ok(num::NonZeroU32::new(1).unwrap()));
|
||||
test_abi_compat(&0u32 as *const u32, Result::<_, ()>::Ok(Wrapper(&0u32)));
|
||||
test_abi_compat(0u32, Result::<_, ()>::Ok(Wrapper(num::NonZeroU32::new(1).unwrap())));
|
||||
// - Guaranteed Result<ZST1, X> also does the same as Option<X> (RFC 3391)
|
||||
test_abi_compat(&0u32 as *const u32, Result::<(), _>::Err(&0u32));
|
||||
test_abi_compat(main as fn(), Result::<(), _>::Err(main as fn()));
|
||||
test_abi_compat(0u32, Result::<(), _>::Err(num::NonZeroU32::new(1).unwrap()));
|
||||
test_abi_compat(&0u32 as *const u32, Result::<(), _>::Err(Wrapper(&0u32)));
|
||||
test_abi_compat(0u32, Result::<(), _>::Err(Wrapper(num::NonZeroU32::new(1).unwrap())));
|
||||
|
||||
// These must work for *any* type, since we guarantee that `repr(transparent)` is ABI-compatible
|
||||
// with the wrapped field.
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue