1 /* Measure STRLEN functions.
2 Copyright (C) 2013-2024 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <https://www.gnu.org/licenses/>. */
21 # define TEST_NAME "strlen"
23 # define TEST_NAME "wcslen"
24 # define generic_strlen generic_wcslen
25 # define memchr_strlen wcschr_wcslen
27 #include "bench-string.h"
31 typedef size_t (*proto_t) (const CHAR *);
33 size_t generic_strlen (const CHAR *);
34 size_t memchr_strlen (const CHAR *);
36 IMPL (memchr_strlen, 0)
37 IMPL (generic_strlen, 0)
40 memchr_strlen (const CHAR *p)
42 return (const CHAR *)MEMCHR (p, 0, PTRDIFF_MAX) - p;
49 do_one_test (json_ctx_t *json_ctx, impl_t *impl, const CHAR *s, size_t exp_len)
51 size_t len = CALL (impl, s), i, iters = INNER_LOOP_ITERS_LARGE;
52 timing_t start, stop, cur;
56 error (0, 0, "Wrong result in function %s %zd %zd", impl->name,
63 for (i = 0; i < iters; ++i)
69 TIMING_DIFF (cur, start, stop);
71 json_element_double (json_ctx, (double) cur / (double) iters);
75 do_test (json_ctx_t *json_ctx, size_t align, size_t len)
80 if (align + sizeof (CHAR) * len >= page_size)
83 json_element_object_begin (json_ctx);
84 json_attr_uint (json_ctx, "length", len);
85 json_attr_uint (json_ctx, "alignment", align);
86 json_array_begin (json_ctx, "timings");
89 FOR_EACH_IMPL (impl, 0)
91 CHAR *buf = (CHAR *) (buf1);
93 for (i = 0; i < len; ++i)
94 buf[align + i] = 1 + 11111 * i % MAX_CHAR;
97 do_one_test (json_ctx, impl, (CHAR *) (buf + align), len);
101 json_array_end (json_ctx);
102 json_element_object_end (json_ctx);
113 json_init (&json_ctx, 0, stdout);
115 json_document_begin (&json_ctx);
116 json_attr_string (&json_ctx, "timing_type", TIMING_TYPE);
118 json_attr_object_begin (&json_ctx, "functions");
119 json_attr_object_begin (&json_ctx, TEST_NAME);
120 json_attr_string (&json_ctx, "bench-variant", "");
122 json_array_begin (&json_ctx, "ifuncs");
123 FOR_EACH_IMPL (impl, 0)
124 json_element_string (&json_ctx, impl->name);
125 json_array_end (&json_ctx);
127 json_array_begin (&json_ctx, "results");
128 /* Checking with only 4 * N alignments for wcslen, other alignments are wrong for wchar_t type arrays*/
130 for (i = 1; i < 8; ++i)
132 do_test (&json_ctx, sizeof (CHAR) * i, i);
133 do_test (&json_ctx, 0, i);
136 for (i = 2; i <= 12; ++i)
138 do_test (&json_ctx, 0, 1 << i);
139 do_test (&json_ctx, sizeof (CHAR) * 7, 1 << i);
140 do_test (&json_ctx, sizeof (CHAR) * i, 1 << i);
141 do_test (&json_ctx, sizeof (CHAR) * i, (size_t)((1 << i) / 1.5));
144 for (i = 0; i < 512; i += 32)
146 do_test (&json_ctx, 0, i / sizeof (CHAR));
149 for (i = 512; i < 1024; i += 64)
151 do_test (&json_ctx, 0, i / sizeof (CHAR));
154 for (i = 1024; i < 2048; i += 128)
156 do_test (&json_ctx, 0, i / sizeof (CHAR));
159 for (i = 2048; i < 4096; i += 256)
161 do_test (&json_ctx, 0, i / sizeof (CHAR));
164 for (i = 4096; i < 8192; i += 512)
166 do_test (&json_ctx, 0, i / sizeof (CHAR));
169 json_array_end (&json_ctx);
170 json_attr_object_end (&json_ctx);
171 json_attr_object_end (&json_ctx);
172 json_document_end (&json_ctx);
177 #include <support/test-driver.c>
179 #define libc_hidden_builtin_def(X)
182 # define STRLEN generic_strlen
183 # include <string/strlen.c>
185 # define WCSLEN generic_strlen
186 # include <wcsmbs/wcslen.c>