about summary refs log tree commit diff
path: root/tests
diff options
context:
space:
mode:
authorBen Kimock <kimockb@gmail.com>2023-03-28 21:37:15 -0400
committerBen Kimock <kimockb@gmail.com>2023-03-28 21:37:15 -0400
commit9f17ede4acd28df8c0468984d53b965bfbaea8dc (patch)
tree1555185e06b42c0eee3804b6a5fcdbf22d1da867 /tests
parent67540ec950b9bb5919c3c51dcf9fd6b3d380b7dc (diff)
downloadrust-9f17ede4acd28df8c0468984d53b965bfbaea8dc.tar.gz
rust-9f17ede4acd28df8c0468984d53b965bfbaea8dc.zip
Raise an aborting signal without UB
Diffstat (limited to 'tests')
-rw-r--r--tests/ui/process/signal-exit-status.rs6
1 files changed, 4 insertions, 2 deletions
diff --git a/tests/ui/process/signal-exit-status.rs b/tests/ui/process/signal-exit-status.rs
index 9519ed7b4c7..0f05f916cb9 100644
--- a/tests/ui/process/signal-exit-status.rs
+++ b/tests/ui/process/signal-exit-status.rs
@@ -4,14 +4,16 @@
 // ignore-windows
 // ignore-fuchsia code returned as ZX_TASK_RETCODE_EXCEPTION_KILL, FIXME (#58590)
 
+#![feature(core_intrinsics)]
+
 use std::env;
 use std::process::Command;
 
 pub fn main() {
     let args: Vec<String> = env::args().collect();
     if args.len() >= 2 && args[1] == "signal" {
-        // Raise a segfault.
-        unsafe { *(1 as *mut isize) = 0; }
+        // Raise an aborting signal without UB
+        core::intrinsics::abort();
     } else {
         let status = Command::new(&args[0]).arg("signal").status().unwrap();
         assert!(status.code().is_none());