1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/fuzzing/gnrc_tcp/main.c
2022-02-28 14:53:08 +01:00

111 lines
2.8 KiB
C

/*
* Copyright (C) 2019 Sören Tempel <tempel@uni-bremen.de>
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
#include <err.h>
#include <stdlib.h>
#include "thread.h"
#include "fuzzing.h"
#include "net/af.h"
#include "net/gnrc/tcp.h"
#include "net/gnrc/netreg.h"
#include "net/ipv6/addr.h"
#include "net/gnrc/pkt.h"
#define TCB_QUEUE_SIZE 1
#define ACCEPT_TIMEOUT_MS 60000
static uint32_t demux = GNRC_NETREG_DEMUX_CTX_ALL;
static gnrc_nettype_t ntype = GNRC_NETTYPE_TCP;
static gnrc_tcp_tcb_queue_t queue = GNRC_TCP_TCB_QUEUE_INIT;
static gnrc_tcp_tcb_t tcbs[TCB_QUEUE_SIZE];
static void *tcploop(void *arg)
{
mutex_t *tcpmtx = arg;
gnrc_tcp_ep_t ep;
if (gnrc_tcp_ep_from_str(&ep, "[" SERVER_ADDR "]")) {
errx(EXIT_FAILURE, "gnrc_tcp_ep_from_str failed");
}
ep.port = SERVER_PORT;
for (unsigned i = 0; i < TCB_QUEUE_SIZE; ++i) {
gnrc_tcp_tcb_init(&tcbs[i]);
}
mutex_unlock(tcpmtx);
int ret = gnrc_tcp_listen(&queue, tcbs, ARRAY_SIZE(tcbs), &ep);
if (ret) {
errx(EXIT_FAILURE, "gnrc_tcp_listen failed: %d\n", ret);
}
for (;;) {
gnrc_tcp_tcb_t *tcp = NULL;
ret = gnrc_tcp_accept(&queue, &tcp, ACCEPT_TIMEOUT_MS);
if (ret) {
errx(EXIT_FAILURE, "gnrc_tcp_accept failed: %d\n", ret);
}
}
/* Never reached but, for clean programming sake */
gnrc_tcp_stop_listen(&queue);
return NULL;
}
static void inittcp(void)
{
static char tcpthr[THREAD_STACKSIZE_DEFAULT];
static mutex_t tcpmtx = MUTEX_INIT_LOCKED;
kernel_pid_t pid;
pid = thread_create(tcpthr, sizeof(tcpthr), THREAD_PRIORITY_MAIN,
0, tcploop, &tcpmtx, "gnrc_tcp fuzzing");
if (pid < 0) {
errx(EXIT_FAILURE, "thread_create failed: %d\n", pid);
}
mutex_lock(&tcpmtx); /* wait until tcp is initialized */
}
void initialize(ipv6_addr_t *addr)
{
if (ipv6_addr_from_str(addr, SERVER_ADDR) == NULL) {
errx(EXIT_FAILURE, "ipv6_addr_from_str failed");
}
if (fuzzing_init(addr, SERVER_ADDR_PREFIX)) {
errx(EXIT_FAILURE, "fuzzing_init failed");
}
inittcp();
}
int main(void)
{
ipv6_addr_t myaddr;
gnrc_pktsnip_t *ipkt, *tpkt;
initialize(&myaddr);
if (!(ipkt = gnrc_ipv6_hdr_build(NULL, NULL, &myaddr))) {
errx(EXIT_FAILURE, "gnrc_ipv6_hdr_build failed");
}
if (!(tpkt = gnrc_pktbuf_add(ipkt, NULL, 0, GNRC_NETTYPE_TCP))) {
errx(EXIT_FAILURE, "gnrc_pktbuf_add failed");
}
if (fuzzing_read_packet(STDIN_FILENO, tpkt)) {
errx(EXIT_FAILURE, "fuzzing_read_packet failed");
}
if (!gnrc_netapi_dispatch_receive(ntype, demux, tpkt)) {
errx(EXIT_FAILURE, "couldn't find any subscriber");
}
return EXIT_SUCCESS;
}