minibsod, fix clippy warning (#1424)
This commit is contained in:
parent
0be4847cb7
commit
bc42880274
@ -620,6 +620,130 @@ fn write_crash<W: Write>(
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(any(target_os = "linux", target_os = "android"))]
|
||||||
|
fn write_minibsod<W: Write>(writer: &mut BufWriter<W>) -> Result<(), std::io::Error> {
|
||||||
|
match std::fs::read_to_string("/proc/self/maps") {
|
||||||
|
Ok(maps) => writer.write_all(maps.as_bytes())?,
|
||||||
|
Err(e) => writeln!(writer, "Couldn't load mappings: {e:?}")?,
|
||||||
|
};
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(target_os = "freebsd")]
|
||||||
|
fn write_minibsod<W: Write>(writer: &mut BufWriter<W>) -> Result<(), std::io::Error> {
|
||||||
|
let mut s: usize = 0;
|
||||||
|
let arr = &[libc::CTL_KERN, libc::KERN_PROC, libc::KERN_PROC_VMMAP, -1];
|
||||||
|
let mib = arr.as_ptr();
|
||||||
|
let miblen = arr.len() as u32;
|
||||||
|
if unsafe {
|
||||||
|
libc::sysctl(
|
||||||
|
mib,
|
||||||
|
miblen,
|
||||||
|
std::ptr::null_mut(),
|
||||||
|
&mut s,
|
||||||
|
std::ptr::null_mut(),
|
||||||
|
0,
|
||||||
|
)
|
||||||
|
} == 0
|
||||||
|
{
|
||||||
|
s = s * 4 / 3;
|
||||||
|
let mut buf: std::boxed::Box<[u8]> = vec![0; s].into_boxed_slice();
|
||||||
|
let bufptr = buf.as_mut_ptr() as *mut libc::c_void;
|
||||||
|
if unsafe { libc::sysctl(mib, miblen, bufptr, &mut s, std::ptr::null_mut(), 0) } == 0 {
|
||||||
|
let mut start = bufptr as usize;
|
||||||
|
let end = start + s;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
while start < end {
|
||||||
|
let entry = start as *mut u8 as *mut libc::kinfo_vmentry;
|
||||||
|
let sz = (*entry).kve_structsize;
|
||||||
|
if sz == 0 {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
let i = format!(
|
||||||
|
"{}-{} {:?}\n",
|
||||||
|
(*entry).kve_start,
|
||||||
|
(*entry).kve_end,
|
||||||
|
(*entry).kve_path
|
||||||
|
);
|
||||||
|
writer.write(&i.into_bytes())?;
|
||||||
|
|
||||||
|
start = start + sz as usize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return Err(std::io::Error::last_os_error());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return Err(std::io::Error::last_os_error());
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(target_os = "openbsd")]
|
||||||
|
fn write_minibsod<W: Write>(writer: &mut BufWriter<W>) -> Result<(), std::io::Error> {
|
||||||
|
let mut pentry = std::mem::MaybeUninit::<libc::kinfo_vmentry>::uninit();
|
||||||
|
let mut s = std::mem::size_of::<libc::kinfo_vmentry>();
|
||||||
|
let arr = &[libc::CTL_KERN, libc::KERN_PROC_VMMAP, unsafe {
|
||||||
|
libc::getpid()
|
||||||
|
}];
|
||||||
|
let mib = arr.as_ptr();
|
||||||
|
let miblen = arr.len() as u32;
|
||||||
|
unsafe { (*pentry.as_mut_ptr()).kve_start = 0 };
|
||||||
|
if unsafe {
|
||||||
|
libc::sysctl(
|
||||||
|
mib,
|
||||||
|
miblen,
|
||||||
|
pentry.as_mut_ptr() as *mut libc::c_void,
|
||||||
|
&mut s,
|
||||||
|
std::ptr::null_mut(),
|
||||||
|
0,
|
||||||
|
)
|
||||||
|
} == 0
|
||||||
|
{
|
||||||
|
let end: u64 = s as u64;
|
||||||
|
unsafe {
|
||||||
|
let mut entry = pentry.assume_init();
|
||||||
|
while libc::sysctl(
|
||||||
|
mib,
|
||||||
|
miblen,
|
||||||
|
&mut entry as *mut libc::kinfo_vmentry as *mut libc::c_void,
|
||||||
|
&mut s,
|
||||||
|
std::ptr::null_mut(),
|
||||||
|
0,
|
||||||
|
) == 0
|
||||||
|
{
|
||||||
|
if entry.kve_end == end {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// OpenBSD's vm mappings have no knowledge of their paths on disk
|
||||||
|
let i = format!("{}-{}\n", entry.kve_start, entry.kve_end);
|
||||||
|
writer.write(&i.into_bytes())?;
|
||||||
|
entry.kve_start = entry.kve_start + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return Err(std::io::Error::last_os_error());
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(any(
|
||||||
|
target_os = "freebsd",
|
||||||
|
target_os = "openbsd",
|
||||||
|
any(target_os = "linux", target_os = "android"),
|
||||||
|
)))]
|
||||||
|
fn write_minibsod<W: Write>(writer: &mut BufWriter<W>) -> Result<(), std::io::Error> {
|
||||||
|
// TODO for other platforms
|
||||||
|
// Note that for apple, types might not be entirely mapped in libc due to mach crate.
|
||||||
|
writeln!(writer, "{:━^100}", " / ")?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
/// Generates a mini-BSOD given a signal and context.
|
/// Generates a mini-BSOD given a signal and context.
|
||||||
#[cfg(unix)]
|
#[cfg(unix)]
|
||||||
#[allow(clippy::non_ascii_literal)]
|
#[allow(clippy::non_ascii_literal)]
|
||||||
@ -635,115 +759,8 @@ pub fn generate_minibsod<W: Write>(
|
|||||||
dump_registers(writer, ucontext)?;
|
dump_registers(writer, ucontext)?;
|
||||||
writeln!(writer, "{:━^100}", " BACKTRACE ")?;
|
writeln!(writer, "{:━^100}", " BACKTRACE ")?;
|
||||||
writeln!(writer, "{:?}", backtrace::Backtrace::new())?;
|
writeln!(writer, "{:?}", backtrace::Backtrace::new())?;
|
||||||
#[cfg(any(target_os = "linux", target_os = "android"))]
|
writeln!(writer, "{:━^100}", " MAPS ")?;
|
||||||
{
|
write_minibsod(writer)
|
||||||
writeln!(writer, "{:━^100}", " MAPS ")?;
|
|
||||||
|
|
||||||
match std::fs::read_to_string("/proc/self/maps") {
|
|
||||||
Ok(maps) => writer.write_all(maps.as_bytes())?,
|
|
||||||
Err(e) => writeln!(writer, "Couldn't load mappings: {e:?}")?,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_os = "freebsd")]
|
|
||||||
{
|
|
||||||
let mut s: usize = 0;
|
|
||||||
let arr = &[libc::CTL_KERN, libc::KERN_PROC, libc::KERN_PROC_VMMAP, -1];
|
|
||||||
let mib = arr.as_ptr();
|
|
||||||
let miblen = arr.len() as u32;
|
|
||||||
if unsafe {
|
|
||||||
libc::sysctl(
|
|
||||||
mib,
|
|
||||||
miblen,
|
|
||||||
std::ptr::null_mut(),
|
|
||||||
&mut s,
|
|
||||||
std::ptr::null_mut(),
|
|
||||||
0,
|
|
||||||
)
|
|
||||||
} == 0
|
|
||||||
{
|
|
||||||
s = s * 4 / 3;
|
|
||||||
let mut buf: std::boxed::Box<[u8]> = vec![0; s].into_boxed_slice();
|
|
||||||
let bufptr = buf.as_mut_ptr() as *mut libc::c_void;
|
|
||||||
if unsafe { libc::sysctl(mib, miblen, bufptr, &mut s, std::ptr::null_mut(), 0) } == 0 {
|
|
||||||
let mut start = bufptr as usize;
|
|
||||||
let end = start + s;
|
|
||||||
|
|
||||||
unsafe {
|
|
||||||
while start < end {
|
|
||||||
let entry = start as *mut u8 as *mut libc::kinfo_vmentry;
|
|
||||||
let sz = (*entry).kve_structsize;
|
|
||||||
if sz == 0 {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
let i = format!(
|
|
||||||
"{}-{} {:?}\n",
|
|
||||||
(*entry).kve_start,
|
|
||||||
(*entry).kve_end,
|
|
||||||
(*entry).kve_path
|
|
||||||
);
|
|
||||||
writer.write(&i.into_bytes())?;
|
|
||||||
|
|
||||||
start = start + sz as usize;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return Err(std::io::Error::last_os_error());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return Err(std::io::Error::last_os_error());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_os = "openbsd")]
|
|
||||||
{
|
|
||||||
let mut pentry = std::mem::MaybeUninit::<libc::kinfo_vmentry>::uninit();
|
|
||||||
let mut s = std::mem::size_of::<libc::kinfo_vmentry>();
|
|
||||||
let arr = &[libc::CTL_KERN, libc::KERN_PROC_VMMAP, unsafe {
|
|
||||||
libc::getpid()
|
|
||||||
}];
|
|
||||||
let mib = arr.as_ptr();
|
|
||||||
let miblen = arr.len() as u32;
|
|
||||||
unsafe { (*pentry.as_mut_ptr()).kve_start = 0 };
|
|
||||||
if unsafe {
|
|
||||||
libc::sysctl(
|
|
||||||
mib,
|
|
||||||
miblen,
|
|
||||||
pentry.as_mut_ptr() as *mut libc::c_void,
|
|
||||||
&mut s,
|
|
||||||
std::ptr::null_mut(),
|
|
||||||
0,
|
|
||||||
)
|
|
||||||
} == 0
|
|
||||||
{
|
|
||||||
let end: u64 = s as u64;
|
|
||||||
unsafe {
|
|
||||||
let mut entry = pentry.assume_init();
|
|
||||||
while libc::sysctl(
|
|
||||||
mib,
|
|
||||||
miblen,
|
|
||||||
&mut entry as *mut libc::kinfo_vmentry as *mut libc::c_void,
|
|
||||||
&mut s,
|
|
||||||
std::ptr::null_mut(),
|
|
||||||
0,
|
|
||||||
) == 0
|
|
||||||
{
|
|
||||||
if entry.kve_end == end {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
// OpenBSD's vm mappings have no knowledge of their paths on disk
|
|
||||||
let i = format!("{}-{}\n", entry.kve_start, entry.kve_end);
|
|
||||||
writer.write(&i.into_bytes())?;
|
|
||||||
entry.kve_start = entry.kve_start + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return Err(std::io::Error::last_os_error());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user