summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2008-05-17 13:06:21 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2008-05-17 13:06:21 +0000
commit101f2414cfe22a332a2e34115fa19181af69efe7 (patch)
treea24b798aed2e282c91f6d71952eb3bd67579425e
parente9ee81a75f56f7f30836c53ecc6d230443db8593 (diff)
downloadgcc-101f2414cfe22a332a2e34115fa19181af69efe7.tar.gz
* fold-const.c (fold_unary) <CASE_CONVERT>: Fold the cast into
a BIT_AND_EXPR only for an INTEGER_TYPE. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@135467 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/fold-const.c3
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/bit_packed_array3.adb40
4 files changed, 50 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 86c6d31605b..ae051b34e8c 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -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
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index c167bc4f670..dc1e182c16f 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -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)
{
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a50160189cd..10325d74427 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,9 @@
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.
2008-05-16 Paul Thomas <pault@gcc.gnu.org>
diff --git a/gcc/testsuite/gnat.dg/bit_packed_array3.adb b/gcc/testsuite/gnat.dg/bit_packed_array3.adb
new file mode 100644
index 00000000000..0b121efdc5f
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/bit_packed_array3.adb
@@ -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;