fuzz-http.c 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * Copyright (C) 2023 Teluu Inc. (http://www.teluu.com)
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; either version 2 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  17. */
  18. #include <stdio.h>
  19. #include <stdint.h>
  20. #include <stdlib.h>
  21. #include <pjlib.h>
  22. #include <pjlib-util.h>
  23. #include "../../pjlib-util/src/pjlib-util/http_client.c"
  24. #define kMinInputLength 10
  25. #define kMaxInputLength 1024
  26. pj_pool_factory *mem;
  27. int http_parse(uint8_t *data, size_t Size) {
  28. int ret;
  29. pj_pool_t *pool;
  30. pj_size_t rem;
  31. pj_http_resp response;
  32. pool = pj_pool_create(mem, "http", 1000, 1000, NULL);
  33. ret = http_response_parse(pool, &response, data, Size, &rem);
  34. pj_pool_release(pool);
  35. return ret;
  36. }
  37. extern int
  38. LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size)
  39. {
  40. if (Size < kMinInputLength || Size > kMaxInputLength) {
  41. return 1;
  42. }
  43. int ret = 0;
  44. uint8_t *data;
  45. pj_caching_pool caching_pool;
  46. /* Add NULL byte */
  47. data = (uint8_t *)calloc((Size+1), sizeof(uint8_t));
  48. memcpy((void *)data, (void *)Data, Size);
  49. /* init Calls */
  50. pj_init();
  51. pj_caching_pool_init( &caching_pool, &pj_pool_factory_default_policy, 0);
  52. pj_log_set_level(0);
  53. mem = &caching_pool.factory;
  54. /* Call fuzzer */
  55. ret = http_parse(data, Size);
  56. free(data);
  57. pj_caching_pool_destroy(&caching_pool);
  58. return ret;
  59. }