blob: 8e4c9088d8097b081f26426521f8ce0f90579d2e [file] [log] [blame]
/*
*
* honggfuzz - core structures and macros
* -----------------------------------------
*
* Author: Robert Swiecki <swiecki@google.com>
*
* Copyright 2010-2015 by Google Inc. 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
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*
*/
#ifndef _COMMON_H_
#define _COMMON_H_
#include <limits.h>
#include <pthread.h>
#include <semaphore.h>
#include <stdbool.h>
#include <stdint.h>
#include <sys/param.h>
#include <sys/types.h>
#define PROG_NAME "honggfuzz"
#define PROG_VERSION "0.4"
#define PROG_AUTHORS "Robert Swiecki <swiecki@google.com> and others, Copyright 2010-2015 by Google Inc. All Rights Reserved."
/* Name of the template which will be replaced with the proper name of the file */
#define _HF_FILE_PLACEHOLDER "___FILE___"
/* Default name of the report created with some architectures */
#define _HF_REPORT_FILE "HONGGFUZZ.REPORT.TXT"
/* Default stack-size of created threads. Must be bigger then _HF_DYNAMIC_FILE_MAX_SZ */
#define _HF_PTHREAD_STACKSIZE (1024 * 1024 * 4) /* 4MB */
/* Align to the upper-page boundary */
#define _HF_PAGE_ALIGN_UP(x) (((size_t)x + (size_t)sysconf(_SC_PAGESIZE) - 1) & ~((size_t)sysconf(_SC_PAGESIZE) - 1))
typedef enum {
_HF_DYNFILE_NONE = 0,
_HF_DYNFILE_INSTR_COUNT,
_HF_DYNFILE_BRANCH_COUNT,
_HF_DYNFILE_UNIQUE_PC_COUNT,
} dynFileMethod_t;
typedef struct {
char **cmdline;
char *inputFile;
bool nullifyStdio;
bool fuzzStdin;
bool saveUnique;
char *fileExtn;
double flipRate;
char *externalCommand;
long tmOut;
long mutationsMax;
long mutationsCnt;
long threadsMax;
size_t maxFileSz;
void *ignoreAddr;
char *reportFile;
unsigned long asLimit;
char **files;
int fileCnt;
sem_t *sem;
int pid;
/* For the linux/ code */
uint8_t *dynamicFileBest;
size_t dynamicFileBestSz;
dynFileMethod_t dynFileMethod;
int64_t branchBestCnt;
pthread_mutex_t dynamicFile_mutex;
} honggfuzz_t;
typedef struct fuzzer_t {
pid_t pid;
time_t timeStarted;
char origFileName[PATH_MAX];
char fileName[PATH_MAX];
uint64_t pc;
uint64_t backtrace;
uint64_t access;
int exception;
char report[8192];
/* For linux/ code */
uint8_t *dynamicFile;
int64_t branchCnt;
size_t dynamicFileSz;
} fuzzer_t;
#define _HF_MAX_FUNCS 200
typedef struct {
void *pc;
char func[64];
int line;
} funcs_t;
#define ARRAYSIZE(x) (sizeof(x) / sizeof(*x))
#endif