forked from OSchip/llvm-project
[analyzer] Catch the first taint propagation implied buffer overflow.
Change the ArrayBoundCheckerV2 to be more aggressive in reporting buffer overflows when the offset is tainted. Previously, we did not report bugs when the state was underconstrained (not enough information about the bound to determine if there is an overflow) to avoid false positives. However, if we know that the buffer offset is tainted - comes in from the user space and can be anything, we should report it as a bug. + The very first example of us catching a taint related bug. This is the only example we can currently handle. More to come... llvm-svn: 144826
This commit is contained in:
parent
5c5bf9b634
commit
20829c90be
|
@ -153,9 +153,17 @@ void ArrayBoundCheckerV2::checkLocation(SVal location, bool isLoad,
|
|||
const ProgramState *state_exceedsUpperBound, *state_withinUpperBound;
|
||||
llvm::tie(state_exceedsUpperBound, state_withinUpperBound) =
|
||||
state->assume(*upperboundToCheck);
|
||||
|
||||
// If we are under constrained and the index variables are tainted, report.
|
||||
if (state_exceedsUpperBound && state_withinUpperBound) {
|
||||
if (state->isTainted(rawOffset.getByteOffset()))
|
||||
reportOOB(checkerContext, state_exceedsUpperBound, OOB_Excedes);
|
||||
return;
|
||||
}
|
||||
|
||||
// Are we constrained enough to definitely exceed the upper bound?
|
||||
if (state_exceedsUpperBound && !state_withinUpperBound) {
|
||||
// If we are constrained enough to definitely exceed the upper bound, report.
|
||||
if (state_exceedsUpperBound) {
|
||||
assert(!state_withinUpperBound);
|
||||
reportOOB(checkerContext, state_exceedsUpperBound, OOB_Excedes);
|
||||
return;
|
||||
}
|
||||
|
@ -277,9 +285,9 @@ RegionRawOffsetV2 RegionRawOffsetV2::computeOffset(const ProgramState *state,
|
|||
offset = addValue(state,
|
||||
getValue(offset, svalBuilder),
|
||||
scaleValue(state,
|
||||
cast<NonLoc>(index),
|
||||
astContext.getTypeSizeInChars(elemType),
|
||||
svalBuilder),
|
||||
cast<NonLoc>(index),
|
||||
astContext.getTypeSizeInChars(elemType),
|
||||
svalBuilder),
|
||||
svalBuilder);
|
||||
|
||||
if (offset.isUnknownOrUndef())
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
// RUN: %clang_cc1 -analyze -analyzer-checker=experimental.security.taint,experimental.security.ArrayBoundV2 -verify %s
|
||||
|
||||
int scanf(const char *restrict format, ...);
|
||||
int getchar(void);
|
||||
|
||||
#define BUFSIZE 10
|
||||
|
||||
int Buffer[BUFSIZE];
|
||||
void bufferFoo1(void)
|
||||
{
|
||||
int n;
|
||||
scanf("%d", &n);
|
||||
Buffer[n] = 1; // expected-warning {{Out of bound memory access }}
|
||||
}
|
Loading…
Reference in New Issue