/* * Copyright (C) 2015 Martine Lenders * * 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. */ /** * @{ * * @file */ #include #include #include "net/gnrc/netif.h" #include "net/gnrc/netif/hdr.h" void gnrc_netif_hdr_print(gnrc_netif_hdr_t *hdr) { char addr_str[GNRC_NETIF_HDR_L2ADDR_PRINT_LEN]; printf("if_pid: %u ", (unsigned) hdr->if_pid); printf("rssi: %d ", (signed) hdr->rssi); #if IS_USED(MODULE_GNRC_NETIF_TIMESTAMP) /* Only last 32 bits are printed due to printf from avg-libc doesn't support 64-bit values */ printf(" timestamp: %" PRIu32 ".%09" PRIu32 " ", (uint32_t)(hdr->timestamp / NS_PER_SEC), (uint32_t)(hdr->timestamp % NS_PER_SEC)); #endif printf("lqi: %u\n", (unsigned) hdr->lqi); printf("flags: "); if (hdr->flags) { if (hdr->flags & GNRC_NETIF_HDR_FLAGS_BROADCAST) { printf("BROADCAST "); } if (hdr->flags & GNRC_NETIF_HDR_FLAGS_MULTICAST) { printf("MULTICAST "); } #if IS_USED(MODULE_GNRC_NETIF_TIMESTAMP) if (hdr->flags & GNRC_NETIF_HDR_FLAGS_TIMESTAMP) { printf("TIMESTAMP "); } #endif puts(""); } else { puts("0x0"); } if (hdr->src_l2addr_len > 0) { printf("src_l2addr: %s\n", gnrc_netif_addr_to_str(gnrc_netif_hdr_get_src_addr(hdr), hdr->src_l2addr_len, addr_str)); } else { puts("src_l2addr: (nil)"); } if (hdr->dst_l2addr_len > 0) { printf("dst_l2addr: %s\n", gnrc_netif_addr_to_str(gnrc_netif_hdr_get_dst_addr(hdr), hdr->dst_l2addr_len, addr_str)); } else { puts("dst_l2addr: (nil)"); } } /** @} */