diff options
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/bitmap.c | 55 |
2 files changed, 54 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2f84490a063..b4ae5cd05cf 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2005-07-08 Kenneth Zadeck <zadeck@naturalbridge.com> + + * bitmap.c (bitmap_and, bitmap_and_into, bitmap_and_compl, + bitmap_and_compl_into, bitmap_xor, bitmap_xor_into): Removed "a != + b" assert and inserted fastpath code for this case. + (bitmap_ior): Removed "a != b" assert. + 2005-07-08 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com> * config/m32r/linux.h (STARTFILE_SPEC): Support PIE. diff --git a/gcc/bitmap.c b/gcc/bitmap.c index c7b25c53ee0..e587c24bda2 100644 --- a/gcc/bitmap.c +++ b/gcc/bitmap.c @@ -583,7 +583,14 @@ bitmap_and (bitmap dst, bitmap a, bitmap b) bitmap_element *b_elt = b->first; bitmap_element *dst_prev = NULL; - gcc_assert (dst != a && dst != b && a != b); + gcc_assert (dst != a && dst != b); + + if (a == b) + { + bitmap_copy (dst, a); + return; + } + while (a_elt && b_elt) { if (a_elt->indx < b_elt->indx) @@ -631,7 +638,9 @@ bitmap_and_into (bitmap a, bitmap b) bitmap_element *b_elt = b->first; bitmap_element *next; - gcc_assert (a != b); + if (a == b) + return; + while (a_elt && b_elt) { if (a_elt->indx < b_elt->indx) @@ -677,8 +686,14 @@ bitmap_and_compl (bitmap dst, bitmap a, bitmap b) bitmap_element *b_elt = b->first; bitmap_element *dst_prev = NULL; - gcc_assert (dst != a && dst != b && a != b); + gcc_assert (dst != a && dst != b); + if (a == b) + { + bitmap_clear (dst); + return; + } + while (a_elt) { if (!b_elt || a_elt->indx < b_elt->indx) @@ -737,7 +752,17 @@ bitmap_and_compl_into (bitmap a, bitmap b) bitmap_element *next; BITMAP_WORD changed = 0; - gcc_assert (a != b); + if (a == b) + { + if (bitmap_empty_p (a)) + return false; + else + { + bitmap_clear (a); + return true; + } + } + while (a_elt && b_elt) { if (a_elt->indx < b_elt->indx) @@ -782,7 +807,8 @@ bitmap_ior (bitmap dst, bitmap a, bitmap b) bitmap_element *dst_prev = NULL; bool changed = false; - gcc_assert (dst != a && dst != b && a != b); + gcc_assert (dst != a && dst != b); + while (a_elt || b_elt) { if (a_elt && b_elt && a_elt->indx == b_elt->indx) @@ -883,7 +909,9 @@ bitmap_ior_into (bitmap a, bitmap b) bitmap_element *a_prev = NULL; bool changed = false; - gcc_assert (a != b); + if (a == b) + return false; + while (b_elt) { if (!a_elt || b_elt->indx < a_elt->indx) @@ -946,7 +974,13 @@ bitmap_xor (bitmap dst, bitmap a, bitmap b) bitmap_element *b_elt = b->first; bitmap_element *dst_prev = NULL; - gcc_assert (dst != a && dst != b && a != b); + gcc_assert (dst != a && dst != b); + if (a == b) + { + bitmap_clear (dst); + return; + } + while (a_elt || b_elt) { if (a_elt && b_elt && a_elt->indx == b_elt->indx) @@ -1014,7 +1048,12 @@ bitmap_xor_into (bitmap a, bitmap b) bitmap_element *b_elt = b->first; bitmap_element *a_prev = NULL; - gcc_assert (a != b); + if (a == b) + { + bitmap_clear (a); + return; + } + while (b_elt) { if (!a_elt || b_elt->indx < a_elt->indx) |