diff options
Diffstat (limited to 'libc/sysdeps/linux/common/bits')
| -rw-r--r-- | libc/sysdeps/linux/common/bits/kernel_stat.h | 36 | ||||
| -rw-r--r-- | libc/sysdeps/linux/common/bits/stat.h | 72 | 
2 files changed, 72 insertions, 36 deletions
diff --git a/libc/sysdeps/linux/common/bits/kernel_stat.h b/libc/sysdeps/linux/common/bits/kernel_stat.h index b338e3d5c..04c984757 100644 --- a/libc/sysdeps/linux/common/bits/kernel_stat.h +++ b/libc/sysdeps/linux/common/bits/kernel_stat.h @@ -2,12 +2,11 @@  #define _BITS_STAT_STRUCT_H  /* This file provides whatever this particular arch's kernel thinks  - * struct stat should look like...  It turns out each arch has a  + * struct kernel_stat should look like...  It turns out each arch has a    * different opinion on the subject... */ -#warning please verify struct stat for your architecture matches struct stat for x86... +#warning "Please verify struct kernel_stat for your architecture actually matches struct kernel_stat for x86  If it doesn't, then you will need to add a proper kernel_stat.h for your architecture..." -#ifndef __USE_FILE_OFFSET64 -struct stat { +struct kernel_stat {  	unsigned short st_dev;  	unsigned short __pad1;  	unsigned long st_ino; @@ -29,34 +28,8 @@ struct stat {  	unsigned long  __unused4;  	unsigned long  __unused5;  }; -#else -struct stat { -	unsigned short	st_dev; -	unsigned char	__pad0[10]; -#define STAT64_HAS_BROKEN_ST_INO	1 -	unsigned long	__st_ino; -	unsigned int	st_mode; -	unsigned int	st_nlink; -	unsigned long	st_uid; -	unsigned long	st_gid; -	unsigned short	st_rdev; -	unsigned char	__pad3[10]; -	long long	st_size; -	unsigned long	st_blksize; -	unsigned long	st_blocks;	/* Number 512-byte blocks allocated. */ -	unsigned long	__pad4;		/* future possible st_blocks high bits */ -	unsigned long	st_atime; -	unsigned long	__pad5; -	unsigned long	st_mtime; -	unsigned long	__pad6; -	unsigned long	st_ctime; -	unsigned long	__pad7;		/* will be high 32 bits of ctime someday */ -	unsigned long long	st_ino; -}; -#endif -#ifdef __USE_LARGEFILE64 -struct stat64 { +struct kernel_stat64 {  	unsigned short	st_dev;  	unsigned char	__pad0[10];  #define STAT64_HAS_BROKEN_ST_INO	1 @@ -79,7 +52,6 @@ struct stat64 {  	unsigned long	__pad7;		/* will be high 32 bits of ctime someday */  	unsigned long long	st_ino;  }; -#endif  #endif	/*  _BITS_STAT_STRUCT_H */ diff --git a/libc/sysdeps/linux/common/bits/stat.h b/libc/sysdeps/linux/common/bits/stat.h index 942accda1..3ecec4a47 100644 --- a/libc/sysdeps/linux/common/bits/stat.h +++ b/libc/sysdeps/linux/common/bits/stat.h @@ -35,10 +35,74 @@  #define _MKNOD_VER_SVR4		2  #define _MKNOD_VER		_MKNOD_VER_LINUX /* The bits defined below.  */ -/* Pull in whatever this particular arch's kernel thinks that struct stat  - * should look like.  It turns out that each arch has a different opinion  - * on the subject, and different kernel revs use different names... */ -#include <bits/kernel_stat.h> +struct stat +{ +    __dev_t st_dev;			/* Device.  */ +    unsigned short int __pad1; +#ifndef __USE_FILE_OFFSET64 +    __ino_t st_ino;			/* File serial number.	*/ +#else +    __ino_t __st_ino;			/* 32bit file serial number.	*/ +#endif +    __mode_t st_mode;			/* File mode.  */ +    __nlink_t st_nlink;			/* Link count.  */ +    __uid_t st_uid;			/* User ID of the file's owner.	*/ +    __gid_t st_gid;			/* Group ID of the file's group.*/ +    __dev_t st_rdev;			/* Device number, if device.  */ +    unsigned short int __pad2; +#ifndef __USE_FILE_OFFSET64 +    __off_t st_size;			/* Size of file, in bytes.  */ +#else +    __off64_t st_size;			/* Size of file, in bytes.  */ +#endif +    __blksize_t st_blksize;		/* Optimal block size for I/O.  */ + +#ifndef __USE_FILE_OFFSET64 +    __blkcnt_t st_blocks;		/* Number 512-byte blocks allocated. */ +#else +    __blkcnt64_t st_blocks;		/* Number 512-byte blocks allocated. */ +#endif +    __time_t st_atime;			/* Time of last access.  */ +    unsigned long int __unused1; +    __time_t st_mtime;			/* Time of last modification.  */ +    unsigned long int __unused2; +    __time_t st_ctime;			/* Time of last status change.  */ +    unsigned long int __unused3; +#ifndef __USE_FILE_OFFSET64 +    unsigned long int __unused4; +    unsigned long int __unused5; +#else +    __ino64_t st_ino;			/* File serial number.	*/ +#endif +}; + +#ifdef __USE_LARGEFILE64 +struct stat64 +{ +    __dev_t st_dev;			/* Device.  */ +    unsigned int __pad1; + +    __ino_t __st_ino;			/* 32bit file serial number.	*/ +    __mode_t st_mode;			/* File mode.  */ +    __nlink_t st_nlink;			/* Link count.  */ +    __uid_t st_uid;			/* User ID of the file's owner.	*/ +    __gid_t st_gid;			/* Group ID of the file's group.*/ +    __dev_t st_rdev;			/* Device number, if device.  */ +    unsigned int __pad2; +    __off64_t st_size;			/* Size of file, in bytes.  */ +    __blksize_t st_blksize;		/* Optimal block size for I/O.  */ + +    __blkcnt64_t st_blocks;		/* Number 512-byte blocks allocated. */ +    __time_t st_atime;			/* Time of last access.  */ +    unsigned long int __unused1; +    __time_t st_mtime;			/* Time of last modification.  */ +    unsigned long int __unused2; +    __time_t st_ctime;			/* Time of last status change.  */ +    unsigned long int __unused3; +    __ino64_t st_ino;			/* File serial number.		*/ +}; +#endif +  /* Tell code we have these members.  */  #define	_STATBUF_ST_BLKSIZE  | 
