3 @@ -123,7 +123,7 @@ int main(int argc, char **argv) {
4 pagesizemask = (ptrdiff_t) ~(pagesize - 1);
5 printf("pagesizemask is 0x%tx\n", pagesizemask);
7 - while ((opt = getopt(argc, argv, "p:")) != -1) {
8 + while ((opt = getopt(argc, argv, "qp:")) != -1) {
12 @@ -150,6 +150,9 @@ int main(int argc, char **argv) {
13 /* okay, got address */
20 usage(argv[0]); /* doesn't return */
32 #include "memtester.h"
35 char progress[] = "-\\|/";
37 +void inline dprintf(const char *format, ...) {
40 + va_start(ap, format);
41 + vprintf(format, ap);
46 #define PROGRESSOFTEN 2500
47 #define ONE 0x00000001L
48 @@ -65,16 +76,16 @@ int test_stuck_address(ulv *bufa, size_t
51 for (j = 0; j < 16; j++) {
52 - printf("\b\b\b\b\b\b\b\b\b\b\b");
53 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
55 - printf("setting %3u", j);
56 + dprintf("setting %3u", j);
58 for (i = 0; i < count; i++) {
59 *p1 = ((j + i) % 2) == 0 ? (ul) p1 : ~((ul) p1);
62 - printf("\b\b\b\b\b\b\b\b\b\b\b");
63 - printf("testing %3u", j);
64 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
65 + dprintf("testing %3u", j);
68 for (i = 0; i < count; i++, p1++) {
69 @@ -97,7 +108,7 @@ int test_stuck_address(ulv *bufa, size_t
73 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
74 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
78 @@ -112,13 +123,13 @@ int test_random_value(ulv *bufa, ulv *bu
80 for (i = 0; i < count; i++) {
81 *p1++ = *p2++ = rand_ul();
82 - if (!(i % PROGRESSOFTEN)) {
83 + if (!quiet && !(i % PROGRESSOFTEN)) {
85 putchar(progress[++j % PROGRESSLEN]);
92 return compare_regions(bufa, bufb, count);
94 @@ -226,23 +237,23 @@ int test_solidbits_comparison(ulv *bufa,
97 for (j = 0; j < 64; j++) {
98 - printf("\b\b\b\b\b\b\b\b\b\b\b");
99 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
100 q = (j % 2) == 0 ? UL_ONEBITS : 0;
101 - printf("setting %3u", j);
102 + dprintf("setting %3u", j);
106 for (i = 0; i < count; i++) {
107 *p1++ = *p2++ = (i % 2) == 0 ? q : ~q;
109 - printf("\b\b\b\b\b\b\b\b\b\b\b");
110 - printf("testing %3u", j);
111 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
112 + dprintf("testing %3u", j);
114 if (compare_regions(bufa, bufb, count)) {
118 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
119 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
123 @@ -257,23 +268,23 @@ int test_checkerboard_comparison(ulv *bu
126 for (j = 0; j < 64; j++) {
127 - printf("\b\b\b\b\b\b\b\b\b\b\b");
128 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
129 q = (j % 2) == 0 ? CHECKERBOARD1 : CHECKERBOARD2;
130 - printf("setting %3u", j);
131 + dprintf("setting %3u", j);
135 for (i = 0; i < count; i++) {
136 *p1++ = *p2++ = (i % 2) == 0 ? q : ~q;
138 - printf("\b\b\b\b\b\b\b\b\b\b\b");
139 - printf("testing %3u", j);
140 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
141 + dprintf("testing %3u", j);
143 if (compare_regions(bufa, bufb, count)) {
147 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
148 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
152 @@ -284,25 +295,25 @@ int test_blockseq_comparison(ulv *bufa,
159 for (j = 0; j < 256; j++) {
160 - printf("\b\b\b\b\b\b\b\b\b\b\b");
161 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
164 - printf("setting %3u", j);
165 + dprintf("setting %3u", j);
167 for (i = 0; i < count; i++) {
168 *p1++ = *p2++ = (ul) UL_BYTE(j);
170 - printf("\b\b\b\b\b\b\b\b\b\b\b");
171 - printf("testing %3u", j);
172 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
173 + dprintf("testing %3u", j);
175 if (compare_regions(bufa, bufb, count)) {
179 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
180 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
184 @@ -316,10 +327,10 @@ int test_walkbits0_comparison(ulv *bufa,
187 for (j = 0; j < UL_LEN * 2; j++) {
188 - printf("\b\b\b\b\b\b\b\b\b\b\b");
189 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
192 - printf("setting %3u", j);
193 + dprintf("setting %3u", j);
195 for (i = 0; i < count; i++) {
196 if (j < UL_LEN) { /* Walk it up. */
197 @@ -328,14 +339,14 @@ int test_walkbits0_comparison(ulv *bufa,
198 *p1++ = *p2++ = ONE << (UL_LEN * 2 - j - 1);
201 - printf("\b\b\b\b\b\b\b\b\b\b\b");
202 - printf("testing %3u", j);
203 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
204 + dprintf("testing %3u", j);
206 if (compare_regions(bufa, bufb, count)) {
210 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
211 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
215 @@ -346,13 +357,13 @@ int test_walkbits1_comparison(ulv *bufa,
222 for (j = 0; j < UL_LEN * 2; j++) {
223 - printf("\b\b\b\b\b\b\b\b\b\b\b");
224 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
227 - printf("setting %3u", j);
228 + dprintf("setting %3u", j);
230 for (i = 0; i < count; i++) {
231 if (j < UL_LEN) { /* Walk it up. */
232 @@ -361,14 +372,14 @@ int test_walkbits1_comparison(ulv *bufa,
233 *p1++ = *p2++ = UL_ONEBITS ^ (ONE << (UL_LEN * 2 - j - 1));
236 - printf("\b\b\b\b\b\b\b\b\b\b\b");
237 - printf("testing %3u", j);
238 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
239 + dprintf("testing %3u", j);
241 if (compare_regions(bufa, bufb, count)) {
245 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
246 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
250 @@ -379,13 +390,13 @@ int test_bitspread_comparison(ulv *bufa,
257 for (j = 0; j < UL_LEN * 2; j++) {
258 - printf("\b\b\b\b\b\b\b\b\b\b\b");
259 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
262 - printf("setting %3u", j);
263 + dprintf("setting %3u", j);
265 for (i = 0; i < count; i++) {
266 if (j < UL_LEN) { /* Walk it up. */
267 @@ -400,14 +411,14 @@ int test_bitspread_comparison(ulv *bufa,
268 | (ONE << (UL_LEN * 2 + 1 - j)));
271 - printf("\b\b\b\b\b\b\b\b\b\b\b");
272 - printf("testing %3u", j);
273 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
274 + dprintf("testing %3u", j);
276 if (compare_regions(bufa, bufb, count)) {
280 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
281 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
285 @@ -419,29 +430,29 @@ int test_bitflip_comparison(ulv *bufa, u
292 for (k = 0; k < UL_LEN; k++) {
294 for (j = 0; j < 8; j++) {
295 - printf("\b\b\b\b\b\b\b\b\b\b\b");
296 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
298 - printf("setting %3u", k * 8 + j);
299 + dprintf("setting %3u", k * 8 + j);
303 for (i = 0; i < count; i++) {
304 *p1++ = *p2++ = (i % 2) == 0 ? q : ~q;
306 - printf("\b\b\b\b\b\b\b\b\b\b\b");
307 - printf("testing %3u", k * 8 + j);
308 + dprintf("\b\b\b\b\b\b\b\b\b\b\b");
309 + dprintf("testing %3u", k * 8 + j);
311 if (compare_regions(bufa, bufb, count)) {
316 - printf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
317 + dprintf("\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b");
329 /* Function declaration. */
331 int test_stuck_address(unsigned long volatile *bufa, size_t count);