Summary: This is a compiler-rt part. The clang part is D48958. See [[ https://bugs.llvm.org/show_bug.cgi?id=21530 | PR21530 ]], https://github.com/google/sanitizers/issues/940. Reviewers: #sanitizers, samsonov, vsk, rsmith, pcc, eugenis, kcc, filcab Reviewed By: #sanitizers, vsk, filcab Subscribers: llvm-commits, eugenis, filcab, kubamracek, dberris, #sanitizers, regehr Tags: #sanitizers Differential Revision: https://reviews.llvm.org/D48959 llvm-svn: 338287
28 lines
650 B
C++
28 lines
650 B
C++
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
// Test for signed-integer-overflow.
|
|
#include <assert.h>
|
|
#include <climits>
|
|
#include <cstddef>
|
|
#include <cstdint>
|
|
#include <cstdlib>
|
|
#include <iostream>
|
|
|
|
static volatile int Sink;
|
|
static unsigned char Large = UINT8_MAX;
|
|
|
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
|
|
assert(Data);
|
|
if (Size > 0 && Data[0] == 'H') {
|
|
Sink = 1;
|
|
if (Size > 1 && Data[1] == 'i') {
|
|
Sink = 2;
|
|
if (Size > 2 && Data[2] == '!') {
|
|
Large = Large + 1; // 'char overflow'.
|
|
}
|
|
}
|
|
}
|
|
return 0;
|
|
}
|