You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

286 lines
4.1 KiB

/*
* Copyright (c) 2017-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#include <stdio.h>
#include <stdlib.h>
void exit_bo_good_unreachable_bad() {
int arr[1];
exit(1);
// unreachable so no buffer overrun
arr[42] = 42;
}
void fgetc_m1_bad(FILE* f) {
int arr[10000];
int c = fgetc(f);
arr[c] = 42;
}
void fgetc_255_bad(FILE* f) {
int arr[255];
int c = fgetc(f);
if (c >= 0) {
arr[c] = 42;
}
}
void fgetc_256_good(FILE* f) {
int arr[256];
int c = fgetc(f);
if (c >= 0) {
arr[c] = 42;
}
}
void fgetc_256_bad(FILE* f) {
int arr[256];
int c = fgetc(f);
arr[c + 1] = 42;
}
void fgetc_257_good(FILE* f) {
int arr[257];
int c = fgetc(f);
arr[c + 1] = 42;
}
void memcpy_bad1() {
int arr1[10];
int arr2[20];
memcpy(arr1, arr2, 44);
}
void memcpy_bad2() {
int arr1[10];
int arr2[20];
memcpy(arr2, arr1, 44);
}
void memcpy_bad3() {
int arr1[10];
int arr2[20];
memcpy(arr1, arr2, -1);
}
void memcpy_bad4() {
int src[1];
int buff[1];
int* dst = &buff[0];
memcpy(dst, src, sizeof(dst));
}
void memcpy_good1() {
int arr1[10];
int arr2[20];
memcpy(arr2, arr1, 40);
}
void memcpy_good2() {
int arr1[10];
int arr2[20];
memcpy(arr2, arr1, 0);
}
void memcpy_good3() {
int arr1[10];
int arr2[20];
memcpy(arr2, arr1, 20);
}
void memcpy_good4() {
int src[3];
int dst[3];
memcpy(dst, src, sizeof(dst));
}
void memcpy_len_Good(size_t len) {
char dst[len];
char src[len];
memcpy(dst, src, len);
}
void call_memcpy_len1_Good() { memcpy_len_Good(40); }
extern size_t unknown_uint();
void call_memcpy_len2_Good() {
size_t x = unknown();
memcpy_len_Good(x);
}
void memmove_bad1() {
int arr1[10];
int arr2[20];
memmove(arr1, arr2, 44);
}
void memmove_bad2() {
int arr1[10];
int arr2[20];
memmove(arr2, arr1, 44);
}
void memmove_bad3() {
int arr1[10];
int arr2[20];
memmove(arr1, arr2, -1);
}
void memmove_bad4() {
int src[1];
int buff[1];
int* dst = &buff[0];
memmove(dst, src, sizeof(dst));
}
void memmove_good1() {
int arr1[10];
int arr2[20];
memmove(arr2, arr1, 40);
}
void memmove_good2() {
int arr1[10];
int arr2[20];
memmove(arr2, arr1, 0);
}
void memmove_good3() {
int arr1[10];
int arr2[20];
memmove(arr2, arr1, 20);
}
void memmove_good4() {
int src[3];
int dst[3];
memmove(dst, src, sizeof(dst));
}
void memset_bad1() {
int arr[10];
memset(arr, 0, 44);
}
void memset_bad2() {
int arr[10];
memset(arr, 0, -1);
}
void memset_bad3() {
int arr[1];
int* dst = &arr[0];
memset(dst, 0, sizeof(dst));
}
void memset_good1() {
int arr[10];
memset(arr, 0, 40);
}
void memset_good2() {
int arr[10];
memset(arr, 0, 0);
}
void memset_good3() {
int arr[10];
memset(arr, 0, 20);
}
void memset_good4() {
int arr[10];
memset(arr, 0, sizeof(arr));
}
void strncpy_bad1() {
int arr1[10];
int arr2[20];
strncpy(arr1, arr2, 44);
}
void strncpy_bad2() {
int arr1[10];
int arr2[20];
strncpy(arr2, arr1, 44);
}
void strncpy_bad3() {
int arr1[10];
int arr2[20];
strncpy(arr1, arr2, -1);
}
void strncpy_bad4() {
int src[1];
int buff[1];
int* dst = &buff[0];
strncpy(dst, src, sizeof(dst));
}
void strncpy_good1() {
int arr1[10];
int arr2[20];
strncpy(arr2, arr1, 40);
}
void strncpy_good2() {
int arr1[10];
int arr2[20];
strncpy(arr2, arr1, 0);
}
void strncpy_good3() {
int arr1[10];
int arr2[20];
strncpy(arr2, arr1, 20);
}
void strncpy_good4() {
int src[3];
int dst[3];
strncpy(dst, src, sizeof(dst));
}
void strncpy_good5_FP() {
char src[5] = "test";
char dst[5];
strncpy(dst, src, 10);
}
void memcpy_contents_Good() {
int src[3] = {5, 5, 5};
int dst[3];
memcpy(dst, src, sizeof(dst));
int a[6];
a[dst[0]] = 0;
}
void memcpy_contents_Bad() {
int src[3] = {5, 5, 5};
int dst[3];
memcpy(dst, src, sizeof(dst));
int a[5];
a[dst[0]] = 0;
}
void memcpy_integer_Good() {
int src = 5;
int dst;
memcpy(&dst, &src, sizeof(int));
int a[10];
a[dst] = 0;
}
void memcpy_integer_Bad() {
int src = 5;
int dst;
memcpy(&dst, &src, sizeof(int));
int a[5];
a[dst] = 0;
}