mirror of
https://github.com/torvalds/linux.git
synced 2026-04-19 07:13:56 -04:00
Add tests for STATMOUNT_BY_FD flag, which adds support for passing a file descriptors to statmount(). The fd can also be on a "unmounted" mount (mount unmounted with MNT_DETACH), we also include tests for that. Co-developed-by: Andrei Vagin <avagin@gmail.com> Signed-off-by: Andrei Vagin <avagin@gmail.com> Signed-off-by: Bhavik Sachdev <b.sachdev1904@gmail.com> Link: https://patch.msgid.link/20251129091455.757724-4-b.sachdev1904@gmail.com Signed-off-by: Christian Brauner <brauner@kernel.org>
88 lines
1.9 KiB
C
88 lines
1.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef __STATMOUNT_H
|
|
#define __STATMOUNT_H
|
|
|
|
#include <stdint.h>
|
|
#include <linux/mount.h>
|
|
#include <asm/unistd.h>
|
|
|
|
#ifndef __NR_statmount
|
|
#if defined __alpha__
|
|
#define __NR_statmount 567
|
|
#elif defined _MIPS_SIM
|
|
#if _MIPS_SIM == _MIPS_SIM_ABI32 /* o32 */
|
|
#define __NR_statmount 4457
|
|
#endif
|
|
#if _MIPS_SIM == _MIPS_SIM_NABI32 /* n32 */
|
|
#define __NR_statmount 6457
|
|
#endif
|
|
#if _MIPS_SIM == _MIPS_SIM_ABI64 /* n64 */
|
|
#define __NR_statmount 5457
|
|
#endif
|
|
#else
|
|
#define __NR_statmount 457
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef __NR_listmount
|
|
#if defined __alpha__
|
|
#define __NR_listmount 568
|
|
#elif defined _MIPS_SIM
|
|
#if _MIPS_SIM == _MIPS_SIM_ABI32 /* o32 */
|
|
#define __NR_listmount 4458
|
|
#endif
|
|
#if _MIPS_SIM == _MIPS_SIM_NABI32 /* n32 */
|
|
#define __NR_listmount 6458
|
|
#endif
|
|
#if _MIPS_SIM == _MIPS_SIM_ABI64 /* n64 */
|
|
#define __NR_listmount 5458
|
|
#endif
|
|
#else
|
|
#define __NR_listmount 458
|
|
#endif
|
|
#endif
|
|
|
|
static inline int statmount(uint64_t mnt_id, uint64_t mnt_ns_id, uint32_t fd,
|
|
uint64_t mask, struct statmount *buf, size_t bufsize,
|
|
unsigned int flags)
|
|
{
|
|
struct mnt_id_req req = {
|
|
.size = MNT_ID_REQ_SIZE_VER0,
|
|
.param = mask,
|
|
};
|
|
|
|
if (flags & STATMOUNT_BY_FD) {
|
|
req.size = MNT_ID_REQ_SIZE_VER1;
|
|
req.mnt_fd = fd;
|
|
} else {
|
|
req.mnt_id = mnt_id;
|
|
if (mnt_ns_id) {
|
|
req.size = MNT_ID_REQ_SIZE_VER1;
|
|
req.mnt_ns_id = mnt_ns_id;
|
|
}
|
|
}
|
|
|
|
return syscall(__NR_statmount, &req, buf, bufsize, flags);
|
|
}
|
|
|
|
static inline ssize_t listmount(uint64_t mnt_id, uint64_t mnt_ns_id,
|
|
uint64_t last_mnt_id, uint64_t list[], size_t num,
|
|
unsigned int flags)
|
|
{
|
|
struct mnt_id_req req = {
|
|
.size = MNT_ID_REQ_SIZE_VER0,
|
|
.mnt_id = mnt_id,
|
|
.param = last_mnt_id,
|
|
};
|
|
|
|
if (mnt_ns_id) {
|
|
req.size = MNT_ID_REQ_SIZE_VER1;
|
|
req.mnt_ns_id = mnt_ns_id;
|
|
}
|
|
|
|
return syscall(__NR_listmount, &req, list, num, flags);
|
|
}
|
|
|
|
#endif /* __STATMOUNT_H */
|