diff options
author | Jakub Jelinek <jakub@redhat.com> | 2007-10-03 19:32:28 +0000 |
---|---|---|
committer | Jakub Jelinek <jakub@redhat.com> | 2007-10-03 19:32:28 +0000 |
commit | 75cb5a0d471729d28a59b693441e2d527c9e962e (patch) | |
tree | abac9733c1b6c0a7a9c760b7cfe2d21c672e9e90 /string | |
parent | 441097af93882803bbb3296dd1fdbdd4a7773deb (diff) | |
download | glibc-75cb5a0d471729d28a59b693441e2d527c9e962e.tar glibc-75cb5a0d471729d28a59b693441e2d527c9e962e.tar.gz glibc-75cb5a0d471729d28a59b693441e2d527c9e962e.tar.bz2 glibc-75cb5a0d471729d28a59b693441e2d527c9e962e.zip |
Updated to fedora-glibc-20071003T1908cvs/fedora-glibc-2_6_90-17
Diffstat (limited to 'string')
-rw-r--r-- | string/bits/string3.h | 130 | ||||
-rw-r--r-- | string/strcoll_l.c | 24 |
2 files changed, 21 insertions, 133 deletions
diff --git a/string/bits/string3.h b/string/bits/string3.h index 876fe77929..a5593e3b89 100644 --- a/string/bits/string3.h +++ b/string/bits/string3.h @@ -45,65 +45,27 @@ __warndecl (__warn_memset_zero_len, #endif -#ifdef __cplusplus __extern_always_inline void * __NTH (memcpy (void *__restrict __dest, __const void *__restrict __src, size_t __len)) { return __builtin___memcpy_chk (__dest, __src, __len, __bos0 (__dest)); } -#else -# define memcpy(dest, src, len) \ - ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___memcpy_chk (dest, src, len, __bos0 (dest)) \ - : __memcpy_ichk (dest, src, len)) -static __always_inline void * -__NTH (__memcpy_ichk (void *__restrict __dest, __const void *__restrict __src, - size_t __len)) -{ - return __builtin___memcpy_chk (__dest, __src, __len, __bos0 (__dest)); -} -#endif -#ifdef __cplusplus __extern_always_inline void * __NTH (memmove (void *__restrict __dest, __const void *__restrict __src, size_t __len)) { return __builtin___memmove_chk (__dest, __src, __len, __bos0 (__dest)); } -#else -# define memmove(dest, src, len) \ - ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___memmove_chk (dest, src, len, __bos0 (dest)) \ - : __memmove_ichk (dest, src, len)) -static __always_inline void * -__NTH (__memmove_ichk (void *__dest, __const void *__src, size_t __len)) -{ - return __builtin___memmove_chk (__dest, __src, __len, __bos0 (__dest)); -} -#endif #ifdef __USE_GNU -# ifdef __cplusplus __extern_always_inline void * __NTH (mempcpy (void *__restrict __dest, __const void *__restrict __src, size_t __len)) { return __builtin___mempcpy_chk (__dest, __src, __len, __bos0 (__dest)); } -# else -# define mempcpy(dest, src, len) \ - ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___mempcpy_chk (dest, src, len, __bos0 (dest)) \ - : __mempcpy_ichk (dest, src, len)) -static __always_inline void * -__NTH (__mempcpy_ichk (void *__restrict __dest, - __const void *__restrict __src, size_t __len)) -{ - return __builtin___mempcpy_chk (__dest, __src, __len, __bos0 (__dest)); -} -# endif #endif @@ -112,7 +74,6 @@ __NTH (__mempcpy_ichk (void *__restrict __dest, especially problematic if the intended fill value is zero. In this case no work is done at all. We detect these problems by referring non-existing functions. */ -#ifdef __cplusplus __extern_always_inline void * __NTH (memset (void *__dest, int __ch, size_t __len)) { @@ -123,103 +84,43 @@ __NTH (memset (void *__dest, int __ch, size_t __len)) } return __builtin___memset_chk (__dest, __ch, __len, __bos0 (__dest)); } -#else -# define memset(dest, ch, len) \ - (__builtin_constant_p (len) && (len) == 0 \ - ? (__warn_memset_zero_len (), (void) (ch), (void) (len), (void *) (dest)) \ - : ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___memset_chk (dest, ch, len, __bos0 (dest)) \ - : __memset_ichk (dest, ch, len))) -static __always_inline void * -__NTH (__memset_ichk (void *__dest, int __ch, size_t __len)) -{ - return __builtin___memset_chk (__dest, __ch, __len, __bos0 (__dest)); -} -#endif #ifdef __USE_BSD -# ifdef __cplusplus __extern_always_inline void __NTH (bcopy (__const void *__restrict __src, void *__restrict __dest, size_t __len)) { - __builtin___memmove_chk (__dest, __src, __len, __bos0 (__dest)); + (void) __builtin___memmove_chk (__dest, __src, __len, __bos0 (__dest)); } + __extern_always_inline void __NTH (bzero (void *__dest, size_t __len)) { - __builtin___memset_chk (__dest, '\0', __len, __bos0 (__dest)); + (void) __builtin___memset_chk (__dest, '\0', __len, __bos0 (__dest)); } -# else -# define bcopy(src, dest, len) ((void) \ - ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___memmove_chk (dest, src, len, __bos0 (dest)) \ - : __memmove_ichk (dest, src, len))) -# define bzero(dest, len) ((void) \ - ((__bos0 (dest) != (size_t) -1) \ - ? __builtin___memset_chk (dest, '\0', len, __bos0 (dest)) \ - : __memset_ichk (dest, '\0', len))) -# endif #endif -#ifdef __cplusplus __extern_always_inline char * __NTH (strcpy (char *__restrict __dest, __const char *__restrict __src)) { return __builtin___strcpy_chk (__dest, __src, __bos (__dest)); } -#else -# define strcpy(dest, src) \ - ((__bos (dest) != (size_t) -1) \ - ? __builtin___strcpy_chk (dest, src, __bos (dest)) \ - : __strcpy_ichk (dest, src)) -static __always_inline char * -__NTH (__strcpy_ichk (char *__restrict __dest, __const char *__restrict __src)) -{ - return __builtin___strcpy_chk (__dest, __src, __bos (__dest)); -} -#endif #ifdef __USE_GNU -# ifdef __cplusplus __extern_always_inline char * __NTH (stpcpy (char *__restrict __dest, __const char *__restrict __src)) { return __builtin___stpcpy_chk (__dest, __src, __bos (__dest)); } -# else -# define stpcpy(dest, src) \ - ((__bos (dest) != (size_t) -1) \ - ? __builtin___stpcpy_chk (dest, src, __bos (dest)) \ - : __stpcpy_ichk (dest, src)) -static __always_inline char * -__NTH (__stpcpy_ichk (char *__restrict __dest, __const char *__restrict __src)) -{ - return __builtin___stpcpy_chk (__dest, __src, __bos (__dest)); -} -# endif #endif -#ifdef __cplusplus __extern_always_inline char * __NTH (strncpy (char *__restrict __dest, __const char *__restrict __src, size_t __len)) { return __builtin___strncpy_chk (__dest, __src, __len, __bos (__dest)); } -#else -# define strncpy(dest, src, len) \ - ((__bos (dest) != (size_t) -1) \ - ? __builtin___strncpy_chk (dest, src, len, __bos (dest)) \ - : __strncpy_ichk (dest, src, len)) -static __always_inline char * -__NTH (__strncpy_ichk (char *__restrict __dest, __const char *__restrict __src, - size_t __len)) -{ - return __builtin___strncpy_chk (__dest, __src, __len, __bos (__dest)); -} -#endif // XXX We have no corresponding builtin yet. extern char *__stpncpy_chk (char *__dest, __const char *__src, size_t __n, @@ -238,41 +139,16 @@ __NTH (stpncpy (char *__dest, __const char *__src, size_t __n)) } -#ifdef __cplusplus __extern_always_inline char * __NTH (strcat (char *__restrict __dest, __const char *__restrict __src)) { return __builtin___strcat_chk (__dest, __src, __bos (__dest)); } -#else -# define strcat(dest, src) \ - ((__bos (dest) != (size_t) -1) \ - ? __builtin___strcat_chk (dest, src, __bos (dest)) \ - : __strcat_ichk (dest, src)) -static __always_inline char * -__NTH (__strcat_ichk (char *__restrict __dest, __const char *__restrict __src)) -{ - return __builtin___strcat_chk (__dest, __src, __bos (__dest)); -} -#endif -#ifdef __cplusplus __extern_always_inline char * __NTH (strncat (char *__restrict __dest, __const char *__restrict __src, size_t __len)) { return __builtin___strncat_chk (__dest, __src, __len, __bos (__dest)); } -#else -# define strncat(dest, src, len) \ - ((__bos (dest) != (size_t) -1) \ - ? __builtin___strncat_chk (dest, src, len, __bos (dest)) \ - : __strncat_ichk (dest, src, len)) -static __always_inline char * -__NTH (__strncat_ichk (char *__restrict __dest, __const char *__restrict __src, - size_t __len)) -{ - return __builtin___strncat_chk (__dest, __src, __len, __bos (__dest)); -} -#endif diff --git a/string/strcoll_l.c b/string/strcoll_l.c index c46921dcc9..8bd84b10aa 100644 --- a/string/strcoll_l.c +++ b/string/strcoll_l.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1995,96,97,2002, 2004 Free Software Foundation, Inc. +/* Copyright (C) 1995,96,97,2002, 2004, 2007 Free Software Foundation, Inc. This file is part of the GNU C Library. Written by Ulrich Drepper <drepper@gnu.org>, 1995. @@ -128,7 +128,7 @@ STRCOLL (s1, s2, l) Please note that the localedef programs makes sure that `position' is not used at the first level. */ - if (! __libc_use_alloca (s1len + s2len)) + if (! __libc_use_alloca ((s1len + s2len) * (sizeof (int32_t) + 1))) { idx1arr = (int32_t *) malloc ((s1len + s2len) * (sizeof (int32_t) + 1)); idx2arr = &idx1arr[s1len]; @@ -186,7 +186,10 @@ STRCOLL (s1, s2, l) /* The last pushed character was handled. Continue with forward characters. */ if (idx1cnt < idx1max) - idx1now = idx1cnt; + { + idx1now = idx1cnt; + backw1_stop = ~0ul; + } else /* Nothing anymore. The backward sequence ended with the last sequence in the string. Note that seq1len @@ -245,7 +248,10 @@ STRCOLL (s1, s2, l) /* The last pushed character was handled. Continue with forward characters. */ if (idx2cnt < idx2max) - idx2now = idx2cnt; + { + idx2now = idx2cnt; + backw2_stop = ~0ul; + } else /* Nothing anymore. The backward sequence ended with the last sequence in the string. Note that seq2len @@ -370,7 +376,10 @@ STRCOLL (s1, s2, l) /* The last pushed character was handled. Continue with forward characters. */ if (idx1cnt < idx1max) - idx1now = idx1cnt; + { + idx1now = idx1cnt; + backw1_stop = ~0ul; + } else { /* Nothing anymore. The backward sequence @@ -426,7 +435,10 @@ STRCOLL (s1, s2, l) /* The last pushed character was handled. Continue with forward characters. */ if (idx2cnt < idx2max) - idx2now = idx2cnt; + { + idx2now = idx2cnt; + backw2_stop = ~0ul; + } else { /* Nothing anymore. The backward sequence |