72800d3b89
Except for `simd-intrinsic/`, which has a lot of files containing multiple types like `u8x64` which really are better when hand-formatted. There is a surprising amount of two-space indenting in this directory. Non-trivial changes: - `rustfmt::skip` needed in `debug-column.rs` to preserve meaning of the test. - `rustfmt::skip` used in a few places where hand-formatting read more nicely: `enum/enum-match.rs` - Line number adjustments needed for the expected output of `debug-column.rs` and `coroutine-debug.rs`.
31 lines
983 B
Rust
31 lines
983 B
Rust
// Verifies that KCFI operand bundles are omitted.
|
|
//
|
|
//@ revisions: aarch64 x86_64
|
|
//@ [aarch64] compile-flags: --target aarch64-unknown-none
|
|
//@ [aarch64] needs-llvm-components: aarch64
|
|
//@ [x86_64] compile-flags: --target x86_64-unknown-none
|
|
//@ [x86_64] needs-llvm-components:
|
|
//@ compile-flags: -Cno-prepopulate-passes -Zsanitizer=kcfi -Copt-level=0
|
|
|
|
#![crate_type = "lib"]
|
|
#![feature(no_core, no_sanitize, lang_items)]
|
|
#![no_core]
|
|
|
|
#[lang = "sized"]
|
|
trait Sized {}
|
|
#[lang = "copy"]
|
|
trait Copy {}
|
|
|
|
impl Copy for i32 {}
|
|
|
|
#[no_sanitize(kcfi)]
|
|
pub fn foo(f: fn(i32) -> i32, arg: i32) -> i32 {
|
|
// CHECK-LABEL: emit_kcfi_operand_bundle_attr_no_sanitize::foo
|
|
// CHECK: Function Attrs: {{.*}}
|
|
// CHECK-LABEL: define{{.*}}foo{{.*}}!{{<unknown kind #36>|kcfi_type}} !{{[0-9]+}}
|
|
// CHECK: start:
|
|
// CHECK-NOT: {{%.+}} = call {{(noundef )*}}i32 %f(i32 {{(noundef )*}}%arg){{.*}}[ "kcfi"(i32 {{[-0-9]+}}) ]
|
|
// CHECK: ret i32 {{%.+}}
|
|
f(arg)
|
|
}
|