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);
ATF_TC_HEAD(strcpy_basic,tc)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
ATF_TC_BODY(strcpy_basic,tc)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
ATF_TP_ADD_TCS(tp)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