summaryrefslogtreecommitdiff
path: root/library/std/src/sys/unix/stack_overflow.rs
diff options
context:
space:
mode:
authorPatrick Mooney <pmooney@pfmooney.com>2022-04-04 17:55:30 +0000
committerPatrick Mooney <pmooney@oxide.computer>2022-04-05 11:22:32 -0500
commit33fd73fedeb5cd61dbbb7562fd927c0b6994653a (patch)
treee3a4ae176e25ffb1c2642d79cd47ba9416f9588a /library/std/src/sys/unix/stack_overflow.rs
parent634770c0a7f8598164ab825cfe419cc8b03c36e5 (diff)
downloadrust-33fd73fedeb5cd61dbbb7562fd927c0b6994653a.tar.gz
Update libc to 0.2.121
With the updated libc, UNIX stack overflow handling in libstd can now use the common `si_addr` accessor function, rather than attempting to use a field from that name in `siginfo_t`. This simplifies the collection of the fault address, particularly on platforms where that data resides within a union in `siginfo_t`.
Diffstat (limited to 'library/std/src/sys/unix/stack_overflow.rs')
-rw-r--r--library/std/src/sys/unix/stack_overflow.rs18
1 files changed, 1 insertions, 17 deletions
diff --git a/library/std/src/sys/unix/stack_overflow.rs b/library/std/src/sys/unix/stack_overflow.rs
index 1e8d1137ac8..75a5c0f9279 100644
--- a/library/std/src/sys/unix/stack_overflow.rs
+++ b/library/std/src/sys/unix/stack_overflow.rs
@@ -54,22 +54,6 @@ mod imp {
use crate::sys::unix::os::page_size;
use crate::sys_common::thread_info;
- #[cfg(any(target_os = "linux", target_os = "android"))]
- unsafe fn siginfo_si_addr(info: *mut libc::siginfo_t) -> usize {
- #[repr(C)]
- struct siginfo_t {
- a: [libc::c_int; 3], // si_signo, si_errno, si_code
- si_addr: *mut libc::c_void,
- }
-
- (*(info as *const siginfo_t)).si_addr as usize
- }
-
- #[cfg(not(any(target_os = "linux", target_os = "android")))]
- unsafe fn siginfo_si_addr(info: *mut libc::siginfo_t) -> usize {
- (*info).si_addr as usize
- }
-
// Signal handler for the SIGSEGV and SIGBUS handlers. We've got guard pages
// (unmapped pages) at the end of every thread's stack, so if a thread ends
// up running into the guard page it'll trigger this handler. We want to
@@ -97,7 +81,7 @@ mod imp {
_data: *mut libc::c_void,
) {
let guard = thread_info::stack_guard().unwrap_or(0..0);
- let addr = siginfo_si_addr(info);
+ let addr = (*info).si_addr() as usize;
// If the faulting address is within the guard page, then we print a
// message saying so and abort.