summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-10-01 00:07:16 +0000
committerUlrich Drepper <drepper@redhat.com>1998-10-01 00:07:16 +0000
commit36ab45e15f650b5034089879cf2cdfa427f17d72 (patch)
tree613fc4831f3a1a2961dc0a0ea91dffe788e26afe
parentf304af81b635347b9b26f9bfdda70705f5a13313 (diff)
downloadglibc-36ab45e15f650b5034089879cf2cdfa427f17d72.tar.gz
glibc-36ab45e15f650b5034089879cf2cdfa427f17d72.tar.xz
glibc-36ab45e15f650b5034089879cf2cdfa427f17d72.zip
Update.
1998-09-29  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> 
 
	* string/bits/string2.h (__string2_1bptr_p): Don't use a statement 
	expression. 
	(__mempcpy, strcpy, __stpcpy, strcmp, strcspn, strspn, strpbrk, 
	__strsep): Greatly reduce size of expansion by combining common 
	expressions. 
	(__mempcpy_small, __strcpy_small, __stpcpy_small): Convert to 
	inline function. 
	(__mempcpy_args, __strcpy_args, __stpcpy_args): New macros, used 
	by the above definitions. 
 
-rw-r--r--ChangeLog12
-rw-r--r--string/bits/string2.h873
2 files changed, 436 insertions, 449 deletions
diff --git a/ChangeLog b/ChangeLog
index 902171656f..92fcd183c3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+1998-09-29  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> 
+ 
+	* string/bits/string2.h (__string2_1bptr_p): Don't use a statement 
+	expression. 
+	(__mempcpy, strcpy, __stpcpy, strcmp, strcspn, strspn, strpbrk, 
+	__strsep): Greatly reduce size of expansion by combining common 
+	expressions. 
+	(__mempcpy_small, __strcpy_small, __stpcpy_small): Convert to 
+	inline function. 
+	(__mempcpy_args, __strcpy_args, __stpcpy_args): New macros, used 
+	by the above definitions. 
+ 
 1998-09-27  Geoff Keating  <geoffk@ozemail.com.au> 
  
 	* sysdeps/unix/sysv/linux/powerpc/bits/ipc.h: New file, use 
diff --git a/string/bits/string2.h b/string/bits/string2.h
index 172c21734a..c47a73841a 100644
--- a/string/bits/string2.h
+++ b/string/bits/string2.h
@@ -89,8 +89,7 @@ __STRING2_COPY_TYPE (8);
    pointer case, so we use this instead.
    Note that __x is evaluated twice. */
 #define __string2_1bptr_p(__x) \
-	(({ const void *__a, *__b; __a = (__x) + 1; __b = (__x); \
-	    (size_t)__a - (size_t)__b; }) == 1)
+  ((size_t)(const void *)((__x) + 1) - (size_t)(const void *)(__x) == 1)
 
 /* Set N bytes of S to C.  */
 #ifndef _HAVE_STRING_ARCH_memset
@@ -108,139 +107,135 @@ __STRING2_COPY_TYPE (8);
 #  define __mempcpy(dest, src, n) \
   (__extension__ (__builtin_constant_p (src) && __builtin_constant_p (n)      \
 		  && __string2_1bptr_p (src) && n <= 8			      \
-		  ? __mempcpy_small (dest, src, n)			      \
+		  ? __mempcpy_small (dest, __mempcpy_args (src), n)	      \
 		  : __mempcpy (dest, src, n)))
 /* In glibc we use this function frequently but for namespace reasons
    we have to use the name `__mempcpy'.  */
 #  define mempcpy(dest, src, n) __mempcpy (dest, src, n)
 
 #  if _STRING_ARCH_unaligned
-#   define __mempcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest++ = *(char *) src;			      \
-			break;						      \
-		      case 2:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			__dest += 2;					      \
-			break;						      \
-		      case 3:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			__dest += sizeof (__uint16_t);			      \
-			*__dest++ = ((char *) src)[2];			      \
-			break;						      \
-		      case 4:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			__dest += 4;					      \
-			break;						      \
-		      case 5:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			__dest += 4;					      \
-			*__dest++ = ((char *) src)[4];			      \
-			break;						      \
-		      case 6:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			__dest += 6;					      \
-			break;						      \
-		      case 7:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			__dest += 6;					      \
-			*__dest++ = ((char *) src)[6];			      \
-			break;						      \
-		      case 8:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint32_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET32 (src, 4);		      \
-			__dest += 8;					      \
-			break;						      \
-		      }							      \
-		    __dest; }))
+#   define __mempcpy_args(src) \
+     ((char *) (src))[0], ((char *) (src))[2], ((char *) (src))[4],	      \
+     ((char *) (src))[6],						      \
+     __extension__ __STRING2_SMALL_GET16 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET16 (src, 4),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 4)
+__STRING_INLINE void *
+__mempcpy_small (void *__dest1,
+		 char __src0_1, char __src2_1, char __src4_1, char __src6_1,
+		 __uint16_t __src0_2, __uint16_t __src4_2,
+		 __uint32_t __src0_4, __uint32_t __src4_4,
+		 size_t __srclen)
+{
+  char *__dest = (char *) __dest1;
+  switch (__srclen)
+    {
+    case 1:
+      *__dest++ = __src0_1;
+      break;
+    case 2:
+      *((__uint16_t *) __dest) = __src0_2;
+      __dest += 2;
+      break;
+    case 3:
+      *((__uint16_t *) __dest) = __src0_2;
+      __dest += 2;
+      *__dest++ = __src2_1;
+      break;
+    case 4:
+      *((__uint32_t *) __dest) = __src0_4;
+      __dest += 4;
+      break;
+    case 5:
+      *((__uint32_t *) __dest) = __src0_4;
+      __dest += 4;
+      *__dest++ = __src4_1;
+      break;
+    case 6:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      __dest += 6;
+      break;
+    case 7:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      __dest += 6;
+      *__dest++ = __src6_1;
+      break;
+    case 8:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint32_t *) (__dest + 4)) = __src4_4;
+      __dest += 8;
+      break;
+    }
+  return (void *) __dest;
+}
 #  else
-#   define __mempcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 2:						      \
-			*((__STRING2_COPY_ARR2 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR2)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1] } });	      \
-			break;						      \
-		      case 3:						      \
-			*((__STRING2_COPY_ARR3 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR3)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2] } });	      \
-			break;						      \
-		      case 4:						      \
-			*((__STRING2_COPY_ARR4 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR4)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3] } });	      \
-			break;						      \
-		      case 5:						      \
-			*((__STRING2_COPY_ARR5 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR5)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4] } });	      \
-			break;						      \
-		      case 6:						      \
-			*((__STRING2_COPY_ARR6 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR6)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5] } });	      \
-			break;						      \
-		      case 7:						      \
-			*((__STRING2_COPY_ARR7 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR7)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       ((__const char *) (src))[6] } });	      \
-			break;						      \
-		      case 8:						      \
-			*((__STRING2_COPY_ARR8 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR8)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       ((__const char *) (src))[6],		      \
-			       ((__const char *) (src))[7] } });	      \
-			break;						      \
-		    }							      \
-		  __dest + (srclen); }))
+#   define __mempcpy_args(src) \
+     __extension__ ((__STRING2_COPY_ARR2)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1] } }),      \
+     __extension__ ((__STRING2_COPY_ARR3)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2] } }),				      \
+     __extension__ ((__STRING2_COPY_ARR4)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3] } }),      \
+     __extension__ ((__STRING2_COPY_ARR5)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4] } }),				      \
+     __extension__ ((__STRING2_COPY_ARR6)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5] } }),      \
+     __extension__ ((__STRING2_COPY_ARR7)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  ((__const char *) (src))[6] } }),				      \
+     __extension__ ((__STRING2_COPY_ARR8)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  ((__const char *) (src))[6], ((__const char *) (src))[7] } })
+__STRING_INLINE void *
+__mempcpy_small (void *__dest1,
+		 __STRING2_COPY_ARR2 __src2, __STRING2_COPY_ARR3 __src3,
+		 __STRING2_COPY_ARR4 __src4, __STRING2_COPY_ARR5 __src5,
+		 __STRING2_COPY_ARR6 __src6, __STRING2_COPY_ARR7 __src7,
+		 __STRING2_COPY_ARR8 __src8, size_t __srclen)
+{
+  char *__dest = (char *) __dest1;
+  switch (__srclen)
+    {
+    case 1:
+      *__dest = '\0';
+      break;
+    case 2:
+      __extension__ *((__STRING2_COPY_ARR2 *) __dest) = __src2;
+      break;
+    case 3:
+      __extension__ *((__STRING2_COPY_ARR3 *) __dest) = __src3;
+      break;
+    case 4:
+      __extension__ *((__STRING2_COPY_ARR4 *) __dest) = __src4;
+      break;
+    case 5:
+      __extension__ *((__STRING2_COPY_ARR5 *) __dest) = __src5;
+      break;
+    case 6:
+      __extension__ *((__STRING2_COPY_ARR6 *) __dest) = __src6;
+      break;
+    case 7:
+      __extension__ *((__STRING2_COPY_ARR7 *) __dest) = __src7;
+      break;
+    case 8:
+      __extension__ *((__STRING2_COPY_ARR8 *) __dest) = __src8;
+      break;
+    }
+  return (void *) (__dest + __srclen);
+}
 #  endif
 # endif
 #endif
@@ -251,130 +246,122 @@ __STRING2_COPY_TYPE (8);
 # define strcpy(dest, src) \
   (__extension__ (__builtin_constant_p (src)				      \
 		  ? (__string2_1bptr_p (src) && strlen (src) + 1 <= 8	      \
-		     ? __strcpy_small (dest, src, strlen (src) + 1)	      \
+		     ? __strcpy_small (dest, __strcpy_args (src),	      \
+				       strlen (src) + 1)		      \
 		     : (char *) memcpy (dest, src, strlen (src) + 1))	      \
 		  : strcpy (dest, src)))
 
 # if _STRING_ARCH_unaligned
-#  define __strcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 2:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			break;						      \
-		      case 3:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			*(__dest + 2) = '\0';				      \
-			break;						      \
-		      case 4:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			break;						      \
-		      case 5:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*(__dest + 4) = '\0';				      \
-			break;						      \
-		      case 6:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			break;						      \
-		      case 7:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			*(__dest + 6) = '\0';				      \
-			break;						      \
-		      case 8:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint32_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET32 (src, 4);		      \
-			break;						      \
-		      }							      \
-		    __dest; }))
+#  define __strcpy_args(src) \
+     __extension__ __STRING2_SMALL_GET16 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET16 (src, 4),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 4)
+__STRING_INLINE char *
+__strcpy_small (char *__dest,
+		__uint16_t __src0_2, __uint16_t __src4_2,
+		__uint32_t __src0_4, __uint32_t __src4_4,
+		size_t __srclen)
+{
+  switch (__srclen)
+    {
+    case 1:
+      *__dest = '\0';
+      break;
+    case 2:
+      *((__uint16_t *) __dest) = __src0_2;
+      break;
+    case 3:
+      *((__uint16_t *) __dest) = __src0_2;
+      *(__dest + 2) = '\0';
+      break;
+    case 4:
+      *((__uint32_t *) __dest) = __src0_4;
+      break;
+    case 5:
+      *((__uint32_t *) __dest) = __src0_4;
+      *(__dest + 4) = '\0';
+      break;
+    case 6:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      break;
+    case 7:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      *(__dest + 6) = '\0';
+      break;
+    case 8:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint32_t *) (__dest + 4)) = __src4_4;
+      break;
+    }
+  return __dest;
+}
 # else
-#  define __strcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 2:						      \
-			*((__STRING2_COPY_ARR2 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR2)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 3:						      \
-			*((__STRING2_COPY_ARR3 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR3)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 4:						      \
-			*((__STRING2_COPY_ARR4 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR4)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 5:						      \
-			*((__STRING2_COPY_ARR5 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR5)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 6:						      \
-			*((__STRING2_COPY_ARR6 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR6)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 7:						      \
-			*((__STRING2_COPY_ARR7 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR7)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 8:						      \
-			*((__STRING2_COPY_ARR8 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR8)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       ((__const char *) (src))[6],		      \
-			       '\0' } });				      \
-			break;						      \
-		    }							      \
-		  __dest; }))
+#  define __strcpy_args(src) \
+     __extension__ ((__STRING2_COPY_ARR2)				      \
+      { { ((__const char *) (src))[0], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR3)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR4)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR5)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR6)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR7)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR8)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  ((__const char *) (src))[6], '\0' } })
+__STRING_INLINE char *
+__strcpy_small (char *__dest,
+		__STRING2_COPY_ARR2 __src2, __STRING2_COPY_ARR3 __src3,
+		__STRING2_COPY_ARR4 __src4, __STRING2_COPY_ARR5 __src5,
+		__STRING2_COPY_ARR6 __src6, __STRING2_COPY_ARR7 __src7,
+		__STRING2_COPY_ARR8 __src8, size_t __srclen)
+{
+  switch (__srclen)
+    {
+    case 1:
+      *__dest = '\0';
+      break;
+    case 2:
+      __extension__ *((__STRING2_COPY_ARR2 *) __dest) = __src2;
+      break;
+    case 3:
+      __extension__ *((__STRING2_COPY_ARR3 *) __dest) = __src3;
+      break;
+    case 4:
+      __extension__ *((__STRING2_COPY_ARR4 *) __dest) = __src4;
+      break;
+    case 5:
+      __extension__ *((__STRING2_COPY_ARR5 *) __dest) = __src5;
+      break;
+    case 6:
+      __extension__ *((__STRING2_COPY_ARR6 *) __dest) = __src6;
+      break;
+    case 7:
+      __extension__ *((__STRING2_COPY_ARR7 *) __dest) = __src7;
+      break;
+    case 8:
+      __extension__ *((__STRING2_COPY_ARR8 *) __dest) = __src8;
+      break;
+  }
+  return __dest;
+}
 # endif
 #endif
 
@@ -385,7 +372,8 @@ __STRING2_COPY_TYPE (8);
 #  define __stpcpy(dest, src) \
   (__extension__ (__builtin_constant_p (src)				      \
 		  ? (__string2_1bptr_p (src) && strlen (src) + 1 <= 8	      \
-		     ? __stpcpy_small (dest, src, strlen (src) + 1)	      \
+		     ? __stpcpy_small (dest, __stpcpy_args (src),	      \
+				       strlen (src) + 1)		      \
 		     : ((char *) __mempcpy (dest, src, strlen (src) + 1) - 1))\
 		  : __stpcpy (dest, src)))
 /* In glibc we use this function frequently but for namespace reasons
@@ -393,132 +381,123 @@ __STRING2_COPY_TYPE (8);
 #  define stpcpy(dest, src) __stpcpy (dest, src)
 
 #  if _STRING_ARCH_unaligned
-#   define __stpcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 2:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			++__dest;					      \
-			break;						      \
-		      case 3:						      \
-			*((__uint16_t *) __dest) =			      \
-			  __STRING2_SMALL_GET16 (src, 0);		      \
-			__dest += sizeof (__uint16_t);			      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 4:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			__dest += 3;					      \
-			break;						      \
-		      case 5:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			__dest += 4;					      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 6:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			__dest += 5;					      \
-			break;						      \
-		      case 7:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint16_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET16 (src, 4);		      \
-			__dest += 6;					      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 8:						      \
-			*((__uint32_t *) __dest) =			      \
-			  __STRING2_SMALL_GET32 (src, 0);		      \
-			*((__uint32_t *) (__dest + 4)) =		      \
-			  __STRING2_SMALL_GET32 (src, 4);		      \
-			__dest += 7;					      \
-			break;						      \
-		      }							      \
-		    __dest; }))
+#   define __stpcpy_args(src) \
+     __extension__ __STRING2_SMALL_GET16 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET16 (src, 4),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 0),			      \
+     __extension__ __STRING2_SMALL_GET32 (src, 4)
+__STRING_INLINE char *
+__stpcpy_small (char *__dest,
+		__uint16_t __src0_2, __uint16_t __src4_2,
+		__uint32_t __src0_4, __uint32_t __src4_4,
+		size_t __srclen)
+{
+  switch (__srclen)
+    {
+    case 1:
+      *__dest = '\0';
+      break;
+    case 2:
+      *((__uint16_t *) __dest) = __src0_2;
+      ++__dest;
+      break;
+    case 3:
+      *((__uint16_t *) __dest) = __src0_2;
+      __dest += sizeof (__uint16_t);
+      *__dest = '\0';
+      break;
+    case 4:
+      *((__uint32_t *) __dest) = __src0_4;
+      __dest += 3;
+      break;
+    case 5:
+      *((__uint32_t *) __dest) = __src0_4;
+      __dest += 4;
+      *__dest = '\0';
+      break;
+    case 6:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      __dest += 5;
+      break;
+    case 7:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint16_t *) (__dest + 4)) = __src4_2;
+      __dest += 6;
+      *__dest = '\0';
+      break;
+    case 8:
+      *((__uint32_t *) __dest) = __src0_4;
+      *((__uint32_t *) (__dest + 4)) = __src4_4;
+      __dest += 7;
+      break;
+    }
+  return __dest;
+}
 #  else
-#   define __stpcpy_small(dest, src, srclen) \
-  (__extension__ ({ char *__dest = (char *) (dest);			      \
-		    switch (srclen)					      \
-		      {							      \
-		      case 1:						      \
-			*__dest = '\0';					      \
-			break;						      \
-		      case 2:						      \
-			*((__STRING2_COPY_ARR2 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR2)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 3:						      \
-			*((__STRING2_COPY_ARR3 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR3)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 4:						      \
-			*((__STRING2_COPY_ARR4 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR4)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 5:						      \
-			*((__STRING2_COPY_ARR5 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR5)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 6:						      \
-			*((__STRING2_COPY_ARR6 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR6)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 7:						      \
-			*((__STRING2_COPY_ARR7 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR7)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       '\0' } });				      \
-			break;						      \
-		      case 8:						      \
-			*((__STRING2_COPY_ARR8 *) __dest) =		      \
-			  ((__STRING2_COPY_ARR8)			      \
-			   { { ((__const char *) (src))[0],		      \
-			       ((__const char *) (src))[1],		      \
-			       ((__const char *) (src))[2],		      \
-			       ((__const char *) (src))[3],		      \
-			       ((__const char *) (src))[4],		      \
-			       ((__const char *) (src))[5],		      \
-			       ((__const char *) (src))[6],		      \
-			       '\0' } });				      \
-			break;						      \
-		    }							      \
-		  __dest + ((srclen) - 1); }))
+#  define __stpcpy_args(src) \
+     __extension__ ((__STRING2_COPY_ARR2)				      \
+      { { ((__const char *) (src))[0], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR3)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR4)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR5)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR6)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], '\0' } }),			      \
+     __extension__ ((__STRING2_COPY_ARR7)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  '\0' } }),							      \
+     __extension__ ((__STRING2_COPY_ARR8)				      \
+      { { ((__const char *) (src))[0], ((__const char *) (src))[1],	      \
+	  ((__const char *) (src))[2], ((__const char *) (src))[3],	      \
+	  ((__const char *) (src))[4], ((__const char *) (src))[5],	      \
+	  ((__const char *) (src))[6], '\0' } })
+__STRING_INLINE char *
+__stpcpy_small (char *__dest,
+		__STRING2_COPY_ARR2 __src2, __STRING2_COPY_ARR3 __src3,
+		__STRING2_COPY_ARR4 __src4, __STRING2_COPY_ARR5 __src5,
+		__STRING2_COPY_ARR6 __src6, __STRING2_COPY_ARR7 __src7,
+		__STRING2_COPY_ARR8 __src8, size_t __srclen)
+{
+  switch (__srclen)
+    {
+    case 1:
+      *__dest = '\0';
+      break;
+    case 2:
+      __extension__ *((__STRING2_COPY_ARR2 *) __dest) = __src2;
+      break;
+    case 3:
+      __extension__ *((__STRING2_COPY_ARR3 *) __dest) = __src3;
+      break;
+    case 4:
+      __extension__ *((__STRING2_COPY_ARR4 *) __dest) = __src4;
+      break;
+    case 5:
+      __extension__ *((__STRING2_COPY_ARR5 *) __dest) = __src5;
+      break;
+    case 6:
+      __extension__ *((__STRING2_COPY_ARR6 *) __dest) = __src6;
+      break;
+    case 7:
+      __extension__ *((__STRING2_COPY_ARR7 *) __dest) = __src7;
+      break;
+    case 8:
+      __extension__ *((__STRING2_COPY_ARR8 *) __dest) = __src8;
+      break;
+  }
+  return __dest + __srclen - 1;
+}
 #  endif
 # endif
 #endif
@@ -571,23 +550,27 @@ __STRING2_COPY_TYPE (8);
 /* Compare characters of S1 and S2.  */
 #ifndef _HAVE_STRING_ARCH_strcmp
 # define strcmp(s1, s2) \
-  (__extension__ (__builtin_constant_p (s1) && __builtin_constant_p (s2)      \
-		  && (!__string2_1bptr_p (s1) || strlen (s1) >= 4)	      \
-		  && (!__string2_1bptr_p (s2) || strlen (s2) >= 4)	      \
-		  ? memcmp ((__const char *) (s1), (__const char *) (s2),     \
-			    (strlen (s1) < strlen (s2)			      \
-			     ? strlen (s1) : strlen (s2)) + 1)		      \
-		  : (__builtin_constant_p (s1) && __string2_1bptr_p (s1)      \
-		     && strlen (s1) < 4					      \
-		     ? (__builtin_constant_p (s2) && __string2_1bptr_p (s2)   \
-			? __strcmp_cc (s1, s2, strlen (s1))		      \
-			: __strcmp_cg (s1, s2, strlen (s1)))		      \
-		     : (__builtin_constant_p (s2) && __string2_1bptr_p (s2)   \
-			&& strlen (s2) < 4				      \
-			? (__builtin_constant_p (s1) && __string2_1bptr_p (s1)\
-			   ? __strcmp_cc (s1, s2, strlen (s2))		      \
-			   : __strcmp_gc (s1, s2, strlen (s2)))		      \
-			: strcmp (s1, s2)))))
+  __extension__								      \
+  ({ size_t __s1_len, __s2_len;						      \
+     int __s1_is_const = __builtin_constant_p (s1);			      \
+     int __s2_is_const = __builtin_constant_p (s2);			      \
+     (__s1_is_const && __s2_is_const					      \
+      && (__s1_len = strlen (s1), __s2_len = strlen (s2),		      \
+	  (!__string2_1bptr_p (s1) || __s1_len >= 4)			      \
+	  && (!__string2_1bptr_p (s2) || __s2_len >= 4))		      \
+      ? memcmp ((__const char *) (s1), (__const char *) (s2),		      \
+		(__s1_len < __s2_len ? __s1_len : __s2_len) + 1)	      \
+      : (__s1_is_const && __string2_1bptr_p (s1)			      \
+	 && (__s1_len = strlen (s1), __s1_len < 4)			      \
+	 ? (__s2_is_const && __string2_1bptr_p (s2)			      \
+	    ? __strcmp_cc (s1, s2, __s1_len)				      \
+	    : __strcmp_cg (s1, s2, __s1_len))				      \
+	 : (__s2_is_const && __string2_1bptr_p (s2)			      \
+	    && (__s2_len = strlen (s2), __s2_len < 4)			      \
+	    ? (__s1_is_const && __string2_1bptr_p (s1)			      \
+	       ? __strcmp_cc (s1, s2, __s2_len)				      \
+	       : __strcmp_gc (s1, s2, __s2_len))			      \
+	    : strcmp (s1, s2)))); })
 
 # define __strcmp_cc(s1, s2, l) \
   (__extension__ ({ register int __result =				      \
@@ -680,21 +663,19 @@ __STRING2_COPY_TYPE (8);
    consists entirely of characters not in REJECT.  */
 #ifndef _HAVE_STRING_ARCH_strcspn
 # define strcspn(s, reject) \
-  (__extension__ (__builtin_constant_p (reject) && __string2_1bptr_p (reject) \
-		  ? (((__const char *) (reject))[0] == '\0'		      \
-		     ? strlen (s)					      \
-		     : (((__const char *) (reject))[1] == '\0'		      \
-			? __strcspn_c1 (s, ((__const char *) (reject))[0])    \
-			: (((__const char *) (reject))[2] == '\0'	      \
-			   ? __strcspn_c2 (s, ((__const char *) (reject))[0], \
-					   ((__const char *) (reject))[1])    \
-			   : (((__const char *) (reject))[3] == '\0'	      \
-			      ? __strcspn_c3 (s,			      \
-					      ((__const char *) (reject))[0], \
-					      ((__const char *) (reject))[1], \
-					      ((__const char *) (reject))[2]) \
-			      : strcspn (s, reject)))))			      \
-		  : strcspn (s, reject)))
+  __extension__								      \
+  ({ char __r0, __r1, __r2;						      \
+     (__builtin_constant_p (reject) && __string2_1bptr_p (reject)	      \
+      ? ((__r0 = ((__const char *) (reject))[0], __r0 == '\0')		      \
+	 ? strlen (s)							      \
+	 : ((__r1 = ((__const char *) (reject))[1], __r1 == '\0')	      \
+	    ? __strcspn_c1 (s, __r0)					      \
+	    : ((__r2 = ((__const char *) (reject))[2], __r2 == '\0')	      \
+	       ? __strcspn_c2 (s, __r0, __r1)				      \
+	       : (((__const char *) (reject))[3] == '\0'		      \
+		  ? __strcspn_c3 (s, __r0, __r1, __r2)			      \
+		  : strcspn (s, reject)))))				      \
+		  : strcspn (s, reject)); })
 
 __STRING_INLINE size_t __strcspn_c1 (__const char *__s, char __reject);
 __STRING_INLINE size_t
@@ -737,21 +718,19 @@ __strcspn_c3 (__const char *__s, char __reject1, char __reject2,
    consists entirely of characters in ACCEPT.  */
 #ifndef _HAVE_STRING_ARCH_strspn
 # define strspn(s, accept) \
-  (__extension__ (__builtin_constant_p (accept) && __string2_1bptr_p (accept) \
-		  ? (((__const char *) (accept))[0] == '\0'		      \
-		     ? 0						      \
-		     : (((__const char *) (accept))[1] == '\0'		      \
-			? __strspn_c1 (s, ((__const char *) (accept))[0])     \
-			: (((__const char *) (accept))[2] == '\0'	      \
-			   ? __strspn_c2 (s, ((__const char *) (accept))[0],  \
-					  ((__const char *) (accept))[1])     \
-			   : (((__const char *) (accept))[3] == '\0'	      \
-			      ? __strspn_c3 (s,				      \
-					     ((__const char *) (accept))[0],  \
-					     ((__const char *) (accept))[1],  \
-					     ((__const char *) (accept))[2])  \
-			      : strspn (s, accept)))))			      \
-		  : strspn (s, accept)))
+  __extension__								      \
+  ({ char __a0, __a1, __a2;						      \
+     (__builtin_constant_p (accept) && __string2_1bptr_p (accept)	      \
+      ? ((__a0 = ((__const char *) (accept))[0], __a0 == '\0')		      \
+	 ? 0								      \
+	 : ((__a1 = ((__const char *) (accept))[1], __a1 == '\0')	      \
+	    ? __strspn_c1 (s, __a0)					      \
+	    : ((__a2 = ((__const char *) (accept))[2], __a2 == '\0')	      \
+	       ? __strspn_c2 (s, __a0, __a1)				      \
+	       : (((__const char *) (accept))[3] == '\0'		      \
+		  ? __strspn_c3 (s, __a0, __a1, __a2)			      \
+		  : strspn (s, accept)))))				      \
+      : strspn (s, accept)); })
 
 __STRING_INLINE size_t __strspn_c1 (__const char *__s, char __accept);
 __STRING_INLINE size_t
@@ -794,21 +773,19 @@ __strspn_c3 (__const char *__s, char __accept1, char __accept2, char __accept3)
 /* Find the first occurrence in S of any character in ACCEPT.  */
 #ifndef _HAVE_STRING_ARCH_strpbrk
 # define strpbrk(s, accept) \
-  (__extension__ (__builtin_constant_p (accept) && __string2_1bptr_p (accept) \
-		  ? (((__const char  *) (accept))[0] == '\0'		      \
-		     ? NULL						      \
-		     : (((__const char *) (accept))[1] == '\0'		      \
-			? strchr (s, ((__const char *) (accept))[0])	      \
-			: (((__const char *) (accept))[2] == '\0'	      \
-			   ? __strpbrk_c2 (s, ((__const char *) (accept))[0], \
-					   ((__const char *) (accept))[1])    \
-			   : (((__const char *) (accept))[3] == '\0'	      \
-			      ? __strpbrk_c3 (s,			      \
-					      ((__const char *) (accept))[0], \
-					      ((__const char *) (accept))[1], \
-					      ((__const char *) (accept))[2]) \
-			      : strpbrk (s, accept)))))			      \
-		  : strpbrk (s, accept)))
+  __extension__								      \
+  ({ char __a0, __a1, __a2;						      \
+     (__builtin_constant_p (accept) && __string2_1bptr_p (accept)	      \
+      ? ((__a0 = ((__const char  *) (accept))[0], __a0 == '\0')		      \
+	 ? NULL								      \
+	 : ((__a1 = ((__const char *) (accept))[1], __a1 == '\0')	      \
+	    ? strchr (s, __a0)						      \
+	    : ((__a2 = ((__const char *) (accept))[2], __a2 == '\0')	      \
+	       ? __strpbrk_c2 (s, __a0, __a1)				      \
+	       : (((__const char *) (accept))[3] == '\0'		      \
+		  ? __strpbrk_c3 (s, __a0, __a1, __a2)			      \
+		  : strpbrk (s, accept)))))				      \
+      : strpbrk (s, accept)); })
 
 __STRING_INLINE char *__strpbrk_c2 (__const char *__s, char __accept1,
 				     char __accept2);
@@ -907,20 +884,18 @@ __strtok_r_1c (char *__s, char __sep, char **__nextp)
 #ifndef _HAVE_STRING_ARCH_strsep
 
 # define __strsep(s, reject) \
-  (__extension__ (__builtin_constant_p (reject) && __string2_1bptr_p (reject) \
-		  && ((__const char *) (reject))[0] != '\0'		      \
-		  ? (((__const char *) (reject))[1] == '\0'		      \
-		     ? __strsep_1c (s,					      \
-				    ((__const char *) (reject))[0])	      \
-		     : (((__const char *) (reject))[2] == '\0'		      \
-			? __strsep_2c (s, ((__const char *) (reject))[0],     \
-				       ((__const char *) (reject))[1])	      \
-			: (((__const char *) (reject))[3] == '\0'	      \
-			   ? __strsep_3c (s, ((__const char *) (reject))[0],  \
-					  ((__const char *) (reject))[1],     \
-					  ((__const char *) (reject))[2])     \
-			   : __strsep_g (s, reject))))			      \
-		  : __strsep_g (s, reject)))
+  __extension__								      \
+  ({ char __r0, __r1, __r2;						      \
+     (__builtin_constant_p (reject) && __string2_1bptr_p (reject)	      \
+      && (__r0 = ((__const char *) (reject))[0], __r0 != '\0')		      \
+      ? ((__r1 = ((__const char *) (reject))[1], __r1 == '\0')		      \
+	 ? __strsep_1c (s, __r0)					      \
+	 : ((__r2 = ((__const char *) (reject))[2], __r2 == '\0')	      \
+	    ? __strsep_2c (s, __r0, __r1)				      \
+	    : (((__const char *) (reject))[3] == '\0'			      \
+	       ? __strsep_3c (s, __r0, __r1, __r2)			      \
+	       : __strsep_g (s, reject))))				      \
+      : __strsep_g (s, reject)); })
 
 __STRING_INLINE char *__strsep_1c (char **__s, char __reject);
 __STRING_INLINE char *