diff options
| author | Ryan Levick <ryan.levick@gmail.com> | 2020-08-27 19:11:48 +0200 |
|---|---|---|
| committer | Ryan Levick <ryan.levick@gmail.com> | 2020-08-27 19:11:48 +0200 |
| commit | 970e7793bfefd3d93034869ef8672affa02fff24 (patch) | |
| tree | b2b717e314c2bfc7d6c987ba38f412d0a6ffbf5c /library/std/src/sys/windows/mod.rs | |
| parent | 6ead62235a50e43b08a103d403d6fbfbc2b48352 (diff) | |
| download | rust-970e7793bfefd3d93034869ef8672affa02fff24.tar.gz rust-970e7793bfefd3d93034869ef8672affa02fff24.zip | |
Add __fastfail for Windows on arm/aarch64
Diffstat (limited to 'library/std/src/sys/windows/mod.rs')
| -rw-r--r-- | library/std/src/sys/windows/mod.rs | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/library/std/src/sys/windows/mod.rs b/library/std/src/sys/windows/mod.rs index a0d5a7471d8..8fbd43ad5a5 100644 --- a/library/std/src/sys/windows/mod.rs +++ b/library/std/src/sys/windows/mod.rs @@ -306,10 +306,20 @@ pub fn dur2timeout(dur: Duration) -> c::DWORD { /// that function for more information on `__fastfail` #[allow(unreachable_code)] pub fn abort_internal() -> ! { - #[cfg(any(target_arch = "x86", target_arch = "x86_64"))] + const FAST_FAIL_FATAL_APP_EXIT: usize = 7; unsafe { - llvm_asm!("int $$0x29" :: "{ecx}"(7) ::: volatile); // 7 is FAST_FAIL_FATAL_APP_EXIT - crate::intrinsics::unreachable(); + cfg_if::cfg_if! { + if #[cfg(any(target_arch = "x86", target_arch = "x86_64"))] { + llvm_asm!("int $$0x29" :: "{ecx}"(FAST_FAIL_FATAL_APP_EXIT) ::: volatile); + crate::intrinsics::unreachable(); + } else if #[cfg(target_arch = "arm")] { + llvm_asm!(".inst 0xDEFB" :: "{r0}"(FAST_FAIL_FATAL_APP_EXIT) ::: volatile); + crate::intrinsics::unreachable(); + } else if #[cfg(target_arch = "aarch64")] { + llvm_asm!(".inst 0xF003" :: "{x0}"(FAST_FAIL_FATAL_APP_EXIT) ::: volatile); + crate::intrinsics::unreachable(); + } + } } crate::intrinsics::abort(); } |
