diff options
author | Rich Felker <dalias@aerifal.cx> | 2012-07-23 16:39:44 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012-07-23 16:39:44 -0400 |
commit | 207460d09742304941f1a010a89fc2efa46bcb29 (patch) | |
tree | 69f53d2669c7877e8d0c4fb298a8f64ca543dd40 | |
parent | 42f0e965c42d7611e7a02718bffb1a8ffba74488 (diff) | |
download | musl-207460d09742304941f1a010a89fc2efa46bcb29.tar.gz musl-207460d09742304941f1a010a89fc2efa46bcb29.tar.bz2 musl-207460d09742304941f1a010a89fc2efa46bcb29.tar.xz musl-207460d09742304941f1a010a89fc2efa46bcb29.zip |
add extended attributes syscalls
based on patch by orc and Isaac Dunham, with some fixes.
-rw-r--r-- | include/sys/xattr.h | 27 | ||||
-rw-r--r-- | src/linux/xattr.c | 47 |
2 files changed, 74 insertions, 0 deletions
diff --git a/include/sys/xattr.h b/include/sys/xattr.h new file mode 100644 index 00000000..2801cb85 --- /dev/null +++ b/include/sys/xattr.h @@ -0,0 +1,27 @@ +#ifndef _SYS_XATTR_H +#define _SYS_XATTR_H +#ifdef __cplusplus +extern "C" { +#endif + +#define __NEED_ssize_t +#define __NEED_size_t +#include <bits/alltypes.h> + +#define XATTR_CREATE 1 +#define XATTR_REPLACE 2 + +ssize_t getxattr(const char *, const char *, void *, size_t); +ssize_t lgetxattr(const char *, const char *, void *, size_t); +ssize_t fgetxattr(int filedes, const char *, void *, size_t); +ssize_t listxattr(const char *, char *, size_t); +ssize_t llistxattr(const char *, char *, size_t); +ssize_t flistxattr(int filedes, char *, size_t); +int setxattr(const char *, const char *, const void *, size_t, int); +int lsetxattr(const char *, const char *, const void *, size_t, int); +int fsetxattr(int, const char *, const void *, size_t, int); + +#ifdef __cplusplus +} +#endif +#endif diff --git a/src/linux/xattr.c b/src/linux/xattr.c new file mode 100644 index 00000000..a66ab827 --- /dev/null +++ b/src/linux/xattr.c @@ -0,0 +1,47 @@ +#include <sys/xattr.h> +#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); +} |