]>
git.saurik.com Git - apple/xnu.git/blob - tools/tests/libMicro/strcasecmp.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.
39 static int unaligned
= 0;
40 static int opts
= 100;
53 lm_tsdsize
= sizeof (tsd_t
);
55 (void) sprintf(lm_optstr
, "s:n");
57 (void) sprintf(lm_usage
,
58 " [-s string size (default %d)]\n"
59 " [-n causes unaligned cmp]\n"
60 "notes: measures strcasecmp()\n",
63 (void) sprintf(lm_header
, "%8s", "size");
69 benchmark_optswitch(int opt
, char *optarg
)
76 opts
= sizetoll(optarg
);
85 benchmark_initbatch(void *tsd
)
87 tsd_t
*ts
= (tsd_t
*)tsd
;
90 "The quick brown fox jumps over the lazy dog.";
92 if (ts
->ts_once
++ == 0) {
96 ts
->ts_a
= malloc(opts
+ 1);
97 ts
->ts_b
= malloc(opts
+ 1 + unaligned
);
98 ts
->ts_b
+= unaligned
;
100 for (i
= 0; i
< opts
; i
++) {
101 ts
->ts_a
[i
] = ts
->ts_b
[i
] = demo
[i%l
];
110 benchmark(void *tsd
, result_t
*res
)
113 tsd_t
*ts
= (tsd_t
*)tsd
;
115 char *src
= ts
->ts_a
;
116 char *src2
= ts
->ts_b
;
117 int *sum
= &ts
->ts_fakegcc
;
121 for (i
= 0; i
< lm_optB
; i
+= 10) {
122 *sum
+= strcasecmp(src
, src2
);
123 *sum
+= strcasecmp(src
, src2
);
124 *sum
+= strcasecmp(src
, src2
);
125 *sum
+= strcasecmp(src
, src2
);
126 *sum
+= strcasecmp(src
, src2
);
127 *sum
+= strcasecmp(src
, src2
);
128 *sum
+= strcasecmp(src
, src2
);
129 *sum
+= strcasecmp(src
, src2
);
130 *sum
+= strcasecmp(src
, src2
);
131 *sum
+= strcasecmp(src
, src2
);
142 static char result
[256];
145 (void) sprintf(result
, "%8d", opts
);
147 (void) sprintf(result
, "%8d <unaligned>", opts
);