diff --git a/clang/test/CodeGen/cheri/cap-table-abi-flags.S b/clang/test/CodeGen/cheri/cap-table-abi-flags.S index 72a0f199aece..866fae8ffddd 100644 --- a/clang/test/CodeGen/cheri/cap-table-abi-flags.S +++ b/clang/test/CodeGen/cheri/cap-table-abi-flags.S @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target # RUN: %cheri_purecap_clang -cheri-cap-table-abi=plt -c %s -o - -### 2>&1 | FileCheck %s -check-prefix CMDLINE # Preprocess first then run as (make sure both contain the cap-table-abi flag diff --git a/clang/test/CodeGen/cheri/cap-table-abi-flags.c b/clang/test/CodeGen/cheri/cap-table-abi-flags.c index b8daab35ae10..ef18f68d0dcd 100644 --- a/clang/test/CodeGen/cheri/cap-table-abi-flags.c +++ b/clang/test/CodeGen/cheri/cap-table-abi-flags.c @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // RUN: %cheri_purecap_clang -cheri-cap-table-abi=plt -c %s -o - | llvm-readobj --arch-specific - | FileCheck %s -check-prefix PLT // PLT: ISA Extension: CHERI purecap (PLT based) (0xC2) diff --git a/clang/test/CodeGen/cheri/cheri-inregs-param-info.c b/clang/test/CodeGen/cheri/cheri-inregs-param-info.c index 484281d97880..bc93432c48c5 100644 --- a/clang/test/CodeGen/cheri/cheri-inregs-param-info.c +++ b/clang/test/CodeGen/cheri/cheri-inregs-param-info.c @@ -1,4 +1,5 @@ // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --function-signature +// REQUIRES: mips-registered-target // RUN: %cheri_purecap_cc1 -emit-llvm -O2 %s -o - | FileCheck %s // RUN: %cheri_purecap_cc1 -S -O2 %s -o - | FileCheck %s --check-prefix ASM // This used to crash with an assertion: diff --git a/clang/test/CodeGen/cheri/stack-bounds-pass.c b/clang/test/CodeGen/cheri/stack-bounds-pass.c index 0b16adc68a1b..d13936b239a3 100644 --- a/clang/test/CodeGen/cheri/stack-bounds-pass.c +++ b/clang/test/CodeGen/cheri/stack-bounds-pass.c @@ -1,4 +1,5 @@ // REQUIRES: asserts +// REQUIRES: mips-registered-target // RUN: %cheri_purecap_clang -mcpu=cheri128 -cheri=128 -xc -O0 -fsanitize-address-use-after-scope -g0 %s -o %t.ll -c -S -emit-llvm -Xclang -disable-O0-optnone -Wno-array-bounds -Wno-return-stack-address // RUN: %cheri_purecap_opt -cheri-bound-allocas %t.ll -o /dev/null -S -cheri-stack-bounds-single-intrinsic-threshold=10 \ // RUN: -cheri-stack-bounds=if-needed -debug-only="cheri-bound-allocas" 2>&1 | FileCheck -check-prefix DBG %s diff --git a/clang/test/CodeGenCXX/cheri/csetbounds-stats-all.cpp b/clang/test/CodeGenCXX/cheri/csetbounds-stats-all.cpp index 8fd61b026000..b12e1c0fc94f 100644 --- a/clang/test/CodeGenCXX/cheri/csetbounds-stats-all.cpp +++ b/clang/test/CodeGenCXX/cheri/csetbounds-stats-all.cpp @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // RUN: rm -f %t-hybrid.csv %t-purecap.csv // RUN: %cheri128_purecap_cc1 %s -mllvm -cheri-cap-table-abi=pcrel -cheri-bounds=aggressive \ // RUN: -mllvm -collect-csetbounds-stats=csv -cheri-stats-file=%t-purecap.csv -S -o /dev/null -O1 @@ -42,7 +43,8 @@ void test_onstack_int_overaligned(struct Foo *s) { void test__stack_array(void) { char buf[333]; - do_stuff_with_buf(buf); // CSV-NEXT: 0,333,?,"{{.+}}/csetbounds-stats-all.cpp:45:21","Add subobject bounds","array decay for char[333]" + do_stuff_with_buf(buf); + // CSV-NEXT: 0,333,?,"{{.+}}/csetbounds-stats-all.cpp:[[@LINE-1]]:21","Add subobject bounds","array decay for char[333]" } void test_alloca(int n) { @@ -53,7 +55,7 @@ void test_alloca(int n) { void test_varlen_stack_array(int n) { char varlenbuf[n]; do_stuff_with_buf(varlenbuf); - // CSV-NEXT: 0,,?,"{{.+}}/csetbounds-stats-all.cpp:55:21","Add subobject bounds","array decay for char[n]" + // CSV-NEXT: 0,,?,"{{.+}}/csetbounds-stats-all.cpp:[[@LINE-1]]:21","Add subobject bounds","array decay for char[n]" } struct Foo global_foo; diff --git a/clang/test/CodeGenCXX/cheri/debug-info-return-register.cpp b/clang/test/CodeGenCXX/cheri/debug-info-return-register.cpp index 2963733fe092..629b5df466f1 100644 --- a/clang/test/CodeGenCXX/cheri/debug-info-return-register.cpp +++ b/clang/test/CodeGenCXX/cheri/debug-info-return-register.cpp @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // RUN: %cheri_purecap_cc1 %s -emit-obj -o - -fcxx-exceptions -fexceptions -debug-info-kind=standalone \ // RUN: | llvm-dwarfdump -debug-frame - | FileCheck %s -check-prefixes CHECK,DWARF4 // Also try assembling with integrated as and verify that the return and stack registers are correct diff --git a/clang/test/CodeGenCXX/cheri/frame_layout_floating_point.cpp b/clang/test/CodeGenCXX/cheri/frame_layout_floating_point.cpp deleted file mode 100644 index f1d6ed4efa0a..000000000000 --- a/clang/test/CodeGenCXX/cheri/frame_layout_floating_point.cpp +++ /dev/null @@ -1,17 +0,0 @@ -// RUN: %cheri_purecap_cc1 -mframe-pointer=all -target-cpu mips4 -msoft-float -mfloat-abi soft -target-linker-version 305 \ -// RUN: -std=c++11 -fdeprecated-macro -fcxx-exceptions -fexceptions -o - -O0 -S %s 2>&1 -template void c(b...) { - double k __attribute__((__aligned__(a))); -} -template void g() { - constexpr int a = 4096; - constexpr int h = 2048; - try { - c; - } catch (int) { - } -} -const bool i = true; -void j() { g; } diff --git a/clang/test/CodeGenCXX/cheri/frame_layout_hardfloat.cpp b/clang/test/CodeGenCXX/cheri/frame_layout_hardfloat.cpp deleted file mode 100644 index e1b6b4b6b70b..000000000000 --- a/clang/test/CodeGenCXX/cheri/frame_layout_hardfloat.cpp +++ /dev/null @@ -1,4 +0,0 @@ -// RUN: %cheri_purecap_cc1 -target-cpu mips4 -std=c++11 -fdeprecated-macro -fcxx-exceptions -fexceptions -o - -O0 -S %s -// REQUIRES: asserts - -void a(double) {} diff --git a/clang/test/Driver/cheri/bounds-mode.c b/clang/test/Driver/cheri/bounds-mode.c index 1b66a0ce8fa9..dc86af80426e 100644 --- a/clang/test/Driver/cheri/bounds-mode.c +++ b/clang/test/Driver/cheri/bounds-mode.c @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // Check that we accept all the values for -cheri-bounds= (CC1 option) // RUN: %cheri_purecap_cc1 -cheri-bounds=conservative -emit-llvm %s -o /dev/null diff --git a/clang/test/Driver/cheri/cheri-cc1as.S b/clang/test/Driver/cheri/cheri-cc1as.S index 08a7f5052666..02a542d5e1ce 100644 --- a/clang/test/Driver/cheri/cheri-cc1as.S +++ b/clang/test/Driver/cheri/cheri-cc1as.S @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // Check that the ABI is forwarded to the assembler // RUN: %plain_clang_cheri_triple_allowed -target cheri-unknown-freebsd -### -c %s -mabi=n64 2>&1 \ // RUN: | FileCheck -check-prefix=CHERI-ABI-N64 %s diff --git a/clang/test/Driver/cheri/cheri-fnopic.c b/clang/test/Driver/cheri/cheri-fnopic.c index 8500a350a027..4456a328b815 100644 --- a/clang/test/Driver/cheri/cheri-fnopic.c +++ b/clang/test/Driver/cheri/cheri-fnopic.c @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // RUN: %cheri_clang -### -target cheri-unknown-freebsd11 -cheri -mabi=purecap -fno-pic \ // RUN: -c %s 2>&1 | FileCheck --check-prefix=PURECAP_FNOPIC %s // RUN: %cheri_clang -c -### -target cheri-unknown-freebsd11 -cheri -mabi=purecap -fno-pic \ diff --git a/clang/test/Driver/cheri/purecap-triple-n64-abi.c b/clang/test/Driver/cheri/purecap-triple-n64-abi.c index 71d674946f52..9ffa3b92cdd3 100644 --- a/clang/test/Driver/cheri/purecap-triple-n64-abi.c +++ b/clang/test/Driver/cheri/purecap-triple-n64-abi.c @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // There was a bug where CheriBSD would invoke hybrid clang with a -purecap triple suffix. // This should result in an error instead of nonsense output (it broke the debug info by emitting C17 as the return register!) diff --git a/clang/test/Preprocessor/cheri-cap-sizes.c b/clang/test/Preprocessor/cheri-cap-sizes.c index 2bf52173fb9e..cdb300ee3d20 100644 --- a/clang/test/Preprocessor/cheri-cap-sizes.c +++ b/clang/test/Preprocessor/cheri-cap-sizes.c @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // CHERI triple without any flags should set 128 defines // RUN: %plain_clang_cheri_triple_allowed -target cheri-unknown-freebsd11 \ // RUN: -mabi=purecap -E -dM -xc /dev/null 2>&1 | FileCheck --check-prefixes=PURECAP,PURECAP-128,CHERI128 %s diff --git a/clang/test/Preprocessor/cheri-exceptions-defines.cpp b/clang/test/Preprocessor/cheri-exceptions-defines.cpp index fa87e44f22c9..16dfb307b494 100644 --- a/clang/test/Preprocessor/cheri-exceptions-defines.cpp +++ b/clang/test/Preprocessor/cheri-exceptions-defines.cpp @@ -1,3 +1,4 @@ +// REQUIRES: mips-registered-target // RUN: %clang -fgnuc-version=4.2.1 -x c++ -target cheri -mabi=purecap -fno-rtti -fno-exceptions -E -dM %s | FileCheck -check-prefixes=CHECK-CHERI-SANDBOX-NOEXCEPTIONS %s // RUN: %clang_cc1 -fgnuc-version=4.2.1 -x c++ -triple cheri -target-abi purecap -fno-rtti -E -dM %s | FileCheck -check-prefix=CHECK-CHERI-SANDBOX-NOEXCEPTIONS %s // CHECK-CHERI-SANDBOX-NOEXCEPTIONS-NOT: #define OBJC_ZEROCOST_EXCEPTIONS 1 diff --git a/lld/test/ELF/bss-start-common.s b/lld/test/ELF/bss-start-common.s index 3bf3d17936bc..94638a2836dc 100644 --- a/lld/test/ELF/bss-start-common.s +++ b/lld/test/ELF/bss-start-common.s @@ -1,4 +1,4 @@ -# REQUIRES: x86 +# REQUIRES: x86, mips # RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t # RUN: ld.lld %t -o %t2 # RUN: llvm-objdump -t --section-headers %t2 | FileCheck %s diff --git a/lld/test/ELF/cheri/__cap_relocs/cap-relocs-bsymbolic.s b/lld/test/ELF/cheri/__cap_relocs/cap-relocs-bsymbolic.s index 1b27dfeac528..91a7b5310d01 100644 --- a/lld/test/ELF/cheri/__cap_relocs/cap-relocs-bsymbolic.s +++ b/lld/test/ELF/cheri/__cap_relocs/cap-relocs-bsymbolic.s @@ -2,6 +2,7 @@ # All relocations should be load address plus offset and not preemptible! # This was a problem with __cap_relocs and was found building RTLD +// REQUIRES: mips // RUN: %cheri128_purecap_llvm-mc -filetype=obj -defsym=CHERI=1 %s -o %t-cheri.o // RUN: llvm-readobj -r %t-cheri.o | FileCheck %s --check-prefixes OBJ-RELOCS,CHERI-OBJ-RELOCS // RUN: llvm-mc -triple=mips64-unknown-freebsd -position-independent -filetype=obj %s -o %t-mips.o diff --git a/lld/test/ELF/cheri/__cap_relocs/cap-relocs-dynamic-tag.s b/lld/test/ELF/cheri/__cap_relocs/cap-relocs-dynamic-tag.s index b16d37e8aaf0..dd912e39c537 100644 --- a/lld/test/ELF/cheri/__cap_relocs/cap-relocs-dynamic-tag.s +++ b/lld/test/ELF/cheri/__cap_relocs/cap-relocs-dynamic-tag.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc %s -filetype=obj -o %t.o # RUN: ld.lld -z now -shared %t.o -o %t.so # RUN: llvm-readelf --program-headers --section-mapping %t.so | FileCheck %s -check-prefix SEGMENTS diff --git a/lld/test/ELF/cheri/__cap_relocs/capreloc-aether.s b/lld/test/ELF/cheri/__cap_relocs/capreloc-aether.s index e80908445df4..4e69a9d7d88a 100644 --- a/lld/test/ELF/cheri/__cap_relocs/capreloc-aether.s +++ b/lld/test/ELF/cheri/__cap_relocs/capreloc-aether.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc %s -filetype=obj -o %t.o # RUN: ld.lld -T %S/Inputs/capreloc-aether.script %t.o -o %t # RUN: llvm-readobj --cap-relocs %t | FileCheck %s diff --git a/lld/test/ELF/cheri/__cap_relocs/capreloc-local-function-pointer.c b/lld/test/ELF/cheri/__cap_relocs/capreloc-local-function-pointer.c index 7fb7c9b5478b..46f4e5e8e516 100644 --- a/lld/test/ELF/cheri/__cap_relocs/capreloc-local-function-pointer.c +++ b/lld/test/ELF/cheri/__cap_relocs/capreloc-local-function-pointer.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 -emit-obj -mllvm -cheri-cap-table-abi=pcrel %s -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck --check-prefix OBJ-CAPRELOCS %s diff --git a/lld/test/ELF/cheri/__cap_relocs/capreloc-preemptible.c b/lld/test/ELF/cheri/__cap_relocs/capreloc-preemptible.c index aa7d76699f97..e4f34bd046ef 100644 --- a/lld/test/ELF/cheri/__cap_relocs/capreloc-preemptible.c +++ b/lld/test/ELF/cheri/__cap_relocs/capreloc-preemptible.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_clang %s -c -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck --check-prefix READOBJ %s diff --git a/lld/test/ELF/cheri/__cap_relocs/capreloc-string-constant.c b/lld/test/ELF/cheri/__cap_relocs/capreloc-string-constant.c index f262ac8f6152..30095e4f9923 100644 --- a/lld/test/ELF/cheri/__cap_relocs/capreloc-string-constant.c +++ b/lld/test/ELF/cheri/__cap_relocs/capreloc-string-constant.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 %s -emit-obj -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck --check-prefix READOBJ %s diff --git a/lld/test/ELF/cheri/__cap_relocs/capreloc-undefined.c b/lld/test/ELF/cheri/__cap_relocs/capreloc-undefined.c index e2fb4e07e0f8..b8a8645a80b2 100644 --- a/lld/test/ELF/cheri/__cap_relocs/capreloc-undefined.c +++ b/lld/test/ELF/cheri/__cap_relocs/capreloc-undefined.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_clang %s -c -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck --check-prefix READOBJ %s diff --git a/lld/test/ELF/cheri/__cap_relocs/sort-cap-relocs.s b/lld/test/ELF/cheri/__cap_relocs/sort-cap-relocs.s index fe18488b53b5..4d1d4c4549a5 100644 --- a/lld/test/ELF/cheri/__cap_relocs/sort-cap-relocs.s +++ b/lld/test/ELF/cheri/__cap_relocs/sort-cap-relocs.s @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_purecap_llvm-mc -filetype=obj -defsym=FIRST=1 %s -o %t1.o // RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t2.o // RUN: echo "SECTIONS { \ diff --git a/lld/test/ELF/cheri/__cap_relocs/zutil.c b/lld/test/ELF/cheri/__cap_relocs/zutil.c index cfa444bfccda..f96b282eed20 100644 --- a/lld/test/ELF/cheri/__cap_relocs/zutil.c +++ b/lld/test/ELF/cheri/__cap_relocs/zutil.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // Check that when we use R_CHERI_CAPABILITY instead of legacy cap_relocs the zutil.c test works as expected (i.e. bounds on the strings) diff --git a/lld/test/ELF/cheri/abiversion.s b/lld/test/ELF/cheri/abiversion.s index 0e8db894b187..106ddfa77700 100644 --- a/lld/test/ELF/cheri/abiversion.s +++ b/lld/test/ELF/cheri/abiversion.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -pie %t.o -o %t.exe # RUN: llvm-readobj -h %t.exe | FileCheck %s diff --git a/lld/test/ELF/cheri/building-rtld.s b/lld/test/ELF/cheri/building-rtld.s index df92bf061392..0863045fc739 100644 --- a/lld/test/ELF/cheri/building-rtld.s +++ b/lld/test/ELF/cheri/building-rtld.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: not ld.lld -shared --building-freebsd-rtld %t.o -o /dev/null 2>&1 | FileCheck %s .text diff --git a/lld/test/ELF/cheri/cap-table-dynamic-tag.s b/lld/test/ELF/cheri/cap-table-dynamic-tag.s index 39a090c4ac1b..0b50e4238d9f 100644 --- a/lld/test/ELF/cheri/cap-table-dynamic-tag.s +++ b/lld/test/ELF/cheri/cap-table-dynamic-tag.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -z lazy -pie %t.o -o %t.exe # RUN: llvm-readelf --program-headers --section-mapping %t.exe | FileCheck %s -check-prefix LAZY-SEGMENTS diff --git a/lld/test/ELF/cheri/cap-table/abs-symbol-shared.s b/lld/test/ELF/cheri/cap-table/abs-symbol-shared.s index 132028861358..24889b9eed59 100644 --- a/lld/test/ELF/cheri/cap-table/abs-symbol-shared.s +++ b/lld/test/ELF/cheri/cap-table/abs-symbol-shared.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld --fatal-warnings -pie %t.o -o %t.exe # RUN: llvm-readobj --dyn-relocations %t.exe | FileCheck %s --check-prefix=INTERPOSABLE diff --git a/lld/test/ELF/cheri/cap-table/cap-table-broken-mips-output.c b/lld/test/ELF/cheri/cap-table/cap-table-broken-mips-output.c index 91cce29f2318..2960137423c2 100644 --- a/lld/test/ELF/cheri/cap-table/cap-table-broken-mips-output.c +++ b/lld/test/ELF/cheri/cap-table/cap-table-broken-mips-output.c @@ -3,6 +3,7 @@ // This previously caused the following error in llvm-objdump: index past the end of the symbol table // create a n64 output that doesn't have any cap-table entries +// REQUIRES: mips // RUN: %cheri_cc1 %s -emit-obj -x c -O3 -o %t.o // RUN: llvm-objdump -t %t.o | FileCheck --check-prefix OBJ %s // RUN: ld.lld %t.o -o %t.exe diff --git a/lld/test/ELF/cheri/cap-table/cap-table-global-init.c b/lld/test/ELF/cheri/cap-table/cap-table-global-init.c index ab88ed6b5b63..19683f001161 100644 --- a/lld/test/ELF/cheri/cap-table/cap-table-global-init.c +++ b/lld/test/ELF/cheri/cap-table/cap-table-global-init.c @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_purecap_cc1 -pedantic -Wextra %s -emit-obj -mllvm -cheri-cap-table-abi=plt -x c -O0 -o %t.o // RUN: ld.lld %t.o -o %t.exe // RUN: llvm-objdump -t %t.exe | FileCheck %s diff --git a/lld/test/ELF/cheri/cap-table/cap-table-init-relocs.s b/lld/test/ELF/cheri/cap-table/cap-table-init-relocs.s index 8cce6688265d..cfc01029021e 100644 --- a/lld/test/ELF/cheri/cap-table/cap-table-init-relocs.s +++ b/lld/test/ELF/cheri/cap-table/cap-table-init-relocs.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -z now -shared -o %t %t.o -preemptible-caprelocs=legacy --no-relative-cap-relocs -local-caprelocs=legacy # RUN: llvm-readobj -r %t | FileCheck %s --check-prefix LEGACY-BOTH-ELF-RELOCS diff --git a/lld/test/ELF/cheri/cap-table/cap-table-negative-reloc-offset.c b/lld/test/ELF/cheri/cap-table/cap-table-negative-reloc-offset.c index df17419034f2..0beac1cf4f22 100644 --- a/lld/test/ELF/cheri/cap-table/cap-table-negative-reloc-offset.c +++ b/lld/test/ELF/cheri/cap-table/cap-table-negative-reloc-offset.c @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_cc1 -emit-obj -O2 -target-abi purecap -mllvm -cheri-cap-table-abi=plt %s -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck --check-prefix RELOCATIONS %s // RUN: ld.lld -o %t.exe %t.o -verbose 2>&1 | FileCheck %s -check-prefix WARN diff --git a/lld/test/ELF/cheri/cap-table/cap-table-pointer.s b/lld/test/ELF/cheri/cap-table/cap-table-pointer.s index e56b40e0f737..b9ba6458af71 100644 --- a/lld/test/ELF/cheri/cap-table/cap-table-pointer.s +++ b/lld/test/ELF/cheri/cap-table/cap-table-pointer.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld --fatal-warnings -pie %t.o -o %t.exe # RUN: llvm-readobj --cap-relocs --cap-table --dyn-relocations --symbols %t.exe | %cheri_FileCheck %s diff --git a/lld/test/ELF/cheri/cap-table/capcall-reloc-against-data-symbol.s b/lld/test/ELF/cheri/cap-table/capcall-reloc-against-data-symbol.s index 0da8e42f96a4..b1330fb58605 100644 --- a/lld/test/ELF/cheri/cap-table/capcall-reloc-against-data-symbol.s +++ b/lld/test/ELF/cheri/cap-table/capcall-reloc-against-data-symbol.s @@ -8,7 +8,7 @@ # CheriBSD crt1.c will now trap during crt_init_globals() if this happens instead # of creating a writable capability for the text segment. - +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -defsym=BUILD_LIBCHERI=1 -o %t-libcheri.o # RUN: llvm-readobj -r %t.o | FileCheck %s --check-prefix RELOCS diff --git a/lld/test/ELF/cheri/cap-table/caprelocs-duplicate-symbol-names.s b/lld/test/ELF/cheri/cap-table/caprelocs-duplicate-symbol-names.s index b750e32bd1c7..20020fc6db86 100644 --- a/lld/test/ELF/cheri/cap-table/caprelocs-duplicate-symbol-names.s +++ b/lld/test/ELF/cheri/cap-table/caprelocs-duplicate-symbol-names.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc %s -defsym=FILE=1 -filetype=obj -o %t1.o # RUN: %cheri128_purecap_llvm-mc %s -defsym=FILE=2 -filetype=obj -o %t2.o # RUN: %cheri128_purecap_llvm-mc %s -defsym=FILE=3 -filetype=obj -o %t-duplicate.o diff --git a/lld/test/ELF/cheri/cap-table/experimental/per-file-table.c b/lld/test/ELF/cheri/cap-table/experimental/per-file-table.c index 7a91993695e6..2c84f0ae05ff 100644 --- a/lld/test/ELF/cheri/cap-table/experimental/per-file-table.c +++ b/lld/test/ELF/cheri/cap-table/experimental/per-file-table.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: mkdir -p %t // RUN: %cheri128_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -emit-obj -O2 -DFILE1 %s -o %t/file1.o diff --git a/lld/test/ELF/cheri/cap-table/experimental/per-function-table.c b/lld/test/ELF/cheri/cap-table/experimental/per-function-table.c index 72aeb42ff114..42ded0beff6f 100644 --- a/lld/test/ELF/cheri/cap-table/experimental/per-function-table.c +++ b/lld/test/ELF/cheri/cap-table/experimental/per-function-table.c @@ -1,5 +1,5 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri128_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -emit-obj -O2 %s -o %t.o // RUN: ld.lld -z now -shared -o %t.so %t.o -captable-scope=function -z captabledebug diff --git a/lld/test/ELF/cheri/cap-table/experimental/tls-xfail.s b/lld/test/ELF/cheri/cap-table/experimental/tls-xfail.s index 6f6d7e2641f2..3dc2172d7428 100644 --- a/lld/test/ELF/cheri/cap-table/experimental/tls-xfail.s +++ b/lld/test/ELF/cheri/cap-table/experimental/tls-xfail.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -shared -o %t.so %t.o -captable-scope=all # RUN: llvm-readobj -r --cap-table %t.so diff --git a/lld/test/ELF/cheri/cap-table/fnptr-vs-call.c b/lld/test/ELF/cheri/cap-table/fnptr-vs-call.c index 9e57e45dead7..e4e61c656cec 100644 --- a/lld/test/ELF/cheri/cap-table/fnptr-vs-call.c +++ b/lld/test/ELF/cheri/cap-table/fnptr-vs-call.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -DFNPTR1 -emit-obj -O2 %s -o %t-fnptr1.o // RUN: %cheri_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -DFNPTR2 -emit-obj -O2 %s -o %t-fnptr2.o diff --git a/lld/test/ELF/cheri/cap-table/global-capabilities.c b/lld/test/ELF/cheri/cap-table/global-capabilities.c index 5a2b23ae3591..42827d66c09d 100644 --- a/lld/test/ELF/cheri/cap-table/global-capabilities.c +++ b/lld/test/ELF/cheri/cap-table/global-capabilities.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri128_purecap_cc1 -mllvm -mxcaptable -emit-obj -O2 -mllvm -cheri-cap-table-abi=plt %s -o %t-128.o // RUN: llvm-readobj -r %t-128.o | FileCheck %s --check-prefix RELOCS diff --git a/lld/test/ELF/cheri/cap-table/incompatible-abis.s b/lld/test/ELF/cheri/cap-table/incompatible-abis.s index f100ed6d5889..a4540ab1139a 100644 --- a/lld/test/ELF/cheri/cap-table/incompatible-abis.s +++ b/lld/test/ELF/cheri/cap-table/incompatible-abis.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=pcrel -filetype=obj %s -o %t-pcrel.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=plt -filetype=obj %s -o %t-plt.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=fn-desc -filetype=obj %s -o %t-fn-desc.o diff --git a/lld/test/ELF/cheri/cap-table/interposing_table.c b/lld/test/ELF/cheri/cap-table/interposing_table.c index b849ddc3a0ea..f911fd4e42b8 100644 --- a/lld/test/ELF/cheri/cap-table/interposing_table.c +++ b/lld/test/ELF/cheri/cap-table/interposing_table.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_cc1 -emit-obj -O2 -cheri-size 256 -target-cpu cheri256 -target-feature +soft-float \ // RUN: -msoft-float -target-abi purecap -mllvm -cheri-cap-table-abi=plt %s -o %t.o // RUN: ld.lld %t.o %S/Inputs/interposing_table.o -o %t.exe diff --git a/lld/test/ELF/cheri/cap-table/jump-table-size.c b/lld/test/ELF/cheri/cap-table/jump-table-size.c index 297b3b6fca93..5ed6074b08ca 100644 --- a/lld/test/ELF/cheri/cap-table/jump-table-size.c +++ b/lld/test/ELF/cheri/cap-table/jump-table-size.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 -mllvm -mxcaptable -emit-obj -O2 -mllvm -cheri-cap-table-abi=plt %s -o %t.o // RUN: llvm-objdump -d -r -t %t.o | FileCheck %s --check-prefix OBJECT diff --git a/lld/test/ELF/cheri/cap-table/local-fn-ptr-in-plt-abi.c b/lld/test/ELF/cheri/cap-table/local-fn-ptr-in-plt-abi.c index 3f5fc841a0a5..8fd2e1c19b5b 100644 --- a/lld/test/ELF/cheri/cap-table/local-fn-ptr-in-plt-abi.c +++ b/lld/test/ELF/cheri/cap-table/local-fn-ptr-in-plt-abi.c @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -emit-obj -o %t.o %s // RUN: llvm-objdump -d -r %t.o | FileCheck %s --check-prefix DISAS // Should have a R_MIPS_CHERI_CAPTAB20 relocation against the function pointer and a R_MIPS_CHERI_CAPCALL20 against use_callback diff --git a/lld/test/ELF/cheri/cap-table/non-preemptible-fn-ptr-unique-plt-abi.c b/lld/test/ELF/cheri/cap-table/non-preemptible-fn-ptr-unique-plt-abi.c index e5fea8091e34..cb73f1f14866 100644 --- a/lld/test/ELF/cheri/cap-table/non-preemptible-fn-ptr-unique-plt-abi.c +++ b/lld/test/ELF/cheri/cap-table/non-preemptible-fn-ptr-unique-plt-abi.c @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_purecap_cc1 -mllvm -cheri-cap-table-abi=plt -emit-obj -o %t.o %s // RUN: llvm-objdump -d -r %t.o | FileCheck %s --check-prefix DISAS --implicit-check-not R_MIPS_CHERI // Should have a R_MIPS_CHERI_CAPTAB20 relocation against the function pointer and a R_MIPS_CHERI_CAPCALL20 against use_callback diff --git a/lld/test/ELF/cheri/cap-table/relaplt-link.c b/lld/test/ELF/cheri/cap-table/relaplt-link.c index 5b656a866078..ae52cf7d9d67 100644 --- a/lld/test/ELF/cheri/cap-table/relaplt-link.c +++ b/lld/test/ELF/cheri/cap-table/relaplt-link.c @@ -1,4 +1,4 @@ -// REQUIRES: clang, x86 +// REQUIRES: clang, x86, mips // Fix running llvm-strip on CheriABI binaries with a .rel.plt section. // Check that set sh_info correctly for .rel.plt since otherwise llvm-strip will // fail. Since all .rel.plt relocations will affect the captable sh_info should diff --git a/lld/test/ELF/cheri/cap-table/relocatable-output.c b/lld/test/ELF/cheri/cap-table/relocatable-output.c index bfde7ca20f42..de0219a0eebb 100644 --- a/lld/test/ELF/cheri/cap-table/relocatable-output.c +++ b/lld/test/ELF/cheri/cap-table/relocatable-output.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 -DFIRST -emit-obj -O2 -mllvm -cheri-cap-table-abi=plt %s -o %t1.o // RUN: %cheri_purecap_cc1 -DSECOND -emit-obj -O2 -mllvm -cheri-cap-table-abi=plt %s -o %t2.o diff --git a/lld/test/ELF/cheri/cap-table/simple-global-access.c b/lld/test/ELF/cheri/cap-table/simple-global-access.c index efead3be038c..c480de10b5cf 100644 --- a/lld/test/ELF/cheri/cap-table/simple-global-access.c +++ b/lld/test/ELF/cheri/cap-table/simple-global-access.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // FIXME: why is this not an assembly test... // RUN: %cheri128_purecap_cc1 -mllvm -mxcaptable -emit-obj -O0 -mllvm -cheri-cap-table-abi=plt %s -o %t.o diff --git a/lld/test/ELF/cheri/cap-table/unnamed-symbols.c b/lld/test/ELF/cheri/cap-table/unnamed-symbols.c index a93e5c0de863..89b990259efc 100644 --- a/lld/test/ELF/cheri/cap-table/unnamed-symbols.c +++ b/lld/test/ELF/cheri/cap-table/unnamed-symbols.c @@ -1,3 +1,4 @@ +// REQUIRES: mips // RUN: %cheri128_purecap_cc1 -DGET_NUMBER=1 -emit-obj -O0 -mllvm -cheri-cap-table-abi=plt %s -o %t-get_number.o // RUN: %cheri128_purecap_cc1 -DGET_ORDINAL=1 -emit-obj -O0 -mllvm -cheri-cap-table-abi=plt %s -o %t-get_ordinal.o // RUN: %cheri128_purecap_cc1 -DMAIN=1 -emit-obj -O0 -mllvm -cheri-cap-table-abi=plt %s -o %t-main.o diff --git a/lld/test/ELF/cheri/cap-table/weak-symbols-2.s b/lld/test/ELF/cheri/cap-table/weak-symbols-2.s index a6bd7a7c9ac7..5d56ec9e7c53 100644 --- a/lld/test/ELF/cheri/cap-table/weak-symbols-2.s +++ b/lld/test/ELF/cheri/cap-table/weak-symbols-2.s @@ -1,4 +1,5 @@ # Test that weak symbols defined by linker scripts are written correctly +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc -filetype=obj -defsym=MAIN_FILE=1 %s -o %t.o # RUN: ld.lld --fatal-warnings -o %t.exe %t.o diff --git a/lld/test/ELF/cheri/cap-table/weak-symbols.c b/lld/test/ELF/cheri/cap-table/weak-symbols.c index 30c5962377d7..760089a0960b 100644 --- a/lld/test/ELF/cheri/cap-table/weak-symbols.c +++ b/lld/test/ELF/cheri/cap-table/weak-symbols.c @@ -1,4 +1,4 @@ -// REQUIRES: clang +// REQUIRES: clang, mips // RUN: %cheri128_purecap_cc1 -emit-obj -O2 -mllvm -cheri-cap-table-abi=plt %s -o %t.o // RUNNOT: llvm-objdump -d -r %t.o | FileCheck %s --check-prefix OBJECT diff --git a/lld/test/ELF/cheri/capability-in-rodata.s b/lld/test/ELF/cheri/capability-in-rodata.s index 9e6b5abb678d..6eb3409f1fbe 100644 --- a/lld/test/ELF/cheri/capability-in-rodata.s +++ b/lld/test/ELF/cheri/capability-in-rodata.s @@ -3,6 +3,7 @@ # as dynamic binaries. Currently the kernel just gives us a read-write mapping to # work around this but we really should just make this an error +# REQUIRES: mips # RUN: %cheri_purecap_llvm-mc %s -filetype=obj -o %t.o # RUNNOT: llvm-readobj -r %t.o # RUN: not ld.lld -shared %t.o -o %t.so 2>&1 | FileCheck %s diff --git a/lld/test/ELF/cheri/captab-tls-relocations-assert.s b/lld/test/ELF/cheri/captab-tls-relocations-assert.s index cbe48404a6fd..5474a9462208 100644 --- a/lld/test/ELF/cheri/captab-tls-relocations-assert.s +++ b/lld/test/ELF/cheri/captab-tls-relocations-assert.s @@ -2,6 +2,7 @@ # more than 64 members and the fast path using a single 64-bit bitmask no longer works for those values # Check that we no longer trigger this assertion with R_* values >= 64 +# REQUIRES: mips # RUNNOT: %cheri_purecap_llvm-mc %s -filetype=asm -show-encoding -show-inst -show-inst-operands # RUN: %cheri_purecap_llvm-mc %s -filetype=obj -o %t.o # RUN: llvm-readobj -r %t.o | FileCheck %s diff --git a/lld/test/ELF/cheri/cheri-dynamic-flags.s b/lld/test/ELF/cheri/cheri-dynamic-flags.s index 696ce0108294..f3c1f29a68c2 100644 --- a/lld/test/ELF/cheri/cheri-dynamic-flags.s +++ b/lld/test/ELF/cheri/cheri-dynamic-flags.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=pcrel -filetype=obj %s -o %t-pcrel.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=plt -filetype=obj %s -o %t-plt.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=fn-desc -filetype=obj %s -o %t-fn-desc.o diff --git a/lld/test/ELF/cheri/cheri-elf-flags-err.s b/lld/test/ELF/cheri/cheri-elf-flags-err.s index 080565732a42..ab5f77996e9c 100644 --- a/lld/test/ELF/cheri/cheri-elf-flags-err.s +++ b/lld/test/ELF/cheri/cheri-elf-flags-err.s @@ -1,4 +1,5 @@ +# REQUIRES: mips # RUN: llvm-mc -triple=mips64-unknown-freebsd -mcpu=cheri256 -target-abi purecap -position-independent -filetype=obj %s -o %t-cheri256-main.o # RUN: llvm-mc -triple=mips64-unknown-freebsd -mcpu=cheri128 -target-abi purecap -position-independent -filetype=obj %s -o %t-cheri128-main.o # RUN: llvm-mc -triple=mips64-unknown-freebsd -mcpu=cheri256 -target-abi n64 -position-independent -filetype=obj %s -o %t-cheri256-hybrid-main.o diff --git a/lld/test/ELF/cheri/chericap-alignment.s b/lld/test/ELF/cheri/chericap-alignment.s index f9f2a6a6cdb1..2f589f272791 100644 --- a/lld/test/ELF/cheri/chericap-alignment.s +++ b/lld/test/ELF/cheri/chericap-alignment.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: llvm-mc -triple=mips64-unknown-freebsd -mcpu=cheri256 -target-abi purecap -position-independent -filetype=obj -defsym=FIRST=1 -o %t1.o %s # RUN: llvm-mc -triple=mips64-unknown-freebsd -mcpu=cheri256 -target-abi purecap -position-independent -filetype=obj -defsym=FIRST=0 -o %t2.o %s # RUN: ld.lld %t1.o %t2.o -shared -o %t.so diff --git a/lld/test/ELF/cheri/ctors-dtors-start.c b/lld/test/ELF/cheri/ctors-dtors-start.c index 3fedb9507a62..7d7608991256 100644 --- a/lld/test/ELF/cheri/ctors-dtors-start.c +++ b/lld/test/ELF/cheri/ctors-dtors-start.c @@ -1,3 +1,4 @@ +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 %s -emit-obj -o %t.o // RUN: ld.lld %t.o -static -o %t.exe --fatal-warnings // RUN: llvm-objdump -h -r -t --cap-relocs %t.exe | FileCheck --check-prefix WITH-CTORS %s diff --git a/lld/test/ELF/cheri/dyn-relocs-in-exe.s b/lld/test/ELF/cheri/dyn-relocs-in-exe.s index 7d70a81439c0..1ac4776371c6 100644 --- a/lld/test/ELF/cheri/dyn-relocs-in-exe.s +++ b/lld/test/ELF/cheri/dyn-relocs-in-exe.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc %s -filetype=obj -defsym=MAIN=1 -o %t.o # Linking with elf relocs should not work for static binaries diff --git a/lld/test/ELF/cheri/dynamic-cap-reloc.s b/lld/test/ELF/cheri/dynamic-cap-reloc.s index 890f50508dc4..f904a6dec7c9 100644 --- a/lld/test/ELF/cheri/dynamic-cap-reloc.s +++ b/lld/test/ELF/cheri/dynamic-cap-reloc.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc %s -filetype=obj -o %t.o # NOT: llvm-readobj -r %t.o # RUN: ld.lld -preemptible-caprelocs=elf -shared %t.o -o %t-new.so -verbose -verbose-cap-relocs --relative-cap-relocs diff --git a/lld/test/ELF/cheri/exception-table.cpp b/lld/test/ELF/cheri/exception-table.cpp index a604bb760052..2d450b3a8f51 100644 --- a/lld/test/ELF/cheri/exception-table.cpp +++ b/lld/test/ELF/cheri/exception-table.cpp @@ -1,3 +1,4 @@ +// REQUIRES: clang, mips // RUN: %cheri_purecap_cc1 -O2 -mframe-pointer=none -fcxx-exceptions -fexceptions %s -emit-obj -o %t.o // RUN: llvm-readobj -r %t.o | FileCheck %s --check-prefix=MIPS-OBJ-RELOCS // RUN: %riscv64_cheri_purecap_cc1 -O2 -mframe-pointer=none -fcxx-exceptions -fexceptions %s -emit-obj -o %t-riscv64.o diff --git a/lld/test/ELF/cheri/function-with-offset-reloc.s b/lld/test/ELF/cheri/function-with-offset-reloc.s index 243ea7a24101..2f425405c2eb 100644 --- a/lld/test/ELF/cheri/function-with-offset-reloc.s +++ b/lld/test/ELF/cheri/function-with-offset-reloc.s @@ -2,6 +2,7 @@ ## This may no longer work in the future since it's not ideal when using sentries ## and tightly bounded code capabilities. +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc %s -filetype=obj -o %t.o # RUN: %cheri128_purecap_llvm-mc %s -defsym=SHLIB=1 -filetype=obj -o %t-lib.o # RUN: ld.lld %t-lib.o -shared -o %t-lib.so diff --git a/lld/test/ELF/cheri/invalid-captab_rel-reloc.s b/lld/test/ELF/cheri/invalid-captab_rel-reloc.s index 596d1e062903..28b05aa13951 100644 --- a/lld/test/ELF/cheri/invalid-captab_rel-reloc.s +++ b/lld/test/ELF/cheri/invalid-captab_rel-reloc.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -pie %t.o -o %t.exe # RUsN: llvm-readobj --cap-relocs --dynamic-table %t.exe | FileCheck %s diff --git a/lld/test/ELF/cheri/load-_dynamic.s b/lld/test/ELF/cheri/load-_dynamic.s index c44d6dd98a04..86f586f109f3 100644 --- a/lld/test/ELF/cheri/load-_dynamic.s +++ b/lld/test/ELF/cheri/load-_dynamic.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld %t.o -o %t.exe # RUN: llvm-objdump -t -d -h -s --section=.data --section=.text %t.exe | FileCheck %s --check-prefix STATIC diff --git a/lld/test/ELF/cheri/mips-libcxxrt-crash-cfi.s b/lld/test/ELF/cheri/mips-libcxxrt-crash-cfi.s index 46ea4ac2869c..10e58975da7b 100644 --- a/lld/test/ELF/cheri/mips-libcxxrt-crash-cfi.s +++ b/lld/test/ELF/cheri/mips-libcxxrt-crash-cfi.s @@ -1,5 +1,5 @@ ## This used to crash ld.lld for CHERI MIPS -# REQUIRES: asserts +# REQUIRES: asserts, mips # RUN: llvm-mc -filetype=obj -triple=mips64-unknown-freebsd --position-independent %s -o %t.o # RUN: ld.lld --eh-frame-hdr --shared -z notext -o %t.so %t.o # RUN: llvm-mc -filetype=obj -triple=mips64-unknown-freebsd %s -o %t-nopic.o diff --git a/lld/test/ELF/cheri/mix-abis-shlib.s b/lld/test/ELF/cheri/mix-abis-shlib.s index ee10a0cdd06e..6bbe0e77d91b 100644 --- a/lld/test/ELF/cheri/mix-abis-shlib.s +++ b/lld/test/ELF/cheri/mix-abis-shlib.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=pcrel -filetype=obj %s -o %t-pcrel.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=plt -filetype=obj %s -o %t-plt.o # RUN: %cheri128_purecap_llvm-mc -cheri-cap-table-abi=fn-desc -filetype=obj %s -o %t-fn-desc.o diff --git a/lld/test/ELF/cheri/out-of-bounds-linker-script-symbol.s b/lld/test/ELF/cheri/out-of-bounds-linker-script-symbol.s index ffae48c7a931..e107b9fdd16b 100644 --- a/lld/test/ELF/cheri/out-of-bounds-linker-script-symbol.s +++ b/lld/test/ELF/cheri/out-of-bounds-linker-script-symbol.s @@ -12,6 +12,7 @@ # RUN: _TLS_Data_size = SIZEOF(.tdata); \ # RUN: }" > %t.ldscript +# REQUIRES: mips # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s -o %t.o # RUN: %cheri128_purecap_llvm-mc -filetype=obj %s --defsym=TDATA=1 -o %t-tdata.o diff --git a/lld/test/ELF/cheri/pcrel-cap-table.s b/lld/test/ELF/cheri/pcrel-cap-table.s index ce39df77a610..b8aa6a0c961a 100644 --- a/lld/test/ELF/cheri/pcrel-cap-table.s +++ b/lld/test/ELF/cheri/pcrel-cap-table.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: %cheri128_llvm-mc -filetype=obj %s -o %t.o # RUN: ld.lld -z now %t.o -o %t.exe # RUN: llvm-objdump --cap-relocs -t -d -h %t.exe | FileCheck %s diff --git a/lld/test/ELF/cheri/pthread-static-jump-table.c b/lld/test/ELF/cheri/pthread-static-jump-table.c index 961f56f3ee3c..16d8574a1990 100644 --- a/lld/test/ELF/cheri/pthread-static-jump-table.c +++ b/lld/test/ELF/cheri/pthread-static-jump-table.c @@ -1,3 +1,4 @@ +// REQUIRES: clang, mips // RUN: rm -rf %t // RUN: mkdir %t // RUN: %cheri_purecap_cc1 %s -emit-obj -o %t/libc-stubs.o -DLIBC_STUBS diff --git a/lld/test/ELF/cheri/relocation-with-offset.s b/lld/test/ELF/cheri/relocation-with-offset.s index 7ee99166e35a..5eac17731b38 100644 --- a/lld/test/ELF/cheri/relocation-with-offset.s +++ b/lld/test/ELF/cheri/relocation-with-offset.s @@ -1,3 +1,4 @@ +# REQUIRES: mips # RUN: llvm-mc -filetype=obj -triple=mips64-unknown-linux %s -o %t-linux.o # RUN: llvm-objdump --section=.data -s %t-linux.o | FileCheck --check-prefix DATA-RELA %s diff --git a/llvm/test/CodeGen/CHERI-Generic/byval-varargs.ll b/llvm/test/CodeGen/CHERI-Generic/byval-varargs.ll index 3b1d8dbc9ec4..ba484601094c 100644 --- a/llvm/test/CodeGen/CHERI-Generic/byval-varargs.ll +++ b/llvm/test/CodeGen/CHERI-Generic/byval-varargs.ll @@ -1,4 +1,5 @@ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --extra_scrub +; REQUIRES: mips-registered-target, riscv-registered-target ; Check that we can handle varargs functions with byval arguments ; First check that non-CHERI targets add a memcpy ; RUN: sed -e 's/addrspace(200)/addrspace(0)/g' -e 's/p200i8/p0i8/g' %s | llc -mtriple riscv64-unknown-freebsd -o - -relocation-model=pic | FileCheck %s --check-prefixes RV64 diff --git a/llvm/test/CodeGen/CHERI-Generic/regenerate-all.py b/llvm/test/CodeGen/CHERI-Generic/regenerate-all.py index 7c7c738ca16f..54e995065049 100755 --- a/llvm/test/CodeGen/CHERI-Generic/regenerate-all.py +++ b/llvm/test/CodeGen/CHERI-Generic/regenerate-all.py @@ -81,6 +81,9 @@ def __init__(self): parser = argparse.ArgumentParser() parser.add_argument("--llvm-bindir", type=Path, required=True) parser.add_argument("--verbose", action="store_true") + parser.add_argument("--arch", default='all', + choices=[a.name for a in ALL_ARCHITECTURES]+['all'], + help="Architecture for which to generate tests: defaults to 'all'") parser.add_argument("tests", default=[], nargs=argparse.ZERO_OR_MORE) self.args = parser.parse_args() print(self.args) @@ -230,6 +233,8 @@ def update_one_test(test_name: str, input_file: typing.BinaryIO, def main(): options = CmdArgs() architectures = ALL_ARCHITECTURES + if options.args.arch != 'all': + architectures = [arch for arch in architectures if arch.name == options.args.arch] # TODO: add command line flag to select subsets # TODO: add option to delete all files that don't exist in Inputs/ to handle renaming if options.args.tests: diff --git a/llvm/test/Transforms/CheriBoundAllocas/pg_lzcompress-stack-bounds-crash.ll b/llvm/test/Transforms/CheriBoundAllocas/pg_lzcompress-stack-bounds-crash.ll index 453b53456e09..29a1aed454b5 100644 --- a/llvm/test/Transforms/CheriBoundAllocas/pg_lzcompress-stack-bounds-crash.ll +++ b/llvm/test/Transforms/CheriBoundAllocas/pg_lzcompress-stack-bounds-crash.ll @@ -1,6 +1,6 @@ ; RUN: %cheri_purecap_opt -cheri-bound-allocas %s -o - -S -debug-only="cheri-bound-allocas" 2>&1 | %cheri_FileCheck %s -check-prefix DBG ; RUN: %riscv64_cheri_purecap_opt -cheri-bound-allocas %s -o - -S -debug-only="cheri-bound-allocas" 2>&1 | %cheri_FileCheck %s -check-prefix DBG -; REQUIRES: asserts +; REQUIRES: asserts,mips-registered-target,riscv-registered-target ; This crash was found compiling postgres (due to a missing depth limitation in CheriPurecapABI.cpp) target datalayout = "E-m:e-pf200:128:128:128:64-i8:8:32-i16:16:32-i64:64-n32:64-S128-A200-P200-G200" diff --git a/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass-load-store.ll b/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass-load-store.ll index 55cb165d59c4..71fd99920862 100644 --- a/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass-load-store.ll +++ b/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass-load-store.ll @@ -3,7 +3,7 @@ ; is a single trivially rematerizable instruction so it can freely move it around to avoid stack spills. ; we were moving the allocation of the register that is only used later to the beginning -; REQUIRES: asserts +; REQUIRES: asserts,mips-registered-target,riscv-registered-target ; RUN: %cheri_purecap_opt -cheri-bound-allocas %s -o - -S -cheri-stack-bounds=if-needed -debug-only=cheri-bound-allocas 2>%t.dbg | FileCheck %s ; RUN: FileCheck %s -input-file=%t.dbg --check-prefixes=DBG,DBG-TYPED ; RUN: %cheri_purecap_opt -opaque-pointers=1 -instsimplify -cheri-bound-allocas %s -o - -S -cheri-stack-bounds=if-needed -debug-only=cheri-bound-allocas 2>%t.dbg | FileCheck %s --check-prefix=OPAQUE diff --git a/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass.ll b/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass.ll index efae253910f9..c902c8d4e601 100644 --- a/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass.ll +++ b/llvm/test/Transforms/CheriBoundAllocas/stack-bounds-pass.ll @@ -3,7 +3,7 @@ ; is a single trivially rematerizable instruction so it can freely move it around to avoid stack spills. ; we were moving the allocation of the register that is only used later to the beginning -; REQUIRES: asserts +; REQUIRES: asserts,mips-registered-target,riscv-registered-target ; RUN: %cheri_purecap_opt -opaque-pointers=0 -cheri-bound-allocas %s -o - -S | FileCheck %s -check-prefix DEFAULT ; RUN: %cheri_purecap_opt -opaque-pointers=0 -cheri-bound-allocas %s -o - -S -cheri-stack-bounds-single-intrinsic-threshold=0 -cheri-stack-bounds=if-needed | FileCheck %s -check-prefix IF-NEEDED-SINGLE ; RUN: %cheri_purecap_opt -opaque-pointers=0 -cheri-bound-allocas %s -o - -S -cheri-stack-bounds-single-intrinsic-threshold=10 -cheri-stack-bounds=if-needed | FileCheck %s -check-prefix IF-NEEDED-PER-USE diff --git a/llvm/test/tools/llvm-objdump/Mips/lit.local.cfg b/llvm/test/tools/llvm-objdump/Mips/lit.local.cfg new file mode 100644 index 000000000000..7d12f7a9c564 --- /dev/null +++ b/llvm/test/tools/llvm-objdump/Mips/lit.local.cfg @@ -0,0 +1,2 @@ +if not 'Mips' in config.root.targets: + config.unsupported = True