// SPDX-License-Identifier: GPL-2.0-or-later /* * Copyright (c) Crackerjack Project., 2007 * Ported from Crackerjack to LTP by Masatake YAMATO * Copyright (c) 2011 Cyril Hrubis * Copyright (c) 2017 Xiao Yang * Copyright (c) 2021 Xie Ziyao */ /*\ * [Description] * * Test io_setup invoked via syscall(2): * * - io_setup fails and returns EFAULT if ctxp is NULL. * - io_setup fails and returns EINVAL if ctxp is not initialized to 0. * - io_setup fails and returns EINVAL if nr_events is -1. * - io_setup fails and returns EAGAIN if nr_events exceeds the limit * of available events. * - io_setup succeeds if both nr_events and ctxp are valid. */ #include #include "config.h" #include "tst_test.h" #include "lapi/syscalls.h" static void run(void) { aio_context_t ctx; TST_EXP_FAIL(tst_syscall(__NR_io_setup, 1, NULL), EFAULT, "io_setup() when ctxp is NULL"); memset(&ctx, 1, sizeof(ctx)); TST_EXP_FAIL(tst_syscall(__NR_io_setup, 1, &ctx), EINVAL, "io_setup() when ctxp is not initialized to 0"); memset(&ctx, 0, sizeof(ctx)); TST_EXP_FAIL(tst_syscall(__NR_io_setup, -1, &ctx), EINVAL, "io_setup() when nr_events is -1"); unsigned aio_max = 0; if (!access("/proc/sys/fs/aio-max-nr", F_OK)) { SAFE_FILE_SCANF("/proc/sys/fs/aio-max-nr", "%u", &aio_max); TST_EXP_FAIL(tst_syscall(__NR_io_setup, aio_max + 1, &ctx), EAGAIN, "io_setup() when nr_events exceeds the limit"); } else { tst_res(TCONF, "the aio-max-nr file did not exist"); } TST_EXP_PASS(tst_syscall(__NR_io_setup, 1, &ctx), "io_setup() when both nr_events and ctxp are valid"); TST_EXP_PASS_SILENT(tst_syscall(__NR_io_destroy, ctx)); } static struct tst_test test = { .needs_kconfigs = (const char *[]) { "CONFIG_AIO=y", NULL }, .test_all = run, };