| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | /* Test strncat functions.
 | 
					
						
							| 
									
										
										
										
											2024-01-01 18:12:26 +00:00
										 |  |  |    Copyright (C) 2011-2024 Free Software Foundation, Inc. | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    The GNU C Library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |    modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |    License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |    version 2.1 of the License, or (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The GNU C Library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |    but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
					
						
							|  |  |  |    Lesser General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    You should have received a copy of the GNU Lesser General Public | 
					
						
							| 
									
										
										
										
											2012-02-09 23:18:22 +00:00
										 |  |  |    License along with the GNU C Library; if not, see | 
					
						
							| 
									
										
											  
											
												Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
  s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
  s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
  $(find $(git ls-files) -prune -type f \
      ! -name '*.po' \
      ! -name 'ChangeLog*' \
      ! -path COPYING ! -path COPYING.LIB \
      ! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
      ! -path manual/texinfo.tex ! -path scripts/config.guess \
      ! -path scripts/config.sub ! -path scripts/install-sh \
      ! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
      ! -path INSTALL ! -path  locale/programs/charmap-kw.h \
      ! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
      ! '(' -name configure \
            -execdir test -f configure.ac -o -f configure.in ';' ')' \
      ! '(' -name preconfigure \
            -execdir test -f preconfigure.ac ';' ')' \
      -print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
  chmod a+x sysdeps/unix/sysv/linux/riscv/configure
  # Omit irrelevant whitespace and comment-only changes,
  # perhaps from a slightly-different Autoconf version.
  git checkout -f \
    sysdeps/csky/configure \
    sysdeps/hppa/configure \
    sysdeps/riscv/configure \
    sysdeps/unix/sysv/linux/csky/configure
  # Omit changes that caused a pre-commit check to fail like this:
  # remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
  git checkout -f \
    sysdeps/powerpc/powerpc64/ppc-mcount.S \
    sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
  # Omit change that caused a pre-commit check to fail like this:
  # remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
  git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
											
										 
											2019-09-07 05:40:42 +00:00
										 |  |  |    <https://www.gnu.org/licenses/>.  */
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TEST_MAIN
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | #ifndef WIDE
 | 
					
						
							|  |  |  | # define TEST_NAME "strncat"
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | # define TEST_NAME "wcsncat"
 | 
					
						
							|  |  |  | #endif /* WIDE */
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | #include "test-string.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | #ifndef WIDE
 | 
					
						
							|  |  |  | # define STRNCAT strncat
 | 
					
						
							|  |  |  | # define CHAR char
 | 
					
						
							|  |  |  | # define UCHAR unsigned char
 | 
					
						
							|  |  |  | # define SIMPLE_STRNCAT simple_strncat
 | 
					
						
							| 
									
										
										
										
											2023-01-31 23:46:56 +00:00
										 |  |  | # define STRNLEN strnlen
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | # define STRLEN strlen
 | 
					
						
							|  |  |  | # define MEMSET memset
 | 
					
						
							|  |  |  | # define MEMCPY memcpy
 | 
					
						
							|  |  |  | # define MEMCMP memcmp
 | 
					
						
							|  |  |  | # define BIG_CHAR CHAR_MAX
 | 
					
						
							|  |  |  | # define SMALL_CHAR 127
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | # include <wchar.h>
 | 
					
						
							|  |  |  | # define STRNCAT wcsncat
 | 
					
						
							|  |  |  | # define CHAR wchar_t
 | 
					
						
							|  |  |  | # define UCHAR wchar_t
 | 
					
						
							|  |  |  | # define SIMPLE_STRNCAT simple_wcsncat
 | 
					
						
							| 
									
										
										
										
											2023-01-31 23:46:56 +00:00
										 |  |  | # define STRNLEN wcsnlen
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | # define STRLEN wcslen
 | 
					
						
							|  |  |  | # define MEMSET wmemset
 | 
					
						
							|  |  |  | # define MEMCPY wmemcpy
 | 
					
						
							|  |  |  | # define MEMCMP wmemcmp
 | 
					
						
							|  |  |  | # define BIG_CHAR WCHAR_MAX
 | 
					
						
							|  |  |  | # define SMALL_CHAR 1273
 | 
					
						
							|  |  |  | #endif /* WIDE */
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | typedef CHAR *(*proto_t) (CHAR *, const CHAR *, size_t); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | IMPL (STRNCAT, 2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-06 15:23:24 +00:00
										 |  |  | /* Naive implementation to verify results.  */ | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | CHAR * | 
					
						
							| 
									
										
										
										
											2022-04-06 15:23:24 +00:00
										 |  |  | SIMPLE_STRNCAT (CHAR *dst, const CHAR *src, size_t n) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   CHAR *ret = dst; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |   while (*dst++ != '\0'); | 
					
						
							|  |  |  |   --dst; | 
					
						
							|  |  |  |   while (n--) | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |     if ((*dst++ = *src++) == '\0') | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |       return ret; | 
					
						
							|  |  |  |   *dst = '\0'; | 
					
						
							|  |  |  |   return ret; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2023-02-28 12:48:34 +00:00
										 |  |  | __attribute__((noinline)) | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | do_one_test (impl_t *impl, CHAR *dst, const CHAR *src, size_t n) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   size_t k = STRLEN (dst); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |   if (CALL (impl, dst, src, n) != dst) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       error (0, 0, "Wrong result in function %s %p != %p", impl->name, | 
					
						
							|  |  |  | 	     CALL (impl, dst, src, n), dst); | 
					
						
							|  |  |  |       ret = 1; | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-31 23:46:56 +00:00
										 |  |  |   size_t len = STRNLEN (src, n); | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   if (MEMCMP (dst + k, src, len + 1 > n ? n : len + 1) != 0) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |       error (0, 0, "Incorrect concatenation in function %s", | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	     impl->name); | 
					
						
							|  |  |  |       ret = 1; | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   if (n < len && dst[k + n] != '\0') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       error (0, 0, "There is no zero in the end of output string in %s", | 
					
						
							|  |  |  | 	     impl->name); | 
					
						
							|  |  |  |       ret = 1; | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-31 23:46:56 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | do_test_src_no_nullterm_bz30065 (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* NB: "src does not need to be null-terminated if it contains n or more
 | 
					
						
							|  |  |  |    * bytes." */ | 
					
						
							|  |  |  |   CHAR *s1, *s2; | 
					
						
							|  |  |  |   size_t bound = page_size / sizeof (CHAR); | 
					
						
							|  |  |  |   s1 = (CHAR *) (buf1 + BUF1PAGES * page_size); | 
					
						
							|  |  |  |   s2 = (CHAR *) buf2; | 
					
						
							|  |  |  |   MEMSET (s1 - bound, -1, bound); | 
					
						
							|  |  |  |   for (size_t n = 0; n < bound; ++n) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       FOR_EACH_IMPL (impl, 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  s2[0] = '\0'; | 
					
						
							|  |  |  | 	  do_one_test (impl, s2, s1 - n, n); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | do_test (size_t align1, size_t align2, size_t len1, size_t len2, | 
					
						
							|  |  |  | 	 size_t n, int max_char) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   size_t i; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   CHAR *s1, *s2; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   align1 &= 7; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   if ((align1 + len1) * sizeof (CHAR) >= page_size) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   if ((align1 + n) * sizeof (CHAR) > page_size) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |     return; | 
					
						
							|  |  |  |   align2 &= 7; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   if ((align2 + len1 + len2) * sizeof (CHAR) >= page_size) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   if ((align2 + len1 + n) * sizeof (CHAR) > page_size) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   s1 = (CHAR *) (buf1) + align1; | 
					
						
							|  |  |  |   s2 = (CHAR *) (buf2) + align2; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < len1; ++i) | 
					
						
							|  |  |  |     s1[i] = 32 + 23 * i % (max_char - 32); | 
					
						
							|  |  |  |   s1[len1] = '\0'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < len2; i++) | 
					
						
							|  |  |  |     s2[i] = 32 + 23 * i % (max_char - 32); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   FOR_EACH_IMPL (impl, 0) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       s2[len2] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, n); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-09 20:17:14 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | do_overflow_tests (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   size_t i, j, len; | 
					
						
							|  |  |  |   const size_t one = 1; | 
					
						
							|  |  |  |   CHAR *s1, *s2; | 
					
						
							|  |  |  |   uintptr_t s1_addr; | 
					
						
							|  |  |  |   s1 = (CHAR *) buf1; | 
					
						
							|  |  |  |   s2 = (CHAR *) buf2; | 
					
						
							|  |  |  |   s1_addr = (uintptr_t)s1; | 
					
						
							|  |  |  |  for (j = 0; j < 200; ++j) | 
					
						
							|  |  |  |       s2[j] = 32 + 23 * j % (BIG_CHAR - 32); | 
					
						
							|  |  |  |  s2[200] = 0; | 
					
						
							|  |  |  |   for (i = 0; i < 750; ++i) { | 
					
						
							|  |  |  |     for (j = 0; j < i; ++j) | 
					
						
							|  |  |  |       s1[j] = 32 + 23 * j % (BIG_CHAR - 32); | 
					
						
							|  |  |  |     s1[i] = '\0'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        FOR_EACH_IMPL (impl, 0) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       s2[200] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, SIZE_MAX - i); | 
					
						
							|  |  |  |       s2[200] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, i - s1_addr); | 
					
						
							|  |  |  |       s2[200] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, -s1_addr - i); | 
					
						
							|  |  |  |       s2[200] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, SIZE_MAX - s1_addr - i); | 
					
						
							|  |  |  |       s2[200] = '\0'; | 
					
						
							|  |  |  |       do_one_test (impl, s2, s1, SIZE_MAX - s1_addr + i); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     len = 0; | 
					
						
							|  |  |  |     for (j = 8 * sizeof(size_t) - 1; j ; --j) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         len |= one << j; | 
					
						
							|  |  |  |         FOR_EACH_IMPL (impl, 0) | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, len - i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, len + i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, len - s1_addr - i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, len - s1_addr + i); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, ~len - i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, ~len + i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, ~len - s1_addr - i); | 
					
						
							|  |  |  |             s2[200] = '\0'; | 
					
						
							|  |  |  |             do_one_test (impl, s2, s1, ~len - s1_addr + i); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | do_random_tests (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   size_t i, j, n, align1, align2, len1, len2, N; | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |   UCHAR *p1 = (UCHAR *) (buf1 + page_size) - 512; | 
					
						
							|  |  |  |   UCHAR *p2 = (UCHAR *) (buf2 + page_size) - 512; | 
					
						
							|  |  |  |   UCHAR *p3 = (UCHAR *) buf1; | 
					
						
							|  |  |  |   UCHAR *res; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |   fprintf (stdout, "Number of iterations in random test = %zd\n", | 
					
						
							|  |  |  | 	   ITERATIONS); | 
					
						
							|  |  |  |   for (n = 0; n < ITERATIONS; n++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       N = random () & 255; | 
					
						
							|  |  |  |       align1 = random () & 31; | 
					
						
							|  |  |  |       if (random () & 1) | 
					
						
							|  |  |  | 	align2 = random () & 31; | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  | 	align2 = align1 + (random () & 24); | 
					
						
							|  |  |  |       len1 = random () & 511; | 
					
						
							|  |  |  |       if (len1 + align2 > 512) | 
					
						
							|  |  |  | 	len2 = random () & 7; | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  | 	len2 = (512 - len1 - align2) * (random () & (1024 * 1024 - 1)) | 
					
						
							|  |  |  | 	  / (1024 * 1024); | 
					
						
							|  |  |  |       j = align1; | 
					
						
							|  |  |  |       if (align2 + len2 > j) | 
					
						
							|  |  |  | 	j = align2 + len2; | 
					
						
							|  |  |  |       if (len1 + j >= 511) | 
					
						
							|  |  |  | 	len1 = 510 - j - (random () & 7); | 
					
						
							|  |  |  |       if (len1 >= 512) | 
					
						
							|  |  |  | 	len1 = 0; | 
					
						
							|  |  |  |       if (align1 + len1 < 512 - 8) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  j = 510 - align1 - len1 - (random () & 31); | 
					
						
							|  |  |  | 	  if (j > 0 && j < 512) | 
					
						
							|  |  |  | 	    align1 += j; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       j = len1 + align1 + 64; | 
					
						
							|  |  |  |       if (j > 512) | 
					
						
							|  |  |  | 	j = 512; | 
					
						
							|  |  |  |       for (i = 0; i < j; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  if (i == len1 + align1) | 
					
						
							|  |  |  | 	    p1[i] = 0; | 
					
						
							|  |  |  | 	  else | 
					
						
							|  |  |  | 	    { | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	      p1[i] = random () & BIG_CHAR; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	      if (i >= align1 && i < len1 + align1 && !p1[i]) | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 		p1[i] = (random () & SMALL_CHAR) + 3; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	    } | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       for (i = 0; i < len2; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  p3[i] = random () & BIG_CHAR; | 
					
						
							|  |  |  | 	  if (!p3[i]) | 
					
						
							|  |  |  | 	    p3[i] = (random () & SMALL_CHAR) + 3; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |       p3[len2] = 0; | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       FOR_EACH_IMPL (impl, 1) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  MEMSET (p2 - 64, '\1', align2 + 64); | 
					
						
							|  |  |  | 	  MEMSET (p2 + align2 + len2 + 1, '\1', 512 - align2 - len2 - 1); | 
					
						
							|  |  |  | 	  MEMCPY (p2 + align2, p3, len2 + 1); | 
					
						
							|  |  |  | 	  res = (UCHAR *) CALL (impl, (CHAR *) (p2 + align2), | 
					
						
							|  |  |  | 				(CHAR *) (p1 + align1), N); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	  if (res != p2 + align2) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      error (0, 0, "Iteration %zd - wrong result in function %s " | 
					
						
							|  |  |  | 		     "(%zd, %zd, %zd, %zd, %zd) %p != %p", | 
					
						
							|  |  |  | 		     n, impl->name, align1, align2, len1, len2, N, | 
					
						
							|  |  |  | 		     res, p2 + align2); | 
					
						
							|  |  |  | 	      ret = 1; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  for (j = 0; j < align2 + 64; ++j) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      if (p2[j - 64] != '\1') | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 		  error (0, 0, "Iteration %zd - garbage before dst, %s " | 
					
						
							|  |  |  | 			 "%zd, %zd, %zd, %zd, %zd)", | 
					
						
							|  |  |  | 			 n, impl->name, align1, align2, len1, len2, N); | 
					
						
							|  |  |  | 		  ret = 1; | 
					
						
							|  |  |  | 		  break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	    } | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  if (MEMCMP (p2 + align2, p3, len2)) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	    { | 
					
						
							|  |  |  | 	      error (0, 0, "Iteration %zd - garbage in string before, %s " | 
					
						
							|  |  |  | 		     "(%zd, %zd, %zd, %zd, %zd)", | 
					
						
							|  |  |  | 		     n, impl->name, align1, align2, len1, len2, N); | 
					
						
							|  |  |  | 	      ret = 1; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	  if ((len1 + 1) > N) | 
					
						
							|  |  |  | 	    j = align2 + N + 1 + len2; | 
					
						
							|  |  |  | 	  else | 
					
						
							|  |  |  | 	    j = align2 + len1 + 1 + len2; | 
					
						
							|  |  |  | 	  for (; j < 512; ++j) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      if (p2[j] != '\1') | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 		  error (0, 0, "Iteration %zd - garbage after, %s " | 
					
						
							|  |  |  | 			 "(%zd, %zd, %zd, %zd, %zd)", | 
					
						
							|  |  |  | 			 n, impl->name, align1, align2, len1, len2, N); | 
					
						
							|  |  |  | 		  ret = 1; | 
					
						
							|  |  |  | 		  break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  if (len1 + 1 > N) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      if (p2[align2 + N + len2] != '\0') | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 		  error (0, 0, "Iteration %zd - there is no zero at the " | 
					
						
							|  |  |  | 			 "end of output string, %s (%zd, %zd, %zd, %zd, %zd)", | 
					
						
							|  |  |  | 			 n, impl->name, align1, align2, len1, len2, N); | 
					
						
							|  |  |  | 		  ret = 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	    } | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  if (MEMCMP (p1 + align1, p2 + align2 + len2, | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 		      (len1 + 1) > N ? N : len1 + 1)) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      error (0, 0, "Iteration %zd - different strings, %s " | 
					
						
							|  |  |  | 		     "(%zd, %zd, %zd, %zd, %zd)", | 
					
						
							|  |  |  | 		     n, impl->name, align1, align2, len1, len2, N); | 
					
						
							|  |  |  | 	      ret = 1; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | test_main (void) | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   size_t i, n; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   test_init (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   printf ("%28s", ""); | 
					
						
							|  |  |  |   FOR_EACH_IMPL (impl, 0) | 
					
						
							|  |  |  |     printf ("\t%s", impl->name); | 
					
						
							|  |  |  |   putchar ('\n'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (n = 2; n <= 2048; n*=4) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  |       do_test (0, 2, 2, 2, n, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (0, 0, 4, 4, n, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (4, 0, 4, 4, n, BIG_CHAR); | 
					
						
							|  |  |  |       do_test (0, 0, 8, 8, n, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (0, 8, 8, 8, n, SMALL_CHAR); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-03 14:19:12 +00:00
										 |  |  |       do_test (0, 2, 2, 2, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (0, 0, 4, 4, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (4, 0, 4, 4, SIZE_MAX, BIG_CHAR); | 
					
						
							|  |  |  |       do_test (0, 0, 8, 8, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  |       do_test (0, 8, 8, 8, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |       for (i = 1; i < 8; ++i) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  do_test (0, 0, 8 << i, 8 << i, n, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (8 - i, 2 * i, 8 << i, 8 << i, n, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (0, 0, 8 << i, 2 << i, n, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (8 - i, 2 * i, 8 << i, 2 << i, n, SMALL_CHAR); | 
					
						
							| 
									
										
										
										
											2017-01-03 14:19:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	  do_test (0, 0, 8 << i, 8 << i, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (8 - i, 2 * i, 8 << i, 8 << i, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (0, 0, 8 << i, 2 << i, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (8 - i, 2 * i, 8 << i, 2 << i, SIZE_MAX, SMALL_CHAR); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (i = 1; i < 8; ++i) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 	  do_test (i, 2 * i, 8 << i, 1, n, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (2 * i, i, 8 << i, 1, n, BIG_CHAR); | 
					
						
							|  |  |  | 	  do_test (i, i, 8 << i, 10, n, SMALL_CHAR); | 
					
						
							| 
									
										
										
										
											2017-01-03 14:19:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	  do_test (i, 2 * i, 8 << i, 1, SIZE_MAX, SMALL_CHAR); | 
					
						
							|  |  |  | 	  do_test (2 * i, i, 8 << i, 1, SIZE_MAX, BIG_CHAR); | 
					
						
							|  |  |  | 	  do_test (i, i, 8 << i, 10, SIZE_MAX, SMALL_CHAR); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   do_random_tests (); | 
					
						
							| 
									
										
										
										
											2021-06-09 20:17:14 +00:00
										 |  |  |   do_overflow_tests (); | 
					
						
							| 
									
										
										
										
											2023-01-31 23:46:56 +00:00
										 |  |  |   do_test_src_no_nullterm_bz30065 (); | 
					
						
							| 
									
										
										
										
											2011-07-07 01:44:29 +00:00
										 |  |  |   return ret; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-08-26 08:26:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-23 14:32:17 +00:00
										 |  |  | #include <support/test-driver.c>
 |