aboutsummaryrefslogtreecommitdiff
path: root/gcc/varasm.c
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@libertysurf.fr>2005-01-14 09:03:20 +0100
committerEric Botcazou <ebotcazou@gcc.gnu.org>2005-01-14 08:03:20 +0000
commiteebeecacfb9c097f7b3766bcb96097a86d0860b7 (patch)
treee6852849268e281a533559c3020d30399dfee543 /gcc/varasm.c
parent84973b27e8283fa75075f124ad4e6e14dc7726a4 (diff)
downloadgcc-eebeecacfb9c097f7b3766bcb96097a86d0860b7.zip
gcc-eebeecacfb9c097f7b3766bcb96097a86d0860b7.tar.gz
gcc-eebeecacfb9c097f7b3766bcb96097a86d0860b7.tar.bz2
re PR middle-end/18820 (ACATS c95300[123] and c980002 fail at runtime)
PR middle-end/18820 * varasm.c (initializer_constant_valid_p) <ADDR_EXPR>: Return zero for nested functions needing a static chain or functions with a non-constant address. From-SVN: r93633
Diffstat (limited to 'gcc/varasm.c')
-rw-r--r--gcc/varasm.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/gcc/varasm.c b/gcc/varasm.c
index ba0aab5..8252f0e 100644
--- a/gcc/varasm.c
+++ b/gcc/varasm.c
@@ -3501,6 +3501,12 @@ initializer_constant_valid_p (tree value, tree endtype)
&& TREE_CODE (value) == INDIRECT_REF
&& TREE_CONSTANT (TREE_OPERAND (value, 0)))
return null_pointer_node;
+ /* Taking the address of a nested function involves a trampoline. */
+ if (value
+ && TREE_CODE (value) == FUNCTION_DECL
+ && ((decl_function_context (value) && !DECL_NO_STATIC_CHAIN (value))
+ || DECL_NON_ADDR_CONST_P (value)))
+ return NULL_TREE;
return value;
case VIEW_CONVERT_EXPR: