diff options
author | Arnd Bergmann <arnd@arndb.de> | 2007-07-16 02:41:11 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-16 12:05:48 -0400 |
commit | 4b7775870b69129e640ed583c9b362d5cd66159d (patch) | |
tree | 3634c3fb91c927cfd9b4e5751e06463537849ce3 | |
parent | 6d9525b52aecd11b14c4ec982add01c11157172f (diff) |
Introduce compat_u64 and compat_s64 types
One common problem with 32 bit system call and ioctl emulation is the
different alignment rules between i386 and 64 bit machines. A number of
drivers work around this by marking the compat structures as
'attribute((packed))', which is not the right solution because it breaks
all the non-x86 architectures that want to use the same compat code.
Hopefully, this patch improves the situation, it introduces two new types,
compat_u64 and compat_s64. These are defined on all architectures to have
the same size and alignment as the 32 bit version of u64 and s64.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: David S. Miller <davem@davemloft.net>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Andi Kleen <ak@suse.de>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Vasily Tarasov <vtaras@openvz.org>
Cc: <linux-arch@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | include/asm-ia64/compat.h | 2 | ||||
-rw-r--r-- | include/asm-mips/compat.h | 2 | ||||
-rw-r--r-- | include/asm-parisc/compat.h | 2 | ||||
-rw-r--r-- | include/asm-powerpc/compat.h | 2 | ||||
-rw-r--r-- | include/asm-s390/compat.h | 2 | ||||
-rw-r--r-- | include/asm-sparc64/compat.h | 2 | ||||
-rw-r--r-- | include/asm-x86_64/compat.h | 2 |
7 files changed, 14 insertions, 0 deletions
diff --git a/include/asm-ia64/compat.h b/include/asm-ia64/compat.h index 40d01d80610d..0f6e5264ab8f 100644 --- a/include/asm-ia64/compat.h +++ b/include/asm-ia64/compat.h | |||
@@ -31,8 +31,10 @@ typedef s32 compat_timer_t; | |||
31 | 31 | ||
32 | typedef s32 compat_int_t; | 32 | typedef s32 compat_int_t; |
33 | typedef s32 compat_long_t; | 33 | typedef s32 compat_long_t; |
34 | typedef s64 __attribute__((aligned(4))) compat_s64; | ||
34 | typedef u32 compat_uint_t; | 35 | typedef u32 compat_uint_t; |
35 | typedef u32 compat_ulong_t; | 36 | typedef u32 compat_ulong_t; |
37 | typedef u64 __attribute__((aligned(4))) compat_u64; | ||
36 | 38 | ||
37 | struct compat_timespec { | 39 | struct compat_timespec { |
38 | compat_time_t tv_sec; | 40 | compat_time_t tv_sec; |
diff --git a/include/asm-mips/compat.h b/include/asm-mips/compat.h index 67c3f8ec0303..568c76cdd900 100644 --- a/include/asm-mips/compat.h +++ b/include/asm-mips/compat.h | |||
@@ -37,8 +37,10 @@ typedef s32 compat_key_t; | |||
37 | 37 | ||
38 | typedef s32 compat_int_t; | 38 | typedef s32 compat_int_t; |
39 | typedef s32 compat_long_t; | 39 | typedef s32 compat_long_t; |
40 | typedef s64 compat_s64; | ||
40 | typedef u32 compat_uint_t; | 41 | typedef u32 compat_uint_t; |
41 | typedef u32 compat_ulong_t; | 42 | typedef u32 compat_ulong_t; |
43 | typedef u64 compat_u64; | ||
42 | 44 | ||
43 | struct compat_timespec { | 45 | struct compat_timespec { |
44 | compat_time_t tv_sec; | 46 | compat_time_t tv_sec; |
diff --git a/include/asm-parisc/compat.h b/include/asm-parisc/compat.h index 11f4222597a0..5a85d1b025c8 100644 --- a/include/asm-parisc/compat.h +++ b/include/asm-parisc/compat.h | |||
@@ -31,8 +31,10 @@ typedef s32 compat_timer_t; | |||
31 | 31 | ||
32 | typedef s32 compat_int_t; | 32 | typedef s32 compat_int_t; |
33 | typedef s32 compat_long_t; | 33 | typedef s32 compat_long_t; |
34 | typedef s64 compat_s64; | ||
34 | typedef u32 compat_uint_t; | 35 | typedef u32 compat_uint_t; |
35 | typedef u32 compat_ulong_t; | 36 | typedef u32 compat_ulong_t; |
37 | typedef u64 compat_u64; | ||
36 | 38 | ||
37 | struct compat_timespec { | 39 | struct compat_timespec { |
38 | compat_time_t tv_sec; | 40 | compat_time_t tv_sec; |
diff --git a/include/asm-powerpc/compat.h b/include/asm-powerpc/compat.h index aacaabd28ac1..64ab1ddbdf85 100644 --- a/include/asm-powerpc/compat.h +++ b/include/asm-powerpc/compat.h | |||
@@ -33,8 +33,10 @@ typedef s32 compat_timer_t; | |||
33 | 33 | ||
34 | typedef s32 compat_int_t; | 34 | typedef s32 compat_int_t; |
35 | typedef s32 compat_long_t; | 35 | typedef s32 compat_long_t; |
36 | typedef s64 compat_s64; | ||
36 | typedef u32 compat_uint_t; | 37 | typedef u32 compat_uint_t; |
37 | typedef u32 compat_ulong_t; | 38 | typedef u32 compat_ulong_t; |
39 | typedef u64 compat_u64; | ||
38 | 40 | ||
39 | struct compat_timespec { | 41 | struct compat_timespec { |
40 | compat_time_t tv_sec; | 42 | compat_time_t tv_sec; |
diff --git a/include/asm-s390/compat.h b/include/asm-s390/compat.h index 296f4f1a20e1..7f4ad623f7d5 100644 --- a/include/asm-s390/compat.h +++ b/include/asm-s390/compat.h | |||
@@ -60,8 +60,10 @@ typedef s32 compat_timer_t; | |||
60 | 60 | ||
61 | typedef s32 compat_int_t; | 61 | typedef s32 compat_int_t; |
62 | typedef s32 compat_long_t; | 62 | typedef s32 compat_long_t; |
63 | typedef s64 compat_s64; | ||
63 | typedef u32 compat_uint_t; | 64 | typedef u32 compat_uint_t; |
64 | typedef u32 compat_ulong_t; | 65 | typedef u32 compat_ulong_t; |
66 | typedef u64 compat_u64; | ||
65 | 67 | ||
66 | struct compat_timespec { | 68 | struct compat_timespec { |
67 | compat_time_t tv_sec; | 69 | compat_time_t tv_sec; |
diff --git a/include/asm-sparc64/compat.h b/include/asm-sparc64/compat.h index 36511ca51416..01fe6682b405 100644 --- a/include/asm-sparc64/compat.h +++ b/include/asm-sparc64/compat.h | |||
@@ -31,8 +31,10 @@ typedef s32 compat_timer_t; | |||
31 | 31 | ||
32 | typedef s32 compat_int_t; | 32 | typedef s32 compat_int_t; |
33 | typedef s32 compat_long_t; | 33 | typedef s32 compat_long_t; |
34 | typedef s64 compat_s64; | ||
34 | typedef u32 compat_uint_t; | 35 | typedef u32 compat_uint_t; |
35 | typedef u32 compat_ulong_t; | 36 | typedef u32 compat_ulong_t; |
37 | typedef u64 compat_u64; | ||
36 | 38 | ||
37 | struct compat_timespec { | 39 | struct compat_timespec { |
38 | compat_time_t tv_sec; | 40 | compat_time_t tv_sec; |
diff --git a/include/asm-x86_64/compat.h b/include/asm-x86_64/compat.h index b37ab8218ef0..53cb96b68a62 100644 --- a/include/asm-x86_64/compat.h +++ b/include/asm-x86_64/compat.h | |||
@@ -33,8 +33,10 @@ typedef s32 compat_key_t; | |||
33 | 33 | ||
34 | typedef s32 compat_int_t; | 34 | typedef s32 compat_int_t; |
35 | typedef s32 compat_long_t; | 35 | typedef s32 compat_long_t; |
36 | typedef s64 __attribute__((aligned(4))) compat_s64; | ||
36 | typedef u32 compat_uint_t; | 37 | typedef u32 compat_uint_t; |
37 | typedef u32 compat_ulong_t; | 38 | typedef u32 compat_ulong_t; |
39 | typedef u64 __attribute__((aligned(4))) compat_u64; | ||
38 | 40 | ||
39 | struct compat_timespec { | 41 | struct compat_timespec { |
40 | compat_time_t tv_sec; | 42 | compat_time_t tv_sec; |