mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-05 00:31:30 +08:00
Remove ad-hoc range canonicalization from determine_block_size.
Anti ranges of ~[MIN,X] are automatically canonicalized to [X+1,MAX], at creation time. There is no need to handle them specially. Tested by adding a gcc_unreachable and bootstrapping/testing. gcc/ChangeLog: * builtins.c (determine_block_size): Remove ad-hoc range canonicalization.
This commit is contained in:
parent
265d817b1e
commit
f21757eb8f
@ -3287,12 +3287,6 @@ determine_block_size (tree len, rtx len_rtx,
|
||||
}
|
||||
else if (range_type == VR_ANTI_RANGE)
|
||||
{
|
||||
/* Anti range 0...N lets us to determine minimal size to N+1. */
|
||||
if (min == 0)
|
||||
{
|
||||
if (wi::fits_uhwi_p (max) && max.to_uhwi () + 1 != 0)
|
||||
*min_size = max.to_uhwi () + 1;
|
||||
}
|
||||
/* Code like
|
||||
|
||||
int n;
|
||||
@ -3302,7 +3296,7 @@ determine_block_size (tree len, rtx len_rtx,
|
||||
Produce anti range allowing negative values of N. We still
|
||||
can use the information and make a guess that N is not negative.
|
||||
*/
|
||||
else if (!wi::leu_p (max, 1 << 30) && wi::fits_uhwi_p (min))
|
||||
if (!wi::leu_p (max, 1 << 30) && wi::fits_uhwi_p (min))
|
||||
*probable_max_size = min.to_uhwi () - 1;
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user