

# DINFOX SYSTEM TECHNICAL DESCRIPTION

DIN rail modules for power management

Local control and monitoring by HMI or serial link

Remote control and monitoring by long range radio





# **Revision history**

| Doc   | Date       | Author(s) / Reviewer(s) | Description                                                                                                                                       |  |  |  |
|-------|------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| td1.0 | 2025/06/07 | Ludovic Lesur           | $Initial\ version.$                                                                                                                               |  |  |  |
| td1.1 | 2025/07/20 | Ludovic Lesur           | Add RS485-BRIDGE board in nodes list. Add CVF registers and flag on BPSM and BCM nodes. Add shunt resistor field in FLAGS_1 register of BCM node. |  |  |  |

# Version compatibility table

| Doc   | una-lib | una-at  | una-r4s8cr | lmac-driver | dinfox-<br>registers | dmm           | dsm     |
|-------|---------|---------|------------|-------------|----------------------|---------------|---------|
| td1.0 | sw2.2   | ≥ sw5.0 | ≥ sw1.0    | ≥ sw3.0     | sw2.0                | sw6.4 ▶ sw6.5 | sw7.3   |
| td1.1 | ≥ sw3.0 | ≥ sw5.0 | ≥ sw1.0    | ≥ sw3.0     | ≥ sw3.1              | ≥ sw6.6       | ≥ sw7.7 |



# Contents

| 1 | GIO | ai architecture                   | •    |
|---|-----|-----------------------------------|------|
|   | 1.1 | Introduction                      |      |
|   | 1.2 | Functional description            |      |
|   |     |                                   |      |
| 2 | Noc | e identification                  | (    |
|   | 2.1 | Node types                        | . (  |
|   | 2.2 | Node address (NODE_ADDR)          | . (  |
|   |     | 2.2.1 DINFox nodes                |      |
|   |     |                                   |      |
|   |     | 2.2.2 External nodes              |      |
|   | 2.3 | Board identifier (BOARD_ID)       |      |
|   | 2.4 | Nodes list                        | . '  |
|   | _   |                                   |      |
| 3 |     | description                       | 8    |
|   | 3.1 | OSI model                         |      |
|   | 3.2 | Physical layer (RS485)            | . 9  |
|   |     | 3.2.1 DINFox nodes                | . 9  |
|   |     | 3.2.2 External nodes              | . 9  |
|   | 3.3 | Data link layer                   | . 10 |
|   |     | 3.3.1 DINFox nodes (UART)         | . 10 |
|   |     | 3.3.2 External nodes              |      |
|   | 3.4 | Network layer                     |      |
|   | 5.4 |                                   |      |
|   |     | 3.4.1 DINFox nodes (LMAC)         |      |
|   |     | 3.4.2 External nodes              |      |
|   | 3.5 | Transport layer                   | . 12 |
|   |     | 3.5.1 DINFox nodes (UNA-AT)       | . 12 |
|   |     | 3.5.2 External nodes              | . 15 |
|   |     |                                   |      |
| 4 | Noc | es registers                      | 13   |
|   | 4.1 | Physical data representation      | . 13 |
|   |     | 4.1.1 Bit                         | . 13 |
|   |     | 4.1.2 Time                        | . 13 |
|   |     | 4.1.3 Temperature                 | . 14 |
|   |     | 4.1.4 Voltage                     |      |
|   |     | 4.1.5 Current                     |      |
|   |     |                                   |      |
|   |     | 4.1.6 Electrical power            |      |
|   |     | 4.1.7 Electrical energy           |      |
|   |     | 4.1.8 Power factor                | . 10 |
|   |     | 4.1.9 RF power                    | . 10 |
|   |     | 4.1.10 Year                       | . 10 |
|   | 4.2 | DINFox nodes                      | . 1' |
|   |     | 4.2.1 Common registers set        | . 1' |
|   |     | 4.2.2 LVRM specific registers set | . 23 |
|   |     | 4.2.3 BPSM specific registers set |      |
|   |     |                                   |      |
|   |     | 4.2.4 DDRM specific registers set |      |
|   |     | 4.2.5 UHFM specific registers set |      |
|   |     | 4.2.6 GPSM specific registers set | . 43 |
|   |     | 4.2.7 SM specific registers set   | . 50 |
|   |     | 4.2.8 RRM specific registers set  | . 55 |
|   |     | 4.2.9 DMM specific registers set  | . 58 |



# DINFox system technical description

Ref: TD-DFX Revision: td1.1 Date: 2025/07/20

|   |     | 4.2.10 MPMCM specific registers set | Ю   |
|---|-----|-------------------------------------|-----|
|   |     | 4.2.11 BCM specific registers set   | 73  |
|   | 4.3 | External nodes                      | 79  |
|   |     | 4.3.1 R4S8CR specific registers set | 79  |
|   | 4.4 | Bus enumeration                     | 81  |
|   |     | 4.4.1 DINFox nodes                  | 81  |
|   |     | 4.4.2 External nodes                | 81  |
| 5 | Rac | lio link description                | 82  |
|   | 5.1 | RF performances                     | 82  |
|   | 5.2 | Remote monitoring (uplink)          | 82  |
|   | 5.3 | Remote control (downlink)           | 83  |
|   |     | 5.3.1 No-operation (NOP)            | 83  |
|   |     | 5.3.2 Single full read              | 84  |
|   |     | 5.3.3 Single full write             | 84  |
|   |     | 5.3.4 Single masked write           | 84  |
|   |     | 5.3.5 Temporary full write          | 84  |
|   |     | 5.3.6 Temporary masked write        | 84  |
|   |     | 5.3.7 Successive full write         | 85  |
|   |     | 5.3.8 Successive masked write       | 85  |
|   |     | 5.3.9 Dual full write               | 85  |
|   |     | 5.3.10 Triple full write            | 85  |
|   |     | 5.3.11 Dual node write              | 85  |
| 6 | Em  | bedded software                     | 86  |
|   | 6.1 | DINFox master node (DMM)            | 86  |
|   | 6.2 | DINFox slave nodes (DSM)            | 87  |
| 7 | Har | rdware design                       | 88  |
|   | 7.1 | Power supply                        | 88  |
|   |     | 7.1.1 LDO regulator                 | 88  |
|   |     | 7.1.2 Schottky diodes               | 89  |
|   |     | 7.1.3 MCU                           | 89  |
|   |     | 7.1.4 RS485 transceiver             | 90  |
|   |     | 7.1.5 VRS voltage                   | 90  |
|   |     | 7.1.6 Power consumption             | 90  |
|   | 7.0 | Machanical anadification            | 0.1 |



# 1 Global architecture

#### 1.1 Introduction

The main goal of the DINFox project is to design a scalable power system in order to control and monitor any kind of power supply (AC line, solar panel, backup, regulators, relays, etc.).

This main idea can be split in several objectives:

- ▶ Design a **single module for a given function** (1 board for 1 relay for instance) and use a **common physical bus** to perform the communication between boards. Thanks to this modular approach, each DINFox system can be composed of a custom group of nodes according to the required features.
- ▶ Provide a mechanical design in such a way that the boards can be fixed to a DIN rail and can be stacked together without additional wiring.
- ▶ Define a unified interface to access all nodes in order to manage a single API for local control and monitoring.
- ▶ Achieve the minimum power consumption to be able to monitor backup sources such as battery powered systems.

#### 1.2 Functional description

A DINFox system consists of several DIN rail modules, called **nodes**, physically connected through an RS485 bus. The general behavior of the system is controlled by one **master** module which is the master of the RS485 bus. All other nodes are **slaves**, they are continuously listening on the bus to wait for commands.

The DINFox system is a concrete implementation of the **Unified Node Access (UNA)** framework: all nodes of the bus are controlled through a set of registers regardless of the physical interface.



Figure 1: Functional architecture of a DINFox system.



# 2 Node identification

# 2.1 Node types

There are two categories of nodes:

- ▶ DINFox nodes: boards that were specifically designed for this project.
- ▶ External nodes: existing products with RS485 interface which can be managed on the same bus.

# 2.2 Node address (NODE\_ADDR)

Since all the boards of a DINFox system are connected through an RS485 bus, each node must have a unique address.

DINFox nodes are based on the STM32L0 and STM32G4 families from ST-Microelectronics. The LPUART peripheral of these MCUs features a wake-up capability from stop mode where address recognition is performed by hardware. This is very suited to optimize the node power consumption, since the core will be woken-up only if a command was sent to its address. But this feature requires the most significant bit to be set, so that the usable address range is on the 7 lower bits.

As a consequence, each node attached to a DINFox bus has a **unique 7 bits address** (NODE\_ADDR). All address values between **0x00** and **0x7E** are allowed, **0x7F** being used by the LMAC protocol (see section **3.4.1**).

By convention, the address 0x00 is reserved for the master node.

#### 2.2.1 DINFox nodes

Even if there is no constraint on the address mapping for the slave nodes, some values and ranges have been assigned to each node type to facilitate address management when flashing the boards (see table 1).

#### 2.2.2 External nodes

#### 2.2.2.1 KMTronic R4S8CR

The R4S8CR is a relay box manufactured by KMTronic. It is identified by **4 bits ID**, configurable with DIP switches. In order to be compatible with the DINFox system, a 7 bits address has been assigned accordingly: the 0x70 - 0x7E address range has been reserved for this product, where the 4 lower bits of the address correspond to (relay box ID -1). For example, the relay box configured with ID 13 has the 0x7C address assigned.

This address is virtual from a physical point of view: it is only known by the high level layers to identify the node in the system, but is not used in the physical layer.

# 2.3 Board identifier (BOARD\_ID)

As part of the UNA framework, each distinct hardware module has a **unique 8 bits board identifier** (BOARD\_ID). This value is used by the master to enumerate dynamically the slave nodes attached to the bus and their specific features (function, capabilities, set of registers, input controls, output data, radio messages format, etc.).

On a given DINFox system, each node must have a unique address, but several nodes can have the same BOARD\_ID: for example, 3 independent relays will have 3 different addresses but the same board identifier, since this is the same module from an hardware point of view.

The board identifiers have been assigned in chronological order during hardware design. They are defined in the **UNA library** which is available on GitHub: https://github.com/Ludovic-Lesur/una-lib.



# 2.4 Nodes list

The table below shows the list of nodes which are currently supported by the DINFox system. DINFox nodes are marked in green whereas external nodes are in orange.

| BOARD_ID | Node              | Description                                        | Width | Input controls                  | Output data                                                                                                          | NODE_ADDR   |
|----------|-------------------|----------------------------------------------------|-------|---------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------|
| 0x00     | LVRM              | Low voltage relay module                           | 3U    | Relay state                     | Relay state, $V_{COM}$ , $V_{OUT}$ , $I_{OUT}$ , $V_{MCU}$ , $T_{MCU}$                                               | 0x20 - 0x27 |
| 0x01     | BPSM              | Backup power<br>supply module                      | 3U    | Charge enable,<br>backup enable | Charge enabled, Charge status, backup enabled, $V_{SRC}$ , $V_{STR}$ , $V_{BKP}$ , $V_{MCU}$ , $T_{MCU}$             | 0x02        |
| 0x02     | DDRM              | DC-DC converter module                             | 3U    | DC-DC state                     | DC-DC state, $V_{IN}$ , $V_{OUT}$ , $I_{OUT}$ , $V_{MCU}$ , $T_{MCU}$                                                | 0x28 - 0x2F |
| 0x03     | UHFM              | 433 / 868 <i>MHz</i><br>UHF modem                  | 4U    | Radio TX / RX<br>commands       | Radio RX data, $V_{RF}$ , $V_{MCU}$ , $T_{MCU}$                                                                      | 0x03        |
| 0x04     | GPSM              | GPS module                                         | 3U    | Geo-location /<br>time commands | Geo-location, time, $V_{ANT}$ , $V_{GPS}$ , $V_{MCU}$ , $T_{MCU}$                                                    | 0x04        |
| 0x05     | SM                | Sensors module                                     | 3U    | Digital outputs<br>state        | Digital and analog inputs state, $T_{AMB}$ , $H_{AMB}$ , $V_{MCU}$ , $T_{MCU}$ , external sensors data               | 0x05        |
| 0x06     | RS485 –<br>BRIDGE | RS485 to UART /<br>USB interface                   | 2U    | _                               | _                                                                                                                    | 0x01        |
| 0x07     | RRM               | Rectifier and regulator module                     | 3U    | Regulator state                 | $V_{IN}, V_{OUT}, I_{OUT}, V_{MCU}, \ T_{MCU}$                                                                       | 0x30 - 0x37 |
| 0x08     | DMM               | DINFox master<br>module                            | 4U    | _                               | Number of nodes, $V_{USB}$ , $V_{HMI}$ , $V_{RS}$ , $V_{MCU}$ , $T_{MCU}$                                            | 0x00        |
| 0x09     | MPMCM             | Mains power<br>monitoring and<br>controller module | 5U    | _                               | $V_{MAIN}, P_{MAINx}, V_{MCU}, \ T_{MCU}$                                                                            | 0x06        |
| 0x0A     | R4S8CR            | Relay box from<br>KMTronic                         | _     | Relays state                    | Relays state                                                                                                         | 0x70 - 0x7E |
| 0x0B     | ВСМ               | Battery charger<br>module                          | 4U    | Charge enable,<br>backup enable | Charge enabled, Charge status, backup enabled, $V_{SRC}$ , $V_{STR}$ , $I_{STR}$ , $V_{BKP}$ , $V_{MCU}$ , $T_{MCU}$ | 0x07        |

Table 1: DINFox system nodes list.



# 3 Bus description

# 3.1 OSI model

The figure below shows the OSI model implementation of the DINFox bus. There are 3 main groups of layers:

- ▶ On a hardware point of view, all the nodes are physically connected on a shared RS485 bus.
- ▶ Then, the data link, network and transport layers are **specific to the board**: DINFox nodes use the UART, LMAC and UNA-AT protocols, whereas external nodes have custom interfaces imposed by the product manufacturer.
- ► Finally, the application layer **unifies the node access methods** by using 32-bits software registers regardless of the lower layers, as specified in the UNA framework.



Figure 2:  $OSI \ model \ of \ the \ DINFox \ bus.$ 



# 3.2 Physical layer (RS485)

All the nodes of a DINFox system are **physically connected on a shared RS485 bus** composed of 2 differential signals (named A and B).

| Parameter            | Value                            |  |  |
|----------------------|----------------------------------|--|--|
| Differential voltage | 3.0V                             |  |  |
| Data rate            | Node-dependent (see section 3.3) |  |  |

Table 2: RS485 parameters.

#### 3.2.1 DINFox nodes

To reach a very low power consumption, DINFox nodes are based on the MAX3471 transceiver from Maxim Integrated, which is always powered by a  $3.0\,V$  voltage regulator. This is the reason why the differential voltage of the RS485 is fixed to  $3.0\,V$  as mentioned before.

Additionally, DINFox nodes use a 4 wires link composed of a common power supply rail  $(V_{RS})$ , the ground (GND) and the two signals of the RS485 differential pair (A and B). These signals are grouped on a 4 pins connector on both edges of the PCB, so that multiple nodes can be **stacked on a DIN rail** without any wire.



Figure 3: RS485 connectors pin-out of DINFox nodes.

#### 3.2.2 External nodes

To be compatible with the DINFox system, the only requirement of an external node is to support RS485 communication with a differential voltage of 3.0 V, which is imposed by the master node (DMM board).

Depending on the power input specifications, external nodes can either be supplied by the  $V_{RS}$  rail or by an external source.



# 3.3 Data link layer

# 3.3.1 DINFox nodes (UART)

DINFox nodes use the UART standard to transfer data over the RS485 bus, with the following parameters.

| Parameter            | Value      |  |  |
|----------------------|------------|--|--|
| Number of start bits | 1          |  |  |
| Number of data bits  | 8          |  |  |
| Number of stop bits  | 1          |  |  |
| Parity               | None       |  |  |
| Baud rate            | 1200 bauds |  |  |

Table 3: DINFox nodes UART parameters.

#### 3.3.1.1 Slave nodes

On slave nodes, the LPUART peripheral of the MCU is clocked by an external  $32.768\,kHz$  quartz. The internal baud rate generator for TX and RX operations is also deriving from this quartz. Since the input frequency is low, the baud rate value has to be limited to avoid jitter on the signal. At 9600 bauds, there are only 4 clock cycles from the  $32.768\,kHz$ : the resulting signal has a very poor duty cycle stability, leading to bit transmission or reception errors on the RS485 bus. To improve transfer robustness, the baud rate for DINFox nodes has thus been reduced to **1200 bauds**.

#### 3.3.1.2 Master node

Since the master node initiates all the transfers and is never in a continuous reception state, there is no need to keep the LPUART active in stop mode, the RS485 transceiver can be switched off when there is no pending operation. Therefore, the master node can use a high speed clock source when transmitting on the RS485 bus, so that it can communicate with external nodes at higher band rates without any jitter issue.

#### 3.3.2 External nodes

#### 3.3.2.1 KMTronic R4S8CR

R4S8CR protocol is based on the UART standard to transfer data over the RS485 bus, with the following parameters.

| Parameter            | Value      |  |  |
|----------------------|------------|--|--|
| Number of start bits | 1          |  |  |
| Number of data bits  | 8          |  |  |
| Number of stop bits  | 1          |  |  |
| Parity               | None       |  |  |
| Baud rate            | 9600 bauds |  |  |

Table 4: R4S8CR UART parameters.

## 3.4 Network layer

#### 3.4.1 DINFox nodes (LMAC)

The nodes specifically designed for the DINFox system use a custom protocol called **LMAC** (Light Media Access Control), which adds the minimum overhead to transfer 7-bits data between two nodes.

The LMAC protocol is provided as a cross-platform C library and is available on GitHub: https://github.com/Ludovic-Lesur/lmac-driver. It is embedded as a Git sub-module in the nodes firmware.

An LMAC frame is composed of the following fields:

- ▶ The first byte of the frame is the **destination address** of the packet. It must have the **most significant bit set to 1** in order to be recognized as an address (see section **2.2**). All other bytes must have the most significant bit set to 0.
- ▶ The second byte is the **source address**, in other words the address of the node which is transmitting the packet. For a slave node, this field is used to know at which address the response has to be sent. For the master node, it is used to check that the response comes from the expected slave.
- ▶ Next bytes are the data.
- ▶ Then there is a **16-bits checksum** composed of the CKH and CKL fields. It is computed over all the previous bytes using the **Fletcher algorithm**.
- ▶ The frame finally ends with a specific marker **0x7F** which must not be used in any other byte: in particular, the **address 0x7F** is **forbidden** because the source address would be erroneously read as the end marker.



Table 5: LMAC frame structure.

#### 3.4.2 External nodes

#### 3.4.2.1 KMTronic R4S8CR

The R4S8CR relay box uses a custom protocol where the address is not managed by the network layer, but by the transport layer with the commands content. Indeed, each address corresponds to one relay rather than one box, so that multiple boxes can be connected on the same bus. However, all the frames start with a **0xFF** header.



Table 6: R4S8CR frame structure.



## 3.5 Transport layer

#### 3.5.1 DINFox nodes (UNA-AT)

On top of the network protocol, nodes communication is performed through **AT commands** which are transferred in ASCII format in the **DATA** field of the LMAC frame. As part of the UNA framework, the aim of this interface is to read and write 32 bits registers in order to control or monitor the node (see section 4). The commands are sent by the master node and will always be followed by a reply from the queried slave.

All DINFox nodes must support the following commands set. Mandatory fields are marked in orange, optional ones are marked in green. All values, addresses, masks and codes are in **hexadecimal representation** from 2 to 8 characters (1 to 4 bytes value). All AT commands and replies end with a single **CR character** (0x0D ASCII code).

The UNA-AT protocol is provided as a cross-platform C library and is available on GitHub: https://github.com/Ludovic-Lesur/una-at. It is embedded as a Git sub-module in the nodes firmware.

| Command           | Syntax                                                                              | Parameters                                                                                                                                                         | Reply                                                            |
|-------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| Read<br>register  | AT\$R= <reg_addr><cr></cr></reg_addr>                                               | <pre><reg_addr> : Register address to read.</reg_addr></pre>                                                                                                       | <reg_value><cr> or ERROR_<code><cr></cr></code></cr></reg_value> |
| Write<br>register | AT\$W= <reg_addr>,<reg_value>,<reg_mask><cr></cr></reg_mask></reg_value></reg_addr> | <pre><reg_addr> : Register address to write. <reg_value> : Value to write in register. <reg_mask> : Optional writing mask.</reg_mask></reg_value></reg_addr></pre> | OK <cr> Or ERROR_<code><cr></cr></code></cr>                     |

Table 7:  $\mathit{UNA}\text{-}\mathit{AT}$  commands set.

When an error occurs during a command execution, the slave replies ERROR\_<code><CR> on the bus, where <code> is always a 16 bits hexadecimal value. This error code is also stored in the slave errors stack, which can be read later on by the master (see section 4.2.1.6). The error will also be notified through dedicated status bits or a specific error value in the involved register.

#### 3.5.2 External nodes

## 3.5.2.1 KMTronic R4S8CR

The R4S8CR commands are detailed in the following table, where all syntax is written in **hexadecimal format**. This protocol is implemented in a cross-platform C driver available on GitHub: https://github.com/Ludovic-Lesur/r4s8cr-driver. It is embedded as a Git sub-module in the master node firmware.

| Command     | Syntax                             | Parameters                                                                                         | Reply                                                                                                                                                                                                      |
|-------------|------------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read relays | A <relay_box_id>00</relay_box_id>  | <pre><relay_box_id> : 4 bits relay box ID.</relay_box_id></pre>                                    | A <relay_box_id><r1st><r2st><r3st> <r4st><r5st><r6st><r7st><r8st> <rxst>: 00 if the relay x is off, 01 if the relay x is on.</rxst></r8st></r7st></r6st></r5st></r4st></r3st></r2st></r1st></relay_box_id> |
| Write relay | <relay_id><rxst></rxst></relay_id> | <pre><relay_id> : 8 bits relay ID.</relay_id></pre> <rxst> : 00 to turn off, 01 to turn on.</rxst> | None.                                                                                                                                                                                                      |

Table 8: R4S8CR commands set.

#### Note:



# 4 Nodes registers

Nodes input controls and output data are accessed through a **set of registers** (up to 32 bits value), that can be read and/or written by the master module.

# 4.1 Physical data representation

Custom representations have been defined for physical data, in order to align fields on 8 bits and optimize their size, reducing RS485 frame lengths and power consumption when sending data through radio.

All conversion functions between physical values and custom representations are defined in the cross-platform Unified Node Access library (UNA-LIB) which is available in a GitHub repository: https://github.com/Ludovic-Lesur/una-lib.

#### 4.1.1 Bit

A single bit is represented by a 2-bits value with the following mapping.

| VALUE[1:0] | Meaning                                               |  |
|------------|-------------------------------------------------------|--|
| 0b00       | Bit was successfully read as 0.                       |  |
| 0b01       | Bit was successfully read as 1.                       |  |
| 0b10       | Bit is not readable because it is forced by hardware. |  |
| 0b11       | Error occurred during bit reading (error value).      |  |

Table 9: Bit representation.

#### 4.1.2 Time

| 7                   | 6              | 5          | 4 | 3           | 2           | 1 | 0 |
|---------------------|----------------|------------|---|-------------|-------------|---|---|
| UNIT[1:0]           |                | VALUE[5:0] |   |             |             |   |   |
| <b>0b00</b> : se    | 0b00 : seconds |            |   | Raw value ( | 0-63  range |   |   |
| <b>0b01</b> : m     | 0b01 : minutes |            |   |             |             |   |   |
| <b>0b10</b> : hours |                |            |   |             |             |   |   |
| 0b11:               | days           |            |   |             |             |   |   |

Table 10: 8-bits time representation.

The available time ranges are the following:

- $\blacktriangleright\ \sim [\,0-1\ \mathrm{minute}\,]$  with 1 second resolution.
- $\blacktriangleright\ \sim [\,0-1\ \mathrm{hour}\,]$  with 1 minute resolution.
- $\triangleright \sim [0-2.5 \text{ days}]$  with 1 hour resolution.
- ightharpoonup ~ [0-2 months] with 1 day resolution.
- ► 0xFF is used as error value.



## 4.1.3 Temperature

| 7                     | 6 | 5 | 4           | 3                          | 2            | 1 | 0 |
|-----------------------|---|---|-------------|----------------------------|--------------|---|---|
| SIGN                  |   |   |             | VALUE[6:0]                 |              |   |   |
| 0b0 : positive        |   |   | Raw absolut | te value in $^{\circ}C$ (0 | - 127 range) |   |   |
| <b>0b1</b> : negative |   |   |             |                            |              |   |   |

Table 11: 8-bits temperature representation.

The available temperature range is the following:

- ▶ -127 °C to +126 °C with 1°C resolution.
- ightharpoonup 0x7F is used as error value.

## 4.1.4 Voltage

| 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6       | 5   | 4 | 3 | 2 | 1 | 0 |
|--------------------|----|----|----|----|----|----|---------|----------|---------|-----|---|---|---|---|---|
| UNIT               |    |    |    |    |    |    | VA      | LUE[14:  | 0]      |     |   |   |   |   |   |
| $\mathbf{0b0}: mV$ |    |    |    |    |    | Ra | w value | (0 - 32) | 767 ran | ge) |   |   |   |   |   |
| $\mathbf{0b1}:dV$  |    |    |    |    |    |    |         |          |         |     |   |   |   |   |   |

Table 12: 16 bits voltage representation.

The available voltage ranges are the following:

- $\blacktriangleright \ \sim [\,0-32\,V\,]$  with  $1\,mV$  resolution.
- $\blacktriangleright \ \sim [\,0-3.2\,kV\,]$  with  $100\,mV$  resolution.
- ▶ 0xFFFF is used as error value.

#### 4.1.5 Current



Table 13: 16 bits current representation.

The available current ranges are the following:

- $\blacktriangleright~\sim [\,0-16\,mA\,]$  with  $1\,\mu A$  resolution.
- $\blacktriangleright \ \sim [\,0-1.6\,A\,]$  with  $100\,\mu A$  resolution.
- $\blacktriangleright \ \sim [\,0-16\,A\,]$  with  $1\,mA$  resolution.
- $\blacktriangleright\ \sim [\,0-1.6\,kA\,]$  with  $100\,mA$  resolution.
- ▶ 0xFFFF is used as error value.



#### 4.1.6 Electrical power

| 15             | 14   | 13          | 12 | 11 | 10 | 9 | 8  | 7       | 6       | 5       | 4   | 3 | 2 | 1 | 0 |
|----------------|------|-------------|----|----|----|---|----|---------|---------|---------|-----|---|---|---|---|
| SIGN           | UNIT | [1:0]       |    |    |    |   |    | VA      | LUE[12: | 0]      |     |   |   |   |   |
| 0b0 : positive | 0b00 | : <i>mW</i> |    |    |    |   | Ra | w value | (0 - 8) | 191 ran | ge) |   |   |   |   |
| 0b1 : negative | 0b01 | : dW        |    |    |    |   |    |         |         |         |     |   |   |   |   |
|                | 0b10 | : W         |    |    |    |   |    |         |         |         |     |   |   |   |   |
|                | 0b11 | : daW       |    |    |    |   |    |         |         |         |     |   |   |   |   |

Table 14: 16 bits electrical power representation.

The available power ranges are the following:

- $\blacktriangleright \ \sim [\, -8 8 \, W \,]$  with  $1 \, mW$  resolution.
- ightharpoonup ~  $[-800-800\,W]$  with  $100\,mW$  resolution.
- $\blacktriangleright\ \sim [\,-8-8\,kW\,]$  with  $1\,W$  resolution.
- $\blacktriangleright \ \sim [\, -80 80 \, kW \,]$  with  $10 \, W$  resolution.
- ▶ 0x7FFF is used as error value.

The same representation applies for VA unit.

#### 4.1.7 Electrical energy

| 15                    | 14     | 13    | 12 | 11 | 10 | 9 | 8  | 7       | 6       | 5       | 4   | 3 | 2 | 1 | 0 |
|-----------------------|--------|-------|----|----|----|---|----|---------|---------|---------|-----|---|---|---|---|
| SIGN                  | UNIT   | [1:0] |    |    |    |   |    | VA      | LUE[12: | 0]      |     |   |   |   |   |
| 0b0 : positive        | 0b00 : | mWh   |    |    |    |   | Ra | w value | (0 - 8) | 191 ran | ge) |   |   |   |   |
| <b>0b1</b> : negative | 0b01   | dWh   |    |    |    |   |    |         |         |         |     |   |   |   |   |
|                       | 0b10   | : Wh  |    |    |    |   |    |         |         |         |     |   |   |   |   |
|                       | 0b11 : | daWh  |    |    |    |   |    |         |         |         |     |   |   |   |   |

 ${\bf Table\ 15:}\ 16\ bits\ electrical\ energy\ representation.$ 

The available power ranges are the following:

- $\blacktriangleright \ \sim [\, -8 8 \, Wh \,]$  with  $1 \, mWh$  resolution.
- ightharpoonup ~ [-800 800 Wh] with 100 mWh resolution.
- $\blacktriangleright \ \sim [\, -8 8 \, kWh \,]$  with  $1 \, Wh$  resolution.
- ightharpoonup ~  $[-80 80 \, kWh]$  with  $10 \, Wh$  resolution.
- ▶ 0x7FFF is used as error value.

The same representation applies for  $V\!Ah$  unit.



#### 4.1.8 Power factor

| 7                     | 6 | 5 | 4              | 3               | 2              | 1 | 0 |
|-----------------------|---|---|----------------|-----------------|----------------|---|---|
| SIGN                  |   |   |                | VALUE[6:0]      |                |   |   |
| <b>0b0</b> : positive |   |   | Floor of absol | ute value × 100 | (0-100  range) |   |   |
| 0b1 : negative        |   |   |                |                 |                |   |   |

Table 16: 8 bits power factor representation.

The available power factor range is the following:

- ightharpoonup -1 to +1 with 0,01 resolution.
- ightharpoonup 0x7F is used as error value.

## 4.1.9 RF power



Table 17: 8 bits RF power representation.

The available RF power range is the following:

- ▶  $-174 \, dBm$  to  $+80 \, dBm$  with  $1 \, dB$  resolution.
- ▶ 0xFF is used as error value.

#### 4.1.10 Year



Table 18: 8 bits year representation.

The available year range is the following:

- $\blacktriangleright~2000$  to 2254 with 1 year resolution.
- ▶ 0xFF is used as error value.



# 4.2 DINFox nodes

DINFox nodes have a minimum registers set available on all nodes. Following the common registers, all nodes can have specific registers that contain the specific input controls or output data of the node. They are defined in the following GitHub repository: https://github.com/Ludovic-Lesur/dinfox-registers.

# 4.2.1 Common registers set

| REG_ADDR | Register name | Size | Access | Format   | Description                       |
|----------|---------------|------|--------|----------|-----------------------------------|
| 0x00     | NODE_ID       | 16   | R      | Table 20 | Node address and board ID.        |
| 0x01     | HW_VERSION    | 16   | R      | Table 21 | Node hardware version.            |
| 0x02     | SW_VERSION_O  | 32   | R      | Table 22 | Node embedded software version    |
| 0x03     | SW_VERSION_1  | 32   | R      | Table 23 | Node embedded software commit ID. |
| 0x04     | FLAGS_0       | 8    | R      | Table 24 | Common compilation flags.         |
| 0x05     | ERROR_STACK   | 16   | R      | Table 25 | Error stack.                      |
| 0x06     | STATUS_0      | 16   | R      | Table 26 | Common status register.           |
| 0x07     | CONTROL_O     | 8    | R/W    | Table 27 | Common control register.          |
| 0x08     | ANALOG_DATA_O | 32   | R      | Table 28 | Common analog data.               |

Table 19:  $DINFox\ common\ registers\ set.$ 

# 4.2.1.1 Node ID register

| 31 | 30 | 29 | 28     | 27      | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19      | 18   | 17 | 16 |
|----|----|----|--------|---------|----|----|----|----|----|----|-----|---------|------|----|----|
|    |    |    |        |         |    |    |    |    |    |    |     |         |      |    |    |
| 15 | 14 | 13 | 12     | 11      | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3       | 2    | 1  | 0  |
|    |    |    | BOARD_ | ID[7:0] |    |    |    |    |    |    | NOD | E_ADDR[ | 6:0] |    |    |

| Bits    | Size | Field     | Reset value | Description                    | Format     |
|---------|------|-----------|-------------|--------------------------------|------------|
| 31 - 16 | 16   | -         | 0x0000      | Unused.                        | _          |
| 15 - 8  | 8    | BOARD_ID  | _           | Node board ID (see table 1)    | Raw value. |
| 7       | 1    | -         | 0b0         | Unused.                        | _          |
| 6 - 0   | 7    | NODE_ADDR | _           | Node address (see section 2.2) | Raw value. |

 ${\bf Table~20:~Node~ID~register.}$ 



#### 4.2.1.2 Hardware version register

| 31 | 30 | 29 | 28    | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19     | 18 | 17 | 16 |
|----|----|----|-------|-------|----|----|----|----|----|----|-------|--------|----|----|----|
|    |    |    |       |       |    |    |    |    |    |    |       |        |    |    |    |
| 15 | 14 | 13 | 12    | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3      | 2  | 1  | 0  |
|    |    |    | MINOR | [7:0] |    |    |    |    |    |    | MAJOR | .[7:0] |    |    |    |

| Bits    | Size | Field | Reset value | Description                         | Format     |
|---------|------|-------|-------------|-------------------------------------|------------|
| 31 - 16 | 16   | _     | 0x0000      | Unused.                             | _          |
| 15 - 8  | 8    | MINOR | _           | Minor part of the hardware version. | Raw value. |
| 7-0     | 8    | MAJOR | _           | Major part of the hardware version. | Raw value. |

 ${\bf Table~21:}~ Hardware~ version~ register.$ 

#### 4.2.1.3 Software version register 0

| 31 | 30 | 29 | 28    | 27    | 26 | 25 | 24   | 23 | 22 | 21 | 20       | 19        | 18 | 17 | 16 |
|----|----|----|-------|-------|----|----|------|----|----|----|----------|-----------|----|----|----|
|    |    |    |       |       |    |    | DTYF |    |    | С  | OMMIT_II | NDEX [7:0 | )] |    |    |
| 15 | 14 | 13 | 12    | 11    | 10 | 9  | 8    | 7  | 6  | 5  | 4        | 3         | 2  | 1  | 0  |
|    |    |    | MINOR | [7:0] |    |    |      |    |    |    | MAJOR    | [7:0]     |    |    |    |

| Bits    | Size | Field        | Reset value | Description                         | Format                                                        |
|---------|------|--------------|-------------|-------------------------------------|---------------------------------------------------------------|
| 31 - 25 | 7    | -            | 0b0000000   | Unused.                             | _                                                             |
| 24      | 1    | DTYF         | _           | Git dirty flag.                     | <ul><li>0b0 : clean code.</li><li>0b1 : dirty code.</li></ul> |
| 23 - 16 | 8    | COMMIT_INDEX | _           | Git commit index.                   | Raw value.                                                    |
| 15 - 8  | 8    | MINOR        | _           | Minor part of the software version. | Raw value.                                                    |
| 7-0     | 8    | MAJOR        | _           | Major part of the software version. | Raw value.                                                    |

Table 22: Software version register 0.



#### 4.2.1.4 Software version register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22       | 21      | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----------|---------|----|----|----|----|----|
|    |    |    |    |    |    |    |         | C        | COMMIT_I | D[27:16 | ]  |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6        | 5       | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | COMMIT_ | ID[15:0] |          |         |    |    |    |    |    |

| Bits          | Size | Field     | Reset value | Description    | Format     |
|---------------|------|-----------|-------------|----------------|------------|
| 31 - 28       | 4    | -         | 0b0000      | Unused.        | _          |
| <b>27</b> – 0 | 28   | COMMIT_ID | _           | Git commit ID. | Raw value. |

 ${\bf Table~23:~Software~version~register~1.}$ 

# 4.2.1.5 Flags register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |      | _  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | NFRF | DF |

| Bits   | Size | Field | Reset value | Description             | Format                                                                                     |
|--------|------|-------|-------------|-------------------------|--------------------------------------------------------------------------------------------|
| 31 - 2 | 30   | _     | 0b0[30]     | Unused.                 | _                                                                                          |
| 1      | 1    | NFRF  | _           | NVM factory reset flag. | <ul><li>0b0 : Factory reset is disabled.</li><li>0b1 : Factory reset is enabled.</li></ul> |
| 0      | 1    | DF    | _           | Debug mode flag.        | <ul><li>0b0 : Debug mode is disabled.</li><li>0b1 : Debug mode is enabled.</li></ul>       |

Table 24: Flags register  $\theta$ .



#### 4.2.1.6 Error stack register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | ERROR | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                      | Format     |
|---------|------|-------|-------------|----------------------------------|------------|
| 31 - 16 | 16   | -     | 0x0000      | Unused.                          | -          |
| 15 - 0  | 16   | ERROR | _           | Last error code stored in stack. | Raw value. |

Table 25: Error stack register.

This register can be read multiple times to unstack all errors, until the returned value is 0.

Errors codes use a **relative base system** where each driver has its own sub-bases. When an error occur, the code is propagated to the upper layers and encapsulated in the sub-base of each calling driver until the application. This way, **all the stack trace is combined in a single 16-bits value** instead of creating multiple codes with absolute bases. This is very useful to monitor the error codes remotely, especially with a radio link which has a limited number of bytes.

Root bases are defined in each embedded software project:

- ▶ Master node: https://github.com/Ludovic-Lesur/dmm/blob/master/application/inc/error\_base.h
- ► Slave nodes: https://github.com/Ludovic-Lesur/dsm/blob/master/application/inc/error\_base.h



# 4.2.1.7 Status register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24 | 23   | 22   | 21   | 20  | 19  | 18  | 17  | 16 |
|----|----|----|----|----|----|-----|----|------|------|------|-----|-----|-----|-----|----|
|    |    |    |    |    |    |     |    |      |      |      |     |     |     |     |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7    | 6    | 5    | 4   | 3   | 2   | 1   | 0  |
|    |    |    |    |    |    | ESF | BF | LPWR | WWDG | IWDG | SFT | POR | PIN | OBL | FW |

| Bits    | Size | Field | Reset value | Description                       | Format                                                                                                                                |
|---------|------|-------|-------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 10 | 22   | -     | 0b0[22]     | Unused.                           | _                                                                                                                                     |
| 9       | 1    | ESF   | 0ь0         | MCU error stack flag.             | 0b0 : error stack is empty.<br>0b1 : error stack is not empty.                                                                        |
| 8       | 1    | BF    | 0b1         | MCU boot flag.                    | <ul><li><b>0b0</b>: MCU did not reboot since last flag clearing.</li><li><b>0b1</b>: MCU rebooted since last flag clearing.</li></ul> |
| 7       | 1    | LPWR  | _           | Low power reset flag.             | 0b0 : no LPWR reset occurred.<br>0b1 : LPWR reset occurred.                                                                           |
| 6       | 1    | WWDG  | _           | Window watchdog reset flag.       | <ul><li>0b0 : no WWDG reset occurred.</li><li>0b1 : WWDG reset occurred.</li></ul>                                                    |
| 5       | 1    | IWDG  | _           | Independent watchdog reset flag.  | 0b0 : no IWDG reset occurred.<br>0b1 : IWDG reset occurred.                                                                           |
| 4       | 1    | SFT   | _           | Software reset flag.              | <ul><li>0b0 : no SFT reset occurred.</li><li>0b1 : SFT reset occurred.</li></ul>                                                      |
| 3       | 1    | POR   | _           | Power on reset flag.              | <ul><li>0b0 : no POR reset occurred.</li><li>0b1 : POR reset occurred.</li></ul>                                                      |
| 2       | 1    | PIN   | _           | NRST pin reset flag.              | <ul><li>0b0 : no PIN reset occurred.</li><li>0b1 : PIN reset occurred.</li></ul>                                                      |
| 1       | 1    | OBL   | _           | Options bytes loading reset flag. | <ul><li>0b0 : no OBL reset occurred.</li><li>0b1 : OBL reset occurred.</li></ul>                                                      |
| 0       | 1    | FW    | _           | Firewall reset flag.              | <ul><li>0b0 : no FW reset occurred.</li><li>0b1 : FW reset occurred.</li></ul>                                                        |

Table 26: Status register 0.



#### 4.2.1.8 Control register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    | BFC | MTRG | RTRG |

| Bits   | Size | Field | Reset value | Description           | Format                                                                                                              |
|--------|------|-------|-------------|-----------------------|---------------------------------------------------------------------------------------------------------------------|
| 31 - 3 | 29   | _     | 0b0[29]     | Unused.               | _                                                                                                                   |
| 2      | 1    | BFC   | 0ь0         | MCU boot flag clear.  | <pre>0b0 : no action. 0b1 : clear boot flag (BF bit) in     status register 0.</pre>                                |
| 1      | 1    | MTRG  | 0b0         | Measure trigger flag. | 0b0: no action (W) or no pending<br>measurement (R).<br>0b1: start measurements (W) or<br>measurements pending (R). |
| 0      | 1    | RTRG  | 0b0         | Reset trigger flag.   | 0b0 : no action.<br>0b1 : trigger software reset.                                                                   |

Table 27: Control register  $\theta$ .

#### 4.2.1.9 Analog data register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23    | 22 | 21 | 20   | 19    | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|-------|----|----|------|-------|----|----|----|
|    |    |    |    |    |    |    |        |       |    |    | TMCU | [7:0] |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7     | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VMCU [ | 15:0] |    |    |      |       |    |    |    |

| Bits    | Size | Field | Reset value | Description         | Format   |
|---------|------|-------|-------------|---------------------|----------|
| 31 - 24 | 8    | -     | 0x00        | Unused.             | _        |
| 23 – 16 | 8    | TMCU  | 0x7F        | MCU temperature.    | Table 11 |
| 15 - 0  | 16   | VMCU  | 0xFFFF      | MCU supply voltage. | Table 12 |

Table 28: Analog data register 0.



# 4.2.2 LVRM specific registers set

| REG_ADDR | Register name   | Size | Access | Format   | Description                                    |
|----------|-----------------|------|--------|----------|------------------------------------------------|
| 0x09     | FLAGS_1         | 8    | R      | Table 30 | Compilation flags.                             |
| 0x0A     | CONFIGURATION_O | 32   | R/W    | Table 31 | Battery voltage thresholds for BMS mode.       |
| 0x0B     | CONFIGURATION_1 | 16   | R/W    | Table 32 | $I_{OUT}$ offset calibration value.            |
| 0x $0$ C | STATUS_1        | 8    | R      | Table 33 | Relay status.                                  |
| 0x0D     | CONTROL_1       | 8    | R/W    | Table 34 | Relay control.                                 |
| 0x0E     | ANALOG_DATA_1   | 32   | R      | Table 35 | $V_{COM}$ and $V_{OUT}$ voltages measurements. |
| 0x0F     | ANALOG_DATA_2   | 16   | R      | Table 36 | $I_{OUT}$ current measurement.                 |

Table 29: LVRM specific registers set.

# 4.2.2.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | RLFH | BMSF |

| Bits   | Size | Field | Reset value | Description                                                                  | Format                                                                                           |
|--------|------|-------|-------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 31 - 2 | 30   | _     | 0b0[30]     | Unused.                                                                      | _                                                                                                |
| 1      | 1    | RLFH  | _           | Relay control mode<br>(set at compilation<br>step according to<br>hardware). | <ul><li>0b0 : Relay controlled by the MCU.</li><li>0b1 : Relay controlled by hardware.</li></ul> |
| 0      | 1    | BMSF  | _           | BMS mode flag (set at compilation step).                                     | <ul><li>0b0 : BMS mode disabled.</li><li>0b1 : BMS mode enabled.</li></ul>                       |

Table 30: Flags register 1.



#### 4.2.2.2 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24       | 23       | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-----|----------|----------|-----|----|----|----|----|----|----|
|    |    |    |    |    |    | VBA | TT_THRE  | SHOLD_H  | IGH |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8        | 7        | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | VB  | ATT_THRI | ESHOLD_I | .OW |    |    |    |    |    |    |

| Bits    | Size | Field                | Reset value | Description                                         | Format          |
|---------|------|----------------------|-------------|-----------------------------------------------------|-----------------|
| 31 – 16 | 16   | VBATT_THRESHOLD_HIGH | _           | High voltage<br>threshold of the BMS<br>hysteresis. | Table 12        |
| 15 – 0  | 16   | VBATT_THRESHOLD_LOW  | _           | Low voltage threshold<br>of the BMS<br>hysteresis.  | Table <b>12</b> |

Table 31: Configuration register 0.

 $\underline{\mathbf{Note:}}$  this register is only used when the  $\mathtt{BMSF}$  bit is set.

#### 4.2.2.3 Configuration register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | I  | OUT_OFFS | SET[15:0 | )] |    |    |    |    |    |    |

| Bits    | Size | Field       | Reset value | Description                              | Format   |
|---------|------|-------------|-------------|------------------------------------------|----------|
| 31 - 16 | 16   | _           | 0x0000      | Unused.                                  | _        |
| 15 - 0  | 16   | IOUT_OFFSET | _           | Output current offset calibration value. | Table 13 |

 ${\bf Table~32:~} Configuration~register~1.$ 

# 4.2.2.4 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | RLS | TST |

| Bits   | Size | Field  | Reset value | Description         | Format                                                          |
|--------|------|--------|-------------|---------------------|-----------------------------------------------------------------|
| 31 - 2 | 30   | _      | 0b0[30]     | Unused.             | _                                                               |
| 1-0    | 2    | RLSTST | 0b11        | Relay state status. | Table 9 0b00 : NC or R path closed. 0b01 : NO or S path closed. |

Table 33:  $Status\ register\ 1.$ 



#### 4.2.2.5 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RLST |

| Bits   | Size | Field | Reset value | Description          | Format                                                                        |
|--------|------|-------|-------------|----------------------|-------------------------------------------------------------------------------|
| 31 - 1 | 31   | _     | 0b0[31]     | Unused.              | _                                                                             |
| 0      | 1    | RLST  | 0b0         | Relay state control. | <ul><li>0b0 : close NC or R path.</li><li>0b1 : close NO or S path.</li></ul> |

 ${\bf Table~34:~Control~register~1.}$ 

# 4.2.2.6 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | TUOV  | 15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VCOM[ | 15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                 | Format   |
|---------|------|-------|-------------|-----------------------------|----------|
| 31 - 16 | 16   | VOUT  | 0xFFFF      | Relay output voltage.       | Table 12 |
| 15 - 0  | 16   | VCOM  | 0xFFFF      | Relay common input voltage. | Table 12 |

Table 35: Analog data register 1.

# 4.2.2.7 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | IOUT[ | 15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description           | Format   |
|---------|------|-------|-------------|-----------------------|----------|
| 31 - 16 | 16   | _     | 0x0000      | Unused.               | _        |
| 15 - 0  | 16   | IOUT  | 0xFFFF      | Relay output current. | Table 13 |

Table 36: Analog data register 2.



# 4.2.3 BPSM specific registers set

| REG_ADDR | Register name   | Size | Access | Format   | Description                                    |
|----------|-----------------|------|--------|----------|------------------------------------------------|
| 0x $0$ 9 | FLAGS_1         | 8    | R      | Table 38 | Compilation flags.                             |
| 0x0A     | CONFIGURATION_O | 32   | R/W    | Table 39 | CHEN threshold and toggle period.              |
| 0x0B     | CONFIGURATION_1 | 32   | R/W    | Table 40 | Low voltage flag (LVF) thresholds.             |
| 0x $0$ C | CONFIGURATION_2 | 32   | R/W    | Table 41 | Critical voltage flag (CVF) thresholds.        |
| 0x0D     | STATUS_1        | 16   | R      | Table 42 | Charging and backup status.                    |
| 0x0E     | CONTROL_1       | 8    | R/W    | Table 43 | Charging and backup control.                   |
| 0x0F     | ANALOG_DATA_1   | 32   | R      | Table 44 | $V_{SRC}$ and $V_{STR}$ voltages measurements. |
| 0x10     | ANALOG_DATA_2   | 16   | R      | Table 45 | $V_{BKP}$ voltage measurement.                 |

 ${\it Table~37:~BPSM~specific~registers~set.}$ 

# 4.2.3.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|------|----|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |      |    |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2  | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    | BKFH |    | CSFH | CEFH |

| Bits   | Size | Field | Reset value | Description                                                                             | Format                                                                                                              |
|--------|------|-------|-------------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| 31 - 4 | 28   | _     | 0x0000000   | Unused.                                                                                 | _                                                                                                                   |
| 3      | 1    | вкғн  | _           | Backup output<br>control mode (set at<br>compilation step<br>according to<br>hardware). | <ul> <li>0b0 : Backup output controlled by the MCU.</li> <li>0b1 : Backup output controlled by hardware.</li> </ul> |
| 2      | 1    | -     | 0b0         | Unused.                                                                                 | _                                                                                                                   |
| 1      | 1    | CSFH  | _           | Charge status mode (set at compilation step according to hardware).                     | <ul> <li>0b0 : Charge status connected to the MCU.</li> <li>0b1 : Charge status connected in hardware.</li> </ul>   |
| 0      | 1    | CEFH  | _           | Charge control mode (set at compilation step according to hardware).                    | <ul> <li>0b0 : Charge controlled by the MCU.</li> <li>0b1 : Charge controlled by hardware.</li> </ul>               |

Table 38: Flags register 1.



# 4.2.3.2 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20      | 19      | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|---------|----|----|---------|---------|----|----|----|
|    |    |    |    |    |    |    |         |         |    | CH | EN_TOGG | LE_PERI | OD |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7       | 6  | 5  | 4       | 3       | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CHEN_TH | RESHOLD |    |    |         |         |    |    |    |

| Bits    | Size | Field              | Reset value | Description                        | Format   |
|---------|------|--------------------|-------------|------------------------------------|----------|
| 31 - 24 | 8    | _                  | 0x00        | Unused.                            | _        |
| 23 – 16 | 8    | CHEN_TOGGLE_PERIOD | _           | Charge toggle period.              | Table 10 |
| 15 – 0  | 16   | CHEN_THRESHOLD     | _           | Voltage threshold to set CHEN bit. | Table 12 |

Table 39: Configuration register 0.

 $\underline{\mathbf{Note:}}$  this register is only used when CHMD = 0b1 and CEFH = 0b0.

#### 4.2.3.3 Configuration register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | LV | F_HIGH_ | THRESHO  | LD |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | L  | VF_LOW_ | THRESHOL | .D |    |    |    |    |    |    |

| Bits    | Size | Field              | Reset value | Description                                   | Format          |
|---------|------|--------------------|-------------|-----------------------------------------------|-----------------|
| 31 – 16 | 16   | LVF_HIGH_THRESHOLD | _           | High threshold of the LVF voltage hysteresis. | Table <b>12</b> |
| 15 – 0  | 16   | LVF_LOW_THRESHOLD  | _           | Low threshold of the LVF voltage hysteresis.  | Table 12        |

 ${\bf Table~40:~} Configuration~register~1.$ 



# 4.2.3.4 Configuration register 2

| 31 | 30                 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------------|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    | CVF_HIGH_THRESHOLD |    |    |    |    |    |         |          |    |    |    |    |    |    |    |
| 15 | 14                 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |                    |    |    |    |    | C  | VF_LOW_ | THRESHOI | .D |    |    |    |    |    |    |

| Bits    | Size | Field              | Reset value | Description                                   | Format          |
|---------|------|--------------------|-------------|-----------------------------------------------|-----------------|
| 31 – 16 | 16   | CVF_HIGH_THRESHOLD | _           | High threshold of the CVF voltage hysteresis. | Table 12        |
| 15 – 0  | 16   | CVF_LOW_THRESHOLD  | _           | Low threshold of the CVF voltage hysteresis.  | Table <b>12</b> |

 ${\bf Table~41:}~Configuration~register~2.$ 

# 4.2.3.5 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23 | 22 | 21   | 20  | 19  | 18  | 17  | 16  |
|----|----|----|----|----|----|-----|-----|----|----|------|-----|-----|-----|-----|-----|
|    |    |    |    |    |    |     |     |    |    |      |     |     |     |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7  | 6  | 5    | 4   | 3   | 2   | 1   | 0   |
|    |    |    |    |    |    | CVF | LVF |    |    | CIID | GST | CHE | NST | DVE | NST |

| Bits    | Size | Field  | Reset value | Description                                   | Format                                                                                                                                                     |
|---------|------|--------|-------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 10 | 22   | _      | 0b0[22]     | Unused.                                       | _                                                                                                                                                          |
| 9       | 1    | CVF    | 0b0         | Critical voltage<br>detector flag.            | <ul> <li>0b0 : storage element voltage is above the critical threshold.</li> <li>0b1 : storage element voltage is under the critical threshold.</li> </ul> |
| 8       | 1    | LVF    | 0b0         | Low voltage detector flag.                    | <ul><li>0b0 : storage element voltage is above the low threshold.</li><li>0b1 : storage element voltage is under the low threshold.</li></ul>              |
| 7-6     | 2    | _      | 0b00        | Unused.                                       | _                                                                                                                                                          |
| 5-4     | 2    | CHRGST | 0b11        | Storage element charging status.              | Table 9 0b00 : charge pending. 0b01 : charge complete.                                                                                                     |
| 3-2     | 2    | CHENST | 0b11        | Storage element<br>charging enable<br>status. | Table 9 0b00 : charge disabled. 0b01 : charge enabled.                                                                                                     |
| 1-0     | 2    | BKENST | 0b11        | Backup output state.                          | Table 9 0b00: backup output disabled. 0b01: backup output enabled.                                                                                         |

Table 42:  $Status\ register\ 1.$ 



# 4.2.3.6 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    | CHEN | CHMD | BKEN |

| Bits   | Size | Field | Reset value | Description                                                           | Format                                                                                                                         |
|--------|------|-------|-------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31 - 3 | 29   | _     | 0b0[29]     | Unused.                                                               | _                                                                                                                              |
| 2      | 1    | CHEN  | 0b0         | Storage element charging control (only if CHMD = 0b1 and CEFH = 0b0). | 0b0 : disable charge.<br>0b1 : enable charge.                                                                                  |
| 1      | 1    | CHMD  | 0b0         | Storage element charging mode.                                        | <ul> <li>0b0 : charge is automatically controlled by software.</li> <li>0b1 : charge is controlled by the CHEN bit.</li> </ul> |
| 0      | 1    | BKEN  | 0b0         | Backup output<br>control.                                             | 0b0 : disable backup output.<br>0b1 : enable backup output.                                                                    |

Table 43:  $Control\ register\ 1.$ 



# 4.2.3.7 Analog data register 1

| 31         | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| VSTR[15:0] |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15         | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|            | VSRC[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bits                 | Size | Field | Reset value | Description              | Format   |
|----------------------|------|-------|-------------|--------------------------|----------|
| 31 – 16              | 16   | VSTR  | 0xFFFF      | Storage element voltage. | Table 12 |
| <b>15</b> – <b>0</b> | 16   | VSRC  | 0xFFFF      | Source voltage.          | Table 12 |

Table 44: Analog data register 1.

# 4.2.3.8 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VBKP[ | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description     | Format   |
|---------|------|-------|-------------|-----------------|----------|
| 31 - 16 | 16   | -     | 0x0000      | Unused.         | _        |
| 15 - 0  | 16   | VBKP  | 0xFFFF      | Backup voltage. | Table 12 |

Table 45: Analog data register 2.



# 4.2.4 DDRM specific registers set

| REG_ADDR | Register name   | Size | Access | Format          | Description                                   |
|----------|-----------------|------|--------|-----------------|-----------------------------------------------|
| 0x09     | FLAGS_1         | 8    | R      | Table 47        | Compilation flags.                            |
| 0x0A     | CONFIGURATION_O | 16   | R/W    | Table 48        | $I_{OUT}$ offset calibration value.           |
| 0x0B     | STATUS_1        | 8    | R      | Table 49        | DC-DC converter status.                       |
| 0x0C     | CONTROL_1       | 8    | R/W    | Table 50        | DC-DC converter control.                      |
| 0x0D     | ANALOG_DATA_1   | 32   | R      | Table 51        | $V_{IN}$ and $V_{OUT}$ voltages measurements. |
| 0x0E     | ANALOG_DATA_2   | 16   | R      | Table <b>52</b> | $I_{OUT}$ current measurement.                |

Table 46: DDRM specific registers set.

# 4.2.4.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DDFH |

| Bits   | Size | Field | Reset value | Description                                                         | Format                                                                                              |
|--------|------|-------|-------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| 31 - 1 | 31   | -     | 0b0[31]     | Unused.                                                             | _                                                                                                   |
| 0      | 1    | DDFH  | _           | DC-DC control mode (set at compilation step according to hardware). | <ul> <li>0b0 : DC-DC controlled by the MCU.</li> <li>0b1 : DC-DC controlled by hardware.</li> </ul> |

Table 47: Flags register 1.

#### 4.2.4.2 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | I  | OUT_OFFS | SET[15:0 | )] |    |    |    |    |    |    |

| Bits    | Size | Field       | Reset value | Description                              | Format   |
|---------|------|-------------|-------------|------------------------------------------|----------|
| 31 - 16 | 16   | _           | 0x0000      | Unused.                                  | -        |
| 15 - 0  | 16   | IOUT_OFFSET | _           | Output current offset calibration value. | Table 13 |

Table 48: Configuration register 0.



# 4.2.4.3 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | DDE | NST |

| Bits   | Size | Field  | Reset value | Description            | Format                                                           |
|--------|------|--------|-------------|------------------------|------------------------------------------------------------------|
| 31 - 2 | 30   | _      | 0b0[30]     | Unused.                | _                                                                |
| 1-0    | 2    | DDENST | 0b11        | DC-DC converter state. | Table 9 0b00: DC-DC output disabled. 0b01: DC-DC output enabled. |

Table 49:  $Status\ register\ 1.$ 

#### 4.2.4.4 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DDEN |

| Bits   | Size | Field | Reset value | Description                    | Format                                                                          |
|--------|------|-------|-------------|--------------------------------|---------------------------------------------------------------------------------|
| 31 - 1 | 31   | _     | 0b0[31]     | Unused.                        | _                                                                               |
| 0      | 1    | DDEN  | 0b0         | DC-DC converter state control. | <ul><li>0b0 : disable DC-DC output</li><li>0b1 : enable DC-DC output.</li></ul> |

Table 50: Control register 1.



# 4.2.4.5 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VOUT [ | [15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VIN[   | 15:0]  |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                     | Format          |
|---------|------|-------|-------------|---------------------------------|-----------------|
| 31 – 16 | 16   | VOUT  | 0xFFFF      | DC-DC converter output voltage. | Table <b>12</b> |
| 15 – 0  | 16   | VIN   | 0xFFFF      | DC-DC converter input voltage.  | Table 12        |

Table 51: Analog data register 1.

# 4.2.4.6 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | IOUT[ | 15:0] |    |    |    |    |    |    | ·  |

| Bits                 | Size | Field | Reset value | Description                     | Format   |
|----------------------|------|-------|-------------|---------------------------------|----------|
| 31 - 16              | 16   | -     | 0x0000      | Unused.                         | _        |
| <b>15</b> – <b>0</b> | 16   | IOUT  | 0xFFFF      | DC-DC converter output current. | Table 13 |

Table 52: Analog data register 2.



# 4.2.5 UHFM specific registers set

| REG_ADDR | Register name       | Size | Access | Format   | Description                      |
|----------|---------------------|------|--------|----------|----------------------------------|
| 0x09     | CONFIGURATION_O     | 16   | R/W    | Table 54 | Sigfox radio parameters.         |
| 0x0A     | CONFIGURATION_1     | 32   | R/W    | Table 55 | Sigfox radio parameters.         |
| 0x0B     | STATUS_1            | 32   | R      | Table 56 | Modem status.                    |
| 0x0C     | CONTROL_1           | 32   | R/W    | Table 57 | Modem control.                   |
| 0x0D     | ANALOG_DATA_1       | 32   | R      | Table 58 | $V_{RF}$ voltage measurement.    |
| 0x0E     | SIGFOX_EP_ID        | 32   | R      | Table 59 | Sigfox end-point ID.             |
| 0x0F     | SIGFOX_UL_PAYLOAD_O | 32   | R/W    | Table 60 | Sigfox UL payload bytes 0 to 3.  |
| 0x10     | SIGFOX_UL_PAYLOAD_1 | 32   | R/W    | Table 61 | Sigfox UL payload bytes 4 to 7.  |
| 0x11     | SIGFOX_UL_PAYLOAD_2 | 32   | R/W    | Table 62 | Sigfox UL payload bytes 8 to 11. |
| 0x12     | SIGFOX_DL_PAYLOAD_O | 32   | R      | Table 63 | Sigfox DL payload bytes 0 to 3.  |
| 0x13     | SIGFOX_DL_PAYLOAD_1 | 32   | R      | Table 64 | Sigfox DL payload bytes 4 to 7.  |
| 0x14     | RADIO_TEST_0        | 32   | R/W    | Table 65 | Radio test modes configuration.  |
| 0x15     | RADIO_TEST_1        | 16   | R/W    | Table 66 | Radio test modes configuration.  |

 ${\it Table \ 53:}\ \it UHFM\ specific\ registers\ set.$ 



#### 4.2.5.1 Configuration register 0

| 31 | 30            | 29 | 28      | 27      | 26 | 25 | 24     | 23   | 22    | 21       | 20   | 19   | 18    | 17   | 16 |
|----|---------------|----|---------|---------|----|----|--------|------|-------|----------|------|------|-------|------|----|
|    |               | RI | P_TEST_ | MODE[4: | 0] |    | UL_PAY | BF   | M     | ISGT[2:0 | ]    | CMSG |       |      |    |
| 15 | 14            | 13 | 12      | 11      | 10 | 9  | 8      | 7    | 6     | 5        | 4    | 3    | 2     | 1    | 0  |
|    | TX_POWER[7:0] |    |         |         |    |    |        | NFR[ | [1:0] | BR[      | 1:0] |      | RC [4 | 4:0] |    |

| Bits    | Size | Field           | Reset value | Description                                                                                       | Format                                                                                                                                                                       |
|---------|------|-----------------|-------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 30 | 2    | _               | 0b00        | Unused.                                                                                           | _                                                                                                                                                                            |
| 29 - 26 | 4    | RFP_TEST_MODE   | 0р0000      | Sigfox RFP Addon test mode reference.                                                             | See sigfox_ep_addon_rfp_api.h file of Sigfox RFP Addon.                                                                                                                      |
| 25 - 21 | 5    | UL_PAYLOAD_SIZE | 0Ь00000     | Uplink payload size.                                                                              | Raw value in bytes<br>(0 to 12 for protocol V1)                                                                                                                              |
| 20      | 1    | BF              | 0ь0         | Bidirectional flag.                                                                               | 0b0 : uplink only 0b1 : uplink with downlink request                                                                                                                         |
| 19 – 17 | 3    | MSGT            | 0Р000       | Application message type ( $\mathtt{CMSG} = 0$ ) or control message type ( $\mathtt{CMSG} = 1$ ). | See sigfox_types.h file of<br>Sigfox End-Point Library.                                                                                                                      |
| 16      | 1    | CMSG            | 0b0         | Control message flag. (Disabled at compilation step).                                             | 0b0 : application message<br>0b1 : control message                                                                                                                           |
| 15 – 8  | 8    | TX_POWER        | 0xBC        | TX power of Sigfox transmission. (14 dBm fixed at compilation step).                              | Table <b>17</b>                                                                                                                                                              |
| 7 – 6   | 2    | NFR             | 0b11        | Number of frames per uplink messages (N).                                                         | 0b00 : no frame (uplink disabled)<br>0b01 : 1 frame (N=1)<br>0b10 : 2 frames (N=2)<br>0b11 : 3 frames (N=3)                                                                  |
| 5 – 4   | 2    | BR              | 0Ь00        | Signal bit rate.                                                                                  | 0b01 : 100 bps<br>0b01 : 600 bps<br>0b10-0b11 : reserved for future<br>use                                                                                                   |
| 3 – 0   | 4    | RC              | 0ь0000      | Sigfox radio configuration zone. (RC1 fixed at compilation step).                                 | 0b0000 : RC1<br>0b0001 : RC2<br>0b0010 : RC3C<br>0b0011 : RC3D<br>0b0100 : RC4<br>0b0101 : RC5<br>0b0110 : RC6<br>0b0111 : RC7<br>0b1000-0b1111 : reserved for<br>future use |

Table 54: Configuration register 0.

 $\underline{\mathbf{Note:}}\ \mathbf{Application}\ \mathbf{message}\ \mathbf{payload}\ \mathbf{is}\ \mathbf{given}\ \mathbf{in}\ \mathbf{the}\ \mathtt{SIGFOX\_UL\_PAYLOAD\_x}\ \mathbf{registers}.$ 



# $\begin{tabular}{ll} 4.2.5.2 & Configuration register 1 \end{tabular}$

| 31          | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| TCONF[15:0] |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15          | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|             | TIFU[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value                                                                                                        | Description                                                       | Format                                  |
|---------|------|-------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------|
| 31 – 16 | 16   | TCONF | 0x07D0  Delay between downlink reception and confirmation frame transmission. (2000 ms fixed at compilation step). |                                                                   | <b>Raw</b> value in $ms$ (1400 to 4000) |
| 15 – 0  | 16   | TIFU  | 0x03E8                                                                                                             | Delay between uplink frames. (1000 ms fixed at compilation step). | Raw value in $ms$ (0 to 2000)           |

 ${\bf Table~55:~} Configuration~register~1.$ 

# 4.2.5.3 Status register 1

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22      | 21      | 20      | 19        | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|------|---------|---------|---------|-----------|----|----|----|
|    |              |    |    |    |    |    |    | BIDI | RECTION | AL_MC[1 | 1:0]    |           |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6       | 5       | 4       | 3         | 2  | 1  | 0  |
|    | DL_RSSI[7:0] |    |    |    |    |    |    |      |         | ME      | SSAGE_S | TATUS [7: | 0] |    |    |

| Bits                  | Size | Field            | Reset value | Description                                                          | Format                                                   |  |  |
|-----------------------|------|------------------|-------------|----------------------------------------------------------------------|----------------------------------------------------------|--|--|
| 31 - 28               | 4    | _                | 0x0         | Unused.                                                              | _                                                        |  |  |
| <b>27</b> – <b>16</b> | 12   | BIDIRECTIONAL_MC | _           | Message counter of<br>the last uplink with<br>bidirectional request. | Raw value.                                               |  |  |
| 15 – 8                | 8    | DL_RSSI          | 0x00        | RSSI of the last<br>downlink message<br>received.                    | Table 17                                                 |  |  |
| 7-0                   | 8    | MESSAGE_STATUS   | 0x00        | Sigfox message transmission status.                                  | See sigfox_ep_api.h file of<br>Sigfox End-Point Library. |  |  |

 ${\bf Table~56:~Status~register~1.}$ 



#### 4.2.5.4 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    | RSEN | CWEN | TTRG | STRG |

| Bits   | Size | Field | Reset value | Description                            | Format                                                                                                                                                      |
|--------|------|-------|-------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 4 | 28   | _     | 0b0[28]     | Unused.                                | -                                                                                                                                                           |
| 3      | 1    | RSEN  | 0b0         | Continuous RSSI measurement control.   | <ul> <li>0b0 : stop RSSI measure (W) or<br/>RSSI measure stopped (R).</li> <li>0b1 : start RSSI measure (W) or<br/>RSSI measure running (R).</li> </ul>     |
| 2      | 1    | CWEN  | 0b0         | Continuous wave control.               | <ul> <li>0b0 : Stop continuous wave (W) or continuous wave stopped (R).</li> <li>0b1 : Start continuous wave (W) or continuous wave running (R).</li> </ul> |
| 1      | 1    | TTRG  | 0b0         | Sigfox RFP Addon<br>test mode trigger. | <ul> <li>0b0 : no action (W) or no test mode pending (R).</li> <li>0b1 : start test mode (W) or test mode pending (R).</li> </ul>                           |
| 0      | 1    | STRG  | 0b0         | Sigfox message<br>trigger.             | <ul> <li>0b0 : no action (W) or no transmission pending (R).</li> <li>0b1 : send message (W) or message transmission pending (R).</li> </ul>                |

Table 57: Control register 1.

 $\underline{\textbf{Note:}} \ \, \textbf{Continuous} \ \, \textbf{RSSI} \ \, \textbf{measurement} \ \, \textbf{and} \ \, \textbf{continuous} \ \, \textbf{wave} \ \, \textbf{are} \ \, \textbf{performed} \ \, \textbf{on the RF} \ \, \textbf{frequency} \ \, \textbf{given by the RADIO\_TEST\_1} \ \, \textbf{register.}$ 



### 4.2.5.5 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VRF_RX | [15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VRF_TX | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field  | Reset value | Description                       | Format          |
|---------|------|--------|-------------|-----------------------------------|-----------------|
| 31 – 16 | 16   | VRF_RX | 0xFFFF      | Radio front-end<br>voltage in RX. | Table <b>12</b> |
| 15 – 0  | 16   | VRF_TX | 0xFFFF      | Radio front-end<br>voltage in TX. | Table 12        |

Table 58: Analog data register 1.

### 4.2.5.6 Sigfox EP ID register

| 31 | 30 | 29 | 28      | 27       | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19       | 18 | 17 | 16 |
|----|----|----|---------|----------|----|----|----|----|----|----|---------|----------|----|----|----|
|    |    | Е  | P_ID_BY | ΓE_3[7:0 | )] |    |    |    |    | Е  | P_ID_BY | ΓE_2[7:0 | )] |    |    |
| 15 | 14 | 13 | 12      | 11       | 10 | 9  | 8  | 7  | 6  | 5  | 4       | 3        | 2  | 1  | 0  |
|    |    | Е  | P_ID_BY | ΓE_1[7:0 | )] |    |    |    |    | Е  | P_ID_BY | ΓE_0[7:0 | )] |    |    |

| Bits    | Size | Field        | Reset value | Description                           | Format |
|---------|------|--------------|-------------|---------------------------------------|--------|
| 31 - 24 | 8    | EP_ID_BYTE_3 | _           | Byte 3 of the Sigfox<br>end-point ID. | -      |
| 23 – 16 | 8    | EP_ID_BYTE_2 | _           | Byte 2 of the Sigfox end-point ID.    | -      |
| 15 - 8  | 8    | EP_ID_BYTE_1 | _           | Byte 1 of the Sigfox end-point ID.    | -      |
| 7-0     | 8    | EP_ID_BYTE_0 | _           | Byte 0 of the Sigfox<br>end-point ID. | -      |

Table 59:  $Sigfox\ EP\ ID\ register.$ 



### 4.2.5.7 Sigfox UL payload register 0

| 31 | 30 | 29   | 28      | 27      | 26   | 25 | 24 | 23 | 22 | 21   | 20      | 19      | 18   | 17 | 16 |
|----|----|------|---------|---------|------|----|----|----|----|------|---------|---------|------|----|----|
|    |    | UL_F | AYLOAD_ | BYTE_3[ | 7:0] |    |    |    |    | UL_F | AYLOAD_ | BYTE_2[ | 7:0] |    |    |
| 15 | 14 | 13   | 12      | 11      | 10   | 9  | 8  | 7  | 6  | 5    | 4       | 3       | 2    | 1  | 0  |
|    |    | UL_F | AYLOAD_ | BYTE_1[ | 7:0] |    |    |    |    | UL_F | AYLOAD_ | BYTE_0[ | 7:0] |    |    |

| Bits    | Size | Field             | Reset value | Description                          | Format |
|---------|------|-------------------|-------------|--------------------------------------|--------|
| 31 - 24 | 8    | UL_PAYLOAD_BYTE_3 | 0x00        | Byte 3 of the Sigfox uplink payload. | _      |
| 23 – 16 | 8    | UL_PAYLOAD_BYTE_2 | 0x00        | Byte 2 of the Sigfox uplink payload. | -      |
| 15 – 8  | 8    | UL_PAYLOAD_BYTE_1 | 0x00        | Byte 1 of the Sigfox uplink payload. | -      |
| 7-0     | 8    | UL_PAYLOAD_BYTE_O | 0x00        | Byte 0 of the Sigfox uplink payload. | -      |

Table 60: Sigfox UL payload register 0.

## 4.2.5.8 Sigfox UL payload register 1

| 31 | 30 | 29   | 28      | 27      | 26   | 25 | 24 | 23 | 22 | 21   | 20       | 19      | 18   | 17 | 16 |
|----|----|------|---------|---------|------|----|----|----|----|------|----------|---------|------|----|----|
|    |    | UL_F | AYLOAD_ | BYTE_7[ | 7:0] |    |    |    |    | UL_F | PAYLOAD_ | BYTE_6[ | 7:0] |    |    |
| 15 | 14 | 13   | 12      | 11      | 10   | 9  | 8  | 7  | 6  | 5    | 4        | 3       | 2    | 1  | 0  |
|    |    | UL_F | AYLOAD_ | BYTE_5[ | 7:0] |    |    |    |    | UL_F | PAYLOAD_ | BYTE_4[ | 7:0] |    |    |

| Bits    | Size | Field             | Reset value | Description                          | Format |
|---------|------|-------------------|-------------|--------------------------------------|--------|
| 31 - 24 | 8    | UL_PAYLOAD_BYTE_7 | 0x00        | Byte 7 of the Sigfox uplink payload. | _      |
| 23 – 16 | 8    | UL_PAYLOAD_BYTE_6 | 0x00        | Byte 6 of the Sigfox uplink payload. | _      |
| 15 - 8  | 8    | UL_PAYLOAD_BYTE_5 | 0x00        | Byte 5 of the Sigfox uplink payload. | _      |
| 7-0     | 8    | UL_PAYLOAD_BYTE_4 | 0x00        | Byte 4 of the Sigfox uplink payload. | _      |

Table 61: Sigfox UL payload register 1.



### 4.2.5.9 Sigfox UL payload register 2

| 31 | 30 | 29   | 28       | 27      | 26    | 25 | 24 | 23 | 22 | 21   | 20      | 19      | 18    | 17 | 16 |
|----|----|------|----------|---------|-------|----|----|----|----|------|---------|---------|-------|----|----|
|    |    | UL_P | AYLOAD_  | BYTE_11 | [7:0] |    |    |    |    | UL_P | AYLOAD_ | BYTE_10 | [7:0] |    |    |
| 15 | 14 | 13   | 12       | 11      | 10    | 9  | 8  | 7  | 6  | 5    | 4       | 3       | 2     | 1  | 0  |
|    |    | UL_F | PAYLOAD_ | BYTE_9[ | 7:0]  |    |    |    |    | UL_F | AYLOAD_ | BYTE_8[ | 7:0]  |    |    |

| Bits    | Size | Field              | Reset value | Description                           | Format |
|---------|------|--------------------|-------------|---------------------------------------|--------|
| 31 - 24 | 8    | UL_PAYLOAD_BYTE_11 | 0x00        | Byte 11 of the Sigfox uplink payload. | _      |
| 23 – 16 | 8    | UL_PAYLOAD_BYTE_10 | 0x00        | Byte 10 of the Sigfox uplink payload. | _      |
| 15 – 8  | 8    | UL_PAYLOAD_BYTE_9  | 0x00        | Byte 9 of the Sigfox uplink payload.  | _      |
| 7-0     | 8    | UL_PAYLOAD_BYTE_8  | 0x00        | Byte 8 of the Sigfox uplink payload.  | _      |

Table 62: Sigfox UL payload register 2.



### 4.2.5.10 Sigfox DL payload register 0

| 31 | 30 | 29   | 28      | 27      | 26   | 25 | 24 | 23 | 22 | 21   | 20       | 19      | 18   | 17 | 16 |
|----|----|------|---------|---------|------|----|----|----|----|------|----------|---------|------|----|----|
|    |    | DL_F | AYLOAD_ | BYTE_3[ | 7:0] |    |    |    |    | DL_F | PAYLOAD_ | BYTE_2[ | 7:0] |    |    |
| 15 | 14 | 13   | 12      | 11      | 10   | 9  | 8  | 7  | 6  | 5    | 4        | 3       | 2    | 1  | 0  |
|    |    | DL_F | AYLOAD_ | BYTE_1[ | 7:0] |    |    |    |    | DL_F | PAYLOAD_ | BYTE_0[ | 7:0] |    |    |

| Bits    | Size | Field             | Reset value | Description                            | Format |
|---------|------|-------------------|-------------|----------------------------------------|--------|
| 31 - 24 | 8    | DL_PAYLOAD_BYTE_3 | 0x00        | Byte 3 of the Sigfox downlink payload. | _      |
| 23 – 16 | 8    | DL_PAYLOAD_BYTE_2 | 0x00        | Byte 2 of the Sigfox downlink payload. | _      |
| 15 – 8  | 8    | DL_PAYLOAD_BYTE_1 | 0x00        | Byte 1 of the Sigfox downlink payload. | _      |
| 7-0     | 8    | DL_PAYLOAD_BYTE_O | 0x00        | Byte 0 of the Sigfox downlink payload. | _      |

Table 63: Sigfox DL payload register 0.

## 4.2.5.11 Sigfox DL payload register 1

| 31 | 30 | 29   | 28      | 27      | 26   | 25 | 24 | 23 | 22 | 21   | 20       | 19      | 18   | 17 | 16 |
|----|----|------|---------|---------|------|----|----|----|----|------|----------|---------|------|----|----|
|    |    | DL_F | AYLOAD_ | BYTE_7[ | 7:0] |    |    |    |    | DL_F | PAYLOAD_ | BYTE_6[ | 7:0] |    |    |
| 15 | 14 | 13   | 12      | 11      | 10   | 9  | 8  | 7  | 6  | 5    | 4        | 3       | 2    | 1  | 0  |
|    |    | DL_F | AYLOAD_ | BYTE_5[ | 7:0] |    |    |    |    | DL_F | PAYLOAD_ | BYTE_4[ | 7:0] |    |    |

| Bits    | Size | Field             | Reset value | Description                            | Format |
|---------|------|-------------------|-------------|----------------------------------------|--------|
| 31 - 24 | 8    | DL_PAYLOAD_BYTE_7 | 0x00        | Byte 7 of the Sigfox downlink payload. | _      |
| 23 – 16 | 8    | DL_PAYLOAD_BYTE_6 | 0x00        | Byte 6 of the Sigfox downlink payload. | -      |
| 15 - 8  | 8    | DL_PAYLOAD_BYTE_5 | 0x00        | Byte 5 of the Sigfox downlink payload. | -      |
| 7-0     | 8    | DL_PAYLOAD_BYTE_4 | 0x00        | Byte 4 of the Sigfox downlink payload. | -      |

 ${\bf Table~64:~Sigfox~DL~payload~register~1.}$ 



#### 4.2.5.12 Radio test register 0

| 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------------|----|----|----|----|----|----|---------|----------|-----|----|----|----|----|----|----|
|                    |    |    |    |    |    | RF | _FREQUE | NCY[31:1 | .6] |    |    |    |    |    |    |
| 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| RF_FREQUENCY[15:0] |    |    |    |    |    |    |         |          |     |    |    |    |    |    |    |

| Bits   | Size | Field        | Reset value | Description                                                                       | Format                                            |
|--------|------|--------------|-------------|-----------------------------------------------------------------------------------|---------------------------------------------------|
| 31 – 0 | 32   | RF_FREQUENCY | 0x33AD5EC0  | RF center frequency<br>used for continuous<br>wave, RSSI and<br>downlink decoder. | Raw value in <i>Hz</i> . (826000000 to 958000000) |

Table 65: Radio test register 0.

### 4.2.5.13 Radio test register 1

| 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20     | 19      | 18 | 17 | 16 |
|----|----|----|------|-------|----|----|----|----|----|----|--------|---------|----|----|----|
|    |    |    |      |       |    |    |    |    |    |    |        |         |    |    |    |
| 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4      | 3       | 2  | 1  | 0  |
|    |    |    | RSSI | [7:0] |    |    |    |    |    |    | TX_POW | ER[7:0] |    |    |    |

| Bits    | Size | Field    | Reset value | Description                                               | Format          |
|---------|------|----------|-------------|-----------------------------------------------------------|-----------------|
| 31 - 16 | 16   | -        | 0x0000      | Unused.                                                   | _               |
| 15 – 8  | 8    | RSSI     | 0x00        | Radio RSSI read<br>during continuous<br>RSSI measurement. | Table <b>17</b> |
| 7-0     | 8    | TX_POWER | 0xBC        | Radio TX power used during continuous wave.               | Table <b>17</b> |

Table 66: Radio test register 1.



## 4.2.6 GPSM specific registers set

| REG_ADDR | Register name   | Size | Access | Format          | Description                                               |
|----------|-----------------|------|--------|-----------------|-----------------------------------------------------------|
| 0x09     | FLAGS_1         | 8    | R      | Table 68        | Compilation flags.                                        |
| 0x0A     | CONFIGURATION_O | 32   | R/W    | Table 69        | Time and geo-location fix timeout.                        |
| 0x0B     | CONFIGURATION_1 | 32   | R/W    | Table 70        | GPS timepulse output frequency.                           |
| 0x0C     | CONFIGURATION_2 | 8    | R/W    | Table 71        | GPS timepulse output duty cycle.                          |
| 0x0D     | STATUS_1        | 8    | R      | Table 72        | GPS status.                                               |
| 0x0E     | CONTROL_1       | 8    | R/W    | Table 73        | GPS control.                                              |
| 0x0F     | ANALOG_DATA_1   | 32   | R      | Table 74        | $V_{GPS}$ and $V_{ANT}$ voltages measurements.            |
| 0x10     | TIME_DATA_O     | 32   | R      | Table <b>75</b> | UTC date.                                                 |
| 0x11     | TIME_DATA_1     | 32   | R      | Table 76        | UTC time.                                                 |
| 0x12     | TIME_DATA_2     | 16   | R      | Table 77        | Time fix duration.                                        |
| 0x13     | GEOLOC_DATA_O   | 32   | R      | Table 78        | Latitude.                                                 |
| 0x14     | GEOLOC_DATA_1   | 32   | R      | Table 79        | Longitude.                                                |
| 0x15     | GEOLOC_DATA_2   | 16   | R      | Table 80        | Altitude.                                                 |
| 0x16     | GEOLOC_DATA_3   | 32   | R      | Table 81        | Geo-location fix duration, number of satellites and HDOP. |

Table 67: GPSM specific registers set.

### 4.2.6.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | BKFH | AAF |

| Bits   | Size | Field | Reset value | Description                                                                           | Format                                                                                                                              |
|--------|------|-------|-------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 2 | 30   | -     | 0b0[30]     | Unused.                                                                               | _                                                                                                                                   |
| 1      | 1    | вкғн  | _           | GPS backup control<br>mode (set at<br>compilation level<br>according to<br>hardware). | <ul> <li><b>0b0</b>: GPS backup signal controlled by the MCU.</li> <li><b>0b1</b>: GPS backup signal forced in hardware.</li> </ul> |
| 0      | 1    | AAF   | _           | Active antenna flag<br>(set at compilation<br>level according to<br>hardware).        | <ul><li>0b0 : Active antenna disabled.</li><li>0b1 : Active antenna enabled.</li></ul>                                              |

Table 68: Flags register 1.



### 4.2.6.2 Configuration register 0

| 31 | 30                 | 29 | 28 | 27 | 26 | 25  | 24       | 23       | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------------|----|----|----|----|-----|----------|----------|-----|----|----|----|----|----|----|
|    |                    |    |    |    |    | GEC | DLOC_TIM | EOUT [15 | :0] |    |    |    |    |    |    |
| 15 | 14                 | 13 | 12 | 11 | 10 | 9   | 8        | 7        | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | TIME_TIMEOUT[15:0] |    |    |    |    |     |          |          |     |    |    |    |    |    |    |

| Bits                 | Size | Field          | Reset value | Description               | Format                        |
|----------------------|------|----------------|-------------|---------------------------|-------------------------------|
| 31 – 16              | 16   | GEOLOC_TIMEOUT | 0x00B4      | Geo-location fix timeout. | $\mathbf{Raw}$ value in $s$ . |
| <b>15</b> – <b>0</b> | 16   | TIME_TIMEOUT   | 0x0078      | Time fix timeout.         | Raw value in $s$ .            |

Table 69: Configuration register 0.

### 4.2.6.3 Configuration register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | F  | FREQUENC | Y[31:16  | ]  |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | FREQUEN  | CY[15:0] |    |    |    |    |    |    |    |

| Bits   | Size | Field     | Reset value | Description                 | Format                                     |
|--------|------|-----------|-------------|-----------------------------|--------------------------------------------|
| 31 – 0 | 32   | FREQUENCY | 0x00989680  | Timepulse signal frequency. | <b>Raw</b> value in $Hz$ . (1 to 10000000) |

 ${\bf Table~70:~} Configuration~register~1.$ 

#### 4.2.6.4 Configuration register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18   | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|------|---------|------|----|----|
|    |    |    |    |    |    |    |    |    |    |    |      |         |      |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3       | 2    | 1  | 0  |
|    |    |    |    |    |    |    |    |    |    |    | DUTY | _CYCLE[ | 6:0] |    |    |

| Bi   | its       | Size | Field      | Reset value | Description                  | Format                           |
|------|-----------|------|------------|-------------|------------------------------|----------------------------------|
| 31 - | <b>-7</b> | 25   | -          | 0b0[25]     | Unused.                      | _                                |
| 6 -  | - 0       | 7    | DUTY_CYCLE | 0x32        | Timepulse signal duty cycle. | <b>Raw</b> value in % (0 to 100) |

Table 71: Configuration register 2.



### 4.2.6.5 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20  | 19   | 18   | 17  | 16  |
|----|----|----|----|----|----|----|----|----|----|-----|-----|------|------|-----|-----|
|    |    |    |    |    |    |    |    |    |    |     |     |      |      |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4   | 3    | 2    | 1   | 0   |
|    |    |    |    |    |    |    |    |    |    | ВКЕ | NST | PWST | TPST | GFS | TFS |

| Bits   | Size | Field  | Reset value | Description                  | Format                                                                              |
|--------|------|--------|-------------|------------------------------|-------------------------------------------------------------------------------------|
| 31 - 6 | 26   | -      | 0b0[26]     | Unused.                      | -                                                                                   |
| 5-4    | 2    | BKENST | 0b11        | GPS backup voltage status.   | Table 9 0b00 : GPS backup disabled. 0b01 : GPS backup enabled.                      |
| 3      | 1    | PWST   | 0Ь0         | GPS power supply status.     | 0b0 : GPS power supply is off.<br><b>0b1</b> : GPS power supply is on.              |
| 2      | 1    | TPST   | 0b0         | GPS timepulse status.        | <ul><li>0b0 : GPS timepulse stopped.</li><li>0b1 : GPS timepulse running.</li></ul> |
| 1      | 1    | GFS    | 0b0         | GPS geo-location fix status. | 0b0: timeout. $0b1$ : success.                                                      |
| 0      | 1    | TFS    | 0b0         | GPS time fix status.         | 0b0 : timeout.<br>0b1 : success.                                                    |

 ${\bf Table~72:~Status~register~1.}$ 



#### 4.2.6.6 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20   | 19   | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|
|    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    | BKEN | PWEN | PWMD | TPEN | GTRG | TTRG |

| Bits   | Size | Field | Reset value | Description                                                  | Format                                                                                                                                                         |
|--------|------|-------|-------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 6 | 26   | _     | 0b0[26]     | Unused.                                                      | _                                                                                                                                                              |
| 5      | 1    | BKEN  | 0b0         | GPS backup voltage control.                                  | <ul><li>0b0 : Turn GPS backup off.</li><li>0b1 : Turn GPS backup on.</li></ul>                                                                                 |
| 4      | 1    | PWEN  | 0ь0         | Direct control of the GPS power supply (only if PWMD = 0b1). | <ul><li>0b0 : Turn GPS off.</li><li>0b1 : Turn GPS on.</li></ul>                                                                                               |
| 3      | 1    | PWMD  | 0ь0         | GPS power supply control mode.                               | <ul> <li><b>0b0</b>: GPS power supply is automatically controlled by software.</li> <li><b>0b1</b>: GPS power supply is controlled by the PWEN bit.</li> </ul> |
| 2      | 1    | TPEN  | 0b0         | GPS timepulse output control.                                | <ul><li>0b0 : Disable GPS timepulse.</li><li>0b1 : Enable GPS timepulse.</li></ul>                                                                             |
| 1      | 1    | GTRG  | 0b0         | GPS geo-location fix<br>trigger.                             | <ul> <li>0b0: no action (W) or no geo-location fix pending (R).</li> <li>0b1: Perform geo-location fix (W) or geo-location fix pending (R).</li> </ul>         |
| 0      | 1    | TTRG  | 0Ь0         | GPS time fix trigger.                                        | <ul><li>0b0 : no action (W) or no time fix pending (R).</li><li>0b1 : Perform time fix (W) or time fix pending (R).</li></ul>                                  |

Table 73:  $Control\ register\ 1.$ 

 $\underline{\mathbf{Note:}}\ \mathbf{Time}\ \mathbf{and}\ \mathbf{geo-location}\ \mathbf{fix}\ \mathbf{timeouts}\ \mathbf{are}\ \mathbf{given}\ \mathbf{by}\ \mathbf{the}\ \mathbf{CONFIGURATION\_1}\ \mathbf{register}.$ 

 $\underline{\mathbf{Note:}}\ \mathbf{Timepulse}\ \mathbf{signal}\ \mathbf{settings}\ \mathbf{are}\ \mathbf{given}\ \mathbf{by}\ \mathbf{the}\ \mathbf{CONFIGURATION\_2}\ \mathbf{and}\ \mathbf{CONFIGURATION\_3}\ \mathbf{registers}.$ 

#### 4.2.6.7 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VANT [ | 15:0]  |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VGPS[  | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description             | Format          |
|---------|------|-------|-------------|-------------------------|-----------------|
| 31 - 16 | 16   | VANT  | 0xFFFF      | Active antenna voltage. | Table <b>12</b> |
| 15 - 0  | 16   | VGPS  | 0xFFFF      | GPS module voltage.     | Table 12        |

Table 74: Analog data register 1.



### 4.2.6.8 Time data register 0

| 31 | 30 | 29 | 28 | 27 | 26    | 25    | 24 | 23 | 22 | 21       | 20   | 19    | 18 | 17       | 16 |
|----|----|----|----|----|-------|-------|----|----|----|----------|------|-------|----|----------|----|
|    |    |    |    |    |       |       |    |    |    |          | YEAR | [7:0] |    |          |    |
| 15 | 14 | 13 | 12 | 11 | 10    | 9     | 8  | 7  | 6  | 5        | 4    | 3     | 2  | 1        | 0  |
|    |    |    |    |    | MONTH | [3:0] |    |    | D  | ATE [4:0 | ]    |       |    | DAY[2:0] |    |

| Bits    | Size | Field | Reset value | Description                       | Format                                                                                                                                                       |
|---------|------|-------|-------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 24 | 12   | -     | 0x000       | Unused.                           | _                                                                                                                                                            |
| 23 – 16 | 8    | YEAR  | 0x00        | UTC year.                         | Table 18                                                                                                                                                     |
| 15 - 12 | 4    | -     | 0b0000      | Unused.                           | _                                                                                                                                                            |
| 11 – 8  | 4    | MONTH | 0b0000      | UTC month.                        | Raw value $(1-12)$                                                                                                                                           |
| 7-3     | 5    | DATE  | 0b00000     | UTC date.                         | Raw value $(1-31)$                                                                                                                                           |
| 2-0     | 3    | DAY   | 0Ь000       | UTC week day (not supported yet). | 0b000 : Monday.<br>0b001 : Tuesday.<br>0b010 : Wednesday.<br>0b011 : Thursday.<br>0b100 : Friday.<br>0b101 : Saturday.<br>0b110 : Sunday.<br>0b111 : unused. |

Table 75:  $Time\ data\ register\ 0.$ 

### 4.2.6.9 Time data register 1

| 31 | 30 | 29 | 28 | 27    | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18       | 17 | 16 |
|----|----|----|----|-------|--------|----|----|----|----|----|----|--------|----------|----|----|
|    |    |    |    |       |        |    |    |    |    |    |    | H      | OUR [4:0 | ]  |    |
| 15 | 14 | 13 | 12 | 11    | 10     | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2        | 1  | 0  |
|    |    |    |    | MINUT | E[5:0] |    |    |    |    |    |    | SECONI | 0[5:0]   |    |    |

| Bits    | Size | Field  | Reset value | Description | Format             |
|---------|------|--------|-------------|-------------|--------------------|
| 31 - 21 | 11   | _      | 0b0[11]     | Unused.     | _                  |
| 20 - 16 | 5    | HOUR   | 0b00000     | UTC hour.   | Raw value $(0-23)$ |
| 15 - 14 | 2    | _      | 0b00        | Unused.     | _                  |
| 13 - 8  | 6    | MINUTE | 00b000000   | UTC minute. | Raw value $(0-59)$ |
| 7 – 6   | 2    | _      | 0b00        | Unused.     | _                  |
| 5 - 0   | 6    | SECOND | 0ь000000    | UTC second. | Raw value $(0-59)$ |

 ${\bf Table~76:~\it Time~data~register~1.}$ 



#### 4.2.6.10 Time data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |         |         |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | FI | X_DURAT | ION[15: | 0] |    |    |    |    |    |    |

| Bits    | Size | Field        | Reset value | Description        | Format                    |
|---------|------|--------------|-------------|--------------------|---------------------------|
| 31 - 16 | 16   | -            | 0x0000      | Unused.            | -                         |
| 15 - 0  | 16   | FIX_DURATION | 0x0000      | Time fix duration. | <b>Raw</b> value in $s$ . |

Table 77:  $Time\ data\ register\ 2.$ 

## $4.2.6.11 \quad \text{Geo-location data register 0} \\$

| 31     | 30     | 29 | 28 | 27    | 26     | 25 | 24  | 23        | 22 | 21 | 20     | 19     | 18 | 17 | 16 |
|--------|--------|----|----|-------|--------|----|-----|-----------|----|----|--------|--------|----|----|----|
| NF     |        |    |    |       |        |    | SEC | COND [16: | 2] |    |        |        |    |    |    |
| 15     | 14     | 13 | 12 | 11    | 10     | 9  | 8   | 7         | 6  | 5  | 4      | 3      | 2  | 1  | 0  |
| SECONI | D[1:0] |    |    | MINUT | E[5:0] |    |     |           |    |    | DEGREI | E[7:0] |    |    |    |

| Bits    | Size | Field  | Reset value | Description          | Format                                                                                 |
|---------|------|--------|-------------|----------------------|----------------------------------------------------------------------------------------|
| 31      | 1    | NF     | 0b0         | Latitude north flag. | <b>0b0</b> : south. <b>0b1</b> : north.                                                |
| 30 - 14 | 17   | SECOND | 0b0[17]     | Second of latitude.  | Fractional part of minutes $\times 100000$ seconds ["] = (SECOND / 100000) $\times$ 60 |
| 13 - 8  | 6    | MINUTE | 0ь000000    | Minute of latitude.  | Raw value in '                                                                         |
| 7-0     | 8    | DEGREE | 0x00        | Degree of latitude.  | Raw value in °                                                                         |

Table 78: Geo-location data register 0.



#### 4.2.6.12 Geo-location data register 1

| 31    | 30     | 29 | 28 | 27    | 26     | 25 | 24 | 23        | 22  | 21 | 20    | 19     | 18 | 17 | 16 |
|-------|--------|----|----|-------|--------|----|----|-----------|-----|----|-------|--------|----|----|----|
| EF    |        |    |    |       |        |    | SE | COND [16: | :2] |    |       |        |    |    |    |
| 15    | 14     | 13 | 12 | 11    | 10     | 9  | 8  | 7         | 6   | 5  | 4     | 3      | 2  | 1  | 0  |
| SECON | D[1:0] |    |    | MINUT | E[5:0] |    |    |           |     |    | DEGRE | E[7:0] |    |    |    |

| Bits    | Size | Field  | Reset value | Description          | Format                                                                                 |
|---------|------|--------|-------------|----------------------|----------------------------------------------------------------------------------------|
| 31      | 1    | EF     | 0ь0         | Longitude east flag. | <ul><li>0b0 : west.</li><li>0b1 : east.</li></ul>                                      |
| 30 – 14 | 17   | SECOND | 0b0[17]     | Second of longitude. | Fractional part of minutes $\times 100000$ seconds ["] = (SECOND / 100000) $\times 60$ |
| 13 – 8  | 6    | MINUTE | 0ь000000    | Minute of longitude. | Raw value in '                                                                         |
| 7-0     | 8    | DEGREE | 0x00        | Degree of longitude. | Raw value in $^{\circ}$                                                                |

Table 79: Geo-location data register 1.

# 4.2.6.13 Geo-location data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |         |         |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | ALTITUD | E[15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field    | Reset value | Description | Format           |
|---------|------|----------|-------------|-------------|------------------|
| 31 - 16 | 16   | -        | 0x0000      | Unused.     | _                |
| 15 - 0  | 16   | ALTITUDE | 0x0000      | Altitude.   | Raw value in $m$ |

Table 80: Geo-location data register 2.

## 4.2.6.14 Geo-location data register 3

| 31 | 30                 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17    | 16 |
|----|--------------------|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|
|    | HDOP[11:0]         |    |    |    |    |    |    |    |    |    |    |    | NSAT | [3:0] |    |
| 15 | 14                 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1     | 0  |
|    | FIX_DURATION[15:0] |    |    |    |    |    |    |    |    |    |    |    |      |       |    |

| Bits    | Size | Field        | Reset value | Description            | Format                        |
|---------|------|--------------|-------------|------------------------|-------------------------------|
| 31 - 20 | 12   | HDOP         | 0x000       | Horizontal precision.  | <b>Raw</b> value $\times 100$ |
| 19 - 16 | 4    | NSAT         | 0b0000      | Number of satellites.  | Raw value                     |
| 15 – 0  | 16   | FIX_DURATION | 0x0000      | Position fix duration. | $\mathbf{Raw}$ value in $s$ . |

Table 81: Geo-location data register 3.



## 4.2.7 SM specific registers set

| REG_ADDR | Register name | Size | Access | Format   | Description                                        |
|----------|---------------|------|--------|----------|----------------------------------------------------|
| 0x $0$ 9 | FLAGS_1       | 8    | R      | Table 83 | Compilation flags.                                 |
| 0x0A     | FLAGS_2       | 32   | R      | Table 84 | $V_{AIN0}$ and $V_{AIN1}$ front–end configuration. |
| 0x0B     | FLAGS_3       | 32   | R      | Table 85 | $V_{AIN2}$ and $V_{AIN3}$ front–end configuration. |
| 0x0C     | ANALOG_DATA_1 | 32   | R      | Table 86 | $V_{AIN0}$ and $V_{AIN1}$ voltages measurements.   |
| 0x0D     | ANALOG_DATA_2 | 32   | R      | Table 87 | $V_{AIN2}$ and $V_{AIN3}$ voltages measurements.   |
| 0x0E     | ANALOG_DATA_3 | 16   | R      | Table 88 | $T_{amb}$ and $H_{amb}$ measurements.              |
| 0x0F     | DIGITAL_DATA  | 8    | R      | Table 89 | Digital inputs measurements.                       |

 ${\bf Table~82:}~SM~specific~registers~set.$ 

## 4.2.7.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    | DIGF | DIOF | AINF |

| Bits   | Size | Field | Reset value | Description                  | Format                                                                                   |
|--------|------|-------|-------------|------------------------------|------------------------------------------------------------------------------------------|
| 31 - 3 | 29   | _     | 0b0[29]     | Unused.                      | -                                                                                        |
| 2      | 1    | DIGF  | _           | Digital sensors enable flag. | <ul><li>0b0 : digital sensors disabled.</li><li>0b1 : digital sensors enabled.</li></ul> |
| 1      | 1    | DIOF  | _           | Digital inputs enable flag.  | <ul><li>0b0 : digital inputs disabled.</li><li>0b1 : digital inputs enabled.</li></ul>   |
| 0      | 1    | AINF  | _           | Analog inputs enable flag.   | <ul><li>0b0 : analog inputs disabled.</li><li>0b1 : analog inputs enabled.</li></ul>     |

Table 83: Flags register 1.



### 4.2.7.2 Flags register 2

| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|
| AI1T |    |    |    |    |    |    | A  | I1G[15:0 | 0] |    |    |    |    |    |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| AIOT |    |    |    |    |    |    | Δ. | IOG[15:0 | าไ |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                                                                 | Format                                                                                                                              |
|---------|------|-------|-------------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31      | 1    | AI1T  | _           | $V_{AIN1}$ conversion type (set at compilation step according to hardware). | 0b0 : attenuation. 0b1 : amplification.                                                                                             |
| 30 – 16 | 15   | AI1G  | _           | $V_{AIN1}$ conversion gain (set at compilation step according to hardware). | Raw value expressed as: $\frac{V_{AIN1}}{V_{ADC}} \text{ for attenuation.}$ $\frac{V_{ADC}}{V_{AIN1}} \text{ for amplification.}$   |
| 15      | 1    | AIOT  | _           | $V_{AIN0}$ conversion type (set at compilation step according to hardware). | 0b0 : attenuation. 0b1 : amplification.                                                                                             |
| 14 – 0  | 15   | AIOG  | _           | $V_{AIN0}$ conversion gain (set at compilation step according to hardware). | Raw value expressed as: $\frac{V_{AIN0}}{V_{ADC}} \ \text{for attenuation.}$ $\frac{V_{ADC}}{V_{AIN0}} \ \text{for amplification.}$ |

Table 84: Flags register 2.



### 4.2.7.3 Flags register 3

| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|
| AI3T |    |    |    |    |    |    | A. | I3G[15:0 | 0] |    |    |    |    |    |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| AI2T |    |    |    |    |    |    | A. | I2G[15:0 | 0] |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                                                                 | Format                                                                                                                              |
|---------|------|-------|-------------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31      | 1    | AI1T  | _           | $V_{AIN3}$ conversion type (set at compilation step according to hardware). | 0b0 : attenuation. 0b1 : amplification.                                                                                             |
| 30 – 16 | 15   | AI1G  | _           | $V_{AIN3}$ conversion gain (set at compilation step according to hardware). | Raw value expressed as: $\frac{V_{AIN3}}{V_{ADC}} \text{ for attenuation.}$ $\frac{V_{ADC}}{V_{AIN3}} \text{ for amplification.}$   |
| 15      | 1    | AIOT  | _           | $V_{AIN2}$ conversion type (set at compilation step according to hardware). | 0b0 : attenuation.<br>0b1 : amplification.                                                                                          |
| 14 – 0  | 15   | AIOG  | _           | $V_{AIN2}$ conversion gain (set at compilation step according to hardware). | Raw value expressed as: $\frac{V_{AIN2}}{V_{ADC}} \ \text{for attenuation.}$ $\frac{V_{ADC}}{V_{AIN2}} \ \text{for amplification.}$ |

Table 85: Configuration register 3.



### 4.2.7.4 Analog data register 1

| 31          | 30          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|             | VAIN1[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15          | 14          | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| VAINO[15:0] |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description         | Format   |
|---------|------|-------|-------------|---------------------|----------|
| 31 - 16 | 16   | VAIN1 | 0xFFFF      | $V_{AIN1}$ voltage. | Table 12 |
| 15 - 0  | 16   | VAINO | 0xFFFF      | $V_{AIN0}$ voltage. | Table 12 |

Table 86: Analog data register 1.

## 4.2.7.5 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VAIN3 | [15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VAIN2 | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description         | Format   |
|---------|------|-------|-------------|---------------------|----------|
| 31 - 16 | 16   | VAIN3 | 0xFFFF      | $V_{AIN3}$ voltage. | Table 12 |
| 15 - 0  | 16   | VAIN2 | 0xFFFF      | $V_{AIN2}$ voltage. | Table 12 |

Table 87: Analog data register 2.

### 4.2.7.6 Analog data register 3

| 31 | 30        | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18 | 17 | 16 |
|----|-----------|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|
|    |           |    |    |    |    |    |    |    |    |    |      |       |    |    |    |
| 15 | 14        | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
|    | HAMB[7:0] |    |    |    |    |    |    |    |    |    | TAMB | [7:0] |    |    |    |

| Bits    | Size | Field | Reset value | Description          | Format          |
|---------|------|-------|-------------|----------------------|-----------------|
| 31 - 16 | 16   | -     | 0x0000      | Unused.              | -               |
| 15 – 8  | 8    | HAMB  | 0xFF        | Ambient humidity.    | Raw value in %. |
| 7-0     | 8    | TAMB  | 0x7F        | Ambient temperature. | Table 11        |

Table 88: Analog data register 3.



### 4.2.7.7 Digital data register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20  | 19 | 18  | 17 | 16  |
|----|----|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|-----|
|    |    |    |    |    |    |    |    |    |     |    |     |    |     |    |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5  | 4   | 3  | 2   | 1  | 0   |
|    |    |    |    |    |    |    |    | DI | :03 | DI | :02 | DI | :01 | DI | 100 |

| Bits   | Size | Field | Reset value | Description            | Format                                                       |
|--------|------|-------|-------------|------------------------|--------------------------------------------------------------|
| 31 - 8 | 24   | _     | 0x000000    | Unused.                | _                                                            |
| 7 – 6  | 2    | DIO3  | 0b11        | Digital input 3 state. | Table 9           0b0 : low level           0b1 : high level |
| 5-4    | 2    | DI02  | 0b11        | Digital input 2 state. | Table 9           0b0 : low level           0b1 : high level |
| 3 – 2  | 2    | DIO1  | 0b11        | Digital input 1 state. | Table 9           0b0 : low level           0b1 : high level |
| 1-0    | 2    | DIOO  | 0b11        | Digital input 0 state. | Table 9           0b0 : low level           0b1 : high level |

Table 89: Digital data register.



## 4.2.8 RRM specific registers set

| REG_ADDR | Register name   | Size | Access | Format   | Description                                   |
|----------|-----------------|------|--------|----------|-----------------------------------------------|
| 0x09     | FLAGS_1         | 8    | R      | Table 91 | Compilation flags.                            |
| 0x0A     | CONFIGURATION_O | 16   | R/W    | Table 92 | $I_{OUT}$ offset calibration value.           |
| 0x0B     | STATUS_1        | 8    | R      | Table 93 | Regulator status.                             |
| 0x $0$ C | CONTROL_1       | 8    | R/W    | Table 94 | Regulator control.                            |
| 0x0D     | ANALOG_DATA_1   | 32   | R      | Table 95 | $V_{IN}$ and $V_{OUT}$ voltages measurements. |
| 0x0E     | ANALOG_DATA_2   | 16   | R      | Table 96 | $I_{OUT}$ current measurement.                |

 ${\bf Table~90:}~RRM~specific~registers~set.$ 

### 4.2.8.1 Flags register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RFH |

| Bits   | Size | Field | Reset value | Description                                                             | Format                                                                                                                  |
|--------|------|-------|-------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31 - 1 | 31   | -     | 0b0[31]     | Unused.                                                                 | _                                                                                                                       |
| 0      | 1    | RFH   | -           | Regulator control mode (set at compilation step according to hardware). | <ul> <li><b>0b0</b>: Regulator controlled by the MCU.</li> <li><b>0b1</b>: Regulator controlled by hardware.</li> </ul> |

Table 91: Flags register 1.

#### 4.2.8.2 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |         |          |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | I  | OUT_OFF | SET[15:0 | )] |    |    |    |    |    |    |

| Bits                 | Size | Field       | Reset value | Description                              | Format   |
|----------------------|------|-------------|-------------|------------------------------------------|----------|
| 31 - 16              | 16   | _           | 0x0000      | Unused.                                  |          |
| <b>15</b> – <b>0</b> | 16   | IOUT_OFFSET | _           | Output current offset calibration value. | Table 13 |

Table 92: Configuration register 0.



### 4.2.8.3 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | REI | NST |

| Bits   | Size | Field | Reset value | Description      | Format                                                                     |
|--------|------|-------|-------------|------------------|----------------------------------------------------------------------------|
| 31 - 2 | 30   | _     | 0b0[30]     | Unused.          | _                                                                          |
| 1-0    | 2    | RENST | 0b11        | Regulator state. | Table 9 0b00 : Regulator output disabled. 0b01 : Regulator output enabled. |

Table 93:  $Status\ register\ 1.$ 

#### 4.2.8.4 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REN |

| Bits   | Size | Field | Reset value | Description              | Format                                                                                   |
|--------|------|-------|-------------|--------------------------|------------------------------------------------------------------------------------------|
| 31 - 1 | 31   | -     | 0b0[31]     | Unused.                  | _                                                                                        |
| 0      | 1    | REN   | 0ь0         | Regulator state control. | <ul><li>0b0 : disable regulator output.</li><li>0b1 : enable regulator output.</li></ul> |

Table 94: Control register 1.



### 4.2.8.5 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VOUT [ | 15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VIN[1  | 15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description               | Format          |
|---------|------|-------|-------------|---------------------------|-----------------|
| 31 – 16 | 16   | VOUT  | 0xFFFF      | Regulator output voltage. | Table <b>12</b> |
| 15 – 0  | 16   | VIN   | 0xFFFF      | Regulator input voltage.  | Table 12        |

Table 95: Analog data register 1.

### 4.2.8.6 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | IOUT[ | 15:0] |    |    |    |    |    |    | ·  |

| Bits    | Size | Field | Reset value | Description               | Format   |
|---------|------|-------|-------------|---------------------------|----------|
| 31 - 16 | 16   | -     | 0x0000      | Unused.                   | _        |
| 15 – 0  | 16   | IOUT  | 0xFFFF      | Regulator output current. | Table 13 |

Table 96: Analog data register 2.



## 4.2.9 DMM specific registers set

| REG_ADDR | Register name   | Size | Access | Format           | Description                                   |
|----------|-----------------|------|--------|------------------|-----------------------------------------------|
| 0x09     | CONFIGURATION_O | 32   | R/W    | Table 98         | Radio monitoring and nodes scan periods.      |
| 0x0A     | STATUS_1        | 8    | R      | Table 99         | Nodes count.                                  |
| 0x0B     | CONTROL_1       | 8    | R/W    | Table <b>100</b> | Nodes scan trigger flag.                      |
| 0x $0$ C | ANALOG_DATA_1   | 32   | R      | Table <b>101</b> | $V_{RS}$ and $V_{HMI}$ voltages measurements. |
| 0x0D     | ANALOG_DATA_2   | 16   | R      | Table <b>102</b> | $V_{USB}$ voltage measurement.                |

 ${\it Table~97:~DMM~specific~registers~set.}$ 

### 4.2.9.1 Configuration register 0

| 31 | 30 | 29  | 28      | 27       | 26   | 25 | 24 | 23 | 22 | 21   | 20       | 19       | 18   | 17 | 16 |
|----|----|-----|---------|----------|------|----|----|----|----|------|----------|----------|------|----|----|
|    |    |     |         |          |      |    |    |    |    | SIG  | FOX_DL_I | PERIOD[7 | 7:0] |    |    |
| 15 | 14 | 13  | 12      | 11       | 10   | 9  | 8  | 7  | 6  | 5    | 4        | 3        | 2    | 1  | 0  |
|    |    | SIG | FOX_UL_ | PERIOD[7 | 7:0] |    |    |    |    | NODE | ES_SCAN_ | PERIOD[  | 7:0] |    |    |

| Bits    | Size | Field             | Reset value | Description                  | Format   |
|---------|------|-------------------|-------------|------------------------------|----------|
| 31 - 24 | 8    | _                 | 0x00        | Unused.                      | _        |
| 23 – 16 | 8    | SIGFOX_DL_PERIOD  | _           | Remote control period.       | Table 10 |
| 15 - 8  | 8    | SIGFOX_UL_PERIOD  | _           | Remote monitoring period.    | Table 10 |
| 7-0     | 8    | NODES_SCAN_PERIOD | _           | Automatic nodes scan period. | Table 10 |

Table 98: Configuration register 0.

### 4.2.9.2 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19      | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|---------|---------|----|----|----|
|    |    |    |    |    |    |    |    |    |    |    |         |         |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4       | 3       | 2  | 1  | 0  |
|    |    |    |    |    |    |    |    |    |    | ľ  | ODES_CO | UNT[7:0 | ]  |    |    |

| Bits   | Size | Field       | Reset value | Description                           | Format     |
|--------|------|-------------|-------------|---------------------------------------|------------|
| 31 - 8 | 24   | _           | 0x000000    | Unused.                               | _          |
| 7-0    | 8    | NODES_COUNT | _           | Number of nodes connected on the bus. | Raw value. |

Table 99:  $Status\ register\ 1.$ 



#### 4.2.9.3 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STRG |

| Bits   | Size | Field | Reset value | Description                 | Format                                                                                                                   |
|--------|------|-------|-------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31 - 1 | 31   | _     | 0b0[31]     | Unused.                     | _                                                                                                                        |
| 0      | 1    | STRG  | 0Ь0         | Nodes scan trigger<br>flag. | <ul><li>0b0 : no action.</li><li>0b1 : start nodes scan. The bit is automatically cleared after the operation.</li></ul> |

Table 100: Control register 1.

## 4.2.9.4 Analog data register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VHMI[ | 15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VRS[  | 15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description                  | Format   |
|---------|------|-------|-------------|------------------------------|----------|
| Bits    | Size | Field | Reset value | Description                  | Format   |
| 31 - 16 | 16   | VHMI  | 0xFFFF      | HMI voltage.                 | Table 12 |
| 15 – 0  | 16   | VRS   | 0xFFFF      | RS485 bus power supply rail. | Table 12 |

Table 101: Analog data register 1.

### 4.2.9.5 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |        |       |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VUSB [ | 15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description  | Format   |
|---------|------|-------|-------------|--------------|----------|
| 31 - 16 | 16   | -     | 0x0000      | Unused.      | -        |
| 15 - 0  | 16   | VUSB  | 0xFFFF      | USB voltage. | Table 12 |

Table 102: Analog data register 2.



### 4.2.10 MPMCM specific registers set

| REG_ADDR    | Register name        | Size | Access | Format           | Description                               |
|-------------|----------------------|------|--------|------------------|-------------------------------------------|
| 0x09        | FLAGS_1              | 16   | R      | Table <b>104</b> | Transformer attenuation ratio.            |
| 0x0A        | FLAGS_2              | 32   | R      | Table <b>105</b> | Current sensors attenuation ratio.        |
| 0x0B        | CONFIGURATION_O      | 16   | R/W    | Table <b>106</b> | Transformer gain.                         |
| 0x $0$ C    | CONFIGURATION_1      | 32   | R/W    | Table <b>107</b> | CH1 and CH2 current sensors gain.         |
| 0x0D        | CONFIGURATION_2      | 32   | R/W    | Table <b>108</b> | CH3 and CH4 current sensors gain.         |
| 0x0E        | CONFIGURATION_3      | 8    | R/W    | Table <b>109</b> | Linky TIC sampling period.                |
| 0x0F        | STATUS_1             | 8    | R      | Table <b>110</b> | AC channels measurements status.          |
| 0x10        | CONTROL_1            | 8    | R/W    | Table <b>111</b> | AC channels measurements control.         |
| 0x11        | MAINS_FREQUENCY_O    | 32   | R      | Table <b>112</b> | Run and averaged mains frequency.         |
| 0x12        | MAINS_FREQUENCY_1    | 32   | R      | Table <b>113</b> | Min and max mains frequency.              |
| 0x13        | CH1_ACTIVE_POWER_O   | 32   | R      | Table 114        | CH1 run and averaged active power.        |
| 0x14        | CH1_ACTIVE_POWER_1   | 32   | R      | Table <b>115</b> | CH1 min and max active power.             |
| 0x15        | CH1_RMS_VOLTAGE_0    | 32   | R      | Table <b>116</b> | CH1 run and averaged RMS voltage.         |
| 0x16        | CH1_RMS_VOLTAGE_1    | 32   | R      | Table <b>117</b> | CH1 min and max RMS voltage;              |
| 0x17        | CH1_RMS_CURRENT_0    | 32   | R      | Table 118        | CH1 run and averaged RMS current.         |
| 0x18        | CH1_RMS_CURRENT_1    | 32   | R      | Table <b>119</b> | CH1 min and max RMS current.              |
| 0x19        | CH1_APPARENT_POWER_O | 32   | R      | Table <b>120</b> | CH1 run and averaged apparent power.      |
| 0x1A        | CH1_APPARENT_POWER_1 | 32   | R      | Table <b>121</b> | CH1 min and max apparent power.           |
| 0x1B        | CH1_POWER_FACTOR_O   | 32   | R      | Table <b>122</b> | CH1 run and averaged power factor.        |
| 0x1C        | CH1_POWER_FACTOR_1   | 32   | R      | Table <b>123</b> | CH1 min and max power factor.             |
| 0x1D        | CH1_ENERGY           | 32   | R      | Table <b>124</b> | CH1 cumulated active and apparent energy. |
| 0x1E - 0x28 |                      |      | Sa     | me for CH2       |                                           |
| 0x29 - 0x33 |                      |      | Sa     | me for CH3       |                                           |
| 0x34 - 0x3E |                      |      | Sa     | me for CH4       |                                           |
| 0x3F - 0x49 |                      |      | Sa     | me for TIC       |                                           |

Table 103: MPMCM specific registers set.

<u>Note:</u> As far as active power, apparent power and power factor are concerned, when the sign changes during the accumulation period (switch between production and consumption modes), the maximum and minimum values correspond to the absolute minimum value and absolute maximum value observed during the accumulation period.



### 4.2.10.1 Flags register 1

| 31 | 30 | 29   | 28      | 27      | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16  |
|----|----|------|---------|---------|------|----|----|----|----|----|----|----|-----|-----|-----|
|    |    |      |         |         |      |    |    |    |    |    |    |    |     |     |     |
| 15 | 14 | 13   | 12      | 11      | 10   | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1   | 0   |
|    |    | TRAN | SFORMER | _ATTEN[ | 7:0] |    |    |    |    |    |    |    | LTM | LTE | AME |

| Bits    | Size | Field             | Reset value | Description                                                                    | Format                                                                                           |
|---------|------|-------------------|-------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 31 - 16 | 16   | _                 | 0x0000      | Unused.                                                                        | -                                                                                                |
| 15 – 8  | 8    | TRANSFORMER_ATTEN | _           | Transformer attenuation ratio (set at compilation step according to hardware). | ${f Raw}$ value in $V/V$ .                                                                       |
| 7-3     | 5    | _                 | 0b0[5]      | Unused.                                                                        | -                                                                                                |
| 2       | 1    | LTM               | _           | Linky TIC mode.                                                                | <ul><li><b>0b0</b> : Historic mode.</li><li><b>0b1</b> : Standard mode.</li></ul>                |
| 1       | 1    | LTE               | _           | Linky TIC interface<br>enable flag.                                            | <ul><li>0b0 : Linky TIC interface disabled.</li><li>0b1 : Linky TIC interface enabled.</li></ul> |
| 0       | 1    | AME               | _           | Analog measure enable.                                                         | <ul><li>0b0 : Analog measure disabled.</li><li>0b1 : Analog measure enabled.</li></ul>           |

Table 104: Flags register 1.



### 4.2.10.2 Flags register 2

| 31 | 30 | 29      | 28      | 27       | 26        | 25 | 24 | 23 | 22 | 21      | 20      | 19       | 18      | 17 | 16 |
|----|----|---------|---------|----------|-----------|----|----|----|----|---------|---------|----------|---------|----|----|
|    |    | CH4_CUR | RENT_SE | NSOR_ATT | TEN [7:0] |    |    |    |    | CH3_CUR | RENT_SE | NSOR_ATT | EN[7:0] |    |    |
| 15 | 14 | 13      | 12      | 11       | 10        | 9  | 8  | 7  | 6  | 5       | 4       | 3        | 2       | 1  | 0  |
|    |    |         |         |          |           |    |    |    |    |         |         |          |         |    |    |

| Bits   | s Size      | Field                       | Reset value | Description                                                                           | Format                      |
|--------|-------------|-----------------------------|-------------|---------------------------------------------------------------------------------------|-----------------------------|
| 31 – 2 | <b>24</b> 8 | CH4<br>CURRENT_SENSOR_ATTEN | _           | CH4 current sensor attenuation ratio (set at compilation step according to hardware). | <b>Raw</b> value in $V/V$ . |
| 23 – 1 | 8           | CH3 CURRENT_SENSOR_ATTEN    | _           | CH3 current sensor attenuation ratio (set at compilation step according to hardware). | ${f Raw}$ value in $V/V$ .  |
| 15 –   | 8 8         | CH2<br>CURRENT_SENSOR_ATTEN | -           | CH2 current sensor attenuation ratio (set at compilation step according to hardware). | <b>Raw</b> value in $V/V$ . |
| 7 – (  | 0 8         | CH1<br>CURRENT_SENSOR_ATTEN | _           | CH1 current sensor attenuation ratio (set at compilation step according to hardware). | ${f Raw}$ value in $V/V$ .  |

Table 105: Flags register 2.

# 4.2.10.3 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24      | 23      | 22   | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|------|---------|---------|------|----|----|----|----|----|----|
|    |    |    |    |    |    |      |         |         |      |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8       | 7       | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | TRAN | SFORMER | _GAIN[1 | 5:0] |    |    |    |    |    |    |

| Bits    | Size | Field            | Reset value | Description                                       | Format                                |
|---------|------|------------------|-------------|---------------------------------------------------|---------------------------------------|
| 31 - 16 | 16   | _                | 0x0000      | Unused.                                           | _                                     |
| 15 – 0  | 16   | TRANSFORMER_GAIN | _           | Transformer gain (between primary and secondary). | <b>Raw</b> value in $10 \times V/V$ . |

Table 106: Configuration register 0.



### ${\bf 4.2.10.4}\quad {\bf Configuration\ register\ 1}$

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23       | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|---------|---------|----------|---------|----|----|----|----|----|----|
|    |    |    |    |    |    | CH2_CUR | RENT_SE | NSOR_GAI | N[15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7        | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CH1_CUR | RENT_SE | NSOR_GAI | N[15:0] |    |    |    |    |    |    |

| ]  | Bits   | Size | Field                      | Reset value | Description              | Format                                |
|----|--------|------|----------------------------|-------------|--------------------------|---------------------------------------|
| 31 | 1 - 16 | 16   | CH2<br>CURRENT_SENSOR_GAIN | _           | CH2 current sensor gain. | <b>Raw</b> value in $10 \times A/V$ . |
| 1  | 15-0   | 16   | CH1<br>CURRENT_SENSOR_GAIN | _           | CH1 current sensor gain. | <b>Raw</b> value in $10 \times A/V$ . |

 ${\bf Table~107:~Configuration~register~1.}$ 

### 4.2.10.5 Configuration register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24       | 23       | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|---------|----------|----------|---------|----|----|----|----|----|----|
|    |    |    |    |    |    | CH4_CUR | RENT_SE  | NSOR_GAI | N[15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8        | 7        | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CH3_CUR | RENT_SEN | NSOR_GAI | N[15:0] |    |    |    |    |    |    |

| Bits    | Size | Field                      | Reset value | Description              | Format                                |
|---------|------|----------------------------|-------------|--------------------------|---------------------------------------|
| 31 – 16 | 16   | CH4<br>CURRENT_SENSOR_GAIN | _           | CH4 current sensor gain. | <b>Raw</b> value in $10 \times A/V$ . |
| 15 - 0  | 16   | CH3<br>CURRENT_SENSOR_GAIN | _           | CH3 current sensor gain. | <b>Raw</b> value in $10 \times A/V$ . |

Table 108: Configuration register 2.

#### 4.2.10.6 Configuration register 3

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20       | 19      | 18    | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|-------|----------|---------|-------|----|----|
|    |    |    |    |    |    |    |    |    |    |       |          |         |       |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 4        | 3       | 2     | 1  | 0  |
|    |    |    |    |    |    |    |    |    |    | TIC_S | SAMPLING | _PERIOD | [7:0] |    |    |

| Bits   | Size | Field               | Reset value | Description                | Format   |
|--------|------|---------------------|-------------|----------------------------|----------|
| 31 - 8 | 24   | -                   | 0x000000    | Unused.                    | _        |
| 7-0    | 8    | TIC_SAMPLING_PERIOD | _           | Linky TIC sampling period. | Table 10 |

Table 109: Configuration register 3.



#### 4.2.10.7 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20   | 19   | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|-----|------|------|------|------|------|
|    |    |    |    |    |    |    |    |    |    |     |      |      |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4    | 3    | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    | MVD | TICD | CH4D | CH3D | CH2D | CH1D |

| Bits   | Size | Field | Reset value | Description                              | Format                                                                                  |
|--------|------|-------|-------------|------------------------------------------|-----------------------------------------------------------------------------------------|
| 31 - 6 | 26   | _     | 0b0[26]     | Unused.                                  | _                                                                                       |
| 5      | 1    | MVD   | 0b0         | Mains voltage detect flag.               | <ul><li>0b0 : mains voltage not detected</li><li>0b1 : mains voltage detected</li></ul> |
| 4      | 1    | TICD  | 0b0         | Linky TIC detect flag.                   | <ul><li>0b0 : Linky TIC not detected</li><li>0b1 : Linky TIC detected</li></ul>         |
| 3      | 1    | CH4D  | 0b0         | AC channel 4 current sensor detect flag. | 0b0 : sensor not connected<br>0b1 : sensor connected                                    |
| 2      | 1    | CH3D  | 0b0         | AC channel 3 current sensor detect flag. | 0b0 : sensor not connected<br>0b1 : sensor connected                                    |
| 1      | 1    | CH2D  | 0b0         | AC channel 2 current sensor detect flag. | 0b0 : sensor not connected<br>0b1 : sensor connected                                    |
| 0      | 1    | CH1D  | 0b0         | AC channel 1 current sensor detect flag. | 0b0 : sensor not connected<br>0b1 : sensor connected                                    |

Table 110: Status register 1.



### 4.2.10.8 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20   | 19   | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|
|    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    | FRQS | TICS | CH4S | CH3S | CH2S | CH1S |

| Bits   | Size | Field | Reset value | Description                                 | Format                                                                               |
|--------|------|-------|-------------|---------------------------------------------|--------------------------------------------------------------------------------------|
| 31 - 6 | 26   | -     | 0b0[26]     | Unused.                                     | _                                                                                    |
| 5      | 1    | FRQS  | 0ь0         | Mains frequency<br>measurements<br>control. | 0b0 : no action<br>0b1 : store frequency measurements<br>in registers and reset them |
| 4      | 1    | TICS  | 0ь0         | TIC measurements control.                   | 0b0 : no action<br>0b1 : store TIC measurements in<br>registers and reset them       |
| 3      | 1    | CH4S  | 0ь0         | AC channel 4<br>measurements<br>control.    | 0b0 : no action<br>0b1 : store all CH4 measurements<br>in registers and reset them   |
| 2      | 1    | CH3S  | 0b0         | AC channel 3 measurements control.          | 0b0: no action<br>0b1: store all CH3 measurements<br>in registers and reset them     |
| 1      | 1    | CH2S  | 0ь0         | AC channel 2 measurements control.          | 0b0 : no action<br>0b1 : store all CH2 measurements<br>in registers and reset them   |
| 0      | 1    | CH1S  | 0ь0         | AC channel 1<br>measurements<br>control.    | 0b0 : no action<br>0b1 : store all CH1 measurements<br>in registers and reset them   |

 ${\bf Table\ 111:}\ Control\ register\ 1.$ 



### 4.2.10.9 Mains frequency register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24      | 23       | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|--------|---------|----------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | MAINS_ | FREQUEN | ICY_MEAN | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8       | 7        | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | MAINS  | _FREQUE | NCY_RUN  | [15:0] |    |    |    |    |    |    |

| Bits    | Size | Field                | Reset value | Description                                                      | Format                          |
|---------|------|----------------------|-------------|------------------------------------------------------------------|---------------------------------|
| 31 – 16 | 16   | MAINS_FREQUENCY_MEAN | 0xFFFF      | Averaged value of mains frequency since last measurements reset. | $\mathbf{Raw}$ value in $cHz$ . |
| 15 – 0  | 16   | MAINS_FREQUENCY_RUN  | 0xFFFF      | Averaged value of<br>mains frequency<br>during last second.      | Raw value in $cHz$ .            |

Table 112: Mains frequency register 0.

### 4.2.10.10 Mains frequency register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24      | 23      | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-------|---------|---------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | MAINS | _FREQUE | NCY_MAX | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8       | 7       | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | MAINS | _FREQUE | NCY_MIN | [15:0] |    |    |    |    |    |    |

| Bits    | Size | Field               | Reset value | Description                                                     | Format                          |
|---------|------|---------------------|-------------|-----------------------------------------------------------------|---------------------------------|
| 31 – 16 | 16   | MAINS_FREQUENCY_MAX | 0xFFFF      | Maximum value of mains frequency since last measurements reset. | $\mathbf{Raw}$ value in $cHz$ . |
| 15 – 0  | 16   | MAINS_FREQUENCY_MIN | 0xFFFF      | Minimum value of mains frequency since last measurements reset. | $\mathbf{Raw}$ value in $cHz$ . |

Table 113: Mains frequency register 1.



### $4.2.10.11 \quad \text{CHx active power register 0} \\$

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24       | 23       | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|--------|----------|----------|---------|----|----|----|----|----|----|
|    |    |    |    |    |    | CHx_AC | TIVE_POV | WER_MEAN | T[15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8        | 7        | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CHx_AC | TIVE_PO  | WER_RUN  | [15:0]  |    |    |    |    |    |    |

| Bits    | Size | Field                 | Reset value | Description                                                   | Format   |
|---------|------|-----------------------|-------------|---------------------------------------------------------------|----------|
| 31 – 16 | 16   | CHx_ACTIVE_POWER_MEAN | 0x7FFF      | Averaged value of active power since last measurements reset. | Table 14 |
| 15 – 0  | 16   | CHx_ACTIVE_POWER_RUN  | 0x7FFF      | Averaged value of active power during last second.            | Table 14 |

Table 114: CHx active power register 0.

#### 4.2.10.12 CHx active power register 1

| 31 | 30                         | 29 | 28 | 27 | 26 | 25     | 24      | 23      | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------------------|----|----|----|----|--------|---------|---------|--------|----|----|----|----|----|----|
|    |                            |    |    |    |    | CHx_AC | TIVE_PO | WER_MAX | [15:0] |    |    |    |    |    |    |
| 15 | 14                         | 13 | 12 | 11 | 10 | 9      | 8       | 7       | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CHx_ACTIVE_POWER_MIN[15:0] |    |    |    |    |        |         |         |        |    |    |    |    |    |    |

|   | Bits   | Size | Field                | Reset value | Description                                                  | Format          |
|---|--------|------|----------------------|-------------|--------------------------------------------------------------|-----------------|
| 3 | 1 – 16 | 16   | CHx_ACTIVE_POWER_MAX | 0x7FFF      | Maximum value of active power since last measurements reset. | Table 14        |
| 1 | 15 – 0 | 16   | CHx_ACTIVE_POWER_MIN | 0x7FFF      | Minimum value of active power since last measurements reset. | Table <b>14</b> |

Table 115: CHx active power register 1.



### 4.2.10.13 CHx RMS voltage register 0

| 31 | 30                        | 29 | 28 | 27 | 26 | 25     | 24      | 23      | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------------------|----|----|----|----|--------|---------|---------|--------|----|----|----|----|----|----|
|    |                           |    |    |    |    | CHx_RM | S_VOLTA | GE_MEAN | [15:0] |    |    |    |    |    |    |
| 15 | 14                        | 13 | 12 | 11 | 10 | 9      | 8       | 7       | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CHx_RMS_VOLTAGE_RUN[15:0] |    |    |    |    |        |         |         |        |    |    |    |    |    |    |

| Bits    | Size | Field                | Reset value | Description                                                           | Format   |
|---------|------|----------------------|-------------|-----------------------------------------------------------------------|----------|
| 31 – 16 | 16   | CHx_RMS_VOLTAGE_MEAN | 0xFFFF      | Averaged value of<br>RMS voltage since<br>last measurements<br>reset. | Table 12 |
| 15 – 0  | 16   | CHx_RMS_VOLTAGE_RUN  | 0xFFFF      | Averaged value of<br>RMS voltage during<br>last second.               | Table 12 |

Table 116: CHx RMS voltage register 0.

### 4.2.10.14 CHx RMS voltage register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24       | 23       | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-------|----------|----------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CHx_R | MS_VOLTA | AGE_MAX[ | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8        | 7        | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CHx_R | MS_VOLTA | AGE_MIN[ | [15:0] |    |    |    |    |    |    |

| ĺ | Bits    | Size | Field               | Reset value | Description                                                          | Format          |
|---|---------|------|---------------------|-------------|----------------------------------------------------------------------|-----------------|
|   | 31 – 16 | 16   | CHx_RMS_VOLTAGE_MAX | 0xFFFF      | Maximum value of<br>RMS voltage since<br>last measurements<br>reset. | Table <b>12</b> |
|   | 15 – 0  | 16   | CHx_RMS_VOLTAGE_MIN | 0xFFFF      | Minimum value of<br>RMS voltage since<br>last measurements<br>reset. | Table <b>12</b> |

Table 117:  $CHx\ RMS\ voltage\ register\ 1.$ 



### 4.2.10.15 CHx RMS current register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24       | 23       | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|--------|----------|----------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CHx_RM | S_CURRE  | ENT_MEAN | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8        | 7        | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CHx_R  | MS_CURRI | ENT_RUN[ | 15:0]  |    |    |    |    |    |    |

| Bits    | Size | Field                | Reset value | Description                                                           | Format          |
|---------|------|----------------------|-------------|-----------------------------------------------------------------------|-----------------|
| 31 – 16 | 16   | CHx_RMS_CURRENT_MEAN | 0xFFFF      | Averaged value of<br>RMS current since<br>last measurements<br>reset. | Table <b>12</b> |
| 15 – 0  | 16   | CHx_RMS_CURRENT_RUN  | 0xFFFF      | Averaged value of<br>RMS current during<br>last second.               | Table <b>12</b> |

Table 118: CHx RMS current register  $\theta$ .

### $4.2.10.16 \quad \text{CHx RMS current register 1}$

| 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24       | 23      | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-------|----------|---------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CHx_R | MS_CURRI | ENT_MAX | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8        | 7       | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CHx_R | MS_CURRI | ENT_MIN | [15:0] |    |    |    |    |    |    |

| Bits    | Size | Field               | Reset value | Description                                                          | Format          |
|---------|------|---------------------|-------------|----------------------------------------------------------------------|-----------------|
| 31 – 16 | 16   | CHx_RMS_CURRENT_MAX | 0xFFFF      | Maximum value of<br>RMS current since<br>last measurements<br>reset. | Table 12        |
| 15 – 0  | 16   | CHx_RMS_CURRENT_MIN | 0xFFFF      | Minimum value of<br>RMS current since<br>last measurements<br>reset. | Table <b>12</b> |

Table 119:  $CHx\ RMS\ current\ register\ 1.$ 



### 4.2.10.17 CHx apparent power register 0

| 31 | 30                           | 29 | 28 | 27 | 26 | 25      | 24       | 23       | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------------------------|----|----|----|----|---------|----------|----------|---------|----|----|----|----|----|----|
|    |                              |    |    |    |    | CHx_APP | ARENT_PO | OWER_MEA | N[15:0] |    |    |    |    |    |    |
| 15 | 14                           | 13 | 12 | 11 | 10 | 9       | 8        | 7        | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CHx_APPARENT_POWER_RUN[15:0] |    |    |    |    |         |          |          |         |    |    |    |    |    |    |

| Bits    | Size | Field                   | Reset value | Description                                                     | Format   |
|---------|------|-------------------------|-------------|-----------------------------------------------------------------|----------|
| 31 – 16 | 16   | CHx_APPARENT_POWER_MEAN | 0x7FFF      | Averaged value of apparent power since last measurements reset. | Table 14 |
| 15 – 0  | 16   | CHx_APPARENT_POWER_RUN  | 0x7FFF      | Averaged value of apparent power during last second.            | Table 14 |

Table 120: CHx apparent power register 0.

### 4.2.10.18 CHx apparent power register 1

| 31 | 30                           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | CHx_APPARENT_POWER_MAX[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14                           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CHx_APPARENT_POWER_MIN[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bits    | Size | Field                  | Reset value | Description                                                    | Format   |
|---------|------|------------------------|-------------|----------------------------------------------------------------|----------|
| 31 – 16 | 16   | CHx_APPARENT_POWER_MAX | 0x7FFF      | Maximum value of apparent power since last measurements reset. | Table 14 |
| 15 – 0  | 16   | CHx_APPARENT_POWER_MIN | 0x7FFF      | Minimum value of apparent power since last measurements reset. | Table 14 |

Table 121: CHx apparent power register 1.



### 4.2.10.19 CHx power factor register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21     | 20       | 19       | 18     | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|--------|----------|----------|--------|----|----|
|    |    |    |    |    |    |    |    |    |    | CHx_P( | OWER_FAC | TOR_MEA  | N[7:0] |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5      | 4        | 3        | 2      | 1  | 0  |
|    |    |    |    |    |    |    |    |    |    | CHx_P  | OWER_FAC | CTOR_RUN | I[7:0] |    |    |

| Bits    | Size | Field                 | Reset value | Description                                                   | Format          |
|---------|------|-----------------------|-------------|---------------------------------------------------------------|-----------------|
| 31 - 24 | 8    | _                     | 0x00        | Unused.                                                       | -               |
| 24 – 16 | 8    | CHx_POWER_FACTOR_MEAN | 0x7F        | Averaged value of power factor since last measurements reset. | Table <b>16</b> |
| 15 – 8  | 8    | _                     | 0x00        | Unused.                                                       | -               |
| 7 – 0   | 8    | CHx_POWER_FACTOR_RUN  | 0x7F        | Averaged value of power factor during last second.            | Table <b>16</b> |

Table 122:  $\mathit{CHx}\ \mathit{power}\ \mathit{factor}\ \mathit{register}\ \mathit{0}.$ 

## $4.2.10.20 \quad \text{CHx power factor register 1}$

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20       | 19       | 18     | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|-------|----------|----------|--------|----|----|
|    |    |    |    |    |    |    |    |    |    | CHx_P | OWER_FAC | CTOR_MAX | [7:0]  |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 4        | 3        | 2      | 1  | 0  |
|    |    |    |    |    |    |    |    |    |    | CHx_P | OWER_FAG | CTOR_MIN | I[7:0] |    |    |

| Bits    | Size | Field                | Reset value | Description                                                  | Format          |
|---------|------|----------------------|-------------|--------------------------------------------------------------|-----------------|
| 31 - 24 | 8    | _                    | 0x00        | Unused.                                                      | _               |
| 23 – 16 | 8    | CHx_POWER_FACTOR_MAX | 0x7F        | Maximum value of power factor since last measurements reset. | Table <b>16</b> |
| 15 – 8  | 8    | _                    | 0x00        | Unused.                                                      | -               |
| 7 – 0   | 8    | CHx_POWER_FACTOR_MIN | 0x7F        | Minimum value of power factor since last measurements reset. | Table <b>16</b> |

Table 123:  $\mathit{CHx}\ \mathit{power}\ \mathit{factor}\ \mathit{register}\ 1.$ 



### 4.2.10.21 CHx energy register

| 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24       | 23        | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-------|----------|-----------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CHx_A | PPARENT. | _ENERGY   | [15:0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8        | 7         | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CHx_  | ACTIVE_  | ENERGY [1 | L5:0]  |    |    |    |    |    |    |

| Bits    | Size | Field               | Reset value | Description                                                    | Format          |
|---------|------|---------------------|-------------|----------------------------------------------------------------|-----------------|
| 31 – 16 | 16   | CHx_APPARENT_ENERGY | 0x0000      | Accumulated apparent energy since last measurements reset.     | Table <b>15</b> |
| 15 – 0  | 16   | CHx_ACTIVE_ENERGY   | 0x0000      | Accumulated active<br>energy since last<br>measurements reset. | Table <b>15</b> |

Table 124: CHx energy register.



## 4.2.11 BCM specific registers set

| REG_ADDR | Register name   | Size | Access | Format           | Description                                           |
|----------|-----------------|------|--------|------------------|-------------------------------------------------------|
| 0x $0$ 9 | FLAGS_1         | 16   | R      | Table <b>126</b> | Compilation flags.                                    |
| 0x0A     | CONFIGURATION_O | 32   | R/W    | Table <b>127</b> | CHEN threshold and toggle period.                     |
| 0x0B     | CONFIGURATION_1 | 32   | R/W    | Table <b>128</b> | Low voltage flag (LVF) thresholds.                    |
| 0x $0$ C | CONFIGURATION_2 | 32   | R/W    | Table <b>129</b> | Critical voltage flag (CVF) thresholds.               |
| 0x0D     | STATUS_1        | 16   | R      | Table <b>130</b> | Charging and backup status.                           |
| 0x $0$ E | CONTROL_1       | 8    | R/W    | Table <b>132</b> | Charging and backup control.                          |
| 0x0F     | ANALOG_DATA_1   | 32   | R      | Table <b>133</b> | $V_{SRC}$ and $V_{STR}$ voltages measurements.        |
| 0x10     | ANALOG_DATA_2   | 32   | R      | Table <b>134</b> | $V_{BKP}$ voltage and $I_{STR}$ current measurements. |

 ${\it Table~125:~BCM~specific~registers~set.}$ 

# 4.2.11.1 Flags register 1

| 31 | 30 | 29 | 28      | 27      | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|----|----|----|---------|---------|----|----|----|----|----|----|----|------|------|------|------|
|    |    |    |         |         |    |    |    |    |    |    |    |      |      |      |      |
| 15 | 14 | 13 | 12      | 11      | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
|    |    |    | SHUNT R | ESISTOR |    |    |    |    |    |    |    | BKFH | CLFH | CSFH | CEFH |

| Bits    | Size | Field          | Reset value | Description                                                                             | Format                                                                                                            |
|---------|------|----------------|-------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| 31 - 16 | 16   | -              | 0x0000      | Unused.                                                                                 | _                                                                                                                 |
| 15 - 8  | 8    | SHUNT_RESISTOR | _           | LTC4013 shunt resistor value.                                                           | <b>Raw</b> value in $m\Omega$ .                                                                                   |
| 7 - 4   | 4    | _              | 0x0         | Unused.                                                                                 | _                                                                                                                 |
| 3       | 1    | BKFH           | _           | Backup output<br>control mode (set at<br>compilation step<br>according to<br>hardware). | 0b0 : Backup output controlled by<br>the MCU.<br>0b1 : Backup output controlled by<br>hardware.                   |
| 2       | 1    | CLFH           | _           | LED control mode<br>(set at compilation<br>step according to<br>hardware).              | <ul><li>0b0 : LED controlled by the MCU.</li><li>0b1 : LED controlled by hardware.</li></ul>                      |
| 1       | 1    | CSFH           | _           | Charge status mode<br>(set at compilation<br>step according to<br>hardware).            | <ul> <li>0b0 : Charge status connected to the MCU.</li> <li>0b1 : Charge status connected in hardware.</li> </ul> |
| 0       | 1    | CEFH           | _           | Charge control mode<br>(set at compilation<br>step according to<br>hardware).           | <ul> <li>0b0 : Charge controlled by the MCU.</li> <li>0b1 : Charge controlled by hardware.</li> </ul>             |

Table 126: Flags register 1.



### 4.2.11.2 Configuration register 0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23      | 22 | 21 | 20       | 19      | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|---------|----|----|----------|---------|----|----|----|
|    |    |    |    |    |    |    |         |         |    | CH | HEN_TOGG | LE_PERI | OD |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7       | 6  | 5  | 4        | 3       | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CHEN_TH | RESHOLD |    |    |          |         |    |    |    |

| Bits    | Size | Field              | Reset value | Description                        | Format   |
|---------|------|--------------------|-------------|------------------------------------|----------|
| 31 - 24 | 8    | _                  | 0x00        | Unused.                            | _        |
| 23 – 16 | 8    | CHEN_TOGGLE_PERIOD | _           | Charge toggle period.              | Table 10 |
| 15 – 0  | 16   | CHEN_THRESHOLD     | _           | Voltage threshold to set CHEN bit. | Table 12 |

Table 127: Configuration register 0.

 $\underline{\mathbf{Note:}}$  this register is only used when CHMD = 0b1 and CEFH = 0b0.

### 4.2.11.3 Configuration register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | LV | F_HIGH_ | THRESHO  | LD |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | L  | VF_LOW_ | THRESHOL | .D |    |    |    |    |    |    |

| Bits    | Size | Field              | Reset value | Description                                   | Format          |
|---------|------|--------------------|-------------|-----------------------------------------------|-----------------|
| 31 – 16 | 16   | LVF_HIGH_THRESHOLD | _           | High threshold of the LVF voltage hysteresis. | Table <b>12</b> |
| 15 – 0  | 16   | LVF_LOW_THRESHOLD  | _           | Low threshold of the LVF voltage hysteresis.  | Table 12        |

Table 128:  $Configuration\ register\ 1.$ 



### 4.2.11.4 Configuration register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | C/ | F_HIGH_ | THRESHO  | LD |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | C  | VF_LOW_ | THRESHOL | .D |    |    |    |    |    |    |

| Bits    | Size | Field              | Reset value | Description                                   | Format   |
|---------|------|--------------------|-------------|-----------------------------------------------|----------|
| 31 – 16 | 16   | CVF_HIGH_THRESHOLD | _           | High threshold of the CVF voltage hysteresis. | Table 12 |
| 15 – 0  | 16   | CVF_LOW_THRESHOLD  | _           | Low threshold of the CVF voltage hysteresis.  | Table 12 |

Table 129: Configuration register 2.



### 4.2.11.5 Status register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23  | 22   | 21  | 20   | 19  | 18  | 17  | 16  |
|----|----|----|----|----|----|-----|-----|-----|------|-----|------|-----|-----|-----|-----|
|    |    |    |    |    |    |     |     |     |      |     |      |     |     |     |     |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5   | 4    | 3   | 2   | 1   | 0   |
|    |    |    |    |    |    | CVF | LVF | CHR | GST1 | CHR | GST0 | CHE | NST | BKE | NST |

| Bits    | Size | Field   | Reset value                          | Description                        | Format                                                                                                                                  |
|---------|------|---------|--------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 10 | 22   | _       | 0b0[22]                              | Unused.                            | _                                                                                                                                       |
| 9       | 1    | CVF     | 0b0                                  | Critical voltage<br>detector flag. | <ul><li>0b0 : battery voltage is above the critical threshold.</li><li>0b1 : battery voltage is under the critical threshold.</li></ul> |
| 8       | 1    | LVF     | 0b0                                  | Low voltage detector flag.         | <ul><li>0b0 : battery voltage is above the low threshold.</li><li>0b1 : battery voltage is under the low threshold.</li></ul>           |
| 7 – 6   | 2    | CHRGST1 | 0b11                                 | Battery charging status 1.         | Table 9 See table 131 for bit meaning.                                                                                                  |
| 5-4     | 2    | CHRGST0 | 0b11                                 | Battery charging status 0.         | Table 9 See table 131 for bit meaning.                                                                                                  |
| 3 – 2   | 2    | CHENST  | 0b11 Battery charging enable status. |                                    | Table 9 0b00 : charge disabled. 0b01 : charge enabled.                                                                                  |
| 1-0     | 2    | BKENST  | 0b11                                 | Backup output state.               | Table 9 0b00: backup output disabled. 0b01: backup output enabled.                                                                      |

Table 130: Status register 1.

| CHRGST1 | CHRGSTO | Charge status                         |
|---------|---------|---------------------------------------|
| 0b0     | 0b0     | Not charging or terminated            |
| 0b0     | 0b1     | Constant current charging (CC)        |
| 0b1     | 0b1     | Constant voltage charging (CV)        |
| 0b1     | 0b0     | Low battery or thermal shutdown fault |

Table 131:  $BCM\ charge\ status\ bits.$ 



### 4.2.11.6 Control register 1

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    |    |    |    |    |    | CHEN | CHMD | BKEN |

| Bits   | Size | Field | Reset value | Description                                                   | Format                                                                                                                         |
|--------|------|-------|-------------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31 - 3 | 29   | _     | 0b0[29]     | Unused.                                                       | _                                                                                                                              |
| 2      | 1    | CHEN  | 0b0         | Battery charging control (only if CHMD = 0b1 and CEFH = 0b0). | 0b0 : disable charge.<br>0b1 : enable charge.                                                                                  |
| 1      | 1    | CHMD  | 0b0         | Battery charging mode.                                        | <ul> <li>0b0 : charge is automatically controlled by software.</li> <li>0b1 : charge is controlled by the CHEN bit.</li> </ul> |
| 0      | 1    | BKEN  | 0b0         | Backup output<br>control.                                     | 0b0 : disable backup output.<br>0b1 : enable backup output.                                                                    |

Table 132:  $Control\ register\ 1.$ 



### $4.2.11.7 \quad \text{Analog data register 1} \\$

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | VSTR[ | [15:0] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VSRC[ | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description      | Format   |
|---------|------|-------|-------------|------------------|----------|
| 31 - 16 | 16   | VSTR  | 0xFFFF      | Battery voltage. | Table 12 |
| 15 - 0  | 16   | VSRC  | 0xFFFF      | Source voltage.  | Table 12 |

Table 133: Analog data register 1.

## 4.2.11.8 Analog data register 2

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | ISTR[ | 15:0]  |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | VBKP[ | [15:0] |    |    |    |    |    |    |    |

| Bits    | Size | Field | Reset value | Description             | Format   |
|---------|------|-------|-------------|-------------------------|----------|
| 31 - 16 | 16   | ISTR  | 0xFFFF      | Battery charge current. | Table 13 |
| 15 - 0  | 16   | VBKP  | 0xFFFF      | Backup voltage.         | Table 12 |

Table 134: Analog data register 2.



# 4.3 External nodes

# 4.3.1 R4S8CR specific registers set

| REG_ADDR | Register name | Size | Access | Format           | Description     |
|----------|---------------|------|--------|------------------|-----------------|
| 0x $0$ 0 | STATUS        | 16   | R      | Table <b>136</b> | Relays status.  |
| 0x01     | CONTROL       | 8    | R/W    | Table <b>137</b> | Relays control. |

Table 135: R4S8CR registers set.

## 4.3.1.1 Status register

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18   | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|
|     |     |     |     |     |     |     |     |     |     |     |     |     |      |     |     |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2    | 1   | 0   |
| R8S | TST | R7S | TST | R6S | TST | R5S | TST | R4S | TST | R3S | TST | R2S | STST | R1S | TST |

| Bits    | Size | Field  | Reset value | Description     | Format                         |
|---------|------|--------|-------------|-----------------|--------------------------------|
| 31 - 16 | 16   | _      | 0x0000      | Unused.         | _                              |
| 15 - 14 | 2    | R8STST | 0b11        | Relay 8 state.  |                                |
| 13 - 12 | 2    | R7STST | 0b11        | Relay 7 status. |                                |
| 11 - 10 | 2    | R6STST | 0b11        | Relay 6 status. | Table 9                        |
| 9 - 8   | 2    | R5STST | 0b11        | Relay 5 status. |                                |
| 7-6     | 2    | R4STST | 0b11        | Relay 4 status. | $\mathbf{0b0}:$ NC path closed |
| 5-4     | 2    | R3STST | 0b11        | Relay 3 status. | $\mathbf{0b1}:$ NO path closed |
| 3 - 2   | 2    | R2STST | 0b11        | Relay 2 status. |                                |
| 1 - 0   | 2    | R1STST | 0b11        | Relay 1 status. |                                |

 ${\bf Table~136:~Status~register.}$ 



### 4.3.1.2 Control register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|------|------|------|------|------|------|------|------|
|    |    |    |    |    |    |    |    |      |      |      |      |      |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    | R8ST | R7ST | R6ST | R5ST | R4ST | R3ST | R2ST | R1ST |

| Bits   | Size | Field | Reset value | Description    | Format                     |
|--------|------|-------|-------------|----------------|----------------------------|
| 31 - 8 | 24   | -     | 0x000000    | Unused.        | _                          |
| 7      | 1    | R8ST  | 0b0         | Relay 8 state. |                            |
| 6      | 1    | R7ST  | 0b0         | Relay 7 state. |                            |
| 5      | 1    | R6ST  | 0b0         | Relay 6 state. |                            |
| 4      | 1    | R5ST  | 0b0         | Relay 5 state. | <b>0b0</b> : close NC path |
| 3      | 1    | R4ST  | 0b0         | Relay 4 state. | <b>0b1</b> : close NO path |
| 2      | 1    | R3ST  | 0b0         | Relay 3 state. |                            |
| 1      | 1    | R2ST  | 0b0         | Relay 2 state. |                            |
| 0      | 1    | R1ST  | 0b0         | Relay 1 state. |                            |

 ${\bf Table~137:~Control~register.}$ 





### 4.4 Bus enumeration

Thanks to the node addressing system and the read commands, the master module is able to enumerate dynamically all the slaves nodes attached to the RS485 bus.

#### 4.4.1 DINFox nodes

For each NODE\_ADDR between 0x00 and 0x6F, the master uses the UNA-AT protocol at 1200 bauds and reads the common NODE\_ID register (see section 4.2.1.1). If a data is received, the master stores the address and the BOARD\_ID (directly read in the reply) in its nodes list.

### 4.4.2 External nodes

#### 4.4.2.1 KMTronic R4S8CR

For each NODE\_ADDR between 0x70 and 0x7E, the master uses the KMTronic protocol at 9600 bauds and reads the relays state. If a data is received, the master stores the address in its nodes list.



# 5 Radio link description

A DINFox system can be remotely monitored or controlled thanks to the **UHFM** node, which features a long-range bidirectional radio interface using **Sigfox** technology.

# 5.1 RF performances

The **UHFM HW1.0** has an RF front-end composed of a sub-GHz transceiver, a discrete RX LNA, a discrete TX filter, a diode switch and a common antenna connector. The next table recaps its characteristics.

| Parameter       | Condition                                                | Min | Тур  | Max | Unit |
|-----------------|----------------------------------------------------------|-----|------|-----|------|
| RF output power | $V_{RS}=5V,$ continuous wave at 868.13 $MHz$             |     | 14   |     | dBm  |
| TX current      |                                                          |     | 32   |     | mA   |
| TX current      | $V_{RS} = 5 V$ , Sigfox uplink frame at 868.13 $MHz$     |     | 26   |     | mA   |
| RF sensitivity  | $V_{RS} = 5 V$ , Sigfox downlink frame at $869.525  MHz$ |     | -128 |     | dBm  |
| RX current      |                                                          |     | 16   |     | mA   |

Table 138: UHFM HW1.0 characteristics.

# 5.2 Remote monitoring (uplink)

The remote monitoring is performed via the Sigfox uplink mechanism, which is periodically initiated by the DINFox system. One uplink operation sends the data of one node.

The payload starts with a 2 bytes header composed of the address of the node (NODE\_ADDR) and its board ID (BOARD\_ID) which uniquely identifies the node within the DINFox system. The remaining bytes (1 to 10) contain the node data, whose format depends on the board ID.

| В0        | B1       | B2 Bn (2 to 11)            |
|-----------|----------|----------------------------|
| NODE_ADDR | BOARD_ID | DATA (depends on board ID) |

Table 139: Uplink payload format.

This format has several advantages:

- ▶ By containing the board ID, the frame is self-sufficient: on the server side, the parser can decode any UL payload without knowing the nodes address mapping (which is dynamically enumerated by the DINFox system itself, not the server).
- ▶ The UL payload length can be optimized for a given board ID. Indeed, the number of data for a given node is fixed. A more generic format with register address and value would have been less efficient in term of bytes count.
- ► Frame formats which where already defined from other Sigfox projects can be reused, such as the startup frame or the error stack, improving the code factorization on the server side.

When multiple uplink payload formats have to be defined for a same module (same board ID), the **UL payload size** is used as distinguishing criteria.

The DATA field format is described in each node driver, implemented in the master embedded software: https://github.com/Ludovic-Lesur/dmm/tree/master/middleware/radio/src.



# 5.3 Remote control (downlink)

The remote control is performed via the Sigfox downlink mechanism, which is periodically initiated by the DINFox system. One downlink operation controls one or two nodes. Contrary to the uplink, a more generic interface was defined by accessing the node registers, since the DL payload length is fixed.

The 8 bytes of the payload starts with a 1 byte header containing an operation code (OP\_CODE) which defines the action to perform on the node(s). The remaining bytes contain optional dynamic data, whose format depends on the operation code.

| В0      | B1 | B2 | В3       | B4                | <b>B</b> 5 | B6 | В7 |
|---------|----|----|----------|-------------------|------------|----|----|
| OP_CODE |    |    | DATA (de | epends on operati | ion code)  |    |    |

 ${\bf Table~140:~} Downlink~payload~format.$ 

Since the DATA field is limited to 7 bytes, some operation codes have a limited access range regarding the register size that can be accessed. However most of writable registers are 8 bits long and are fully supported by all operation codes.

| OP_CODE | Operation               | Number<br>of nodes | Number of<br>registers | 8 bits<br>registers | 16 bits<br>registers | 32 bits<br>registers | Format           |
|---------|-------------------------|--------------------|------------------------|---------------------|----------------------|----------------------|------------------|
| 0x00    | No-operation (NOP)      | _                  | _                      | _                   | _                    | _                    | Table <b>142</b> |
| 0x01    | Single full read        | 1                  | 1                      | ✓                   | 1                    | 1                    | Table <b>143</b> |
| 0x02    | Single full write       | 1                  | 1                      | ✓                   | 1                    | 1                    | Table <b>144</b> |
| 0x03    | Single masked write     | 1                  | 1                      | ✓                   | 1                    | ×                    | Table <b>145</b> |
| 0x04    | Temporary full write    | 1                  | 1                      | ✓                   | 1                    | 1                    | Table <b>146</b> |
| 0x05    | Temporary masked write  | 1                  | 1                      | ✓                   | 1                    | ×                    | Table <b>147</b> |
| 0x06    | Successive full write   | 1                  | 1                      | ✓                   | 1                    | ×                    | Table <b>148</b> |
| 0x07    | Successive masked write | 1                  | 1                      | ✓                   | ×                    | ×                    | Table <b>149</b> |
| 0x08    | Dual full write         | 1                  | 2                      | ✓                   | 1                    | ×                    | Table <b>150</b> |
| 0x09    | Triple full write       | 1                  | 3                      | ✓                   | ×                    | ×                    | Table <b>151</b> |
| 0x0A    | Dual node write         | 2                  | 1                      | 1                   | ×                    | Х                    | Table <b>152</b> |

Table 141: Downlink operation codes.

### 5.3.1 No-operation (NOP)

The NOP operation should be used when a downlink is requested by the DINFox system but there is none action to perform. In terms of power consumption, it is better to send a NOP operation instead of sending nothing, because the radio modem will remain in RX state less time.

| В0   | B1 | B2 | В3 | B4 | B5 | B6 | В7 |
|------|----|----|----|----|----|----|----|
| 0x00 |    |    |    |    |    |    |    |

 ${\bf Table~142:~NOP~operation~DL~payload~format.}$ 



#### 5.3.2 Single full read

This operation reads one 32 bits register. The register value will be sent in the dedicated uplink action log message of the master board.

| В0   | B1        | B2       | В3 | B4 | <b>B</b> 5 | B6 | В7 |
|------|-----------|----------|----|----|------------|----|----|
| 0x01 | NODE_ADDR | REG_ADDR |    |    |            |    |    |

Table 143: Single full read operation DL payload format.

#### 5.3.3 Single full write

This operation writes a value in one 32 bits register.

| В0   | B1        | B2       | В3        | B4 | B5 | В6 | B7 |
|------|-----------|----------|-----------|----|----|----|----|
| 0x02 | NODE_ADDR | REG_ADDR | REG_VALUE |    |    |    |    |

Table 144: Single full write operation DL payload format.

#### 5.3.4 Single masked write

This operation writes a value in a subpart of a 16 bits register defined by a mask.

| В0       | B1        | B2       | В3       | B4 | B5    | В6    | В7 |
|----------|-----------|----------|----------|----|-------|-------|----|
| 0x $0$ 3 | NODE_ADDR | REG_ADDR | REG_MASK |    | REG_V | VALUE |    |

Table 145: Single masked write operation DL payload format.

#### 5.3.5 Temporary full write

This operation writes a value in one 32 bits register during a specified duration, and then comes back to the previous (read before downlink operation). The DURATION field follows the time byte format (see table 10).



Table 146: Temporary full write operation DL payload format.

#### 5.3.6 Temporary masked write

This operation writes a value in a subpart of a 16 bits register defined by a mask, during a specified duration, and then comes back to the previous (read before downlink operation). The DURATION field follows the time byte format (see table 10).



Table 147: Temporary masked write operation DL payload format.



#### 5.3.7 Successive full write

This operation performs two successive full write operations spaced by a given duration. The DURATION field follows the time byte format (see table 10).

| В0   | B1        | B2       | В3          | B4 | B5    | B6          | В7 |  |
|------|-----------|----------|-------------|----|-------|-------------|----|--|
| 0x06 | NODE_ADDR | REG_ADDR | REG_VALUE_1 |    | REG_V | REG_VALUE_2 |    |  |

Table 148: Successive full write DL payload format.

#### 5.3.8 Successive masked write

This operation performs two successive masked write operations spaced by a given duration. The DURATION field follows the time byte format (see table 10).



Table 149: Successive masked write DL payload format.

#### 5.3.9 Dual full write

This operation performs 2 independent full write operation on two 16 bits registers.

| В0   | B1        | B2         | В3          | B4 | <b>B</b> 5 | B6          | В7 |
|------|-----------|------------|-------------|----|------------|-------------|----|
| 0x08 | NODE_ADDR | REG_1_ADDR | REG_1_VALUE |    | REG_2_ADDR | REG_2_VALUE |    |

 ${\bf Table~150:~Dual~full~write~operation~DL~payload~format.}$ 

### 5.3.10 Triple full write

This operation performs 3 independent full write operation on three 8 bits registers.

| В0   | B1        | B2         | В3          | B4         | B5          | В6         | В7          |
|------|-----------|------------|-------------|------------|-------------|------------|-------------|
| 0x09 | NODE_ADDR | REG_1_ADDR | REG_1_VALUE | REG_2_ADDR | REG_2_VALUE | REG_3_ADDR | REG_3_VALUE |

Table 151: Triple full write operation DL payload format.

### 5.3.11 Dual node write

This operation performs 2 independent full write operation on two 8 bits registers of two different nodes.



 ${\it Table 152: Dual \ node \ write \ operation \ DL \ payload \ format.}$ 



## 6 Embedded software

# 6.1 DINFox master node (DMM)

The master node embedded software is hosted on GitHub: https://github.com/Ludovic-Lesur/dmm. As shown in the diagram below, the code is structured in such a way that all slaves node are accessed through a common interface (node.h header file). From low to high layers, the architecture is composed of:

- $\blacktriangleright$  the common physical layer (RS485 bus) handled by the LPUART peripheral.
- ▶ the specific slave nodes drivers, using the LMAC and the UNA-AT protocols for the DINFox nodes.
- ▶ a common node interface to write and read registers of all slave nodes (UNA framework implementation).
- ▶ the human machine interface (HMI) layer which handles the local user interface (screen, buttons and switches) and defines the data printing format for each node.
- ▶ the radio layer which defines the uplink messages format for each node and implements the downlink operation codes.
- ▶ the main application which calls the HMI and the radio drivers.



 ${\bf Figure~4:~Simplified~architecture~of~the~master~embedded~software.}$ 



# 6.2 DINFox slave nodes (DSM)

The slave nodes embedded software is hosted on GitHub: https://github.com/Ludovic-Lesur/dsm. As shown in the diagram below, the code is structured in such a way that all registers are accessed through a common interface (node.h header file). From low to high layers, the architecture is composed of:

- ▶ the common physical layer (RS485 bus) handled by the LPUART peripheral.
- ▶ the LMAC driver which manages the network layer.
- $\blacktriangleright$  the AT and UNA-AT drivers which are responsible for command parsing and execution.
- ▶ a common node interface to write and read registers of all slave nodes (UNA framework implementation). Contrary to the master node where all slaves have to be dynamically supported, the node is here selected at compilation level with macros (build configuration), since the final code will be flashed on 1 defined slave.
- $\blacktriangleright$  the main application which calls the command line task continuously.



Figure 5: Simplified architecture of the slave embedded software.



# 7 Hardware design

### 7.1 Power supply

DINFox nodes have been designed to achieve a very low power consumption, in order to be compatible with backup power systems. As shown in the below power tree, DINFox nodes are usually powered by two parallel sources:

- ▶ the power input  $(V_{SRC}, V_{IN}, V_{COM}, \text{ etc...})$ , generally a high voltage source but not always present.
- ▶ the bus voltage rail  $V_{RS}$ , typically provided by a **BPSM** or a **BCM** module connected to an energy storage element, in order to keep a backup voltage for all nodes when the power input is not available.



Figure 6: Simplified power tree of DINFox nodes.

Powering a node by its power input has two advantages:

- $\blacktriangleright$  The node does not drain current from the backup source  $V_{RS}$  when the high voltage is available.
- ▶ Avoid pseudo-powering issues of the MCU via the ADC pins, as there are some direct voltage dividers on the power input and output for monitoring.

Since most of the nodes monitor the power input, they can determine if they are currently powered by the power input or by the backup rail  $V_{RS}$ . Therefore, they can adjust their behavior accordingly to reduce the power consumption (ADC conversions period, enable LED blinking, etc...).

#### 7.1.1 LDO regulator

In order to optimize the power consumption, a very low quiescent current LDO regulator has to be chosen to power the MCU and the RS485 transceiver, which is always in reception on slaves nodes. The regulator must also withstand the high voltage input when available (up to 28V). The TPS709 regulator from Texas Instruments is an ideal reference and has been selected for all the boards (**TPS70930DBVx**, 3.0V output in SOT23-5 package).

| Parameter         | Condition           | Min | Typ | Max  | Unit    |
|-------------------|---------------------|-----|-----|------|---------|
| Input voltage     | _                   | 2.7 |     | 30.0 | V       |
| Output current    | _                   |     |     | 150  | mA      |
| Quiescent current | $I_{OUT} = 0  mA$   |     | 1.4 | 2.25 | $\mu A$ |
|                   | $I_{OUT} = 150  mA$ |     | 350 |      | $\mu A$ |
| Dropout voltage   | $I_{OUT} = 50  mA$  |     | 295 | 650  | mV      |
|                   | $I_{OUT} = 150  mA$ |     | 960 | 1400 | mV      |

Table 153: TPS70930DBVx LDO regulator characteristics.

<u>Warning:</u> whereas the regulator supports 30 V, the enable input of the TPS709 is limited to 6.5 V. As a consequence, when this regulator is not controlled and always on (for the MCU and the RS485 transceiver) the enable input must not be tied to the input but left floating: there is an internal pull-up that will ensure the regulator is on, with the right logic voltage whatever the input voltage.



#### 7.1.2 Schottky diodes

Schottky diodes perform the OR operation between the power input and  $V_{RS}$ , by naturally selecting the highest voltage as source. Caution must be taken on the **reverse current**: indeed, when one of the voltage inputs is not available (especially the power input), an extra leakage current is drained by the second diode which is in reverse state. Some Schottky diodes have an excellent low forward voltage (main characteristic of these diodes) but a very poor reverse current (tens of  $\mu A$ ) which drastically increase the node power consumption in idle mode. Also, the reverse voltage has to be higher than the power input maximum voltage (28 V).

Taken these parameters into account, the PMEG6010ELR reference from Nexperia was chosen for all the boards.

| Parameter               | Condition    | Min | Тур | Max | Unit |
|-------------------------|--------------|-----|-----|-----|------|
| Average forward current | _            |     |     | 1.0 | A    |
| Reverse voltage         | _            |     |     | 60  | V    |
| Forward voltage         | $I_F = 1 A$  |     | 605 | 660 | mV   |
| Reverse current         | $V_R = 60 V$ |     | 90  | 300 | nA   |

Table 154: PMEG6010ELR Schottky diode characteristics.

#### 7.1.3 MCU

Most of slave nodes are based on the  $\mathbf{STM32L0x1}$  MCU. Thanks to the LPUART peripheral clocked on the external  $32.768\,kHz$  quartz, the MCU is able to stay in  $\mathbf{stop}$  mode while waiting for commands with address match feature. Since there are only static measures to do, the core is only woken-up when a command is sent to the node address (and periodically to clear the internal watchdog).

| Parameter                | Condition | Min  | Typ | Max | Unit    |
|--------------------------|-----------|------|-----|-----|---------|
| Supply voltage           | _         | 1.65 |     | 3.6 | V       |
| MCU current in stop mode | _         |      | 1.5 |     | $\mu A$ |

Table 155: STM32L0x1 characteristics.

The MPMCM is an exception regarding power consumption. This node performs mains voltage measurements which require continuous AC data acquisition and processing. It is based on a STM32G4x1 MCU which is more powerful than a STM32L0x1. The LPUART peripheral has the same wake-up features, but the MCU is not put in stop mode when measuring (only when the mains voltage is not present).

As a consequence, this node continuously drains a high current. But power consumption is not a constraint in this case, because the node is indirectly powered by the mains voltage instead of the backup voltage  $V_{RS}$ .



#### 7.1.4 RS485 transceiver

There are lots of RS485 transceiver references, but only few of them are low power. In particular, the **MAX3471** of Maxims Integrated is one of the best part regarding power consumption: it can be powered by a  $3.0\,V$  supply and drains less than  $2\,\mu A$  in reception mode, whereas other transceivers drain hundreds of  $\mu A$ , even few mA.

| Parameter      | Condition        | Min | Тур | Max | Unit    |
|----------------|------------------|-----|-----|-----|---------|
| Supply voltage | _                | 2.5 |     | 5.5 | V       |
| RX current     | $V_{CC} < 3.6 V$ |     | 1.6 | 2.0 | $\mu A$ |
| TX current     | $V_{CC} < 3.6 V$ |     | 50  | 60  | $\mu A$ |

Table 156: MAX3471 characteristics.

### 7.1.5 VRS voltage

Due to the drop-out voltages of the LDO regulator (1400 mV maximum) and the Schottky diodes (660 mV maximum), the minimum supply voltage of the DINFox node is  $V_{RS} = 5 V$ .

| Parameter | Condition | Min | Typ | Max | Unit |
|-----------|-----------|-----|-----|-----|------|
| $V_{RS}$  | -         | 5.0 |     | 28  | V    |

Table 157:  $V_{RS}$  characteristics.

<u>Note:</u> if powering the nodes with their power inputs is not required, it is possible to remove the diodes, select a lower input voltage LDO regulator which will have a lower drop-out (such as TPS782, TPS7A05, etc...) and thus reduce  $V_{RS}$  to 3.6V. But in this case, caution must be taken with the voltage dividers which are directly connected to the MCU: either disconnect them or ensure that  $V_{RS}$  is always present.

### 7.1.6 Power consumption

Regarding the overall power consumption of a DINFox system, the most critical parameter is the RX current, because slave nodes are continuously listening on the RS485 bus to wait for commands. Thanks to the previous components selection, a slave node in continuous reception drains less than  $5 \,\mu A$  (except for **MPMCM** node).

| Parameter                    | Condition | Min Typ Max | Unit    |
|------------------------------|-----------|-------------|---------|
| Diode reverse current        | _         | 90          | nA      |
| LDO quiescent current        | -         | 1.4         | $\mu A$ |
| MCU current in stop mode     | -         | 1.5         | $\mu A$ |
| RS485 transceiver RX current | -         | 1.6         | $\mu A$ |
| Node overall RX current      | _         | 4.5         | $\mu A$ |

Table 158: DINFox slave node overall RX current.



## 7.2 Mechanical specification

As shown in the next drawing, DINFox nodes have been designed to be mounted on a **DIN rail**. They have a common height of  $70 \, mm$  and a variable width expressed in the standard U unit (multiple of  $17.6 \, mm$ ).

The RS485 interface described in section **3.2.1** is exposed on a male connector on the left edge and a female connector on the right edge, so that the modules can be **stacked side by side** without any wire.



Figure 7: Mechanical dimensions of a DINFox node.