RAK811 Evaluation Board Quick Start Guide
Prerequisites
Before going through the installation guide of the WisDuino RAK811 Evaluation Board, make sure to prepare the necessary items listed below:
- WisDuino RAK811 Evaluation Board
- Micro- USB cable
- Gateway in Range for Testing
- A Windows/Mac OS/Linux Computer
The bootloader of the WisDuino RAK811 Evaluation Board is already pre-installed upon manufacturing, so flashing the bootloader is not necessary for you to perform. If you find that the bootloader of your RAK811 Evaluation Board is damaged, contact the support through the RAKwireless forum. However, if you want to upgrade the firmware of the device, refer to the section Firmware Upgrading.
Package Inclusion
- 1pc - WisDuino RAK811 Evaluation Board
- 1pc - Micro - USB Cable
- 1pc - LoRa Antenna (SMA)
- 5pcs - Jumper Caps
- 5pcs - Male to Female Jumper Wires
Product Configuration
Interfacing with RAK811 Evaluation Board
In order to interface with the RAK811 Evaluation Board with your Windows Machine, you need to download the RAK Serial Port Tool.
Before powering the RAK811 Evaluation Board, install the LoRa antenna first. Not doing so might damage the board.
- Using a standard Micro - USB Cable, connect your RAK811 Evaluation Board to your computer.
If this is your first time connecting your RAK811 Evaluation Board to the computer, it should automatically download the CH340 driver for them to communicate properly. Make sure to have internet access if you want such automatic installation to be successful. If such a process fails, re-plug your Micro-USB cord and proceed to the next step.
-
Any serial communication tool can be used; but, it is recommended to use the RAK Serial Port Tool.
-
Configure the serial communication tool by selecting the proper port detected by the computer and configure the link as follows:
- Baud Rate: 115200 baud
- Data Bits: 8 bits
- Stop Bits: 1 stop bit
- Parity: NONE
- The RAK811 console output can be read in the RAK Serial Port Tool, as shown in Figure 2.
Configuring the RAK811
To connect the RAK811 board to a LoRa P2P connection or a LoRaWAN network, the board must be configured and LoRa parameters must be set by sending AT commands. Connect the RAK811 board to the computer as described in the previous section. Using the serial communication tool, for example, the RAK Serial Port Tool, it is possible to send commands to the RAK811. For example, sending the at+set_config=device:restart
and at+version
commands will display the current firmware version, as shown in Figure 3. For more supported commands, refer to AT Commands for RAK811 Evaluation Board.
Connecting to The Things Stack (TTN V3)
This section will show how to connect the RAK811 board to The Things Stack (TTN V3) platform.
As shown in Figure 4, The Things Stack is an open-source LoRaWAN Network Server suitable for global, geo-distributed public and private deployments as well as for small, local networks. The architecture follows the LoRaWAN Network Reference Model for standards compliance and interoperability. This project is actively maintained by The Things Industries.
LoRaWAN is a protocol for low-power wide-area networks. It allows for large-scale Internet of Things deployments where low-powered devices efficiently communicate with Internet-connected applications over long-range wireless connections.
The RAK811 board can be part of this ecosystem as a device, and the objective of this section is to demonstrate how simple it is to send data to The Things Stack using the LoRaWAN protocol. To achieve this, the RAK811 board must be located inside the coverage of a LoRaWAN gateway connected to The Things Stack server.
Registration to TTN and Creating LoRaWAN Applications
- The first step is to go to The Things Network platform and select a cluster, as shown in Figure 5. The Things Industries adds more clusters from time to time so select the one close to your location. In this guide, Europe 1 is selected.
You can use the same login credentials on the TTN V2 if you have one. If you have no account yet, you need to create one.
- To register as a new user to TTN, click on Login with The Things ID then select register on the next page as shown in Figure 6 and Figure 7.
-
You should now be on the step of creating your TTN account. Fill in all the necessary details and activate your account.
-
After creating an account, you should log in on the platform using your username/email and password then click Submit, as shown in Figure 8.
- Click Authorize to proceed.
- Now that you are logged in to the platform, the next step is to create an application. Click Create an application.
- To have an application registered, input first the specific details and necessary information about your application then click Create application.
If you have no error on the previous step, you should now be on the application console page. The next step is to add end-devices to your The Things Stack application. LoRaWAN specifications enforce that each end device has to be personalized and activated. There are two options for registering devices depending on the activation mode selected. Activation can be done either via Over-The-Air-Activation (OTAA) or Activation-By-Personalization (ABP).
Once you have the application in The Things Stack (TTN V3), you need to ensure that you are in coverage of a LoRaWAN gateway that is registered to The Things Stack (TTN V3) as well. Without the coverage of that LoRaWAN gateway, you cannot activate any device that you will register in your application.
RAKwireless has LoRaWAN gateways that you can connect to The Things Stack (TTN V3) if no LoRaWAN gateway coverage is available in your location.
The Things Stack OTAA Device Registration
- Go to your application console to register a device. To start adding an OTAA end device, click + Add end device, as shown in Figure 12.
- To register the board, click first Manually, configure the activation method by selecting Over the air activation (OTAA) and compatible LoRaWAN version, then click Start button, as shown in Figure 13 and Figure 14.
-
Then you need to put a unique End device ID and EUIs (DevEUI and AppEUI), as shown in Figure 15. Check if your board has a DevEUI on sticker or QR that you can scan then use this as the device’s unique DevEUI. The AppEUI cannot be all zero as well for the RAK811 Evaluation Board, else the device will have errors when it connects to the network server.
-
Optionally, you can add a more descriptive End device name and End device description about your device.
-
After putting all the details, you need to click Network layer settings to proceed to the next step.
It is advisable to use a meaningful End device ID, End device name, and End device description that will match your device's purpose. The End device ID rak-device
is for illustration purposes only.
- Next step is to set up Frequency plan, compatible Regional Parameter version, and LoRaWAN class supported. Then you can click Join settings.
- The last step in the registration of a new OTAA end-device is the configuration of the AppKey. To get the AppKey, you must click the generate button. Then you need to click Add end device to finish your new device registration.
You should now be able to see the device on The Things Stack console after you fully register your device, as shown in Figure 18.
-
The AppEUI, DevEUI, and AppKey are the parameters that you will need to activate your LoRaWAN end device via OTAA. The AppKey is hidden by default for security reasons, but you can easily show it by clicking the show button. You can also copy the parameters quickly using the copy button.
-
The three OTAA parameters on The Things Stack device console are MSB by default.
-
These parameters are always accessible on the device console page, as shown in Figure 18.
RAK811 OTAA Configuration for The Things Stack
The RAK811 board supports a series of AT commands to configure its internal parameters and control the functionalities of the module. To set up the RAK811 Evaluation Board to join The Things Stack using OTAA, you need to connect to the PC via USB cable and open the RAK Serial Port Tool. Wait for the communication to start. It is recommended to test the serial communication and verify the current configuration by sending either of these two AT commands:
If you got any error related to the AT Commands, you can always check the Error Code Table to get more insights.
at+set_config=device:restart
at+version
As an example, these are the list of the parameters you need to configure in RAK811:
- LoRa join mode: OTAA
- LoRa class: Class A
- LoRa region: EU868
- Device EUI: 1133557799224466
- Application EUI: 1000000000000009
- Application Key: 04FA4E626EF5CF227C969601176275C2
You need to set valid values to the Device EUI, Application EUI, and Application Key. It cannot be all zero values else it will cause an error once the device attempts to join the network server.
- Set the LoRa join mode to OTAA.
at+set_config=lora:join_mode:0
- Set the LoRa class to Class A.
at+set_config=lora:class:0
- Set the frequency/region to EU868.
- Refer to the RAK811 Datasheet for the list of supported frequencies.
at+set_config=lora:region:EU868
- Set the Device EUI.
at+set_config=lora:dev_eui:1133557799224466
- Set the Application EUI.
at+set_config=lora:app_eui:1000000000000009
- Set the Application Key.
at+set_config=lora:app_key:04FA4E626EF5CF227C969601176275C2
After configuring all the parameters, you need to reset your RAK811 Module for saving the parameters.
- After resetting, join in OTAA mode.
at+join
After 5 or 6 seconds, if the request is successfully received by a LoRa gateway, then you should see the messages shown in Figure 21.
- Try to send a message from the RAK811 board.
at+send=lora:2:1234567890
You can see the data sent by the RAK811 board on The Things Stack platform, as shown in Figure 22.
The Things Stack ABP Device Registration
- To register an ABP device, you need to go to your application console and select the application where you want your device to be added. Then you need to click + Add end device, as shown in Figure 23.
- To register the board, click first Manually then configure the activation method by selecting Activation by personalization (ABP), compatible LoRaWAN version and click Start button, as shown in Figure 24 and Figure 25.
-
At this step, you need to put a unique End device ID and DevEUI, as shown in Figure 26. Check if your board has a DevEUI on sticker or QR that you can scan then use this as the device’s unique DevEUI.
-
Optionally, you can add a more descriptive End device name and End device description about your device.
-
After putting all the details, click Network layer settings to proceed to the next step.
It is advisable to use a meaningful End device ID, End device name, and End device description that will match your device's purpose. The End device ID rak-device-abp
is for illustration purposes only.
- Next step is to set up Frequency plan, compatible Regional Parameter version, and LoRaWAN class supported. In an ABP device, you also need to generate Device Address and NwkSKey (Network Session Keys). Then you can click Application layers settings
- The last step in the registration of a new ABP end-device is the configuration of the AppSKey. To get the AppSKey, you must click the generate button. Then you need to click Add end device to finish your new device registration.
You should now be able to see the device on The Things Stack console after you fully register your device, as shown in Figure 29.
RAK811 ABP Configuration for The Things Stack
To set up the RAK811 Evaluation Board to join The Things Stack using ABP, you need to connect to the PC via USB cable and open the RAK Serial Port Tool. It is recommended to test the serial communication by sending either of these two AT commands:
If you got any error related to the AT Commands, you can always check the Error Code Table to get more insights.
at+set_config=device:restart
at+version
As an example, these are the list of the parameters you need to configure in RAK811:
- LoRa join mode: ABP
- LoRa class: Class A
- LoRa region: EU868
- Device address: 260BDE80
- Network Session Key: 433C7A924F7F6947778FE821525F183A
- Application Session Key: A585653A949C2B2D44B55E99E94CB533
You need to set valid values to the Device address, Network Session Key, and Application Session Key. It cannot be all zero values else it will cause an error once the device attempts to join the network server.
- Set the LoRa join mode to ABP.
at+set_config=lora:join_mode:1
- Set the LoRa class to Class A.
at+set_config=lora:class:0
- Set the frequency/region to EU868.
- Refer to the RAK811 Datasheet for the list of supported frequencies.
at+set_config=lora:region:EU868
- Set the Device Address.
at+set_config=lora:dev_addr:260BDE80
- Set the LoRa Network Session Key.
at+set_config=lora:nwks_key:433C7A924F7F6947778FE821525F183A
- Set the LoRa Application Session Key.
at+set_config=lora:apps_key:A585653A949C2B2D44B55E99E94CB533
After configuring all the parameters, you need to reset the RAK811 Evaluation board for saving the parameters.
- After resetting, join in ABP mode.
at+join
By using the ABP mode in LoRaWAN, it doesn’t require to join a network before sending a LoRaWAN package. But to keep the consistency of internal states of the firmware of the RAK811 board, it is still required to send at+join
command in the ABP mode. This time, the firmware should reply almost immediately with an “OK”.
- Try to send data from the RAK811 to The Things Network in ABP mode.
at+send=lora:2:1234567890
You can see the data sent by the RAK811 board on The Things Stack device console Live data section and the Last seen info should be a few seconds ago.
Connecting with ChirpStack
In this section, it shows how to connect the RAK811 board to the ChirpStack platform.
The ChirpStack or previously known as the LoRaServer project provides open-source components for building LoRaWAN networks. Like the case of The Things Stack, the RAK811 board is located in the periphery and will transmit the data to the backend servers through a LoRa gateway. Learn more about ChirpStack.
It is assumed that you are using RAK Gateway and its built-in ChirpStack or RAK cloud testing ChirpStack. Also, the gateway with the ChirpStack must be configured successfully. For further information, check the RAK documents for more details.
-
In summary, these are the requirements:
- Have ChirpStack online gateway, the frequency band of the nodes should be consistent with the frequency band of the gateway in use.
- The RAK Serial Port Tool provided by RAK
- RAK811 board
The frequency band used in the demonstration is EU868. Use a high-frequency version of RAK811. The product number should be “RAK811 (H)”.
Before you start, you must choose which mode you are going to use, whether in OTAA or ABP mode, to register the device to the network server.
Sign up and loginLogin to the ChirpStack server using your account and password.
Create a new Application
- Go to the Application section, as shown in Figure 35.
- By default, you should create a new application, although you can reuse the existing ones. For this setup, create a new Application by clicking on the “CREATE” button, and filling in the required parameters, as shown in Figure 36 and Figure 37.
- For this setup, create an Application named “rak_node_test”.
ChirpStack LoraServer supports multiple system configurations, with only one by default.
- Service profile: Field is to select the system profile.
- Payload codec: It is the parsing method for selecting load data such as parsing LPP format data.
-
Choose the Application created in the previous step, then select the DEVICES tab, as shown in Figure 38 and Figure 39.
-
Once done, click “+ CREATE”.
- Once inside the DEVICE tab, create a new device (LoRaWAN node) by clicking on the “+ CREATE” button.
- Once the node is created, fill in the necessary data. You can generate a Device EUI automatically by clicking the following icon, or you can write a correct Device EUI in the edit box.
Fill in the parameters requested:
-
Device name and Device description: These are descriptive texts about your device.
-
Device EUI: This interface allows you to generate a Device EUI automatically by clicking the icon highlighted in red, as shown in Figure 42. You can also add a specific Device EUI directly in the form.
-
Device Profile:
- If you want to join in OTAA mode, select “DeviceProfile_OTAA”.
- If you want to join in ABP mode, select “DeviceProfile_ABP”.
Device profiles DeviceProfile_OTAA and DeviceProfile_ABP are only available if you are using the built-in Chirpstack LoRaWAN Server of RAK Gateways.
If you have your own Chirpstack installation, you can set up the device profile with LoRaWAN MAC version 1.0.2
and LoRaWAN Regional Parameters revision A
to make it compatible with RAK811.
LoRaWAN Join Mode
In LoRaWAN, there are two ways a node can connect itself to the LoRaWAN network. This is referred to as Join Mode. LoRaWAN allows the OTAA mode and the ABP mode. In this section, the configuration process of these two modes, both on the platform side and the node side will be explained.
OTAA Mode
Configure the OTAA Mode on the Platform
- If you have selected “DeviceProfile_OTAA”, as shown in Figure 43, then after the device is created, an Application Key must be also created for this device.
- A previously created Application Key can be entered here, or a new one can be generated automatically by clicking the icon highlighted in red in Figure 44:
- Once the Application Key is added to the form, the process can be finalized by clicking on the “SET DEVICE-KEYS” button.
- As shown in Figure 45, a new device should be listed in the DEVICES tab. The most important parameters, such as the Device EUI are shown in the summary.
- To end the process, it is a good practice to review that the Application Key is properly associated with this device. The Application Key can be verified in the KEYS(OTAA) tab, as shown in Figure 46.
Standard OTAA mode requires the Device EUI, Application Key, and Application EUI, but in the ChirpStack’s implementation, only the Device EUI and the Application Key are mandatory. The Application EUI is not required and not recorded in the Application tab. Nevertheless, the Application EUI is a mandatory parameter in the RAK811 board’s firmware. In order to resolve this mismatch, you can reuse the Device EUI as the Application EUI during the configuration on the side of the node.
Configure the OTAA mode on the RAK811
The RAK811 board supports a series of AT commands to configure its internal parameters and control the functionalities of the module.
If you got any error related to the AT Commands, you can always check the Error Code Table to get more insights.
To set up the RAK811 Evaluation Board to join Chirpstack using OTAA, you need to connect to the PC via USB cable and open the RAK Serial Port Tool. Wait for the communication to start. It is recommended to test the serial communication by sending either of these two AT commands:
at+set_config=device:restart
at+version
As an example, these are the list of the parameters you need to configure in RAK811:
- LoRa join mode: OTAA
- LoRa class: Class A
- LoRa region: EU868
- Device EUI: 5e9d1e0857cf25f1
- Application EUI: 5e9d1e0857cf25f1
- Application Key: f921d50cd7d02ee3c5e6142154f274b2
You need to set valid values to the Device EUI, Application EUI, and Application Key. It cannot be all zero values else it will cause an error once the device attempts to join the network server.
- Set the LoRa join mode to OTAA.
at+set_config=lora:join_mode:0
- Set the LoRa class to Class A.
at+set_config=lora:class:0
- Set the frequency/region to EU868.
- Refer to the RAK811 Datasheet for the list of supported frequencies.
at+set_config=lora:region:EU868
- Set the Device EUI.
at+set_config=lora:dev_eui:5e9d1e0857cf25f1
- Set the Application EUI.
at+set_config=lora:app_eui:5e9d1e0857cf25f1
Remember, the Application EUI parameter is not required in the ChirpStack platform; therefore, it is possible to use the same id as the Device EUI. Otherwise, the firmware will complain.
- Set the Application Key.
- Get the Application Key from the ChirpStack console.
at+set_config=lora:app_key:f921d50cd7d02ee3c5e6142154f274b2
After configuring all the parameters, you need to reset the RAK811 Evaluation Board to save the parameters.
- After resetting, start to join.
at+join
- You can then see the JoinRequest and JoinAccept on the ChirpStack page.
- Try to send data from RAK811 Evaluation Board to ChirpStack.
at+send=lora:2:1234567890
- On the ChirpStack platform, you should also see the messages in the LORAWAN FRAMES tab, as shown in Figure 52. By convention, messages sent from nodes to gateways are considered as Uplinks while messages sent by gateways to nodes are considered as Downlinks.
This concludes the exercise to send data in the OTAA mode.
ABP Mode
Configure the ABP Mode on the Platform
- During the registration of a new device, if you select “DeviceProfile_ABP”, as shown in Figure 53, then the ChirpStack platform will assume that this device will join the LoRaWAN network using the ABP mode.
Check “Disable counting frame verification”. During the test, when the module is restarted, the frame counting number will also be restarted from zero. This would cause a synchronization problem with the ChirpStack server treating it as a replay attack. For the testing purpose, it is safe to disable this feature, but remember to activate it in a production environment.
- After selecting the ABP mode, the following parameters appear in the Activation tab:
Then, you can see that there are some parameters for ABP in the “ACTIVATION” item:
- Device address
- Network Session Key
- Application Session Key
- The parameters can be generated as random numbers by the platform or can be set with user values. Once these parameters are filled in properly, the process is completed by clicking on the “ACTIVATE DEVICE” button.
Configure the ABP Mode on the RAK811
In the following steps, you will configure the RAK811 board to work in the ABP mode. To set up the RAK811 Evaluation Board to join Chirpstack using ABP, you need to connect to the PC via USB cable and open the RAK Serial Port Tool. Wait for the communication to start. It is recommended to test the serial communication by sending either of these two AT commands:
If you got any error related to the AT Commands, you can always check the Error Code Table to get more insights.
at+set_config=device:restart
at+version
As an example, these are the list of the parameters you need to configure in RAK811:
- LoRa join mode: ABP
- LoRa class: Class A
- LoRa region: EU868
- Device address: 26011af9
- Network Session Key: c280cb8d1df688bc18601a97025c5488
- Application Session Key: 4d42ec5caf97f03d833cdaf5003f69e1
You need to set valid values to the Device address, Network Session Key, and Application Session Key. It cannot be all zero values else it will cause an error once the device attempts to join the network server.
- Set LoRa join mode to ABP.
at+set_config=lora:join_mode:1
- Set LoRa class to Class A.
at+set_config=lora:class:0
- Set the frequency/region to EU868.
- Refer to the RAK811 Datasheet for the list of supported frequencies.
at+set_config=lora:region:EU868
- Set the Device Address.
at+set_config=lora:dev_addr:26011af9
- Set the Network Session Key.
at+set_config=lora:nwks_key:c280cb8d1df688bc18601a97025c5488
- Set the Application Session Key.
at+set_config=lora:apps_key:4d42ec5caf97f03d833cdaf5003f69e1
After configuring all the parameters, you need to reset the RAK811 Evaluation Board for saving the parameters.
- After resetting the RAK811 Evaluation Board, join in ABP mode.
at+join
By using the ABP mode in the LoRaWAN protocol, it doesn’t require to join a network before sending the LoRaWAN package. But, to keep the consistency of internal states of the firmware of the RAK811 board, it is still required to send at+join
command in the ABP mode. This time, the firmware should reply almost immediately with an “OK”.
- Try to send data from RAK811 Evaluation Board to ChirpStack.
at+send=lora:2:1234567890
LoRa P2P Mode
This section will show you how to set up and connect two RAK811 units to work in the LoRa P2P mode. You will be using EU868 as your frequency, although it applies also to other standard bands.
-
Two RAK811 units shall be set to operate on EU868 frequency.
-
The setup of the RAK811 units is done by connecting them with a general-purpose computer through the UART port. The setup of each RAK811 can be done separately, but testing the LoRa P2P mode will require having both units connected simultaneously to their respective UART port. This could be one computer with two USB ports or two computers with one USB port each.
-
Set the RAK811 to work in LoRa P2P mode. Open the RAK Serial Port Tool and send the following command:
If you got any error related to the AT Commands, you can always check the Error Code Table to get more insights.
at+set_config=lora:work_mode:1
- Then, configure LoRa P2P parameters for both of them.
at+set_config=lorap2p:XXX:Y:Z:A:B:C
For this example, the LoRa parameters are the following:
- Link frequency: 869525000 Hz
- Spreading factor: 7
- Bandwidth: 125 kHz
- Coding Rate: 4/5
- Preamble Length: 5
- Power: 5 dBm
Refer to the Configuring Using AT Commands section to learn more about the definition of the parameters used.
Hence, it is translated into the following RAK811 AT command and sent to both units.
at+set_config=lorap2p:869525000:7:0:1:5:5
- Set the transmission mode of the module. Unit 1 is configured as the sender, and Unit 2 is set to the receiver by AT command.
at+set_config=lorap2p:transfer_mode:2
at+set_config=lorap2p:transfer_mode:1
- Try sending a message from Unit 1 to Unit 2.
at+send=lorap2p:1234567890
Miscellaneous
Upgrading the Firmware
For the RAK811 Evaluation Board with firmware version V3.0.0.12 and below, you need to use the STM32CubeProgrammer to upload the HEX file of the Latest RAK811 Firmware.
If the firmware version of your RAK811 Evaluation Board is V3.0.0.14 and up, you can use the RAK Device Firmware Upgrade (DFU) Tool to update your device and have the latest firmware.
Execute the following procedure to upgrade the firmware in Device Firmware Upgrade (DFU) mode through the UART1 interface.
-
Download the latest application firmware of the RAK811 that can be found on the RAK811 Datasheet.
-
Download the RAK Device Firmware Upgrade (DFU) Tool.
-
Connect the RAK811 Evaluation Board to the computer via USB cable.
-
Open the Device Firmware Upgrade tool. Select the serial port and baud rate of the module and click the "Select Port" button.
- Select the application firmware file of the module with the suffix ".bin".
- Click the "Upgrade" button to upgrade the device. After the upgrade is complete, the RAK811 board will be ready to work with the new firmware.
Interfacing with Arduino Boards
The updated hardware and software guide on interfacing the RAK811 Evaluation Board to Arduino is completely discussed in the WisNode Arduino Library repository.
Requirements:
- WisDuino RAK811 Evaluation Board (v1.1 or v1.2)
- Gateway in range for testing
- Arduino Uno
- External USB-UART TTL Converter
- Jumper wires
Arduino Hardware Preparation
The guide uses Arduino Uno as the host but can be adapted on other boards as well.
There are two versions of the RAK811 Evaluation Board and hardware configuration will depend on the board version.
Arduino Software Preparation
Same with the hardware, the software library will be based on your board version.
The installation guide of these libraries can be found on the main GitHub repository of WisNode-Arduino-Library.
These libraries have included LoRaWAN examples of both OTAA and ABP, as well as an example for LoRa-P2P communication.
The library uses the Software Serial library of Arduino to communicate to the RAK811 via pin 10 and pin 11. Because of this, the RAK811 needs to be configured to a 9600 baud rate for this library to work.