ST + Nimbelink Cellular IoT Dev Kit Getting Started Guide
The ThingSpace ST Micro – NimbeLink Cellular IoT Development Kit combines the ST Micro NUCLEO-L476RG microcontroller (MCU)
development board and the NimbeLink Skywire NL-M1DK modem board development kit to enable IoT device developers to evaluate the
capabilities of the STM32L4 MCU on the Verizon Wireless Cat-M1 network at a low cost. The kit delivers direct connection to ThingSpace
and other cloud servers together with a variety of sensing features.
The STM32L4 MCU enables a wide diversity of applications by exploiting low-power communication, multiway sensing, and ARM Cortex -M4 core-based
STM32L4 Series features. The support for Arduino Uno V3 connectivity provides unlimited expansion capabilities with a large choice of specialized add-on boards.
Skywire 4G LTE M Embedded Modem
The NimbeLink Skywire M1 development kit is specifically designed to help minimize the power requirement of the finished prototype. This makes the
development kit ideal for proof-of-concept, field-testable prototyping of low-power M1 IoT devices. The development kit includes a Skywire 4G LTE M
Embedded Modem and an adapter board that, among other things, combines the modem’s separate cellular UART and GPS UART into a single USB port for
easy computer access to the modem. Skywire Cat M LTE modems are among the smallest in the industry.
You can manage the ST Micro – NimbeLink Cellular IoT Development Kit using the ThingSpace device management platform whose features include:
- Cloud messaging capability
1Universal Asynchronous Receiver/Transmitter for serial communications
1. Purchase the ThingSpace ST Micro – NimbeLink Cellular IoT Development Kit from Arrow.com
2. Download and install the following tools from ST Micro onto your computer:
development environment (IDE)
that includes the ST-LINK drivers
||Tools for adding the STM32CubeMX
3. Install the appropriate IDE for the Nucleo-L476RG MCU board (we recommend Atollic TrueSTUDIO) specified in Getting started with STM32 MCU Discovery Kits software development tools.
4. Set up the SkyWire modem board as specified in the Skywire M1 Development Kit User Manual.
Connecting to the Verizon LTE Cat M1 Network
Verizon provides sample code for you to connect the NUCLEO-L476RG and the SkyWire CAT-M1 module to the Verizon Network.
Click here to view the GitHub with the sample code file.
The file has 4 public routines:
bool modem_port_init(rw_port_tx_cb tx_cb, rw_port_rx_cb rx_cb)
Initializes the port used to talk to the modem (UART in this case) by setting the baud rate, flow control mechanisms etc. It accepts
and stores two callbacks: transmit and receive.
void modem_port_tx(size_t sz, const uint8_t data)
Transmit "sz" bytes from the buffer "data". AT commands can be passed through this routine
Initialize the modem hardware. In the NimbeLink case, it sets up a GPIO on the MCU that’s connected to the modem’s reset line.
Reset the modem through hardware means.
2General Purpose Input/Output
typedef void (*rw_port_tx_cb)(size_t sz, bool err);
If "err" is unset, "sz" represents the number of bytes transmitted. "err" is set if the hardware port faced an error while transmitting the bytes.
typedef void (*rw_port_rx_cb)(size_t sz, const uint8_t data);
Port hardware received "sz" bytes. The received bytes are stored in the buffer "data". The AT interpreter framework implements this callback, usually to store & parse the received bytes.
The function "uart_pin_init" is a helper function used during initialization and is private to the file, whereas "USART1_IRQHandler" is an L476-specific UART interrupt handler.
At the top of the file are macros that define the mapping of NimbeLink pins to the MCU’s GPIOs and certain timing constants.
Integrating the Modem Sample Code into your Application
Use the following code in your application to call the script in the sample code that turns on the LTE modem and connects it to the network.
modem_hw_reset(); // To force the modem into a known state
modem_tx(8, "at+cimi\r"); // Retrieve IMSI
// Ensure command was transmitted without errors using the transmit callback (tx_cb).
// Response bytes will be received through the receive callback (rx_cb).
// Parse received bytes.
Issues connecting to the Verizon Network
If you’re having issues connecting to the Verizon network please see our frequently asked questions page.
For more Information
Please contact your distributor for information or assistance.