fold-const.c (fold_unary): Fold the cast into a BIT_AND_EXPR only for an INTEGER_TYPE.
authorEric Botcazou <ebotcazou@adacore.com>
Sat, 17 May 2008 13:06:21 +0000 (13:06 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Sat, 17 May 2008 13:06:21 +0000 (13:06 +0000)
* fold-const.c (fold_unary) <CASE_CONVERT>: Fold the cast into
a BIT_AND_EXPR only for an INTEGER_TYPE.

From-SVN: r135467

gcc/ChangeLog
gcc/fold-const.c
gcc/testsuite/ChangeLog
gcc/testsuite/gnat.dg/bit_packed_array3.adb [new file with mode: 0644]

index 86c6d31605bc14a0525a2d04598dacc4d6d99e7d..ae051b34e8c5ce757ce5a9c56223df6080c58327 100644 (file)
@@ -1,3 +1,8 @@
+2008-05-17  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * fold-const.c (fold_unary) <CASE_CONVERT>: Fold the cast into
+       a BIT_AND_EXPR only for an INTEGER_TYPE.
+
 2008-05-16  David S. Miller  <davem@davemloft.net>
 
        * config/sparc/linux.h (NO_PROFILE_COUNTERS): Undef before
@@ -23,7 +28,6 @@
        (df_simulate_one_insn_backwards): Renamed to df_simulate_one_insn.
        (df_simulate_one_insn_forwards): Removed.
 
-       
 2008-05-16  Doug Kwan  <dougkwan@google.com>
 
        * real.c (real_to_decimal, real_to_hexadecimal): Distinguish
index c167bc4f6706ae3fe8b86c16a46bc8c12c0a58ae..dc1e182c16ff6e5038e952d13ca231abf1246fc7 100644 (file)
@@ -7864,8 +7864,7 @@ fold_unary (enum tree_code code, tree type, tree op0)
       /* Convert (T)(x & c) into (T)x & (T)c, if c is an integer
         constants (if x has signed type, the sign bit cannot be set
         in c).  This folds extension into the BIT_AND_EXPR.  */
-      if (INTEGRAL_TYPE_P (type)
-         && TREE_CODE (type) != BOOLEAN_TYPE
+      if (TREE_CODE (type) == INTEGER_TYPE
          && TREE_CODE (op0) == BIT_AND_EXPR
          && TREE_CODE (TREE_OPERAND (op0, 1)) == INTEGER_CST)
        {
index a50160189cd44a1eda4ffd0341b65391d1350117..10325d7442781c2f5d5eedf78b0767abab65d23a 100644 (file)
@@ -1,3 +1,7 @@
+2008-05-17  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gnat.dg/bit_packed_array3.adb: New test.
+
 2008-05-17  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gnat.dg/warn4.adb: New test.
diff --git a/gcc/testsuite/gnat.dg/bit_packed_array3.adb b/gcc/testsuite/gnat.dg/bit_packed_array3.adb
new file mode 100644 (file)
index 0000000..0b121ef
--- /dev/null
@@ -0,0 +1,40 @@
+-- { dg-do run }
+-- { dg-options "-O2 -gnatp" }
+
+procedure Bit_Packed_Array3 is
+
+   type Bitmap_T is array (1 .. 10) of Boolean;
+   pragma Pack (Bitmap_T);
+
+   type Maps_T is record
+      M1 : Bitmap_T;
+   end record;
+   pragma Pack (Maps_T);
+   for Maps_T'Size use 10;
+   pragma Suppress_Initialization (Maps_T);
+
+   Tmap : constant Bitmap_T := (others => True);
+   Fmap : constant Bitmap_T := (others => False);
+   Amap : constant Bitmap_T :=
+     (1 => False, 2 => True, 3 => False, 4 => True, 5 => False,
+      6 => True, 7 => False, 8 => True, 9 => False, 10 => True);
+
+   function Some_Maps return Maps_T is
+      Value : Maps_T := (M1 => Amap);
+   begin
+      return Value;
+   end;
+   pragma Inline (Some_Maps);
+
+   Maps : Maps_T;
+begin
+   Maps := Some_Maps;
+
+   for I in Maps.M1'Range loop
+      if (I mod 2 = 0 and then not Maps.M1 (I))
+        or else (I mod 2 /= 0 and then Maps.M1 (I))
+      then
+         raise Program_Error;
+      end if;
+   end loop;
+end;