1 /* Functions to support general ended bitmaps.
2 Copyright (C) 1997-2025 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
23 /* Implementation of sparse integer sets as a linked list or tree.
25 This sparse set representation is suitable for sparse sets with an
26 unknown (a priori) universe.
28 Sets are represented as double-linked lists of container nodes of
29 type "struct bitmap_element" or as a binary trees of the same
30 container nodes. Each container node consists of an index for the
31 first member that could be held in the container, a small array of
32 integers that represent the members in the container, and pointers
33 to the next and previous element in the linked list, or left and
34 right children in the tree. In linked-list form, the container
35 nodes in the list are sorted in ascending order, i.e. the head of
36 the list holds the element with the smallest member of the set.
37 In tree form, nodes to the left have a smaller container index.
39 For a given member I in the set:
40 - the element for I will have index is I / (bits per element)
41 - the position for I within element is I % (bits per element)
43 This representation is very space-efficient for large sparse sets, and
44 the size of the set can be changed dynamically without much overhead.
45 An important parameter is the number of bits per element. In this
46 implementation, there are 128 bits per element. This results in a
47 high storage overhead *per element*, but a small overall overhead if
48 the set is very sparse.
50 The storage requirements for linked-list sparse sets are O(E), with E->N
51 in the worst case (a sparse set with large distances between the values
54 This representation also works well for data flow problems where the size
55 of the set may grow dynamically, but care must be taken that the member_p,
56 add_member, and remove_member operations occur with a suitable access
59 The linked-list set representation works well for problems involving very
60 sparse sets. The canonical example in GCC is, of course, the "set of
61 sets" for some CFG-based data flow problems (liveness analysis, dominance
64 For random-access sparse sets of unknown universe, the binary tree
65 representation is likely to be a more suitable choice. Theoretical
66 access times for the binary tree representation are better than those
67 for the linked-list, but in practice this is only true for truely
70 Often the most suitable representation during construction of the set
71 is not the best choice for the usage of the set. For such cases, the
72 "view" of the set can be changed from one representation to the other.
73 This is an O(E) operation:
75 * from list to tree view : bitmap_tree_view
76 * from tree to list view : bitmap_list_view
78 Traversing linked lists or trees can be cache-unfriendly. Performance
79 can be improved by keeping container nodes in the set grouped together
80 in memory, using a dedicated obstack for a set (or group of related
81 sets). Elements allocated on obstacks are released to a free-list and
82 taken off the free list. If multiple sets are allocated on the same
83 obstack, elements freed from one set may be re-used for one of the other
84 sets. This usually helps avoid cache misses.
86 A single free-list is used for all sets allocated in GGC space. This is
87 bad for persistent sets, so persistent sets should be allocated on an
88 obstack whenever possible.
90 For random-access sets with a known, relatively small universe size, the
91 SparseSet or simple bitmap representations may be more efficient than a
98 In linked-list form, in-order iterations of the set can be executed
99 efficiently. The downside is that many random-access operations are
100 relatively slow, because the linked list has to be traversed to test
101 membership (i.e. member_p/ add_member/remove_member).
103 To improve the performance of this set representation, the last
104 accessed element and its index are cached. For membership tests on
105 members close to recently accessed members, the cached last element
106 improves membership test to a constant-time operation.
108 The following operations can always be performed in O(1) time in
111 * clear : bitmap_clear
112 * smallest_member : bitmap_first_set_bit
113 * pop_smallest : bitmap_clear_first_set_bit
114 * choose_one : (not implemented, but could be
117 The following operations can be performed in O(E) time worst-case in
118 list view (with E the number of elements in the linked list), but in
119 O(1) time with a suitable access patterns:
121 * member_p : bitmap_bit_p
122 * add_member : bitmap_set_bit / bitmap_set_range
123 * remove_member : bitmap_clear_bit / bitmap_clear_range
125 The following operations can be performed in O(E) time in list view:
127 * cardinality : bitmap_count_bits
128 * largest_member : bitmap_last_set_bit (but this could
129 in constant time with a pointer to
130 the last element in the chain)
131 * set_size : bitmap_last_set_bit
133 In tree view the following operations can all be performed in O(log E)
134 amortized time with O(E) worst-case behavior.
144 Additionally, the linked-list sparse set representation supports
145 enumeration of the members in O(E) time:
147 * forall : EXECUTE_IF_SET_IN_BITMAP
148 * set_copy : bitmap_copy
149 * set_intersection : bitmap_intersect_p /
150 bitmap_and / bitmap_and_into /
151 EXECUTE_IF_AND_IN_BITMAP
152 * set_union : bitmap_ior / bitmap_ior_into
153 * set_difference : bitmap_intersect_compl_p /
154 bitmap_and_comp / bitmap_and_comp_into /
155 EXECUTE_IF_AND_COMPL_IN_BITMAP
156 * set_disjuction : bitmap_xor_comp / bitmap_xor_comp_into
157 * set_compare : bitmap_equal_p
159 Some operations on 3 sets that occur frequently in data flow problems
160 are also implemented:
162 * A | (B & C) : bitmap_ior_and_into
163 * A | (B & ~C) : bitmap_ior_and_compl /
164 bitmap_ior_and_compl_into
169 An alternate "view" of a bitmap is its binary tree representation.
170 For this representation, splay trees are used because they can be
171 implemented using the same data structures as the linked list, with
172 no overhead for meta-data (like color, or rank) on the tree nodes.
174 In binary tree form, random-access to the set is much more efficient
175 than for the linked-list representation. Downsides are the high cost
176 of clearing the set, and the relatively large number of operations
177 necessary to balance the tree. Also, iterating the set members is
180 As for the linked-list representation, the last accessed element and
181 its index are cached, so that membership tests on the latest accessed
182 members is a constant-time operation. Other lookups take O(logE)
183 time amortized (but O(E) time worst-case).
185 The following operations can always be performed in O(1) time:
187 * choose_one : (not implemented, but could be
188 implemented in constant time)
190 The following operations can be performed in O(logE) time amortized
191 but O(E) time worst-case, but in O(1) time if the same element is
194 * member_p : bitmap_bit_p
195 * add_member : bitmap_set_bit
196 * remove_member : bitmap_clear_bit
198 The following operations can be performed in O(logE) time amortized
199 but O(E) time worst-case:
201 * smallest_member : bitmap_first_set_bit
202 * largest_member : bitmap_last_set_bit
203 * set_size : bitmap_last_set_bit
205 The following operations can be performed in O(E) time:
207 * clear : bitmap_clear
209 The binary tree sparse set representation does *not* support any form
210 of enumeration, and does also *not* support logical operations on sets.
211 The binary tree representation is only supposed to be used for sets
212 on which many random-access membership tests will happen. */
215 #include "array-traits.h"
217 /* Bitmap memory usage. */
218 class bitmap_usage
: public mem_usage
221 /* Default contructor. */
222 bitmap_usage (): m_nsearches (0), m_search_iter (0) {}
224 bitmap_usage (size_t allocated
, size_t times
, size_t peak
,
225 uint64_t nsearches
, uint64_t search_iter
)
226 : mem_usage (allocated
, times
, peak
),
227 m_nsearches (nsearches
), m_search_iter (search_iter
) {}
229 /* Sum the usage with SECOND usage. */
231 operator+ (const bitmap_usage
&second
)
233 return bitmap_usage (m_allocated
+ second
.m_allocated
,
234 m_times
+ second
.m_times
,
235 m_peak
+ second
.m_peak
,
236 m_nsearches
+ second
.m_nsearches
,
237 m_search_iter
+ second
.m_search_iter
);
240 /* Dump usage coupled to LOC location, where TOTAL is sum of all rows. */
242 dump (mem_location
*loc
, const mem_usage
&total
) const
244 char *location_string
= loc
->to_string ();
246 fprintf (stderr
, "%-48s " PRsa (9) ":%5.1f%%"
247 PRsa (9) PRsa (9) ":%5.1f%%"
248 PRsa (11) PRsa (11) "%10s\n",
249 location_string
, SIZE_AMOUNT (m_allocated
),
250 get_percent (m_allocated
, total
.m_allocated
),
251 SIZE_AMOUNT (m_peak
), SIZE_AMOUNT (m_times
),
252 get_percent (m_times
, total
.m_times
),
253 SIZE_AMOUNT (m_nsearches
), SIZE_AMOUNT (m_search_iter
),
254 loc
->m_ggc
? "ggc" : "heap");
256 free (location_string
);
259 /* Dump header with NAME. */
261 dump_header (const char *name
)
263 fprintf (stderr
, "%-48s %11s%16s%17s%12s%12s%10s\n", name
, "Leak", "Peak",
264 "Times", "N searches", "Search iter", "Type");
267 /* Number search operations. */
268 uint64_t m_nsearches
;
269 /* Number of search iterations. */
270 uint64_t m_search_iter
;
273 /* Bitmap memory description. */
274 extern mem_alloc_description
<bitmap_usage
> bitmap_mem_desc
;
276 /* Fundamental storage type for bitmap. */
278 typedef unsigned long BITMAP_WORD
;
279 /* BITMAP_WORD_BITS needs to be unsigned, but cannot contain casts as
280 it is used in preprocessor directives -- hence the 1u. */
281 #define BITMAP_WORD_BITS (CHAR_BIT * SIZEOF_LONG * 1u)
283 /* Number of words to use for each element in the linked list. */
285 #ifndef BITMAP_ELEMENT_WORDS
286 #define BITMAP_ELEMENT_WORDS ((128 + BITMAP_WORD_BITS - 1) / BITMAP_WORD_BITS)
289 /* Number of bits in each actual element of a bitmap. */
291 #define BITMAP_ELEMENT_ALL_BITS (BITMAP_ELEMENT_WORDS * BITMAP_WORD_BITS)
293 /* Obstack for allocating bitmaps and elements from. */
294 struct bitmap_obstack
{
295 struct bitmap_element
*elements
;
297 struct obstack obstack
;
300 /* Bitmap set element. We use a linked list to hold only the bits that
301 are set. This allows for use to grow the bitset dynamically without
302 having to realloc and copy a giant bit array.
304 The free list is implemented as a list of lists. There is one
305 outer list connected together by prev fields. Each element of that
306 outer is an inner list (that may consist only of the outer list
307 element) that are connected by the next fields. The prev pointer
308 is undefined for interior elements. This allows
309 bitmap_elt_clear_from to be implemented in unit time rather than
310 linear in the number of elements to be freed. */
312 struct GTY((chain_next ("%h.next"))) bitmap_element
{
313 /* In list form, the next element in the linked list;
314 in tree form, the left child node in the tree. */
315 struct bitmap_element
*next
;
316 /* In list form, the previous element in the linked list;
317 in tree form, the right child node in the tree. */
318 struct bitmap_element
*prev
;
319 /* regno/BITMAP_ELEMENT_ALL_BITS. */
321 /* Bits that are set, counting from INDX, inclusive */
322 BITMAP_WORD bits
[BITMAP_ELEMENT_WORDS
];
325 /* Head of bitmap linked list. The 'current' member points to something
326 already pointed to by the chain started by first, so GTY((skip)) it. */
328 class GTY(()) bitmap_head
{
330 static bitmap_obstack crashme
;
331 /* Poison obstack to not make it not a valid initialized GC bitmap. */
332 CONSTEXPR
bitmap_head()
333 : indx (0), tree_form (false), padding (0), alloc_descriptor (0), first (NULL
),
334 current (NULL
), obstack (&crashme
)
336 /* Index of last element looked at. */
338 /* False if the bitmap is in list form; true if the bitmap is in tree form.
339 Bitmap iterators only work on bitmaps in list form. */
340 unsigned tree_form
: 1;
341 /* Next integer is shifted, so padding is needed. */
343 /* Bitmap UID used for memory allocation statistics. */
344 unsigned alloc_descriptor
: 29;
345 /* In list form, the first element in the linked list;
346 in tree form, the root of the tree. */
347 bitmap_element
*first
;
348 /* Last element looked at. */
349 bitmap_element
* GTY((skip(""))) current
;
350 /* Obstack to allocate elements from. If NULL, then use GGC allocation. */
351 bitmap_obstack
* GTY((skip(""))) obstack
;
356 /* Get bitmap descriptor UID casted to an unsigned integer pointer.
357 Shift the descriptor because pointer_hash<Type>::hash is
358 doing >> 3 shift operation. */
359 unsigned *get_descriptor ()
361 return (unsigned *)(ptrdiff_t)(alloc_descriptor
<< 3);
366 extern bitmap_element bitmap_zero_bits
; /* Zero bitmap element */
367 extern bitmap_obstack bitmap_default_obstack
; /* Default bitmap obstack */
369 /* Change the view of the bitmap to list, or tree. */
370 void bitmap_list_view (bitmap
);
371 void bitmap_tree_view (bitmap
);
373 /* Clear a bitmap by freeing up the linked list. */
374 extern void bitmap_clear (bitmap
);
376 /* Copy a bitmap to another bitmap. */
377 extern void bitmap_copy (bitmap
, const_bitmap
);
379 /* Move a bitmap to another bitmap. */
380 extern void bitmap_move (bitmap
, bitmap
);
382 /* True if two bitmaps are identical. */
383 extern bool bitmap_equal_p (const_bitmap
, const_bitmap
);
385 /* True if the bitmaps intersect (their AND is non-empty). */
386 extern bool bitmap_intersect_p (const_bitmap
, const_bitmap
);
388 /* True if the complement of the second intersects the first (their
389 AND_COMPL is non-empty). */
390 extern bool bitmap_intersect_compl_p (const_bitmap
, const_bitmap
);
392 /* True if MAP is an empty bitmap. */
393 inline bool bitmap_empty_p (const_bitmap map
)
398 /* True if the bitmap has only a single bit set. */
399 extern bool bitmap_single_bit_set_p (const_bitmap
);
401 /* Count the number of bits set in the bitmap. */
402 extern unsigned long bitmap_count_bits (const_bitmap
);
404 /* Count the number of unique bits set across the two bitmaps. */
405 extern unsigned long bitmap_count_unique_bits (const_bitmap
, const_bitmap
);
407 /* Boolean operations on bitmaps. The _into variants are two operand
408 versions that modify the first source operand. The other variants
409 are three operand versions that to not destroy the source bitmaps.
410 The operations supported are &, & ~, |, ^. */
411 extern void bitmap_and (bitmap
, const_bitmap
, const_bitmap
);
412 extern bool bitmap_and_into (bitmap
, const_bitmap
);
413 extern bool bitmap_and_compl (bitmap
, const_bitmap
, const_bitmap
);
414 extern bool bitmap_and_compl_into (bitmap
, const_bitmap
);
415 #define bitmap_compl_and(DST, A, B) bitmap_and_compl (DST, B, A)
416 extern void bitmap_compl_and_into (bitmap
, const_bitmap
);
417 extern void bitmap_clear_range (bitmap
, unsigned int, unsigned int);
418 extern void bitmap_set_range (bitmap
, unsigned int, unsigned int);
419 extern bool bitmap_ior (bitmap
, const_bitmap
, const_bitmap
);
420 extern bool bitmap_ior_into (bitmap
, const_bitmap
);
421 extern bool bitmap_ior_into_and_free (bitmap
, bitmap
*);
422 extern void bitmap_xor (bitmap
, const_bitmap
, const_bitmap
);
423 extern void bitmap_xor_into (bitmap
, const_bitmap
);
425 /* DST = A | (B & C). Return true if DST changes. */
426 extern bool bitmap_ior_and_into (bitmap DST
, const_bitmap B
, const_bitmap C
);
427 /* DST = A | (B & ~C). Return true if DST changes. */
428 extern bool bitmap_ior_and_compl (bitmap DST
, const_bitmap A
,
429 const_bitmap B
, const_bitmap C
);
430 /* A |= (B & ~C). Return true if A changes. */
431 extern bool bitmap_ior_and_compl_into (bitmap A
,
432 const_bitmap B
, const_bitmap C
);
434 /* Clear a single bit in a bitmap. Return true if the bit changed. */
435 extern bool bitmap_clear_bit (bitmap
, int);
437 /* Set a single bit in a bitmap. Return true if the bit changed. */
438 extern bool bitmap_set_bit (bitmap
, int);
440 /* Return true if a bit is set in a bitmap. */
441 extern bool bitmap_bit_p (const_bitmap
, int);
443 /* Set and get multiple bit values in a sparse bitmap. This allows a bitmap to
444 function as a sparse array of bit patterns where the patterns are
445 multiples of power of 2. This is more efficient than performing this as
446 multiple individual operations. */
447 void bitmap_set_aligned_chunk (bitmap
, unsigned int, unsigned int, BITMAP_WORD
);
448 BITMAP_WORD
bitmap_get_aligned_chunk (const_bitmap
, unsigned int, unsigned int);
450 /* Debug functions to print a bitmap. */
451 extern void debug_bitmap (const_bitmap
);
452 extern void debug_bitmap_file (FILE *, const_bitmap
);
454 /* Print a bitmap. */
455 extern void bitmap_print (FILE *, const_bitmap
, const char *, const char *);
457 /* Initialize and release a bitmap obstack. */
458 extern void bitmap_obstack_initialize (bitmap_obstack
*);
459 extern void bitmap_obstack_release (bitmap_obstack
*);
460 extern void bitmap_register (bitmap MEM_STAT_DECL
);
461 extern void dump_bitmap_statistics (void);
463 /* Initialize a bitmap header. OBSTACK indicates the bitmap obstack
464 to allocate from, NULL for GC'd bitmap. */
467 bitmap_initialize (bitmap head
, bitmap_obstack
*obstack CXX_MEM_STAT_INFO
)
469 head
->first
= head
->current
= NULL
;
470 head
->indx
= head
->tree_form
= 0;
472 head
->alloc_descriptor
= 0;
473 head
->obstack
= obstack
;
474 if (GATHER_STATISTICS
)
475 bitmap_register (head PASS_MEM_STAT
);
478 /* Release a bitmap (but not its head). This is suitable for pairing with
479 bitmap_initialize. */
482 bitmap_release (bitmap head
)
485 /* Poison the obstack pointer so the obstack can be safely released.
486 Do not zero it as the bitmap then becomes initialized GC. */
487 head
->obstack
= &bitmap_head::crashme
;
490 /* Allocate and free bitmaps from obstack, malloc and gc'd memory. */
491 extern bitmap
bitmap_alloc (bitmap_obstack
*obstack CXX_MEM_STAT_INFO
);
492 #define BITMAP_ALLOC bitmap_alloc
493 extern bitmap
bitmap_gc_alloc (ALONE_CXX_MEM_STAT_INFO
);
494 #define BITMAP_GGC_ALLOC bitmap_gc_alloc
495 extern void bitmap_obstack_free (bitmap
);
497 /* A few compatibility/functions macros for compatibility with sbitmaps */
498 inline void dump_bitmap (FILE *file
, const_bitmap map
)
500 bitmap_print (file
, map
, "", "\n");
502 extern void debug (const bitmap_head
&ref
);
503 extern void debug (const bitmap_head
*ptr
);
505 extern unsigned bitmap_first_set_bit (const_bitmap
);
506 extern unsigned bitmap_clear_first_set_bit (bitmap
);
507 extern unsigned bitmap_last_set_bit (const_bitmap
);
509 /* Compute bitmap hash (for purposes of hashing etc.) */
510 extern hashval_t
bitmap_hash (const_bitmap
);
512 /* Do any cleanup needed on a bitmap when it is no longer used. */
513 #define BITMAP_FREE(BITMAP) \
514 ((void) (bitmap_obstack_free ((bitmap) BITMAP), (BITMAP) = (bitmap) NULL))
516 /* Iterator for bitmaps. */
518 struct bitmap_iterator
520 /* Pointer to the current bitmap element. */
521 bitmap_element
*elt1
;
523 /* Pointer to 2nd bitmap element when two are involved. */
524 bitmap_element
*elt2
;
526 /* Word within the current element. */
529 /* Contents of the actually processed word. When finding next bit
530 it is shifted right, so that the actual bit is always the least
531 significant bit of ACTUAL. */
535 /* Initialize a single bitmap iterator. START_BIT is the first bit to
539 bmp_iter_set_init (bitmap_iterator
*bi
, const_bitmap map
,
540 unsigned start_bit
, unsigned *bit_no
)
542 bi
->elt1
= map
->first
;
545 gcc_checking_assert (!map
->tree_form
);
547 /* Advance elt1 until it is not before the block containing start_bit. */
552 bi
->elt1
= &bitmap_zero_bits
;
556 if (bi
->elt1
->indx
>= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
558 bi
->elt1
= bi
->elt1
->next
;
561 /* We might have gone past the start bit, so reinitialize it. */
562 if (bi
->elt1
->indx
!= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
563 start_bit
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
565 /* Initialize for what is now start_bit. */
566 bi
->word_no
= start_bit
/ BITMAP_WORD_BITS
% BITMAP_ELEMENT_WORDS
;
567 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
];
568 bi
->bits
>>= start_bit
% BITMAP_WORD_BITS
;
570 /* If this word is zero, we must make sure we're not pointing at the
571 first bit, otherwise our incrementing to the next word boundary
572 will fail. It won't matter if this increment moves us into the
574 start_bit
+= !bi
->bits
;
579 /* Initialize an iterator to iterate over the intersection of two
580 bitmaps. START_BIT is the bit to commence from. */
583 bmp_iter_and_init (bitmap_iterator
*bi
, const_bitmap map1
, const_bitmap map2
,
584 unsigned start_bit
, unsigned *bit_no
)
586 bi
->elt1
= map1
->first
;
587 bi
->elt2
= map2
->first
;
589 gcc_checking_assert (!map1
->tree_form
&& !map2
->tree_form
);
591 /* Advance elt1 until it is not before the block containing
601 if (bi
->elt1
->indx
>= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
603 bi
->elt1
= bi
->elt1
->next
;
606 /* Advance elt2 until it is not before elt1. */
611 bi
->elt1
= bi
->elt2
= &bitmap_zero_bits
;
615 if (bi
->elt2
->indx
>= bi
->elt1
->indx
)
617 bi
->elt2
= bi
->elt2
->next
;
620 /* If we're at the same index, then we have some intersecting bits. */
621 if (bi
->elt1
->indx
== bi
->elt2
->indx
)
623 /* We might have advanced beyond the start_bit, so reinitialize
625 if (bi
->elt1
->indx
!= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
626 start_bit
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
628 bi
->word_no
= start_bit
/ BITMAP_WORD_BITS
% BITMAP_ELEMENT_WORDS
;
629 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
] & bi
->elt2
->bits
[bi
->word_no
];
630 bi
->bits
>>= start_bit
% BITMAP_WORD_BITS
;
634 /* Otherwise we must immediately advance elt1, so initialize for
636 bi
->word_no
= BITMAP_ELEMENT_WORDS
- 1;
640 /* If this word is zero, we must make sure we're not pointing at the
641 first bit, otherwise our incrementing to the next word boundary
642 will fail. It won't matter if this increment moves us into the
644 start_bit
+= !bi
->bits
;
649 /* Initialize an iterator to iterate over the bits in MAP1 & ~MAP2. */
652 bmp_iter_and_compl_init (bitmap_iterator
*bi
,
653 const_bitmap map1
, const_bitmap map2
,
654 unsigned start_bit
, unsigned *bit_no
)
656 bi
->elt1
= map1
->first
;
657 bi
->elt2
= map2
->first
;
659 gcc_checking_assert (!map1
->tree_form
&& !map2
->tree_form
);
661 /* Advance elt1 until it is not before the block containing start_bit. */
666 bi
->elt1
= &bitmap_zero_bits
;
670 if (bi
->elt1
->indx
>= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
672 bi
->elt1
= bi
->elt1
->next
;
675 /* Advance elt2 until it is not before elt1. */
676 while (bi
->elt2
&& bi
->elt2
->indx
< bi
->elt1
->indx
)
677 bi
->elt2
= bi
->elt2
->next
;
679 /* We might have advanced beyond the start_bit, so reinitialize for
681 if (bi
->elt1
->indx
!= start_bit
/ BITMAP_ELEMENT_ALL_BITS
)
682 start_bit
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
684 bi
->word_no
= start_bit
/ BITMAP_WORD_BITS
% BITMAP_ELEMENT_WORDS
;
685 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
];
686 if (bi
->elt2
&& bi
->elt1
->indx
== bi
->elt2
->indx
)
687 bi
->bits
&= ~bi
->elt2
->bits
[bi
->word_no
];
688 bi
->bits
>>= start_bit
% BITMAP_WORD_BITS
;
690 /* If this word is zero, we must make sure we're not pointing at the
691 first bit, otherwise our incrementing to the next word boundary
692 will fail. It won't matter if this increment moves us into the
694 start_bit
+= !bi
->bits
;
699 /* Advance to the next bit in BI. We don't advance to the next
703 bmp_iter_next (bitmap_iterator
*bi
, unsigned *bit_no
)
709 /* Advance to first set bit in BI. */
712 bmp_iter_next_bit (bitmap_iterator
* bi
, unsigned *bit_no
)
714 #if (GCC_VERSION >= 3004)
716 unsigned int n
= __builtin_ctzl (bi
->bits
);
717 gcc_assert (sizeof (unsigned long) == sizeof (BITMAP_WORD
));
722 while (!(bi
->bits
& 1))
730 /* Advance to the next nonzero bit of a single bitmap, we will have
731 already advanced past the just iterated bit. Return true if there
732 is a bit to iterate. */
735 bmp_iter_set (bitmap_iterator
*bi
, unsigned *bit_no
)
737 /* If our current word is nonzero, it contains the bit we want. */
741 bmp_iter_next_bit (bi
, bit_no
);
745 /* Round up to the word boundary. We might have just iterated past
746 the end of the last word, hence the -1. It is not possible for
747 bit_no to point at the beginning of the now last word. */
748 *bit_no
= ((*bit_no
+ BITMAP_WORD_BITS
- 1)
749 / BITMAP_WORD_BITS
* BITMAP_WORD_BITS
);
754 /* Find the next nonzero word in this elt. */
755 while (bi
->word_no
!= BITMAP_ELEMENT_WORDS
)
757 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
];
760 *bit_no
+= BITMAP_WORD_BITS
;
764 /* Make sure we didn't remove the element while iterating. */
765 gcc_checking_assert (bi
->elt1
->indx
!= -1U);
767 /* Advance to the next element. */
768 bi
->elt1
= bi
->elt1
->next
;
771 *bit_no
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
776 /* Advance to the next nonzero bit of an intersecting pair of
777 bitmaps. We will have already advanced past the just iterated bit.
778 Return true if there is a bit to iterate. */
781 bmp_iter_and (bitmap_iterator
*bi
, unsigned *bit_no
)
783 /* If our current word is nonzero, it contains the bit we want. */
787 bmp_iter_next_bit (bi
, bit_no
);
791 /* Round up to the word boundary. We might have just iterated past
792 the end of the last word, hence the -1. It is not possible for
793 bit_no to point at the beginning of the now last word. */
794 *bit_no
= ((*bit_no
+ BITMAP_WORD_BITS
- 1)
795 / BITMAP_WORD_BITS
* BITMAP_WORD_BITS
);
800 /* Find the next nonzero word in this elt. */
801 while (bi
->word_no
!= BITMAP_ELEMENT_WORDS
)
803 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
] & bi
->elt2
->bits
[bi
->word_no
];
806 *bit_no
+= BITMAP_WORD_BITS
;
810 /* Advance to the next identical element. */
813 /* Make sure we didn't remove the element while iterating. */
814 gcc_checking_assert (bi
->elt1
->indx
!= -1U);
816 /* Advance elt1 while it is less than elt2. We always want
817 to advance one elt. */
820 bi
->elt1
= bi
->elt1
->next
;
824 while (bi
->elt1
->indx
< bi
->elt2
->indx
);
826 /* Make sure we didn't remove the element while iterating. */
827 gcc_checking_assert (bi
->elt2
->indx
!= -1U);
829 /* Advance elt2 to be no less than elt1. This might not
831 while (bi
->elt2
->indx
< bi
->elt1
->indx
)
833 bi
->elt2
= bi
->elt2
->next
;
838 while (bi
->elt1
->indx
!= bi
->elt2
->indx
);
840 *bit_no
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
845 /* Advance to the next nonzero bit in the intersection of
846 complemented bitmaps. We will have already advanced past the just
850 bmp_iter_and_compl (bitmap_iterator
*bi
, unsigned *bit_no
)
852 /* If our current word is nonzero, it contains the bit we want. */
856 bmp_iter_next_bit (bi
, bit_no
);
860 /* Round up to the word boundary. We might have just iterated past
861 the end of the last word, hence the -1. It is not possible for
862 bit_no to point at the beginning of the now last word. */
863 *bit_no
= ((*bit_no
+ BITMAP_WORD_BITS
- 1)
864 / BITMAP_WORD_BITS
* BITMAP_WORD_BITS
);
869 /* Find the next nonzero word in this elt. */
870 while (bi
->word_no
!= BITMAP_ELEMENT_WORDS
)
872 bi
->bits
= bi
->elt1
->bits
[bi
->word_no
];
873 if (bi
->elt2
&& bi
->elt2
->indx
== bi
->elt1
->indx
)
874 bi
->bits
&= ~bi
->elt2
->bits
[bi
->word_no
];
877 *bit_no
+= BITMAP_WORD_BITS
;
881 /* Make sure we didn't remove the element while iterating. */
882 gcc_checking_assert (bi
->elt1
->indx
!= -1U);
884 /* Advance to the next element of elt1. */
885 bi
->elt1
= bi
->elt1
->next
;
889 /* Make sure we didn't remove the element while iterating. */
890 gcc_checking_assert (! bi
->elt2
|| bi
->elt2
->indx
!= -1U);
892 /* Advance elt2 until it is no less than elt1. */
893 while (bi
->elt2
&& bi
->elt2
->indx
< bi
->elt1
->indx
)
894 bi
->elt2
= bi
->elt2
->next
;
896 *bit_no
= bi
->elt1
->indx
* BITMAP_ELEMENT_ALL_BITS
;
901 /* If you are modifying a bitmap you are currently iterating over you
903 - never remove the current bit;
904 - if you set or clear a bit before the current bit this operation
905 will not affect the set of bits you are visiting during the iteration;
906 - if you set or clear a bit after the current bit it is unspecified
907 whether that affects the set of bits you are visiting during the
909 If you want to remove the current bit you can delay this to the next
910 iteration (and after the iteration in case the last iteration is
913 /* Loop over all bits set in BITMAP, starting with MIN and setting
914 BITNUM to the bit number. ITER is a bitmap iterator. BITNUM
915 should be treated as a read-only variable as it contains loop
918 #ifndef EXECUTE_IF_SET_IN_BITMAP
919 /* See sbitmap.h for the other definition of EXECUTE_IF_SET_IN_BITMAP. */
920 #define EXECUTE_IF_SET_IN_BITMAP(BITMAP, MIN, BITNUM, ITER) \
921 for (bmp_iter_set_init (&(ITER), (BITMAP), (MIN), &(BITNUM)); \
922 bmp_iter_set (&(ITER), &(BITNUM)); \
923 bmp_iter_next (&(ITER), &(BITNUM)))
926 /* Loop over all the bits set in BITMAP1 & BITMAP2, starting with MIN
927 and setting BITNUM to the bit number. ITER is a bitmap iterator.
928 BITNUM should be treated as a read-only variable as it contains
931 #define EXECUTE_IF_AND_IN_BITMAP(BITMAP1, BITMAP2, MIN, BITNUM, ITER) \
932 for (bmp_iter_and_init (&(ITER), (BITMAP1), (BITMAP2), (MIN), \
934 bmp_iter_and (&(ITER), &(BITNUM)); \
935 bmp_iter_next (&(ITER), &(BITNUM)))
937 /* Loop over all the bits set in BITMAP1 & ~BITMAP2, starting with MIN
938 and setting BITNUM to the bit number. ITER is a bitmap iterator.
939 BITNUM should be treated as a read-only variable as it contains
942 #define EXECUTE_IF_AND_COMPL_IN_BITMAP(BITMAP1, BITMAP2, MIN, BITNUM, ITER) \
943 for (bmp_iter_and_compl_init (&(ITER), (BITMAP1), (BITMAP2), (MIN), \
945 bmp_iter_and_compl (&(ITER), &(BITNUM)); \
946 bmp_iter_next (&(ITER), &(BITNUM)))
948 /* A class that ties the lifetime of a bitmap to its scope. */
952 auto_bitmap (ALONE_CXX_MEM_STAT_INFO
)
953 { bitmap_initialize (&m_bits
, &bitmap_default_obstack PASS_MEM_STAT
); }
954 explicit auto_bitmap (bitmap_obstack
*o CXX_MEM_STAT_INFO
)
955 { bitmap_initialize (&m_bits
, o PASS_MEM_STAT
); }
956 ~auto_bitmap () { bitmap_clear (&m_bits
); }
957 // Allow calling bitmap functions on our bitmap.
958 operator bitmap () { return &m_bits
; }
961 // Prevent making a copy that references our bitmap.
962 auto_bitmap (const auto_bitmap
&) = delete;
963 auto_bitmap
&operator = (const auto_bitmap
&) = delete;
964 auto_bitmap (auto_bitmap
&&) = delete;
965 auto_bitmap
&operator = (auto_bitmap
&&) = delete;
970 extern void debug (const auto_bitmap
&ref
);
971 extern void debug (const auto_bitmap
*ptr
);
973 /* Base class for bitmap_view; see there for details. */
974 template<typename T
, typename Traits
= array_traits
<T
> >
975 class base_bitmap_view
978 typedef typename
Traits::element_type array_element_type
;
980 base_bitmap_view (const T
&, bitmap_element
*);
981 operator const_bitmap () const { return &m_head
; }
984 base_bitmap_view (const base_bitmap_view
&);
989 /* Provides a read-only bitmap view of a single integer bitmask or a
990 constant-sized array of integer bitmasks, or of a wrapper around such
992 template<typename T
, typename Traits
>
993 class bitmap_view
<T
, Traits
, true> : public base_bitmap_view
<T
, Traits
>
996 bitmap_view (const T
&array
)
997 : base_bitmap_view
<T
, Traits
> (array
, m_bitmap_elements
) {}
1000 /* How many bitmap_elements we need to hold a full T. */
1001 static const size_t num_bitmap_elements
1003 * sizeof (typename
Traits::element_type
)
1004 * Traits::constant_size
,
1005 BITMAP_ELEMENT_ALL_BITS
);
1006 bitmap_element m_bitmap_elements
[num_bitmap_elements
];
1009 /* Initialize the view for array ARRAY, using the array of bitmap
1010 elements in BITMAP_ELEMENTS (which is known to contain enough
1012 template<typename T
, typename Traits
>
1013 base_bitmap_view
<T
, Traits
>::base_bitmap_view (const T
&array
,
1014 bitmap_element
*bitmap_elements
)
1016 m_head
.obstack
= NULL
;
1018 /* The code currently assumes that each element of ARRAY corresponds
1019 to exactly one bitmap_element. */
1020 const size_t array_element_bits
= CHAR_BIT
* sizeof (array_element_type
);
1021 STATIC_ASSERT (BITMAP_ELEMENT_ALL_BITS
% array_element_bits
== 0);
1022 size_t array_step
= BITMAP_ELEMENT_ALL_BITS
/ array_element_bits
;
1023 size_t array_size
= Traits::size (array
);
1025 /* Process each potential bitmap_element in turn. The loop is written
1026 this way rather than per array element because usually there are
1027 only a small number of array elements per bitmap element (typically
1028 two or four). The inner loops should therefore unroll completely. */
1029 const array_element_type
*array_elements
= Traits::base (array
);
1030 unsigned int indx
= 0;
1031 for (size_t array_base
= 0;
1032 array_base
< array_size
;
1033 array_base
+= array_step
, indx
+= 1)
1035 /* How many array elements are in this particular bitmap_element. */
1036 unsigned int array_count
1037 = (STATIC_CONSTANT_P (array_size
% array_step
== 0)
1038 ? array_step
: MIN (array_step
, array_size
- array_base
));
1040 /* See whether we need this bitmap element. */
1041 array_element_type ior
= array_elements
[array_base
];
1042 for (size_t i
= 1; i
< array_count
; ++i
)
1043 ior
|= array_elements
[array_base
+ i
];
1047 /* Grab the next bitmap element and chain it. */
1048 bitmap_element
*bitmap_element
= bitmap_elements
++;
1050 m_head
.current
->next
= bitmap_element
;
1052 m_head
.first
= bitmap_element
;
1053 bitmap_element
->prev
= m_head
.current
;
1054 bitmap_element
->next
= NULL
;
1055 bitmap_element
->indx
= indx
;
1056 m_head
.current
= bitmap_element
;
1059 /* Fill in the bits of the bitmap element. */
1060 if (array_element_bits
< BITMAP_WORD_BITS
)
1062 /* Multiple array elements fit in one element of
1063 bitmap_element->bits. */
1064 size_t array_i
= array_base
;
1065 for (unsigned int word_i
= 0; word_i
< BITMAP_ELEMENT_WORDS
;
1068 BITMAP_WORD word
= 0;
1069 for (unsigned int shift
= 0;
1070 shift
< BITMAP_WORD_BITS
&& array_i
< array_size
;
1071 shift
+= array_element_bits
)
1072 word
|= array_elements
[array_i
++] << shift
;
1073 bitmap_element
->bits
[word_i
] = word
;
1078 /* Array elements are the same size as elements of
1079 bitmap_element->bits, or are an exact multiple of that size. */
1080 unsigned int word_i
= 0;
1081 for (unsigned int i
= 0; i
< array_count
; ++i
)
1082 for (unsigned int shift
= 0; shift
< array_element_bits
;
1083 shift
+= BITMAP_WORD_BITS
)
1084 bitmap_element
->bits
[word_i
++]
1085 = array_elements
[array_base
+ i
] >> shift
;
1086 while (word_i
< BITMAP_ELEMENT_WORDS
)
1087 bitmap_element
->bits
[word_i
++] = 0;
1092 #endif /* GCC_BITMAP_H */