toxcore/testing/fuzzing/fuzz_adapter.h
sudden6 7dd8dbd897
intercept network, crypto and time
This fuzzing harness must be as deterministic as possible for the fuzzer
to detect additional coverage reliably.
2022-01-10 21:05:49 +01:00

49 lines
1.4 KiB
C

/* SPDX-License-Identifier: GPL-3.0-or-later
* Copyright © 2021 The TokTok team.
*/
#ifndef C_TOXCORE_TESTING_FUZZING_FUZZ_ADAPTER_H
#define C_TOXCORE_TESTING_FUZZING_FUZZ_ADAPTER_H
#include <stdint.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Init function for the fuzzing harness
* @param buf Begin of fuzz data
* @param length Length of buf
*/
void network_adapter_init(const uint8_t *buf, size_t length);
/* The following functions intercept calls to standard network functions for fuzzing purposes and return data from the fuzz buffer. */
ssize_t fuzz_sendto(int sockfd, const void *buf, size_t len,
int flags, const struct sockaddr *addr,
socklen_t addrlen);
ssize_t fuzz_send(int sockfd, const void *buf, size_t len, int flags);
ssize_t fuzz_recvfrom(int sockfd, void *buf, size_t len,
int flags, struct sockaddr *src_addr,
socklen_t *addr_len);
ssize_t fuzz_recv(int sockfd, void *buf, size_t len, int flags);
/* The following functions intercept generation of random data */
void fuzz_random_bytes(uint8_t *rnd, size_t length);
/* The following function replaces all time bases with a monotonic counter */
uint64_t fuzz_get_count(void);
#ifdef __cplusplus
}
#endif
#endif // C_TOXCORE_TESTING_FUZZING_FUZZ_ADAPTER_H