cf6d6050f7
* The WASI targets deal with the `main` symbol a bit differently than native so some `codegen` and `assembly` tests have been ignored. * All `ignore-emscripten` directives have been updated to `ignore-wasm32` to be more clear that all wasm targets are ignored and it's not just Emscripten. * Most `ignore-wasm32-bare` directives are now gone. * Some ignore directives for wasm were switched to `needs-unwind` instead. * Many `ignore-wasm32*` directives are removed as the tests work with WASI as opposed to `wasm32-unknown-unknown`.
38 lines
1.1 KiB
Rust
38 lines
1.1 KiB
Rust
//@ run-pass
|
|
#![allow(dead_code)]
|
|
#![allow(improper_ctypes)]
|
|
|
|
#[link(name = "rust_test_helpers", kind = "static")]
|
|
extern "C" {
|
|
pub fn issue_97463_leak_uninit_data(a: u32, b: u32, c: u32) -> u16;
|
|
}
|
|
|
|
fn main() {
|
|
const C1: usize = 0x327b23c6;
|
|
const C2: usize = C1 & 0xFFFF;
|
|
|
|
let r1: usize = 0x0;
|
|
let r2: usize = C1;
|
|
let r3: usize = 0x0;
|
|
let value: u16 = unsafe { issue_97463_leak_uninit_data(r1 as u32, r2 as u32, r3 as u32) };
|
|
|
|
// NOTE: as an example of the sensitivity of this test to optimization choices,
|
|
// uncommenting this block of code makes the bug go away on pnkfelix's machine.
|
|
// (But observing via `dbg!` doesn't hide the bug. At least sometimes.)
|
|
/*
|
|
println!("{}", value);
|
|
println!("{}", value as usize);
|
|
println!("{}", usize::from(value));
|
|
println!("{}", (value as usize) & 0xFFFF);
|
|
*/
|
|
|
|
let d1 = value;
|
|
let d2 = value as usize;
|
|
let d3 = usize::from(value);
|
|
let d4 = (value as usize) & 0xFFFF;
|
|
|
|
let d = (&d1, &d2, &d3, &d4);
|
|
let d_ = (d1, d2, d3, d4);
|
|
|
|
assert_eq!(((&(C2 as u16), &C2, &C2, &C2), (C2 as u16, C2, C2, C2)), (d, d_));
|
|
}
|