]>
git.saurik.com Git - apple/xnu.git/blob - tools/tests/libMicro/strcmp.c
4 * The contents of this file are subject to the terms
5 * of the Common Development and Distribution License
6 * (the "License"). You may not use this file except
7 * in compliance with the License.
9 * You can obtain a copy of the license at
10 * src/OPENSOLARIS.LICENSE
11 * or http://www.opensolaris.org/os/licensing.
12 * See the License for the specific language governing
13 * permissions and limitations under the License.
15 * When distributing Covered Code, include this CDDL
16 * HEADER in each file and include the License file at
17 * usr/src/OPENSOLARIS.LICENSE. If applicable,
18 * add the following below this CDDL HEADER, with the
19 * fields enclosed by brackets "[]" replaced with your
20 * own identifying information: Portions Copyright [yyyy]
21 * [name of copyright owner]
27 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
28 * Use is subject to license terms.
38 static int unaligned
= 0;
39 static int opts
= 100;
52 lm_tsdsize
= sizeof (tsd_t
);
54 (void) sprintf(lm_optstr
, "s:n");
56 (void) sprintf(lm_usage
,
57 " [-s string size (default %d)]\n"
58 " [-n causes unaligned cmp]\n"
59 "notes: measures strcmp()\n",
62 (void) sprintf(lm_header
, "%8s", "size");
68 benchmark_optswitch(int opt
, char *optarg
)
75 opts
= sizetoll(optarg
);
84 benchmark_initbatch(void *tsd
)
86 tsd_t
*ts
= (tsd_t
*)tsd
;
88 "The quick brown fox jumps over the lazy dog.";
90 if (ts
->ts_once
++ == 0) {
94 ts
->ts_a
= malloc(opts
+ 1);
95 ts
->ts_b
= malloc(opts
+ 1 + unaligned
);
96 ts
->ts_b
+= unaligned
;
98 for (i
= 0; i
< opts
; i
++) {
99 ts
->ts_a
[i
] = ts
->ts_b
[i
] = demo
[i%l
];
108 benchmark(void *tsd
, result_t
*res
)
111 tsd_t
*ts
= (tsd_t
*)tsd
;
112 int *sum
= &ts
->ts_fakegcc
;
113 char *src
= ts
->ts_a
;
114 char *src2
= ts
->ts_b
;
118 for (i
= 0; i
< lm_optB
; i
+= 10) {
119 *sum
+= strcmp(src
, src2
);
120 *sum
+= strcmp(src
, src2
);
121 *sum
+= strcmp(src
, src2
);
122 *sum
+= strcmp(src
, src2
);
123 *sum
+= strcmp(src
, src2
);
124 *sum
+= strcmp(src
, src2
);
125 *sum
+= strcmp(src
, src2
);
126 *sum
+= strcmp(src
, src2
);
127 *sum
+= strcmp(src
, src2
);
128 *sum
+= strcmp(src
, src2
);
139 static char result
[256];
142 (void) sprintf(result
, "%8d", opts
);
144 (void) sprintf(result
, "%8d <unaligned>", opts
);