t_snprintb.c revision 1.6 1 1.6 kre /* $NetBSD: t_snprintb.c,v 1.6 2019/04/29 07:55:38 kre Exp $ */
2 1.1 jmmv
3 1.1 jmmv /*
4 1.1 jmmv * Copyright (c) 2002, 2004, 2008, 2010 The NetBSD Foundation, Inc.
5 1.1 jmmv * All rights reserved.
6 1.1 jmmv *
7 1.1 jmmv * This code was contributed to The NetBSD Foundation by Christos Zoulas.
8 1.1 jmmv *
9 1.1 jmmv * Redistribution and use in source and binary forms, with or without
10 1.1 jmmv * modification, are permitted provided that the following conditions
11 1.1 jmmv * are met:
12 1.1 jmmv * 1. Redistributions of source code must retain the above copyright
13 1.1 jmmv * notice, this list of conditions and the following disclaimer.
14 1.1 jmmv * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 jmmv * notice, this list of conditions and the following disclaimer in the
16 1.1 jmmv * documentation and/or other materials provided with the distribution.
17 1.1 jmmv *
18 1.1 jmmv * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 1.1 jmmv * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 1.1 jmmv * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 1.1 jmmv * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 1.1 jmmv * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 1.1 jmmv * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 1.1 jmmv * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 1.1 jmmv * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 1.1 jmmv * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 1.1 jmmv * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 1.1 jmmv * POSSIBILITY OF SUCH DAMAGE.
29 1.1 jmmv */
30 1.1 jmmv
31 1.1 jmmv #include <sys/cdefs.h>
32 1.1 jmmv __COPYRIGHT("@(#) Copyright (c) 2008, 2010\
33 1.1 jmmv The NetBSD Foundation, inc. All rights reserved.");
34 1.6 kre __RCSID("$NetBSD: t_snprintb.c,v 1.6 2019/04/29 07:55:38 kre Exp $");
35 1.1 jmmv
36 1.1 jmmv #include <string.h>
37 1.1 jmmv #include <util.h>
38 1.1 jmmv
39 1.1 jmmv #include <atf-c.h>
40 1.1 jmmv
41 1.1 jmmv static void
42 1.1 jmmv h_snprintb(const char *fmt, uint64_t val, const char *res)
43 1.1 jmmv {
44 1.1 jmmv char buf[1024];
45 1.1 jmmv int len, slen;
46 1.1 jmmv
47 1.1 jmmv len = snprintb(buf, sizeof(buf), fmt, val);
48 1.1 jmmv slen = (int) strlen(res);
49 1.1 jmmv
50 1.1 jmmv ATF_REQUIRE_STREQ(res, buf);
51 1.1 jmmv ATF_REQUIRE_EQ(len, slen);
52 1.1 jmmv }
53 1.1 jmmv
54 1.1 jmmv ATF_TC(snprintb);
55 1.1 jmmv ATF_TC_HEAD(snprintb, tc)
56 1.1 jmmv {
57 1.1 jmmv atf_tc_set_md_var(tc, "descr", "Checks snprintb(3)");
58 1.1 jmmv }
59 1.1 jmmv ATF_TC_BODY(snprintb, tc)
60 1.1 jmmv {
61 1.1 jmmv h_snprintb("\10\2BITTWO\1BITONE", 3, "03<BITTWO,BITONE>");
62 1.4 shm h_snprintb("\177\20b\0A\0\0", 0, "0x0");
63 1.5 ryo
64 1.1 jmmv h_snprintb("\177\20b\05NOTBOOT\0b\06FPP\0b\013SDVMA\0b\015VIDEO\0"
65 1.1 jmmv "b\020LORES\0b\021FPA\0b\022DIAG\0b\016CACHE\0"
66 1.1 jmmv "b\017IOCACHE\0b\022LOOPBACK\0b\04DBGCACHE\0",
67 1.1 jmmv 0xe860, "0xe860<NOTBOOT,FPP,SDVMA,VIDEO,CACHE,IOCACHE>");
68 1.5 ryo
69 1.5 ryo h_snprintb("\177\20f\0\4FOO\0=\1ONE\0=\2TWO\0\0", 1,
70 1.5 ryo "0x1<FOO=0x1=ONE>");
71 1.5 ryo h_snprintb("\177\20f\0\4X\0=\1ONE\0=\2TWO\0\0", 1,
72 1.5 ryo "0x1<X=0x1=ONE>");
73 1.6 kre h_snprintb("\177\020F\0\4\0:\1ONE\0:\2TWO\0\0", 1,
74 1.6 kre "0x1<ONE>");
75 1.5 ryo
76 1.6 kre h_snprintb("\177\20f\0\4FOO\0=\1ONE\0=\2TWO\0\0", 2,
77 1.6 kre "0x2<FOO=0x2=TWO>");
78 1.6 kre h_snprintb("\177\20f\0\4X\0=\1ONE\0=\2TWO\0\0", 2,
79 1.6 kre "0x2<X=0x2=TWO>");
80 1.6 kre h_snprintb("\177\020F\0\4\0:\1ONE\0:\2TWO\0\0", 2,
81 1.6 kre "0x2<TWO>");
82 1.6 kre
83 1.6 kre h_snprintb("\177\20f\0\4FOO\0=\1ONE\0=\2TWO\0*=OTHER\0\0", 3,
84 1.6 kre "0x3<FOO=0x3=OTHER>");
85 1.6 kre h_snprintb("\177\20f\0\4X\0=\1ONE\0=\2TWO\0*=Other(%d)\0\0", 3,
86 1.6 kre "0x3<X=0x3=Other(3)>");
87 1.6 kre h_snprintb("\177\20f\0\x8X\0=\1ONE\0=\2TWO\0*=other(%o)\0\0", 0x20,
88 1.6 kre "0x20<X=0x20=other(40)>");
89 1.6 kre h_snprintb("\177\020F\0\4\0:\1ONE\0:\2TWO\0\0", 3,
90 1.6 kre "0x3<>");
91 1.6 kre
92 1.6 kre h_snprintb("\177\20f\0\4Field_1\0=\1ONE\0=\2TWO\0"
93 1.6 kre "f\4\4Field_2\0=\1ONE\0=\2TWO\0\0", 0x12,
94 1.6 kre "0x12<Field_1=0x2=TWO,Field_2=0x1=ONE>");
95 1.6 kre
96 1.6 kre h_snprintb("\177\20f\0\4Field_1\0=\1ONE\0=\2TWO\0"
97 1.6 kre "F\x8\4\0*Field_3=%d\0"
98 1.6 kre "f\4\4Field_2\0:\1:ONE\0:\2:TWO\0\0", 0xD12,
99 1.6 kre "0xd12<Field_1=0x2=TWO,Field_3=13,Field_2=0x1:ONE>");
100 1.1 jmmv }
101 1.1 jmmv
102 1.2 pgoyette static void
103 1.2 pgoyette h_snprintb_m(const char *fmt, uint64_t val, int line_max, const char *res,
104 1.2 pgoyette int res_len)
105 1.2 pgoyette {
106 1.2 pgoyette char buf[1024];
107 1.2 pgoyette int len;
108 1.2 pgoyette
109 1.2 pgoyette len = snprintb_m(buf, sizeof(buf), fmt, val, line_max);
110 1.2 pgoyette
111 1.3 pgoyette ATF_REQUIRE_EQ(len, res_len);
112 1.2 pgoyette ATF_REQUIRE_EQ(0, memcmp(res, buf, res_len + 1));
113 1.2 pgoyette }
114 1.2 pgoyette
115 1.2 pgoyette ATF_TC(snprintb_m);
116 1.2 pgoyette ATF_TC_HEAD(snprintb_m, tc)
117 1.2 pgoyette {
118 1.2 pgoyette atf_tc_set_md_var(tc, "descr", "Checks snprintb_m(3)");
119 1.2 pgoyette }
120 1.2 pgoyette ATF_TC_BODY(snprintb_m, tc)
121 1.2 pgoyette {
122 1.2 pgoyette h_snprintb_m("\177\020b\0LSB\0b\1_BITONE\0f\4\4NIBBLE2\0"
123 1.2 pgoyette "f\x10\4BURST\0=\4FOUR\0=\xfSIXTEEN\0"
124 1.2 pgoyette "b\x1fMSB\0\0",
125 1.2 pgoyette 0x800f0701,
126 1.2 pgoyette 33,
127 1.2 pgoyette "0x800f0701<LSB,NIBBLE2=0x0>\0"
128 1.2 pgoyette "0x800f0701<BURST=0xf=SIXTEEN,MSB>\0\0",
129 1.2 pgoyette 62);
130 1.2 pgoyette
131 1.2 pgoyette h_snprintb_m("\177\020b\0LSB\0b\1_BITONE\0f\4\4NIBBLE2\0"
132 1.2 pgoyette "f\x10\4BURST\0=\4FOUR\0=\xfSIXTEEN\0"
133 1.2 pgoyette "b\x1fMSB\0\0",
134 1.2 pgoyette 0x800f0701,
135 1.2 pgoyette 32,
136 1.2 pgoyette "0x800f0701<LSB,NIBBLE2=0x0>\0"
137 1.2 pgoyette "0x800f0701<BURST=0xf=SIXTEEN>\0"
138 1.2 pgoyette "0x800f0701<MSB>\0\0",
139 1.2 pgoyette 74);
140 1.2 pgoyette }
141 1.2 pgoyette
142 1.1 jmmv ATF_TP_ADD_TCS(tp)
143 1.1 jmmv {
144 1.1 jmmv
145 1.1 jmmv ATF_TP_ADD_TC(tp, snprintb);
146 1.2 pgoyette ATF_TP_ADD_TC(tp, snprintb_m);
147 1.1 jmmv
148 1.1 jmmv return atf_no_error();
149 1.1 jmmv }
150