|
Packit Service |
dff8e4 |
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
Packit Service |
dff8e4 |
#pragma once
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#include <fcntl.h>
|
|
Packit Service |
dff8e4 |
#include <stdbool.h>
|
|
Packit Service |
dff8e4 |
#include <stddef.h>
|
|
Packit Service |
dff8e4 |
#include <sys/stat.h>
|
|
Packit Service |
dff8e4 |
#include <sys/statfs.h>
|
|
Packit Service |
dff8e4 |
#include <sys/types.h>
|
|
Packit Service |
dff8e4 |
#include <sys/vfs.h>
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#include "macro.h"
|
|
Packit Service |
dff8e4 |
#include "missing_stat.h"
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int is_symlink(const char *path);
|
|
Packit Service |
dff8e4 |
int is_dir(const char *path, bool follow);
|
|
Packit Service |
dff8e4 |
int is_dir_fd(int fd);
|
|
Packit Service |
dff8e4 |
int is_device_node(const char *path);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int dir_is_empty_at(int dir_fd, const char *path);
|
|
Packit Service |
dff8e4 |
static inline int dir_is_empty(const char *path) {
|
|
Packit Service |
dff8e4 |
return dir_is_empty_at(AT_FDCWD, path);
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
static inline int dir_is_populated(const char *path) {
|
|
Packit Service |
dff8e4 |
int r;
|
|
Packit Service |
dff8e4 |
r = dir_is_empty(path);
|
|
Packit Service |
dff8e4 |
if (r < 0)
|
|
Packit Service |
dff8e4 |
return r;
|
|
Packit Service |
dff8e4 |
return !r;
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
bool null_or_empty(struct stat *st) _pure_;
|
|
Packit Service |
dff8e4 |
int null_or_empty_path(const char *fn);
|
|
Packit Service |
dff8e4 |
int null_or_empty_fd(int fd);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int path_is_read_only_fs(const char *path);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int files_same(const char *filea, const char *fileb, int flags);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/* The .f_type field of struct statfs is really weird defined on
|
|
Packit Service |
dff8e4 |
* different archs. Let's give its type a name. */
|
|
Packit Service |
dff8e4 |
typedef typeof(((struct statfs*)NULL)->f_type) statfs_f_type_t;
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) _pure_;
|
|
Packit Service |
dff8e4 |
int fd_is_fs_type(int fd, statfs_f_type_t magic_value);
|
|
Packit Service |
dff8e4 |
int path_is_fs_type(const char *path, statfs_f_type_t magic_value);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
bool is_temporary_fs(const struct statfs *s) _pure_;
|
|
Packit Service |
dff8e4 |
bool is_network_fs(const struct statfs *s) _pure_;
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int fd_is_temporary_fs(int fd);
|
|
Packit Service |
dff8e4 |
int fd_is_network_fs(int fd);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int path_is_temporary_fs(const char *path);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/* Because statfs.t_type can be int on some architectures, we have to cast
|
|
Packit Service |
dff8e4 |
* the const magic to the type, otherwise the compiler warns about
|
|
Packit Service |
dff8e4 |
* signed/unsigned comparison, because the magic can be 32 bit unsigned.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
#define F_TYPE_EQUAL(a, b) (a == (typeof(a)) b)
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int stat_verify_regular(const struct stat *st);
|
|
Packit Service |
dff8e4 |
int fd_verify_regular(int fd);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int stat_verify_directory(const struct stat *st);
|
|
Packit Service |
dff8e4 |
int fd_verify_directory(int fd);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/* glibc and the Linux kernel have different ideas about the major/minor size. These calls will check whether the
|
|
Packit Service |
dff8e4 |
* specified major is valid by the Linux kernel's standards, not by glibc's. Linux has 20bits of minor, and 12 bits of
|
|
Packit Service |
dff8e4 |
* major space. See MINORBITS in linux/kdev_t.h in the kernel sources. (If you wonder why we define _y here, instead of
|
|
Packit Service |
dff8e4 |
* comparing directly >= 0: it's to trick out -Wtype-limits, which would otherwise complain if the type is unsigned, as
|
|
Packit Service |
dff8e4 |
* such a test would be pointless in such a case.) */
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#define DEVICE_MAJOR_VALID(x) \
|
|
Packit Service |
dff8e4 |
({ \
|
|
Packit Service |
dff8e4 |
typeof(x) _x = (x), _y = 0; \
|
|
Packit Service |
dff8e4 |
_x >= _y && _x < (UINT32_C(1) << 12); \
|
|
Packit Service |
dff8e4 |
\
|
|
Packit Service |
dff8e4 |
})
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#define DEVICE_MINOR_VALID(x) \
|
|
Packit Service |
dff8e4 |
({ \
|
|
Packit Service |
dff8e4 |
typeof(x) _x = (x), _y = 0; \
|
|
Packit Service |
dff8e4 |
_x >= _y && _x < (UINT32_C(1) << 20); \
|
|
Packit Service |
dff8e4 |
})
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int device_path_make_major_minor(mode_t mode, dev_t devno, char **ret);
|
|
Packit Service |
dff8e4 |
int device_path_make_canonical(mode_t mode, dev_t devno, char **ret);
|
|
Packit Service |
dff8e4 |
int device_path_parse_major_minor(const char *path, mode_t *ret_mode, dev_t *ret_devno);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int proc_mounted(void);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
bool stat_inode_unmodified(const struct stat *a, const struct stat *b);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
int statx_fallback(int dfd, const char *path, int flags, unsigned mask, struct statx *sx);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#if HAS_FEATURE_MEMORY_SANITIZER
|
|
Packit Service |
dff8e4 |
# warning "Explicitly initializing struct statx, to work around msan limitation. Please remove as soon as msan has been updated to not require this."
|
|
Packit Service |
dff8e4 |
# define STRUCT_STATX_DEFINE(var) \
|
|
Packit Service |
dff8e4 |
struct statx var = {}
|
|
Packit Service |
dff8e4 |
# define STRUCT_NEW_STATX_DEFINE(var) \
|
|
Packit Service |
dff8e4 |
union { \
|
|
Packit Service |
dff8e4 |
struct statx sx; \
|
|
Packit Service |
dff8e4 |
struct new_statx nsx; \
|
|
Packit Service |
dff8e4 |
} var = {}
|
|
Packit Service |
dff8e4 |
#else
|
|
Packit Service |
dff8e4 |
# define STRUCT_STATX_DEFINE(var) \
|
|
Packit Service |
dff8e4 |
struct statx var
|
|
Packit Service |
dff8e4 |
# define STRUCT_NEW_STATX_DEFINE(var) \
|
|
Packit Service |
dff8e4 |
union { \
|
|
Packit Service |
dff8e4 |
struct statx sx; \
|
|
Packit Service |
dff8e4 |
struct new_statx nsx; \
|
|
Packit Service |
dff8e4 |
} var
|
|
Packit Service |
dff8e4 |
#endif
|