diff options
author | Richard Guenther <rguenther@suse.de> | 2010-04-23 14:20:59 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2010-04-23 14:20:59 +0000 |
commit | c67f69a3f3977669094ed9a815116d2b97ac09d1 (patch) | |
tree | 50df64df3664841767cd0b745467545dd81c33a7 /gcc | |
parent | 086058c2a6338dc9e0f1b8d0962da1ee7363f4c7 (diff) | |
download | gcc-c67f69a3f3977669094ed9a815116d2b97ac09d1.zip gcc-c67f69a3f3977669094ed9a815116d2b97ac09d1.tar.gz gcc-c67f69a3f3977669094ed9a815116d2b97ac09d1.tar.bz2 |
re PR lto/42653 (ICE with -g and -flto (requires both flags to crash))
2010-04-23 Richard Guenther <rguenther@suse.de>
PR lto/42653
* tree.c (free_lang_data_in_decl): Do not reset DECL_CONTEXT
of FUNCTION_DECLs.
* g++.dg/lto/20100423-1_0.C: New testcase.
From-SVN: r158666
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/lto/20100423-1_0.C | 38 | ||||
-rw-r--r-- | gcc/tree.c | 3 |
4 files changed, 51 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index bfbbc86..d81d2eb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-04-23 Richard Guenther <rguenther@suse.de> + + PR lto/42653 + * tree.c (free_lang_data_in_decl): Do not reset DECL_CONTEXT + of FUNCTION_DECLs. + 2010-04-22 Laurynas Biveinis <laurynas.biveinis@gmail.com> * sese.h (create_if_region_on_edge): Remove. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d057d15..5dfed40 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-04-23 Richard Guenther <rguenther@suse.de> + + PR lto/42653 + * g++.dg/lto/20100423-1_0.C: New testcase. + 2010-04-22 Uros Bizjak <ubizjak@gmail.com> * gcc.dg/graphite/interchange-0.c: Fix dg-final directive. diff --git a/gcc/testsuite/g++.dg/lto/20100423-1_0.C b/gcc/testsuite/g++.dg/lto/20100423-1_0.C new file mode 100644 index 0000000..f6a741d --- /dev/null +++ b/gcc/testsuite/g++.dg/lto/20100423-1_0.C @@ -0,0 +1,38 @@ +// { dg-lto-do assemble } +// { dg-lto-options {{-g -flto}} } + +namespace llvm +{ + class Function; + class MachineCodeInfo; + class ExecutionEngine + { + }; + class JIT : public ExecutionEngine + { + void runJITOnFunction (Function * F, MachineCodeInfo * MCI = 0); + }; + class JITEventListener + { + public: + JITEventListener () + { + } + virtual ~JITEventListener (); + }; +} + +using namespace llvm; +void +JIT::runJITOnFunction (Function * F, MachineCodeInfo * MCI) +{ + class MCIListener:public JITEventListener + { + MachineCodeInfo *const MCI; + public: + MCIListener (MachineCodeInfo * mci):MCI (mci) + { + } + }; +} + @@ -4361,7 +4361,8 @@ free_lang_data_in_decl (tree decl) /* Ignore any intervening types, because we are going to clear their TYPE_CONTEXT fields. */ - if (TREE_CODE (decl) != FIELD_DECL) + if (TREE_CODE (decl) != FIELD_DECL + && TREE_CODE (decl) != FUNCTION_DECL) DECL_CONTEXT (decl) = decl_function_context (decl); if (DECL_CONTEXT (decl) |