selftests: vm: return Kselftest Skip code for skipped tests

When vm test is skipped because of unmet dependencies and/or unsupported
configuration, it exits with error which is treated as a fail by the
Kselftest framework. This leads to false negative result even when the
test could not be run.

Change it to return kselftest skip code when a test gets skipped to
clearly report that the test could not be run.

Kselftest framework SKIP code is 4 and the framework prints appropriate
messages to indicate that the test is skipped.
Signed-off-by: default avatarShuah Khan (Samsung OSG) <shuah@kernel.org>
Acked-by: default avatarMike Rapoport <rppt@linux.vnet.ibm.com>
Signed-off-by: default avatarShuah Khan (Samsung OSG) <shuah@kernel.org>
parent 68581446
...@@ -16,6 +16,8 @@ ...@@ -16,6 +16,8 @@
#include <unistd.h> #include <unistd.h>
#include <string.h> #include <string.h>
#include "../kselftest.h"
#define MAP_SIZE 1048576 #define MAP_SIZE 1048576
struct map_list { struct map_list {
...@@ -169,7 +171,7 @@ int main(int argc, char **argv) ...@@ -169,7 +171,7 @@ int main(int argc, char **argv)
printf("Either the sysctl compact_unevictable_allowed is not\n" printf("Either the sysctl compact_unevictable_allowed is not\n"
"set to 1 or couldn't read the proc file.\n" "set to 1 or couldn't read the proc file.\n"
"Skipping the test\n"); "Skipping the test\n");
return 0; return KSFT_SKIP;
} }
lim.rlim_cur = RLIM_INFINITY; lim.rlim_cur = RLIM_INFINITY;
......
...@@ -9,6 +9,8 @@ ...@@ -9,6 +9,8 @@
#include <stdbool.h> #include <stdbool.h>
#include "mlock2.h" #include "mlock2.h"
#include "../kselftest.h"
struct vm_boundaries { struct vm_boundaries {
unsigned long start; unsigned long start;
unsigned long end; unsigned long end;
...@@ -303,7 +305,7 @@ static int test_mlock_lock() ...@@ -303,7 +305,7 @@ static int test_mlock_lock()
if (mlock2_(map, 2 * page_size, 0)) { if (mlock2_(map, 2 * page_size, 0)) {
if (errno == ENOSYS) { if (errno == ENOSYS) {
printf("Cannot call new mlock family, skipping test\n"); printf("Cannot call new mlock family, skipping test\n");
_exit(0); _exit(KSFT_SKIP);
} }
perror("mlock2(0)"); perror("mlock2(0)");
goto unmap; goto unmap;
...@@ -412,7 +414,7 @@ static int test_mlock_onfault() ...@@ -412,7 +414,7 @@ static int test_mlock_onfault()
if (mlock2_(map, 2 * page_size, MLOCK_ONFAULT)) { if (mlock2_(map, 2 * page_size, MLOCK_ONFAULT)) {
if (errno == ENOSYS) { if (errno == ENOSYS) {
printf("Cannot call new mlock family, skipping test\n"); printf("Cannot call new mlock family, skipping test\n");
_exit(0); _exit(KSFT_SKIP);
} }
perror("mlock2(MLOCK_ONFAULT)"); perror("mlock2(MLOCK_ONFAULT)");
goto unmap; goto unmap;
...@@ -425,7 +427,7 @@ static int test_mlock_onfault() ...@@ -425,7 +427,7 @@ static int test_mlock_onfault()
if (munlock(map, 2 * page_size)) { if (munlock(map, 2 * page_size)) {
if (errno == ENOSYS) { if (errno == ENOSYS) {
printf("Cannot call new mlock family, skipping test\n"); printf("Cannot call new mlock family, skipping test\n");
_exit(0); _exit(KSFT_SKIP);
} }
perror("munlock()"); perror("munlock()");
goto unmap; goto unmap;
...@@ -457,7 +459,7 @@ static int test_lock_onfault_of_present() ...@@ -457,7 +459,7 @@ static int test_lock_onfault_of_present()
if (mlock2_(map, 2 * page_size, MLOCK_ONFAULT)) { if (mlock2_(map, 2 * page_size, MLOCK_ONFAULT)) {
if (errno == ENOSYS) { if (errno == ENOSYS) {
printf("Cannot call new mlock family, skipping test\n"); printf("Cannot call new mlock family, skipping test\n");
_exit(0); _exit(KSFT_SKIP);
} }
perror("mlock2(MLOCK_ONFAULT)"); perror("mlock2(MLOCK_ONFAULT)");
goto unmap; goto unmap;
...@@ -583,7 +585,7 @@ static int test_vma_management(bool call_mlock) ...@@ -583,7 +585,7 @@ static int test_vma_management(bool call_mlock)
if (call_mlock && mlock2_(map, 3 * page_size, MLOCK_ONFAULT)) { if (call_mlock && mlock2_(map, 3 * page_size, MLOCK_ONFAULT)) {
if (errno == ENOSYS) { if (errno == ENOSYS) {
printf("Cannot call new mlock family, skipping test\n"); printf("Cannot call new mlock family, skipping test\n");
_exit(0); _exit(KSFT_SKIP);
} }
perror("mlock(ONFAULT)\n"); perror("mlock(ONFAULT)\n");
goto out; goto out;
......
...@@ -2,6 +2,9 @@ ...@@ -2,6 +2,9 @@
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: GPL-2.0
#please run as root #please run as root
# Kselftest framework requirement - SKIP code is 4.
ksft_skip=4
mnt=./huge mnt=./huge
exitcode=0 exitcode=0
...@@ -36,7 +39,7 @@ if [ -n "$freepgs" ] && [ -n "$hpgsize_KB" ]; then ...@@ -36,7 +39,7 @@ if [ -n "$freepgs" ] && [ -n "$hpgsize_KB" ]; then
echo $(( $lackpgs + $nr_hugepgs )) > /proc/sys/vm/nr_hugepages echo $(( $lackpgs + $nr_hugepgs )) > /proc/sys/vm/nr_hugepages
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
echo "Please run this test as root" echo "Please run this test as root"
exit 1 exit $ksft_skip
fi fi
while read name size unit; do while read name size unit; do
if [ "$name" = "HugePages_Free:" ]; then if [ "$name" = "HugePages_Free:" ]; then
......
...@@ -69,6 +69,8 @@ ...@@ -69,6 +69,8 @@
#include <setjmp.h> #include <setjmp.h>
#include <stdbool.h> #include <stdbool.h>
#include "../kselftest.h"
#ifdef __NR_userfaultfd #ifdef __NR_userfaultfd
static unsigned long nr_cpus, nr_pages, nr_pages_per_cpu, page_size; static unsigned long nr_cpus, nr_pages, nr_pages_per_cpu, page_size;
...@@ -1322,7 +1324,7 @@ int main(int argc, char **argv) ...@@ -1322,7 +1324,7 @@ int main(int argc, char **argv)
int main(void) int main(void)
{ {
printf("skip: Skipping userfaultfd test (missing __NR_userfaultfd)\n"); printf("skip: Skipping userfaultfd test (missing __NR_userfaultfd)\n");
return 0; return KSFT_SKIP;
} }
#endif /* __NR_userfaultfd */ #endif /* __NR_userfaultfd */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment