123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #include "fuzzer.h"
- #include "Zend/zend.h"
- #include "main/php_config.h"
- #include "main/php_main.h"
- #include "oniguruma.h"
- #include <stdio.h>
- #include <stdint.h>
- #include <stdlib.h>
- #include "fuzzer-sapi.h"
- int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
- #ifdef HAVE_MBREGEX
- char *args[2];
- char *data = malloc(Size+1);
- memcpy(data, Data, Size);
- data[Size] = '\0';
- if (fuzzer_request_startup() == FAILURE) {
- return 0;
- }
- fuzzer_setup_dummy_frame();
- args[0] = data;
- args[1] = "test123";
- fuzzer_call_php_func("mb_ereg", 2, args);
- args[0] = data;
- args[1] = "test123";
- fuzzer_call_php_func("mb_eregi", 2, args);
- args[0] = data;
- args[1] = data;
- fuzzer_call_php_func("mb_ereg", 2, args);
- args[0] = data;
- args[1] = data;
- fuzzer_call_php_func("mb_eregi", 2, args);
- fuzzer_request_shutdown();
- free(data);
- #else
- fprintf(stderr, "\n\nERROR:\nPHP built without mbstring, recompile with --enable-mbstring to use this fuzzer\n");
- exit(1);
- #endif
- return 0;
- }
- int LLVMFuzzerInitialize(int *argc, char ***argv) {
- fuzzer_init_php();
-
- onig_set_parse_depth_limit(512);
-
- return 0;
- }
|