This document describes how to run the embeNET demo application on the LAUNCHXL-CC1312R1 boards equipped with CC1312R1 chip from Texas Instruments.
Optionally, to play with the MQTT-SN demo service you'll need:
Optionally, to easily interact with the custom UDP service you'll need
Picture below presents the architecture of the embeNET network presented in this demo.
 
 The PC acts as a Border Router and becomes the gateway to the network. One LaunchXL board runnig the Root firmware is connected to the PC via USB cable and acts as a network interface. The other LaunchXL boards are running the Node firmware. When running the Border Router application, it connects to the root using serial connection (COM in Windows) and a new network interface is registered in the system. All other LaunchXL boards then join the network as nodes. Since embeNET is a true mesh network, every node in the network is a router and can extend the network through successive hops.
The embeNET demo package for CC1312 is distributed as a single ZIP file. Unzip it into a convenient location on disk. Inside you'll find a couple of folders:
In order to build the firmware project you'll need to add two items to the Code Composer Studio IDE:
We've found that the best method for doing that (at least in CodeComposer 12.5.0) is to go to select "Resource explorer" from the "View" menu.
 
 There navigate to "Wireless connectivity" -> "Embedded Software" and select SimpleLink CC13xx CC26xx SDK - 7.10.01.24. Next hit the install button.
 
 Next select the ARM GNU Embedded Toolchain and SysConfig. then press "INSTALL" button.
 
 Once you have it installed, import the project located in embenet_demo_src folder.
You should see and navigate a project called "embenet_node_demo".
 
 Within the project there will be following folders:
In the main folder you'll find the application files, including main.c
The boards have a built in XDS110 USB Debug Probe that can be used to program and debug the code on the microcontroller. The demo project is already configured to use this device.
There are basically two steps to prepare the demo. You need to build and deploy the code for root and for nodes.
The project has two build configurations: Root and Node. You can switch between them using the "Build Configurations" project option.
 
 These configurations differ only in the compile-time definition IS_ROOT being set to "1" for Root and to "0" for Node.
Once you set Build Configuration to "Root" rebuild the project using the Rebuild project option. The application should build without errors. Connect the board you plan to use as root and hit the "Flash" button.
 
 This should load the code into FLASH and begin execution.
Once you set Build Configuration to "Node" rebuild the project using the Rebuild project option. The application should build without errors. Connect the board you plan to use as root and hit the "Flash" button.
 
 This should load the code into FLASH and begin execution.
To start the network you need to connect the root board to the PC. It should register as two COM ports. Next go to the embenet_br folder and edit the config.json file that holds the border router configuration. The file will look similar to this:
The file has the following entries:
Please edit the file to make sure that the serial_port entry matches the COM port registered for the root board as "XDS110 Class Application/User UART".
Each node in the network, including root has an IPv6 address consisting of two parts:
prefix:uid
where the prefix is set for the network in the config.json file and the uid is the 64-bit IEEE EUI-64 identifier, also know as the MAC address. In case of CC1312 chips this number can be read from internal registers.
Each node that wishes to join the embeNET network needs to be authorized by the built-in Authentication Authority. The authentication process uses a pre-shared key (psk), that needs to be configured in the nodes during commissioning. In the provided demo application firmware the key is hardcoded in main.c file. During the authentication process both the uid and psk have to match what is defined in the join_rules in order to let the node join the network. However, when uid is set to 0, EVERY node with matching psk (pre-shared key) will be able to join the network. We call it the "zero rule". It is useful for testing and experimenting, however it should probably be disabled in the real deployment.
The network is started once you run the border router application embenet_br.exe. The application will try to connect to the root node and then manage the network.
This is a console application that will also log a lot of information about what is going on in the network and what packets are received from the nodes. Analyzing this log may help dealing with problems, if they arise during the further development process.
Once the border router application is running, all nodes within the communication range, should start to join the network. Be aware that this process may take couple of minutes depending on the network topology and the state of the nodes. For example: nodes that previously joined the network may require some time to notice that the border router was restarted before they attempt to join again.
While running, the border router application registers a virtual network interface within Windows. The interface name will be set according to the config.json file. You can check the presence of this interface by running the standard Windows command:
ipconfig
Also, each connected node is reachable by ICMPv6 'ping'.
The demo package includes an application that visualizes the network. It is called enms_visualizer and it is based on the ENMS service running in the background of the network. To use it simply run the application while the network is running. After a minute or so the ENMS messages will feed the application with the current state of the network, that will be visualized as a graph, spanning from the root node.
Exemplary topology with two nodes may look like this:  
    
A network service in embeNET, is a separated piece of functionality built around the communication over a single UDP port (rarely - multiple UDP ports). Three examples of services distributed with the embeNET stack are:
The users however can easily develop their own services using UDP. An example of such a custom UDP service is implemented in the demo nodes.
The MQTT-SN demo service uses MQTT-SN client and does three things:
Refer to Using MQTT-SN demo service for more information on how this service works and how to use it.
The custom service implemented in the demo works on UDP port number 1234. Please note that this service works on remote nodes only - it is not available in root node. The service does two things:
There are many ways you can interact with UDP ports to test this service. One of the easiest is to use an application called UDP - Sender/Reciever app from Microsoft Store. Once you run set the mode to Sender/Receiver. Next, in the Remote IP box input the IPv6 address of the remote node that you wish to communicate with. When using the default network prefix, this IP address will have the following form:
where the UID will be the MAC address of the node.
In the Remote Port and Local Port boxes put port number: 1234
Once you hit Connect you should see incoming text messages. You can also send some commands to light the LEDs on and off.
In order to get to know the internals of the demo and to modify or extend it refer to Internals of the embeNET demo for LAUNCHXL-CC1312R1 board
In order to test MQTT-SN part of the demo go to Using MQTT-SN demo service.