1 /* SPDX-License-Identifier: GPL-2.0 */
2
3 #ifndef __STATMOUNT_H
4 #define __STATMOUNT_H
5
6 #include <stdint.h>
7 #include <linux/mount.h>
8 #include <asm/unistd.h>
9
statmount(uint64_t mnt_id,uint64_t mnt_ns_id,uint64_t mask,struct statmount * buf,size_t bufsize,unsigned int flags)10 static inline int statmount(uint64_t mnt_id, uint64_t mnt_ns_id, uint64_t mask,
11 struct statmount *buf, size_t bufsize,
12 unsigned int flags)
13 {
14 struct mnt_id_req req = {
15 .size = MNT_ID_REQ_SIZE_VER0,
16 .mnt_id = mnt_id,
17 .param = mask,
18 };
19
20 if (mnt_ns_id) {
21 req.size = MNT_ID_REQ_SIZE_VER1;
22 req.mnt_ns_id = mnt_ns_id;
23 }
24
25 return syscall(__NR_statmount, &req, buf, bufsize, flags);
26 }
27
listmount(uint64_t mnt_id,uint64_t mnt_ns_id,uint64_t last_mnt_id,uint64_t list[],size_t num,unsigned int flags)28 static ssize_t listmount(uint64_t mnt_id, uint64_t mnt_ns_id,
29 uint64_t last_mnt_id, uint64_t list[], size_t num,
30 unsigned int flags)
31 {
32 struct mnt_id_req req = {
33 .size = MNT_ID_REQ_SIZE_VER0,
34 .mnt_id = mnt_id,
35 .param = last_mnt_id,
36 };
37
38 if (mnt_ns_id) {
39 req.size = MNT_ID_REQ_SIZE_VER1;
40 req.mnt_ns_id = mnt_ns_id;
41 }
42
43 return syscall(__NR_listmount, &req, list, num, flags);
44 }
45
46 #endif /* __STATMOUNT_H */
47