Commit dce80777 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] statfs64 fix

From: Andi Kleen <ak@muc.de>

It fixes the statfs64 emulation on x86-64.  The problem is that x86-64
needs an __attribute__((aligned)) on the compat_statfs64 structure.  The
conclusion last time this was discussed was that the structure should be
duplicated.

Essentially it is the old shared structure copied to every user and x86-64
uses __attribute__((packed)).
parent 85734c47
...@@ -34,4 +34,18 @@ struct statfs64 { ...@@ -34,4 +34,18 @@ struct statfs64 {
__u32 f_spare[5]; __u32 f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif #endif
...@@ -43,5 +43,18 @@ struct statfs64 { ...@@ -43,5 +43,18 @@ struct statfs64 {
long f_spare[5]; long f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
} __attribute__((packed));
#endif /* _ASM_IA64_STATFS_H */ #endif /* _ASM_IA64_STATFS_H */
...@@ -75,6 +75,20 @@ struct statfs64 { /* Same as struct statfs */ ...@@ -75,6 +75,20 @@ struct statfs64 { /* Same as struct statfs */
long f_spare[6]; long f_spare[6];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */ #endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */
#endif /* _ASM_STATFS_H */ #endif /* _ASM_STATFS_H */
...@@ -41,4 +41,18 @@ struct statfs64 { ...@@ -41,4 +41,18 @@ struct statfs64 {
long f_spare[5]; long f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif #endif
...@@ -44,4 +44,18 @@ struct statfs64 { ...@@ -44,4 +44,18 @@ struct statfs64 {
long f_spare[5]; long f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif /* _PPC64_STATFS_H */ #endif /* _PPC64_STATFS_H */
...@@ -53,5 +53,19 @@ struct statfs64 { ...@@ -53,5 +53,19 @@ struct statfs64 {
int f_spare[5]; int f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif /* __s390x__ */ #endif /* __s390x__ */
#endif #endif
...@@ -38,4 +38,18 @@ struct statfs64 { ...@@ -38,4 +38,18 @@ struct statfs64 {
long f_spare[5]; long f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
#endif #endif
...@@ -41,4 +41,18 @@ struct statfs64 { ...@@ -41,4 +41,18 @@ struct statfs64 {
long f_spare[5]; long f_spare[5];
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
} __attribute__((packed));
#endif #endif
...@@ -76,20 +76,6 @@ struct compat_rusage { ...@@ -76,20 +76,6 @@ struct compat_rusage {
compat_long_t ru_nivcsw; compat_long_t ru_nivcsw;
}; };
struct compat_statfs64 {
__u32 f_type;
__u32 f_bsize;
__u64 f_blocks;
__u64 f_bfree;
__u64 f_bavail;
__u64 f_files;
__u64 f_ffree;
__kernel_fsid_t f_fsid;
__u32 f_namelen;
__u32 f_frsize;
__u32 f_spare[5];
};
struct compat_dirent { struct compat_dirent {
u32 d_ino; u32 d_ino;
compat_off_t d_off; compat_off_t d_off;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment