aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/Sema/SemaDeclAttr.cpp10
-rw-r--r--test/Sema/attr-malloc.c8
2 files changed, 10 insertions, 8 deletions
diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp
index e65b3aa6fd..23fe4010fb 100644
--- a/lib/Sema/SemaDeclAttr.cpp
+++ b/lib/Sema/SemaDeclAttr.cpp
@@ -437,16 +437,16 @@ static void HandleMallocAttr(Decl *d, const AttributeList &Attr, Sema &S) {
S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0;
return;
}
-
- const FunctionDecl *FD = dyn_cast<FunctionDecl>(d);
-
- if (!FD) {
+
+ const FunctionType *FT = getFunctionType(d, false);
+
+ if (!FT) {
S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
<< Attr.getName() << 0 /*function*/;
return;
}
- QualType RetTy = FD->getResultType();
+ QualType RetTy = FT->getResultType();
if (!(RetTy->isAnyPointerType() || RetTy->isBlockPointerType())) {
S.Diag(Attr.getLoc(), diag::warn_attribute_malloc_pointer_only);
diff --git a/test/Sema/attr-malloc.c b/test/Sema/attr-malloc.c
index 8841d6993a..36e8b1d699 100644
--- a/test/Sema/attr-malloc.c
+++ b/test/Sema/attr-malloc.c
@@ -7,12 +7,14 @@ int no_vars __attribute((malloc)); // expected-warning {{only applies to functio
void returns_void (void) __attribute((malloc)); // expected-warning {{functions returning pointer type}}
int returns_int (void) __attribute((malloc)); // expected-warning {{functions returning pointer type}}
-int * returns_intptr(void) __attribute((malloc));
+int * returns_intptr(void) __attribute((malloc)); // no-warning
typedef int * iptr;
-iptr returns_iptr (void) __attribute((malloc));
+iptr returns_iptr (void) __attribute((malloc)); // no-warning
+
+__attribute((malloc)) void *(*f)(); // no-warning
__attribute((malloc))
-void * xalloc(unsigned n) { return malloc(n); }
+void * xalloc(unsigned n) { return malloc(n); } // no-warning
// RUN: grep 'define noalias .* @xalloc(' %t &&
#define malloc_like __attribute((__malloc__))