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.
41 lines
933 B
41 lines
933 B
4 years ago
|
/*
|
||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
|
*
|
||
|
* This source code is licensed under the MIT license found in the
|
||
|
* LICENSE file in the root directory of this source tree.
|
||
|
*/
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
void latent_use_after_free(int b, int* x) {
|
||
|
if (b) {
|
||
|
free(x);
|
||
|
}
|
||
|
*x = 42;
|
||
|
if (!b) {
|
||
|
// just to avoid memory leaks
|
||
|
free(x);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void manifest_use_after_free(int* x) { latent_use_after_free(1, x); }
|
||
|
|
||
|
// FN because it's flagged only as latent at the moment
|
||
|
void FN_nonlatent_use_after_free_bad(int b, int* x) {
|
||
|
// the branch is independent of the issue here, so we should report the issue
|
||
|
// in this function
|
||
|
if (b) {
|
||
|
}
|
||
|
free(x);
|
||
|
*x = 42;
|
||
|
}
|
||
|
|
||
|
// all latent issues that reach main are manifest, so this should be called
|
||
|
// "main_bad" but that would defeat the actual point :)
|
||
|
int main(int argc, char** argv) {
|
||
|
int* x = malloc(sizeof(int));
|
||
|
if (x) {
|
||
|
latent_use_after_free(argc, x);
|
||
|
}
|
||
|
}
|