S390: Fix utf32 to utf8 handling of low surrogates (disable cu41).
[glibc.git] / string / test-memset.c
blobfee3bdf37f1fe9069090d04da9347728c4175be7
1 /* Test memset functions.
2 Copyright (C) 1999-2016 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4 Written by Jakub Jelinek <jakub@redhat.com>, 1999.
6 The GNU C Library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the GNU C Library; if not, see
18 <http://www.gnu.org/licenses/>. */
20 #define TEST_MAIN
21 #ifdef TEST_BZERO
22 # define TEST_NAME "bzero"
23 #else
24 # ifndef WIDE
25 # define TEST_NAME "memset"
26 # else
27 # define TEST_NAME "wmemset"
28 # endif /* WIDE */
29 #endif /* !TEST_BZERO */
30 #define MIN_PAGE_SIZE 131072
31 #include "test-string.h"
33 #ifndef WIDE
34 # define MEMSET memset
35 # define CHAR char
36 # define UCHAR unsigned char
37 # define SIMPLE_MEMSET simple_memset
38 # define MEMCMP memcmp
39 # define BIG_CHAR CHAR_MAX
40 #else
41 # include <wchar.h>
42 # define MEMSET wmemset
43 # define CHAR wchar_t
44 # define UCHAR wchar_t
45 # define SIMPLE_MEMSET simple_wmemset
46 # define MEMCMP wmemcmp
47 # define BIG_CHAR WCHAR_MAX
48 #endif /* WIDE */
50 CHAR *SIMPLE_MEMSET (CHAR *, int, size_t);
52 #ifdef TEST_BZERO
53 typedef void (*proto_t) (char *, size_t);
54 void simple_bzero (char *, size_t);
55 void builtin_bzero (char *, size_t);
57 IMPL (simple_bzero, 0)
58 IMPL (builtin_bzero, 0)
59 IMPL (bzero, 1)
61 void
62 simple_bzero (char *s, size_t n)
64 SIMPLE_MEMSET (s, 0, n);
67 void
68 builtin_bzero (char *s, size_t n)
70 __builtin_bzero (s, n);
72 #else
73 typedef CHAR *(*proto_t) (CHAR *, int, size_t);
75 IMPL (SIMPLE_MEMSET, 0)
76 # ifndef WIDE
77 char *builtin_memset (char *, int, size_t);
78 IMPL (builtin_memset, 0)
79 # endif /* !WIDE */
80 IMPL (MEMSET, 1)
82 # ifndef WIDE
83 char *
84 builtin_memset (char *s, int c, size_t n)
86 return __builtin_memset (s, c, n);
88 # endif /* !WIDE */
89 #endif /* !TEST_BZERO */
91 CHAR *
92 inhibit_loop_to_libcall
93 SIMPLE_MEMSET (CHAR *s, int c, size_t n)
95 CHAR *r = s, *end = s + n;
96 while (r < end)
97 *r++ = c;
98 return s;
101 static void
102 do_one_test (impl_t *impl, CHAR *s, int c __attribute ((unused)), size_t n)
104 CHAR tstbuf[n];
105 #ifdef TEST_BZERO
106 simple_bzero (tstbuf, n);
107 CALL (impl, s, n);
108 if (memcmp (s, tstbuf, n) != 0)
109 #else
110 CHAR *res = CALL (impl, s, c, n);
111 if (res != s
112 || SIMPLE_MEMSET (tstbuf, c, n) != tstbuf
113 || MEMCMP (s, tstbuf, n) != 0)
114 #endif /* !TEST_BZERO */
116 error (0, 0, "Wrong result in function %s", impl->name);
117 ret = 1;
118 return;
122 static void
123 do_test (size_t align, int c, size_t len)
125 align &= 7;
126 if ((align + len) * sizeof (CHAR) > page_size)
127 return;
129 FOR_EACH_IMPL (impl, 0)
130 do_one_test (impl, (CHAR *) (buf1) + align, c, len);
133 #ifndef TEST_BZERO
134 static void
135 do_random_tests (void)
137 size_t i, j, k, n, align, len, size;
138 int c, o;
139 UCHAR *p, *res;
140 UCHAR *p2 = (UCHAR *) buf2;
142 for (i = 0; i < 65536 / sizeof (CHAR); ++i)
143 p2[i] = random () & BIG_CHAR;
145 for (n = 0; n < ITERATIONS; n++)
147 if ((random () & 31) == 0)
148 size = 65536 / sizeof (CHAR);
149 else
150 size = 512;
151 p = (UCHAR *) (buf1 + page_size) - size;
152 len = random () & (size - 1);
153 align = size - len - (random () & 31);
154 if (align > size)
155 align = size - len;
156 if ((random () & 7) == 0)
157 align &= ~63;
158 if ((random () & 7) == 0)
159 c = 0;
160 else
161 c = random () & BIG_CHAR;
162 o = random () & BIG_CHAR;
163 if (o == c)
164 o = (c + 1) & BIG_CHAR;
165 j = len + align + 128;
166 if (j > size)
167 j = size;
168 if (align >= 128)
169 k = align - 128;
170 else
171 k = 0;
172 for (i = k; i < align; ++i)
173 p[i] = o;
174 for (i = align + len; i < j; ++i)
175 p[i] = o;
177 FOR_EACH_IMPL (impl, 1)
179 for (i = 0; i < len; ++i)
181 p[i + align] = p2[i];
182 if (p[i + align] == c)
183 p[i + align] = o;
185 res = (UCHAR *) CALL (impl, (CHAR *) p + align, c, len);
186 if (res != p + align)
188 error (0, 0, "Iteration %zd - wrong result in function %s (%zd, %d, %zd) %p != %p",
189 n, impl->name, align, c, len, res, p + align);
190 ret = 1;
192 for (i = k; i < align; ++i)
193 if (p[i] != o)
195 error (0, 0, "Iteration %zd - garbage before %s (%zd, %d, %zd)",
196 n, impl->name, align, c, len);
197 ret = 1;
198 break;
200 for (; i < align + len; ++i)
201 if (p[i] != c)
203 error (0, 0, "Iteration %zd - not cleared correctly %s (%zd, %d, %zd)",
204 n, impl->name, align, c, len);
205 ret = 1;
206 break;
208 for (; i < j; ++i)
209 if (p[i] != o)
211 error (0, 0, "Iteration %zd - garbage after %s (%zd, %d, %zd)",
212 n, impl->name, align, c, len);
213 ret = 1;
214 break;
219 #endif /* !TEST_BZERO */
222 test_main (void)
224 size_t i;
225 int c = 0;
227 test_init ();
229 printf ("%24s", "");
230 FOR_EACH_IMPL (impl, 0)
231 printf ("\t%s", impl->name);
232 putchar ('\n');
234 #ifndef TEST_BZERO
235 for (c = -65; c <= 130; c += 65)
236 #endif
238 for (i = 0; i < 18; ++i)
239 do_test (0, c, 1 << i);
240 for (i = 1; i < 32; ++i)
242 do_test (i, c, i);
243 if (i & (i - 1))
244 do_test (0, c, i);
246 do_test (1, c, 14);
247 do_test (3, c, 1024);
248 do_test (4, c, 64);
249 do_test (2, c, 25);
252 #ifndef TEST_BZERO
253 do_random_tests ();
254 #endif
256 return ret;
259 #include "../test-skeleton.c"