android13/external/ltp/testcases/kernel/syscalls/open_tree/open_tree01.c

75 lines
1.5 KiB
C

// SPDX-License-Identifier: GPL-2.0-or-later
/*
* Copyright (c) 2020 Viresh Kumar <viresh.kumar@linaro.org>
*
* Basic open_tree() test.
*/
#include "tst_test.h"
#include "lapi/fsmount.h"
#define MNTPOINT "mntpoint"
#define OT_MNTPOINT "ot_mntpoint"
#define TCASE_ENTRY(_flags) {.name = "Flag " #_flags, .flags = _flags}
static struct tcase {
char *name;
unsigned int flags;
} tcases[] = {
TCASE_ENTRY(OPEN_TREE_CLONE),
TCASE_ENTRY(OPEN_TREE_CLOEXEC)
};
static int dir_created;
static void cleanup(void)
{
if (dir_created)
SAFE_RMDIR(OT_MNTPOINT);
}
static void setup(void)
{
fsopen_supported_by_kernel();
SAFE_MKDIR(OT_MNTPOINT, 0777);
dir_created = 1;
}
static void run(unsigned int n)
{
struct tcase *tc = &tcases[n];
int otfd;
TEST(otfd = open_tree(AT_FDCWD, MNTPOINT, tc->flags | OPEN_TREE_CLONE));
if (otfd == -1) {
tst_res(TFAIL | TTERRNO, "open_tree() failed");
return;
}
TEST(move_mount(otfd, "", AT_FDCWD, OT_MNTPOINT,
MOVE_MOUNT_F_EMPTY_PATH));
SAFE_CLOSE(otfd);
if (TST_RET == -1) {
tst_res(TFAIL | TTERRNO, "move_mount() failed");
return;
}
if (tst_is_mounted_at_tmpdir(OT_MNTPOINT)) {
SAFE_UMOUNT(OT_MNTPOINT);
tst_res(TPASS, "%s: open_tree() passed", tc->name);
}
}
static struct tst_test test = {
.tcnt = ARRAY_SIZE(tcases),
.test = run,
.setup = setup,
.cleanup = cleanup,
.needs_root = 1,
.mount_device = 1,
.mntpoint = MNTPOINT,
.all_filesystems = 1,
.skip_filesystems = (const char *const []){"fuse", NULL},
};