From 6eeacd7dc7c2da55b7948364ac5da962a2ce097b Mon Sep 17 00:00:00 2001 From: Jessica Clarke Date: Sat, 16 Mar 2024 01:03:45 +0000 Subject: [PATCH] rtld-elf: Drop dlopen_nocheri tests There isn't a libbasic_nocheri to dlopen these days since lib64 is hybrid, with no non-CHERI equivalent, so these tests fail. Fixes: 699a0c9f79bf ("Purge the last remnants of bsd.cheri.mk") --- .../dlopen-hybrid/dlopen-hybrid.c | 13 --------- .../dlopen-purecap/dlopen-purecap.c | 27 ------------------- 2 files changed, 40 deletions(-) diff --git a/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-hybrid/dlopen-hybrid.c b/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-hybrid/dlopen-hybrid.c index d008fde38266..08d26d68b245 100644 --- a/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-hybrid/dlopen-hybrid.c +++ b/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-hybrid/dlopen-hybrid.c @@ -66,22 +66,9 @@ ATF_TC_BODY(dlopen_hybrid, tc) test_dlopen_success("libbasic_hybrid.so.0", "hybrid", true); } -ATF_TC(dlopen_nocheri); -ATF_TC_HEAD(dlopen_nocheri, tc) -{ - atf_tc_set_md_var(tc, "descr", - "Check that we can dlopen() a non-CHERI library from a hybrid binary"); -} -ATF_TC_BODY(dlopen_nocheri, tc) -{ - test_dlopen_success("libbasic_nocheri.so.0", "not CHERI", true); -} - - ATF_TP_ADD_TCS(tp) { ATF_TP_ADD_TC(tp, dlopen_purecap_fail); ATF_TP_ADD_TC(tp, dlopen_hybrid); - ATF_TP_ADD_TC(tp, dlopen_nocheri); return atf_no_error(); } diff --git a/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-purecap/dlopen-purecap.c b/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-purecap/dlopen-purecap.c index 8f89ae283e30..3c7b20665070 100644 --- a/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-purecap/dlopen-purecap.c +++ b/libexec/rtld-elf/tests/cheri/abi-mismatch/dlopen-purecap/dlopen-purecap.c @@ -67,36 +67,9 @@ ATF_TC_BODY(dlopen_hybrid_fail, tc) test_dlopen_failure("libbasic_hybrid.so.0", error_msg); } -ATF_TC(dlopen_nocheri_fail); -ATF_TC_HEAD(dlopen_nocheri_fail, tc) -{ - atf_tc_set_md_var(tc, "descr", - "Check that dlopen() of a non-CHERI library from a purecap binary fails"); -} -ATF_TC_BODY(dlopen_nocheri_fail, tc) -{ - char error_msg[PATH_MAX]; - const char* exedir = get_executable_dir(); - -#if defined(__riscv) || (__aarch64__) - /* - * RISC-V has no CHERI vs non-CHERI distinction in its flags (just like all - * extensions other than C, which influences linker relaxation). We - * therefore fall back on it not being purecap. - */ - snprintf(error_msg, sizeof(error_msg), - "%s/%s: cannot load %s/../%s since it is not CheriABI", - exedir, "dlopen-purecap", exedir, "libbasic_nocheri.so.0"); -#else -#error "Unknown architecture" -#endif - test_dlopen_failure("libbasic_nocheri.so.0", error_msg); -} - ATF_TP_ADD_TCS(tp) { ATF_TP_ADD_TC(tp, dlopen_purecap); ATF_TP_ADD_TC(tp, dlopen_hybrid_fail); - ATF_TP_ADD_TC(tp, dlopen_nocheri_fail); return atf_no_error(); }