mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge #19973
19973: sys/shell/gnrc_txtsnd: Move to separate module r=yarrick a=yarrick Co-authored-by: Erik Ekman <eekman@google.com>
This commit is contained in:
commit
715da20ad6
@ -479,6 +479,7 @@ PSEUDOMODULES += shell_cmd_gnrc_pktbuf
|
|||||||
PSEUDOMODULES += shell_cmd_gnrc_rpl
|
PSEUDOMODULES += shell_cmd_gnrc_rpl
|
||||||
PSEUDOMODULES += shell_cmd_gnrc_sixlowpan_ctx
|
PSEUDOMODULES += shell_cmd_gnrc_sixlowpan_ctx
|
||||||
PSEUDOMODULES += shell_cmd_gnrc_sixlowpan_frag_stats
|
PSEUDOMODULES += shell_cmd_gnrc_sixlowpan_frag_stats
|
||||||
|
PSEUDOMODULES += shell_cmd_gnrc_txtsnd
|
||||||
PSEUDOMODULES += shell_cmd_gnrc_udp
|
PSEUDOMODULES += shell_cmd_gnrc_udp
|
||||||
PSEUDOMODULES += shell_cmd_heap
|
PSEUDOMODULES += shell_cmd_heap
|
||||||
PSEUDOMODULES += shell_cmd_i2c_scan
|
PSEUDOMODULES += shell_cmd_i2c_scan
|
||||||
|
@ -51,6 +51,9 @@ ifneq (,$(filter shell_cmds_default,$(USEMODULE)))
|
|||||||
USEMODULE += shell_cmd_gnrc_netif_lora
|
USEMODULE += shell_cmd_gnrc_netif_lora
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
ifneq (,$(filter gnrc_txtsnd,$(USEMODULE)))
|
||||||
|
USEMODULE += shell_cmd_gnrc_txtsnd
|
||||||
|
endif
|
||||||
ifneq (,$(filter gnrc_netif_lorawan,$(USEMODULE)))
|
ifneq (,$(filter gnrc_netif_lorawan,$(USEMODULE)))
|
||||||
USEMODULE += shell_cmd_gnrc_netif_lorawan
|
USEMODULE += shell_cmd_gnrc_netif_lorawan
|
||||||
endif
|
endif
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
#include "net/loramac.h"
|
#include "net/loramac.h"
|
||||||
#include "net/netif.h"
|
#include "net/netif.h"
|
||||||
#include "shell.h"
|
#include "shell.h"
|
||||||
#include "container.h"
|
|
||||||
|
|
||||||
#ifdef MODULE_NETSTATS
|
#ifdef MODULE_NETSTATS
|
||||||
#include "net/netstats.h"
|
#include "net/netstats.h"
|
||||||
@ -1793,67 +1792,6 @@ static int _netif_del(netif_t *iface, char *addr_str)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* shell commands */
|
/* shell commands */
|
||||||
#ifdef MODULE_GNRC_TXTSND
|
|
||||||
static int _gnrc_netif_send(int argc, char **argv)
|
|
||||||
{
|
|
||||||
netif_t *iface;
|
|
||||||
uint8_t addr[GNRC_NETIF_L2ADDR_MAXLEN];
|
|
||||||
size_t addr_len;
|
|
||||||
gnrc_pktsnip_t *pkt, *hdr;
|
|
||||||
gnrc_netif_hdr_t *nethdr;
|
|
||||||
uint8_t flags = 0x00;
|
|
||||||
|
|
||||||
if (argc < 4) {
|
|
||||||
printf("usage: %s <if> [<L2 addr>|bcast] <data>\n", argv[0]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
iface = netif_get_by_name(argv[1]);
|
|
||||||
if (!iface) {
|
|
||||||
printf("error: invalid interface given\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* parse address */
|
|
||||||
addr_len = gnrc_netif_addr_from_str(argv[2], addr);
|
|
||||||
|
|
||||||
if (addr_len == 0) {
|
|
||||||
if (strcmp(argv[2], "bcast") == 0) {
|
|
||||||
flags |= GNRC_NETIF_HDR_FLAGS_BROADCAST;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
printf("error: invalid address given\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* put packet together */
|
|
||||||
pkt = gnrc_pktbuf_add(NULL, argv[3], strlen(argv[3]), GNRC_NETTYPE_UNDEF);
|
|
||||||
if (pkt == NULL) {
|
|
||||||
printf("error: packet buffer full\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
hdr = gnrc_netif_hdr_build(NULL, 0, addr, addr_len);
|
|
||||||
if (hdr == NULL) {
|
|
||||||
printf("error: packet buffer full\n");
|
|
||||||
gnrc_pktbuf_release(pkt);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
pkt = gnrc_pkt_prepend(pkt, hdr);
|
|
||||||
nethdr = (gnrc_netif_hdr_t *)hdr->data;
|
|
||||||
nethdr->flags = flags;
|
|
||||||
/* and send it */
|
|
||||||
if (gnrc_netif_send(container_of(iface, gnrc_netif_t, netif), pkt) < 1) {
|
|
||||||
printf("error: unable to send\n");
|
|
||||||
gnrc_pktbuf_release(pkt);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
SHELL_COMMAND(txtsnd, "Sends a custom string as is over the link layer", _gnrc_netif_send);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* TODO: updated tests/net/gnrc_dhcpv6_client to no longer abuse this shell command
|
/* TODO: updated tests/net/gnrc_dhcpv6_client to no longer abuse this shell command
|
||||||
* and add static qualifier */
|
* and add static qualifier */
|
||||||
|
89
sys/shell/cmds/gnrc_txtsnd.c
Normal file
89
sys/shell/cmds/gnrc_txtsnd.c
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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 sys_shell_commands
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @brief Shell command for sending raw text on network
|
||||||
|
*
|
||||||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||||||
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
||||||
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "net/gnrc.h"
|
||||||
|
#include "net/gnrc.h"
|
||||||
|
#include "net/gnrc/netif/hdr.h"
|
||||||
|
#include "net/ipv6/addr.h"
|
||||||
|
#include "shell.h"
|
||||||
|
#include "container.h"
|
||||||
|
|
||||||
|
static int _gnrc_netif_send(int argc, char **argv)
|
||||||
|
{
|
||||||
|
netif_t *iface;
|
||||||
|
uint8_t addr[GNRC_NETIF_L2ADDR_MAXLEN];
|
||||||
|
size_t addr_len;
|
||||||
|
gnrc_pktsnip_t *pkt, *hdr;
|
||||||
|
gnrc_netif_hdr_t *nethdr;
|
||||||
|
uint8_t flags = 0x00;
|
||||||
|
|
||||||
|
if (argc < 4) {
|
||||||
|
printf("usage: %s <if> [<L2 addr>|bcast] <data>\n", argv[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
iface = netif_get_by_name(argv[1]);
|
||||||
|
if (!iface) {
|
||||||
|
printf("error: invalid interface given\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* parse address */
|
||||||
|
addr_len = gnrc_netif_addr_from_str(argv[2], addr);
|
||||||
|
|
||||||
|
if (addr_len == 0) {
|
||||||
|
if (strcmp(argv[2], "bcast") == 0) {
|
||||||
|
flags |= GNRC_NETIF_HDR_FLAGS_BROADCAST;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("error: invalid address given\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* put packet together */
|
||||||
|
pkt = gnrc_pktbuf_add(NULL, argv[3], strlen(argv[3]), GNRC_NETTYPE_UNDEF);
|
||||||
|
if (pkt == NULL) {
|
||||||
|
printf("error: packet buffer full\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
hdr = gnrc_netif_hdr_build(NULL, 0, addr, addr_len);
|
||||||
|
if (hdr == NULL) {
|
||||||
|
printf("error: packet buffer full\n");
|
||||||
|
gnrc_pktbuf_release(pkt);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
pkt = gnrc_pkt_prepend(pkt, hdr);
|
||||||
|
nethdr = (gnrc_netif_hdr_t *)hdr->data;
|
||||||
|
nethdr->flags = flags;
|
||||||
|
/* and send it */
|
||||||
|
if (gnrc_netif_send(container_of(iface, gnrc_netif_t, netif), pkt) < 1) {
|
||||||
|
printf("error: unable to send\n");
|
||||||
|
gnrc_pktbuf_release(pkt);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
SHELL_COMMAND(txtsnd, "Sends a custom string as is over the link layer", _gnrc_netif_send);
|
Loading…
Reference in New Issue
Block a user