fold-const.c (make_range_step): Bail out if the range isn't testing for zero.
* fold-const.c (make_range_step) <TRUTH_NOT_EXPR>: Bail out if the range isn't testing for zero. From-SVN: r195642
This commit is contained in:
parent
a1948282e8
commit
9f419393f2
@ -1,3 +1,8 @@
|
||||
2013-02-01 Eric Botcazou <ebotcazou@adacore.com>
|
||||
|
||||
* fold-const.c (make_range_step) <TRUTH_NOT_EXPR>: Bail out if the
|
||||
range isn't testing for zero.
|
||||
|
||||
2013-01-31 Steven Bosscher <steven@gcc.gnu.org>
|
||||
|
||||
PR middle-end/56113
|
||||
|
@ -3813,6 +3813,10 @@ make_range_step (location_t loc, enum tree_code code, tree arg0, tree arg1,
|
||||
switch (code)
|
||||
{
|
||||
case TRUTH_NOT_EXPR:
|
||||
/* We can only do something if the range is testing for zero. */
|
||||
if (low == NULL_TREE || high == NULL_TREE
|
||||
|| ! integer_zerop (low) || ! integer_zerop (high))
|
||||
return NULL_TREE;
|
||||
*p_in_p = ! in_p;
|
||||
return arg0;
|
||||
|
||||
|
@ -1,3 +1,7 @@
|
||||
2013-02-01 Eric Botcazou <ebotcazou@adacore.com>
|
||||
|
||||
* gnat.dg/opt26.adb: New test.
|
||||
|
||||
2013-01-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
|
||||
|
||||
Revert.
|
||||
|
37
gcc/testsuite/gnat.dg/opt26.adb
Normal file
37
gcc/testsuite/gnat.dg/opt26.adb
Normal file
@ -0,0 +1,37 @@
|
||||
-- { dg-do run }
|
||||
-- { dg-options "-gnato -O" }
|
||||
|
||||
with Interfaces; use Interfaces;
|
||||
|
||||
procedure Opt26 is
|
||||
|
||||
procedure Shift_Left_Bool
|
||||
(Bool : in Boolean;
|
||||
U8 : out Interfaces.Unsigned_8)
|
||||
is
|
||||
begin
|
||||
U8 := Shift_Left (Boolean'Pos (Bool), 6);
|
||||
end Shift_Left_Bool;
|
||||
|
||||
procedure Shift_Left_Not_Bool
|
||||
(Bool : in Boolean;
|
||||
U8 : out Interfaces.Unsigned_8)
|
||||
is
|
||||
begin
|
||||
U8 := Shift_Left (Boolean'Pos (not Bool), 6);
|
||||
end Shift_Left_Not_Bool;
|
||||
|
||||
Bool : constant Boolean := True;
|
||||
Byte1, Byte2 : Interfaces.Unsigned_8;
|
||||
|
||||
begin
|
||||
|
||||
Shift_Left_Bool (Bool, Byte1);
|
||||
|
||||
Shift_Left_Not_Bool (Bool, Byte2);
|
||||
|
||||
if Byte1 + Byte2 /= 64 then
|
||||
raise Program_Error;
|
||||
end if;
|
||||
|
||||
end;
|
Loading…
Reference in New Issue
Block a user