19ee40678SPoul-Henning Kamp #include <stdlib.h>
29ee40678SPoul-Henning Kamp #include <stdio.h>
3*01ded8b9SRebecca Cran #include <string.h>
49ee40678SPoul-Henning Kamp #include <unistd.h>
59ee40678SPoul-Henning Kamp
69ee40678SPoul-Henning Kamp u_long NBUCKETS = 2000;
79ee40678SPoul-Henning Kamp u_long NOPS = 200000;
89ee40678SPoul-Henning Kamp u_long NSIZE = (16*1024);
99ee40678SPoul-Henning Kamp
109ee40678SPoul-Henning Kamp char **foo;
119ee40678SPoul-Henning Kamp
129ee40678SPoul-Henning Kamp int
main(int argc,char ** argv)139ee40678SPoul-Henning Kamp main(int argc, char **argv)
149ee40678SPoul-Henning Kamp {
15*01ded8b9SRebecca Cran u_long i,j,k;
169ee40678SPoul-Henning Kamp
179ee40678SPoul-Henning Kamp if (argc > 1) NOPS = strtoul(argv[1],0,0);
189ee40678SPoul-Henning Kamp if (argc > 2) NBUCKETS = strtoul(argv[2],0,0);
199ee40678SPoul-Henning Kamp if (argc > 3) NSIZE = strtoul(argv[3],0,0);
20*01ded8b9SRebecca Cran printf("BRK(0)=%p ", sbrk(0));
21*01ded8b9SRebecca Cran foo = malloc(sizeof(*foo) * NBUCKETS);
22*01ded8b9SRebecca Cran memset(foo, 0, sizeof(*foo) * NBUCKETS);
23adeb92a2SKelly Yancey for (i = 1; i <= 4096; i *= 2) {
249ee40678SPoul-Henning Kamp for (j = 0; j < 40960/i && j < NBUCKETS; j++) {
259ee40678SPoul-Henning Kamp foo[j] = malloc(i);
269ee40678SPoul-Henning Kamp }
279ee40678SPoul-Henning Kamp for (j = 0; j < 40960/i && j < NBUCKETS; j++) {
289ee40678SPoul-Henning Kamp free(foo[j]);
29*01ded8b9SRebecca Cran foo[j] = NULL;
309ee40678SPoul-Henning Kamp }
319ee40678SPoul-Henning Kamp }
329ee40678SPoul-Henning Kamp
339ee40678SPoul-Henning Kamp for (i = 0; i < NOPS; i++) {
349ee40678SPoul-Henning Kamp j = random() % NBUCKETS;
359ee40678SPoul-Henning Kamp k = random() % NSIZE;
369ee40678SPoul-Henning Kamp foo[j] = realloc(foo[j], k & 1 ? 0 : k);
37adeb92a2SKelly Yancey if (k & 1 || k == 0) {
38adeb92a2SKelly Yancey /*
39adeb92a2SKelly Yancey * Workaround because realloc return bogus pointer rather than
40adeb92a2SKelly Yancey * NULL if passed zero length.
41adeb92a2SKelly Yancey */
42*01ded8b9SRebecca Cran foo[j] = NULL;
43adeb92a2SKelly Yancey }
449ee40678SPoul-Henning Kamp if (foo[j])
459ee40678SPoul-Henning Kamp foo[j][0] = 1;
469ee40678SPoul-Henning Kamp }
47*01ded8b9SRebecca Cran printf("BRK(1)=%p ", sbrk(0));
489ee40678SPoul-Henning Kamp for (j = 0; j < NBUCKETS; j++) {
499ee40678SPoul-Henning Kamp if (foo[j]) {
509ee40678SPoul-Henning Kamp free(foo[j]);
51*01ded8b9SRebecca Cran foo[j] = NULL;
529ee40678SPoul-Henning Kamp }
539ee40678SPoul-Henning Kamp }
54*01ded8b9SRebecca Cran printf("BRK(2)=%p NOPS=%lu NBUCKETS=%lu NSIZE=%lu\n",
559ee40678SPoul-Henning Kamp sbrk(0), NOPS, NBUCKETS, NSIZE);
569ee40678SPoul-Henning Kamp return 0;
579ee40678SPoul-Henning Kamp }
58