/* * Copyright (C) 2015 Freie Universität Berlin * * 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. */ /** * @ingroup net_pktdump * @{ * * @file * @brief Generic module to dump packages received via netapi to STDOUT * * @author Hauke Petersen * * @} */ #include #include #include #include "byteorder.h" #include "thread.h" #include "msg.h" #include "kernel.h" #include "net/ng_pktdump.h" #include "net/ng_netbase.h" #include "net/ipv6/addr.h" #include "net/ipv6/hdr.h" #include "net/ng_sixlowpan.h" #include "net/udp.h" #include "od.h" /** * @brief PID of the pktdump thread */ static kernel_pid_t _pid = KERNEL_PID_UNDEF; /** * @brief Stack for the pktdump thread */ static char _stack[NG_PKTDUMP_STACKSIZE]; static void _dump_snip(ng_pktsnip_t *pkt) { switch (pkt->type) { case NG_NETTYPE_UNDEF: printf("NETTYPE_UNDEF (%i)\n", pkt->type); od_hex_dump(pkt->data, pkt->size, OD_WIDTH_DEFAULT); break; #ifdef MODULE_NG_NETIF case NG_NETTYPE_NETIF: printf("NETTYPE_NETIF (%i)\n", pkt->type); ng_netif_hdr_print(pkt->data); break; #endif #ifdef MODULE_NG_SIXLOWPAN case NG_NETTYPE_SIXLOWPAN: printf("NETTYPE_SIXLOWPAN (%i)\n", pkt->type); ng_sixlowpan_print(pkt->data, pkt->size); break; #endif #ifdef MODULE_NG_IPV6 case NG_NETTYPE_IPV6: printf("NETTYPE_IPV6 (%i)\n", pkt->type); ipv6_hdr_print(pkt->data); break; #endif #ifdef MODULE_NG_ICMPV6 case NG_NETTYPE_ICMPV6: printf("NETTYPE_ICMPV6 (%i)\n", pkt->type); break; #endif #ifdef MODULE_NG_TCP case NG_NETTYPE_TCP: printf("NETTYPE_TCP (%i)\n", pkt->type); break; #endif #ifdef MODULE_NG_UDP case NG_NETTYPE_UDP: printf("NETTYPE_UDP (%i)\n", pkt->type); udp_hdr_print(pkt->data); break; #endif #ifdef TEST_SUITES case NG_NETTYPE_TEST: printf("NETTYPE_TEST (%i)\n", pkt->type); od_hex_dump(pkt->data, pkt->size, OD_WIDTH_DEFAULT); break; #endif default: printf("NETTYPE_UNKNOWN (%i)\n", pkt->type); od_hex_dump(pkt->data, pkt->size, OD_WIDTH_DEFAULT); break; } } static void _dump(ng_pktsnip_t *pkt) { int snips = 0; int size = 0; ng_pktsnip_t *snip = pkt; while (snip != NULL) { printf("~~ SNIP %2i - size: %3u byte, type: ", snips, (unsigned int)snip->size); _dump_snip(snip); ++snips; size += snip->size; snip = snip->next; } printf("~~ PKT - %2i snips, total size: %3i byte\n", snips, size); ng_pktbuf_release(pkt); } static void *_eventloop(void *arg) { (void)arg; msg_t msg, reply; msg_t msg_queue[NG_PKTDUMP_MSG_QUEUE_SIZE]; /* setup the message queue */ msg_init_queue(msg_queue, NG_PKTDUMP_MSG_QUEUE_SIZE); reply.content.value = (uint32_t)(-ENOTSUP); reply.type = NG_NETAPI_MSG_TYPE_ACK; while (1) { msg_receive(&msg); switch (msg.type) { case NG_NETAPI_MSG_TYPE_RCV: puts("PKTDUMP: data received:"); _dump((ng_pktsnip_t *)msg.content.ptr); break; case NG_NETAPI_MSG_TYPE_SND: puts("PKTDUMP: data to send:"); _dump((ng_pktsnip_t *)msg.content.ptr); break; case NG_NETAPI_MSG_TYPE_GET: case NG_NETAPI_MSG_TYPE_SET: msg_reply(&msg, &reply); break; default: puts("PKTDUMP: received something unexpected"); break; } } /* never reached */ return NULL; } kernel_pid_t ng_pktdump_getpid(void) { return _pid; } kernel_pid_t ng_pktdump_init(void) { if (_pid == KERNEL_PID_UNDEF) { _pid = thread_create(_stack, sizeof(_stack), NG_PKTDUMP_PRIO, CREATE_STACKTEST, _eventloop, NULL, "pktdump"); } return _pid; }