summary refs log tree commit diff
path: root/tests/codegen-llvm/tied-features-strength.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/codegen-llvm/tied-features-strength.rs')
-rw-r--r--tests/codegen-llvm/tied-features-strength.rs34
1 files changed, 34 insertions, 0 deletions
diff --git a/tests/codegen-llvm/tied-features-strength.rs b/tests/codegen-llvm/tied-features-strength.rs
new file mode 100644
index 00000000000..81499c070d1
--- /dev/null
+++ b/tests/codegen-llvm/tied-features-strength.rs
@@ -0,0 +1,34 @@
+// ignore-tidy-linelength
+//@ add-core-stubs
+//@ revisions: ENABLE_SVE DISABLE_SVE DISABLE_NEON ENABLE_NEON
+//@ compile-flags: --crate-type=rlib --target=aarch64-unknown-linux-gnu
+//@ needs-llvm-components: aarch64
+
+// Rust made SVE require neon.
+//@ [ENABLE_SVE] compile-flags: -C target-feature=+sve -Copt-level=0
+// ENABLE_SVE: attributes #0
+// ENABLE_SVE-SAME: +neon
+// ENABLE_SVE-SAME: +sve
+
+// However, disabling SVE does not disable neon.
+//@ [DISABLE_SVE] compile-flags: -C target-feature=-sve -Copt-level=0
+// DISABLE_SVE: attributes #0
+// DISABLE_SVE-NOT: -neon
+// DISABLE_SVE-SAME: -sve
+
+// OTOH, neon fn `fp-armv8` are fully tied; toggling neon must toggle `fp-armv8` the same way.
+//@ [DISABLE_NEON] compile-flags: -C target-feature=-neon -Copt-level=0
+// DISABLE_NEON: attributes #0
+// DISABLE_NEON-SAME: -neon
+// DISABLE_NEON-SAME: -fp-armv8
+
+//@ [ENABLE_NEON] compile-flags: -C target-feature=+neon -Copt-level=0
+// ENABLE_NEON: attributes #0 = { {{.*}} "target-features"="{{((\+outline-atomics,?)|(\+v8a,?)|(\+fp-armv8,?)|(\+neon,?))*}}" }
+
+#![feature(no_core, lang_items)]
+#![no_core]
+
+extern crate minicore;
+use minicore::*;
+
+pub fn test() {}