2015-09-10 00:10:12 +02:00
|
|
|
/*
|
2018-06-19 10:02:17 +02:00
|
|
|
* Copyright (C) 2015-18 Freie Universität Berlin
|
2015-09-10 00:10:12 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup app_sniffer
|
|
|
|
* @brief Sniffer application based on the new network stack
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Sniffer application for RIOT
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2018-06-19 10:02:17 +02:00
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
2015-09-10 00:10:12 +02:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2018-06-19 10:02:17 +02:00
|
|
|
#include "fmt.h"
|
2015-09-10 00:10:12 +02:00
|
|
|
#include "thread.h"
|
2015-09-16 03:41:25 +02:00
|
|
|
#include "xtimer.h"
|
2015-09-10 00:10:12 +02:00
|
|
|
#include "shell.h"
|
|
|
|
#include "net/gnrc.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Buffer size used by the shell
|
|
|
|
*/
|
|
|
|
#define SHELL_BUFSIZE (64U)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Priority of the RAW dump thread
|
|
|
|
*/
|
|
|
|
#define RAWDUMP_PRIO (THREAD_PRIORITY_MAIN - 1)
|
|
|
|
|
2018-06-18 15:34:23 +02:00
|
|
|
/**
|
|
|
|
* @brief Message queue size of the RAW dump thread
|
|
|
|
*/
|
|
|
|
#define RAWDUMP_MSG_Q_SIZE (32U)
|
|
|
|
|
2015-09-10 00:10:12 +02:00
|
|
|
/**
|
|
|
|
* @brief Stack for the raw dump thread
|
|
|
|
*/
|
2018-06-19 10:55:19 +02:00
|
|
|
static char rawdmp_stack[THREAD_STACKSIZE_SMALL];
|
2015-09-10 00:10:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Make a raw dump of the given packet contents
|
|
|
|
*/
|
|
|
|
void dump_pkt(gnrc_pktsnip_t *pkt)
|
|
|
|
{
|
|
|
|
gnrc_pktsnip_t *snip = pkt;
|
2018-10-27 00:00:38 +02:00
|
|
|
uint8_t lqi = 0;
|
|
|
|
if (pkt->next) {
|
|
|
|
if (pkt->next->type == GNRC_NETTYPE_NETIF) {
|
|
|
|
gnrc_netif_hdr_t *netif_hdr = pkt->next->data;
|
|
|
|
lqi = netif_hdr->lqi;
|
|
|
|
pkt = gnrc_pktbuf_remove_snip(pkt, pkt->next);
|
|
|
|
}
|
|
|
|
}
|
2022-09-16 12:26:34 +02:00
|
|
|
uint64_t now = xtimer_now64();
|
2017-06-03 04:38:49 +02:00
|
|
|
|
2018-06-19 10:02:17 +02:00
|
|
|
print_str("rftest-rx --- len ");
|
|
|
|
print_u32_hex((uint32_t)gnrc_pkt_len(pkt));
|
|
|
|
print_str(" lqi ");
|
|
|
|
print_byte_hex(lqi);
|
|
|
|
print_str(" rx_time ");
|
2022-09-16 12:26:34 +02:00
|
|
|
print_u64_hex(now);
|
2018-06-19 10:02:17 +02:00
|
|
|
print_str("\n");
|
2015-09-10 00:10:12 +02:00
|
|
|
while (snip) {
|
|
|
|
for (size_t i = 0; i < snip->size; i++) {
|
2018-06-19 10:02:17 +02:00
|
|
|
print_byte_hex(((uint8_t *)(snip->data))[i]);
|
|
|
|
print_str(" ");
|
2015-09-10 00:10:12 +02:00
|
|
|
}
|
|
|
|
snip = snip->next;
|
|
|
|
}
|
2018-06-19 10:02:17 +02:00
|
|
|
print_str("\n\n");
|
2015-09-10 00:10:12 +02:00
|
|
|
|
|
|
|
gnrc_pktbuf_release(pkt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Event loop of the RAW dump thread
|
|
|
|
*
|
|
|
|
* @param[in] arg unused parameter
|
|
|
|
*/
|
|
|
|
void *rawdump(void *arg)
|
|
|
|
{
|
2018-06-18 15:34:23 +02:00
|
|
|
msg_t msg_q[RAWDUMP_MSG_Q_SIZE];
|
2015-09-10 00:10:12 +02:00
|
|
|
|
2018-06-18 15:34:23 +02:00
|
|
|
(void)arg;
|
|
|
|
msg_init_queue(msg_q, RAWDUMP_MSG_Q_SIZE);
|
2015-09-10 00:10:12 +02:00
|
|
|
while (1) {
|
2018-06-18 15:34:23 +02:00
|
|
|
msg_t msg;
|
2015-09-10 00:10:12 +02:00
|
|
|
|
2018-06-18 15:34:23 +02:00
|
|
|
msg_receive(&msg);
|
2015-09-10 00:10:12 +02:00
|
|
|
switch (msg.type) {
|
|
|
|
case GNRC_NETAPI_MSG_TYPE_RCV:
|
|
|
|
dump_pkt((gnrc_pktsnip_t *)msg.content.ptr);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
/* do nothing */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* never reached */
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maybe you are a golfer?!
|
|
|
|
*/
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
gnrc_netreg_entry_t dump;
|
|
|
|
|
|
|
|
puts("RIOT sniffer application");
|
|
|
|
|
|
|
|
/* start and register rawdump thread */
|
|
|
|
puts("Run the rawdump thread and register it");
|
2016-11-10 14:45:29 +01:00
|
|
|
dump.target.pid = thread_create(rawdmp_stack, sizeof(rawdmp_stack), RAWDUMP_PRIO,
|
2018-10-02 22:36:32 +02:00
|
|
|
THREAD_CREATE_STACKTEST, rawdump, NULL, "rawdump");
|
2015-09-10 00:10:12 +02:00
|
|
|
dump.demux_ctx = GNRC_NETREG_DEMUX_CTX_ALL;
|
|
|
|
gnrc_netreg_register(GNRC_NETTYPE_UNDEF, &dump);
|
|
|
|
|
|
|
|
/* start the shell */
|
|
|
|
puts("All ok, starting the shell now");
|
|
|
|
char line_buf[SHELL_DEFAULT_BUFSIZE];
|
|
|
|
shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|