diff options
author | Cory Barker <cobark@google.com> | 2022-06-30 19:56:47 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2022-06-30 19:56:47 +0000 |
commit | 3cdf346579adc9751acb7fb28bb0e1f56db98f91 (patch) | |
tree | 2db9ca57cd1f0315199ba9a28933f62c7f4ee0a9 /test-instr.c | |
parent | d94a43ad0c3cc20b78a9d49798f9f90ccd5feb7d (diff) | |
parent | e3b7c39c0037458d68bf9f374bf3812fd6f7edf4 (diff) | |
download | AFLplusplus-3cdf346579adc9751acb7fb28bb0e1f56db98f91.tar.gz |
Merge remote-tracking branch upstream-stable am: 847ac56921 am: 1f1113e9e4 am: 6a557435e5 am: e3b7c39c00
Original change: https://android-review.googlesource.com/c/platform/external/AFLplusplus/+/2133182
Change-Id: Ibbfe3396138a41b3ddb9547ea0e098d7615bfe88
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'test-instr.c')
-rw-r--r-- | test-instr.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/test-instr.c b/test-instr.c new file mode 100644 index 00000000..b2caa1fe --- /dev/null +++ b/test-instr.c @@ -0,0 +1,71 @@ +/* + american fuzzy lop++ - a trivial program to test the build + -------------------------------------------------------- + Originally written by Michal Zalewski + Copyright 2014 Google Inc. All rights reserved. + Copyright 2019-2022 AFLplusplus Project. All rights reserved. + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at: + https://www.apache.org/licenses/LICENSE-2.0 + */ + +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <string.h> +#include <sys/types.h> +#include <sys/stat.h> +#include <fcntl.h> + +#ifdef TEST_SHARED_OBJECT + #define main main_exported +#endif + +int main(int argc, char **argv) { + + int fd = 0; + char buff[8]; + char *buf = buff; + + // we support command line parameter and stdin + if (argc == 2) { + + buf = argv[1]; + printf("Input %s - ", buf); + + } else { + + if (argc >= 3 && strcmp(argv[1], "-f") == 0) { + + if ((fd = open(argv[2], O_RDONLY)) < 0) { + + fprintf(stderr, "Error: unable to open %s\n", argv[2]); + exit(-1); + + } + + } + + if (read(fd, buf, sizeof(buf)) < 1) { + + printf("Hum?\n"); + return 1; + + } + + } + + // we support three input cases (plus a 4th if stdin is used but there is no + // input) + if (buf[0] == '0') + printf("Looks like a zero to me!\n"); + else if (buf[0] == '1') + printf("Pretty sure that is a one!\n"); + else + printf("Neither one or zero? How quaint!\n"); + + return 0; + +} + |