From 91d024d568448e334ecc60b0c55a30b7c3ead9e4 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Martin=20v=2E=20L=C3=B6wis?= Date: Fri, 17 Mar 2000 09:11:17 +0000 Subject: [PATCH] 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 --- gcc/ChangeLog | 5 +++++ gcc/calls.c | 7 ++++--- 2 files changed, 9 insertions(+), 3 deletions(-) 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; } } -- 2.30.2