From 5e043dc905a76adbb55b1ca7a769a644d4091cc1 Mon Sep 17 00:00:00 2001 From: Richard Guenther Date: Mon, 26 Nov 2007 12:30:40 +0000 Subject: [PATCH] re PR middle-end/34233 (ICE: get_callee_fndecl, at tree.c:6592) 2007-11-26 Richard Guenther PR middle-end/34233 * builtins.c (expand_builtin_pow): Use expand_expr to expand the result of build_call_expr. * gcc.dg/pr34233.c: New testcase. From-SVN: r130436 --- gcc/ChangeLog | 6 ++++++ gcc/builtins.c | 4 +++- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gcc.dg/pr34233.c | 8 ++++++++ 4 files changed, 22 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gcc.dg/pr34233.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 4a6466c988ec..76daadca1158 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2007-11-26 Richard Guenther + + PR middle-end/34233 + * builtins.c (expand_builtin_pow): Use expand_expr to expand + the result of build_call_expr. + 2007-11-26 Steven Bosscher Revital Eres diff --git a/gcc/builtins.c b/gcc/builtins.c index 4f4cba250ed7..1eb6cfc3d6e1 100644 --- a/gcc/builtins.c +++ b/gcc/builtins.c @@ -2938,7 +2938,9 @@ expand_builtin_pow (tree exp, rtx target, rtx subtarget) || n == 1)) { tree call_expr = build_call_expr (fn, 1, narg0); - op = expand_builtin (call_expr, NULL_RTX, subtarget, mode, 0); + /* Use expand_expr in case the newly built call expression + was folded to a non-call. */ + op = expand_expr (call_expr, subtarget, mode, EXPAND_NORMAL); if (n != 1) { op2 = expand_expr (narg0, subtarget, VOIDmode, EXPAND_NORMAL); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cb45e6e8c172..d90427f50746 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-11-26 Richard Guenther + + PR middle-end/34233 + * gcc.dg/pr34233.c: New testcase. + 2007-11-26 Steven Bosscher Revital Eres diff --git a/gcc/testsuite/gcc.dg/pr34233.c b/gcc/testsuite/gcc.dg/pr34233.c new file mode 100644 index 000000000000..1982efaa6728 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr34233.c @@ -0,0 +1,8 @@ +/* { dg-do compile } */ +/* { dg-options "-ffast-math" } */ + +double foo(void) +{ + return __builtin_pow (0.0, -1.5); +} +