diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2008-01-08 04:05:03 -0500 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2008-01-27 23:19:02 -0500 |
| commit | e08d8aaeadac37c8d149b5d5bda6cf7a98d21e92 (patch) | |
| tree | ce4d8d2d91bdc51984a46c4966e9547a6cc370b9 /include/asm-sh | |
| parent | 6e3037d30e0abb8e84d0e05144b99047d5bab897 (diff) | |
sh: Fix posix_types.h userspace breakage from sh64 merge.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'include/asm-sh')
| -rw-r--r-- | include/asm-sh/Kbuild | 5 | ||||
| -rw-r--r-- | include/asm-sh/posix_types.h | 129 | ||||
| -rw-r--r-- | include/asm-sh/posix_types_32.h | 122 | ||||
| -rw-r--r-- | include/asm-sh/posix_types_64.h | 131 |
4 files changed, 265 insertions, 122 deletions
diff --git a/include/asm-sh/Kbuild b/include/asm-sh/Kbuild index 76a8ccf254a5..43910cdf78a5 100644 --- a/include/asm-sh/Kbuild +++ b/include/asm-sh/Kbuild | |||
| @@ -1,3 +1,8 @@ | |||
| 1 | include include/asm-generic/Kbuild.asm | 1 | include include/asm-generic/Kbuild.asm |
| 2 | 2 | ||
| 3 | header-y += cpu-features.h | 3 | header-y += cpu-features.h |
| 4 | |||
| 5 | unifdef-y += unistd_32.h | ||
| 6 | unifdef-y += unistd_64.h | ||
| 7 | unifdef-y += posix_types_32.h | ||
| 8 | unifdef-y += posix_types_64.h | ||
diff --git a/include/asm-sh/posix_types.h b/include/asm-sh/posix_types.h index 0a3d2f54ab27..4b9d11c9fc77 100644 --- a/include/asm-sh/posix_types.h +++ b/include/asm-sh/posix_types.h | |||
| @@ -1,122 +1,7 @@ | |||
| 1 | #ifndef __ASM_SH_POSIX_TYPES_H | 1 | #ifdef __KERNEL__ |
| 2 | #define __ASM_SH_POSIX_TYPES_H | 2 | # ifdef CONFIG_SUPERH32 |
| 3 | 3 | # include "posix_types_32.h" | |
| 4 | /* | 4 | # else |
| 5 | * This file is generally used by user-level software, so you need to | 5 | # include "posix_types_64.h" |
| 6 | * be a little careful about namespace pollution etc. Also, we cannot | 6 | # endif |
| 7 | * assume GCC is being used. | 7 | #endif /* __KERNEL__ */ |
| 8 | */ | ||
| 9 | |||
| 10 | typedef unsigned long __kernel_ino_t; | ||
| 11 | typedef unsigned short __kernel_mode_t; | ||
| 12 | typedef unsigned short __kernel_nlink_t; | ||
| 13 | typedef long __kernel_off_t; | ||
| 14 | typedef int __kernel_pid_t; | ||
| 15 | typedef unsigned short __kernel_ipc_pid_t; | ||
| 16 | typedef unsigned short __kernel_uid_t; | ||
| 17 | typedef unsigned short __kernel_gid_t; | ||
| 18 | typedef unsigned int __kernel_size_t; | ||
| 19 | typedef int __kernel_ssize_t; | ||
| 20 | typedef int __kernel_ptrdiff_t; | ||
| 21 | typedef long __kernel_time_t; | ||
| 22 | typedef long __kernel_suseconds_t; | ||
| 23 | typedef long __kernel_clock_t; | ||
| 24 | typedef int __kernel_timer_t; | ||
| 25 | typedef int __kernel_clockid_t; | ||
| 26 | typedef int __kernel_daddr_t; | ||
| 27 | typedef char * __kernel_caddr_t; | ||
| 28 | typedef unsigned short __kernel_uid16_t; | ||
| 29 | typedef unsigned short __kernel_gid16_t; | ||
| 30 | typedef unsigned int __kernel_uid32_t; | ||
| 31 | typedef unsigned int __kernel_gid32_t; | ||
| 32 | |||
| 33 | typedef unsigned short __kernel_old_uid_t; | ||
| 34 | typedef unsigned short __kernel_old_gid_t; | ||
| 35 | typedef unsigned short __kernel_old_dev_t; | ||
| 36 | |||
| 37 | #ifdef __GNUC__ | ||
| 38 | typedef long long __kernel_loff_t; | ||
| 39 | #endif | ||
| 40 | |||
| 41 | typedef struct { | ||
| 42 | #if defined(__KERNEL__) || defined(__USE_ALL) | ||
| 43 | int val[2]; | ||
| 44 | #else /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 45 | int __val[2]; | ||
| 46 | #endif /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 47 | } __kernel_fsid_t; | ||
| 48 | |||
| 49 | #if defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) | ||
| 50 | |||
| 51 | #undef __FD_SET | ||
| 52 | static __inline__ void __FD_SET(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 53 | { | ||
| 54 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 55 | unsigned long __rem = __fd % __NFDBITS; | ||
| 56 | __fdsetp->fds_bits[__tmp] |= (1UL<<__rem); | ||
| 57 | } | ||
| 58 | |||
| 59 | #undef __FD_CLR | ||
| 60 | static __inline__ void __FD_CLR(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 61 | { | ||
| 62 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 63 | unsigned long __rem = __fd % __NFDBITS; | ||
| 64 | __fdsetp->fds_bits[__tmp] &= ~(1UL<<__rem); | ||
| 65 | } | ||
| 66 | |||
| 67 | |||
| 68 | #undef __FD_ISSET | ||
| 69 | static __inline__ int __FD_ISSET(unsigned long __fd, const __kernel_fd_set *__p) | ||
| 70 | { | ||
| 71 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 72 | unsigned long __rem = __fd % __NFDBITS; | ||
| 73 | return (__p->fds_bits[__tmp] & (1UL<<__rem)) != 0; | ||
| 74 | } | ||
| 75 | |||
| 76 | /* | ||
| 77 | * This will unroll the loop for the normal constant case (8 ints, | ||
| 78 | * for a 256-bit fd_set) | ||
| 79 | */ | ||
| 80 | #undef __FD_ZERO | ||
| 81 | static __inline__ void __FD_ZERO(__kernel_fd_set *__p) | ||
| 82 | { | ||
| 83 | unsigned long *__tmp = __p->fds_bits; | ||
| 84 | int __i; | ||
| 85 | |||
| 86 | if (__builtin_constant_p(__FDSET_LONGS)) { | ||
| 87 | switch (__FDSET_LONGS) { | ||
| 88 | case 16: | ||
| 89 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 90 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 91 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 92 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 93 | __tmp[ 8] = 0; __tmp[ 9] = 0; | ||
| 94 | __tmp[10] = 0; __tmp[11] = 0; | ||
| 95 | __tmp[12] = 0; __tmp[13] = 0; | ||
| 96 | __tmp[14] = 0; __tmp[15] = 0; | ||
| 97 | return; | ||
| 98 | |||
| 99 | case 8: | ||
| 100 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 101 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 102 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 103 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 104 | return; | ||
| 105 | |||
| 106 | case 4: | ||
| 107 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 108 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 109 | return; | ||
| 110 | } | ||
| 111 | } | ||
| 112 | __i = __FDSET_LONGS; | ||
| 113 | while (__i) { | ||
| 114 | __i--; | ||
| 115 | *__tmp = 0; | ||
| 116 | __tmp++; | ||
| 117 | } | ||
| 118 | } | ||
| 119 | |||
| 120 | #endif /* defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) */ | ||
| 121 | |||
| 122 | #endif /* __ASM_SH_POSIX_TYPES_H */ | ||
diff --git a/include/asm-sh/posix_types_32.h b/include/asm-sh/posix_types_32.h new file mode 100644 index 000000000000..0a3d2f54ab27 --- /dev/null +++ b/include/asm-sh/posix_types_32.h | |||
| @@ -0,0 +1,122 @@ | |||
| 1 | #ifndef __ASM_SH_POSIX_TYPES_H | ||
| 2 | #define __ASM_SH_POSIX_TYPES_H | ||
| 3 | |||
| 4 | /* | ||
| 5 | * This file is generally used by user-level software, so you need to | ||
| 6 | * be a little careful about namespace pollution etc. Also, we cannot | ||
| 7 | * assume GCC is being used. | ||
| 8 | */ | ||
| 9 | |||
| 10 | typedef unsigned long __kernel_ino_t; | ||
| 11 | typedef unsigned short __kernel_mode_t; | ||
| 12 | typedef unsigned short __kernel_nlink_t; | ||
| 13 | typedef long __kernel_off_t; | ||
| 14 | typedef int __kernel_pid_t; | ||
| 15 | typedef unsigned short __kernel_ipc_pid_t; | ||
| 16 | typedef unsigned short __kernel_uid_t; | ||
| 17 | typedef unsigned short __kernel_gid_t; | ||
| 18 | typedef unsigned int __kernel_size_t; | ||
| 19 | typedef int __kernel_ssize_t; | ||
| 20 | typedef int __kernel_ptrdiff_t; | ||
| 21 | typedef long __kernel_time_t; | ||
| 22 | typedef long __kernel_suseconds_t; | ||
| 23 | typedef long __kernel_clock_t; | ||
| 24 | typedef int __kernel_timer_t; | ||
| 25 | typedef int __kernel_clockid_t; | ||
| 26 | typedef int __kernel_daddr_t; | ||
| 27 | typedef char * __kernel_caddr_t; | ||
| 28 | typedef unsigned short __kernel_uid16_t; | ||
| 29 | typedef unsigned short __kernel_gid16_t; | ||
| 30 | typedef unsigned int __kernel_uid32_t; | ||
| 31 | typedef unsigned int __kernel_gid32_t; | ||
| 32 | |||
| 33 | typedef unsigned short __kernel_old_uid_t; | ||
| 34 | typedef unsigned short __kernel_old_gid_t; | ||
| 35 | typedef unsigned short __kernel_old_dev_t; | ||
| 36 | |||
| 37 | #ifdef __GNUC__ | ||
| 38 | typedef long long __kernel_loff_t; | ||
| 39 | #endif | ||
| 40 | |||
| 41 | typedef struct { | ||
| 42 | #if defined(__KERNEL__) || defined(__USE_ALL) | ||
| 43 | int val[2]; | ||
| 44 | #else /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 45 | int __val[2]; | ||
| 46 | #endif /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 47 | } __kernel_fsid_t; | ||
| 48 | |||
| 49 | #if defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) | ||
| 50 | |||
| 51 | #undef __FD_SET | ||
| 52 | static __inline__ void __FD_SET(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 53 | { | ||
| 54 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 55 | unsigned long __rem = __fd % __NFDBITS; | ||
| 56 | __fdsetp->fds_bits[__tmp] |= (1UL<<__rem); | ||
| 57 | } | ||
| 58 | |||
| 59 | #undef __FD_CLR | ||
| 60 | static __inline__ void __FD_CLR(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 61 | { | ||
| 62 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 63 | unsigned long __rem = __fd % __NFDBITS; | ||
| 64 | __fdsetp->fds_bits[__tmp] &= ~(1UL<<__rem); | ||
| 65 | } | ||
| 66 | |||
| 67 | |||
| 68 | #undef __FD_ISSET | ||
| 69 | static __inline__ int __FD_ISSET(unsigned long __fd, const __kernel_fd_set *__p) | ||
| 70 | { | ||
| 71 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 72 | unsigned long __rem = __fd % __NFDBITS; | ||
| 73 | return (__p->fds_bits[__tmp] & (1UL<<__rem)) != 0; | ||
| 74 | } | ||
| 75 | |||
| 76 | /* | ||
| 77 | * This will unroll the loop for the normal constant case (8 ints, | ||
| 78 | * for a 256-bit fd_set) | ||
| 79 | */ | ||
| 80 | #undef __FD_ZERO | ||
| 81 | static __inline__ void __FD_ZERO(__kernel_fd_set *__p) | ||
| 82 | { | ||
| 83 | unsigned long *__tmp = __p->fds_bits; | ||
| 84 | int __i; | ||
| 85 | |||
| 86 | if (__builtin_constant_p(__FDSET_LONGS)) { | ||
| 87 | switch (__FDSET_LONGS) { | ||
| 88 | case 16: | ||
| 89 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 90 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 91 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 92 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 93 | __tmp[ 8] = 0; __tmp[ 9] = 0; | ||
| 94 | __tmp[10] = 0; __tmp[11] = 0; | ||
| 95 | __tmp[12] = 0; __tmp[13] = 0; | ||
| 96 | __tmp[14] = 0; __tmp[15] = 0; | ||
| 97 | return; | ||
| 98 | |||
| 99 | case 8: | ||
| 100 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 101 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 102 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 103 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 104 | return; | ||
| 105 | |||
| 106 | case 4: | ||
| 107 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 108 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 109 | return; | ||
| 110 | } | ||
| 111 | } | ||
| 112 | __i = __FDSET_LONGS; | ||
| 113 | while (__i) { | ||
| 114 | __i--; | ||
| 115 | *__tmp = 0; | ||
| 116 | __tmp++; | ||
| 117 | } | ||
| 118 | } | ||
| 119 | |||
| 120 | #endif /* defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) */ | ||
| 121 | |||
| 122 | #endif /* __ASM_SH_POSIX_TYPES_H */ | ||
diff --git a/include/asm-sh/posix_types_64.h b/include/asm-sh/posix_types_64.h new file mode 100644 index 000000000000..0620317a6f0f --- /dev/null +++ b/include/asm-sh/posix_types_64.h | |||
| @@ -0,0 +1,131 @@ | |||
| 1 | #ifndef __ASM_SH64_POSIX_TYPES_H | ||
| 2 | #define __ASM_SH64_POSIX_TYPES_H | ||
| 3 | |||
| 4 | /* | ||
| 5 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 6 | * License. See the file "COPYING" in the main directory of this archive | ||
| 7 | * for more details. | ||
| 8 | * | ||
| 9 | * include/asm-sh64/posix_types.h | ||
| 10 | * | ||
| 11 | * Copyright (C) 2000, 2001 Paolo Alberelli | ||
| 12 | * Copyright (C) 2003 Paul Mundt | ||
| 13 | * | ||
| 14 | * This file is generally used by user-level software, so you need to | ||
| 15 | * be a little careful about namespace pollution etc. Also, we cannot | ||
| 16 | * assume GCC is being used. | ||
| 17 | */ | ||
| 18 | |||
| 19 | typedef unsigned long __kernel_ino_t; | ||
| 20 | typedef unsigned short __kernel_mode_t; | ||
| 21 | typedef unsigned short __kernel_nlink_t; | ||
| 22 | typedef long __kernel_off_t; | ||
| 23 | typedef int __kernel_pid_t; | ||
| 24 | typedef unsigned short __kernel_ipc_pid_t; | ||
| 25 | typedef unsigned short __kernel_uid_t; | ||
| 26 | typedef unsigned short __kernel_gid_t; | ||
| 27 | typedef long unsigned int __kernel_size_t; | ||
| 28 | typedef int __kernel_ssize_t; | ||
| 29 | typedef int __kernel_ptrdiff_t; | ||
| 30 | typedef long __kernel_time_t; | ||
| 31 | typedef long __kernel_suseconds_t; | ||
| 32 | typedef long __kernel_clock_t; | ||
| 33 | typedef int __kernel_timer_t; | ||
| 34 | typedef int __kernel_clockid_t; | ||
| 35 | typedef int __kernel_daddr_t; | ||
| 36 | typedef char * __kernel_caddr_t; | ||
| 37 | typedef unsigned short __kernel_uid16_t; | ||
| 38 | typedef unsigned short __kernel_gid16_t; | ||
| 39 | typedef unsigned int __kernel_uid32_t; | ||
| 40 | typedef unsigned int __kernel_gid32_t; | ||
| 41 | |||
| 42 | typedef unsigned short __kernel_old_uid_t; | ||
| 43 | typedef unsigned short __kernel_old_gid_t; | ||
| 44 | typedef unsigned short __kernel_old_dev_t; | ||
| 45 | |||
| 46 | #ifdef __GNUC__ | ||
| 47 | typedef long long __kernel_loff_t; | ||
| 48 | #endif | ||
| 49 | |||
| 50 | typedef struct { | ||
| 51 | #if defined(__KERNEL__) || defined(__USE_ALL) | ||
| 52 | int val[2]; | ||
| 53 | #else /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 54 | int __val[2]; | ||
| 55 | #endif /* !defined(__KERNEL__) && !defined(__USE_ALL) */ | ||
| 56 | } __kernel_fsid_t; | ||
| 57 | |||
| 58 | #if defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) | ||
| 59 | |||
| 60 | #undef __FD_SET | ||
| 61 | static __inline__ void __FD_SET(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 62 | { | ||
| 63 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 64 | unsigned long __rem = __fd % __NFDBITS; | ||
| 65 | __fdsetp->fds_bits[__tmp] |= (1UL<<__rem); | ||
| 66 | } | ||
| 67 | |||
| 68 | #undef __FD_CLR | ||
| 69 | static __inline__ void __FD_CLR(unsigned long __fd, __kernel_fd_set *__fdsetp) | ||
| 70 | { | ||
| 71 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 72 | unsigned long __rem = __fd % __NFDBITS; | ||
| 73 | __fdsetp->fds_bits[__tmp] &= ~(1UL<<__rem); | ||
| 74 | } | ||
| 75 | |||
| 76 | |||
| 77 | #undef __FD_ISSET | ||
| 78 | static __inline__ int __FD_ISSET(unsigned long __fd, const __kernel_fd_set *__p) | ||
| 79 | { | ||
| 80 | unsigned long __tmp = __fd / __NFDBITS; | ||
| 81 | unsigned long __rem = __fd % __NFDBITS; | ||
| 82 | return (__p->fds_bits[__tmp] & (1UL<<__rem)) != 0; | ||
| 83 | } | ||
| 84 | |||
| 85 | /* | ||
| 86 | * This will unroll the loop for the normal constant case (8 ints, | ||
| 87 | * for a 256-bit fd_set) | ||
| 88 | */ | ||
| 89 | #undef __FD_ZERO | ||
| 90 | static __inline__ void __FD_ZERO(__kernel_fd_set *__p) | ||
| 91 | { | ||
| 92 | unsigned long *__tmp = __p->fds_bits; | ||
| 93 | int __i; | ||
| 94 | |||
| 95 | if (__builtin_constant_p(__FDSET_LONGS)) { | ||
| 96 | switch (__FDSET_LONGS) { | ||
| 97 | case 16: | ||
| 98 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 99 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 100 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 101 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 102 | __tmp[ 8] = 0; __tmp[ 9] = 0; | ||
| 103 | __tmp[10] = 0; __tmp[11] = 0; | ||
| 104 | __tmp[12] = 0; __tmp[13] = 0; | ||
| 105 | __tmp[14] = 0; __tmp[15] = 0; | ||
| 106 | return; | ||
| 107 | |||
| 108 | case 8: | ||
| 109 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 110 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 111 | __tmp[ 4] = 0; __tmp[ 5] = 0; | ||
| 112 | __tmp[ 6] = 0; __tmp[ 7] = 0; | ||
| 113 | return; | ||
| 114 | |||
| 115 | case 4: | ||
| 116 | __tmp[ 0] = 0; __tmp[ 1] = 0; | ||
| 117 | __tmp[ 2] = 0; __tmp[ 3] = 0; | ||
| 118 | return; | ||
| 119 | } | ||
| 120 | } | ||
| 121 | __i = __FDSET_LONGS; | ||
| 122 | while (__i) { | ||
| 123 | __i--; | ||
| 124 | *__tmp = 0; | ||
| 125 | __tmp++; | ||
| 126 | } | ||
| 127 | } | ||
| 128 | |||
| 129 | #endif /* defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2) */ | ||
| 130 | |||
| 131 | #endif /* __ASM_SH64_POSIX_TYPES_H */ | ||
