]> git.saurik.com Git - bison.git/blob - lib/bitset_stats.c
Minor white space issues, e.g. trailing white space at end of line.
[bison.git] / lib / bitset_stats.c
1 /* Bitset statistics.
2 Copyright (C) 2002 Free Software Foundation, Inc.
3 Contributed by Michael Hayes (m.hayes@elec.canterbury.ac.nz).
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 */
19
20 /* This file is a wrapper bitset implementation for the other bitset
21 implementations. It provides bitset compatibility checking and
22 statistics gathering without having to instrument the bitset
23 implementations. When statistics gathering is enabled, the bitset
24 operations get vectored through here and we then call the appropriate
25 routines.
26 */
27
28 #ifdef HAVE_CONFIG_H
29 #include "config.h"
30 #endif
31
32 #include "bbitset.h"
33 #include "abitset.h"
34 #include "ebitset.h"
35 #include "lbitset.h"
36 #include "vbitset.h"
37 #include "bitset_stats.h"
38 #include <stdlib.h>
39 #include <string.h>
40 #include <stdio.h>
41
42 #ifdef HAVE_GETTEXT_H
43 #include "gettext.h"
44 #define _(Msgid) gettext (Msgid)
45 #else
46 #define _(Msgid) Msgid
47 #endif
48
49 /* Configuration macros. */
50 #define BITSET_STATS_FILE "bitset.dat"
51 #define BITSET_LOG_COUNT_BINS 10
52 #define BITSET_LOG_SIZE_BINS 16
53 #define BITSET_DENSITY_BINS 20
54
55
56 /* Accessor macros. */
57 #define BITSET_STATS_ALLOCS_INC(TYPE) \
58 bitset_stats_info->types[(TYPE)].allocs++
59 #define BITSET_STATS_FREES_INC(BSET) \
60 bitset_stats_info->types[BITSET_TYPE_ (BSET)].frees++
61 #define BITSET_STATS_SETS_INC(BSET) \
62 bitset_stats_info->types[BITSET_TYPE_ (BSET)].sets++
63 #define BITSET_STATS_CACHE_SETS_INC(BSET) \
64 bitset_stats_info->types[BITSET_TYPE_ (BSET)].cache_sets++
65 #define BITSET_STATS_RESETS_INC(BSET) \
66 bitset_stats_info->types[BITSET_TYPE_ (BSET)].resets++
67 #define BITSET_STATS_CACHE_RESETS_INC(BSET) \
68 bitset_stats_info->types[BITSET_TYPE_ (BSET)].cache_resets++
69 #define BITSET_STATS_TESTS_INC(BSET) \
70 bitset_stats_info->types[BITSET_TYPE_ (BSET)].tests++
71 #define BITSET_STATS_CACHE_TESTS_INC(BSET) \
72 bitset_stats_info->types[BITSET_TYPE_ (BSET)].cache_tests++
73 #define BITSET_STATS_LISTS_INC(BSET) \
74 bitset_stats_info->types[BITSET_TYPE_ (BSET)].lists++
75 #define BITSET_STATS_LIST_COUNTS_INC(BSET, I) \
76 bitset_stats_info->types[BITSET_TYPE_ (BSET)].list_counts[(I)]++
77 #define BITSET_STATS_LIST_SIZES_INC(BSET, I) \
78 bitset_stats_info->types[BITSET_TYPE_ (BSET)].list_sizes[(I)]++
79 #define BITSET_STATS_LIST_DENSITY_INC(BSET, I) \
80 bitset_stats_info->types[BITSET_TYPE_ (BSET)].list_density[(I)]++
81
82
83 struct bitset_type_info_struct
84 {
85 unsigned int allocs;
86 unsigned int frees;
87 unsigned int lists;
88 unsigned int sets;
89 unsigned int cache_sets;
90 unsigned int resets;
91 unsigned int cache_resets;
92 unsigned int tests;
93 unsigned int cache_tests;
94 unsigned int list_counts[BITSET_LOG_COUNT_BINS];
95 unsigned int list_sizes[BITSET_LOG_SIZE_BINS];
96 unsigned int list_density[BITSET_DENSITY_BINS];
97 };
98
99 struct bitset_stats_info_struct
100 {
101 unsigned int runs;
102 struct bitset_type_info_struct types[BITSET_TYPE_NUM];
103 };
104
105
106 struct bitset_stats_info_struct bitset_stats_info_data;
107 struct bitset_stats_info_struct *bitset_stats_info;
108 bool bitset_stats_enabled = false;
109
110
111 /* Print a percentage histogram with message MSG to FILE. */
112 static void
113 bitset_percent_histogram_print (FILE *file, const char *name, const char *msg,
114 unsigned int n_bins, unsigned int *bins)
115 {
116 unsigned int i;
117 unsigned int total;
118
119 total = 0;
120 for (i = 0; i < n_bins; i++)
121 total += bins[i];
122
123 if (!total)
124 return;
125
126 fprintf (file, "%s %s", name, msg);
127 for (i = 0; i < n_bins; i++)
128 fprintf (file, "%.0f-%.0f%%\t%8u (%5.1f%%)\n",
129 i * 100.0 / n_bins,
130 (i + 1) * 100.0 / n_bins, bins[i],
131 (100.0 * bins[i]) / total);
132 }
133
134
135 /* Print a log histogram with message MSG to FILE. */
136 static void
137 bitset_log_histogram_print (FILE *file, const char *name, const char *msg,
138 unsigned int n_bins, unsigned int *bins)
139 {
140 unsigned int i;
141 unsigned int total;
142 unsigned int max_width;
143
144 total = 0;
145 for (i = 0; i < n_bins; i++)
146 total += bins[i];
147
148 if (!total)
149 return;
150
151 /* Determine number of useful bins. */
152 for (i = n_bins; i > 3 && ! bins[i - 1]; i--)
153 continue;
154 n_bins = i;
155
156 /* 2 * ceil (log10 (2) * (N - 1)) + 1. */
157 max_width = 2 * (unsigned int) (0.30103 * (n_bins - 1) + 0.9999) + 1;
158
159 fprintf (file, "%s %s", name, msg);
160 for (i = 0; i < 2; i++)
161 fprintf (file, "%*d\t%8u (%5.1f%%)\n",
162 max_width, i, bins[i], 100.0 * bins[i] / total);
163
164 for (; i < n_bins; i++)
165 fprintf (file, "%*lu-%lu\t%8u (%5.1f%%)\n",
166 max_width - ((unsigned int) (0.30103 * (i) + 0.9999) + 1),
167 (unsigned long) 1 << (i - 1),
168 ((unsigned long) 1 << i) - 1,
169 bins[i],
170 (100.0 * bins[i]) / total);
171 }
172
173
174 /* Print bitset statistics to FILE. */
175 static void
176 bitset_stats_print_1 (FILE *file, const char *name,
177 struct bitset_type_info_struct *stats)
178 {
179 if (!stats)
180 return;
181
182 fprintf (file, "%s:\n", name);
183 fprintf (file, _("%u bitset_allocs, %u freed (%.2f%%).\n"),
184 stats->allocs, stats->frees,
185 stats->allocs ? 100.0 * stats->frees / stats->allocs : 0);
186 fprintf (file, _("%u bitset_sets, %u cached (%.2f%%)\n"),
187 stats->sets, stats->cache_sets,
188 stats->sets ? 100.0 * stats->cache_sets / stats->sets : 0);
189 fprintf (file, _("%u bitset_resets, %u cached (%.2f%%)\n"),
190 stats->resets, stats->cache_resets,
191 stats->resets ? 100.0 * stats->cache_resets / stats->resets : 0);
192 fprintf (file, _("%u bitset_tests, %u cached (%.2f%%)\n"),
193 stats->tests, stats->cache_tests,
194 stats->tests ? 100.0 * stats->cache_tests / stats->tests : 0);
195
196 fprintf (file, _("%u bitset_lists\n"), stats->lists);
197
198 bitset_log_histogram_print (file, name, _("count log histogram\n"),
199 BITSET_LOG_COUNT_BINS, stats->list_counts);
200
201 bitset_log_histogram_print (file, name, _("size log histogram\n"),
202 BITSET_LOG_SIZE_BINS, stats->list_sizes);
203
204 bitset_percent_histogram_print (file, name, _("density histogram\n"),
205 BITSET_DENSITY_BINS, stats->list_density);
206 }
207
208
209 /* Print all bitset statistics to FILE. */
210 static void
211 bitset_stats_print (FILE *file, bool verbose ATTRIBUTE_UNUSED)
212 {
213 int i;
214
215 if (!bitset_stats_info)
216 return;
217
218 fprintf (file, _("Bitset statistics:\n\n"));
219
220 if (bitset_stats_info->runs > 1)
221 fprintf (file, _("Accumulated runs = %u\n"), bitset_stats_info->runs);
222
223 for (i = 0; i < BITSET_TYPE_NUM; i++)
224 bitset_stats_print_1 (file, bitset_type_names[i],
225 &bitset_stats_info->types[i]);
226 }
227
228
229 /* Initialise bitset statistics logging. */
230 void
231 bitset_stats_enable (void)
232 {
233 if (!bitset_stats_info)
234 bitset_stats_info = &bitset_stats_info_data;
235 bitset_stats_enabled = true;
236 }
237
238
239 void
240 bitset_stats_disable (void)
241 {
242 bitset_stats_enabled = false;
243 }
244
245
246 /* Read bitset statistics file. */
247 void
248 bitset_stats_read (const char *filename)
249 {
250 FILE *file;
251
252 if (!bitset_stats_info)
253 return;
254
255 if (!filename)
256 filename = BITSET_STATS_FILE;
257
258 file = fopen (filename, "r");
259 if (file)
260 {
261 if (fread (&bitset_stats_info_data, sizeof (bitset_stats_info_data),
262 1, file) != 1)
263 {
264 if (ferror (file))
265 perror (_("Could not read stats file."));
266 else
267 fprintf (stderr, _("Bad stats file size.\n"));
268 }
269 if (fclose (file) != 0)
270 perror (_("Could not read stats file."));
271 }
272 bitset_stats_info_data.runs++;
273 }
274
275
276 /* Write bitset statistics file. */
277 void
278 bitset_stats_write (const char *filename)
279 {
280 FILE *file;
281
282 if (!bitset_stats_info)
283 return;
284
285 if (!filename)
286 filename = BITSET_STATS_FILE;
287
288 file = fopen (filename, "w");
289 if (file)
290 {
291 if (fwrite (&bitset_stats_info_data, sizeof (bitset_stats_info_data),
292 1, file) != 1)
293 perror (_("Could not write stats file."));
294 if (fclose (file) != 0)
295 perror (_("Could not write stats file."));
296 }
297 else
298 perror (_("Could not open stats file for writing."));
299 }
300
301
302 /* Dump bitset statistics to FILE. */
303 void
304 bitset_stats_dump (FILE *file)
305 {
306 bitset_stats_print (file, false);
307 }
308
309
310 /* Function to be called from debugger to print bitset stats. */
311 void
312 debug_bitset_stats (void)
313 {
314 bitset_stats_print (stderr, true);
315 }
316
317
318 static void
319 bitset_stats_set (bitset dst, bitset_bindex bitno)
320 {
321 bitset bset = dst->s.bset;
322 bitset_windex wordno = bitno / BITSET_WORD_BITS;
323 bitset_windex offset = wordno - bset->b.cindex;
324
325 BITSET_STATS_SETS_INC (bset);
326
327 if (offset < bset->b.csize)
328 {
329 bset->b.cdata[offset] |= (bitset_word) 1 << (bitno % BITSET_WORD_BITS);
330 BITSET_STATS_CACHE_SETS_INC (bset);
331 }
332 else
333 BITSET_SET_ (bset, bitno);
334 }
335
336
337 static void
338 bitset_stats_reset (bitset dst, bitset_bindex bitno)
339 {
340 bitset bset = dst->s.bset;
341 bitset_windex wordno = bitno / BITSET_WORD_BITS;
342 bitset_windex offset = wordno - bset->b.cindex;
343
344 BITSET_STATS_RESETS_INC (bset);
345
346 if (offset < bset->b.csize)
347 {
348 bset->b.cdata[offset] &=
349 ~((bitset_word) 1 << (bitno % BITSET_WORD_BITS));
350 BITSET_STATS_CACHE_RESETS_INC (bset);
351 }
352 else
353 BITSET_RESET_ (bset, bitno);
354 }
355
356
357 static bool
358 bitset_stats_toggle (bitset src, bitset_bindex bitno)
359 {
360 return BITSET_TOGGLE_ (src->s.bset, bitno);
361 }
362
363
364 static bool
365 bitset_stats_test (bitset src, bitset_bindex bitno)
366 {
367 bitset bset = src->s.bset;
368 bitset_windex wordno = bitno / BITSET_WORD_BITS;
369 bitset_windex offset = wordno - bset->b.cindex;
370
371 BITSET_STATS_TESTS_INC (bset);
372
373 if (offset < bset->b.csize)
374 {
375 BITSET_STATS_CACHE_TESTS_INC (bset);
376 return (bset->b.cdata[offset] >> (bitno % BITSET_WORD_BITS)) & 1;
377 }
378 else
379 return BITSET_TEST_ (bset, bitno);
380 }
381
382
383 static bitset_bindex
384 bitset_stats_resize (bitset src, bitset_bindex size)
385 {
386 return BITSET_RESIZE_ (src->s.bset, size);
387 }
388
389
390 static bitset_bindex
391 bitset_stats_size (bitset src)
392 {
393 return BITSET_SIZE_ (src->s.bset);
394 }
395
396
397 static bitset_bindex
398 bitset_stats_count (bitset src)
399 {
400 return BITSET_COUNT_ (src->s.bset);
401 }
402
403
404 static bool
405 bitset_stats_empty_p (bitset dst)
406 {
407 return BITSET_EMPTY_P_ (dst->s.bset);
408 }
409
410
411 static void
412 bitset_stats_ones (bitset dst)
413 {
414 BITSET_ONES_ (dst->s.bset);
415 }
416
417
418 static void
419 bitset_stats_zero (bitset dst)
420 {
421 BITSET_ZERO_ (dst->s.bset);
422 }
423
424
425 static void
426 bitset_stats_copy (bitset dst, bitset src)
427 {
428 BITSET_CHECK2_ (dst, src);
429 BITSET_COPY_ (dst->s.bset, src->s.bset);
430 }
431
432
433 static bool
434 bitset_stats_disjoint_p (bitset dst, bitset src)
435 {
436 BITSET_CHECK2_ (dst, src);
437 return BITSET_DISJOINT_P_ (dst->s.bset, src->s.bset);
438 }
439
440
441 static bool
442 bitset_stats_equal_p (bitset dst, bitset src)
443 {
444 BITSET_CHECK2_ (dst, src);
445 return BITSET_EQUAL_P_ (dst->s.bset, src->s.bset);
446 }
447
448
449 static void
450 bitset_stats_not (bitset dst, bitset src)
451 {
452 BITSET_CHECK2_ (dst, src);
453 BITSET_NOT_ (dst->s.bset, src->s.bset);
454 }
455
456
457 static bool
458 bitset_stats_subset_p (bitset dst, bitset src)
459 {
460 BITSET_CHECK2_ (dst, src);
461 return BITSET_SUBSET_P_ (dst->s.bset, src->s.bset);
462 }
463
464
465 static void
466 bitset_stats_and (bitset dst, bitset src1, bitset src2)
467 {
468 BITSET_CHECK3_ (dst, src1, src2);
469 BITSET_AND_ (dst->s.bset, src1->s.bset, src2->s.bset);
470 }
471
472
473 static bool
474 bitset_stats_and_cmp (bitset dst, bitset src1, bitset src2)
475 {
476 BITSET_CHECK3_ (dst, src1, src2);
477 return BITSET_AND_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset);
478 }
479
480
481 static void
482 bitset_stats_andn (bitset dst, bitset src1, bitset src2)
483 {
484 BITSET_CHECK3_ (dst, src1, src2);
485 BITSET_ANDN_ (dst->s.bset, src1->s.bset, src2->s.bset);
486 }
487
488
489 static bool
490 bitset_stats_andn_cmp (bitset dst, bitset src1, bitset src2)
491 {
492 BITSET_CHECK3_ (dst, src1, src2);
493 return BITSET_ANDN_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset);
494 }
495
496
497 static void
498 bitset_stats_or (bitset dst, bitset src1, bitset src2)
499 {
500 BITSET_CHECK3_ (dst, src1, src2);
501 BITSET_OR_ (dst->s.bset, src1->s.bset, src2->s.bset);
502 }
503
504
505 static bool
506 bitset_stats_or_cmp (bitset dst, bitset src1, bitset src2)
507 {
508 BITSET_CHECK3_ (dst, src1, src2);
509 return BITSET_OR_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset);
510 }
511
512
513 static void
514 bitset_stats_xor (bitset dst, bitset src1, bitset src2)
515 {
516 BITSET_CHECK3_ (dst, src1, src2);
517 BITSET_XOR_ (dst->s.bset, src1->s.bset, src2->s.bset);
518 }
519
520
521 static bool
522 bitset_stats_xor_cmp (bitset dst, bitset src1, bitset src2)
523 {
524 BITSET_CHECK3_ (dst, src1, src2);
525 return BITSET_XOR_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset);
526 }
527
528
529 static void
530 bitset_stats_and_or (bitset dst, bitset src1, bitset src2, bitset src3)
531 {
532 BITSET_CHECK4_ (dst, src1, src2, src3);
533 BITSET_AND_OR_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
534 }
535
536
537 static bool
538 bitset_stats_and_or_cmp (bitset dst, bitset src1, bitset src2, bitset src3)
539 {
540 BITSET_CHECK4_ (dst, src1, src2, src3);
541 return BITSET_AND_OR_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
542 }
543
544
545 static void
546 bitset_stats_andn_or (bitset dst, bitset src1, bitset src2, bitset src3)
547 {
548 BITSET_CHECK4_ (dst, src1, src2, src3);
549 BITSET_ANDN_OR_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
550 }
551
552
553 static bool
554 bitset_stats_andn_or_cmp (bitset dst, bitset src1, bitset src2, bitset src3)
555 {
556 BITSET_CHECK4_ (dst, src1, src2, src3);
557 return BITSET_ANDN_OR_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
558 }
559
560
561 static void
562 bitset_stats_or_and (bitset dst, bitset src1, bitset src2, bitset src3)
563 {
564 BITSET_CHECK4_ (dst, src1, src2, src3);
565 BITSET_OR_AND_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
566 }
567
568
569 static bool
570 bitset_stats_or_and_cmp (bitset dst, bitset src1, bitset src2, bitset src3)
571 {
572 BITSET_CHECK4_ (dst, src1, src2, src3);
573 return BITSET_OR_AND_CMP_ (dst->s.bset, src1->s.bset, src2->s.bset, src3->s.bset);
574 }
575
576
577 static bitset_bindex
578 bitset_stats_list (bitset bset, bitset_bindex *list,
579 bitset_bindex num, bitset_bindex *next)
580 {
581 bitset_bindex count;
582 bitset_bindex tmp;
583 bitset_bindex size;
584 bitset_bindex i;
585 enum bitset_type type;
586
587 count = BITSET_LIST_ (bset->s.bset, list, num, next);
588
589 type = BITSET_TYPE_ (bset->s.bset);
590 BITSET_STATS_LISTS_INC (bset->s.bset);
591
592 /* Log histogram of number of set bits. */
593 for (i = 0, tmp = count; tmp; tmp >>= 1, i++)
594 continue;
595 if (i >= BITSET_LOG_COUNT_BINS)
596 i = BITSET_LOG_COUNT_BINS - 1;
597 BITSET_STATS_LIST_COUNTS_INC (bset->s.bset, i);
598
599 /* Log histogram of number of bits in set. */
600 size = BITSET_SIZE_ (bset->s.bset);
601 for (i = 0, tmp = size; tmp; tmp >>= 1, i++)
602 continue;
603 if (i >= BITSET_LOG_SIZE_BINS)
604 i = BITSET_LOG_SIZE_BINS - 1;
605 BITSET_STATS_LIST_SIZES_INC (bset->s.bset, i);
606
607 /* Histogram of fraction of bits set. */
608 i = size ? (count * BITSET_DENSITY_BINS) / size : 0;
609 if (i >= BITSET_DENSITY_BINS)
610 i = BITSET_DENSITY_BINS - 1;
611 BITSET_STATS_LIST_DENSITY_INC (bset->s.bset, i);
612 return count;
613 }
614
615
616 static bitset_bindex
617 bitset_stats_list_reverse (bitset bset, bitset_bindex *list,
618 bitset_bindex num, bitset_bindex *next)
619 {
620 return BITSET_LIST_REVERSE_ (bset->s.bset, list, num, next);
621 }
622
623
624 static void
625 bitset_stats_free (bitset bset)
626 {
627 BITSET_STATS_FREES_INC (bset->s.bset);
628 BITSET_FREE_ (bset->s.bset);
629 }
630
631
632 struct bitset_vtable bitset_stats_vtable = {
633 bitset_stats_set,
634 bitset_stats_reset,
635 bitset_stats_toggle,
636 bitset_stats_test,
637 bitset_stats_resize,
638 bitset_stats_size,
639 bitset_stats_count,
640 bitset_stats_empty_p,
641 bitset_stats_ones,
642 bitset_stats_zero,
643 bitset_stats_copy,
644 bitset_stats_disjoint_p,
645 bitset_stats_equal_p,
646 bitset_stats_not,
647 bitset_stats_subset_p,
648 bitset_stats_and,
649 bitset_stats_and_cmp,
650 bitset_stats_andn,
651 bitset_stats_andn_cmp,
652 bitset_stats_or,
653 bitset_stats_or_cmp,
654 bitset_stats_xor,
655 bitset_stats_xor_cmp,
656 bitset_stats_and_or,
657 bitset_stats_and_or_cmp,
658 bitset_stats_andn_or,
659 bitset_stats_andn_or_cmp,
660 bitset_stats_or_and,
661 bitset_stats_or_and_cmp,
662 bitset_stats_list,
663 bitset_stats_list_reverse,
664 bitset_stats_free,
665 BITSET_STATS
666 };
667
668
669 /* Return enclosed bitset type. */
670 enum bitset_type
671 bitset_stats_type_get (bitset bset)
672 {
673 return BITSET_TYPE_ (bset->s.bset);
674 }
675
676
677 size_t
678 bitset_stats_bytes (void)
679 {
680 return sizeof (struct bitset_stats_struct);
681 }
682
683
684 bitset
685 bitset_stats_init (bitset bset, bitset_bindex n_bits, enum bitset_type type)
686 {
687 size_t bytes;
688 bitset sbset;
689
690 bset->b.vtable = &bitset_stats_vtable;
691
692 /* Disable cache. */
693 bset->b.cindex = 0;
694 bset->b.csize = 0;
695 bset->b.cdata = 0;
696
697 BITSET_NBITS_ (bset) = n_bits;
698
699 /* Set up the actual bitset implementation that
700 we are a wrapper over. */
701 switch (type)
702 {
703 case BITSET_ARRAY:
704 bytes = abitset_bytes (n_bits);
705 sbset = (bitset) xcalloc (1, bytes);
706 abitset_init (sbset, n_bits);
707 break;
708
709 case BITSET_LIST:
710 bytes = lbitset_bytes (n_bits);
711 sbset = (bitset) xcalloc (1, bytes);
712 lbitset_init (sbset, n_bits);
713 break;
714
715 case BITSET_TABLE:
716 bytes = ebitset_bytes (n_bits);
717 sbset = (bitset) xcalloc (1, bytes);
718 ebitset_init (sbset, n_bits);
719 break;
720
721 case BITSET_VARRAY:
722 bytes = vbitset_bytes (n_bits);
723 sbset = (bitset) xcalloc (1, bytes);
724 vbitset_init (sbset, n_bits);
725 break;
726
727 default:
728 abort ();
729 }
730
731 bset->s.bset = sbset;
732
733 BITSET_STATS_ALLOCS_INC (type);
734
735 return bset;
736 }