diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-08-18 15:06:25 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-08-18 15:06:25 +0000 |
commit | c1a42fdd53afe2d837970e6a260c7b76c0a95fd9 (patch) | |
tree | bcf250ed3ff8fd317902f9c52f1b53cb2328d258 | |
parent | b13f5d99af2764b77510feaad66e3f190ae1a458 (diff) | |
download | bcm5719-llvm-c1a42fdd53afe2d837970e6a260c7b76c0a95fd9.tar.gz bcm5719-llvm-c1a42fdd53afe2d837970e6a260c7b76c0a95fd9.zip |
Make sure to add MallocAttr to explicitly-declared operator new/new[]
when -fassume-sane-operator-new. Patch by Tom Jablin!
llvm-svn: 111363
-rw-r--r-- | clang/lib/Sema/SemaExprCXX.cpp | 5 | ||||
-rw-r--r-- | clang/test/CodeGenCXX/new.cpp | 4 |
2 files changed, 8 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp index 5e46090c058..8599a146c69 100644 --- a/clang/lib/Sema/SemaExprCXX.cpp +++ b/clang/lib/Sema/SemaExprCXX.cpp @@ -1257,8 +1257,11 @@ void Sema::DeclareGlobalAllocationFunction(DeclarationName Name, Context.getCanonicalType( Func->getParamDecl(0)->getType().getUnqualifiedType()); // FIXME: Do we need to check for default arguments here? - if (Func->getNumParams() == 1 && InitialParamType == Argument) + if (Func->getNumParams() == 1 && InitialParamType == Argument) { + if(AddMallocAttr && !Func->hasAttr<MallocAttr>()) + Func->addAttr(::new (Context) MallocAttr()); return; + } } } } diff --git a/clang/test/CodeGenCXX/new.cpp b/clang/test/CodeGenCXX/new.cpp index 3f22e89f2a5..61a5a153ca5 100644 --- a/clang/test/CodeGenCXX/new.cpp +++ b/clang/test/CodeGenCXX/new.cpp @@ -73,6 +73,10 @@ void t8(int n) { new U[n]; } +// noalias +// CHECK: declare noalias i8* @_Znam +void *operator new[](size_t); + void t9() { bool b; |