mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
examples: add example for cascading subnets
This commit is contained in:
parent
b208db0f27
commit
faae6d56be
50
examples/gnrc_networking_subnets/Makefile
Normal file
50
examples/gnrc_networking_subnets/Makefile
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
# name of your application
|
||||||
|
APPLICATION = gnrc_networking-subnets
|
||||||
|
|
||||||
|
# If no BOARD is found in the environment, use this default:
|
||||||
|
BOARD ?= native
|
||||||
|
|
||||||
|
# This has to be the absolute path to the RIOT base directory:
|
||||||
|
RIOTBASE ?= $(CURDIR)/../..
|
||||||
|
|
||||||
|
# Include packages that pull up and auto-init the link layer.
|
||||||
|
USEMODULE += gnrc_netdev_default
|
||||||
|
USEMODULE += auto_init_gnrc_netif
|
||||||
|
# Activate ICMPv6 error messages
|
||||||
|
USEMODULE += gnrc_icmpv6_error
|
||||||
|
# Specify the mandatory networking modules for IPv6 and UDP
|
||||||
|
USEMODULE += gnrc_udp
|
||||||
|
# This application dumps received packets to STDIO using the pktdump module
|
||||||
|
USEMODULE += gnrc_pktdump
|
||||||
|
# Additional networking modules that can be dropped if not needed
|
||||||
|
USEMODULE += gnrc_icmpv6_echo
|
||||||
|
# Add also the shell, some shell commands
|
||||||
|
USEMODULE += shell
|
||||||
|
USEMODULE += shell_commands
|
||||||
|
USEMODULE += ps
|
||||||
|
USEMODULE += netstats_l2
|
||||||
|
USEMODULE += netstats_ipv6
|
||||||
|
|
||||||
|
# leaf nodes only have a single interface
|
||||||
|
ifeq (1, $(LEAF))
|
||||||
|
APPLICATION := $(APPLICATION)_leaf
|
||||||
|
USEMODULE += gnrc_ipv6_default
|
||||||
|
else
|
||||||
|
USEMODULE += gnrc_ipv6_router_default
|
||||||
|
USEMODULE += gnrc_ipv6_auto_subnets
|
||||||
|
CFLAGS += -DNETDEV_TAP_MAX=2
|
||||||
|
PORT ?= tap_a0 tap_b0
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Comment this out to disable code in RIOT that does safety checking
|
||||||
|
# which is not needed in a production environment but helps in the
|
||||||
|
# development process:
|
||||||
|
DEVELHELP ?= 1
|
||||||
|
|
||||||
|
# Change this to 0 show compiler invocation lines by default:
|
||||||
|
QUIET ?= 1
|
||||||
|
|
||||||
|
include $(RIOTBASE)/Makefile.include
|
||||||
|
|
||||||
|
# Set a custom channel if needed
|
||||||
|
include $(RIOTMAKE)/default-radio-settings.inc.mk
|
38
examples/gnrc_networking_subnets/Makefile.ci
Normal file
38
examples/gnrc_networking_subnets/Makefile.ci
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
BOARD_INSUFFICIENT_MEMORY := \
|
||||||
|
arduino-duemilanove \
|
||||||
|
arduino-leonardo \
|
||||||
|
arduino-mega2560 \
|
||||||
|
arduino-nano \
|
||||||
|
arduino-uno \
|
||||||
|
atmega1284p \
|
||||||
|
atmega328p \
|
||||||
|
atmega328p-xplained-mini \
|
||||||
|
atxmega-a3bu-xplained \
|
||||||
|
bluepill-stm32f030c8 \
|
||||||
|
derfmega128 \
|
||||||
|
i-nucleo-lrwan1 \
|
||||||
|
ict_panhead \
|
||||||
|
m1284p \
|
||||||
|
mega-xplained \
|
||||||
|
microduino-corerf \
|
||||||
|
msb-430 \
|
||||||
|
msb-430h \
|
||||||
|
nucleo-f030r8 \
|
||||||
|
nucleo-f031k6 \
|
||||||
|
nucleo-f042k6 \
|
||||||
|
nucleo-f303k8 \
|
||||||
|
nucleo-f334r8 \
|
||||||
|
nucleo-l011k4 \
|
||||||
|
nucleo-l031k6 \
|
||||||
|
nucleo-l053r8 \
|
||||||
|
samd10-xmini \
|
||||||
|
slstk3400a \
|
||||||
|
stk3200 \
|
||||||
|
stm32f030f4-demo \
|
||||||
|
stm32f0discovery \
|
||||||
|
stm32l0538-disco \
|
||||||
|
telosb \
|
||||||
|
waspmote-pro \
|
||||||
|
z1 \
|
||||||
|
zigduino \
|
||||||
|
#
|
78
examples/gnrc_networking_subnets/README.md
Normal file
78
examples/gnrc_networking_subnets/README.md
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
# Auto-configuration for nested subnets on a (simple) tree topology
|
||||||
|
|
||||||
|
This example demonstrates IPv6 subnet auto-configuration for networks on a
|
||||||
|
tree topology.
|
||||||
|
|
||||||
|
This allows to connect multiple links with individual subnets and route
|
||||||
|
between them.
|
||||||
|
Each link can have an arbitrary number of hosts, but there can be only
|
||||||
|
a single router on each link.
|
||||||
|
Routers can have multiple interfaces to connect different downlinks.
|
||||||
|
|
||||||
|
![](../../doc/doxygen/src/gnrc_ipv6_auto_subnets_simple.svg)
|
||||||
|
|
||||||
|
## Setup on native
|
||||||
|
|
||||||
|
To simulate such a network on `native` a `setup_taps.sh` script is provided that
|
||||||
|
will create TAP interfaces and bridges.
|
||||||
|
Each bridge will be it's own subnet and `native` instances will act as routers
|
||||||
|
to route between them.
|
||||||
|
The setup script will also start `radvd` to advertise a large prefix that allows
|
||||||
|
for sub-division by RIOT.
|
||||||
|
|
||||||
|
The interfaces that should be created are specified in the `tapology.txt` file.
|
||||||
|
|
||||||
|
Each router will have (at least) two interfaces that should be on different
|
||||||
|
bridges.
|
||||||
|
|
||||||
|
To start the first router, run
|
||||||
|
|
||||||
|
make term PORT="tap_a0 tap_b1"
|
||||||
|
|
||||||
|
This will route between the `tap_a0` interface on `br0` and the `tap_b1`
|
||||||
|
interface on `br1`.
|
||||||
|
Start more `native` instances to simulate a cascading tree network:
|
||||||
|
|
||||||
|
make term PORT="tap_b0 tap_c1"
|
||||||
|
make term PORT="tap_c0 tap_d1"
|
||||||
|
…
|
||||||
|
|
||||||
|
It is also possible to connect non-routing leaf nodes with a single interface:
|
||||||
|
|
||||||
|
make flash term LEAF=1 PORT=tap_b2
|
||||||
|
|
||||||
|
|
||||||
|
## Setup on hardware
|
||||||
|
|
||||||
|
On physical hardware the setup will be the same.
|
||||||
|
Routing nodes need at least two interfaces between which they can route.
|
||||||
|
For a simple setup, you can use `ethos` or `slipdev` to turn any UART into
|
||||||
|
a network interface. (If you need to use DHCPv6 IA_PD for obtaining a prefix,
|
||||||
|
use `slipdev_l2addr` instead of plain `slipdev`)
|
||||||
|
|
||||||
|
### Obtaining the prefix
|
||||||
|
|
||||||
|
#### Via router advertisements
|
||||||
|
|
||||||
|
Usually routers are configured to advertise a /64 prefix that can not be divided
|
||||||
|
further when using SLAAC.
|
||||||
|
If you can configure your router to advertise a larger prefix instead, this
|
||||||
|
will be the easiest solution.
|
||||||
|
|
||||||
|
#### Via DHCPv6
|
||||||
|
|
||||||
|
If you can't change the configuration of your router, but your router supports
|
||||||
|
DHCPv6 IA_PD, you can use this to request a larger prefix.
|
||||||
|
|
||||||
|
This requires a gateway node that uses the `gnrc_dhcpv6_client_simple_pd`
|
||||||
|
module *instead* of `gnrc_ipv6_auto_subnets`.
|
||||||
|
|
||||||
|
Make sure to set the `CONFIG_GNRC_DHCPV6_CLIENT_6LBR_UPSTREAM` option to the
|
||||||
|
ID of the upstream interface on the gateway device, e.g.
|
||||||
|
|
||||||
|
CFLAGS += -DCONFIG_GNRC_DHCPV6_CLIENT_6LBR_UPSTREAM=6
|
||||||
|
|
||||||
|
As with GNRC the interface ID is based on the PID of the interface thread, this can
|
||||||
|
change if you add modules / threads and is a common source of errors.
|
||||||
|
If the configuration is set wrong, you will not get a prefix for the downstream
|
||||||
|
interface(s).
|
1
examples/gnrc_networking_subnets/main.c
Symbolic link
1
examples/gnrc_networking_subnets/main.c
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../gnrc_networking/main.c
|
64
examples/gnrc_networking_subnets/setup_taps.sh
Executable file
64
examples/gnrc_networking_subnets/setup_taps.sh
Executable file
@ -0,0 +1,64 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
PREFIX=2001:db8::/60
|
||||||
|
|
||||||
|
SCRIPTPATH=$(dirname $(realpath "$0"))
|
||||||
|
|
||||||
|
RIOTBASE=$SCRIPTPATH/../..
|
||||||
|
RIOTTOOLS=$RIOTBASE/dist/tools
|
||||||
|
TOPOLOGY=$SCRIPTPATH/tapology.txt
|
||||||
|
|
||||||
|
setup() {
|
||||||
|
echo "creating tap interfaces"
|
||||||
|
i=0
|
||||||
|
sed '/^#/d' "$1" | while read -r level num; do
|
||||||
|
# we actually want to execute the output here.
|
||||||
|
# shellcheck disable=SC2091
|
||||||
|
$(printf -- "sudo %s/tapsetup/tapsetup -b br%s -t tap_%s -c %s\n" "$RIOTTOOLS" "$i" "$level" "$num") > /dev/null;
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
|
||||||
|
# add address to br0 so this can be tested by pinging the host system
|
||||||
|
sudo ip addr add ${PREFIX/::\//::1\/} dev br0
|
||||||
|
|
||||||
|
# start radvd with a large prefix
|
||||||
|
sudo "$RIOTTOOLS"/radvd/radvd.sh -c br0 $PREFIX
|
||||||
|
}
|
||||||
|
|
||||||
|
teardown() {
|
||||||
|
echo "deleting tap interfaces"
|
||||||
|
i=0
|
||||||
|
sed '/^#/d' "$1" | while read -r level num; do
|
||||||
|
$(printf -- "sudo %s/tapsetup/tapsetup -b br%s -t tap_%s -d\n" "$RIOTTOOLS" "$i" "$level") > /dev/null;
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
|
||||||
|
# stop radvd
|
||||||
|
sudo "$RIOTTOOLS"/radvd/radvd.sh -d
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ $# -gt 1 ]; then
|
||||||
|
TOPOLOGY=$2
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f "$TOPOLOGY" ]; then
|
||||||
|
echo "no such file: $TOPOLOGY"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $# -gt 0 ]; then
|
||||||
|
case $1 in
|
||||||
|
-c)
|
||||||
|
;;
|
||||||
|
-d)
|
||||||
|
teardown "$TOPOLOGY"
|
||||||
|
exit
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "usage: $0 [-c <topology>] [-d topology]"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
setup "$TOPOLOGY"
|
9
examples/gnrc_networking_subnets/tapology.txt
Normal file
9
examples/gnrc_networking_subnets/tapology.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# This file specifies the tap bridges and tap devices that
|
||||||
|
# should be created.
|
||||||
|
#
|
||||||
|
# bridge nodes
|
||||||
|
a 1
|
||||||
|
b 3
|
||||||
|
c 3
|
||||||
|
d 3
|
||||||
|
e 3
|
1
examples/gnrc_networking_subnets/udp.c
Symbolic link
1
examples/gnrc_networking_subnets/udp.c
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../gnrc_networking/udp.c
|
Loading…
Reference in New Issue
Block a user