aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorTony Ambardar <tony.ambardar@gmail.com>2024-05-06 20:28:32 -0700
committerRich Felker <dalias@aerifal.cx>2024-05-23 09:13:49 -0400
commit05ce67fea99ca09cd4b6625cff7aec9cc222dd5a (patch)
tree2cdba37f1d75c63e307feab1d067a809884370f2 /include
parent007997299248b8682dcbb73595c53dfe86071c83 (diff)
downloadmusl-05ce67fea99ca09cd4b6625cff7aec9cc222dd5a.zip
musl-05ce67fea99ca09cd4b6625cff7aec9cc222dd5a.tar.gz
musl-05ce67fea99ca09cd4b6625cff7aec9cc222dd5a.tar.bz2
add renameat2 linux syscall wrapper
This syscall is available since Linux 3.15 and also implemented in glibc from version 2.28. It is commonly used in filesystem or security contexts. Constants RENAME_NOREPLACE, RENAME_EXCHANGE, RENAME_WHITEOUT are guarded by _GNU_SOURCE as with glibc.
Diffstat (limited to 'include')
-rw-r--r--include/stdio.h7
1 files changed, 7 insertions, 0 deletions
diff --git a/include/stdio.h b/include/stdio.h
index cb85861..4ea4c17 100644
--- a/include/stdio.h
+++ b/include/stdio.h
@@ -158,6 +158,13 @@ char *ctermid(char *);
#define L_ctermid 20
#endif
+#if defined(_GNU_SOURCE)
+#define RENAME_NOREPLACE (1 << 0)
+#define RENAME_EXCHANGE (1 << 1)
+#define RENAME_WHITEOUT (1 << 2)
+
+int renameat2(int, const char *, int, const char *, unsigned);
+#endif
#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \
|| defined(_BSD_SOURCE)