+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
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;
--- /dev/null
+-- { 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;