From: Martin v. Löwis Date: Fri, 17 Mar 2000 09:11:17 +0000 (+0000) Subject: call.c (special_function_p): It is only malloc if it returns Pmode. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=91d024d568448e334ecc60b0c55a30b7c3ead9e4;p=gcc.git call.c (special_function_p): It is only malloc if it returns Pmode. * call.c (special_function_p): It is only malloc if it returns Pmode. From-SVN: r32604 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7f1fc13882c..09dffc1d613 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-03-17 Martin v. Löwis + + * call.c (special_function_p): It is only malloc if it returns + Pmode. + 2000-03-17 Michael Hayes * config/c4x/c4x.h (ASM_SPEC, CPP_SPEC, LINK_SPEC): Support C33. diff --git a/gcc/calls.c b/gcc/calls.c index 7ae7b3d60f3..6a4c1484ffc 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -645,9 +645,10 @@ special_function_p (fndecl, returns_twice, is_longjmp, fork_or_exec, C++ operator new is not suitable because it is not required to return a unique pointer; indeed, the standard placement new just returns its argument. */ - else if (! strcmp (tname, "malloc") - || ! strcmp (tname, "calloc") - || ! strcmp (tname, "strdup")) + else if (TYPE_MODE (TREE_TYPE (TREE_TYPE (fndecl))) == Pmode + && (! strcmp (tname, "malloc") + || ! strcmp (tname, "calloc") + || ! strcmp (tname, "strdup"))) *is_malloc = 1; } }