Move the definition of the struct present in stat(2), and put there a reference to stat-struct(3) instead. Signed-off-by: Alejandro Colomar <alx.manpages@xxxxxxxxx> Cc: G. Branden Robinson <g.branden.robinson@xxxxxxxxx> --- man2/stat.2 | 143 +-------------------------------------- man7/system_data_types.7 | 141 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 144 insertions(+), 140 deletions(-) diff --git a/man2/stat.2 b/man2/stat.2 index 016c1f47d..02bf5fbeb 100644 --- a/man2/stat.2 +++ b/man2/stat.2 @@ -116,47 +116,8 @@ is specified by the file descriptor .SS The stat structure All of these system calls return a .I stat -structure, which contains the following fields: -.PP -.in +4n -.EX -struct stat { - dev_t st_dev; /* ID of device containing file */ - ino_t st_ino; /* Inode number */ - mode_t st_mode; /* File type and mode */ - nlink_t st_nlink; /* Number of hard links */ - uid_t st_uid; /* User ID of owner */ - gid_t st_gid; /* Group ID of owner */ - dev_t st_rdev; /* Device ID (if special file) */ - off_t st_size; /* Total size, in bytes */ - blksize_t st_blksize; /* Block size for filesystem I/O */ - blkcnt_t st_blocks; /* Number of 512B blocks allocated */ - - /* Since Linux 2.6, the kernel supports nanosecond - precision for the following timestamp fields. - For the details before Linux 2.6, see NOTES. */ - - struct timespec st_atim; /* Time of last access */ - struct timespec st_mtim; /* Time of last modification */ - struct timespec st_ctim; /* Time of last status change */ - -#define st_atime st_atim.tv_sec /* Backward compatibility */ -#define st_mtime st_mtim.tv_sec -#define st_ctime st_ctim.tv_sec -}; -.EE -.in -.PP -.IR Note : -the order of fields in the -.I stat -structure varies somewhat -across architectures. -In addition, -the definition above does not show the padding bytes -that may be present between some fields on various architectures. -Consult the glibc and kernel source code -if you need to know the details. +structure (see +.BR stat-struct (3)). .PP .\" Background: inode attributes are modified with i_mutex held, but .\" read by stat() without taking the mutex. @@ -182,69 +143,6 @@ or the old .I st_uid together with the new .IR st_mode . -.PP -The fields in the -.I stat -structure are as follows: -.TP -.I st_dev -This field describes the device on which this file resides. -(The -.BR major (3) -and -.BR minor (3) -macros may be useful to decompose the device ID in this field.) -.TP -.I st_ino -This field contains the file's inode number. -.TP -.I st_mode -This field contains the file type and mode. -See -.BR inode (7) -for further information. -.TP -.I st_nlink -This field contains the number of hard links to the file. -.TP -.I st_uid -This field contains the user ID of the owner of the file. -.TP -.I st_gid -This field contains the ID of the group owner of the file. -.TP -.I st_rdev -This field describes the device that this file (inode) represents. -.TP -.I st_size -This field gives the size of the file (if it is a regular -file or a symbolic link) in bytes. -The size of a symbolic link is the length of the pathname -it contains, without a terminating null byte. -.TP -.I st_blksize -This field gives the "preferred" block size for efficient filesystem I/O. -.TP -.I st_blocks -This field indicates the number of blocks allocated to the file, -in 512-byte units. -(This may be smaller than -.IR st_size /512 -when the file has holes.) -.TP -.I st_atime -This is the time of the last access of file data. -.TP -.I st_mtime -This is the time of last modification of file data. -.TP -.I st_ctime -This is the file's last status change timestamp -(time of last change to the inode). -.PP -For further information on the above fields, see -.BR inode (7). -.\" .SS fstatat() The .BR fstatat () @@ -494,42 +392,6 @@ fields may be less portable. The interpretation differs between systems, and possibly on a single system when NFS mounts are involved.) .SH NOTES -.SS Timestamp fields -Older kernels and older standards did not support nanosecond timestamp -fields. -Instead, there were three timestamp -.RI fields\(em st_atime , -.IR st_mtime , -and -.IR st_ctime \(emtyped -as -.IR time_t -that recorded timestamps with one-second precision. -.PP -Since kernel 2.5.48, the -.I stat -structure supports nanosecond resolution for the three file timestamp fields. -The nanosecond components of each timestamp are available -via names of the form -.IR st_atim.tv_nsec , -if suitable feature test macros are defined. -Nanosecond timestamps were standardized in POSIX.1-2008, -and, starting with version 2.12, -glibc exposes the nanosecond component names if -.BR _POSIX_C_SOURCE -is defined with the value 200809L or greater, or -.BR _XOPEN_SOURCE -is defined with the value 700 or greater. -Up to and including glibc 2.19, -the definitions of the nanoseconds components are also defined if -.B _BSD_SOURCE -or -.B _SVID_SOURCE -is defined. -If none of the aforementioned macros are defined, -then the nanosecond values are exposed with names of the form -.IR st_atimensec . -.\" .SS C library/kernel differences Over time, increases in the size of the .I stat @@ -710,6 +572,7 @@ main(int argc, char *argv[]) .BR readlink (2), .BR statx (2), .BR utime (2), +.BR stat-struct (3), .BR capabilities (7), .BR inode (7), .BR symlink (7) diff --git a/man7/system_data_types.7 b/man7/system_data_types.7 index d117b1d2b..cfccdd0f4 100644 --- a/man7/system_data_types.7 +++ b/man7/system_data_types.7 @@ -1434,6 +1434,147 @@ and .I size_t types in this page. .RE +.\"------------------------------------- stat -------------------------/ +.TP +.I stat +.RS +.IR Include : +.IR <sys/stat.h> . +Alternatively, +.IR <ftw.h> . +.PP +.EX +struct stat { + dev_t st_dev; /* ID of device containing file */ + ino_t st_ino; /* Inode number */ + mode_t st_mode: /* File type and mode */ + nlink_t st_nlink; /* Number of hard links */ + uid_t st_uid; /* User ID of owner */ + gid_t st_gid; /* Group ID of owner */ + dev_t st_rdev; /* Device ID (if special file) */ + off_t st_size; /* Total size, in bytes */ + blksize_t st_blksize; /* Block size for filesystem I/O */ + blkcnt_t st_blocks; /* Number of 512 B blocks allocated */ + + /* Since POSIX.1-2008, this structure supports nanosecond + precision for the following timestamp fields. + For the details before POSIX.1-2008, see Notes. */ + + struct timespec st_atim; /* Time of last access */ + struct timespec st_mtim; /* Time of last modification */ + struct timespec st_ctim; /* Time of last status change */ + +#define st_atime st_atim.tv_sec /* Backward compatibility */ +#define st_mtine st_mtim.tv_sec +#define st_ctime st_ctim.tv_sec +}; +.EE +.PP +Describes information about a file. +.PP +The fields are as follows: +.TP +.I st_dev +This field describes the device on which this file resides. +(The +.BR major (3) +and +.BR minor (3) +macros may be useful to decompose the device ID in this field.) +.TP +.I st_ino +This field contains the file's inode number. +.TP +.I st_mode +This field contains the file type and mode. +See +.BR inode (7) +for further information. +.TP +.I st_nlink +This field contains the number of hard links to the file. +.TP +.I st_uid +This field contains the user ID of the owner of the file. +.TP +.I st_gid +This field contains the ID of the group owner of the file. +.TP +.I st_rdev +This field describes the device that this file (inode) represents. +.TP +.I st_size +This field gives the size of the file (if it is a regular +file or a symbolic link) in bytes. +The size of a symbolic link is the length of the pathname +it contains, without a terminating null byte. +.TP +.I st_blksize +This field gives the "preferred" block size for efficient filesystem I/O. +.TP +.I st_blocks +This field indicates the number of blocks allocated to the file, +in 512-byte units. +(This may be smaller than +.IR st_size /512 +when the file has holes.) +.TP +.I st_atime +This is the time of the last access of file data. +.TP +.I st_mtime +This is the time of last modification of file data. +.TP +.I st_ctime +This is the file's last status change timestamp +(time of last change to the inode). +.PP +For further information on the above fields, see +.BR inode (7). +.\" +.PP +.IR "Conforming to" : +POSIX.1-2001 and later (see Notes). +.PP +.IR Notes : +Old kernels and old standards did not support nanosecond timestamp fields. +Instead, there were three timestamp +.RI fields\(em st_atime , +.IR st_mtime , +and +.IR st_ctime \(emtyped +as +.IR time_t +that recorded timestamps with one-second precision. +.PP +Since Linux 2.5.48, the +.I stat +structure supports nanosecond resolution for the three file timestamp fields. +The nanosecond components of each timestamp are available +via names of the form +.IR st_atim.tv_nsec , +if suitable test macros are defined. +Nanosecond timestamps were standardized in POSIX.1-2008, +and, starting with version 2.12, +glibc exposes the nanosecond component names if +.BR _POSIX_C_SOURCE +is defined with the value 200809L or greater, or +.BR _XOPEN_SOURCE +is defined with the value 700 or greater. +Up to and including glibc 2.19, +the definitions of the nanoseconds components are also defined if +.B _BSD_SOURCE +or +.B _SVID_SOURCE +is defined. +If none of the aforementioned macros are defined, +then the nanosecond values are exposed with names of the form +.IR st_atimensec . +.PP +.IR "See also" : +.BR stat (2), +.BR inode (7) +.RE .\"------------------------------------- suseconds_t ------------------/ .TP .I suseconds_t -- 2.33.1