[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
// RUN: %clang_analyze_cc1 %s \
|
|
|
|
// RUN: -verify=expected,tracking \
|
|
|
|
// RUN: -analyzer-config track-conditions=true \
|
|
|
|
// RUN: -analyzer-output=text \
|
|
|
|
// RUN: -analyzer-checker=core
|
2019-07-05 22:00:08 +08:00
|
|
|
|
|
|
|
// RUN: not %clang_analyze_cc1 -verify %s \
|
|
|
|
// RUN: -analyzer-checker=core \
|
|
|
|
// RUN: -analyzer-config track-conditions-debug=true \
|
|
|
|
// RUN: 2>&1 | FileCheck %s -check-prefix=CHECK-INVALID-DEBUG
|
|
|
|
|
|
|
|
// CHECK-INVALID-DEBUG: (frontend): invalid input for analyzer-config option
|
|
|
|
// CHECK-INVALID-DEBUG-SAME: 'track-conditions-debug', that expects
|
|
|
|
// CHECK-INVALID-DEBUG-SAME: 'track-conditions' to also be enabled
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
//
|
2019-07-05 22:00:08 +08:00
|
|
|
// RUN: %clang_analyze_cc1 %s \
|
|
|
|
// RUN: -verify=expected,tracking,debug \
|
|
|
|
// RUN: -analyzer-config track-conditions=true \
|
|
|
|
// RUN: -analyzer-config track-conditions-debug=true \
|
|
|
|
// RUN: -analyzer-output=text \
|
|
|
|
// RUN: -analyzer-checker=core
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
// RUN: %clang_analyze_cc1 %s -verify \
|
|
|
|
// RUN: -analyzer-output=text \
|
|
|
|
// RUN: -analyzer-checker=core
|
|
|
|
|
|
|
|
namespace example_1 {
|
|
|
|
int flag;
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
void foo() {
|
|
|
|
flag = coin(); // tracking-note{{Value assigned to 'flag'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
flag = 1;
|
|
|
|
|
|
|
|
foo(); // TODO: Add nodes here about flag's value being invalidated.
|
|
|
|
if (flag) // expected-note {{Assuming 'flag' is 0}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
x = new int;
|
|
|
|
|
|
|
|
foo(); // tracking-note{{Calling 'foo'}}
|
|
|
|
// tracking-note@-1{{Returning from 'foo'}}
|
|
|
|
|
|
|
|
if (flag) // expected-note {{Assuming 'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace example_1
|
|
|
|
|
|
|
|
namespace example_2 {
|
|
|
|
int flag;
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
void foo() {
|
|
|
|
flag = coin(); // tracking-note{{Value assigned to 'flag'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test() {
|
|
|
|
int *x = 0;
|
|
|
|
flag = 1;
|
|
|
|
|
|
|
|
foo();
|
|
|
|
if (flag) // expected-note {{Assuming 'flag' is 0}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
x = new int;
|
|
|
|
|
|
|
|
x = 0; // expected-note{{Null pointer value stored to 'x'}}
|
|
|
|
|
|
|
|
foo(); // tracking-note{{Calling 'foo'}}
|
|
|
|
// tracking-note@-1{{Returning from 'foo'}}
|
|
|
|
|
|
|
|
if (flag) // expected-note {{Assuming 'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace example_2
|
|
|
|
|
|
|
|
namespace global_variable_invalidation {
|
|
|
|
int flag;
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
void foo() {
|
|
|
|
// coin() could write bar, do it's invalidated.
|
|
|
|
flag = coin(); // tracking-note{{Value assigned to 'flag'}}
|
|
|
|
// tracking-note@-1{{Value assigned to 'bar'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
int bar;
|
|
|
|
|
|
|
|
void test() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
flag = 1;
|
|
|
|
|
|
|
|
foo(); // tracking-note{{Calling 'foo'}}
|
|
|
|
// tracking-note@-1{{Returning from 'foo'}}
|
|
|
|
|
|
|
|
if (bar) // expected-note {{Assuming 'bar' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'bar'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
if (flag) // expected-note {{Assuming 'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace global_variable_invalidation
|
|
|
|
|
|
|
|
namespace variable_declaration_in_condition {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
bool foo() {
|
2019-08-14 07:22:33 +08:00
|
|
|
return coin();
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int bar;
|
|
|
|
|
|
|
|
void test() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
2019-08-14 17:39:38 +08:00
|
|
|
if (int flag = foo()) // debug-note{{Tracking condition 'flag'}}
|
|
|
|
// expected-note@-1{{Assuming 'flag' is not equal to 0}}
|
|
|
|
// expected-note@-2{{Taking true branch}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
|
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace variable_declaration_in_condition
|
|
|
|
|
|
|
|
namespace conversion_to_bool {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
struct ConvertsToBool {
|
2019-08-14 07:22:33 +08:00
|
|
|
operator bool() const { return coin(); }
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
void test() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
|
|
|
if (ConvertsToBool())
|
2019-08-14 07:22:33 +08:00
|
|
|
// debug-note@-1{{Tracking condition 'ConvertsToBool()'}}
|
|
|
|
// expected-note@-2{{Assuming the condition is true}}
|
|
|
|
// expected-note@-3{{Taking true branch}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end of namespace variable_declaration_in_condition
|
|
|
|
|
2019-08-14 17:39:38 +08:00
|
|
|
namespace note_from_different_but_not_nested_stackframe {
|
|
|
|
|
|
|
|
void nullptrDeref(int *ptr, bool True) {
|
|
|
|
if (True) // expected-note{{'True' is true}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
|
|
|
// debug-note@-2{{Tracking condition 'True}}
|
|
|
|
*ptr = 5;
|
|
|
|
// expected-note@-1{{Dereference of null pointer (loaded from variable 'ptr')}}
|
|
|
|
// expected-warning@-2{{Dereference of null pointer (loaded from variable 'ptr')}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void f() {
|
|
|
|
int *ptr = nullptr;
|
|
|
|
// expected-note@-1{{'ptr' initialized to a null pointer value}}
|
|
|
|
bool True = true;
|
|
|
|
nullptrDeref(ptr, True);
|
|
|
|
// expected-note@-1{{Passing null pointer value via 1st parameter 'ptr'}}
|
|
|
|
// expected-note@-2{{Calling 'nullptrDeref'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end of namespace note_from_different_but_not_nested_stackframe
|
|
|
|
|
2019-08-14 07:22:33 +08:00
|
|
|
namespace important_returning_pointer_loaded_from {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
int *getIntPtr();
|
|
|
|
|
|
|
|
void storeValue(int **i) {
|
|
|
|
*i = getIntPtr(); // tracking-note{{Value assigned to 'i'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
int *conjurePointer() {
|
|
|
|
int *i;
|
|
|
|
storeValue(&i); // tracking-note{{Calling 'storeValue'}}
|
|
|
|
// tracking-note@-1{{Returning from 'storeValue'}}
|
|
|
|
return i; // tracking-note{{Returning pointer (loaded from 'i')}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void f(int *ptr) {
|
|
|
|
if (ptr) // expected-note{{Assuming 'ptr' is null}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
;
|
|
|
|
if (!conjurePointer())
|
|
|
|
// tracking-note@-1{{Calling 'conjurePointer'}}
|
|
|
|
// tracking-note@-2{{Returning from 'conjurePointer'}}
|
|
|
|
// debug-note@-3{{Tracking condition '!conjurePointer()'}}
|
|
|
|
// expected-note@-4{{Assuming the condition is true}}
|
|
|
|
// expected-note@-5{{Taking true branch}}
|
|
|
|
*ptr = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace important_returning_pointer_loaded_from
|
|
|
|
|
|
|
|
namespace unimportant_returning_pointer_loaded_from {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
int *getIntPtr();
|
|
|
|
|
|
|
|
int *conjurePointer() {
|
2019-08-14 17:39:38 +08:00
|
|
|
int *i = getIntPtr();
|
|
|
|
return i;
|
2019-08-14 07:22:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void f(int *ptr) {
|
|
|
|
if (ptr) // expected-note{{Assuming 'ptr' is null}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
;
|
|
|
|
if (!conjurePointer())
|
2019-08-14 17:39:38 +08:00
|
|
|
// debug-note@-1{{Tracking condition '!conjurePointer()'}}
|
|
|
|
// expected-note@-2{{Assuming the condition is true}}
|
|
|
|
// expected-note@-3{{Taking true branch}}
|
2019-08-14 07:22:33 +08:00
|
|
|
*ptr = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace unimportant_returning_pointer_loaded_from
|
|
|
|
|
|
|
|
namespace unimportant_returning_pointer_loaded_from_through_cast {
|
|
|
|
|
|
|
|
void *conjure();
|
|
|
|
|
|
|
|
int *cast(void *P) {
|
|
|
|
return static_cast<int *>(P);
|
|
|
|
}
|
|
|
|
|
|
|
|
void f() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
|
|
|
if (cast(conjure()))
|
2019-08-14 17:39:38 +08:00
|
|
|
// debug-note@-1{{Tracking condition 'cast(conjure())'}}
|
|
|
|
// expected-note@-2{{Assuming the condition is false}}
|
|
|
|
// expected-note@-3{{Taking false branch}}
|
2019-08-14 07:22:33 +08:00
|
|
|
return;
|
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end of namespace unimportant_returning_pointer_loaded_from_through_cast
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
namespace unimportant_returning_value_note {
|
|
|
|
bool coin();
|
|
|
|
|
2019-08-14 07:22:33 +08:00
|
|
|
bool flipCoin() { return coin(); }
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
|
|
|
|
void i(int *ptr) {
|
|
|
|
if (ptr) // expected-note{{Assuming 'ptr' is null}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
;
|
|
|
|
if (!flipCoin())
|
2019-08-14 07:22:33 +08:00
|
|
|
// debug-note@-1{{Tracking condition '!flipCoin()'}}
|
|
|
|
// expected-note@-2{{Assuming the condition is true}}
|
|
|
|
// expected-note@-3{{Taking true branch}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*ptr = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace unimportant_returning_value_note
|
|
|
|
|
|
|
|
namespace important_returning_value_note {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
bool flipCoin() {
|
|
|
|
if (coin()) // tracking-note{{Assuming the condition is false}}
|
|
|
|
// tracking-note@-1{{Taking false branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'coin()'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
return true;
|
|
|
|
return coin(); // tracking-note{{Returning value}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void i(int *ptr) {
|
|
|
|
if (ptr) // expected-note{{Assuming 'ptr' is null}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
;
|
|
|
|
if (!flipCoin())
|
|
|
|
// tracking-note@-1{{Calling 'flipCoin'}}
|
|
|
|
// tracking-note@-2{{Returning from 'flipCoin'}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-3{{Tracking condition '!flipCoin()'}}
|
|
|
|
// expected-note@-4{{Assuming the condition is true}}
|
|
|
|
// expected-note@-5{{Taking true branch}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*ptr = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace important_returning_value_note
|
|
|
|
|
2019-08-14 07:22:33 +08:00
|
|
|
namespace important_returning_value_note_in_linear_function {
|
|
|
|
bool coin();
|
|
|
|
|
|
|
|
struct super_complicated_template_hackery {
|
|
|
|
static constexpr bool value = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
bool flipCoin() {
|
|
|
|
if (super_complicated_template_hackery::value)
|
|
|
|
// tracking-note@-1{{'value' is false}}
|
|
|
|
// tracking-note@-2{{Taking false branch}}
|
|
|
|
return true;
|
|
|
|
return coin(); // tracking-note{{Returning value}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void i(int *ptr) {
|
|
|
|
if (ptr) // expected-note{{Assuming 'ptr' is null}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
;
|
|
|
|
if (!flipCoin())
|
|
|
|
// tracking-note@-1{{Calling 'flipCoin'}}
|
|
|
|
// tracking-note@-2{{Returning from 'flipCoin'}}
|
|
|
|
// debug-note@-3{{Tracking condition '!flipCoin()'}}
|
|
|
|
// expected-note@-4{{Assuming the condition is true}}
|
|
|
|
// expected-note@-5{{Taking true branch}}
|
|
|
|
*ptr = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace important_returning_value_note_in_linear_function
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
namespace tracked_condition_is_only_initialized {
|
|
|
|
int getInt();
|
|
|
|
|
|
|
|
void f() {
|
2019-08-14 17:39:38 +08:00
|
|
|
int flag = getInt();
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
if (flag) // expected-note{{Assuming 'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace tracked_condition_is_only_initialized
|
|
|
|
|
|
|
|
namespace tracked_condition_written_in_same_stackframe {
|
|
|
|
int flag;
|
|
|
|
int getInt();
|
|
|
|
|
|
|
|
void f(int y) {
|
2019-08-14 17:39:38 +08:00
|
|
|
y = 1;
|
|
|
|
flag = y;
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
if (flag) // expected-note{{'flag' is 1}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace tracked_condition_written_in_same_stackframe
|
|
|
|
|
|
|
|
namespace tracked_condition_written_in_nested_stackframe {
|
|
|
|
int flag;
|
|
|
|
int getInt();
|
|
|
|
|
|
|
|
void foo() {
|
|
|
|
int y;
|
2019-08-14 17:39:38 +08:00
|
|
|
y = 1;
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
flag = y; // tracking-note{{The value 1 is assigned to 'flag'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void f(int y) {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
|
|
|
foo(); // tracking-note{{Calling 'foo'}}
|
|
|
|
// tracking-note@-1{{Returning from 'foo'}}
|
|
|
|
|
|
|
|
if (flag) // expected-note{{'flag' is 1}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace tracked_condition_written_in_nested_stackframe
|
|
|
|
|
2019-08-14 07:48:10 +08:00
|
|
|
namespace condition_written_in_nested_stackframe_before_assignment {
|
|
|
|
int flag = 0;
|
|
|
|
int getInt();
|
|
|
|
|
|
|
|
void foo() {
|
|
|
|
flag = getInt(); // tracking-note{{Value assigned to 'flag'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void f() {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
int y = 0;
|
|
|
|
|
2019-08-14 17:39:38 +08:00
|
|
|
foo(); // tracking-note{{Calling 'foo'}}
|
|
|
|
// tracking-note@-1{{Returning from 'foo'}}
|
|
|
|
y = flag;
|
2019-08-14 07:48:10 +08:00
|
|
|
|
|
|
|
if (y) // expected-note{{Assuming 'y' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
|
|
|
// debug-note@-2{{Tracking condition 'y'}}
|
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
} // end of namespace condition_written_in_nested_stackframe_before_assignment
|
|
|
|
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
namespace collapse_point_not_in_condition {
|
|
|
|
|
|
|
|
[[noreturn]] void halt();
|
|
|
|
|
|
|
|
void assert(int b) {
|
|
|
|
if (!b) // tracking-note{{Assuming 'b' is not equal to 0}}
|
|
|
|
// tracking-note@-1{{Taking false branch}}
|
|
|
|
halt();
|
|
|
|
}
|
|
|
|
|
|
|
|
void f(int flag) {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
|
|
|
assert(flag); // tracking-note{{Calling 'assert'}}
|
|
|
|
// tracking-note@-1{{Returning from 'assert'}}
|
|
|
|
|
|
|
|
if (flag) // expected-note{{'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end of namespace collapse_point_not_in_condition
|
|
|
|
|
|
|
|
namespace unimportant_write_before_collapse_point {
|
|
|
|
|
|
|
|
[[noreturn]] void halt();
|
|
|
|
|
|
|
|
void assert(int b) {
|
|
|
|
if (!b) // tracking-note{{Assuming 'b' is not equal to 0}}
|
|
|
|
// tracking-note@-1{{Taking false branch}}
|
|
|
|
halt();
|
|
|
|
}
|
|
|
|
int getInt();
|
|
|
|
|
|
|
|
void f(int flag) {
|
|
|
|
int *x = 0; // expected-note{{'x' initialized to a null pointer value}}
|
|
|
|
|
2019-08-14 17:39:38 +08:00
|
|
|
flag = getInt();
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
assert(flag); // tracking-note{{Calling 'assert'}}
|
|
|
|
// tracking-note@-1{{Returning from 'assert'}}
|
|
|
|
|
|
|
|
if (flag) // expected-note{{'flag' is not equal to 0}}
|
|
|
|
// expected-note@-1{{Taking true branch}}
|
2019-07-05 22:00:08 +08:00
|
|
|
// debug-note@-2{{Tracking condition 'flag'}}
|
[analyzer] Track terminator conditions on which a tracked expression depends
This patch is a major part of my GSoC project, aimed to improve the bug
reports of the analyzer.
TL;DR: Help the analyzer understand that some conditions are important,
and should be explained better. If an CFGBlock is a control dependency
of a block where an expression value is tracked, explain the condition
expression better by tracking it.
if (A) // let's explain why we believe A to be true
10 / x; // division by zero
This is an experimental feature, and can be enabled by the
off-by-default analyzer configuration "track-conditions".
In detail:
This idea was inspired by the program slicing algorithm. Essentially,
two things are used to produce a program slice (a subset of the program
relevant to a (statement, variable) pair): data and control
dependencies. The bug path (the linear path in the ExplodedGraph that leads
from the beginning of the analysis to the error node) enables to
analyzer to argue about data dependencies with relative ease.
Control dependencies are a different slice of the cake entirely.
Just because we reached a branch during symbolic execution, it
doesn't mean that that particular branch has any effect on whether the
bug would've occured. This means that we can't simply rely on the bug
path to gather control dependencies.
In previous patches, LLVM's IDFCalculator, which works on a control flow
graph rather than the ExplodedGraph was generalized to solve this issue.
We use this information to heuristically guess that the value of a tracked
expression depends greatly on it's control dependencies, and start
tracking them as well.
After plenty of evaluations this was seen as great idea, but still
lacking refinements (we should have different descriptions about a
conditions value), hence it's off-by-default.
Differential Revision: https://reviews.llvm.org/D62883
llvm-svn: 365207
2019-07-05 21:29:54 +08:00
|
|
|
*x = 5; // expected-warning{{Dereference of null pointer}}
|
|
|
|
// expected-note@-1{{Dereference of null pointer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end of namespace unimportant_write_before_collapse_point
|