mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-11 17:08:42 +00:00
b19289331d
independent of the underlying system. Let me know if any of these are too aggressive. llvm-svn: 119345
29 lines
1.2 KiB
C
29 lines
1.2 KiB
C
// RUN: %clang -Xclang -verify -fsyntax-only %s
|
|
// RUN: %clang -emit-llvm -S -o %t %s
|
|
|
|
#include <stddef.h>
|
|
|
|
// Declare malloc here explicitly so we don't depend on system headers.
|
|
void * malloc(size_t) __attribute((malloc));
|
|
|
|
int no_vars __attribute((malloc)); // expected-warning {{functions returning a pointer type}}
|
|
|
|
void returns_void (void) __attribute((malloc)); // expected-warning {{functions returning a pointer type}}
|
|
int returns_int (void) __attribute((malloc)); // expected-warning {{functions returning a pointer type}}
|
|
int * returns_intptr(void) __attribute((malloc)); // no-warning
|
|
typedef int * iptr;
|
|
iptr returns_iptr (void) __attribute((malloc)); // no-warning
|
|
|
|
__attribute((malloc)) void *(*f)(); // expected-warning{{'malloc' attribute only applies to functions returning a pointer type}}
|
|
__attribute((malloc)) int (*g)(); // expected-warning{{'malloc' attribute only applies to functions returning a pointer type}}
|
|
|
|
__attribute((malloc))
|
|
void * xalloc(unsigned n) { return malloc(n); } // no-warning
|
|
// RUN: grep 'define noalias .* @xalloc(' %t
|
|
|
|
#define malloc_like __attribute((__malloc__))
|
|
void * xalloc2(unsigned) malloc_like;
|
|
void * xalloc2(unsigned n) { return malloc(n); }
|
|
// RUN: grep 'define noalias .* @xalloc2(' %t
|
|
|