ABP vs OTAA

ABP vs OTAA

This section can help you understand the differences between ABP and OTAA activation modes for LORaWAN end devices, and comprehend why using OTAA is recommended.

A DevEUI is a 64-bit unique ID assigned to an end device by the manufacturer. This value is linked to the hardware and it cannot be altered.

Unlike DevEUI, which identifies an end device globally, a 32-bit DevAddr identifies the end device within the current network and all communication after joining the network is done with it. A DevAddr value consists of NwkAddr (end device address within network) prefixed by a NwkID (network identifier).

Note: DevAddr is not unique - multiple devices can have the same DevAddr.

A DevAddr and session keys are assigned to an end device during a procedure called activation. LoRaWAN supports two modes of activating an end device: ABP (Activation By Personalization) and OTAA (Over-The-Air Activation).

ABP

In ABP activation, a fixed DevAddr and session keys for a pre-selected network are hardcoded into the end device, and they remain the same throughout the lifetime of an ABP end device. With this mode, an end device skips the join procedure which seems to be simpler, but there are quite a few limitations of using ABP, which are explained below.

OTAA

OTAA end devices are provisioned with root keys. In OTAA activation, an end device performs a join procedure with a LoRaWAN network, during which a dynamic DevAddr is assigned to an end device, and root keys are utilized to derive session keys. Hence, DevAddr and session keys change as each new session is established.

Why is OTAA better than ABP?

ABP’s drawbacks are arising as consequences of its main characteristics.

  1. ABP end devices use a fixed DevAddr.

Taking the structure of DevAddr into the account and the fact that, with ABP, NwkID is fixed, we come to the conclusion that this device can work correctly only in its predefined network. Even if a network or a cluster allows registering end devices with different DevAddr values than the ones that were assigned to that network/cluster, the Packet Broker will not route the traffic from those end devices to the right network/cluster.

Also, even if the network/cluster is assigned with additional address blocks, the Network Server will not be able to perform optimization of DevAddr allocation, hence the device matching procedure for ABP end devices will not be improved.

OTAA end devices are assigned a new DevAddr at establishing each new session. This allows them to move to different networks/clusters.

  1. ABP end devices use a fixed security session.

Frame counters associated with ABP devices should not be reset during their lifetime, otherwise the messages from those end devices may end up being dropped. When an ABP end device runs out of frame counters, it is the end of its lifetime.

Session keys are hardcoded into an ABP device, meaning that even if they leak, they cannot be rotated, which is a serious security threat.

Unlike ABP, OTAA end devices re-negotiate frame counters and session keys at establishing each new session. Hence, the lifetime of an OTAA device is not conditioned by the width of the frame counter.

For enhancing security, you can use a dedicated Join Server to handle the join flow, Network Server and Application Server authentication, store root keys and generate session keys. Using a dedicated Join Server also prevents the vendor lock-in. Another option is using Hardware Secured Elements (see ATECC608A) which prevent the exposure of keys to software, firmware, manufacturing sites, and other third parties.

  1. ABP end devices use fixed network parameters.

When registering an ABP device on The Things Stack, you will need to provide the RX1 Delay, RX1 Data Rate Offset, RX2 Data Rate Index, RX2 Frequency and a list of Factory Preset Frequencies. If these values are not correctly configured, uplinks and/or downlinks might not work.

OTAA end devices re-negotiate network parameters at establishing each new session, meaning you do not have to worry about them being misconfigured.