4 * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5 * See https://llvm.org/LICENSE.txt for license information.
6 * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
14 #include "stringlib.h"
16 static const struct fun
19 char *(*fun
)(const char *s
, int c
);
25 F(__strchr_aarch64_mte
)
26 # if __ARM_FEATURE_SVE
27 F(__strchr_aarch64_sve
)
34 static int test_status
;
35 #define ERR(...) (test_status=1, printf(__VA_ARGS__))
40 static char sbuf
[LEN
+2*A
];
42 static void *alignup(void *p
)
44 return (void*)(((uintptr_t)p
+ A
-1) & -A
);
47 static void test(const struct fun
*fun
, int align
, int seekpos
, int len
)
49 char *src
= alignup(sbuf
);
50 char *s
= src
+ align
;
51 char *f
= seekpos
!= -1 ? s
+ seekpos
: 0;
55 if (len
> LEN
|| seekpos
>= len
- 1 || align
>= A
)
57 if (seekchar
>= 'a' && seekchar
<= 'a' + 23)
60 for (int i
= 0; i
< len
+ A
; i
++)
62 for (int i
= 0; i
< len
- 2; i
++)
65 s
[seekpos
] = seekchar
;
68 p
= fun
->fun(s
, seekchar
);
71 ERR("%s(%p,0x%02x,%d) returned %p\n", fun
->name
, s
, seekchar
, len
, p
);
72 ERR("expected: %p\n", f
);
80 for (int i
=0; funtab
[i
].name
; i
++) {
82 for (int a
= 0; a
< A
; a
++) {
84 for (n
= 1; n
< 100; n
++) {
85 for (int sp
= 0; sp
< n
- 1; sp
++)
86 test(funtab
+i
, a
, sp
, n
);
87 test(funtab
+i
, a
, -1, n
);
89 for (; n
< LEN
; n
*= 2) {
90 test(funtab
+i
, a
, -1, n
);
91 test(funtab
+i
, a
, n
/ 2, n
);
94 printf("%s %s\n", test_status
? "FAIL" : "PASS", funtab
[i
].name
);