2022-07-08 16:08:32 +00:00
|
|
|
//@normalize-stderr-test: "::<.*>" -> ""
|
2019-12-02 21:15:58 -05:00
|
|
|
|
2022-06-20 15:30:34 -07:00
|
|
|
#[inline(never)]
|
|
|
|
fn func_a() -> Box<[*mut ()]> {
|
|
|
|
func_b::<u8>()
|
|
|
|
}
|
|
|
|
#[inline(never)]
|
|
|
|
fn func_b<T>() -> Box<[*mut ()]> {
|
|
|
|
func_c()
|
|
|
|
}
|
2020-10-05 17:29:55 -04:00
|
|
|
|
|
|
|
macro_rules! invoke_func_d {
|
2022-06-20 15:30:34 -07:00
|
|
|
() => {
|
|
|
|
func_d()
|
|
|
|
};
|
2020-10-05 17:29:55 -04:00
|
|
|
}
|
|
|
|
|
2022-06-20 15:30:34 -07:00
|
|
|
#[inline(never)]
|
|
|
|
fn func_c() -> Box<[*mut ()]> {
|
|
|
|
invoke_func_d!()
|
|
|
|
}
|
|
|
|
#[inline(never)]
|
|
|
|
fn func_d() -> Box<[*mut ()]> {
|
|
|
|
unsafe {
|
|
|
|
let count = miri_backtrace_size(0);
|
|
|
|
let mut buf = vec![std::ptr::null_mut(); count];
|
|
|
|
miri_get_backtrace(1, buf.as_mut_ptr());
|
|
|
|
buf.into()
|
|
|
|
}
|
|
|
|
}
|
2020-09-24 15:05:50 -04:00
|
|
|
|
2019-12-02 21:15:58 -05:00
|
|
|
fn main() {
|
2020-09-24 15:05:50 -04:00
|
|
|
let mut seen_main = false;
|
|
|
|
let frames = func_a();
|
2019-12-02 21:15:58 -05:00
|
|
|
for frame in frames.into_iter() {
|
2022-02-24 22:11:20 -08:00
|
|
|
let miri_frame = unsafe { miri_resolve_frame(*frame, 1) };
|
|
|
|
|
|
|
|
let mut name = vec![0; miri_frame.name_len];
|
|
|
|
let mut filename = vec![0; miri_frame.filename_len];
|
|
|
|
|
|
|
|
unsafe {
|
|
|
|
miri_resolve_frame_names(*frame, 0, name.as_mut_ptr(), filename.as_mut_ptr());
|
|
|
|
}
|
2022-04-30 10:40:35 -07:00
|
|
|
|
2022-02-24 22:11:20 -08:00
|
|
|
let name = String::from_utf8(name).unwrap();
|
|
|
|
let filename = String::from_utf8(filename).unwrap();
|
2020-09-24 15:05:50 -04:00
|
|
|
|
2020-10-10 13:07:57 -04:00
|
|
|
if name == "func_a" {
|
|
|
|
assert_eq!(func_a as *mut (), miri_frame.fn_ptr);
|
|
|
|
}
|
|
|
|
|
2020-09-24 15:05:50 -04:00
|
|
|
// Print every frame to stderr.
|
|
|
|
let out = format!("{}:{}:{} ({})", filename, miri_frame.lineno, miri_frame.colno, name);
|
|
|
|
eprintln!("{}", out);
|
|
|
|
// Print the 'main' frame (and everything before it) to stdout, skipping
|
|
|
|
// the printing of internal (and possibly fragile) libstd frames.
|
|
|
|
if !seen_main {
|
|
|
|
println!("{}", out);
|
|
|
|
seen_main = name == "main";
|
|
|
|
}
|
2019-12-02 21:15:58 -05:00
|
|
|
}
|
|
|
|
}
|
2020-10-10 13:07:57 -04:00
|
|
|
|
|
|
|
// This goes at the bottom of the file so that we can change it
|
|
|
|
// without disturbing line numbers of the functions in the backtrace.
|
|
|
|
|
|
|
|
extern "Rust" {
|
2022-02-24 22:11:20 -08:00
|
|
|
fn miri_backtrace_size(flags: u64) -> usize;
|
|
|
|
fn miri_get_backtrace(flags: u64, buf: *mut *mut ());
|
2020-10-10 13:07:57 -04:00
|
|
|
fn miri_resolve_frame(ptr: *mut (), flags: u64) -> MiriFrame;
|
2022-02-24 22:11:20 -08:00
|
|
|
fn miri_resolve_frame_names(ptr: *mut (), flags: u64, name_buf: *mut u8, filename_buf: *mut u8);
|
2020-10-10 13:07:57 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
#[repr(C)]
|
|
|
|
struct MiriFrame {
|
2022-02-24 22:11:20 -08:00
|
|
|
name_len: usize,
|
|
|
|
filename_len: usize,
|
2020-10-10 13:07:57 -04:00
|
|
|
lineno: u32,
|
|
|
|
colno: u32,
|
|
|
|
fn_ptr: *mut (),
|
2022-04-30 10:40:35 -07:00
|
|
|
}
|