blob: 623631ec4ed766cd343356cbae2c7a65166aaf3b [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughesb8104622014-08-19 09:18:03 -070028
Elliott Hughes733cedd2020-02-21 23:21:28 -080029#pragma once
30
31/**
32 * @file sys/stat.h
33 * @brief File status.
34 */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080035
Elliott Hughes5704c422016-01-25 18:06:24 -080036#include <bits/timespec.h>
Yabin Cuidb499032014-12-09 20:15:48 -080037#include <linux/stat.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080038#include <sys/cdefs.h>
39#include <sys/types.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080040
41__BEGIN_DECLS
42
Elliott Hughes5cc8a462022-10-06 00:26:18 +000043#if defined(__aarch64__) || defined(__riscv)
Elliott Hughesdb1ea342014-01-17 18:42:49 -080044#define __STAT64_BODY \
Elliott Hughes9257c472014-12-18 15:17:42 -080045 dev_t st_dev; \
46 ino_t st_ino; \
47 mode_t st_mode; \
48 nlink_t st_nlink; \
Elliott Hughes6b555932014-02-18 16:43:31 -080049 uid_t st_uid; \
50 gid_t st_gid; \
Elliott Hughes9257c472014-12-18 15:17:42 -080051 dev_t st_rdev; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080052 unsigned long __pad1; \
Elliott Hughes9257c472014-12-18 15:17:42 -080053 off_t st_size; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080054 int st_blksize; \
55 int __pad2; \
56 long st_blocks; \
Elliott Hughes0ac0df82014-11-07 19:15:10 -080057 struct timespec st_atim; \
58 struct timespec st_mtim; \
59 struct timespec st_ctim; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080060 unsigned int __unused4; \
61 unsigned int __unused5; \
62
Elliott Hughesb8fa5b12013-12-19 16:50:22 -080063#elif defined(__x86_64__)
Elliott Hughesdb1ea342014-01-17 18:42:49 -080064#define __STAT64_BODY \
Elliott Hughes1c52e6c2014-12-18 12:38:44 -080065 dev_t st_dev; \
66 ino_t st_ino; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080067 unsigned long st_nlink; \
Elliott Hughes1c52e6c2014-12-18 12:38:44 -080068 mode_t st_mode; \
Elliott Hughes6b555932014-02-18 16:43:31 -080069 uid_t st_uid; \
70 gid_t st_gid; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080071 unsigned int __pad0; \
Elliott Hughes1c52e6c2014-12-18 12:38:44 -080072 dev_t st_rdev; \
73 off_t st_size; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080074 long st_blksize; \
75 long st_blocks; \
Elliott Hughes0ac0df82014-11-07 19:15:10 -080076 struct timespec st_atim; \
77 struct timespec st_mtim; \
78 struct timespec st_ctim; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080079 long __pad3[3]; \
80
Elliott Hughes9257c472014-12-18 15:17:42 -080081#else /* __arm__ || __i386__ */
Elliott Hughesdb1ea342014-01-17 18:42:49 -080082#define __STAT64_BODY \
83 unsigned long long st_dev; \
84 unsigned char __pad0[4]; \
85 unsigned long __st_ino; \
86 unsigned int st_mode; \
Elliott Hughes9257c472014-12-18 15:17:42 -080087 nlink_t st_nlink; \
Elliott Hughes6b555932014-02-18 16:43:31 -080088 uid_t st_uid; \
89 gid_t st_gid; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080090 unsigned long long st_rdev; \
91 unsigned char __pad3[4]; \
92 long long st_size; \
93 unsigned long st_blksize; \
94 unsigned long long st_blocks; \
Elliott Hughes0ac0df82014-11-07 19:15:10 -080095 struct timespec st_atim; \
96 struct timespec st_mtim; \
97 struct timespec st_ctim; \
Elliott Hughesdb1ea342014-01-17 18:42:49 -080098 unsigned long long st_ino; \
99
Raghu Gandham6437eac2012-08-02 16:50:10 -0700100#endif
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800101
Elliott Hughesdb1ea342014-01-17 18:42:49 -0800102struct stat { __STAT64_BODY };
103struct stat64 { __STAT64_BODY };
104
Calin Juravlef963da22014-05-13 11:01:11 +0100105#undef __STAT64_BODY
106
Elliott Hughes0ac0df82014-11-07 19:15:10 -0800107/* Compatibility with older versions of POSIX. */
108#define st_atime st_atim.tv_sec
109#define st_mtime st_mtim.tv_sec
110#define st_ctime st_ctim.tv_sec
111/* Compatibility with glibc. */
112#define st_atimensec st_atim.tv_nsec
113#define st_mtimensec st_mtim.tv_nsec
114#define st_ctimensec st_ctim.tv_nsec
Dan Alberta4e774c2017-06-12 14:59:38 -0700115/* Compatibility with Linux headers and old NDKs. */
116#define st_atime_nsec st_atim.tv_nsec
117#define st_mtime_nsec st_mtim.tv_nsec
118#define st_ctime_nsec st_ctim.tv_nsec
David 'Digit' Turner09baf4e2009-06-22 12:16:06 +0200119
Elliott Hughes3ba55f82016-06-08 18:11:23 -0700120#if defined(__USE_BSD)
Hakan Kvistf27b7fb2012-10-10 08:32:52 +0200121/* Permission macros provided by glibc for compatibility with BSDs. */
122#define ACCESSPERMS (S_IRWXU | S_IRWXG | S_IRWXO) /* 0777 */
123#define ALLPERMS (S_ISUID | S_ISGID | S_ISVTX | S_IRWXU | S_IRWXG | S_IRWXO) /* 07777 */
124#define DEFFILEMODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH) /* 0666 */
125#endif
126
Elliott Hughes1f1a51a2016-03-31 17:05:30 -0700127#if defined(__USE_BSD) || defined(__USE_GNU)
128#define S_IREAD S_IRUSR
129#define S_IWRITE S_IWUSR
130#define S_IEXEC S_IXUSR
131#endif
132
Elliott Hughes92887612016-08-16 13:26:35 -0700133/* POSIX mandates these, but Linux doesn't implement them as distinct file types. */
134#define S_TYPEISMQ(__sb) 0
135#define S_TYPEISSEM(__sb) 0
136#define S_TYPEISSHM(__sb) 0
137#define S_TYPEISTMO(__sb) 0
138
Elliott Hughesff26a162017-08-17 22:34:21 +0000139int chmod(const char* __path, mode_t __mode);
140int fchmod(int __fd, mode_t __mode);
141int mkdir(const char* __path, mode_t __mode);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800142
Elliott Hughesff26a162017-08-17 22:34:21 +0000143int fstat(int __fd, struct stat* __buf);
Elliott Hughes25f17e42018-02-12 15:48:01 -0800144int fstat64(int __fd, struct stat64* __buf) __RENAME_STAT64(fstat, 3, 21);
Elliott Hughesff26a162017-08-17 22:34:21 +0000145int fstatat(int __dir_fd, const char* __path, struct stat* __buf, int __flags);
Elliott Hughes25f17e42018-02-12 15:48:01 -0800146int fstatat64(int __dir_fd, const char* __path, struct stat64* __buf, int __flags) __RENAME_STAT64(fstatat, 3, 21);
Elliott Hughesff26a162017-08-17 22:34:21 +0000147int lstat(const char* __path, struct stat* __buf);
Elliott Hughes25f17e42018-02-12 15:48:01 -0800148int lstat64(const char* __path, struct stat64* __buf) __RENAME_STAT64(lstat, 3, 21);
Elliott Hughesff26a162017-08-17 22:34:21 +0000149int stat(const char* __path, struct stat* __buf);
Elliott Hughes25f17e42018-02-12 15:48:01 -0800150int stat64(const char* __path, struct stat64* __buf) __RENAME_STAT64(stat, 3, 21);
Elliott Hughesdb1ea342014-01-17 18:42:49 -0800151
Elliott Hughesff26a162017-08-17 22:34:21 +0000152int mknod(const char* __path, mode_t __mode, dev_t __dev);
George Burgess IV90242352018-02-06 12:51:31 -0800153mode_t umask(mode_t __mask);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800154
George Burgess IVb97049c2017-07-24 15:05:05 -0700155#if defined(__BIONIC_INCLUDE_FORTIFY_HEADERS)
156#include <bits/fortify/stat.h>
157#endif
Nick Kralevichcd587702012-09-26 10:02:30 -0700158
Elliott Hughes95c6cd72019-12-20 13:26:14 -0800159#if __ANDROID_API__ >= 21
Elliott Hughesff26a162017-08-17 22:34:21 +0000160int mkfifo(const char* __path, mode_t __mode) __INTRODUCED_IN(21);
Josh Gao8778d642016-07-22 15:26:36 -0700161#else
162// Implemented as a static inline before 21.
163#endif
164
Elliott Hughesff26a162017-08-17 22:34:21 +0000165int mkfifoat(int __dir_fd, const char* __path, mode_t __mode) __INTRODUCED_IN(23);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800166
Elliott Hughesff26a162017-08-17 22:34:21 +0000167int fchmodat(int __dir_fd, const char* __path, mode_t __mode, int __flags);
168int mkdirat(int __dir_fd, const char* __path, mode_t __mode);
169int mknodat(int __dir_fd, const char* __path, mode_t __mode, dev_t __dev) __INTRODUCED_IN(21);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800170
Elliott Hughesdb1ea342014-01-17 18:42:49 -0800171#define UTIME_NOW ((1L << 30) - 1L)
172#define UTIME_OMIT ((1L << 30) - 2L)
Elliott Hughesf106a392019-10-03 16:09:04 -0700173int utimensat(int __dir_fd, const char* __path, const struct timespec __times[2], int __flags);
Elliott Hughesff26a162017-08-17 22:34:21 +0000174int futimens(int __dir_fd, const struct timespec __times[2]) __INTRODUCED_IN(19);
Ken Sumrallae2d5ba2011-03-18 11:55:12 -0700175
Elliott Hughes733cedd2020-02-21 23:21:28 -0800176#if defined(__USE_GNU)
177/**
178 * [statx(2)](http://man7.org/linux/man-pages/man2/statx.2.html) returns
179 * extended file status information.
180 *
181 * Returns 0 on success and returns -1 and sets `errno` on failure.
182 */
183int statx(int __dir_fd, const char* __path, int __flags, unsigned __mask, struct statx* __buf) __INTRODUCED_IN(30);
184#endif
185
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800186__END_DECLS
187
Josh Gaob8e1b7052016-04-13 17:18:20 -0700188#include <android/legacy_sys_stat_inlines.h>