diff options
| author | Eric Andersen <andersen@codepoet.org> | 2003-01-24 11:44:14 +0000 | 
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2003-01-24 11:44:14 +0000 | 
| commit | 85800279bcad0b3495ccc22374f42cd04675f9e4 (patch) | |
| tree | 30f6754fb734191d6cd7d3fad292a94c02430418 /libc/sysdeps/linux/sh/bits | |
| parent | 8c29bb071a5d7f6cf8edb26b93bd9e48d4ad3df1 (diff) | |
Ok, people are probably going to hate me for this...  This commit changes the
type of 'struct stat' and 'struct stat64' so they use consistant types.
This change is the result of a bug I found while trying to use GNU tar.  The
problem was caused by our using kernel types within struct stat and trying to
directly compare these values with standard types.  Trying an 'if (a < b)' when
'a' is an 'unsigned long' and 'b' is an 'int' leads to very different results
then when comparing entities of the same type (i.e. time_t values)....
Grumble.  Nasty stuff, but I'm glad I got this out of the way now.
As a result of this fix, uClibc 0.9.17 will not be binary compatible with
earlier releases.  I have always warned people this can and will happen.
 -Erik
Diffstat (limited to 'libc/sysdeps/linux/sh/bits')
| -rw-r--r-- | libc/sysdeps/linux/sh/bits/kernel_stat.h | 63 | 
1 files changed, 3 insertions, 60 deletions
| diff --git a/libc/sysdeps/linux/sh/bits/kernel_stat.h b/libc/sysdeps/linux/sh/bits/kernel_stat.h index 3dc6ebdbf..cd818464d 100644 --- a/libc/sysdeps/linux/sh/bits/kernel_stat.h +++ b/libc/sysdeps/linux/sh/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... */  #include <endian.h> -#ifndef __USE_FILE_OFFSET64 -struct stat { +struct kernel_stat {  	unsigned short st_dev;  	unsigned short __pad1;  	unsigned long st_ino; @@ -29,62 +28,8 @@ struct stat {  	unsigned long  __unused4;  	unsigned long  __unused5;  }; -#else -struct stat { -#if defined(__BIG_ENDIAN__) -	unsigned char   __pad0b[6]; -	unsigned short	st_dev; -#elif defined(__LITTLE_ENDIAN__) -	unsigned short	st_dev; -	unsigned char	__pad0b[6]; -#else -#error Must know endian to build stat64 structure! -#endif -	unsigned char	__pad0[4]; - -	unsigned long	st_ino; -	unsigned int	st_mode; -	unsigned int	st_nlink; - -	unsigned long	st_uid; -	unsigned long	st_gid; - -#if defined(__BIG_ENDIAN__) -	unsigned char	__pad3b[6]; -	unsigned short	st_rdev; -#else /* Must be little */ -	unsigned short	st_rdev; -	unsigned char	__pad3b[6]; -#endif -	unsigned char	__pad3[4]; - -	long long	st_size; -	unsigned long	st_blksize; -#if defined(__BIG_ENDIAN__) -	unsigned long	__pad4;		/* Future possible st_blocks hi bits */ -	unsigned long	st_blocks;	/* Number 512-byte blocks allocated. */ -#else /* Must be little */ -	unsigned long	st_blocks;	/* Number 512-byte blocks allocated. */ -	unsigned long	__pad4;		/* Future possible st_blocks hi bits */ -#endif - -	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	__unused1; -	unsigned long	__unused2; -}; -#endif - -#ifdef __USE_LARGEFILE64 -struct stat64 { +struct kernel_stat64 {  #if defined(__BIG_ENDIAN__)  	unsigned char   __pad0b[6];  	unsigned short	st_dev; @@ -135,8 +80,6 @@ struct stat64 {  	unsigned long	__unused1;  	unsigned long	__unused2;  }; -#endif -  #endif	/*  _BITS_STAT_STRUCT_H */ | 
