mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
105 lines
3.3 KiB
Markdown
105 lines
3.3 KiB
Markdown
This README contains information how to establish an IPv6 connecton between
|
|
Linux BLE router and an IPSP enabled BLE device.
|
|
|
|
Prerequisites
|
|
=============
|
|
In general, any device capable of running Linux operating system, can be used
|
|
as a BLE router provided the following conditions are met:
|
|
|
|
* Linux Kernel >3.18 and <=4.12 is used
|
|
* The nRF IoT SDK version used in this package does not yet support the
|
|
`BLE_6LOWPAN_LEGACY_MODE` flag, which would remove the upper version bound.
|
|
See [the package documentation](https://riot-os.org/api/group__pkg__nordic-softdevice-ble.html)
|
|
for further directions.
|
|
* bluez, libcap-ng0, radvd tools are present.
|
|
|
|
If a built-in Bluetooth device is not available then Bluetooth 4.0 compatible
|
|
USB dongle can be used.
|
|
|
|
The following procedures have been tested on Ubuntu 15.10 and Ubuntu 16.04.
|
|
|
|
Establishing an IPv6 connection
|
|
===============================
|
|
Use the following procedure to establish a connection between an nRF52 device
|
|
and Linux router:
|
|
|
|
First enable 6LoWPAN module. This is necessary only once per session:
|
|
|
|
# Log in as a root user.
|
|
sudo su
|
|
|
|
# Mount debugfs file system.
|
|
mount -t debugfs none /sys/kernel/debug
|
|
|
|
# Load 6LoWPAN module.
|
|
modprobe bluetooth_6lowpan
|
|
|
|
# Enable the bluetooth 6lowpan module.
|
|
echo 1 > /sys/kernel/debug/bluetooth/6lowpan_enable
|
|
|
|
# Look for available HCI devices.
|
|
hciconfig
|
|
|
|
# Reset HCI device - for example hci0 device.
|
|
hciconfig hci0 reset
|
|
|
|
# Read 00:AA:BB:XX:YY:ZZ address of the nRF5x device.
|
|
hcitool lescan
|
|
|
|
If you see device name and address in lescan output then you can connect to the
|
|
device:
|
|
|
|
echo "connect 00:AA:BB:XX:YY:ZZ 1" > /sys/kernel/debug/bluetooth/6lowpan_control
|
|
|
|
If above is successful then LED1 will stop blinking and LED2 will switch on.
|
|
You can then check the connection using the following commands:
|
|
|
|
# Check if bt0 interface is present and up
|
|
ifconfig
|
|
|
|
# Try to ping the device using its link-local address, for example, on bt0 interface.
|
|
ping6 fe80::2aa:bbff:fexx:yyzz%bt0
|
|
|
|
If you'd like to learn more about the procedure please refer to
|
|
[Connecting devices to the router].
|
|
|
|
Distributing routable IPv6 prefix
|
|
=================================
|
|
In Linux, Router Advertisement Daemon (RADVD) can be used to distribute prefixes
|
|
in the network, hance configure routable IPv6 address.
|
|
|
|
To configure RADVD create `/etc/radvd.conf` file and paste the following contents:
|
|
|
|
interface bt0
|
|
{
|
|
AdvSendAdvert on;
|
|
prefix 2001:db8::/64
|
|
{
|
|
AdvOnLink off;
|
|
AdvAutonomous on;
|
|
AdvRouterAddr on;
|
|
};
|
|
};
|
|
|
|
Next, start RADVD daemon:
|
|
|
|
# Set IPv6 forwarding (must be present).
|
|
sudo echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
|
|
# Run radvd daemon.
|
|
sudo service radvd restart
|
|
|
|
If successful then all devices connected to the host will receive
|
|
a routable `2001:db8` prefix.
|
|
|
|
This can be verified by sending echo request to the full address:
|
|
|
|
ping6 -I bt0 2001:db8::2aa:bbff:fexx:yyzz
|
|
|
|
where `aa:bbff:fexx:yyzz` is device Bluetooth address.
|
|
|
|
If you'd like to learn more about the procedure please refer to
|
|
[Distributing a global IPv6 prefix].
|
|
|
|
* [Connecting devices to the router]: http://developer.nordicsemi.com/nRF5_IoT_SDK/doc/0.9.0/html/a00089.html
|
|
* [Distributing a global IPv6 prefix]: http://developer.nordicsemi.com/nRF5_IoT_SDK/doc/0.9.0/html/a00090.html
|