1*57718be8SEnji Cooper /* $NetBSD: t_strcpy.c,v 1.1 2011/07/07 08:59:33 jruoho Exp $ */ 2*57718be8SEnji Cooper 3*57718be8SEnji Cooper /* 4*57718be8SEnji Cooper * Written by J.T. Conklin <jtc@acorntoolworks.com> 5*57718be8SEnji Cooper * Public domain. 6*57718be8SEnji Cooper */ 7*57718be8SEnji Cooper 8*57718be8SEnji Cooper #include <atf-c.h> 9*57718be8SEnji Cooper #include <string.h> 10*57718be8SEnji Cooper #include <unistd.h> 11*57718be8SEnji Cooper #include <stdio.h> 12*57718be8SEnji Cooper #include <stdlib.h> 13*57718be8SEnji Cooper 14*57718be8SEnji Cooper ATF_TC(strcpy_basic); 15*57718be8SEnji Cooper ATF_TC_HEAD(strcpy_basic, tc) 16*57718be8SEnji Cooper { 17*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "Test strcpy(3) results"); 18*57718be8SEnji Cooper } 19*57718be8SEnji Cooper 20*57718be8SEnji Cooper ATF_TC_BODY(strcpy_basic, tc) 21*57718be8SEnji Cooper { 22*57718be8SEnji Cooper /* try to trick the compiler */ 23*57718be8SEnji Cooper char * (*f)(char *, const char *s) = strcpy; 24*57718be8SEnji Cooper 25*57718be8SEnji Cooper unsigned int a0, a1, t; 26*57718be8SEnji Cooper char buf0[64]; 27*57718be8SEnji Cooper char buf1[64]; 28*57718be8SEnji Cooper char *ret; 29*57718be8SEnji Cooper 30*57718be8SEnji Cooper struct tab { 31*57718be8SEnji Cooper const char* val; 32*57718be8SEnji Cooper size_t len; 33*57718be8SEnji Cooper }; 34*57718be8SEnji Cooper 35*57718be8SEnji Cooper const struct tab tab[] = { 36*57718be8SEnji Cooper /* 37*57718be8SEnji Cooper * patterns that check for all combinations of leading and 38*57718be8SEnji Cooper * trailing unaligned characters (on a 64 bit processor) 39*57718be8SEnji Cooper */ 40*57718be8SEnji Cooper 41*57718be8SEnji Cooper { "", 0 }, 42*57718be8SEnji Cooper { "a", 1 }, 43*57718be8SEnji Cooper { "ab", 2 }, 44*57718be8SEnji Cooper { "abc", 3 }, 45*57718be8SEnji Cooper { "abcd", 4 }, 46*57718be8SEnji Cooper { "abcde", 5 }, 47*57718be8SEnji Cooper { "abcdef", 6 }, 48*57718be8SEnji Cooper { "abcdefg", 7 }, 49*57718be8SEnji Cooper { "abcdefgh", 8 }, 50*57718be8SEnji Cooper { "abcdefghi", 9 }, 51*57718be8SEnji Cooper { "abcdefghij", 10 }, 52*57718be8SEnji Cooper { "abcdefghijk", 11 }, 53*57718be8SEnji Cooper { "abcdefghijkl", 12 }, 54*57718be8SEnji Cooper { "abcdefghijklm", 13 }, 55*57718be8SEnji Cooper { "abcdefghijklmn", 14 }, 56*57718be8SEnji Cooper { "abcdefghijklmno", 15 }, 57*57718be8SEnji Cooper { "abcdefghijklmnop", 16 }, 58*57718be8SEnji Cooper { "abcdefghijklmnopq", 17 }, 59*57718be8SEnji Cooper { "abcdefghijklmnopqr", 18 }, 60*57718be8SEnji Cooper { "abcdefghijklmnopqrs", 19 }, 61*57718be8SEnji Cooper { "abcdefghijklmnopqrst", 20 }, 62*57718be8SEnji Cooper { "abcdefghijklmnopqrstu", 21 }, 63*57718be8SEnji Cooper { "abcdefghijklmnopqrstuv", 22 }, 64*57718be8SEnji Cooper { "abcdefghijklmnopqrstuvw", 23 }, 65*57718be8SEnji Cooper 66*57718be8SEnji Cooper /* 67*57718be8SEnji Cooper * patterns that check for the cases where the expression: 68*57718be8SEnji Cooper * 69*57718be8SEnji Cooper * ((word - 0x7f7f..7f) & 0x8080..80) 70*57718be8SEnji Cooper * 71*57718be8SEnji Cooper * returns non-zero even though there are no zero bytes in 72*57718be8SEnji Cooper * the word. 73*57718be8SEnji Cooper */ 74*57718be8SEnji Cooper 75*57718be8SEnji Cooper { "" "\xff\xff\xff\xff\xff\xff\xff\xff" "abcdefgh", 16 }, 76*57718be8SEnji Cooper { "a" "\xff\xff\xff\xff\xff\xff\xff\xff" "bcdefgh", 16 }, 77*57718be8SEnji Cooper { "ab" "\xff\xff\xff\xff\xff\xff\xff\xff" "cdefgh", 16 }, 78*57718be8SEnji Cooper { "abc" "\xff\xff\xff\xff\xff\xff\xff\xff" "defgh", 16 }, 79*57718be8SEnji Cooper { "abcd" "\xff\xff\xff\xff\xff\xff\xff\xff" "efgh", 16 }, 80*57718be8SEnji Cooper { "abcde" "\xff\xff\xff\xff\xff\xff\xff\xff" "fgh", 16 }, 81*57718be8SEnji Cooper { "abcdef" "\xff\xff\xff\xff\xff\xff\xff\xff" "gh", 16 }, 82*57718be8SEnji Cooper { "abcdefg" "\xff\xff\xff\xff\xff\xff\xff\xff" "h", 16 }, 83*57718be8SEnji Cooper { "abcdefgh" "\xff\xff\xff\xff\xff\xff\xff\xff" "", 16 }, 84*57718be8SEnji Cooper }; 85*57718be8SEnji Cooper 86*57718be8SEnji Cooper for (a0 = 0; a0 < sizeof(long); ++a0) { 87*57718be8SEnji Cooper for (a1 = 0; a1 < sizeof(long); ++a1) { 88*57718be8SEnji Cooper for (t = 0; t < (sizeof(tab) / sizeof(tab[0])); ++t) { 89*57718be8SEnji Cooper 90*57718be8SEnji Cooper memcpy(&buf1[a1], tab[t].val, tab[t].len + 1); 91*57718be8SEnji Cooper ret = f(&buf0[a0], &buf1[a1]); 92*57718be8SEnji Cooper 93*57718be8SEnji Cooper /* 94*57718be8SEnji Cooper * verify strcpy returns address of 95*57718be8SEnji Cooper * first parameter 96*57718be8SEnji Cooper */ 97*57718be8SEnji Cooper if (&buf0[a0] != ret) { 98*57718be8SEnji Cooper fprintf(stderr, "a0 %d, a1 %d, t %d\n", 99*57718be8SEnji Cooper a0, a1, t); 100*57718be8SEnji Cooper atf_tc_fail("strcpy did not return " 101*57718be8SEnji Cooper "its first arg"); 102*57718be8SEnji Cooper } 103*57718be8SEnji Cooper 104*57718be8SEnji Cooper /* 105*57718be8SEnji Cooper * verify string was copied correctly 106*57718be8SEnji Cooper */ 107*57718be8SEnji Cooper if (memcmp(&buf0[a0], &buf1[a1], 108*57718be8SEnji Cooper tab[t].len + 1) != 0) { 109*57718be8SEnji Cooper fprintf(stderr, "a0 %d, a1 %d, t %d\n", 110*57718be8SEnji Cooper a0, a1, t); 111*57718be8SEnji Cooper atf_tc_fail("not correctly copied"); 112*57718be8SEnji Cooper } 113*57718be8SEnji Cooper } 114*57718be8SEnji Cooper } 115*57718be8SEnji Cooper } 116*57718be8SEnji Cooper } 117*57718be8SEnji Cooper 118*57718be8SEnji Cooper ATF_TP_ADD_TCS(tp) 119*57718be8SEnji Cooper { 120*57718be8SEnji Cooper 121*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, strcpy_basic); 122*57718be8SEnji Cooper 123*57718be8SEnji Cooper return atf_no_error(); 124*57718be8SEnji Cooper } 125