aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPierre-Marie de Rodat <derodat@adacore.com>2016-05-10 15:57:37 +0000
committerPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2016-05-10 15:57:37 +0000
commitcd36c83e9bb1c8cf66082da63234925482695ef1 (patch)
tree70b03e461d6650956ff172656edd2eeb9bc01fb3
parentafc610dba10fd532e83da10e19c5e0c5d7bcc34d (diff)
downloadgcc-cd36c83e9bb1c8cf66082da63234925482695ef1.zip
gcc-cd36c83e9bb1c8cf66082da63234925482695ef1.tar.gz
gcc-cd36c83e9bb1c8cf66082da63234925482695ef1.tar.bz2
DWARF: fix stack usage assessment for DW_OP_neg
When the DWARF back-end generates DW_OP_neg operations in DWARF procedures, we get an ICE because of inconsistent stack usage computation for the embedding expression. This is because resolve_args_picking_1 thinks DW_OP_neg is a binary operation (pops 2 stack slots, pushes 1) whereas it really is an unary one (one pop, one push). This change fixes resolve_args_picking_1 and adds a regression testcase (which crashes with the current trunk). Bootstrapped and regtested without regression on x86_64-linux. gcc/ * dwarf2out.c (resolve_args_picking_1): Consider DW_OP_neg as an unary operation, not a binary one. gcc/testsuite/ * gnat.dg/debug6.adb, gnat.dg/debug6_pkg.ads: New testcase. From-SVN: r236087
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/dwarf2out.c2
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/debug6.adb10
-rw-r--r--gcc/testsuite/gnat.dg/debug6_pkg.ads16
5 files changed, 36 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index e43a062..941748c 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-05-10 Pierre-Marie de Rodat <derodat@adacore.com>
+
+ * dwarf2out.c (resolve_args_picking_1): Consider DW_OP_neg as an
+ unary operation, not a binary one.
+
2016-05-10 Ilya Enkovich <ilya.enkovich@intel.com>
PR tree-optimization/70786
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c
index da95e19..8f192e8 100644
--- a/gcc/dwarf2out.c
+++ b/gcc/dwarf2out.c
@@ -15407,6 +15407,7 @@ resolve_args_picking_1 (dw_loc_descr_ref loc, unsigned initial_frame_offset,
case DW_OP_swap:
case DW_OP_rot:
case DW_OP_abs:
+ case DW_OP_neg:
case DW_OP_not:
case DW_OP_plus_uconst:
case DW_OP_skip:
@@ -15543,7 +15544,6 @@ resolve_args_picking_1 (dw_loc_descr_ref loc, unsigned initial_frame_offset,
case DW_OP_minus:
case DW_OP_mod:
case DW_OP_mul:
- case DW_OP_neg:
case DW_OP_or:
case DW_OP_plus:
case DW_OP_shl:
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7cf507f5..1e42f38 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2016-05-10 Pierre-Marie de Rodat <derodat@adacore.com>
+
+ * gnat.dg/debug6.adb, gnat.dg/debug6_pkg.ads: New testcase.
+
2016-05-10 Ilya Enkovich <ilya.enkovich@intel.com>
PR tree-optimization/70786
diff --git a/gcc/testsuite/gnat.dg/debug6.adb b/gcc/testsuite/gnat.dg/debug6.adb
new file mode 100644
index 0000000..25fdef2
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/debug6.adb
@@ -0,0 +1,10 @@
+-- { dg-do compile }
+-- { dg-options "-g" }
+
+with Debug6_Pkg; use Debug6_Pkg;
+
+procedure Debug6 is
+ V : Value := (Kind => Undefined);
+begin
+ Process (V);
+end Debug6;
diff --git a/gcc/testsuite/gnat.dg/debug6_pkg.ads b/gcc/testsuite/gnat.dg/debug6_pkg.ads
new file mode 100644
index 0000000..dfc9744
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/debug6_pkg.ads
@@ -0,0 +1,16 @@
+package Debug6_Pkg is
+
+ type Vkind is (Int, Undefined);
+ for Vkind use (Int => -2 ** 31, Undefined => 0);
+
+ type Value (Kind : Vkind) is record
+ case Kind is
+ when Undefined => null;
+ when Int => Value : Integer;
+ when others => null;
+ end case;
+ end record;
+
+ procedure Process (V : Value);
+
+end Debug6_Pkg;