unplugged-system/external/ltp/testcases/kernel/syscalls/io_setup/io_setup02.c

65 lines
1.9 KiB
C
Raw Normal View History

// SPDX-License-Identifier: GPL-2.0-or-later
/*
* Copyright (c) Crackerjack Project., 2007
* Ported from Crackerjack to LTP by Masatake YAMATO <yamato@redhat.com>
* Copyright (c) 2011 Cyril Hrubis <chrubis@suse.cz>
* Copyright (c) 2017 Xiao Yang <yangx.jy@cn.fujitsu.com>
* Copyright (c) 2021 Xie Ziyao <xieziyao@huawei.com>
*/
/*\
* [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 <linux/aio_abi.h>
#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,
};