diff options
author | Anna Zaks <ganna@apple.com> | 2012-06-08 18:44:43 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-06-08 18:44:43 +0000 |
commit | 528b14c5d9bc5b55fedba858b67487dacd23820c (patch) | |
tree | 1ab5e7c71055aa70eb5fa38432b2fa2276e17ac3 /clang/test/Analysis/malloc-sizeof.c | |
parent | bf86b295bb12f27331ce524eeb06f95a66c86514 (diff) | |
download | bcm5719-llvm-528b14c5d9bc5b55fedba858b67487dacd23820c.tar.gz bcm5719-llvm-528b14c5d9bc5b55fedba858b67487dacd23820c.zip |
[analyzer] MallocSizeofChecker false positive: when sizeof is argument
to addition.
We should not to warn in case the malloc size argument is an
addition containing 'sizeof' operator - it is common to use the pattern
to pack values of different sizes into a buffer.
Ex:
uint8_t *buffer = (uint8_t*)malloc(dataSize + sizeof(length));
llvm-svn: 158219
Diffstat (limited to 'clang/test/Analysis/malloc-sizeof.c')
-rw-r--r-- | clang/test/Analysis/malloc-sizeof.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/clang/test/Analysis/malloc-sizeof.c b/clang/test/Analysis/malloc-sizeof.c index af8600abe5a..6eb466ac6a1 100644 --- a/clang/test/Analysis/malloc-sizeof.c +++ b/clang/test/Analysis/malloc-sizeof.c @@ -10,13 +10,14 @@ void free(void *ptr); struct A {}; struct B {}; -void foo() { +void foo(unsigned int unsignedInt, unsigned int readSize) { int *ip1 = malloc(sizeof(1)); int *ip2 = malloc(4 * sizeof(int)); long *lp1 = malloc(sizeof(short)); // expected-warning {{Result of 'malloc' is converted to a pointer of type 'long', which is incompatible with sizeof operand type 'short'}} long *lp2 = malloc(5 * sizeof(double)); // expected-warning {{Result of 'malloc' is converted to a pointer of type 'long', which is incompatible with sizeof operand type 'double'}} - long *lp3 = malloc(5 * sizeof(char) + 2); // expected-warning {{Result of 'malloc' is converted to a pointer of type 'long', which is incompatible with sizeof operand type 'char'}} + char *cp3 = malloc(5 * sizeof(char) + 2); // no warning + unsigned char *buf = malloc(readSize + sizeof(unsignedInt)); // no warning struct A *ap1 = calloc(1, sizeof(struct A)); struct A *ap2 = calloc(2, sizeof(*ap1)); |