File: sparse_fuzzer.cpp

package info (click to toggle)
android-platform-tools 35.0.2-1~exp6
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 211,716 kB
  • sloc: cpp: 995,749; java: 290,495; ansic: 145,647; xml: 58,531; python: 39,608; sh: 14,500; javascript: 5,198; asm: 4,866; makefile: 3,115; yacc: 769; awk: 368; ruby: 183; sql: 140; perl: 88; lex: 67
file content (29 lines) | stat: -rw-r--r-- 738 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include "include/sparse/sparse.h"

static volatile int count;

int WriteCallback(void* priv  __attribute__((__unused__)), const void* data, size_t len) {
  if (!data) {
    return 0;
  }
  if (len == 0) {
    return 0;
  }

  const char* p = (const char*)data;
  // Just to make sure the data is accessible
  // We only check the head and tail to save time
  count += *p;
  count += *(p+len-1);
  return 0;
}

extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
  struct sparse_file* file = sparse_file_import_buf((char*)data, size, true, false);
  if (!file) {
      return 0;
  }
  int32_t result = sparse_file_callback(file, false, false, WriteCallback, nullptr);
  sparse_file_destroy(file);
  return result;
}