1
0
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:
Marian Buschsieweke 2019-09-10 16:14:28 +02:00 committed by GitHub
commit b87ab96d17
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 45 additions and 41 deletions

View File

@ -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",

View File

@ -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 */

View File

@ -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;

View File

@ -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)) {

View File

@ -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);
} }

View File

@ -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",

View File

@ -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);
} }

View File

@ -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);

View File

@ -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",

View File

@ -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);

View File

@ -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)) {

View File

@ -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);

View File

@ -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 */

View File

@ -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)) {