Example Applications

This section provides a high-level overview of the out-of-box example applications.

Linux® Collector and Gateway Example Applications

The Linux Collector and Gateway Applications are provided as part of the TI 15.4-Stack Linux SDK Installer. The Linux Collector Example Application interfaces with the CC13x0 running the MAC CoProcessor through a UART.

The collector example application does the following:

  • Builds a full-function device (FFD) that performs the functions of a network coordinator
  • Starts a network and permits devices to join the network
  • Provides an application to monitor and collects sensor data from one or more sensor devices
  • Provides a socket server interface to the Linux Gateway Application

The Linux Gateway Application, implemented within the Node.js framework, connects as a client to the socket server created by the Linux Collector. The Linux Gateway Application establishes a local Web server to which the user can connect through a Web browser to monitor and control the network devices.

The Collector and Gateway Applications, which provide IEEE 802.15.4 to IP Bridge, are a great starting point for creating Internet of Things (IoT) applications with the TI 15.4-Stack.

Figure 110. shows the software architecture of the Linux Collector Example Application.

../_images/fig-collector-block-diagram.png

Figure 110. Software Block Diagram of the TI 15.4-Stack 2.2.0 Linux® Collector Example Application

Following are high-level descriptions of each software block and where to find the relevant source code:

Linux Kernel — Has features and functionality provided by the processor SDK

NPI Server v2.0 — (directory: examples/npi_server2) Provides a serial communications link and interface to the application with the CC13x0 LP running MAC CoProcessor

API MAC — (directory: components/api) Provides an interface to the management and data services of the TI-15.4 MAC protocol stack

Collector — (file: example/collector/collector.c) Implements an example application that starts the network, allows new devices to join the network, configures the joining devices on how often to report the sensor data, for sleepy devices configures how often to poll for buffered messages in case of nonbeacon and frequency-hopping mode of network operation, and tracks connected devices to determine if they are active or inactive on the network. This determination is achieved by the collector periodically sending tracking request messages and awaiting corresponding tracking response messages.

Logical Link Controller — (file: example/collector/cllc.c) Abstracts the network management functionality from the application such as starting the network, associating new devices, and responding to orphan notifications from the devices that have lost sync

Collector Start-Up Code — (files: example/collector/linux_main.c and appsrv.c) implements logic that is needed to configure the application at start-up.

Note

A portion of the Web server gateway code is also within appsrv.c.

NPI Server — Start-up: example/npi_server2/linux_main.c Application: example/npi_server2/app_main.c

Common Library Component Module — (See directory: components/common) Provides various functionalities such as timer services, semaphores, and so on (see Linux® Software Components for more details)

Collector-Specific Functions — (file: example/collector/csf_linux.c) Implements the user interface- specific functions, interfaces with the nonvolatile (NV) module to provide persistent data service to store information over power cycles, implements a server socket for user application to connect to the application to get useful network information and control network devices

Local Gateway Application — (file: example/collector/appsrv.c) Implements an application client that connects to the application server implemented in the collector specific function and also a Web server application

Gateway Protocol Files — These files define the message content and body between the appsrv component and the front-end gateway application in the gateway folder. (Files: example/collector/*.proto, generated files: “*.pb-c.[ch]”, corresponding *_proto.c.) The Node.js package uses a single protobuf definition file: example/gateway/appClient/protofiles/appsrv.proto.

Web Application — This is the gateway application (see the gateway directory and related Node.js files) that lets users view the network information, device information, information about reported data from the network devices and also control the network devices

MAC CoProcessor — (Prebuilt embedded hex file) Runs on the CC13x0 device, implements an 802.15.4e/g MAC/PHY layer and provides an MT-based interface to the applications running on the Linux host

Linux® Serial Bootloader Example Application

The Linux serial bootloader example application is the Linux flash update application that provides ability to upgrade the firmware on the CC13x0 device through the ROM serial bootloader.

Application Design Details

The serial bootloader example application has two main modules:

  • cc13xxdnld module
  • sblUart module

The cc13xxdnld software module has no dependencies on the operating system or hosting hardware and is intended to be portable across microprocessor units (MPUs), MCUs, and operating systems (OSs). The sblUart files contain the operating-system or hardware-specific calls to the UART that are provided as callback functions to the cc13xxdnld software module. These calls require UART read/write access to communicate with the CC13x0 and the CC26xx ROM bootloader.

CcDnld API

Overview

The CcDnld API should be used in application code. The CcDnld API is intended to ease the integration of the CC13x0 bootloader functionality in a host processor connected to the CC13x0 UART.

General Behavior

Before using the CcDnld API, a binary or a hex image should be prepared to be loaded into the CC13x0 Flash.

To load data to the CC13x0 flash following must be performed:

  1. Set the UART send and receive data callbacks with CcDnld_init().
  2. Connect to the CC13x0 ROM bootloader with CcDnld_connect().
  3. Optionally Erase flash with CcDnld_flashEraseRange().
  4. Optionally Program flash with CcDnld_startDownload() and CcDnld_sendData().
  5. Optionally Erase flash with CcDnld_flashEraseRange().
  6. Optionally Verify flash with CcDnld_verify().

Error Handling

The CcDnld API returns the CcDnld_Status that contains a success or an error code. Table 26. lists the CcDnld_Status codes.

Table 26. CcDnld_Status Codes
Status Description
CcDnld_Status_Success Success
CcDnld_Status_Cmd_Error Invalid command
CcDnld_Status_State_Error Invalid state
CcDnld_Status_Param_Error Invalid parameter

Supported Functions

Table 27. lists the supported functions of the CcDnld API.

Table 27. CcDnld API Supported Functions
Generic API Function Description
CcDnld_init() Registers the UART read/write function points
CcDnld_connect() Connects to the CC13x0 and CC26xx ROM bootloader
CcDnld_flashEraseRange() Erases the specified flash range
CcDnld_startDownload() Sends the download command to the CC13x0 and CC26xx ROM bootloader
CcDnld_sendData() Sends program data to be program data to be programmed to the flash
CcDnld_verify() Verify a flash range with data in a buffer

Important Linux® Host-Design Considerations

In addition to a standard 2-wire UART interface, the final design should include two GPIO signals to control the CC13x0 device.

  • GPIO Signal A: used to reset or power cycle the CC13x0 device
  • GPIO Signal B: controls the masked ROM bootloader entry into the flash update mode

At power up, the CC13x0 device can be configured to read a GPIO pin and then do one of the following actions:

  1. Proceed normally.
  2. Enter bootloader or flash programmer mode.

The configuration for this feature is stored in the customer configuration (CCFG) section of the on-chip Flash memory (see the Bootloader chapter in the TI CC13x0 Technical Reference Manual for details).

Note

When running the out-of-box MAC CoProcessor binaries from the TI 15.4-Stack Linux SDK on CC13x0 LP, pressing BTN-1 on LP at boot-up will make the CC13x0 device enter bootloader mode.