12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- #include "fuzzer.h"
- #include "Zend/zend.h"
- #include "main/php_config.h"
- #include "main/php_main.h"
- #include <stdio.h>
- #include <stdint.h>
- #include <stdlib.h>
- #include "fuzzer-sapi.h"
- #include "ext/standard/php_var.h"
- int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
- unsigned char *orig_data = malloc(Size+1);
- memcpy(orig_data, Data, Size);
- orig_data[Size] = '\0';
- if (fuzzer_request_startup() == FAILURE) {
- return 0;
- }
- fuzzer_setup_dummy_frame();
- {
- const unsigned char *data = orig_data;
- zval result;
- ZVAL_UNDEF(&result);
- php_unserialize_data_t var_hash;
- PHP_VAR_UNSERIALIZE_INIT(var_hash);
- php_var_unserialize(&result, (const unsigned char **) &data, data + Size, &var_hash);
- PHP_VAR_UNSERIALIZE_DESTROY(var_hash);
- zval_ptr_dtor(&result);
- }
- free(orig_data);
- fuzzer_request_shutdown();
- return 0;
- }
- int LLVMFuzzerInitialize(int *argc, char ***argv) {
- fuzzer_init_php();
-
- return 0;
- }
|