2022-08-14 04:37:03 -05:00
|
|
|
// needs-sanitizer-support
|
|
|
|
// needs-sanitizer-memory
|
|
|
|
//
|
2022-07-16 06:08:48 -05:00
|
|
|
// revisions: unoptimized optimized
|
|
|
|
//
|
|
|
|
// [optimized]compile-flags: -Z sanitizer=memory -Zsanitizer-memory-track-origins -O
|
|
|
|
// [unoptimized]compile-flags: -Z sanitizer=memory -Zsanitizer-memory-track-origins
|
2022-08-14 04:37:03 -05:00
|
|
|
//
|
|
|
|
// run-fail
|
|
|
|
// error-pattern: MemorySanitizer: use-of-uninitialized-value
|
|
|
|
// error-pattern: Uninitialized value was created by an allocation
|
2022-09-09 11:15:08 -05:00
|
|
|
// error-pattern: in the stack frame
|
2022-08-14 04:37:03 -05:00
|
|
|
//
|
|
|
|
// This test case intentionally limits the usage of the std,
|
|
|
|
// since it will be linked with an uninstrumented version of it.
|
|
|
|
|
|
|
|
#![feature(core_intrinsics)]
|
|
|
|
#![feature(start)]
|
|
|
|
|
|
|
|
use std::hint::black_box;
|
|
|
|
use std::mem::MaybeUninit;
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
#[no_mangle]
|
|
|
|
#[allow(invalid_value)]
|
|
|
|
fn random() -> char {
|
|
|
|
let r = unsafe { MaybeUninit::uninit().assume_init() };
|
|
|
|
// Avoid optimizing everything out.
|
|
|
|
black_box(r)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[start]
|
|
|
|
fn main(_: isize, _: *const *const u8) -> isize {
|
|
|
|
random();
|
|
|
|
0
|
|
|
|
}
|