nRF9160: LwM2M Client

The LwM2M Client demonstrates usage of the Lightweight Machine to Machine (LwM2M) protocol to connect a Thingy:91 or an nRF9160 DK to an LwM2M server through LTE. This sample uses the LwM2M client utils library.


The sample supports the following development kits:

Hardware platforms


Board name

Build target





nRF9160 DK




Additionally, the sample requires an activated SIM card, and an LwM2M server such as Leshan Demo Server or Coiote Device Management server.


LwM2M is an application layer protocol based on CoAP over UDP. It is designed to expose various resources for reading, writing, and executing through an LwM2M server in a very lightweight environment. The client sends data such as button and switch states, accelerometer data, temperature, and GNSS position to the LwM2M server. It can also receive activation commands such as buzzer activation and light control.


The GNSS module interferes with the LTE connection. If GNSS is not needed or if the device is in an area with poor connection, disable the GNSS module. You can disable the GNSS module by setting the configuration option CONFIG_APP_GPS to n.

The following LwM2M objects are implemented in this sample:

LwM2M objects

LwM2M objects

Object ID


nRF9160 DK

LwM2M Server








Connectivity Monitoring
































Generic Sensor




Light Control




Push Button








On/Off Switch




DTLS Support

The sample has DTLS security enabled by default. You need to provide the following information to the LwM2M server before you can make a successful connection:

See server setup for instructions on providing the information to the server.

Sensor simulation

You can use the sample for obtaining actual sensor measurements or simulated sensor data for all sensors (including the accelerometer). If the sample is running on the nRF9160 DK, only simulated sensor data is available, as it does not have any of the external sensors needed for actual measurements.

For example, you can enable the CONFIG_ENV_SENSOR_USE_SIM configuration option if you require simulated data from the temperature, humidity, pressure or gas resistance sensors.


LwM2M specifies the Notify operation, which can be used to notify the server of changes to the value of a resource field, for example, the measured value of a temperature sensor. This allows active monitoring while using minimal bandwidth, as notifications can be sent with the updated values without the need for the server querying the client regularly.

To enable notifications, the server must initiate an observation request on one or more resources of interest. For more information, see Enabling notifications.

Sensor Module

The sample has a sensor module which, if enabled, reads the selected sensors, and updates the client’s resource values if it detects a sufficiently large change in one of the values. The threshold for a sufficiently large change can be configured. For example, a change in temperature of one degree Celsius.

Each sensor can be enabled separately. The sampling period and change threshold of a sensor can also be configured independently of all the other sensors.

The sensor module is intended to be used together with notifications. If notifications are enabled for a Sensor Value resource, and the corresponding sensor is enabled in the sensor module, a notification will be sent only when that value changes significantly (as specified by the change threshold). Thus, the bandwidth usage can be significantly limited, while simultaneously registering important changes in sensor values.

See the Sensor module options for information on enabling and configuring the sensor module.


When you track several resources and enable sensor module for several sensors , socket errors such as net_lwm2m_engine: Poll reported a socket error, 08 and net_lwm2m_rd_client: RD Client socket error: 5 might occur.


See Configuring your application for information about how to permanently or temporarily change the configuration.


Before building and running the sample, make sure that you complete the following steps:

  1. Select the device to be tested.

  2. Select the LwM2M server to be used for testing and register the device on it. You can also optionally enable notifications for the resources so that the resources are actively monitored by the server.

  3. Configure the application to work with the chosen LwM2M server.

Server setup

The following instructions describe how to register your device to Leshan Demo Server or Coiote Device Management server:

  1. For adding the device to the LwM2M server, complete the following steps and for adding the device to an LwM2M bootstrap server, see the procedure in registering the device to an LwM2M bootstrap server:

    1. Open the Leshan Demo Server web UI.

    2. Click on SECURITY in the upper right corner in the UI.


    4. Enter the following data and click ADD:

      • Endpoint - urn:imei:your Device IMEI

      • Security Mode - psk

      • Identity: - urn:imei:your Device IMEI

      • Key - 000102030405060708090a0b0c0d0e0f

    For registering the device to an LwM2M bootstrap server, complete the following steps:

    1. Open the Leshan Boostrap Server Demo web UI.

    2. Click on BOOTSTRAP in the top right corner.


    4. Click on Add clients configuration.

    5. Enter your Client Endpoint name - urn:imei:your device IMEI.

    6. Click NEXT and in the LWM2M Server Configuration section, enter the following data:

      • Server URL - coaps://

      • Select Pre-shared Key as the Security Mode

      • Identity - urn:imei:your device IMEI

      • Key - 000102030405060708090a0b0c0d0e0f

    7. Click NEXT and in the LWM2M Bootstrap Server Configuration section enter the following data:

      • Server URL - coaps://

      • Select Pre-shared Key as the Security Mode

      • Identity - urn:imei:your device IMEI

      • Key - 000102030405060708090a0b0c0d0e0f

      This information is used when your client connects to the server. If you choose Pre-shared Key, add the values for Identity and Key fields (the configured Identity or Key need not match the Bootstrap Server configuration). The same credentials will be provided in the Leshan Demo Server Security configuration page (see DTLS Support for instructions). If No Security is chosen, no further configuration is needed. In this mode, no DTLS will be used for the communication with the LwM2M server.

    8. After adding values for the fields under both the LwM2M Server Configuration and LwM2M Bootstrap Server Configuration tabs, click Add.


The Client Configuration page of the LWM2M Bootstrap server and the Registered Clients page of the LWM2M server display only a limited number of devices by default. You can increase the number of displayed devices from the drop-down menu associated with Rows per page. In both cases, the menu is displayed at the bottom-right corner of the Client Configuration pages.

  1. Set the server address in the client:

    1. Open src/prj.conf.

    2. Set CONFIG_APP_LWM2M_SERVER to the correct server URL:

    3. Set CONFIG_LWM2M_PEER_PORT to the port number used by the server you have chosen. Remember to set it to the port number used by the bootstrap server if bootstrap is enabled.

  2. Set CONFIG_APP_LWM2M_PSK to the hexadecimal representation of the PSK used when registering the device with the server.

Enabling notifications

Enabling notifications for a resource varies slightly from server to server. The client must be connected to the server to enable notifications. Following are the instructions for enabling notifications in the Leshan Demo server and Coiote Device Management server:

  1. Open the Leshan Demo Server web UI.

  2. Identify your device in the Clients tab and select it.

  3. Select the desired object in the menu on the left in the UI.

  4. Identify one or more resources you want to track and click OBS next to it.

    • You can track either a single resource or all the resources of an object. It is recommended to track only the resources that are expected to change.

    • If you want to use the Sensor Module, at least the Sensor Value resource must be tracked for all sensors enabled in the Sensor Module.

Configuration options

Check and configure the following configuration options for the sample:

Server options

CONFIG_APP_LWM2M_SERVER - Configuration for LwM2M server URL

The sample configuration sets the URL of the LwM2M server to be used. The URL must not be prefixed with the application protocol.

CONFIG_APP_LWM2M_PSK - Configuration for Pre-Shared Key

The sample configuration is used to set the hexadecimal representation of the PSK used when registering the device with the server.

CONFIG_APP_ENDPOINT_PREFIX - Configuration for setting prefix for endpoint name

This configuration option changes the prefix of the endpoint name.

LwM2M objects options

CONFIG_APP_TEMP_SENSOR - Configuration for enabling an LwM2M Temperature sensor object

The sample configuration is used to enable an LwM2M Temperature sensor object. All compatible objects are enabled by default. Disabled objects will not be visible in the server. This configuration option can be used for other LwM2M objects also by modifying the option accordingly.

CONFIG_APP_GPS - Configuration for enabling GNSS functionality

This configuration might interfere with LTE if the GNSS conditions are not optimal. Disable this option if GNSS is not needed.

CONFIG_GPS_PRIORITY_ON_FIRST_FIX - Configuration for prioritizing GNSS over LTE during the search for first fix.

Enabling this option makes it significantly easier for the GNSS module to find a position but will also affect performance for the rest of the application during the search for first fix.

CONFIG_ENV_SENSOR_USE_SIM - Configuration to enable simulated sensor data

The configuration when enabled, makes the sensor returns simulated data and not actual measurements. This option is available for all sensors, including the accelerometer.

CONFIG_LWM2M_IPSO_APP_COLOUR_SENSOR_VERSION_1_0 - Configuration for selecting the IPSO Color sensor object version

The configuration option sets the version of the OMA IPSO object specification that is to be used by the user defined Color sensor IPSO object to 1.0.

CONFIG_LWM2M_IPSO_APP_COLOUR_SENSOR_VERSION_1_1 - Configuration for selecting the IPSO Color sensor object version

The configuration option sets the version of the OMA IPSO object specification that is to be used by the user defined Color sensor IPSO object to 1.1.

CONFIG_APP_CUSTOM_VERSION - Configuration to set custom application version reported in the Device object

The configuration option allows to specify custom application version reported to the LwM2M server. By default, the current nRF Connect SDK version is used.

Sensor module options

CONFIG_SENSOR_MODULE - Configuration for periodic sensor reading

This configuration option enables periodic reading of sensors and updating the resource values when the change is sufficiently large. The server is notified if a change in one or more resources is observed.

CONFIG_SENSOR_MODULE_TEMP - Configuration to enable Temperature sensor

This configuration option enables the Temperature sensor in the Sensor Module.

CONFIG_SENSOR_MODULE_TEMP_PERIOD - Configuration for interval between sensor readings

This configuration option sets the time interval (in seconds) between sensor readings from the Temperature sensor.

CONFIG_SENSOR_MODULE_TEMP_DELTA_INT - Configuration for setting required change

This configuration option sets the required change (integer part) in sensor value before the corresponding resource value is updated.

CONFIG_SENSOR_MODULE_TEMP_DELTA_DEC - Configuration for setting required change

This configuration option sets the required change (decimal part) in sensor value before the corresponding resource value is updated.


You can use the configuration options for different sensor types by modifying the configuration options accordingly.

Additional configuration

Check and configure the following LwM2M options that are used by the sample:


Changing lifetime might not work correctly if you set it to a value beyond 60 seconds. It might cause resending message error and eventually timeout.

For Thingy:91, configure the ADXL362 accelerometer sensor range by choosing one of the following options (default value is ±2 g):

Resolution depends on range: ±2 g has higher resolution than ±4 g, which again has higher resolution than ±8 g.

Configuration files

The sample provides predefined configuration files for typical use cases.

The following files are available:

  • prj.conf - Standard default configuration file

  • overlay-queue - Enables LwM2M Queue Mode support

  • overlay-bootstrap.conf - Enables LwM2M bootstrap support

The sample can either be configured by editing the prj.conf file and the relevant overlay files, or through menuconfig or guiconfig.

Building and running

This sample can be found under samples/nrf9160/lwm2m_client in the nRF Connect SDK folder structure.

The sample is built as a non-secure firmware image for the nrf9160dk_nrf9160_ns build target. Because of this, it automatically includes the Secure Partition Manager. You can also configure it to use TF-M instead of SPM.

See Building and programming an application for information about how to build and program the application.

After building and running the sample, you can locate your device in the server:

  • Leshan - Devices are listed under Clients.

  • Coiote - Devices are listed under Device inventory.

Queue Mode support

To use the LwM2M Client with LwM2M Queue Mode support, build it with the -DOVERLAY_CONFIG=overlay-queue.conf option:

west build -b nrf9160dk_nrf9160_ns -- -DOVERLAY_CONFIG=overlay-queue.conf

Bootstrap support

To successfully run the bootstrap procedure, the device must first be registered in the LwM2M bootstrap server. See Registering your device to an LwM2M boot strap server for instructions.

To build the LwM2M Client with LwM2M bootstrap support, build it with the -DOVERLAY_CONFIG=overlay-bootstrap.conf option:

west build -b nrf9160dk_nrf9160_ns -- -DOVERLAY_CONFIG=overlay-bootstrap.conf

See Providing CMake options for instructions on how to add this option. Keep in mind that the used bootstrap port is set in the aforementioned configuration file.


After programming the sample to your development kit, test it by performing the following steps:

  1. Connect the kit to the computer using a USB cable. The kit is assigned a COM port (Windows) or ttyACM device (Linux), which is visible in the Device Manager.

  2. Connect to the kit with a terminal emulator (for example, PuTTY). See How to connect with PuTTY for the required settings.

  3. Observe that the sample starts in the terminal window.

  4. Check that the device is connected to the chosen LwM2M server.

  5. Press Button 1 on nRF9160 DK or SW3 on Thingy:91 and confirm that the button event appears in the terminal.

  6. Check that the button press event has been registered on the LwM2M server by confirming that the press count has been updated.

  7. Retrieve sensor data from various sensors and check if values are reasonable.

  8. Test GNSS module:

    1. Ensure that CONFIG_GPS_PRIORITY_ON_FIRST_FIX is enabled.

    2. Ensure that you are in a location with good GNSS signal, preferably outside.

    3. Wait for the GNSS to receive a fix, which will be displayed in the terminal. It might take several minutes for the first fix.

  9. Try to enable or disable some sensors in menuconfig and check if the sensors appear or disappear correspondingly in the LwM2M server.

Firmware Over-the-Air (FOTA)

You can update the firmware of the device if you are using Coiote Device Management server or Leshan server. Application firmware updates and modem firmware (both full and delta) updates are supported.

To update the firmware, complete the following steps:

  1. Identify the firmware image file to be uploaded to the device. See LTE modem and FOTA upgrades for more information.

  2. Open Coiote Device Management server and click LwM2M firmware.

  3. Click Schedule new firmware upgrade.

  4. Click Upload file in the bottom left corner and upload the firmware image file.

  5. Configure the necessary firmware update settings in the menu to the right.

  6. Click Upgrade.

  7. Observe in the terminal window that the image file is being downloaded. The download will take some time. If the server lifetime is not increased, Coiote might drop the connection to the device. The device reconnects later.

  8. When the download is complete, the device restarts on its own after installing the firmware. Restart the device manually if it has not started automatically. The device runs the updated firmware and reconnects to Coiote Device Management server automatically.


This application uses the following nRF Connect SDK libraries and drivers:

It uses the following sdk-nrfxlib library:

It uses the following Zephyr libraries:

In addition, it uses the following sample: