diff options
author | Eric Botcazou <ebotcazou@adacore.com> | 2009-10-20 09:19:17 +0000 |
---|---|---|
committer | Eric Botcazou <ebotcazou@gcc.gnu.org> | 2009-10-20 09:19:17 +0000 |
commit | a1aa17011f52bffc0f3022bc32d87222270dfb8b (patch) | |
tree | b9e333e8cefe1df8d54ec2d92ed5e2045172910b /gcc | |
parent | 717f4048cd7e5d2ff7beb9276c0e09b4cb4d2faa (diff) | |
download | gcc-a1aa17011f52bffc0f3022bc32d87222270dfb8b.zip gcc-a1aa17011f52bffc0f3022bc32d87222270dfb8b.tar.gz gcc-a1aa17011f52bffc0f3022bc32d87222270dfb8b.tar.bz2 |
tree-sra.c (build_ref_for_offset_1): Skip fields without size or with size that can't be represented as a host integer.
* tree-sra.c (build_ref_for_offset_1) <RECORD_TYPE>: Skip fields
without size or with size that can't be represented as a host integer.
From-SVN: r153008
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gnat.dg/discr21.adb | 34 | ||||
-rw-r--r-- | gcc/testsuite/gnat.dg/discr21.ads | 5 | ||||
-rw-r--r-- | gcc/testsuite/gnat.dg/discr21_pkg.ads | 19 | ||||
-rw-r--r-- | gcc/tree-sra.c | 5 |
6 files changed, 72 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 17e513f..739cdb5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2009-10-20 Eric Botcazou <ebotcazou@adacore.com> + + * tree-sra.c (build_ref_for_offset_1) <RECORD_TYPE>: Skip fields + without size or with size that can't be represented as a host integer. + 2009-10-20 Alexandre Oliva <aoliva@redhat.com> * tree-ssa-dce.c (eliminate_unnecessary_stmts): Don't regard diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e0d007a..1868e09 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-10-20 Eric Botcazou <ebotcazou@adacore.com> + + * gnat.dg/discr21.ad[sb]: New test. + * gnat.dg/discr21_pkg.ads: New helper. + 2009-10-20 Paul Thomas <pault@gcc.gnu.org> PR fortran/41706 diff --git a/gcc/testsuite/gnat.dg/discr21.adb b/gcc/testsuite/gnat.dg/discr21.adb new file mode 100644 index 0000000..5c105cd --- /dev/null +++ b/gcc/testsuite/gnat.dg/discr21.adb @@ -0,0 +1,34 @@ +-- { dg-do compile } +-- { dg-options "-gnatws -O3" } + +with Discr21_Pkg; use Discr21_Pkg; + +package body Discr21 is + + type Index is new Natural range 0 .. 100; + + type Arr is array (Index range <> ) of Position; + + type Rec(Size : Index := 1) is record + A : Arr(1 .. Size); + end record; + + Data : Rec; + + function To_V(pos : Position) return VPosition is + begin + return To_Position(pos.x, pos.y, pos.z); + end; + + procedure Read(Data : Rec) is + pos : VPosition := To_V (Data.A(1)); + begin + null; + end; + + procedure Test is + begin + Read (Data); + end; + +end Discr21; diff --git a/gcc/testsuite/gnat.dg/discr21.ads b/gcc/testsuite/gnat.dg/discr21.ads new file mode 100644 index 0000000..8de8ed0 --- /dev/null +++ b/gcc/testsuite/gnat.dg/discr21.ads @@ -0,0 +1,5 @@ +package Discr21 is + + procedure Test; + +end Discr21; diff --git a/gcc/testsuite/gnat.dg/discr21_pkg.ads b/gcc/testsuite/gnat.dg/discr21_pkg.ads new file mode 100644 index 0000000..d156df6 --- /dev/null +++ b/gcc/testsuite/gnat.dg/discr21_pkg.ads @@ -0,0 +1,19 @@ +package Discr21_Pkg is + + type Position is record + x,y,z : Float; + end record; + + type Dim is (Two, Three); + + type VPosition (D: Dim := Three) is record + x, y : Float; + case D is + when Two => null; + when Three => z : Float; + end case; + end record; + + function To_Position (x, y, z : Float) return VPosition; + +end Discr21_Pkg; diff --git a/gcc/tree-sra.c b/gcc/tree-sra.c index dd3f680..8624668 100644 --- a/gcc/tree-sra.c +++ b/gcc/tree-sra.c @@ -1243,7 +1243,10 @@ build_ref_for_offset_1 (tree *res, tree type, HOST_WIDE_INT offset, pos = int_bit_position (fld); gcc_assert (TREE_CODE (type) == RECORD_TYPE || pos == 0); - size = tree_low_cst (DECL_SIZE (fld), 1); + tr_size = DECL_SIZE (fld); + if (!tr_size || !host_integerp (tr_size, 1)) + continue; + size = tree_low_cst (tr_size, 1); if (pos > offset || (pos + size) <= offset) continue; |