2017-03-04 02:02:02 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -triple x86_64-unknown-linux %s
|
2014-03-27 01:05:46 +08:00
|
|
|
|
|
|
|
#include "Inputs/system-header-simulator.h"
|
|
|
|
|
|
|
|
#define __GFP_ZERO 0x8000
|
|
|
|
#define NULL ((void *)0)
|
|
|
|
|
|
|
|
void *kmalloc(size_t, int);
|
|
|
|
|
|
|
|
struct test {
|
|
|
|
};
|
|
|
|
|
|
|
|
void foo(struct test *);
|
|
|
|
|
|
|
|
void test_zeroed() {
|
|
|
|
struct test **list, *t;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
list = kmalloc(sizeof(*list) * 10, __GFP_ZERO);
|
|
|
|
if (list == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i = 0; i < 10; i++) {
|
|
|
|
t = list[i];
|
|
|
|
foo(t);
|
|
|
|
}
|
[analyzer] Support kfree in MallocChecker
Summary:
kmalloc is freed with kfree in the linux kernel. kmalloc support was
added in r204832, but kfree was not. Adding kfree fixes incorrectly
detected memory leaks.
Reviewers: NoQ, nickdesaulniers, dcoughlin, Szelethus
Reviewed By: NoQ, Szelethus
Subscribers: xazax.hun, baloghadamsoftware, szepet, a.sidorin, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, Charusso, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D64030
llvm-svn: 364875
2019-07-02 07:29:10 +08:00
|
|
|
kfree(list); // no-warning
|
2014-03-27 01:05:46 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void test_nonzero() {
|
|
|
|
struct test **list, *t;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
list = kmalloc(sizeof(*list) * 10, 0);
|
|
|
|
if (list == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i = 0; i < 10; i++) {
|
|
|
|
t = list[i]; // expected-warning{{undefined}}
|
|
|
|
foo(t);
|
|
|
|
}
|
[analyzer] Support kfree in MallocChecker
Summary:
kmalloc is freed with kfree in the linux kernel. kmalloc support was
added in r204832, but kfree was not. Adding kfree fixes incorrectly
detected memory leaks.
Reviewers: NoQ, nickdesaulniers, dcoughlin, Szelethus
Reviewed By: NoQ, Szelethus
Subscribers: xazax.hun, baloghadamsoftware, szepet, a.sidorin, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, Charusso, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D64030
llvm-svn: 364875
2019-07-02 07:29:10 +08:00
|
|
|
kfree(list);
|
2014-03-27 01:05:46 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void test_indeterminate(int flags) {
|
|
|
|
struct test **list, *t;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
list = kmalloc(sizeof(*list) * 10, flags);
|
|
|
|
if (list == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i = 0; i < 10; i++) {
|
|
|
|
t = list[i]; // expected-warning{{undefined}}
|
|
|
|
foo(t);
|
|
|
|
}
|
[analyzer] Support kfree in MallocChecker
Summary:
kmalloc is freed with kfree in the linux kernel. kmalloc support was
added in r204832, but kfree was not. Adding kfree fixes incorrectly
detected memory leaks.
Reviewers: NoQ, nickdesaulniers, dcoughlin, Szelethus
Reviewed By: NoQ, Szelethus
Subscribers: xazax.hun, baloghadamsoftware, szepet, a.sidorin, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, Charusso, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D64030
llvm-svn: 364875
2019-07-02 07:29:10 +08:00
|
|
|
kfree(list);
|
2014-03-27 01:05:46 +08:00
|
|
|
}
|