2022-07-06 19:07:52 -07:00
|
|
|
//@ compile-flags: -C no-prepopulate-passes -Zcf-protection=full
|
|
|
|
//@ assembly-output: emit-asm
|
|
|
|
//@ needs-asm-support
|
|
|
|
//@ only-x86_64
|
|
|
|
|
|
|
|
#![crate_type = "lib"]
|
|
|
|
#![feature(naked_functions)]
|
2024-09-05 17:48:13 +02:00
|
|
|
use std::arch::naked_asm;
|
2022-07-06 19:07:52 -07:00
|
|
|
|
|
|
|
// The problem at hand: Rust has adopted a fairly strict meaning for "naked functions",
|
|
|
|
// meaning "no prologue whatsoever, no, really, not one instruction."
|
|
|
|
// Unfortunately, x86's control-flow enforcement, specifically indirect branch protection,
|
|
|
|
// works by using an instruction for each possible landing site,
|
|
|
|
// and LLVM implements this via making sure of that.
|
|
|
|
#[no_mangle]
|
|
|
|
#[naked]
|
|
|
|
pub unsafe extern "sysv64" fn will_halt() -> ! {
|
|
|
|
// CHECK-NOT: endbr{{32|64}}
|
|
|
|
// CHECK: hlt
|
2024-09-05 17:48:13 +02:00
|
|
|
naked_asm!("hlt")
|
2022-07-06 19:07:52 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// what about aarch64?
|
|
|
|
// "branch-protection"=false
|