blob: 821a3b802a7d10befeeb3e85fba0c4b3b328eec2 [file] [log] [blame] [edit]
//@ revisions: paca pacg
//@ compile-flags: --crate-type=rlib --target=aarch64-unknown-linux-gnu
//@ needs-llvm-components: aarch64
//@[paca] compile-flags: -Ctarget-feature=+paca
//@[pacg] compile-flags: -Ctarget-feature=+pacg
//@ ignore-backends: gcc
//@ add-core-stubs
// FIXME(#147881): *disable* the features again for minicore as otherwise that will fail to build.
//@ core-stubs-compile-flags: -C target-feature=-pacg,-paca
#![feature(no_core)]
#![no_core]
extern crate minicore;
use minicore::*;
// Can't use `compile_error!` here without `core`/`std` but requiring these makes this test only
// work if you have libcore built in the sysroot for `aarch64-unknown-linux-gnu`. Can't run this
// test on any aarch64 platform because they all have different default available features - as
// written, this test depends on `aarch64-unknown-linux-gnu` having -paca,-pacg by default.
// Cause a multiple definition error instead.
fn foo() {}
// Enabling one of the tied features does not imply the other is enabled.
//
// With +paca, this multiple definition doesn't cause an error because +paca hasn't implied
// +pacg. With +pacg, the multiple definition error is emitted (and the tied feature error would
// be).
#[cfg(target_feature = "pacg")]
pub unsafe fn foo() {} //[pacg]~ ERROR the name `foo` is defined multiple times
//[paca]~? ERROR the target features paca, pacg must all be either enabled or disabled together