[cfe-commits] r157500 - in /cfe/trunk: lib/CodeGen/CGCall.cpp test/CodeGenCXX/alloc_size.cpp
Nuno Lopes
nunoplopes at sapo.pt
Fri May 25 14:45:08 PDT 2012
Author: nlopes
Date: Fri May 25 16:45:08 2012
New Revision: 157500
URL: http://llvm.org/viewvc/llvm-project?rev=157500&view=rev
Log:
fix codegen support for alloc_size attribute for static C++ methods
add test case for C++ codegen
Added:
cfe/trunk/test/CodeGenCXX/alloc_size.cpp
Modified:
cfe/trunk/lib/CodeGen/CGCall.cpp
Modified: cfe/trunk/lib/CodeGen/CGCall.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGCall.cpp?rev=157500&r1=157499&r2=157500&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/CGCall.cpp (original)
+++ cfe/trunk/lib/CodeGen/CGCall.cpp Fri May 25 16:45:08 2012
@@ -2090,9 +2090,11 @@
// add metadata for __attribute__((alloc_size(foo)))
if (TargetDecl) {
if (const AllocSizeAttr* Attr = TargetDecl->getAttr<AllocSizeAttr>()) {
- std::vector<llvm::Value*> Args;
+ SmallVector<llvm::Value*, 4> Args;
llvm::IntegerType *Ty = llvm::IntegerType::getInt32Ty(getLLVMContext());
- bool isMethod = isa<CXXMethodDecl>(TargetDecl);
+ bool isMethod = false;
+ if (const CXXMethodDecl *MDecl = dyn_cast<CXXMethodDecl>(TargetDecl))
+ isMethod = MDecl->isInstance();
for (AllocSizeAttr::args_iterator I = Attr->args_begin(),
E = Attr->args_end(); I != E; ++I) {
Added: cfe/trunk/test/CodeGenCXX/alloc_size.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/alloc_size.cpp?rev=157500&view=auto
==============================================================================
--- cfe/trunk/test/CodeGenCXX/alloc_size.cpp (added)
+++ cfe/trunk/test/CodeGenCXX/alloc_size.cpp Fri May 25 16:45:08 2012
@@ -0,0 +1,18 @@
+// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s
+
+struct foo {
+ void *my_alloc(unsigned) __attribute__((alloc_size(2)));
+ static void* static_alloc(unsigned) __attribute__((alloc_size(1)));
+};
+
+
+void* f(bool a) {
+ // CHECK: call i8* {{.*}}alloc{{.*}}, !alloc_size !0
+ // CHECK: call i8* {{.*}}static_alloc{{.*}}, !alloc_size !1
+ foo obj;
+ return a ? obj.my_alloc(2) :
+ foo::static_alloc(42);
+}
+
+// CHECK: !0 = metadata !{i32 1}
+// CHECK: !1 = metadata !{i32 0}
More information about the cfe-commits
mailing list