about summary refs log tree commit diff
path: root/tests/ui/sanitizer/memory-eager.rs
blob: 709299f87d49fde2491e479fce2a153adf1d1afd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//@ needs-sanitizer-support
//@ needs-sanitizer-memory
//
//@ revisions: unoptimized optimized
//
//@ [optimized]compile-flags: -Z sanitizer=memory -Zsanitizer-memory-track-origins -O
//@ [unoptimized]compile-flags: -Z sanitizer=memory -Zsanitizer-memory-track-origins
//
//@ run-fail
//@ error-pattern: MemorySanitizer: use-of-uninitialized-value
//@ [optimized]error-pattern: Uninitialized value was created by an allocation
//@ [optimized]error-pattern: in the stack frame
//
// FIXME the unoptimized case actually has that text in the output too, per
// <https://github.com/rust-lang/rust/pull/138759#issuecomment-3037186707>
// but doesn't seem to be getting picked up for some reason. For now we don't
// check for that part, since it's still testing that memory sanitizer reported
// a use of an uninitialized value, which is the critical part.
//
// This test case intentionally limits the usage of the std,
// since it will be linked with an uninstrumented version of it.

#![feature(core_intrinsics)]
#![no_main]

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)
}

#[no_mangle]
extern "C" fn main(_argc: std::ffi::c_int, _argv: *const *const u8) -> std::ffi::c_int {
    random();
    0
}