diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-11-13 20:00:28 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-11-13 20:00:28 +0000 |
commit | c764d4b5b78607d189eb5299ceb6d1640c99df45 (patch) | |
tree | 2036b289ceff75fd1553a88caea4c85608523493 | |
parent | ba93087ebd43c0f7b3e980dc9e49a9313d9c9f01 (diff) |
Add two new test cases for the Malloc/Free checker. Both have to do with
storing malloc'ed memory to global storage.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@88684 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/Analysis/malloc.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/test/Analysis/malloc.c b/test/Analysis/malloc.c index acbfb4c38f..45be977b93 100644 --- a/test/Analysis/malloc.c +++ b/test/Analysis/malloc.c @@ -16,3 +16,21 @@ void f2() { free(p); free(p); // expected-warning{{Try to free a memory block that has been released}} } + +// This case tests that storing malloc'ed memory to a static variable which is then returned +// is not leaked. In the absence of known contracts for functions or inter-procedural analysis, +// this is a conservative answer. +int *f3() { + static int *p = 0; + p = malloc(10); // no-warning + return p; +} + +// This case tests that storing malloc'ed memory to a static global variable which is then returned +// is not leaked. In the absence of known contracts for functions or inter-procedural analysis, +// this is a conservative answer. +static int *p_f4 = 0; +int *f4() { + p_f4 = malloc(10); // no-warning + return p_f4; +} |