diff --git a/include/sys/xattr.h b/include/sys/xattr.h new file mode 100644 index 0000000..0599cb3 --- /dev/null +++ b/include/sys/xattr.h @@ -0,0 +1,11 @@ +#define XATTR_CREATE 1 +#define XATTR_REPLACE 2 +ssize_t getxattr(const char *path, const char *name, void *value, size_t size) +ssize_t lgetxattr(const char *path, const char *name, void *value, size_t size) +ssize_t fgetxattr(int filedes, const char *name, void *value, size_t size) +ssize_t listxattr(const char *path, char *list, size_t size) +ssize_t llistxattr(const char *path, char *list, size_t size) +ssize_t flistxattr(int filedes, char *list, size_t size) +int setxattr(const char *path, const char *name, const void *value, size_t size, int flags) +int lsetxattr(const char *path, const char *name, const void *value, size_t size, int flags) +int fsetxattr(int filedes, const char *name, const void *value, size_t size, int flags) diff --git a/src/linux/xattr.c b/src/linux/xattr.c new file mode 100644 index 0000000..75b5015 --- /dev/null +++ b/src/linux/xattr.c @@ -0,0 +1,48 @@ +#include +#include +#include "syscall.h" + +ssize_t getxattr(const char *path, const char *name, void *value, size_t size) +{ + return syscall(SYS_getxattr, path, name, value, size); +} + +ssize_t lgetxattr(const char *path, const char *name, void *value, size_t size) +{ + return syscall(SYS_lgetxattr, path, name, value, size); +} + +ssize_t fgetxattr(int filedes, const char *name, void *value, size_t size) +{ + return syscall(SYS_fgetxattr, filedes, name, value, size); +} + +ssize_t listxattr(const char *path, char *list, size_t size) +{ + return syscall(SYS_listxattr, path, list, size); +} + +ssize_t llistxattr(const char *path, char *list, size_t size) +{ + return syscall(SYS_llistxattr, path, list, size); +} + +ssize_t flistxattr(int filedes, char *list, size_t size) +{ + return syscall(SYS_flistxattr, filedes, list, size); +} + +int setxattr(const char *path, const char *name, const void *value, size_t size, int flags) +{ + return syscall(SYS_setxattr, path, name, value, size, flags); +} + +int lsetxattr(const char *path, const char *name, const void *value, size_t size, int flags) +{ + return syscall(SYS_lsetxattr, path, name, value, size, flags); +} + +int fsetxattr(int filedes, const char *name, const void *value, size_t size, int flags) +{ + return syscall(SYS_fsetxattr, filedes, name, value, size, flags); +}