mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #10661 from miri64/gnrc_netif_hdr/enh/netif_setter
gnrc_netif_hdr: add setter for netif
This commit is contained in:
commit
b87ab96d17
@ -173,7 +173,7 @@ static gnrc_pktsnip_t *_recv(gnrc_netif_t *netif)
|
|||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
((gnrc_netif_hdr_t *)netif_hdr->data)->if_pid = netif->pid;
|
gnrc_netif_hdr_set_netif((gnrc_netif_hdr_t *)netif_hdr->data, netif);
|
||||||
|
|
||||||
uint8_t *mac = mac_hdr->data;
|
uint8_t *mac = mac_hdr->data;
|
||||||
DEBUG("gnrc_esp_now: received packet from %02x:%02x:%02x:%02x:%02x:%02x of length %u\n",
|
DEBUG("gnrc_esp_now: received packet from %02x:%02x:%02x:%02x:%02x:%02x of length %u\n",
|
||||||
|
@ -162,7 +162,7 @@ static gnrc_pktsnip_t *gnrc_nrfmin_recv(gnrc_netif_t *dev)
|
|||||||
}
|
}
|
||||||
netif->lqi = 0;
|
netif->lqi = 0;
|
||||||
netif->rssi = 0;
|
netif->rssi = 0;
|
||||||
netif->if_pid = dev->pid;
|
gnrc_netif_hdr_set_netif(netif, dev);
|
||||||
pkt_snip->type = nrfmin->proto;
|
pkt_snip->type = nrfmin->proto;
|
||||||
|
|
||||||
/* finally: remove the nrfmin header and append the netif header */
|
/* finally: remove the nrfmin header and append the netif header */
|
||||||
|
@ -86,7 +86,7 @@ static gnrc_pktsnip_t *xbee_adpt_recv(gnrc_netif_t *netif)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
netif_hdr = (gnrc_netif_hdr_t *)netif_snip->data;
|
netif_hdr = (gnrc_netif_hdr_t *)netif_snip->data;
|
||||||
netif_hdr->if_pid = netif->pid;
|
gnrc_netif_hdr_set_netif(netif_hdr, netif);
|
||||||
netif_hdr->rssi = l2hdr.rssi;
|
netif_hdr->rssi = l2hdr.rssi;
|
||||||
if (l2hdr.bcast) {
|
if (l2hdr.bcast) {
|
||||||
netif_hdr->flags = GNRC_NETIF_HDR_FLAGS_BROADCAST;
|
netif_hdr->flags = GNRC_NETIF_HDR_FLAGS_BROADCAST;
|
||||||
|
@ -39,6 +39,7 @@ static gnrc_netreg_entry_t server = GNRC_NETREG_ENTRY_INIT_PID(GNRC_NETREG_DEMUX
|
|||||||
static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
||||||
unsigned int delay)
|
unsigned int delay)
|
||||||
{
|
{
|
||||||
|
gnrc_netif_t *netif;
|
||||||
int iface;
|
int iface;
|
||||||
uint16_t port;
|
uint16_t port;
|
||||||
ipv6_addr_t addr;
|
ipv6_addr_t addr;
|
||||||
@ -46,7 +47,10 @@ static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
|||||||
/* get interface, if available */
|
/* get interface, if available */
|
||||||
iface = ipv6_addr_split_iface(addr_str);
|
iface = ipv6_addr_split_iface(addr_str);
|
||||||
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
||||||
iface = gnrc_netif_iter(NULL)->pid;
|
netif = gnrc_netif_iter(NULL);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
netif = gnrc_netif_get_by_pid(iface);
|
||||||
}
|
}
|
||||||
/* parse destination address */
|
/* parse destination address */
|
||||||
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
||||||
@ -86,11 +90,11 @@ static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* add netif header, if interface was given */
|
/* add netif header, if interface was given */
|
||||||
if (iface > 0) {
|
if (netif != NULL) {
|
||||||
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
gnrc_pktsnip_t *netif_hdr = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||||||
|
|
||||||
((gnrc_netif_hdr_t *)netif->data)->if_pid = (kernel_pid_t)iface;
|
gnrc_netif_hdr_set_netif(netif_hdr->data, netif);
|
||||||
LL_PREPEND(ip, netif);
|
LL_PREPEND(ip, netif_hdr);
|
||||||
}
|
}
|
||||||
/* send packet */
|
/* send packet */
|
||||||
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2015 Freie Universität Berlin
|
* Copyright (C) 2015-17 Freie Universität Berlin
|
||||||
*
|
*
|
||||||
* This file is subject to the terms and conditions of the GNU Lesser
|
* 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
|
* General Public License v2.1. See the file LICENSE in the top level
|
||||||
@ -14,6 +14,7 @@
|
|||||||
* @brief Demonstrating the sending and receiving of UDP data
|
* @brief Demonstrating the sending and receiving of UDP data
|
||||||
*
|
*
|
||||||
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
||||||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||||||
*
|
*
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
@ -38,6 +39,7 @@ static gnrc_netreg_entry_t server = GNRC_NETREG_ENTRY_INIT_PID(GNRC_NETREG_DEMUX
|
|||||||
static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
||||||
unsigned int delay)
|
unsigned int delay)
|
||||||
{
|
{
|
||||||
|
gnrc_netif_t *netif;
|
||||||
int iface;
|
int iface;
|
||||||
uint16_t port;
|
uint16_t port;
|
||||||
ipv6_addr_t addr;
|
ipv6_addr_t addr;
|
||||||
@ -45,7 +47,10 @@ static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
|||||||
/* get interface, if available */
|
/* get interface, if available */
|
||||||
iface = ipv6_addr_split_iface(addr_str);
|
iface = ipv6_addr_split_iface(addr_str);
|
||||||
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
||||||
iface = gnrc_netif_iter(NULL)->pid;
|
netif = gnrc_netif_iter(NULL);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
netif = gnrc_netif_get_by_pid(iface);
|
||||||
}
|
}
|
||||||
/* parse destination address */
|
/* parse destination address */
|
||||||
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
||||||
@ -53,7 +58,7 @@ static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* parse port */
|
/* parse port */
|
||||||
port = (uint16_t)atoi(port_str);
|
port = atoi(port_str);
|
||||||
if (port == 0) {
|
if (port == 0) {
|
||||||
puts("Error: unable to parse destination port");
|
puts("Error: unable to parse destination port");
|
||||||
return;
|
return;
|
||||||
@ -85,11 +90,11 @@ static void send(char *addr_str, char *port_str, char *data, unsigned int num,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* add netif header, if interface was given */
|
/* add netif header, if interface was given */
|
||||||
if (iface > 0) {
|
if (netif != NULL) {
|
||||||
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
gnrc_pktsnip_t *netif_hdr = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||||||
|
|
||||||
((gnrc_netif_hdr_t *)netif->data)->if_pid = (kernel_pid_t)iface;
|
gnrc_netif_hdr_set_netif(netif_hdr->data, netif);
|
||||||
LL_PREPEND(ip, netif);
|
LL_PREPEND(ip, netif_hdr);
|
||||||
}
|
}
|
||||||
/* send packet */
|
/* send packet */
|
||||||
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
||||||
@ -116,7 +121,7 @@ static void start_server(char *port_str)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* parse port */
|
/* parse port */
|
||||||
port = (uint16_t)atoi(port_str);
|
port = atoi(port_str);
|
||||||
if (port == 0) {
|
if (port == 0) {
|
||||||
puts("Error: invalid port specified");
|
puts("Error: invalid port specified");
|
||||||
return;
|
return;
|
||||||
@ -157,10 +162,10 @@ int udp_cmd(int argc, char **argv)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (argc > 5) {
|
if (argc > 5) {
|
||||||
num = (uint32_t)atoi(argv[5]);
|
num = atoi(argv[5]);
|
||||||
}
|
}
|
||||||
if (argc > 6) {
|
if (argc > 6) {
|
||||||
delay = (uint32_t)atoi(argv[6]);
|
delay = atoi(argv[6]);
|
||||||
}
|
}
|
||||||
send(argv[2], argv[3], argv[4], num, delay);
|
send(argv[2], argv[3], argv[4], num, delay);
|
||||||
}
|
}
|
||||||
|
@ -108,7 +108,7 @@ static void _handle_raw_sixlowpan(ble_mac_inbuf_t *inbuf)
|
|||||||
gnrc_netif_hdr_init(netif_hdr->data, BLE_L2_ADDR_LEN, BLE_L2_ADDR_LEN);
|
gnrc_netif_hdr_init(netif_hdr->data, BLE_L2_ADDR_LEN, BLE_L2_ADDR_LEN);
|
||||||
gnrc_netif_hdr_set_src_addr(netif_hdr->data, inbuf->src, BLE_L2_ADDR_LEN);
|
gnrc_netif_hdr_set_src_addr(netif_hdr->data, inbuf->src, BLE_L2_ADDR_LEN);
|
||||||
gnrc_netif_hdr_set_dst_addr(netif_hdr->data, _ble_netif->l2addr, BLE_L2_ADDR_LEN);
|
gnrc_netif_hdr_set_dst_addr(netif_hdr->data, _ble_netif->l2addr, BLE_L2_ADDR_LEN);
|
||||||
((gnrc_netif_hdr_t *)netif_hdr->data)->if_pid = _ble_netif->pid;
|
gnrc_netif_hdr_set_netif(netif_hdr->data, _ble_netif);
|
||||||
|
|
||||||
DEBUG("_handle_raw_sixlowpan(): received packet from %02x:%02x:%02x:%02x:%02x:%02x "
|
DEBUG("_handle_raw_sixlowpan(): received packet from %02x:%02x:%02x:%02x:%02x:%02x "
|
||||||
"of length %d\n",
|
"of length %d\n",
|
||||||
|
@ -1019,7 +1019,7 @@ tftp_state _tftp_send(gnrc_pktsnip_t *buf, tftp_context_t *ctxt, size_t len)
|
|||||||
|
|
||||||
return TS_FAILED;
|
return TS_FAILED;
|
||||||
}
|
}
|
||||||
((gnrc_netif_hdr_t *)netif_hdr->data)->if_pid = gnrc_netif_iter(NULL)->pid;
|
gnrc_netif_hdr_set_netif(netif_hdr->data, gnrc_netif_iter(NULL));
|
||||||
LL_PREPEND(ip, netif_hdr);
|
LL_PREPEND(ip, netif_hdr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -172,7 +172,7 @@ static int _parse_packet(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt,
|
|||||||
gnrc_netif_hdr_t *netif_hdr = netif_snip->data;
|
gnrc_netif_hdr_t *netif_hdr = netif_snip->data;
|
||||||
netif_hdr->lqi = netif->mac.prot.gomach.rx_pkt_lqi;
|
netif_hdr->lqi = netif->mac.prot.gomach.rx_pkt_lqi;
|
||||||
netif_hdr->rssi = netif->mac.prot.gomach.rx_pkt_rssi;
|
netif_hdr->rssi = netif->mac.prot.gomach.rx_pkt_rssi;
|
||||||
netif_hdr->if_pid = netif->pid;
|
gnrc_netif_hdr_set_netif(netif_hdr, netif);
|
||||||
pkt->type = state->proto;
|
pkt->type = state->proto;
|
||||||
gnrc_pktbuf_remove_snip(pkt, pkt->next);
|
gnrc_pktbuf_remove_snip(pkt, pkt->next);
|
||||||
LL_APPEND(pkt, netif_snip);
|
LL_APPEND(pkt, netif_snip);
|
||||||
|
@ -174,7 +174,7 @@ static gnrc_pktsnip_t *_recv(gnrc_netif_t *netif)
|
|||||||
|
|
||||||
hdr->lqi = rx_info.lqi;
|
hdr->lqi = rx_info.lqi;
|
||||||
hdr->rssi = rx_info.rssi;
|
hdr->rssi = rx_info.rssi;
|
||||||
hdr->if_pid = thread_getpid();
|
gnrc_netif_hdr_set_netif(hdr, netif);
|
||||||
pkt->type = state->proto;
|
pkt->type = state->proto;
|
||||||
#if ENABLE_DEBUG
|
#if ENABLE_DEBUG
|
||||||
DEBUG("_recv_ieee802154: received packet from %s of length %u\n",
|
DEBUG("_recv_ieee802154: received packet from %s of length %u\n",
|
||||||
|
@ -98,14 +98,8 @@ void gnrc_icmpv6_echo_req_handle(gnrc_netif_t *netif, ipv6_hdr_t *ipv6_hdr,
|
|||||||
gnrc_pktbuf_release(pkt);
|
gnrc_pktbuf_release(pkt);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
/* (netif == NULL) => ipv6_hdr->dst is loopback address */
|
||||||
if (netif != NULL) {
|
gnrc_netif_hdr_set_netif(hdr->data, netif);
|
||||||
gnrc_netif_hdr_set_netif(hdr->data, netif);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/* ipv6_hdr->dst is loopback address */
|
|
||||||
((gnrc_netif_hdr_t *)hdr->data)->if_pid = KERNEL_PID_UNDEF;
|
|
||||||
}
|
|
||||||
|
|
||||||
LL_PREPEND(pkt, hdr);
|
LL_PREPEND(pkt, hdr);
|
||||||
|
|
||||||
|
@ -189,7 +189,6 @@ void gnrc_rpl_send(gnrc_pktsnip_t *pkt, kernel_pid_t iface, ipv6_addr_t *src, ip
|
|||||||
gnrc_pktbuf_release(pkt);
|
gnrc_pktbuf_release(pkt);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
iface = netif->pid;
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
netif = gnrc_netif_get_by_pid(iface);
|
netif = gnrc_netif_get_by_pid(iface);
|
||||||
@ -225,7 +224,7 @@ void gnrc_rpl_send(gnrc_pktsnip_t *pkt, kernel_pid_t iface, ipv6_addr_t *src, ip
|
|||||||
gnrc_pktbuf_release(pkt);
|
gnrc_pktbuf_release(pkt);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
((gnrc_netif_hdr_t *)hdr->data)->if_pid = iface;
|
gnrc_netif_hdr_set_netif(hdr->data, netif);
|
||||||
LL_PREPEND(pkt, hdr);
|
LL_PREPEND(pkt, hdr);
|
||||||
|
|
||||||
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_IPV6, GNRC_NETREG_DEMUX_CTX_ALL, pkt)) {
|
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_IPV6, GNRC_NETREG_DEMUX_CTX_ALL, pkt)) {
|
||||||
|
@ -131,12 +131,10 @@ static gnrc_pktsnip_t *_build_recvd_pkt(void)
|
|||||||
{
|
{
|
||||||
gnrc_pktsnip_t *netif;
|
gnrc_pktsnip_t *netif;
|
||||||
gnrc_pktsnip_t *pkt;
|
gnrc_pktsnip_t *pkt;
|
||||||
gnrc_netif_hdr_t *netif_hdr;
|
|
||||||
|
|
||||||
netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||||||
assert(netif);
|
assert(netif);
|
||||||
netif_hdr = netif->data;
|
gnrc_netif_hdr_set_netif(netif->data, _mock_netif);
|
||||||
netif_hdr->if_pid = _mock_netif->pid;
|
|
||||||
pkt = gnrc_pktbuf_add(netif, _l2_payload, sizeof(_l2_payload),
|
pkt = gnrc_pktbuf_add(netif, _l2_payload, sizeof(_l2_payload),
|
||||||
GNRC_NETTYPE_IPV6);
|
GNRC_NETTYPE_IPV6);
|
||||||
assert(pkt);
|
assert(pkt);
|
||||||
|
@ -141,7 +141,7 @@ static void _send_packet(void)
|
|||||||
|
|
||||||
gnrc_netif_hdr_init(&(netif_hdr.netif_hdr), 8, 8);
|
gnrc_netif_hdr_init(&(netif_hdr.netif_hdr), 8, 8);
|
||||||
|
|
||||||
netif_hdr.netif_hdr.if_pid = netif->pid;
|
gnrc_netif_hdr_set_netif(&netif_hdr.netif_hdr, netif);
|
||||||
|
|
||||||
uint8_t data1[] = {
|
uint8_t data1[] = {
|
||||||
/* 6LoWPAN Header */
|
/* 6LoWPAN Header */
|
||||||
|
@ -82,6 +82,7 @@ static void *_eventloop(void *arg)
|
|||||||
static void send(char *addr_str, char *port_str, char *data_len_str, unsigned int num,
|
static void send(char *addr_str, char *port_str, char *data_len_str, unsigned int num,
|
||||||
unsigned int delay)
|
unsigned int delay)
|
||||||
{
|
{
|
||||||
|
gnrc_netif_t *netif;
|
||||||
int iface;
|
int iface;
|
||||||
char *conversion_end;
|
char *conversion_end;
|
||||||
uint16_t port;
|
uint16_t port;
|
||||||
@ -91,7 +92,10 @@ static void send(char *addr_str, char *port_str, char *data_len_str, unsigned in
|
|||||||
/* get interface, if available */
|
/* get interface, if available */
|
||||||
iface = ipv6_addr_split_iface(addr_str);
|
iface = ipv6_addr_split_iface(addr_str);
|
||||||
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
if ((iface < 0) && (gnrc_netif_numof() == 1)) {
|
||||||
iface = gnrc_netif_iter(NULL)->pid;
|
netif = gnrc_netif_iter(NULL);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
netif = gnrc_netif_get_by_pid(iface);
|
||||||
}
|
}
|
||||||
/* parse destination address */
|
/* parse destination address */
|
||||||
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
if (ipv6_addr_from_str(&addr, addr_str) == NULL) {
|
||||||
@ -135,16 +139,16 @@ static void send(char *addr_str, char *port_str, char *data_len_str, unsigned in
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* add netif header, if interface was given */
|
/* add netif header, if interface was given */
|
||||||
if (iface > 0) {
|
if (netif != NULL) {
|
||||||
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
gnrc_pktsnip_t *netif_hdr = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||||||
|
|
||||||
if(netif == NULL) {
|
if(netif == NULL) {
|
||||||
puts("Error: unable to allocate NETIF header");
|
puts("Error: unable to allocate NETIF header");
|
||||||
gnrc_pktbuf_release(ip);
|
gnrc_pktbuf_release(ip);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
((gnrc_netif_hdr_t *)netif->data)->if_pid = (kernel_pid_t)iface;
|
gnrc_netif_hdr_set_netif(netif_hdr->data, netif);
|
||||||
LL_PREPEND(ip, netif);
|
LL_PREPEND(ip, netif_hdr);
|
||||||
}
|
}
|
||||||
/* send packet */
|
/* send packet */
|
||||||
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
if (!gnrc_netapi_dispatch_send(GNRC_NETTYPE_UDP, GNRC_NETREG_DEMUX_CTX_ALL, ip)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user