diff options
author | H.J. Lu <hongjiu.lu@intel.com> | 2011-03-21 05:35:38 -0400 |
---|---|---|
committer | Ulrich Drepper <drepper@gmail.com> | 2011-03-21 05:35:38 -0400 |
commit | c97a1282a4d9ff5d462fa5d8f20797ded3629500 (patch) | |
tree | 3814633129440b03ee04577aa49c7b0208c48144 /string/test-strncmp.c | |
parent | 2a1156010784332cbe4bf033ccedb19f52e56a75 (diff) | |
download | glibc-c97a1282a4d9ff5d462fa5d8f20797ded3629500.zip glibc-c97a1282a4d9ff5d462fa5d8f20797ded3629500.tar.gz glibc-c97a1282a4d9ff5d462fa5d8f20797ded3629500.tar.bz2 |
Handle page boundaries in x86 SSE4.2 strncmp.
Diffstat (limited to 'string/test-strncmp.c')
-rw-r--r-- | string/test-strncmp.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/string/test-strncmp.c b/string/test-strncmp.c index 3687879..11c681e 100644 --- a/string/test-strncmp.c +++ b/string/test-strncmp.c @@ -200,6 +200,27 @@ do_test (size_t align1, size_t align2, size_t len, size_t n, int max_char, } static void +do_page_test (size_t offset1, size_t offset2, char *s2) +{ + char *s1; + int exp_result; + + if (offset1 >= page_size || offset2 >= page_size) + return; + + s1 = (char *) (buf1 + offset1); + s2 += offset2; + + exp_result= *s1; + + FOR_EACH_IMPL (impl, 0) + { + check_result (impl, s1, s2, page_size, -exp_result); + check_result (impl, s2, s1, page_size, exp_result); + } +} + +static void do_random_tests (void) { size_t i, j, n, align1, align2, pos, len1, len2, size; @@ -312,6 +333,25 @@ check1 (void) } } +static void +check2 (void) +{ + size_t i; + char *s1, *s2; + + s1 = (char *) buf1; + for (i = 0; i < page_size - 1; i++) + s1[i] = 23; + s1[i] = 0; + + s2 = strdup (s1); + + for (i = 0; i < 64; ++i) + do_page_test (3990 + i, 2635, s2); + + free (s2); +} + int test_main (void) { @@ -320,6 +360,7 @@ test_main (void) test_init (); check1 (); + check2 (); printf ("%23s", ""); FOR_EACH_IMPL (impl, 0) |