## Low data rate, low power sub-1GHz transceiver #### Datasheet - production data #### **Features** - Frequency bands: 150-174 MHz, 300-348 MHz, 387-470 MHz, 779-956 MHz - Modulation schemes: 2-FSK, GFSK, MSK, GMSK, OOK, and ASK - Air data rate from 1 to 500 kbps - Very low power consumption (9 mA RX and 21 mA TX at +11 dBm) - Programmable RX digital filter from 1 kHz to 800 kHz - Programmable channel spacing (12.5 kHz min.) - Excellent performance of receiver sensitivity (-118 dBm), selectivity, and blocking - Programmable output power up to +16 dBm - Fast startup and frequency synthesizer settling time (6 μs) - Frequency offset compensation - Integrated temperature sensor - Battery indicator and low battery detector - RX and TX FIFO buffer (96 bytes each) - Configurability via SPI interface - Automatic acknowledgment, retransmission, and timeout protocol engine - AES 128-bit encryption co-processor - Antenna diversity algorithm - · Fully integrated ultra low power RC oscillator - Wake-up on internal timer and wake-up on external event - Flexible packet length with dynamic payload length - Sync word detection - Address check - · Automatic CRC handling - · FEC with interleaving - Digital RSSI output - Programmable carrier sense (CS) indicator - Automatic clear channel assessment (CCA) before transmitting (for listen-before-talk systems). Embedded CSMA/CA protocol - Programmable preamble quality indicator (PQI) - · Whitening and de-whitening of data - Wireless M-BUS, EN 300 220, FCC CFR47 15 (15.205, 15.209, 15.231, 15.247, 15.249), and ARIB STD T-67, T93, T-108 compliant - QFN20 4x4 mm RoHS package - Operating temperature range from -40 °C to 105 °C ## **Applications** - AMR (automatic meter reading) - Home and building automation - WSN (wireless sensors network) - Industrial monitoring and control - Wireless fire and security alarm systems - Point-to-point wireless link Table 1. Device summary | Order code | Package | Packing | |------------|---------|---------------| | SPIRIT1QTR | QFN20 | Tape and reel | Contents SPIRIT1 # **Contents** | 1 | Desci | ption | |---|--------|---------------------------------------------------| | 2 | Introd | uction | | 3 | | al application diagram and pin description | | | 3.1 | Typical application diagram11 | | 4 | Pinou | 15 | | 5 | Abso | ute maximum ratings and thermal data | | 6 | Chara | cteristics | | | 6.1 | General characteristics | | | 6.2 | Electrical specifications | | | | 6.2.1 Electrical characteristics | | | | 6.2.2 Digital SPI | | | | 6.2.3 RF receiver | | | | 6.2.4 RF transmitter | | | | 6.2.5 Crystal oscillator | | | | 6.2.6 Sensors | | 7 | Opera | ting modes | | | 7.1 | Reset sequence | | | 7.2 | Timer usage | | | 7.3 | Low duty cycle reload mode | | | | 7.3.1 LDC mode with automatically acknowledgement | | | 7.4 | CSMA/CA engine | | 8 | Block | description | | | 8.1 | Power management | | | | 8.1.1 Switching frequency | | | 8.2 | Power-on-reset (POR) 42 | | | 8.3 | Low battery indicator | | | 8.4 | Voltage reference | | | | | SPIRIT1 Contents | | 8.5 | Oscillator and RF synthesizer | 3 | |---|------|--------------------------------------------------|---| | | 8.6 | RCO: features and calibration | 7 | | | | 8.6.1 RC oscillator calibration | 7 | | | 8.7 | AGC 47 | 7 | | | 8.8 | AFC 48 | 8 | | | 8.9 | Symbol timing recovery | 9 | | | | 8.9.1 DLL mode | 9 | | | | 8.9.2 PLL mode | 9 | | | 8.10 | Receiver | 9 | | | 8.11 | Transmitter | 9 | | | 8.12 | Temperature sensors (TS) | 0 | | | 8.13 | AES encryption co-processor | 1 | | _ | _ | | _ | | 9 | | smission and reception | | | | 9.1 | PA configuration | | | | 9.2 | RF channel frequency settings | 4 | | | 9.3 | RX timeout management | 5 | | | 9.4 | Intermediate frequency setting | 6 | | | 9.5 | Modulation scheme | 7 | | | | 9.5.1 Data rate | 9 | | | | 9.5.2 RX channel bandwidth | 0 | | | 9.6 | Data coding and integrity check process | 1 | | | | 9.6.1 FEC | | | | | 9.6.2 CRC | | | | | 9.6.3 Data whitening | | | | 0.7 | 9.6.4 Data padding | | | | 9.7 | Packet handler engine | | | | | 9.7.1 STack packet | | | | | 9.7.2 Wireless M-Bus packet (W M-BUS, EN13757-4) | | | | | 9.7.4 Automatic packet filtering | | | | | 9.7.5 Link layer protocol | | | | 9.8 | Data modes | | | | 9.9 | Data FIFO | | | | 9.10 | Receiver quality indicators | | | | 0.10 | | • | | Contents | SPIRIT1 | |----------|---------| | CONTAINS | SPIRIT | | | | | | | 9.10.1 | RSSI | 71 | |----|-------|----------|----------------------|-------| | | | 9.10.2 | Carrier sense | 72 | | | | 9.10.3 | PQI | 72 | | | | 9.10.4 | SQI | 73 | | | 9.11 | Antenn | na diversity | 73 | | | 9.12 | Freque | ency hopping | 74 | | 10 | MCU | interfac | ce | 75 | | | 10.1 | Serial p | peripheral interface | 75 | | | 10.2 | Interrup | pts | 77 | | | 10.3 | GPIOs | · | 78 | | | 10.4 | MCU c | clock | 80 | | 11 | Regi | ster tab | ole | 82 | | 12 | Pack | age me | echanical data | . 101 | | 13 | Revis | sion his | story | . 103 | SPIRIT1 List of tables # List of tables | Table 1. | Device summary | 1 | |-----------|---------------------------------------------------------------------------------------|------| | Table 2. | Description of the external components of the typical application diagram | . 13 | | Table 3. | BOM for different bands | | | Table 4. | Pinout description | . 15 | | Table 5. | Absolute maximum ratings | . 16 | | Table 6. | Thermal data | | | Table 7. | Recommended operating conditions | | | Table 8. | General characteristics | . 17 | | Table 9. | Power consumption static modes | . 17 | | Table 10. | Power consumption | | | Table 11. | Digital SPI input and output (SDO, SDI, SCLK, CSn, and SDN) and GPIO specification (C | | | | O_1-4) | | | Table 12. | RF receiver characteristics | | | Table 13. | RF receiver characteristics - sensitivity | | | Table 14. | RF transmitter characteristics | | | Table 15. | Crystal oscillator characteristics | | | Table 16. | Ultra low power RC oscillator | | | Table 17. | N-Fractional $\Sigma\Delta$ frequency synthesizer characteristics | | | Table 18. | Analog temperature sensor characteristics | | | Table 19. | Battery indicator and low battery detector | | | Table 20. | States | | | Table 21. | Commands list | | | Table 22. | POR parameters | | | Table 23. | SPIRIT1 timers description and duration | | | Table 24. | SMPS configuration settings | | | Table 25. | Programmability of trans-conductance at startup | | | Table 26. | CP word look-up | | | Table 27. | RC calibrated speed | | | Table 28. | PA_level | | | Table 29. | Frequency threshold | | | Table 30. | RX timeout stop condition configuration | | | Table 31. | IF_OFFSET settings | | | Table 32. | CHFLT_M and CHFLT_E value for channel filter bandwidth (in kHz, for fclk = 24 MHz). | | | Table 33. | CHFLT_M and CHFLT_E value for channel filter bandwidth (in kHz, for fclk = 26 MHz). | | | Table 34. | Packet configuration | | | Table 35. | SPI interface timing requirements | | | Table 36. | Interrupts | | | Table 37. | Digital outputs | | | Table 38. | Digital inputs | | | Table 39. | MCU_CK_CONF configuration register | | | Table 40. | MCU clock vs. state | | | Table 41. | General configuration registers | | | Table 42. | Radio configuration registers (analog blocks) | | | Table 43. | Radio configuration registers (digital blocks) | | | Table 44. | Packet/protocol configuration registers | | | Table 45. | Frequently used registers | | | Table 46. | General information | | | Table 47. | QFN20 (4 x 4 mm.) mechanical data | 101 | | List of tab | SPIR | IT1 | | |-------------|---------------------------|-----|-----| | | | | | | Table 48. | Document revision history | | 103 | SPIRIT1 List of figures # **List of figures** | Figure 1. | SPIRIT1 block diagram | 9 | |------------|---------------------------------------|------| | Figure 2. | Suggested application diagram | | | Figure 3. | Application diagram for Tx boost mode | . 12 | | Figure 4. | Application diagram for SMPS OFF mode | . 13 | | Figure 5. | Diagram and transition | . 32 | | Figure 6. | Power-on reset timing and limits | . 35 | | Figure 7. | LDCR for Tx | . 37 | | Figure 8. | LDCR for Rx | . 37 | | Figure 9. | CSMA flowchart | . 40 | | Figure 10. | Shaping of ASK signal | . 50 | | Figure 11. | Output power ramping configuration | . 53 | | Figure 12. | LFSR block diagram | . 62 | | Figure 13. | Threshold of the linear FIFO | . 70 | | Figure 14. | SPI "write" operation | . 76 | | Figure 15. | SPI "read" operation | . 76 | | Figure 16. | SPI "command" operation | . 76 | | Figure 17. | OFN20 (4 x 4 mm.) drawing dimension | 102 | Description SPIRIT1 ## 1 Description The SPIRIT1 is a very low-power RF transceiver, intended for RF wireless applications in the sub-1 GHz band. It is designed to operate both in the license-free ISM and SRD frequency bands at 169, 315, 433, 868, and 915 MHz, but can also be programmed to operate at other additional frequencies in the 300-348 MHz, 387-470 MHz, and 779-956 MHz bands. The air data rate is programmable from 1 to 500 kbps, and the SPIRIT1 can be used in systems with channel spacing of 12.5/25 kHz, complying with the EN 300 220 standard. It uses a very small number of discrete external components and integrates a configurable baseband modem, which supports data management, modulation, and demodulation. The data management handles the data in the proprietary fully programmable packet format also allows the M-Bus standard compliance format (all performance classes). However, the SPIRIT1 can perform cyclic redundancy checks on the data as well as FEC encoding/decoding on the packets. The SPIRIT1 provides an optional automatic acknowledgement, retransmission, and timeout protocol engine in order to reduce overall system costs by handling all the high-speed link layer operations. Moreover, the SPIRIT1 supports an embedded CSMA/CA engine. An AES 128-bit encryption co-processor is available for secure data transfer. The SPIRIT1 fully supports antenna diversity with an integrated antenna switching control algorithm. The SPIRIT1 supports different modulation schemes: 2-FSK, GFSK, OOK, ASK, and MSK. Transmitted/received data bytes are buffered in two different three-level FIFOs (TX FIFO and RX FIFO), accessible via the SPI interface for host processing. SPIRIT1 Introduction ### 2 Introduction A simplified block diagram of the SPIRIT1 is shown in *Figure 1*. Figure 1. SPIRIT1 block diagram The receiver architecture is low-IF conversion. The received RF signal is amplified by a two-stage low-noise amplifier (LNA) and down-converted in quadrature (I and Q) to the intermediate frequency (IF). LNA and IF amplifiers make up the RX front-end (RXFE) and have programmable gain. At IF, I/Q signals are digitized by ADCs. The demodulated data is then provided to an external MCU either through the 96-byte RX FIFO, readable via SPI, or directly using a programmable GPIO pin. A 128-bit AES co-processor is available to perform (offline) data encryption/decryption to secure data transfer. The transmitter part of the SPIRIT1 is based on direct synthesis of the RF frequency. The power amplifier (PA) input is the LO generated by the RF synthesizer, while the output level can be configured between -30 dBm and +11 dBm in 0.5 dB steps. The data to be transmitted can be provided by an external MCU either through the 96-byte TX FIFO writable via SPI, or directly using a programmable GPIO pin. The SPIRIT1 supports frequency hopping, TX/RX and antenna diversity switch control, extending the link range and improving performance. The SPIRIT1 has a very efficient power management (PM) system. Introduction SPIRIT1 An integrated switched mode power supply (SMPS) regulator allows operation from a battery voltage ranging from +1.8 V to +3.6 V, and with power conversion efficiency of at least 80%. A crystal must be connected between XIN and XOUT. It is digitally configurable to operate with different crystals. As an alternative, an external clock signal can be used to feed XIN for proper operation. The SPIRIT1 also has an integrated low-power RC oscillator, generating the 34.7 kHz signal used as a clock for the slowest timeouts (i.e. sleeping and backoff). A standard 4-pin SPI bus is used to communicate with the external MCU. Four configurable general purpose I/Os are available. ## 3 Typical application diagram and pin description ## 3.1 Typical application diagram This section describes different application diagram of SPIRIT1 that can be used according to customer needs. In particular *Figure 2* shows the default configuration, *Figure 3* shows the TX boost mode configuration and *Figure 4* shows the SMPS off configuration. The default configuration is giving the best power consumption figures. The TX boost mode configuration is used to increase TX output power and the SMPS off configuration is used to enhance sensitivity at the expense of power consumption. When using SMPS off configuration, SMPS should disabled by setting to 1 bit DISABLE\_SMPS in PM\_CONFIG register. It is important the SDN pin to be driven by an external microcontroller. It should be set low when the supply voltage of the device is steady to VDD. A short circuit connection of the SDN pin to ground should be avoided. Figure 2. Suggested application diagram Figure 3. Application diagram for Tx boost mode Figure 4. Application diagram for SMPS OFF mode Table 2. Description of the external components of the typical application diagram | Components | Description | |----------------------|--------------------------------------------------------------------| | CO | Decoupling capacitor for on-chip voltage regulator to digital part | | C1, C2, C3, C14, C15 | RF LC filter/matching capacitors | | C4, C5 | RF balun/matching capacitors | | C6, C7, C8 | RF balun/matching DC blocking capacitors | | C9, C10 | Crystal loading capacitors | | C11, C12, C13 | SMPS LC filter capacitor | | LO | RF choke inductor | | L1, L2, L3, L9 | RF LC filter/matching inductors | | L4, L5, L6 | RF balun/matching inductors | | L7, L8 | SMPS LC filter inductor | | XTAL | 24, 26, 48, 52 MHz | Table 2 assumes to cover all the frequency bands using a set of different as shown in Table 3: BOM for different bands. Table 3. BOM for different bands | Ref | 170 MHz band | | 315 MHz band | | 433 MH | z band | 868 MH | z band | 915/922 MH | z band | |---------------|----------------------|--------------------|----------------------|-----------|----------------------|-----------------|----------------------|-------------------|---------------------|--------------------| | design<br>(1) | STEVAL-<br>IKRV001V1 | | STEVAL-<br>IKRV001V2 | | STEVAL-<br>IKRV001V3 | | STEVAL-<br>IKRV001V4 | | STEVAL-IKRV001V5 | | | Comp. | Supplier | Value | Supplier | Value | Supplier | Value | Supplier | Value | Supplier | Value | | C0 | Murata | 100nF | Murata | 100nF | Murata | 100nF | Murata | 100nF | Murata | 100nF | | C1 | Murata | 18pF | Murata | 12pF | Murata | 8.2pF | | NE | Murata | 7pF | | C2 | Murata | 27pF | Murata | 27pF | Murata | 18pF | Murata | 8.2pF | Murata | 2.4pF | | C3 | Murata | 4.3pF | Murata | 15pF | Murata | 10pF | Murata | 5.6pF | Murata | 3.6pF | | C4 | | NE | Murata | 3.9pF | Murata | 2.2pF | Murata | 2.2pF | Murata | 2pF | | C5 | Murata | 8pF | Murata | 4.7pF | Murata | 3.3pF | Murata | 1.8pF | Murata | 1.5pF | | C6 | Murata | 220pF | Murata | 220pF | Murata | 220pF | Murata | 220pF | Murata | 330pF | | C7 | Murata | 68nH<br>(inductor) | Murata | 220pF | Murata | 220pF | Murata | 220pF | Murata | 220pF | | C8 | Murata | 390pF | Murata | 220pF | Murata | 220pF | Murata | 220pF | Murata | 220pF | | C9 | Murata | 12pF | Murata | 12pF | Murata | 12pF | Murata | 12pF | Murata | 12pF | | C10 | Murata | 10pF | Murata | 10pF | Murata | 10pF | Murata | 10pF | Murata | 10pF | | C11 | Murata | 1µF | Murata | 1µF | Murata | 1µF | Murata | 470nF | Murata | 1µF | | C12 | Murata | 100nF | Murata | 100nF | Murata | 100nF | Murata | 100nF | Murata | 100nF | | C13 | Murata | 560pF | Murata | 330pF | Murata | 330pF | Murata | 330pF | Murata | 330pF | | C14 | Murata | 220pF | Murata | 1.8pF | Murata | 1.8pF | Murata | 1.2pF | | NE | | C15 | Murata | 6.2pF | Murata | 1.2pF | | NE | | NE | | NE | | L0 | Murata | 200nH | Murata | 220nH | Murata | 150nH | Murata | 100nH | Murata | 100nH | | L1 | Coilcraft | 39nH | Murata | 12nH | Murata | 8.2nH | Murata | 3nH | Murata | 3.6nH | | L2 | Coilcraft | 56nH | Murata | 12nH | Murata | 10nH | | 0R0<br>(resistor) | Murata | 5.1nH | | L3 | Murata | 3.6pF<br>(cap.) | Murata | 15nH | Murata | 10nH | Murata | 4.3nH | Tyco<br>Electronics | 0R0 | | L4 | Murata | 100nH | Murata | 47nH | Murata | 39nH | Murata | 18nH | Murata | 15nH | | L5 | Murata | 47nH | Murata | 39nH | Murata | 27nH | Murata | 18nH | Murata | 18nH | | L6 | | NE | | NE | | NE | Murata | 22nH | Murata | 15nH | | L7 | Murata | 10µH | Murata | 10µH | Murata | 10µH | Murata | 10µH | Murata | 10µH | | L8 | | 0R0<br>(resistor) | Murata | 270nH | Murata | 100nH | Coilcraft | 27nH | Coilcraft | 27nH | | L9 | Coilcraft | 51nH | Murata | 15nH | Murata | 6.2nH | Murata | 2.7nH | | NE | | XTAL | NDK | 25 MHz | NDK | 50<br>MHz | NDK | 50 or 52<br>MHz | NDK | 50 or 52<br>MHz | NDK | 50 or<br>52<br>MHz | <sup>1.</sup> For complete BOM including part numbers, please check the corresponding reference design. SPIRIT1 Pinout # 4 Pinout **Table 4. Pinout description** | Pin | Name | I/O | Description | |-----|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | GPIO_0 | I/O | See description of GPIOs below | | 2 | MISO | 0 | SPI data output pin | | 3 | MOSI | I | SPI data input pin | | 4 | SCLK | I | SPI clock input pin | | 5 | CSn | I | SPI chip select | | 6 | XOUT | 0 | Crystal oscillator output. Connect to an external 26 MHz crystal or leave floating if driving the XIN pin with an external signal source | | 7 | XIN | I | Crystal oscillator input. Connect to an external 26 MHz crystal or to an external source. If using an external clock source with no crystal, DC coupling with a nominal 0.2 VDC level is recommended with minimum AC amplitude of 400 mVpp. The instantaneous level at input cannot exceed the 0 - 1.4 V range. | | 8 | VBAT | VDD | +1.8 V to +3.6 V input supply voltage | | 9 | RXp | I | Differential RF input signal for the LNA. See application diagram for a | | 10 | RXn | I | typical matching network | | 11 | GND_PA | GND | Ground for PA. To be carefully decoupled from other grounds. | | 12 | TX | 0 | RF output signal | | 13 | SMPS Ext2 | I | Regulated DC-DC voltage input | | 14 | SMPS Ext1 | 0 | DC-DC output pin | | 15 | SDN | I | Shutdown input pin. 0-VDD V digital input. SDN should be = '0' in all modes except shutdown mode. When SDN ='1' the SPIRIT1 is completely shut down and the contents of the registers are lost. The GPIO and SPI ports during SHUTDOWN are in HiZ. | | 16 | VBAT | VDD | +1.8 V to +3.6 V input supply voltage | | 17 | VREG <sup>(1)</sup> | VDD | Regulated output voltage. A 100 nF decoupling capacitor is required | | 18 | GPIO3 | I/O | General purpose I/O that may be configured through the SPI | | 19 | GPIO2 | I/O | registers to perform various functions, including: – MCU clock output | | 20 | GPIO1 | I/O | <ul> <li>FIFO status flags</li> <li>Wake-up input</li> <li>Battery level detector</li> <li>TX-RX external switch control</li> <li>Antenna diversity control</li> <li>Temperature sensor output</li> </ul> | | 21 | GND | GND | Exposed pad ground pin | <sup>1.</sup> This pin is intended for use with the SPIRIT1 only. It cannot be used to provide supply voltage to other devices. # 5 Absolute maximum ratings and thermal data Absolute maximum ratings are those values above which damage to the device may occur. Functional operation under these conditions is not implied. All voltages are referred to GND. Table 5. Absolute maximum ratings | Pin | Parameter | Value | Unit | |----------------------|-----------------------------------|--------------|------| | 8,14,16 | Supply voltage and SMPS output | -0.3 to +3.9 | V | | 17 | DC voltage on VREG | -0.3 to +1.4 | ٧ | | 1,3,4,5,15,18,19,20 | DC voltage on digital input pins | -0.3 to +3.9 | V | | 2 | DC voltage on digital output pins | -0.3 to +3.9 | ٧ | | 11 | DC voltage on analog pins | -0.3 to +3.9 | V | | 6,7,9,10 | DC voltage on RX/XTAL pins | -0.3 to +1.4 | ٧ | | 13 | DC voltage on SMPS Ext2 pin | -0.3 to +1.8 | ٧ | | 12 | DC voltage on TX pin | -0.3 to +3.9 | V | | T <sub>STG</sub> | Storage temperature range | -40 to +125 | °C | | V <sub>ESD-HBM</sub> | Electrostatic discharge voltage | ±1.0 | KV | Table 6. Thermal data | Symbol | Parameter | QFN20 | Unit | |----------------------|-------------------------------------|-------|------| | R <sub>thj-amb</sub> | Thermal resistance junction-ambient | 45 | °C/W | Table 7. Recommended operating conditions | Symbol | Parameter | | Тур. | Max. | Unit | |------------------|-------------------------------------|-----|------|------|------| | V <sub>BAT</sub> | Operating battery supply voltage | 1.8 | 3 | 3.6 | V | | T <sub>A</sub> | Operating ambient temperature range | -40 | | 105 | °C | 16/104 DocID022758 Rev 10 ## 6 Characteristics #### 6.1 General characteristics **Table 8. General characteristics** | Symbol | Parameter | Min. | Тур. | Max. | Unit | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|-----------|-------| | | | 150 | | 174 | MHz | | FREQ | Frequency range | 300 | | 348 | MHz | | FREQ | Frequency range | 387 | - | 470 | MHz | | | | | | 956 | MHz | | | Air data rate for each modulation scheme. Note that if "Manchester", "3-out-of-6" and/or FEC encoselected, the effective bit rate will be lower. | oding/dec | oding op | tions are | | | | 2-FSK | 1 | | 500 | kBaud | | DR | GMSK (BT=1, BT=0.5) | 1 | | 500 | kBaud | | | GFSK (BT=1, BT=0.5) | 1 | - | 500 | kBaud | | | MSK | 1 | | 500 | kBaud | | | OOK/ASK | 1 | | 250 | kBaud | ## 6.2 Electrical specifications #### 6.2.1 Electrical characteristics Characteristics measured over recommended operating conditions unless otherwise specified. Typical values are referred to $T_A = 25$ °C, $V_{BAT} = 3.0$ V. All performance is referred to a 50 Ohm antenna connector, via the reference design using application diagram as in *Figure 2*, except otherwise noted. Table 9. Power consumption static modes | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |--------|----------------|-------------------------------------|------|------|------|------| | | | Shutdown <sup>(1)</sup> | | 2.5 | | | | | | Standby (1) | | 600 | | nA | | IBAT | Supply current | Sleep (1) | - | 850 | - | | | | | Ready (default mode) <sup>(1)</sup> | | 400 | | μΑ | | | | Lock <sup>(1)</sup> | | 4.4 | | mA | 1. See Table 20. Table 10. Power consumption | Symbol | Parameter | Test conditions | SMPS ON | SMPS OFF | Unit | |--------|----------------|----------------------------------------|---------|----------|------| | | | RX <sup>(1)</sup> 169 MHz | 9.2 | 16.9 | | | | | RX <sup>(1)</sup> 315 MHz | 9.2 | 16.9 | | | | | RX <sup>(1)</sup> 433 MHz | 9.2 | 16.9 | | | | | RX <sup>(1)</sup> 868 MHz | 9.7 | 17.6 | | | | | RX <sup>(1)</sup> 915 MHz | 9.8 | 17.6 | | | | | RX <sup>(1)</sup> 922 MHz | 9.8 | 17.9 | | | | | TX <sup>(1)(2)</sup> +16 dBm 169 MHz | 54 | | | | | | TX <sup>(1)(2)</sup> +16 dBm 315 MHz | 52 | | | | | | TX <sup>(1)(2)</sup> +16 dBm 433 MHz | 49.3 | | A | | IBAT | | TX <sup>(1)(2)</sup> +15.5 dBm 868 MHz | 44 | | | | IBAI | Supply current | TX <sup>(1)(2)</sup> +16 dBm 920 MHz | 45.2 | | mA | | | | TX <sup>(1)</sup> +11 dBm 169 MHz | 18 | 33 | | | | | TX <sup>(1)</sup> +11 dBm 315 MHz | 22 | 37 | | | | | TX <sup>(1)</sup> +11 dBm 433 MHz | 19.5 | 33 | | | | | TX <sup>(1)</sup> +11 dBm 868 MHz | 21 | 41 | | | | | TX <sup>(1)</sup> +11 dBm 920 MHz | 20 | 39 | | | | | TX <sup>(1)</sup> -8 dBm 169 MHz | 6 | | | | | | TX <sup>(1)</sup> -8 dBm 315 MHz | 6.5 | | | | | | TX <sup>(1)</sup> -7 dBm 433 MHz | 7 | | | | | | TX <sup>(1)</sup> -7 dBm 868 MHz | 7 | | | <sup>1.</sup> See table Table 20. ## 6.2.2 Digital SPI Table 11. Digital SPI input and output (SDO, SDI, SCLK, CSn, and SDN) and GPIO specification (GPIO\_1-4) | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |-------------------|----------------------|----------------------------------------------------------------------|------|------|------|------| | f <sub>clk</sub> | Clock frequency | | | | 10 | MHz | | C <sub>IN</sub> | Port I/O capacitance | | | 1.4 | | pF | | _ | Rise time | 0.1*VDD to 0.9*VDD,<br>CL=20 pF (low output<br>current programming) | | 6.0 | | 20 | | T <sub>RISE</sub> | rise une | 0.1*VDD to 0.9*VDD,<br>CL=20 pF (high output<br>current programming) | | 2.5 | | ns | 577 <sup>2.</sup> TX boost mode configuration $V_{BAT}$ = 3.6 V. Table 11. Digital SPI input and output (SDO, SDI, SCLK, CSn, and SDN) and GPIO specification (GPIO\_1-4) (continued) | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |-------------------|--------------------------------|--------------------------------------------------------------------------|-----------------------|------|---------------|------| | _ | Fall time | 0.1*VDD to 0.9*VDD,<br>CL=20 pF (low output<br>current programming) | | 7.0 | | nc | | T <sub>FALL</sub> | raii time | 0.1*VDD to 0.9*VDD,<br>CL=20 pF (high output<br>current programming) | | 2.5 | | ns | | V <sub>IH</sub> | Logic high level input voltage | | VDD/2<br>+0.3 | | | V | | V <sub>IL</sub> | Logic low level input voltage | | | | VDD/8<br>+0.3 | V | | V <sub>OH</sub> | High level output voltage | IOH = -2.4 mA (-4.2 mA if high output current capability is programmed). | (5/8)*<br>VDD+<br>0.1 | | | ٧ | | V <sub>OL</sub> | Low level output voltage | IOL = +2.4 mA (+4 mA if high output current capability is programmed). | | | 0.5 | ٧ | #### 6.2.3 RF receiver Characteristics measured over recommended operating conditions unless otherwise specified. All typical values are referred to $T_A$ = 25 °C, $V_{BAT}$ = 3.0 V, no frequency offset in the RX signal. All performance is referred to a 50 Ohm antenna connector, via the reference design. Table 12. RF receiver characteristics | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------|------|------|------|------| | RL | Return loss | 169.4-169.475 MHz, 433-435<br>MHz, 868-868.6 MHz, 310-320<br>MHz, 902-928 MHz <sup>(1)</sup> | | | -10 | dB | | CH <sub>BW</sub> | Receiver channel bandwidth | | 1 | | 800 | kHz | | P <sub>SAT</sub> | Saturation 1% PER (packet length = 20 bytes) FEC DISABLED | 868 MHz 2-GFSK (BT=1) 38.4<br>kbps (20 kHz dev. CH Filter=100<br>kHz) | | 10 | | dBm | | IIP <sub>3</sub> | Input third order intercept | Input power -50 dBm 915 MHz | -37 | -31 | -26 | dBm | Table 12. RF receiver characteristics (continued) | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |----------------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------| | | | Desired channel 3 dB above sensitivity level. 12.5 kHz Δf, 2-FSK 1.2 kbps, (1 kHz dev. CH Filter=6 kHz) | | 49 | | dB | | C/I <sub>1-CH</sub> <sup>(2) (3)</sup> | Adjacent channel rejection,<br>1% PER (packet length = 20 | Desired channel 3 dB above sensitivity level. 100 kHz ∆f, 2-FSK 1.2 kbps, (4.8 kHz dev. CH Filter=58 kHz) | | 40 | | dB | | O/11-CH | bytes) FEC DISABLED 868<br>MHz | Desired channel 3 dB above sensitivity level. 200 kHz ∆f, 2-GFSK (BT=1) 38.4 kbps, (20 kHz dev. CH Filter=100 kHz) | | 40 | | dB | | | | Desired channel 3 dB above sensitivity level. 750 kHz ∆f, 2-GFSK (BT=1) 250 kbps, (127 kHz dev. CH Filter=540 kHz) | | 38 | | dB | | | Alternate channel rejection,<br>1% PER (packet length = 20<br>bytes)<br>FEC DISABLED<br>868 MHz | Desired channel 3 dB above sensitivity level. 25 kHz ∆f, 2-FSK 1.2 kbps, (1 kHz dev. CH Filter=6 kHz) | | 52 | | dB | | C/I <sub>2-CH</sub> <sup>(4)</sup> | | Desired channel 3 dB above sensitivity level. 200 kHz ∆f, 2-FSK 1.2 kbps, (4.8 kHz dev. CH Filter=58 kHz) | | 43 | | dB | | 0/12-CH | | Desired channel 3 dB above sensitivity level. 400 kHz ∆f, 2-GFSK (BT=1) 38.4 kbps, (20 kHz dev. CH Filter=100 kHz) | | 44 | | dB | | | | Desired channel 3 dB above sensitivity level. 1.5 MHz Δf, 2-GFSK (BT=1) 250 kbps, (127 kHz dev. CH Filter=540 kHz) | | 46 | | dB | | IM <sub>REJ</sub> <sup>(4)</sup> | Image rejection, 1% PER<br>(packet length = 20 bytes)<br>1% PER (packet length = 20<br>bytes) FEC DISABLED | 868 MHz 2-GFSK (BT=1) 38.4<br>kbps (20kHz dev. CH Filter=100<br>kHz), desired channel 3 dB above<br>the sensitivity limit, with IQC<br>correction. | | 47 | | dB | | RX <sub>BLK</sub> <sup>(4)</sup> | Blocking at offset above the upper band edge and below | @ 2 MHz offset, 868 MHz 2-<br>GFSK (BT=1) 38.4kbps, desired<br>channel 3 dB above the sensitivity<br>limit | | -42 | | dBm | | NABLK. | upper band edge and below<br>the lower band edge 1%<br>BER | @ 10 MHz offset, 868 MHz 2-<br>GFSK (BT=1) 38.4kbps, desired<br>channel 3 dB above the sensitivity<br>limit | | -40 | | dBm | Table 12. RF receiver characteristics (continued) | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |--------------------|----------------------------------------------------------------|-----------------------------------------------------------------|------|--------------------------------------------------|------|------| | | | RF = 170 MHz, f< 1 GHz | | -65 | | | | | | RF = 170 MHz, 1 GHz < f < 4 GHz | | -69 | | | | | Spurious emissions | RF = 433 MHz - 435 MHz, f< 1<br>GHz | | -63 | | | | | (maximum values according to ETSI EN 300 220-1) | RF = 433 MHz - 435 MHz, 1 GHz<br>< f < 4 GHz | | -83 | | | | | | RF = 868 MHz, f< 1 GHz | | -70 | | | | | | RF = 868 MHz, 1 GHz < f < 6 GHz | | -60 | | | | | Spurious emissions (maxi- | RF = 312 MHz - 315 MHz, f< 1<br>GHz | | -69 | | | | DV | mum values according to ARIB STD-T93) | RF = 312 MHz - 315 MHz, f> 1<br>GHz | | -59 | | dBm | | RX <sub>SPUR</sub> | Spurious emissions (maximum values according to ARIB STD-T67) | RF = 426 MHz - 470 MHz | | -61 | | иыш | | | | RF = 920 MHz - 924 MHz, f< 710<br>MHz | | | | | | | | RF = 920 MHz - 924 MHz, 710<br>MHz < f < 915 MHz | | <-70 | | | | | Spurious emissions (maximum values according to ARIB STD-T108) | RF = 920 MHz - 924 MHz, 915<br>MHz < f < 930 MHz | | ζ-70 | | | | | | RF = 920 MHz - 924 MHz, 930<br>MHz < f < 1 GHz | | | | | | | | RF = 920 MHz - 924 MHz, f> 1<br>GHz | | -75 | | | | ZIN, RX | Differential Input Impedance (simulated values) | Max RX gain RF = 170 MHz RF = 315 MHz RF = 433 MHz RF = 868 MHz | | 200 - j36<br>180 - j57<br>170 - j70<br>118 - j87 | | Ω | | | , | RF = 915 MHz<br>RF = 922 MHz | | 113 - j87<br>113 - j87 | | | - 1. Guaranteed in an entire single sub band. Reference design can be different for different application bands. - 2. Interferer is CW signal (as specified by ETSI EN 300 220 v1). - 3. Selectivity performance is guaranteed if no SPI accesses are performed during reception or SPI clock is below 1 MHz. - 4. Blocker is CW signal (as specified by ETSI EN 300 220 v1). Table 13. RF receiver characteristics - sensitivity | Symbol | Parameter | Test condition | SMPS ON | SMPS OFF | Unit | |--------|----------------------------------------------------|-----------------------------------------------------------------------|---------|----------|------| | | | 169 MHz 2-FSK 1.2kbps<br>(4 kHz dev. CH Filter=10 kHz) | -117 | -123 | dBm | | | Sensitivity, 1% BER | 169 MHz 2-GFSK (BT=0.5)<br>2.4kbps (2.4 kHz dev. CH<br>Filter=7 kHz) | -114 | -121 | dBm | | DV | (according to W-MBUS N mode specification) | 169 MHz 2-FSK 38.4kbps (20 kHz<br>dev. CH Filter=100 kHz) | -104 | -109 | dBm | | RASENS | X <sub>SENS</sub> 1 | 169 MHz 2-GFSK (BT=0.5)<br>50 kbps (25 kHz dev. CH<br>Filter=100 kHz) | -104 | -108 | dBm | | | Sensitivity, 1% PER (packet length = 20 bytes) FEC | 315 MHz 2-FSK 1.2 kbps (4.8 kHz<br>dev. CH Filter=58 kHz) | -109 | -110 | dBm | | | DISABLED | 315 MHz MSK 500 kbps (CH<br>Filter=800 kHz) | -88 | -88 | dBm | Table 13. RF receiver characteristics - sensitivity (continued) | Symbol | Parameter | Test condition | SMPS ON | SMPS OFF | Unit | |--------------------|-------------------------------------------------------------|-----------------------------------------------------------------------|---------|----------|------| | | | 433 MHz 2-FSK 1.2 kbps (1 kHz<br>dev. CH Filter=6 kHz) | -116 | -120 | dBm | | | Sensitivity, 1% PER (packet | 433 MHz 2-GFSK (BT=1) 1.2<br>kbps (4.8 kHz dev. CH Filter=58<br>kHz) | -106 | -110 | dBm | | | length = 20 bytes) FEC<br>DISABLED | 433 MHz 2-GFSK (BT=1) 38.4<br>kbps (20 kHz dev. CH Filter=100<br>kHz) | -103 | -107 | dBm | | | | 433 MHz 2-GFSK (BT=1) 250<br>kbps (127 kHz dev. CH Filter=540<br>kHz) | -96 | -100 | dBm | | | Sensitivity, 1% PER (packet length = 20 bytes) FEC DISABLED | 868 MHz 2-FSK 1.2 kbps (1 kHz<br>dev. CH Filter=6 kHz) | -118 | -118 | dBm | | | | 868 MHz 2-GFSK (BT=1) 1.2<br>kbps (4.8 kHz dev. CH Filter=58<br>kHz) | -108 | -109 | dBm | | | | 868 MHz 2-GFSK (BT=1) 38.4<br>kbps (20 kHz dev. CH Filter=100<br>kHz) | -105 | -106 | dBm | | RX <sub>SENS</sub> | | 868 MHz GFSK (BT=1) 250 kbps<br>(127 kHz dev. CH Filter=540 kHz) | -98 | -99 | dBm | | | | 868 MHz MSK 250 kbps (CH<br>Filter=540 kHz) | -93 | -94 | dBm | | | | 915 MHz 2-FSK 1.2 kbps (4.8 kHz<br>dev. CH Filter=58 kHz) | -108 | -109 | dBm | | | Sensitivity, 1% PER (packet | 915 MHz 2-FSK 38.4 kbps (20 kHz dev. CH Filter =100 kHz) | -106 | -106 | dBm | | | length = 20 bytes) FEC<br>DISABLED | 915 MHz 2-FSK 250 kbps (127<br>kHz dev. CH Filter=540 kHz) | -98 | -99 | dBm | | | | 915 MHz MSK 500 kbps (CH<br>Filter=800 kHz) | -94 | -95 | dBm | | | | 922 MHz 2-FSK 1.2 kbps (4.8 kHz<br>dev. CH Filter=58 kHz) | -108 | -109 | dBm | | | Sensitivity, 1% PER (packet | 922 MHz 2-FSK 38.4 kbps (20<br>kHz dev. CH Filter =100 kHz) | -106 | -106 | dBm | | | length = 20 bytes) FEC<br>DISABLED | 922 MHz 2-FSK 250 kbps (127<br>kHz dev. CH Filter=540 kHz) | -98 | -99 | dBm | | | | 922 MHz MSK 500 kbps (CH<br>Filter=800 kHz) | -94 | -95 | dBm | Table 13. RF receiver characteristics - sensitivity (continued) | Symbol | Parameter | Test condition | SMPS ON | SMPS OFF | Unit | | |--------------------|----------------------------------------------------------------------------|----------------------------------------------|---------|----------|------|-----| | | Sensitivity, 1% PER (packet length = 20 bytes) FEC DISABLED <sup>(1)</sup> | 433 MHz OOK 1.2 kbps (CH Filter=6 kHz) | | -116 | -117 | dBm | | | | 433 MHz OOK 2.4 kbps (CH<br>Filter=12 kHz) | -113 | -116 | dBm | | | | | 433 MHz OOK 38.4 kbps (CH<br>Filter=100 kHz) | -99 | -100 | dBm | | | DV | | 433 MHz OOK 250 kbps (CH<br>Filter=540 kHz) | -87 | -87 | dBm | | | RX <sub>SENS</sub> | Sensitivity, 1% PER (packet length = 20 bytes) FEC DISABLED (2) | 868 MHz OOK 1.2 kbps (CH<br>Filter=6 kHz) | -116 | -116 | dBm | | | | | 868 MHz OOK 2.4 kbps (CH<br>Filter=12 kHz) | -113 | -114 | dBm | | | | | 868 MHz OOK 38.4 kbps (CH<br>Filter=100 kHz) | -100 | -100 | dBm | | | | | 868 MHz OOK 250 kbps (CH<br>Filter=540 kHz) | -90 | -90 | dBm | | <sup>1.</sup> In OOK modulation, indicated value represents mean power. #### 6.2.4 RF transmitter Characteristics measured over recommended operating conditions unless otherwise specified. All typical values are referred to $T_A$ = 25 °C, $V_{BAT}$ = 3.0 V. All performance is referred to a 50 Ohm antenna connector, via the reference design. **Table 14. RF transmitter characteristics** | Symbol | Parameter | Test conditions | | Тур. | Max. | Unit | |------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------|---|------|------|------| | P <sub>MAX_TX_BO</sub> | Maximum output power <sup>(1)(2)</sup> | Delivered to a 50 Ohm single-<br>ended load via reference design<br>using TX boost mode<br>configuration | - | 16 | | dBm | | P <sub>MAX</sub> | Maximum output power <sup>(2)</sup> | Delivered to a 50 Ohm single-<br>ended load via reference design | - | 11 | | dBm | | P <sub>MIN</sub> | Minimum output power | Delivered to a 50 Ohm single-<br>ended load via reference design | - | -30 | | dBm | | P <sub>STEP</sub> | Output power step | | - | 0.5 | | dB | Table 14. RF transmitter characteristics (continued) | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | | |------------------------|------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------|------|-------|------|-----| | | | | RF = 170 MHz, frequencies below 1 GHz | - | | -36 | dBm | | | | RF = 170 MHz, Frequencies above 1 GHz | - | | < -60 | dBm | | | | | RF = 170 MHz, frequencies within 47-74, 87.5-108,174-230,470-862 MHz | - | | -55 | dBm | | | | Unwanted emissions | RF = 434 MHz, frequencies below 1 GHz | - | | -42 | dBm | | | P <sub>SPUR,ETSI</sub> | according to ETSI<br>EN300 220-1 | RF = 434 MHz, Frequencies above 1 GHz | - | | -46 | dBm | | | | (harmonic included,<br>using reference design) | RF = 434 MHz, frequencies within<br>47-74, 87.5-108,174-230,470-862<br>MHz | - | | -61 | dBm | | | | | RF = 868 MHz, frequencies below 1 GHz | - | | -51 | dBm | | | | | RF = 868 MHz, Frequencies above 1 GHz | - | | -40 | dBm | | | | | RF = 868 MHz, frequencies within 47-74, 87.5-108,174-230,470-862 MHz | - | | -54 | dBm | | Table 14. RF transmitter characteristics (continued) | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |-----------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------| | | | RF = 310-320 MHz, harmonics<br>(measured with max output<br>power) | - | | -37 | dBm | | | | RF = 310-320 MHz, 1.705 MHz<br><f< 30="" mhz<="" td=""><td>-</td><td></td><td>&lt;-60</td><td>dBm</td></f<> | - | | <-60 | dBm | | | | RF = 310-320 MHz, 30 MHz <f<<br>88 MHz</f<<br> | - | | <-60 | dBm | | | | RF = 310-320 MHz, 88 MHz <f<<br>216 MHz</f<<br> | - | | <-60 | dBm | | | Unwanted emissions | RF = 310-320 MHz, 216 MHz <f<<br>960 MHz</f<<br> | - | | <-60 | dBm | | P <sub>SPUR,FCC</sub> | according to FCC part | RF = 310-320 MHz, 960 MHz <f< td=""><td>-</td><td></td><td>&lt;-60</td><td>dBm</td></f<> | - | | <-60 | dBm | | J. J. 3. | 15(harmonic included, using reference design) | RF = 902-928 MHz, 1.705 MHz<br><f< (@="" 30="" max="" mhz="" output="" power)<="" td=""><td>-</td><td></td><td>&lt;-70</td><td>dBm</td></f<> | - | | <-70 | dBm | | | | RF = 902-928 MHz, 30 MHz <f<<br>88 MHz (@ max output power)</f<<br> | - | | <-70 | dBm | | | | RF = 902-928 MHz, 88 MHz <f<<br>216 MHz (@ max output power)</f<<br> | - | | <-70 | dBm | | | | RF = 902-928 MHz, 216 MHz <f<<br>960 MHz (@ max output power)</f<<br> | - | | -52 | dBm | | | | RF = 902-928 MHz, 960 MHz <f<br>(@ max output power)</f<br> | - | | -41 | dBm | | | | 2 <sup>nd</sup> and 7 <sup>th</sup> harmonics | - | | -25 | dBc | Table 14. RF transmitter characteristics (continued) | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|------|------|------|------| | | | RF = 312-315 MHz, frequency<br>below 1 GHz (@ max output<br>power, according to ARIB STD-<br>T93) | - | | -41 | dBm | | | | RF = 312-315 MHz, frequency<br>above 1 GHz (@ max output<br>power, according to ARIB STD-<br>T93) | - | | -48 | dBm | | | | RF = 426-470 MHz (@ max output<br>power, according to ARIB STD-<br>T67) | - | | <-40 | dBm | | | | RF = 915-917 MHz and<br>RF = 920-930 MHz, f< 710 MHz<br>(@ max output power, according<br>to ARIB STD-T108) | - | | <-55 | dBm | | | | RF = 915-917 MHz and<br>RF = 920-930 MHz, 710 MHz <f<<br>915 MHz (@ max output power,<br/>according to ARIB STD-T108)</f<<br> | - | | -55 | dBm | | D | Unwanted emissions | RF = 915-917 MHz and<br>RF = 924-930 MHz, 915 MHz <f<<br>930 MHz (@ max output power,<br/>according to ARIB STD-T108)</f<<br> | - | | -36 | dBm | | P <sub>SPUR,ARIB</sub> | according to ARIB | RF = 920-924 MHz, 915 MHz <f<<br>920.3 MHz (@ max output power,<br/>according to ARIB STD-T108)</f<<br> | - | | <-36 | dBm | | | | RF = 920-924 MHz, 920.3 MHz<br><f< (@="" 924.3="" max="" mhz="" output<br="">power, according to ARIB STD-<br/>T108)</f<> | - | | -55 | dBm | | | | RF = 920-924 MHz, 924.3 MHz<br><f< (@="" 930="" max="" mhz="" output<br="">power, according to ARIB STD-<br/>T108)</f<> | - | | -36 | dBm | | | | RF = 915-917 MHz and<br>RF = 920-930 MHz, 930 MHz <f<<br>1000 MHz (@ max output power,<br/>according to ARIB STD-T108)</f<<br> | - | | -55 | dBm | | | | RF = 915-917 MHz and<br>RF = 920-930 MHz, 1000 MHz <f<<br>1215 MHz (@ max output power,<br/>according to ARIB STD-T108)</f<<br> | - | | <-60 | dBm | | | | RF = 915-917 MHz and<br>RF = 920-930 MHz, 1215 MHz <f<br>(@ max output power, according<br/>to ARIB STD-T108)</f<br> | - | | -38 | dBm | Table 14. RF transmitter characteristics (continued) | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |--------------------|-----------------------------------|-------------------------------------------------------------|------|----------|------|-------| | | | RF = 170 MHz, 2 <sup>nd</sup> harmonic (max power level) | - | | -36 | dBm | | | | RF = 170 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -55 | ubili | | | | RF = 315 MHz, 2 <sup>nd</sup> harmonic<br>(max power level) | | | -52 | dBc | | | | RF = 315 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -52 | ивс | | | | RF = 433 MHz, 2 <sup>nd</sup> harmonic<br>(max power level) | - | | -43 | | | D | Harmonics level | RF = 433 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -46 | dBm | | P <sub>HARM</sub> | | RF = 868 MHz, 2 <sup>nd</sup> harmonic<br>(max power level) | - | | -40 | UDIII | | | | RF = 868 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -42 | | | | | RF = 915 MHz, 2 <sup>nd</sup> harmonic<br>(max power level) | - | | -28 | dBc | | | | RF = 915 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -42 | | | | | RF = 922 MHz, 2 <sup>nd</sup> harmonic<br>(max power level) | - | | -39 | dBm | | | | RF = 922 MHz, 3 <sup>rd</sup> harmonic<br>(max power level) | - | | -60 | | | | | 170 MHz, using reference design | - | 46 + j36 | | Ohm | | | | 315 MHz, using reference design | - | 25 + j27 | | Ohm | | ΡΔ, | Optimum load impedance (simulated | 433 MHz, using reference design | - | 29 + j19 | | Ohm | | PA <sub>LOAD</sub> | values) | 868 MHz, using reference design | - | 34 - j7 | | Ohm | | | , | 915 MHz, using reference design | - | 15 + j28 | | Ohm | | | | 922 MHz, using reference design | - | 42 - j15 | | Ohm | $<sup>{\</sup>it 1.} \quad \hbox{In ASK/OOK modulation, indicated value represents peak power.}$ <sup>2.</sup> $V_{BAT}$ =3.6 V. Please refer to the AN4198 for more information. #### 6.2.5 **Crystal oscillator** Characteristics measured over recommended operating conditions unless otherwise specified. All typical values are referred to $T_A$ = 25 °C, $V_{BAT}$ = 3.0 V. Frequency synthesizer characteristics are referred to 915 MHz band. In order to avoid potential RF performance degradations, the crystal frequency should be chosen to satisfy the following equation: #### **Equation 1** $$nF_{ch} - ROUND(n\frac{F_{ch}}{F_{ref}})F_{ref} > 1MHz$$ where n is an integer in the set [1-7,B] (B is band divider). F<sub>ch</sub> is the channel frequency and F<sub>ref</sub> is the XTAL frequency Symbol **Parameter Test conditions** Min. Тур. Max. Unit 24 26 Range 1 XTAL<sub>E</sub> Crystal frequency MHz Range 2 48 52 Frequency tolerance<sup>(1)</sup> + 40 $F_{TOL}$ ppm 100 Hz -90 dBc/Hz Minimum requirement on 1 kHz -120 dBc/Hz external reference phase $PN_{XTAL}$ noise mask (Fxo=26 MHz), 10 kHz -135 dBc/Hz to avoid degradation on 100 kHz -140 dBc/Hz synthesizer phase/noise 1 MHz -140 dBc/Hz $V_{BAT}$ =1.8 V, Fxo= 52 Startup time(2) 60 120 T<sub>START</sub> 220 μs MHz Table 15. Crystal oscillator characteristics <sup>2.</sup> Startup times are crystal dependent. The crystal oscillator transconductance can be tuned to compensate the variation of crystal oscillator series resistance. | nbol | Parameter | Test conditions | Min. | Тур. | Max | |------|----------------------|----------------------------------------------------|------|------|-----| | | | Calibrated RC oscillator frequency is derived from | | | | | _ | Calibrated fraguency | on otal agaillator | | 247 | | Table 16. Ultra low power RC oscillator Including initial tolerance, crystal loading, aging, and temperature dependence. The acceptable crystal tolerance depends on RF frequency and channel spacing/bandwidth. Table 17. N-Fractional $\Sigma\Delta$ frequency synthesizer characteristics | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |---------------------|-----------------------------------------------------------|-----------------------------------------------|------|------|------|--------| | F <sub>RES</sub> | Frequency resolution | Fxo= 26 MHz high band | - | 33 | | Hz | | | | 10 kHz | -100 | -97 | -94 | dBc/Hz | | | PN <sub>SYNTH</sub> RF carrier phase noise (915 MHz band) | 100 kHz | -104 | -101 | -99 | dBc/Hz | | DNI | | 200 kHz | -105 | -102 | -100 | dBc/Hz | | PINSYNTH | | 500 kHz | -112 | -110 | -107 | dBc/Hz | | | | 1 MHz | -120 | -118 | -116 | dBc/Hz | | | | 2 MHz | -123 | -121 | -119 | dBc/Hz | | TO <sub>TIME</sub> | PLL turn-on/hop time | | | 60 | 80 | μs | | SET <sub>TIME</sub> | PLL RX/TX settling time | Settling time from RX to TX and from TX to RX | | 8.5 | | μs | | CAL <sub>TIME</sub> | PLL calibration time | | | 54 | | μs | #### 6.2.6 Sensors Characteristics measured over recommended operating conditions unless otherwise specified. All typical values are referred to $T_A$ = 25 °C, $V_{BAT}$ = 3.0 V. Table 18. Analog temperature sensor characteristics | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |---------------------|-------------------------|--------------------------------------------------------------------|------|------|------|-----------| | T <sub>ERR</sub> | Error in temperature | Across all the temperature range | | ±2.5 | | °C | | T <sub>SLOPE</sub> | Temperature coefficient | | | 2.5 | | mV/<br>°C | | V <sub>TS-OUT</sub> | Output voltage level | | _ | 0.92 | _ | V | | | Current consumption | Buffered output (low output impedance, about 400 Ohm) | | 600 | | μA | | T <sub>ICC</sub> | Current consumption | Not buffered output (high output impedance, about 100 k $\Omega$ ) | | 10 | | μA | Table 19. Battery indicator and low battery detector<sup>(1)</sup> | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |-----------|--------------------------|-----------------|------|------|------|------| | $V_{BLT}$ | Battery level thresholds | | 2.1 | | 2.7 | V | Table 19. Battery indicator and low battery detector<sup>(1)</sup> | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | |---------------------|-------------------------------|---------------------------------------------------------------------|------|-------|------|------| | ., | Brownout threshold | Measured in slow battery variation (static) conditions (inaccurate) | | 1.535 | | V | | V <sub>BOT</sub> | | Measured in slow battery variation (static) conditions (accurate) | | 1.684 | | ٧ | | BOT <sub>hyst</sub> | Brownout threshold hysteresis | | | 70 | | mV | <sup>1.</sup> For battery powered equipment, the TX does not transmit at a wrong frequency under low battery voltage conditions. It either remains on channel or stops transmitting. The latter can of course be realized by using a lock detect and/or by switching off the PA under control of the battery monitor. For testing reasons this control is enabled/disabled by SPI. Operating modes SPIRIT1 ## 7 Operating modes The SPIRIT1 is provided with a built-in main controller which controls the switching between the two main operating modes: transmit (TX) and receive (RX). In shutdown condition (the SPIRIT1 can be switched on/off with the external pin SDN, all other functions/registers/commands are available through the SPI interface and GPIOs), no internal supply is generated (in order to have minimum battery leakage), and hence, all stored data and configurations are lost. The GPIO and SPI ports during SHUTDOWN are in HiZ. From shutdown, the SPIRIT1 can be switched on from the SDN pin and goes into READY state, which is the default, where the reference signal from XO is available. From READY state, the SPIRIT1 can be moved to LOCK state to generate the high precision LO signal and/or TX or RX modes. Switching from RX to TX and vice versa can happen only by passing through the LOCK state. This operation is normally managed by radio control with a single user command (TX or RX). At the end of the operations above, the SPIRIT1 can return to its default state (READY) and can then be put into a sleeping condition (SLEEP state), having very low power consumption. If no timeout is required, the SPIRIT1 can be moved from READY to STANDBY state, which has the lowest possible current consumption while retaining FIFO, status and configuration registers. To manage the transitions towards and between these operating modes, the controller works as a statemachine, whose state switching is driven by SPI commands. See *Figure 5* for state diagram and transition time between states. Figure 5. Diagram and transition The SPIRIT1 radio control has three stable states (READY, STANDBY, LOCK) which may be defined stable, and they are accessed by the specific commands (respectively READY, 32/104 DocID022758 Rev 10 SPIRIT1 Operating modes STANDBY, and LOCKRX/LOCKTX), which can be left only if any other command is used. All other states are transient, which means that, in a typical configuration, the controller remains in those states, at most for any timeout timer duration. Also the READY and LOCK states behave as transients when they are not directly accessed with the specific commands (for example, when LOCK is temporarily used before reaching the TX or RX states). | STATE[6:0] <sup>(1)</sup> | State/mode | Digital LDO | SPI | Xtal | RF<br>Synth. | Wake-up<br>timer | Respon<br>to | ise time | |---------------------------|--------------------|------------------------------------------|-----|------|--------------|------------------|----------------------|----------------------| | | | | | | Sylitii. | tiller | TX | RX | | - | SHUTDOWN | OFF (register contents lost) | Off | Off | Off | Off | NA | NA | | 0x40 | STANDBY | ON (FIFO and register contents retained) | On | Off | Off | Off | 125 µs | 125 µs | | 0x36 | SLEEP | | On | Off | Off | On | 125 µs | 125 µs | | 0x03 | READY<br>(Default) | | On | On | Off | Don't care | 50 µs | 50 µs | | 0x0F | LOCK | | On | On | On | Don't care | NA | NA | | 0x33 | RX | | On | On | On | Don't care | 15 μs <sup>(3)</sup> | NA | | 0x5f | TX | | On | On | On | Don't care | NA | 15 μs <sup>(3)</sup> | Table 20. States Note: Response time SHUTDOWN to READY is ~650 μs. READY state is the default state after the power-on reset event. In the steady condition, the XO is settled and usable as the time reference for RCO calibration, for frequency synthesis, and as the system clock for the digital circuits. The TX and RX modes can be activated directly by the MCU using the TX and RX commands, or automatically if the state machine wakes up from SLEEP mode and some previous TX or RX is pending. The values are intend to a VCO manual calibration. In LOCK state the synthesizer is in a locking condition<sup>(a)</sup>. If LOCK state is reached using either one of the two specific commands (LOCKTX or LOCKRX), the state machine remains in LOCK state and waits for the next command. This feature can be used by the MCU to perform preliminary calibrations, as the MCU can read the calibration word in the a. LOCK state is reached when one of the following events occurs first: lock detector assertion or locking timeout expiration. <sup>1.</sup> All others values of STATE[6:0] are invalid and are an indication of an error condition due to bad registers configuration and/or hardware issue in the application board hosting SPIRIT1. <sup>2.</sup> These values are crystal dependent. The values are referred to 52 MHz. These two timings are applicable only for the automatic features (autoACK and CSMA) that automatically switch the device from RX to TX and viceversa. In case it is needed to pass from TX to RX (or viceversa) by means of command strobes, it is necessary to abort the current active state and go to the READY state (please refer to the state machine diagram, figure 5). Operating modes SPIRIT1 RCO\_VCO\_CALIBR\_OUT register and store it in a non-volatile memory, and after that it requires a further tuning cycle. When TX is activated by the TX command, the state machine goes into TX state and remains there until the current packet is fully transmitted or, in the case of direct mode TX, TXFIFO underflow condition is reached or the SABORT command is applied. After TX completion, the possible destinations are: - TX. if the persistent-TX option is enabled in the PROTOCOL configuration registers - PROTOCOL, if some protocol option (e.g. automatic re-transmission) is enabled - READY, if TX is completed and no protocol option is in progress. Similarly, when RX is activated by the RX command, the state machine goes into RX state and remains there until the packet is successfully received or the RX timeout expires. In case of direct mode RX, the RX stops when the RXFIFO overflow condition is reached or the SABORT command is applied. After RX completion, the possible destinations are: - RX, if the persistent-RX option is enabled in the PROTOCOL configuration registers - PROTOCOL, if some protocol option (e.g. automatic acknowledgement) is enabled - READY, if RX is completed and the LDCR mode is not active - SLEEP, if RX is completed and the LDCR mode is active. The SABORT command can always be used in TX or RX state to break any deadlock condition and the subsequent destination depends on SPIRIT1 programming according to the description above. Commands are used in the SPIRIT1 to change the operating mode, to enable/disable functions, and so on. A command is sent on the SPI interface and may be followed by any other SPI access without pulling CSn high. The complete list of commands is reported in *Table 21*. Note that the command code is the second byte to be sent on the MOSI pin (the first byte must be 0x80). | Command code | Command name | Execution state | Description | | |--------------|--------------|-------------------------|-----------------------------------------------------------------------------------|--| | 0x60 | TX | READY | Start to transmit | | | 0x61 | RX | READY | Start to receive | | | 0x62 | READY | STANDBY, SLEEP,<br>LOCK | Go to READY | | | 0x63 | STANDBY | READY | Go to STANDBY | | | 0x64 | SLEEP | READY | Go to SLEEP | | | 0x65 | LOCKRX | READY | Go to LOCK state by using the RX configuration of the synthesizer | | | 0x66 | LOCKTX | READY | Go to LOCK state by using the TX configuration of the synthesizer | | | 0x67 | SABORT | TX, RX | Exit from TX or RX states and go to READY state | | | 0x68 | LDC_RELOAD | All | Reload the LDC timer with the value stored in the LDC_PRESCALER/COUNTER registers | | **Table 21. Commands list** SPIRIT1 Operating modes Command Command name **Execution state** Description code SEQUENCE UPDA Reload the packet sequence counter with the value 0x69 ΑII stored in the PROTOCOL[2] register. TE 0x6A **AES Enc** ΑII Start the encryption routine ΑII Start the procedure to compute the key for decryption 0x6B **AES Key** 0x6C ΑII Start decryption using the current key **AES Dec** ΑII 0x6D **AES KeyDec** Compute the key and start decryption 0x70 **SRES** ΑII Reset 0x71 **FLUSHRXFIFO** ΑII Clean the RX FIFO 0x72 **FLUSHTXFIFO** ΑII Clean the TX FIFO Table 21. Commands list (continued) The commands are immediately valid after SPI transfer completion (i.e. no need for any CSn positive edge). ### 7.1 Reset sequence SPIRIT1 is provided with an automatic power-on reset (POR) circuit which generates an internal RESETN active (low) level for a time $T_{RESET}$ after the VDD reaches the reset release threshold voltage $V_{RRT}$ (provided that SDN is low), as shown below. The same reset pulse is generated after a step-down on the input pin SDN (provided that VDD> $V_{RRT}$ ). Figure 6. Power-on reset timing and limits The parameters $V_{RRT}$ and $T_{RESET}$ are fixed by design. At RESET, all the registers are initialized to their default values. Typical and extreme values are reported in the following table. Operating modes SPIRIT1 Table 22. POR parameters | Symbol | Parameter | | Тур. | Max. | Unit | |--------------------|---------------------------------|------|------|------|------| | V <sub>RRT</sub> | Reset startup threshold voltage | | 0.5 | | V | | T <sub>RESET</sub> | Reset pulse width | 0.24 | 0.65 | 1.0 | ms | Note: An SRES command is also available which generates an internal RESET of the SPIRIT1. ### 7.2 Timer usage Most of the timers are programmable via R/W registers. All timer registers are made up of two bytes: the first byte is a multiplier factor (prescaler); the second byte is a counter value. Timer period= PRESCALER x CONTER x Tclk The available timers and their features are listed in the following table. Table 23. SPIRIT1 timers description and duration | No. | Register name | Description | Source | Time<br>step | Max. time | |-----|----------------------|----------------------|------------------------|--------------|-----------| | 1 | RX_TIMEOUT_PRESCALER | RX operation timeout | f <sub>CLK</sub> /1210 | ~46µs | ~3s | | 2 | RX_TIMEOUT_COUNTER | NA operation timeout | | | | | 3 | LDCR_PRESCALER | Wake-up period | RCO | ~29µs | ~2s | | 4 | LDCR_COUNTER | wake-up period | | | | Note: If the counter register value (prescaler register value) of Rx timeout is 0, it never stops (infinite timeout), despite the value written in the prescaler register (counter register). It is not allowed to set LDC PRESCALER or LDC COUNTER to 0. For both timers, the effective number of cycles counted is given by the value + 1 (e.g. counter=1 and prescaler=1 produces $2 \times 2=4$ counts, counter=1 and prescaler=2 produces $2 \times 3=6$ counts, etc.). The max period of RX TIMEOUT is related to an $f_{CLK}$ of 26 MHz. ## 7.3 Low duty cycle reload mode The SPIRIT1 provides an operating mode, low duty cycle reload (LDCR), that allows operation with very low power consumption, while at the same time keeping an efficient communication link. The device provides a set of timers to handle low duty cycle reception efficiently. The wake up timer is configured, for example to the value Twu, and the device is in SLEEP for the most of the time, and every Twu it is woken up and set to transmit the content of the FIFO: SPIRIT1 Operating modes Since the embedded LDCR system automatically manages the transmission strobe, only a FIFO reload has to be done after the TX done IRQ (or in general, before the next wakeup) in order to prepare the next Tx. On the Rx, there is the same behavior, but on this side, there are some important notes in order to have a reliable link: - 1. At the beginning of the communication the device should always be in continuous Rx (infinite Rx timeout). - 2. On the first reception the Rx timeout has to be set to be a not infinite value. - 3. Since the embedded LDCR system automatically manages the reception strobe the only thing to do is a Rx FIFO reading on the RX\_DATA\_READY interrupt. So from now on, also the Rx starts the SLEEP/ACTIVE cycles: Figure 8. LDCR for Rx The wakeup timer for LDCR mode can be set through the LDC\_PRESCALER/COUNTER registers. This timer is clocked by the 34.7 kHz RC oscillator keeping unused blocks off. Due to clock mismatches, it would be better to synchronize RX with the incoming packet every time it occurs in order to ensure the matching between Tx and Rx active slots and avoid that the Tx transmits out of the Rx active slot. Operating modes SPIRIT1 In fact, even if the Tx and Rx wake up timers are nominally the same, they're measured on different time bases (considering the RC oscillators of the two devices that are not the same because of process tolerances). SPIRIT1 allows doing that in two ways: - The value of the wake-up timer can be reloaded during runtime using the LDCR\_RELOAD command with the values written in the LDC\_RELOAD\_PRESCALER/COUNTER registers. In doing so, the counting can be delayed or anticipated. - Alternatively, the wake-up timer can be automatically reloaded at the time the SYNC is received. This option must be enabled on the PROTOCOL register and it is available only for LDC mode in reception. It is strongly recommended to use the second way with a reload wakeup time equal to Twu-time\_to\_preamble\_and\_sync-guard\_time in order to wake up the device guard\_time ms before the start of Tx. The RC oscillator must be calibrated correctly before the LDC mode can be used. Also the manual calibration setting is recommended to avoid delay during this mode. If some bits of the IRQ\_MASK register are set, the IRQ\_STATUS register must be read to allow the access to the SLEEP state after a reception or transmission phase. ## 7.3.1 LDC mode with automatically acknowledgement. The LDC mode can be used together with the automatic acknowledgement (STack packet format configured). In this case during a single LDC cycle both the operations of reception and transmission are performed. If the SPIRIT1 is used as transmitter and the bitfield NACK\_TX is RESET (packet's field NO\_ACK = 0), at the end of the transmission phase the SPIRIT1 will go automatically in reception phase waiting for an ACK packet. At the end of the reception phase it will go in SLEEP state until the WUT expires. If the SPIRIT1 is used as receiver with the bitfield AUTO\_ACK set and it receives a packet with the NO\_ACK field reset, then the transmission of the ACK packet is automatically performed. At the end the SPIRIT1 will go in SLEEP until the WUT expires. # 7.4 CSMA/CA engine The CSMA/CA engine is a channel access mechanism based on the rule of sensing the channel before transmitting. This avoids the simultaneous use of the channel by different transmitters and increases the probability of correct reception of data being transmitted. CSMA is an optional feature that can be enabled when performing transmission. Please note that CSMA must not be enabled when the transceiver is in receive mode. CSMA cannot be used in conjuction with link layer protocol (see Section 9.7.5) features such as automatic acknowledgment and automatic retransmission. When CSMA is enabled, the device performs a clear channel assessment (CCA) before transmitting any data. In SPIRIT1 implementation, CCA is based on a comparison of the channel RSSI with a programmable static carrier sense threshold. 5// SPIRIT1 Operating modes If the CCA finds the channel busy, a backoff procedure may be activated to repeat the CCA process a certain number of times, until the channel is found to be idle. Each time that CCA is retried, a counter (NB) is incremented by one, up to the upper limit (NB<sub>max</sub>). When the limit is reached, an NBACKOFF\_MAX interrupt request is raised towards the MCU, to notify that the channel has been repeatedly found busy and so the transmission has not been performed. While in backoff, the device stays in SLEEP/READY state in order to reduce power consumption. CCA may optionally be persistent, i.e., rather than entering backoff when the channel is found busy, CCA continues until the channel becomes idle or until the MCU stops it. The thinking behind using this option is to give the MCU the possibility of managing the CCA by itself, for instance, with the allocation of a transmission timer: this timer would start when MCU finishes sending out data to be transmitted, and would end when MCU expects that its transmission takes place, which would occur after a period of CCA. The choice of making CCA persistent should come from trading off transmission latency, under the direct control of the MCU, and power consumption, which would be greater due to a busy wait in reception mode. The overall CSMA/CA flowchart is shown in *Figure 9*, where $T_{cca}$ and $T_{listen}$ are two of the parameters controlling the clear channel assessment procedure. Design practice recommends that these parameters average the channel energy over a certain period expressed as a multiple of the bit period ( $T_{cca}$ ) and repeat such measurement several times covering longer periods ( $T_{listen}$ ). The measurement is performed directly by checking the carrier sense (CS) generated by the receiver module. Operating modes SPIRIT1 Figure 9. CSMA flowchart To avoid any wait synchronization between different channel contenders, which may cause successive failing CCA operations, the backoff wait time is calculated randomly between 0 and a contention window. The backoff time BO is expressed as a multiple of backoff time units (BU). The contention window is calculated on the basis of the binary exponential 577 SPIRIT1 Operating modes backoff (BEB) technique, which doubles the size of the window at each backoff retry (stored in the NB counter): BO= rand(0,2NB)×BU The CSMA procedure is then controlled by the following parameters: SEED\_RELOAD: enables/disables the reload of the seed used by the backoff random generator at the start of each CSMA procedure (at the time when the counter is reset, i.e. NB=0). If this functionality is not enabled, the seed is automatically generated and updated by the generator circuit itself. CSMA\_ON: enables/disables the CSMA procedure (11<sup>th</sup> bit of the PROTOCOL[1] register); this bit is checked at each packet transmission. CSMA\_PERS\_ON: makes the carrier sense persistent, i.e. the channel is continuously monitored until it becomes free again, skipping the backoff waiting steps (9<sup>th</sup> bit of the PROTOCOL[1] register); the MCU can stop the procedure with an SABORT command. BU\_COUNTER\_SEED\_MSBYTE/LSBYTE: these bytes are used to set the seed of the pseudo-random number generator when the CSMA cycle starts (CSMA\_CONFIG[3:2] registers), provided that the SEED\_RELOAD bit is enabled. Value 0 is not allowed, because the pseudo-random generator does not work in that case. BU\_PRESCALER[5:0]: prescaler which is used to configure the backoff time unit <sup>(b)</sup> BU=BU\_PRESCALER in *Figure 9* (field of the CSMA\_CONFIG[1] register). CCA\_PERIOD[1:0]: code which programs the $T_{cca}$ time (expressed as a multiple of Tbit samples) between two successive CS samplings (field of the CSMA\_CONFIG[1] register), as follows: - 00 64×Tbit - 01 128×Tbit - 10 256×Tbit - 11 512×Tbit. CCA\_LENGTH[3:0]: configuration of $T_{listen} = [1..15] \times T_{cca}$ NBACKOFF MAX[2:0]: max. number of backoff cycles. 577 DocID022758 Rev 10 b. Note that the backoff timer is clocked on the 34.7 kHz clock, because, in this case, the SPIRIT1 is in SLEEP state, in order to reduce power consumption. Block description SPIRIT1 # 8 Block description ## 8.1 Power management The SPIRIT1 integrates a high efficiency step-down converter cascaded with LDOs meant to supply both analog and digital parts. However, an LDO directly fed by the external battery provides a controlled voltage to the data interface block. ## 8.1.1 Switching frequency The SMPS switching frequency can be provided either by a divider by four or by a programmable rate multiplier. The divider by four or the rate multiplier is activated when the EN\_RM bit is set both 0 and 1 in the PM\_CONFIG[2:0] register bank. When the rate multiplier is activated, the divider ratio can be programmed by KRM[14:0] word in the PM\_CONFIG[2:0] register bank. In this case, the SMPS switching frequency is given by the following formula: $$F_{sw} = \frac{KRM \cdot f_{CLK}}{2^{15}}$$ The SMPS runs properly when the bits SET\_SMPS\_VTUNE and SET\_SMPS\_PLLBW (see PM\_CONFIG[2:0] register bank) are set according to the programmed switching frequency. | SET_SMPS_PLLBW | SET_SMPS_PLLBW SET_SMPS_VTUNE | | | | |----------------|-------------------------------|-------------------|--|--| | 0 | 0 | 2.0 MHz - 4.5 MHz | | | | 0 | 1 | 3.5 MHz - 7.0 MHz | | | | 1 | 0 | 4.5 MHz - 7.5 MHz | | | | 1 | 1 | 4.5 MHz - 10 MHz | | | Table 24. SMPS configuration settings # 8.2 Power-on-reset (POR) The power-on-reset circuit generates a reset pulse upon power-up which is used to initialize the entire digital logic. Power-on-reset senses $V_{\text{BAT}}$ voltage. # 8.3 Low battery indicator The battery indicator can provide the user with an indication of the battery voltage level. There are two blocks to detect battery level: - Brownout with a fixed threshold as defined in Table 19: Battery indicator and low battery detector - Battery level detector with a programmable threshold as defined in *Table 19: Battery indicator and low battery detector*. SPIRIT1 Block description Both blocks can be optionally activated to provide the MCU with an early warning of impending power failure. It does not reset the system, but gives the MCU time to prepare for an orderly power-down and provides hardware protection of data stored in the program memory, by preventing write instructions being executed. The low battery indicatorr function is available in any of the SPIRIT1 operation modes. As this function requires the internal bias circuit operation, the overall current consumption in STANDBY, SLEEP, and READY modes is increased by 400 µA. ## 8.4 Voltage reference This block provides the precise reference voltage needed by the internal circuit. ## 8.5 Oscillator and RF synthesizer A crystal connected to XIN and XOUT is used to provide a clock signal to the frequency synthesizer. The allowed clock signal frequency is either 24, 26, 48, or 52 MHz. As an alternative, an external clock signal can be used to feed XIN for proper operation. In this option, XOUT can be left either floating or tied to ground. Since the digital macro cannot be clocked at that double frequency (48 MHz or 52 MHz), a divided clock is used in this case. The digital clock divider is enabled by default and must be kept enabled if the crystal is in the (48 - 52) MHz range; if the crystal is in the (24 - 26) MHz range, then the divider must be disabled before starting any TX/RX operation. The safest procedure to disable the divider without any risk of glitches in the digital clock is to switch into STANDBY mode, hence, set the bit-field PD\_CLKDIV in the XO\_RCO\_TEST register, and then come back to the READY state. Also the synthesizer reference signal can be divided by 2, setting the bit-field REFDIV in the SYNTH CONFIG register. The integrated phase locked loop (PLL) is capable to synthesize a wide band of frequencies, in particular the bands from 150 to 174 MHz, from 300 to 348 MHz, from 387 to 470 MHz, or from 779 to 956 MHz, providing the LO signal for the RX chain and the input signal for the PA in the TX chain. Frequency tolerance and startup times depend on the crystal used, although some tuning of the latter parameter is possible through the GM\_CONF field of the ANA\_FUNC\_CONF registers. | Table 25. Programmability | of trans-conductance at startup | |---------------------------|---------------------------------| | | | | GM_CONF[2:0] | Gm at startup [mS] | |--------------|--------------------| | 000 | 13.2 | | 001 | 18.2 | | 010 | 21.5 | | 011 | 25.6 | | 100 | 28.8 | | 101 | 33.9 | Block description SPIRIT1 Table 25. Programmability of trans-conductance at startup | GM_CONF[2:0] | Gm at startup [mS] | |--------------|--------------------| | 110 | 38.5 | | 111 | 43.0 | Depending on the RF frequency and channel spacing, a very high accurate crystal or TCXO can be required. The RF synthesizer implements fractional sigma delta architecture to allow fast settling and narrow channel spacing. It is fully integrated and uses a multi-band VCO to cover the whole frequency range. All internal calibrations are performed automatically. The PLL output frequency can be configured by programming the SYNT field of the SYNT3, SYNT2, SYNT1, and SYNT0 registers and BS field of the SYNT0 register (see Section 9.5.2). The user must configure these registers according to the effective reference frequency in use (24 MHz, 26 MHz, 48 MHz, or 52 MHz). In the latter two cases, the user must enable the frequency divider by 2 for the digital clock, in order to run the digital macro at a lower frequency. The configuration bit for the digital clock divider is inside the XO\_RCO\_TEST register (default case is divider enabled). In addition, the user can also enable a divider by 2 applied to the reference clock. The configuration bit for the reference clock divider is inside the SYNTH\_CONFIG[1] register. The user must select a 3-bit word in order to set the charge pump current according to the LO frequency variations, in order to have a constant loop bandwidth. This can be done by writing the WCP field of the SYNT3 register, according to the following table: Table 26. CP word look-up | Channel | frequency | WCP [2:0] | |---------|-----------|-----------| | 145.1 | 147.1 | 000 | | 147.1 | 149.1 | 001 | | 149.1 | 151.1 | 010 | | 151.1 | 153.2 | 011 | | 153.2 | 155.2 | 100 | | 155.2 | 157.2 | 101 | | 157.2 | 159.2 | 110 | | 159.2 | 161.1 | 111 | | 161.3 | 163.5 | 000 | | 163.5 | 165.7 | 001 | | 165.7 | 168.0 | 010 | | 168.0 | 170.3 | 011 | | 170.3 | 172.5 | 100 | | 172.5 | 174.8 | 101 | | 174.8 | 177.0 | 110 | | 177.0 | 179.3 | 111 | SPIRIT1 Block description Table 26. CP word look-up (continued) | | frequency | WCP [2:0] | |-------|-----------|-----------| | 290.3 | 294 | 000 | | 294.3 | 298.3 | 001 | | 298.3 | 302.3 | 010 | | 302.4 | 306.4 | 011 | | 306.4 | 310.4 | 100 | | 310.4 | 314.4 | 101 | | 314.4 | 318.4 | 110 | | 318.4 | 322.6 | 111 | | 322.6 | 327.0 | 000 | | 327.0 | 331.4 | 001 | | 331.4 | 335.9 | 010 | | 335.9 | 340.5 | 011 | | 340.5 | 344.9 | 100 | | 344.9 | 349.5 | 101 | | 349.5 | 353.9 | 110 | | 353.9 | 358.5 | 111 | | 387.0 | 392.3 | 000 | | 392.3 | 397.7 | 001 | | 397.7 | 403.0 | 010 | | 403.0 | 408.5 | 011 | | 413.8 | 419.2 | 101 | | 419.2 | 424.6 | 110 | | 424.6 | 430.1 | 111 | | 430.1 | 436.0 | 000 | | 436.0 | 441.9 | 001 | | 441.9 | 447.9 | 010 | | 447.9 | 454.0 | 011 | | 454.0 | 459.9 | 100 | | 459.9 | 466.0 | 101 | | 466.0 | 471.9 | 110 | | 471.9 | 478.0 | 111 | | 774.0 | 784.7 | 000 | | 784.7 | 795.3 | 001 | | 795.3 | 806.0 | 010 | | 806.0 | 817.0 | 011 | Block description SPIRIT1 WCP [2:0] **Channel frequency** 817.0 827.7 100 827.7 838.3 101 838.3 849.2 110 849.2 860.2 111 872.0 860.2 000 872.0 883.8 001 883.8 895.8 010 908.0 919.8 100 919.8 932.0 101 932.0 943.8 110 943.8 956.0 111 Table 26. CP word look-up (continued) The SPIRIT1 is provided with an automatic and very fast calibration procedure for the frequency synthesizer. If not disabled, it is performed each time the SYNTH is required to lock to the programmed RF channel frequency (i.e. from READY to LOCK/TX/RX or from RX to TX and vice versa). Calibration time is $54 \mu s$ . After completion, the calibration word is used automatically by the SPIRIT1 and is stored in the RCO\_VCO\_CALIBR\_OUT[1:0] registers. In order to get the synthesizer locked when the calibration procedure is not enabled, the correct calibration words to be used must be previously stored in the RCO\_VCO\_CALIBR\_IN[2:0] registers using VCO\_CALIBR\_TX and VCO\_CALIBR\_RX fields for TX and RX modes respectively. The advantage of performing an offline calibration is that the LOCK/setting time is roughly 20 µs (using proper VCO\_CALIBR\_TX/RX register values). It recommended set the T split time at the longest value (3.47 ns) to facilitate the calibrator operation, SEL\_TSPLIT field of the register SYNTH\_CONFIG[0] (register address 0x9F) at 1 If calibration is enabled, the LOCK/setting time is approximately 80 $\mu$ s. VCO should be recalibrated if the temperature of the environment changes. Indeed a temperature change affects the PLL work point and the calibration words need to the recalculated. Between the READY and the LOCK state a transient state called LOCKWON (MC\_STATE code 0x13) will persist until the LOCK is reached. The LOCKWON state may persist indefinitely in two cases: - in case of hardware problem (bad XTAL or chip soldering). - if a TX, LOCKTX, RX, LOCKRX command is sent with a bad VCO calibration word (RCO\_VCO\_CALIBR\_IN[1:0]) or if the VCO calibration fails. In this case, a SRES command should be sent to restore the device in READY state. As a side effect, all the registers will be restored at the initial values. SPIRIT1 Block description ## 8.6 RCO: features and calibration The SPIRIT1 contains an ultra-low power RC oscillator capable of generating 34.7 kHz with both 24 MHz and 26 MHz; the RC oscillator frequency is calibrated comparing it against the digital domain clock fCLK divided by 692 or 750, respectively. The configuration bit, called 24\_26MHz\_SELECT in the ANA\_FUNC\_CONF register, contains the information of the calibrator about the frequency of the crystal under operation. If the digital domain clock is 25 MHz, the setting of the configuration bit 24\_26MHz\_SELECT will calibrate the low power RC oscillator according to the following table: | Digital domain clock | 24_26MHz_SELECT | RC calibrated speed | |----------------------|-----------------|---------------------| | 24 MHz | 0 | 34.7 kHz | | 26 MHz | 1 | 34.7 kHz | | 25 MHz | 0 | 36.1 kHz | | 25 MHz | 1 | 33.3 kHz | Table 27. RC calibrated speed By default, the calibration is disabled at reset to avoid using an out-of-range reference frequency (for instance, when the XTAL is 26 MHz and the digital divider is active, in fact, by default). After the internal clock divider is correctly configured, the user can enable the RCO calibration in the PROTOCOL[2] register. The user can replace the internal 34 kHz-signal source with an external one (provided through a GPIO, Section 10.3). To enable the usage of the external signal, the user must set the EXT\_RCOSC bit in the XO\_RCO\_CONFIG register. However, the internal calibrator is not automatically disabled from the EXT\_RCOSC bit (the user must reset the RCO\_CALIBRATION bit in the PROTOCOL[2] register, if previously set). ### 8.6.1 RC oscillator calibration RC oscillator calibration is enabled when bit RCO\_CALIBRATION is set in the PROTOCOL[2] register (by default the calibration is disabled). The calibration words found by the calibration algorithm are accessible in the RCO\_VCO\_CALIBR\_OUT[1:0] registers (fields RWT\_OUT[3:0] and RFB\_OUT[4:0],). When the calibration is disabled, the frequency of the RC oscillator is set by a couple of configuration words, namely RWT\_IN[3:0] and RFB\_IN[4:0], in the RCO\_VCO\_CALIBR\_IN[2:0] registers (fields RWT\_IN[3:0] and RFB\_IN[4:0]). RWT\_IN[3:0] can range from 0 up to 13 (decimal value) affecting the raw value of the frequency, while the more accurate and fine control is up to RFB\_IN[4:0] (ranging from 1 up to 31). ## 8.7 AGC The AGC algorithm is designed to keep the signal amplitude within a specific range by controlling the gain of the RF chain in 6 dB steps, up to a maximum attenuation of 48dB, starting at a received signal power of about -50dBm. The signal peak amplitude measured is compared with a low threshold and with a high threshold. If it is above the high threshold, the attenuation is increased sequentially until the Block description SPIRIT1 amplitude goes below the threshold; if the amplitude is below the low threshold, the attenuation is decreased sequentially until the amplitude goes above the threshold. The AGC algorithm is controlled by the following parameters: - High threshold: this value sets the digital signal level above which the attenuation is increased (AGCCTRL1 register, allowed values 0...15). - Low threshold: this value sets the digital signal level below which the attenuation is decreased (AGCCTRL1 register, allowed values 0...15). - Measure time: this parameters sets the measurement interval during which the signal peak is determined (AGCCTRL2 register, allowed values 0...15). the actual time is: $$T_{AGCmeas} = \frac{12}{f_{CLK}} \cdot 2^{MEAS\_TIME}$$ ranging from about 0.5µs to about 15ms. In FSK, GFSK and MSK, the measurement time is normally set to a few µs in order to achieve fast settling of the algorithm. In OOK and ASK, to avoid an unstable behavior, the measure time must be larger than the duration of the longest train of '0' symbols expected. • AGC enable: enables the AGC algorithm (AGC\_ENABLE: 0>disabled, 1>enabled). ## 8.8 AFC The SPIRIT1 implements an automatic frequency compensation algorithm to balance TX/RX crystal frequency inaccuracies. The receiver demodulator estimates the centre of the received data and compensates the offset between nominal and receiver frequency. The tracking range of the algorithm is programmable and is a fraction of the receive channel bandwidth. Frequency offset compensation is supported for 2-FSK, GFSK, and MSK modulation. When the relative frequency error between transmitter and receiver is less than half the modulation bandwidth, the AFC corrects the frequency error without needing extra bandwidth. When the frequency error exceeds BWmod/2, some extra bandwidth is needed to assure proper AFC operation under worst-case conditions. The AFC can be disabled if the TX/RX frequency misalignment is negligible with respect to the receiver bandwidth, for example, when using a TCXO. AFC algorithm works with a fast and a slow period. Fast period starts when the RSSI threshold is asserted and it is a fixed duration period. Its duration is given by the AFC\_FAST\_PERIOD parameter expressed as number of symbols. During the fast period, the AFC\_FAST\_GAIN is used. Slow period starts after the end of the fast period and it could: - last until SYNC detection if there is SYNC and AFC FREEZE ON SYNC is 1 - last indefinitely in all the other cases During the slow period, the AFC SLOW GAIN is used. The AFC\_PD\_LEAKAGE is a parameters that controls the speed of the frequency peak detector of the AFC algorithm. SPIRIT1 Block description ## 8.9 Symbol timing recovery The SPIRIT1 supports two different algorithms for the timing recovery. The choice of the algorithm actually used is controlled by the CLOCK\_REC\_ALGO\_SEL bit of register FDEV0. If CLOCK\_REC\_ALGO\_SEL = 0 then a simple first order algorithm is used (shortly referred to as DLL), if CLOCK\_REC\_ALGO\_SEL = 1 then a second order algorithm is used (shortly referred to as PLL). #### 8.9.1 DLL mode The algorithm is able to control the delay of the local bit timing generator in order to align it to the received bit period. If there is an error between the actual received bit period and the nominal one, the relative edges will drift over time and the algorithm will periodically apply a delay correction to recover. The convergence speed of the loop is controlled by the CLK\_REC\_P\_GAIN parameter in the CLOCKREC register with a smaller value yielding a faster loop. Allowed values are from 0 to 7. #### 8.9.2 PLL mode The PLL algorithm tracks the phase error of the local timing generator relative to received bit period and controls both frequency and phase to achieve the timing lock. Once that the relative period error has been estimated and corrected for example during the preamble phase, then even in presence of long sequences of zeros or ones, the loop is able to keep lock. The convergence speed of the loop is controlled by the CLK\_REC\_P\_GAIN and the CLK\_REC\_I\_GAIN parameters both in the CLOCKREC register. Allowed values are from 0 to 7 for the CLK\_REC\_P\_GAIN and from 0 to 15 for the CLK\_REC\_I\_GAIN. ### 8.10 Receiver The SPIRIT1 contains a low-power low-IF receiver which is able to amplify the input signal and provide it to the ADC with a proper signal to noise ratio. The RF antenna signal is converted to a differential one by an external balun, which performs an impedance transformation also. The receiver gain can be programmed to accommodate the ADC input signal within its dynamic range. After the down-conversion at IF, a first order filter is implemented to attenuate the out-of-band blockers. ## 8.11 Transmitter The SPIRIT1 contains an integrated PA capable of transmitting at output levels between -30 dBm to +11 dBm. The PA is single-ended and has a dedicated pin (TXOUT). The PA output is ramped up and down to prevent unwanted spectral splatter. In TX mode the PA drives the signal generated by the frequency synthesizer out to the antenna terminal. The output power of the PA is programmable via SPI. Delivered power, as well as harmonic content, depends on the external impedance seen by the PA. To obtain approval on ETSI EN 300 220, it is possible to program TX to send an unmodulated carrier. Block description SPIRIT1 The output stage is supplied from the SMPS through an external choke and is loaded with a LC-type network which has the function of transforming the impedance of the antenna and filter out the harmonics. The TX and RX pins are tied directly to share the antenna. During TX, the LNA inputs are internally shorted to ground to allow for the external network resonance, so minimizing the power loss due to the RX. Figure 10. Shaping of ASK signal ## 8.12 Temperature sensors (TS) The SPIRIT1 can provide an analog temperature indication as a voltage level, which is available at the GPIO\_0 pin. The voltage level V0 at room temperature (or any other useful reference temperature) should be acquired and stored by the MCU in order to compensate for the offset. The relationship between temperature and voltage is the following: ## **Equation 2** $$T = 400 \cdot (V_{temp} - V_0) + (T_0 + 3.75)$$ (°C) where $V_0$ is the voltage at temperature $T_0$ . Two output modes are available: buffered or not buffered (high output impedance, about 100 k $\Omega$ ). The latter mode is the default one. The TS function is available in every operating mode. When enabled, the internal logic allows the switching on of all the necessary circuitry. To enable the TS function, the user must perform the following operations: - Set to 1 the TS bit in the ANA FUNC CONF[0] register - Program as "Analog" (00) the GPIO\_MODE field in the GPIO0\_CONF register (other fields are neglected) - Optionally, enable the buffered mode (the EN\_TS\_BUFFER bit in the PM\_CONFIG[2] register). As the TS function requires the internal bias circuit operation, the overall current consumption in STANDBY, SLEEP, and READY modes is increased by 400 µA. ## 8.13 AES encryption co-processor The SPIRIT1 provides data security support as it embeds an advanced encryption standard (AES) core which implements a cryptographic algorithm in compliance with NIST FIPS 197. Three registers are available to use the AES engine of SPIRIT1: - AES\_KEY\_IN [15:0]: R/W type register (128-bit), used to provide the key to use - AES\_DATA\_IN [15:0]: R/W type register (128-bit), used to provide the input to the AES engine - AES\_DATA\_OUT [15:0]: R type register (128-bit), used to retrieve the output of the AES operation. The core processes 128-bit data blocks using 128-bit keys. The AES can be accessed in any of the SPIRIT1 operation modes. To turn on the AES engine, the AES\_ON bit in the ANA\_FUNC\_CONF[0] register must be set. Once the AES engine is on, it processes the operations according to the commands sent. The SPIRIT1 engine provides 4 different operations: - Encryption using a given encryption key (AES Enc command). In this operation, the MCU puts the encryption key into the AES\_KEY\_IN[15:0] register and the data to encrypt into the AES\_DATA\_IN[15:0]. The MCU sends the AES Enc command and when the AES\_EOP (end of operation) is issued, the MCU can retrieve the data encrypted from AES\_DATA\_OUT[15:0] - Decryption key derivation starting from an encryption key (AES Key command). In this operation, the MCU puts the encryption key into AES\_DATA\_IN[15:0]. The MCU sends the AES Key command and when the AES\_EOP (end of operation) is issued, the MCU can retrieve the decryption key from AES\_DATA\_OUT[15:0] - 3. Data decryption using a decryption key (AES Dec command). In this operation, the MCU puts the decryption key into the AES\_KEY\_IN[15:0] register and the data to decrypt into AES\_DATA\_IN[15:0]. The MCU sends the AES Dec command and when the AES\_EOP (end of operation) is issued, the MCU can retrieve the data decrypted from AES\_DATA\_OUT[15:0]. - 4. Data decryption using a decryption key (AES KeyDec command). In this operation, the MCU puts the encryption key into the AES\_KEY\_IN[15:0] register and the data to decrypt into AES\_DATA\_IN[15:0]. The MCU sends the AES KeyDec command and when the AES\_EOP (end of operation) is issued, the MCU can retrieve the data decrypted from AES\_DATA\_OUT[15:0]. # 9 Transmission and reception # 9.1 PA configuration The PA output power level can be configured by programming the PA\_POWER[8:0] register bank. The user can store up to eight output levels to provide flexible PA power ramp-up and ramp-down at the start and end of a frequency modulation transmission as well as ASK modulation shaping. The power levels of the ramp are controlled by 7-bit words ( $PA_LEVEL_x$ , x=0-7), according to the following table: Table 28. PA level | PA_LEVEL_x | Comment | P <sub>OUT</sub> [dBm]<br>(170MHz) | |------------|-------------------------------------------------------------------------------------|------------------------------------| | 0 | No output power: output stage in high impedance mode and all circuits switched off. | - | | 1 | Maximum output power | 11 | | | | | | 30 | | 0 | | | | | | 42 | | -6 | | | | | | 90 | Minimum level | -34 | | 91-127 | Reserved | N/A | Incrementing by 1 the PA register value will correspond about to half dB decrement of output power. The power ramping is enabled by the PA\_RAMP\_ENABLE bit. If enabled, the ramp starts from the level defined by the word PA\_LEVEL\_0 and stops at the level defined by the word PA\_LEVEL\_x, where x is the value of the 3-bit field PA\_LEVEL\_MAX\_INDEX. So, a maximum of 8 steps can be set up. *Figure 11* describes the levels table and shows some examples. Each step is held for a time interval defined by the 2-bit field PA\_RAMP\_STEP\_WIDTH. The step width is expressed in terms of bit period units ( $T_b/8$ ), maximum value is 3 (which means $4 \times T_b/8 = T_b/2$ ). Therefore the PA ramp may last up to 4 $T_b$ (about 3.3 ms if the bit rate is 1.2 kbit/s). Figure 11. Output power ramping configuration The set of 8 levels is used to shape the ASK signal. In this case, the modulator works as a counter that counts up when transmitting a one and down when transmitting a zero. The counter counts at a rate equal to 8 times the symbol rate (in this case, the field PA\_RAMP\_STEP\_WIDTH is not used). This counter value is used as an index for the lookup in the levels table in *Figure 11* to associate the relevant POUT value. Therefore, in order to utilize the whole table, PA\_LEVEL\_MAX\_INDEX should be 7 when ASK is active. The real shaping of the ASK signal is dependent on the configuration of the PA\_LEVEL\_x registers. *Figure 11* shows some examples of ASK shaping. Using the a frequency modulation, the output power is configured by $PA_LEVEL_x$ , with $x=PA_LEVEL_x$ MAX\_INDEX. For OOK modulation, the signal is abruptly switched between two levels only, these are PA\_LEVEL\_0 and PA\_LEVEL\_x, with x=PA\_LEVEL\_MAX\_INDEX. The 2-bit CWC field in the PA\_POWER register bank can be used to tune the internal capacitive load of the PA (up to 3.6 pF in steps of 1.2 pF) in order to optimize the performance at different frequencies. The output power are reported in Table 28: PA\_level. ## 9.2 RF channel frequency settings RF channels can be defined using the CHSPACE and CHNUM registers. The channel center frequency can be programmed as: ### **Equation 3** $$f_c = f_{base} + f_{offset} + \left(\frac{f_{XO}}{2^{15}} \cdot CHSPACE\right) \cdot CHNUM$$ This allows the setting of up to 256 channels with a programmable raster. The raster granularity is about 793 Hz at 26 MHz and becomes about 1587 Hz at 52 MHz. The actual channel spacing is from 793 Hz to 202342 Hz in 793 Hz steps for the 26 MHz configuration and from 1587 to 404685 Hz in 1587 Hz steps for the 52 MHz configuration. The base carrier frequency, i.e. the carrier frequency of channel #0, is controlled by the SYNT0, SYNT1, SYNT2, and SYNT3 registers according to the following formula: ### **Equation 4** $$f_{\text{base}} = \frac{f_{\text{XO}}}{\underline{(B * D)}} \quad \frac{\text{SYNT}}{2^{18}}$$ where: - f<sub>XO</sub> is the frequency of the XTAL oscillator (typically 24 MHz, 26 MHz, 48 MHz, or 52 MHz) - SYNT is a programmable 26-bit integer. ### **Equation 5** ## **Equation 6** $$D = \begin{cases} 1 \text{ if REFDIV 0 (internal reference divider is disabled)} \\ 2 \text{ if REFDIV 1 (internal reference divider is enabled)} \end{cases}$$ The offset frequency is a correction term which can be set to compensate the crystal inaccuracy after e.g. lab calibration. #### **Equation 7** $$f_{\text{offset}} = \frac{f_{\text{XO}}}{2^{18}} \cdot \text{FC\_OFFSET}$$ 57/ #### where: FC\_OFFSET is a 12-bit integer (expressed as 2's complement number) set by the FC\_OFFSET[1:0] registers Furthermore, the selection between VCOH ("high") and VCOL ("low") in the frequency synthesizer according to the band selected and the VCO threshold is required. If the center frequency is below the frequency threshold for that frequency band, the VCO\_L must be selected by setting the bit 2 VCO L SEL field in the SYNTH CONFIG register. If the center frequency is above the frequency threshold for that frequency band, VCO\_H must be selected by setting the bit 1 VCO\_ H \_SEL field in the SYNTH\_CONFIG register. Frequency threshold for each band (MHz)<sup>(1)</sup> Very low band Low band Middle band High band 161281250 322562500 430083334 860166667 Table 29. Frequency threshold The user must make sure that actual frequency programming is inside the specified frequency range. The accuracy of the offset is about 99 Hz for the 26 MHz reference and about 198 Hz for the 52 MHz reference. ## 9.3 RX timeout management In SPIRIT1, the RX state is specifically time monitored in order to minimize power consumption. This is done by a RX timeout approach, which aborts the reception after RX timeout expiration. The timer used to control RX timeout is controlled by the registers RX\_TIMEOUT\_PRESCALER and RX\_TIMEOUT\_COUNTER. However, to avoid the reception to be interrupted during a valid packet, a number of options to stop the timeout timer are available for the user. They are based on the received signal quality indicators (see Section 9.10 for a full description of them): - CS valid - SQI valid - PQI valid More specifically, both 'AND' or 'OR' boolean relationships among any of them can be configured. This is done using the selection bit RX\_TIMEOUT\_AND\_OR\_SELECT in PCKT\_FLT\_OPTIONS register. To choose which of the quality indicators should be taken into account in the AND/OR Boolean relationship, the user should use the mask bits available in the PROTOCOL[2] register. The full true-table including any logical AND/OR among such conditions is reported in *Table 30*. <sup>1.</sup> By default, the VCO H is selected. RX\_TIMEOUT\_ **SQI TIMEOUT** PQI\_TIMEOUT\_M CS\_TIMEOUT\_MASK Description MASK **ASK** AND OR SELECT The RX timeout never expires and the reception 0 0 0 0 ends at the reception of the packet The RX timeout cannot be stopped. It starts at the RX 0 0 0 state and at the end expires (default) RSSI above threshold Χ 1 0 0 Χ 0 1 0 SQI above threshold Х 0 0 1 PQI above threshold Both RSSI AND SQI above 0 1 1 0 threshold Both RSSI AND PQI above 0 1 1 0 threshold Both SQI AND PQI above 0 0 1 1 threshold 0 1 1 1 ALL above threshold RSSI OR SQI above 1 1 1 0 threshold RSSI OR PQI above 1 1 0 1 threshold SQI OR PQI above 1 0 1 1 threshold 1 1 1 1 ANY above threshold Table 30. RX timeout stop condition configuration When reception is aborted on timeout expiration, the packet is considered not valid and will be discarded. It is responsibility of the user to choose the proper boolean condition that suit its application. In particular, it is required to include always SQI valid check, to avoid to stay in RX state for unlimited time, if timeout is stopped but no valid SQI is detected (in such cases, the RX state can be left using a SABORT command). It is also important to notice that, in case a packet is received, that the timeout is stopped by some of the conditions in order to get an RX data ready interrupt, otherwise SPIRIT1 will wait in RX mode for the RX timeout to expire anyway. # 9.4 Intermediate frequency setting The intermediate frequency (IF) is controlled by the registers IF\_OFFSET\_ANA and IF\_OFFSET\_DIG, and can be set as: #### **Equation 8** $$IF\_OFFSET\_ANA = ROUND \cdot \left(\frac{f_{IF}}{f_{XO}} \cdot 3 \cdot 2^{12} - 64\right)$$ ### **Equation 9** $$\text{IF\_OFFSET\_DIG} = \text{ROUND} \cdot \left( \frac{f_{\text{IF}}}{f_{\text{CLK}}} \cdot 3 \cdot 2^{12} - 64 \right)$$ where $f_{XO}$ is the XTAL oscillator frequency (24, 25, 26, 48, 50 or 52 MHz) and $f_{CLK}$ is the digital clock frequency (24, 25 or 26 MHz). The recommended IF value is about 480 kHz resulting in the following register setting: | | <del>_</del> | | | |---------------|---------------|-----------------------|-----------------------| | IF_OFFSET_ANA | IF_OFFSET_DIG | f <sub>IF</sub> [kHz] | f <sub>XO</sub> [MHz] | | 0xB6 | 0xB6 | 480.469 | 24 | | 0xAC | 0xAC | 480.143 | 25 | | 0xA3 | 0xA3 | 480.306 | 26 | | 0x3B | 0xB6 | 480.469 | 48 | | 0x36 | 0xAC | 480.143 | 50 | | 0x31 | 0xA3 | 480.140 | 52 | Table 31. IF\_OFFSET settings ## 9.5 Modulation scheme The following modulation formats are supported: 2-FSK, GFSK, MSK, OOK, and ASK. The actual modulation format used is controlled by the MOD\_TYPE field of the MOD0 register: MOD TYPE = - 0 (00): 2-FSK - 1 (01): GFSK - 2 (10): ASK/OOK - 3 (11): MSK In 2-FSK and GFSK modes, the frequency deviation is controlled by the FDEV register according to the following formula: ### **Equation 10** $$f_{dev} = f_{xo} \frac{floor((8 + FDEV_M) \cdot 2^{FDEV_E - 1})}{2^{18}}$$ #### where: - f<sub>XO</sub> is the XTAL oscillator frequency (typically 26 MHz or 52 MHz). - FDEV\_M is a 3-bit integer ranging from 0 to 7 - FDEV\_E is a 4-bit integer ranging from 0 to 9. The f<sub>dev</sub> values obtainable are then: For $f_{XO} = 52 \text{ MHz}$ | E/M | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-----|----------|----------|----------|----------|----------|----------|----------|----------| | 0 | 793.5 | 793.5 | 991.8 | 991.8 | 1190.2 | 1190.2 | 1388.5 | 1388.5 | | 1 | 1586.9 | 1785.3 | 1983.6 | 2182.0 | 2380.4 | 2578.7 | 2777.1 | 2975.5 | | 2 | 3173.8 | 3570.6 | 3967.3 | 4364.0 | 4760.7 | 5157.5 | 5554.2 | 5950.9 | | 3 | 6347.7 | 7141.1 | 7934.6 | 8728.0 | 9521.5 | 10314.9 | 11108.4 | 11901.9 | | 4 | 12695.3 | 14282.2 | 15869.1 | 17456.1 | 19043.0 | 20629.9 | 22216.8 | 23803.7 | | 5 | 25390.6 | 28564.5 | 31738.3 | 34912.1 | 38085.9 | 41259.8 | 44433.6 | 47607.4 | | 6 | 50781.3 | 57128.9 | 63476.6 | 69824.2 | 76171.9 | 82519.5 | 88867.2 | 95214.8 | | 7 | 101562.5 | 114257.8 | 126953.1 | 139648.4 | 152343.8 | 165039.1 | 177734.4 | 190429.7 | | 8 | 203125.0 | 228515.6 | 253906.3 | 279296.9 | 304687.5 | 330078.1 | 355468.8 | 380859.4 | | 9 | 406250.0 | 457031.3 | 507812.5 | 558593.8 | 609375.0 | 660156.3 | 710937.5 | 761718.8 | For $f_{XO}$ = 26 MHz | E/M | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-----|----------|----------|----------|----------|----------|----------|----------|----------| | 0 | 396.7 | 396.7 | 495.9 | 495.9 | 595.1 | 595.1 | 694.3 | 694.3 | | 1 | 793.5 | 892.6 | 991.8 | 1091.0 | 1190.2 | 1289.4 | 1388.5 | 1487.7 | | 2 | 1586.9 | 1785.3 | 1983.6 | 2182.0 | 2380.4 | 2578.7 | 2777.1 | 2975.5 | | 3 | 3173.8 | 3570.6 | 3967.3 | 4364.0 | 4760.7 | 5157.5 | 5554.2 | 5950.9 | | 4 | 6347.7 | 7141.1 | 7934.6 | 8728.0 | 9521.5 | 10314.9 | 11108.4 | 11901.9 | | 5 | 12695.3 | 14282.2 | 15869.1 | 17456.1 | 19043.0 | 20629.9 | 22216.8 | 23803.7 | | 6 | 25390.6 | 28564.5 | 31738.3 | 34912.1 | 38085.9 | 41259.8 | 44433.6 | 47607.4 | | 7 | 50781.3 | 57128.9 | 63476.6 | 69824.2 | 76171.9 | 82519.5 | 88867.2 | 95214.8 | | 8 | 101562.5 | 114257.8 | 126953.1 | 139648.4 | 152343.8 | 165039.1 | 177734.4 | 190429.7 | | 9 | 203125.0 | 228515.6 | 253906.3 | 279296.9 | 304687.5 | 330078.1 | 355468.8 | 380859.4 | With this solution the maximum deviation for the 26 MHz case is limited to about 355 kHz, but this is still acceptable since the maximum useful deviation is about 125 kHz (MSK @ 500 kbps). In GFSK mode the Gaussian filter BT product can be set to 1 or 0.5 by the field BT\_SEL of the MOD0 register. In MSK mode, the frequency deviation is automatically set to $\frac{1}{4}$ of the data rate and the content of the FDEV register is ignored. The calculation done inside the modem assumes that the digital clock is equal to the synthesizer reference. Hence, in the 52-MHz case the MSK can actually be configured by setting the frequency deviation to $\frac{1}{4}$ of the data rate through the FDEV registers as for normal 2-FSK. The same is true for GMSK mode, which can be configured by setting the frequency deviation to $\frac{1}{4}$ of the data rate through the FDEV registers as for normal GFSK with Gaussian filter BT equal to 1 or 0.5. #### **OOK and ASK** If MOD\_TYPE = 2 and power ramping is enabled, then ASK is used; otherwise, if MOD\_TYPE = 2 and power ramping is disabled, then OOK is used. When OOK is selected, a bit '1' is transmitted with the power specified by PA\_POWER[PA\_LEVEL\_MAX\_INDEX], a bit '0' is transmitted with the power specified by PA\_POWER[0](normally set to PA off). When ASK is selected, a bit '1' is transmitted with a power ramp increasing from PA\_POWER[0] to PA\_POWER[PA\_LEVEL\_MAX\_INDEX], a bit '0' is transmitted with a power ramp decreasing from PA\_POWER[PA\_LEVEL\_MAX\_INDEX] to PA\_POWER[0]. The duration of each power step is 1/8 of the symbol time. If more '1's are transmitted consecutively, the PA power remains at PA\_POWER[PA\_LEVEL\_MAX\_INDEX] for all '1's following the first one; If more '0's are transmitted consecutively, the PA power remains at PA\_POWER[0] for all '0's following the first one. #### CW mode For test and measurement purposes the device can be programmed to generate a continuous wave carrier without any modulation by setting the CW field of the MOD0 register. In transmission, a TXSOURCE like PN9 should be configured to keep the transmitter in TX state for an undefined period of time. In reception, this mode can be also chosen to analyze the RX performance; in this case an infinite RX timeout should be configured to keep the SPIRIT1 in RX state. #### 9.5.1 Data rate The data rate is controlled by the MOD0 and MOD1 registers according to the following formula: ### **Equation 11** DataRate = $$f_{clk} \cdot \frac{(256 + DATA\_RATE\_M) \cdot 2^{DATARATE\_E}}{2^{28}}$$ #### where: - DATARATE M is an 8-bit integer ranging from 0 to 255 - DATARATE E is a 4-bit integer ranging from 0 to 15 - f<sub>clk</sub> is the digital clock frequency (typically 26 MHz). The minimum data rate at $f_{clk}$ = 26 MHz is about 25 Hz; the maximum data rate is about 1.6 MHz. Be advised that performance for such values is not guaranteed. ### 9.5.2 RX channel bandwidth The bandwidth of the channel filter is controlled by the CHFLT\_M and CHFLT\_E fields of the CHFLT register according to tables below. The actual filter bandwidth for any digital clock frequency can be obtained by multiplying the values in the tables below by the factor $f_{\rm clk}/26000000$ . Table 32. CHFLT\_M and CHFLT\_E value for channel filter bandwidth (in kHz, for $f_{clk}$ = 24 MHz) | | E=0 | E=1 | E=2 | E=3 | E=4 | E=5 | E=6 | E=7 | E=8 | E=9 | |-----|-------|-------|-------|-------|------|------|------|-----|-----|-----| | M=0 | 738.6 | 416.2 | 207.4 | 103.7 | 51.8 | 25.8 | 12.9 | 6.5 | 3.2 | 1.7 | | M=1 | 733.9 | 393.1 | 196.1 | 98.0 | 48.9 | 24.5 | 12.3 | 6.1 | 3.0 | 1.6 | | M=2 | 709.3 | 372.2 | 185.6 | 92.8 | 46.3 | 23.2 | 11.6 | 5.8 | 2.9 | 1.5 | | M=3 | 680.1 | 351.5 | 175.4 | 87.7 | 43.8 | 21.9 | 11.0 | 5.4 | 2.8 | 1.4 | | M=4 | 650.9 | 334.2 | 166.8 | 83.4 | 41.6 | 20.9 | 10.4 | 5.2 | 2.6 | 1.3 | | M=5 | 619.3 | 315.4 | 157.5 | 78.7 | 39.3 | 19.7 | 9.8 | 4.9 | 2.5 | 1.2 | | M=6 | 592.9 | 300.4 | 149.9 | 75.0 | 37.5 | 18.7 | 9.3 | 4.7 | 2.3 | 1.2 | | M=7 | 541.6 | 271.8 | 135.8 | 67.8 | 33.9 | 17.0 | 8.5 | 4.2 | 2.1 | 1.1 | | M=8 | 499.8 | 249.5 | 124.6 | 62.3 | 31.1 | 15.6 | 7.8 | 3.9 | 1.9 | 1.0 | Table 33. CHFLT\_M and CHFLT\_E value for channel filter bandwidth (in kHz, for $f_{clk} = 26 \text{ MHz}$ ) | | E=0 | E=1 | E=2 | E=3 | E=4 | E=5 | E=6 | E=7 | E=8 | E=9 | |-----|-------|-------|-------|-------|------|------|------|-----|-----|-----| | M=0 | 800.1 | 450.9 | 224.7 | 112.3 | 56.1 | 28.0 | 14.0 | 7.0 | 3.5 | 1.8 | | M=1 | 795.1 | 425.9 | 212.4 | 106.2 | 53.0 | 26.5 | 13.3 | 6.6 | 3.3 | 1.7 | | M=2 | 768.4 | 403.2 | 201.1 | 100.5 | 50.2 | 25.1 | 12.6 | 6.3 | 3.1 | 1.6 | | M=3 | 736.8 | 380.8 | 190.0 | 95.0 | 47.4 | 23.7 | 11.9 | 5.9 | 3.0 | 1.5 | | M=4 | 705.1 | 362.1 | 180.7 | 90.3 | 45.1 | 22.6 | 11.3 | 5.6 | 2.8 | 1.4 | | M=5 | 670.9 | 341.7 | 170.6 | 85.3 | 42.6 | 21.3 | 10.6 | 5.3 | 2.7 | 1.3 | | M=6 | 642.3 | 325.4 | 162.4 | 81.2 | 40.6 | 20.3 | 10.1 | 5.1 | 2.5 | 1.3 | | M=7 | 586.7 | 294.5 | 147.1 | 73.5 | 36.7 | 18.4 | 9.2 | 4.6 | 2.3 | 1.2 | | M=8 | 541.4 | 270.3 | 135.0 | 67.5 | 33.7 | 16.9 | 8.4 | 4.2 | 2.1 | 1.1 | Although the maximum TX signal BW should not exceed 750 kHz, the bandwidth of the channel select filter in the receiver may need some extra bandwidth to cope with tolerances in transmit and receive frequencies which depend on the tolerances of the used crystals. ## 9.6 Data coding and integrity check process ## 9.6.1 FEC The device provides hardware support for error correction and detection. Error correction can be either enabled or disabled according to link reliability and power consumption needs. Convolutional coding with a rate=½ and k=4 is applied on the payload and CRC before transmission (poly [13,17]). On the receiver side, error correction is performed using soft Viterbi decoding. To further improve error correction performance, a data interleaver is used when convolutional coding is enabled. Data interleaving/de-interleaving is performed using a 4x4-bit matrix interleaver. To fill the entire matrix, at least 2 bytes of data payload are required (16 cells). In the interleaver matrix, the encoded data bits are written along the rows and the sequence to send to the modulator is obtained by reading the matrix elements along the columns of the matrix. Consequently, in the de-interleaver, the received data from the demodulator are written into the matrix along the columns, and sent to the FEC decoder reading them from the rows of the de-interleaving matrix. Due to the size of the matrix, the overall data transmitted must be an exact integer multiple of two, to fill the rows and columns of the matrix. If necessary, the framer is able to add automatically extra bytes at the end of the packet, so the number of bytes is an number. FEC and interleaving are enabled/disabled together. To enable FEC/INTERL, the field FEC\_EN of PCKTCTRL1 must be set to '1'. When FEC/INTERL is enabled, the number of transmitted bits is roughly doubled, hence the on-air packet duration in time is roughly doubled as well. The data rate specified in *Section 9.5.1* always applies to the on-air transmitted data. A termination byte is automatically appended to set the encoder to the 0-state at the end of the packet. ### 9.6.2 CRC Error detection is implemented by means of cyclic redundancy check codes. The length of the checksum is programmable to 8, 16, or 24 bits. The CRC can be added at the end of the packet by the field CRC\_MODE of the register PCKCTRL1. The following standard CRC polynomials can be selected: - CRC mode = 1. 8 bits: the poly is $(0x07) X^8 + X^2 + X + 1$ - CRC mode = 2, 16 bits: the poly is $(0x8005) X^{16}+X^{15}+X^2+1$ - CRC mode = 3, 16 bits: the poly is $(0x1021) X^{16}+X^{12}+X^5+1$ - CRC mode = 4, 24 bits: the poly is (0x864CFB) $X^{24}+X^{23}+X^{18}+X^{17}+X^{14}+X^{11}+X^{10}+X^{7}+X^{6}+X^{5}+X^{4}+X^{3}+X+1$ - CRC is calculated over all fields excluding preamble and SYNC word. CRC is computed starting from an initial word with all bits set to 1. Bits reversion is not done. ## 9.6.3 Data whitening To prevent short repeating sequences (e.g., runs of 0's or 1's) that create spectral lines, which may complicate symbol tracking at the receiver or interferer with other transmissions, the device implements a data whitening feature. Data whitening can optionally be enabled by setting the filed WHIT\_EN of the PCKTCTRL1 register to '1'. Data whitening is implemented by a maximum length LFSR generating a pseudo-random binary sequence used to XOR data before entering the encoding chain. The length of the LSFR is set to 9 bits. The pseudo-random sequence is initialized to all 1's. Data whitening, if enabled, is applied on all fields excluding the preamble and the SYNC words. At the receiver end, the data are XOR-ed with the same pseudo-random sequence. Whitening is applied according to the following LFSR implementation: Figure 12. LFSR block diagram It is recommended to always enable data whitening. ### 9.6.4 Data padding If FEC is enabled then the total length of payload and CRC must be an even number (in order to completely fill up the interleaver). If not, a proper filling byte is automatically inserted in transmission and removed by the receiver. The total packet length is affected, and it is configured automatically enabling the FEC. # 9.7 Packet handler engine Before on-the-air transmission, raw data is properly cast into a packet structure. The SPIRIT1 offers a highly flexible and fully programmable packet; the structure of the packet, the number, the type, and the dimension of the fields inside the packet depend on one of the possible configuration settings. Through a suitable register the user can choose the packet configuration from three options: STack, WM-Bus, and Basic. The current packet format is set by the PCK\_FRMT field of the PCKTCTRL3 register. In particular: - 0 Basic packet format - 2 MBUS packet format - 3 STack packet format. The general packet parameters which can be set by the user are listed and described hereafter. Some particular restrictions are possible depending on the selected packet format. ## 9.7.1 STack packet | 1-32 | 1-4 | 0-16 bit | 1 | 1 | 0-4 | 2 bit | 1 bit | 0-65535 | 0-3 | |--------------|------|----------|------------------|----------------|---------|----------|--------|---------|-----| | Preambl<br>e | Sync | Length | Dest.<br>address | Source address | Control | Seq. No. | NO_ACK | Payload | CRC | **Preamble** (programmable field): the length of the preamble is programmable from 1 to 32 bytes by the PREAMBLE\_LENGTH field of the PCKTCTRL2 register. Each preamble byte is a '10101010' binary sequence. **Sync** (programmable field): the length of the synchronization field is programmable (from 1 to 4 bytes) through dedicated registers. The SYNC word is programmable through registers SYNC1, SYNC2, SYNC3, and SYNC4. If the programmed sync length is 1 then only the SYNC1 word is transmitted; if the programmed sync length is 2 then only SYNC1 and SYNC2 words are transmitted and so on. **Length** (programmable/optional field): the packet length field is an optional field that is defined as the cumulative length of Address (2 bytes always), Control, and Payload fields. It is possible to support fixed and variable packet length. In fixed mode, the field length is not used. **Destination address** (programmable field): When the destination address filtering is enabled in the receiver, the packet handler engine compares the destination address field of the packet received with the value of register TX\_SOURCE\_ADDR. If broadcast address and/or multicast address filtering are enabled the packet handler engine compares the destination address with the programmed broadcast and/or multicast address. **Source address** (programmable field): is filled with the value of register TX\_SOURCE\_ADDR. When source address filtering is enabled in the receiver, the packet handler engine compares the source address received with the programmed source address reference using the source mask address programmed. The field ADDRESS LEN of the PCKTCTRL4 register must be set always to 2. **Control** (programmable/optional field): is programmable from 0 to 4 bytes through the CONTROL\_LEN field of the PCKTCTRL4 register. Control fields of the packet can be set using the TX\_CTRL\_FIELD[3:0] register. **Sequence number** (programmable field): is a 2-bit field and contains the sequence number of the transmitted packet. It is incremented automatically every time a new packet is transmitted. It can be re-loaded with the value in the TX\_SEQ\_NUM\_RELOAD[1:0] field of the PROTOCOL[2] register, by using the SEQUENCE\_UPDATE command. **NO\_ACK** (programmable field): 1 means for the receiver that the packet is not to be auto-acknowledged. It is programmed by the bit field NACK\_TX of the register PROTOCOL[2]. It is important set to 0 this bit field in any other packet format. **Payload** (programmable/optional field): the device supports both fixed and variable payload length transmission from 0 to 65535 bytes. On the transmitter, the payload length is always set as: PCKTLEN1 × 256 + PCKTLEN0. On the receiver, if the field FIX\_VAR\_LEN of the PCKTCTRL2 register is set to 1, the payload length is directly extracted from the received packet itself; if FIX\_VAR\_LEN is set to 0, the payload length is controlled by the PCKTLEN0 and PCKTLEN1 registers as the transmitter. In variable length mode, the width of the binary field transmitted, where the actual length of payload is written, can be configured through the field LEN\_WIDTH of the PCKTCTRL3 register according to the maximum length expected in the specific application. #### Example 1 - If the variable payload length is from 0 to 31 bytes, then the length width should be 5 bits, thus the field LEN\_WIDTH = 4 - If the variable payload length is from 0 to 255 bytes, then the length width should be 8 bits, thus the field LEN WIDTH = 7 - If the variable payload length is from 0 to 65535 bytes, then the length width should be 16 bits, thus the field LEN\_WIDTH = 15. **CRC** (programmable/optional field): There are different polynomials CRC: 8 bits, 16 bits (2 polynomials are available) and 24 bits. When CRC automatic filtering is enabled, the received packet is discarded automatically when CRC check fails. ## 9.7.2 Wireless M-Bus packet (W M-BUS, EN13757-4) The WM-BUS packet structure is shown in the figure below (refer to EN13757 for details about sub-mode specific radio setting). | Bytes nx(01) | | | | | nx(01) | | |--------------|-----------------------------------|-----------------------|-----------------------|-------------|-----------|--| | Preamble | Sync | 1 <sup>st</sup> block | 2 <sup>nd</sup> block | Opt. blocks | Postamble | | | | | | | | | | | | Manchester or 3 out of 6 encoding | | | | | | The preamble consists of a number of chip sequences '01' whose length depends on the chosen sub-mode according to EN13757-4. The length can be programmed using the MBUS\_PRMBL\_CTRL, from a minimum to a maximum dictated from the standard specification. 1st block, 2nd block, and optional blocks: can be defined by the user. The packet handler engine uses the Manchester or the "3 out of 6" encoding for all the blocks according to the defined sub-mode. The postamble consists of a number of chip sequences '01' whose length depends on the chosen sub-mode according to EN13757-4. The length can be programmed using the MBUS\_PSTMBL\_CTRL, from a minimum to a maximum dictated from the standard specification. The sub-mode can be chosen setting the MBUS\_SUBMODE[2:0] field of the MBUS\_CTRL register. There are 5 possible cases: - Submode S1, S2 (long header) (MBUS\_SUBMODE=0): - Header length = MBUS PRMBL CTRL + 279 (in '01' bit pairs) - Sync word = 0x7696 (length 18 bits) - Submode S1-m, S2, T2 (other to meter) (MBUS\_SUBMODE =1): - Header length = MBUS PRMBL CTRL + 15 (in '01' bit pairs) - Sync word = 0x7696 (length 18 bits) - Submode T1, T2 (meter to other) (MBUS\_SUBMODE =3): - Header length = MBUS PRMBL CTRL + 19 (in '01' bit pairs) - Sync word = 0x3D (length 10 bits) - Submode R2, short header (MBUS\_SUBMODE =5): - Header length = MBUS PRMBL CTRL + 39 (in '01' bit pairs) - Sync word = 0x7696 (length 18 bits). - Submode N1, N2, short header: - Header length = 8 (in '01' bit pairs) - Sync word = 0xF68D (length 18 bits). ## 9.7.3 Basic packet | 1-32 | 1-4 | 0-16 bit | 0-1 | 0-4 | 0-65535 | 0-3 | | |----------|------|----------|---------|---------|---------|-----|--| | Preamble | Sync | Length | Address | Control | Payload | CRC | | **Preamble** (programmable field): the length of the preamble is programmable from 1 to 32 bytes by the PREAMBLE\_LENGTH field of the PCKTCTRL2 register. Each preamble byte is a '10101010' binary sequence. **Sync** (programmable field): the length of the synchronization field is programmable (from 1 to 4 bytes) through dedicated registers. The SYNC word is programmable through registers SYNC1, SYNC2, SYNC3, and SYNC4. If the programmed sync length is 1, then only SYNC word is transmitted; if the programmed sync length is 2 then only SYNC1 and SYNC2 words are transmitted and so on. **Length** (programmable/optional field): the packet length field is an optional field that is defined as the cumulative length of Address, Control, and Payload fields. It is possible to support fixed and variable packet length. In fixed mode, the field length is not used. **Destination address** (programmable/optional field): when the destination address filtering is enabled in the receiver, the packet handler engine compares the destination address field of the packet received with the value of register TX\_SOURCE\_ADDR. If broadcast address and/or multicast address filtering are enabled, the packet handler engine compares the destination address with the programmed broadcast and/or multicast address. **Control** (programmable/optional field): is programmable from 0 to 4 bytes through the CONTROL\_LEN field of the PCKTCTRL4 register. Control fields of the packet can be set using the TX\_CTRL\_FIELD[3:0] register. **Payload** (programmable/optional field): the device supports both fixed and variable payload length transmission from 0 to 65535 bytes. On the transmitter, the payload length is always set as: PCKTLEN1 × 256 + PCKTLEN0. On the receiver, if the field FIX\_VAR\_LEN of PCKTCTRL2 register is set to 1, the payload length is directly extracted from the received packet itself; if FIX\_VAR\_LEN is set to 0, the payload length is controlled by the PCKTLEN0 and PCKTLEN1 registers as the transmitter. Furthermore, in variable length mode, the width of the binary field transmitted, where the actual length of payload is written, must be configured through the field LEN\_WIDTH of the PCKTCTRL3 register according to the maximum length expected in the specific application. #### **Example 1** - If the variable payload length is from 0 to 31 bytes, the length width should be 5 bits, thus the field LEN WIDTH = 4 - If the variable payload length is from 0 to 255 bytes, the length width should be 8 bits, thus the field LEN\_WIDTH = 7 - If the variable payload length is from 0 to 65535 bytes, the length width should be 16 bits, thus the field LEN\_WIDTH = 15. **CRC** (programmable/optional field): There are different polynomials CRC: 8 bits, 16 bits (2 polynomials are available) and 24 bits. When the CRC automatic filtering is enabled, the received packet is discarded automatically when the CRC check fails. ## 9.7.4 Automatic packet filtering The following filtering criteria to automatically reject a received packet are supported: - CRC filtering - Destination address filtering - Source address filtering - Control field filtering. Packet filtering is enabled by the AUTO\_PCKT\_FLT field of the PROTOCOL register and the filtering criteria can be controlled by the PCK\_FLT\_OPT and PCK\_FLT\_GOALS registers. Each filtering option works on the correct packet format according to Table 34. - **CRC**: the received packet is discarded if CRC is not passed. To enable this automatic filtering feature the bit field CRC CHECK of the PCK FLT OPT register must be set. - **Destination address**: this automatic filtering feature works on my address, broadcast address and/or multicast address of the receiver. - Destination vs. my address: the received packet is discarded if the destination address received does not match the programmed my address of the receiver. My address can be programmed for the receiver in the TX\_SOURCE\_ADDR register. To enable this automatic filtering option the bitfield DEST\_VS\_SOURCE\_ADDR of the PCKT\_FLT\_OPTIONS register must be set. - Destination vs. broadcast address: the received packet is discarded if the destination address received does not match the programmed broadcast address of the receiver. The broadcast address can be programmed for the receiver in the BROADCAST register. To enable this automatic filtering option the bitfield DEST\_VS\_BROADCAST\_ADDR of the PCKT\_FLT\_OPTIONS register must be set. - Destination vs. multicast address: the received packet is discarded if the destination address received does not match the programmed multicast address of the receiver. The multicast address can be programmed for the receiver in the MULTICAST register. To enable this automatic filtering option the bitfield DEST\_VS\_MULTICAST\_ADDR of the PCKT\_FLT\_OPTIONS register must be set. More than one automatic filtering option can be enabled at the same time. **Source address**: the received packet is discarded if the source address received does not match the programmed source address reference through the source mask address (the reference value used for the comparison is the reference one in AND bitwise with the source mask). The source address reference can be programmed for the receiver in the RX\_SOURCE\_ADDR register and the source address mask in the RX\_SOURCE\_MASK register. To enable this automatic filtering option the bitfield SOURCE\_FILTERING of the PCKT\_FLT\_OPTIONS register must be set. **Control**: the received packet is discarded if the control field received does not match the programmed control reference through the control mask (the reference value used for the comparison is the reference one in AND bitwise with the control mask). The control reference can be programmed for the receiver in the CONTROLx\_FIELD registers and the control field mask in the CONTROLx\_MASK registers. To enable this automatic filtering option the bitfield CONTROL\_FILTERING of the PCKT\_FLT\_OPTIONS register must be set. | | STack | MBUS | Basic | |------------------------------------|----------|------|----------| | Destination address filtering | Optional | No | Optional | | Broadcast and multicast addressing | Optional | No | Optional | | Source address filtering | Optional | No | No | | Custom filtering | Optional | No | Optional | | CRC filtering | Optional | No | Optional | Table 34. Packet configuration When a filtering mechanism is enabled the packet is signaled to the MCU only if the check is positive, otherwise the packet is automatically discarded. ## 9.7.5 Link layer protocol SPIRIT1 has an embedded auto-ACK and auto-retransmission available through the STack packet format. ### Automatic acknowledgment Automatic acknowledgment is enabled on the receiver by setting the bitfield AUTO\_ACK of the PROTOCOL register. In this way, after the receiver receives a packet with success, it sends an ACK packet only if the NO\_ACK bit of the received packet is 1. This gives an opportunity for the transmitter to tell the receiver if the packet sent must be acknowledged or not. The ACK request can be put in the packet (NO\_ACK packet's bitfield at 1) by setting the NACK\_TX field of the PROTOCOL[2] register. If the ACK request is ON (NO\_ACK packet's bitfield at 1), the transmitter stays in RX state to receive an ACK packet until the RX timeout, programmed with the RX\_TIMEOUT\_PRESCALER and RX\_TIMEOUT\_COUNTER, expires. If the transmitter does not receive any ACK packet when it must, the packet transmitted is considered lost, and the TX\_DATA\_SENT in the IRQ\_STATUS register remains at 0. ### Automatic acknowledgment with piggybacking The receiver can fill the ACK packet with data. To do so, the receiver must fill the TX FIFO with the payload it must transmit and the bitfield PIGGYBACKING of PROTOCOL[1] register must be set. With the automatic acknowledgement enabled, the TX strobe is not supported and must not be sent. #### **Automatic retransmission** If the transmitter does not receive the ACK packet, it can be configured to do another transmission. This operation can be repeated up to 15 times. To configure how many times this operation must be performed, the field NMAX\_RETX of the PROTOCOL[2] register is used. With the automatic retransmission enabled the RX strobe is not supported and must not be sent. Using the automatic retransmission the payload must be loaded into the TX FIFO register with a single write FIFO operation in READY state. ## 9.8 Data modes Direct modes are primarily intended to completely bypass all the framer/deframer operations, in order to give the user maximum flexibility in the choice of frame formats, controlled by the field TXSOURCE of the PCKTCTRL1 register. In particular: #### TXSOURCE = - 0 normal modes - 1 direct through FIFO: the packet is written in TX FIFO. The user builds the packet according to his need including preamble, payload and so on. The data are transmitted without any processing. - 2 direct through GPIO: the packet bits are continuously read from one of the GPIO pins, properly configured, and transmitted without any processing. To allow the synchronization of an external data source, a data clock signal is also provided on one of the GPIO pins. Data are sampled by the device on the rising edge of such clock signal; it is the responsibility of the external data source to provide a stable input at this edge. - 3 PN9 mode: a pseudo-random binary sequence is generated internally. This mode is provided for test purposes only. To improve flexibility, the entire packet related functions can be bypassed and the device can operate in one of the following direct modes, controlled by the field RXMODE of PCKTCTRL3. In particular: #### RXMODE = - 0 normal modes - 1 direct through FIFO: the packet bytes are continuously received and written to the RX FIFO without any processing. It is the responsibility of the microcontroller to avoid any overflow conditions on the RX FIFO. - 2 direct through GPIO: the packet bits are continuously written to one of the GPIO pins without any processing. To allow the synchronization of an external data sink, a data clock signal is also provided on one of the GPIO pins. Data are updated by the device on the falling edge of such clock signal so the MCU must read it during falling edge of CLK. ## 9.9 Data FIFO In the SPIRIT1 there are two data FIFOs, a TX FIFO for data to be transmitted and an RX FIFO for the received data. The length of both FIFOs is 96 bytes. The SPI interface is used to read from the RX FIFO and write to the TX FIFO (see *Figure 13*) starting from the address 0xFF. Figure 13. Threshold of the linear FIFO The FIFO has two programmable thresholds: FIFO almost full and FIFO almost empty. The FIFO almost full event occurs when the data crosses the threshold from below to above. The TX FIFO almost empty threshold can be configured using the field TXAETHR in the FIFO\_CONFIG[0] register. The RX FIFO almost empty threshold can be configured using the field RXAETHR in the FIFO\_CONFIG[2] register. The FIFO almost empty event occurs when the data crosses the threshold from above to below. The TX FIFO almost full threshold can be configured using the field TXAFTHR in the FIFO\_CONFIG[1] register. The RX FIFO almost full threshold can be configured using the field RXAFTHR in the FIFO\_CONFIG[3] register. Another event occurs when the FIFO goes into overflow or underflow. The overflow happens when the data in the FIFO are more than 96 bytes. The underflow happens when the SPIRIT1 accesses the FIFO locations to read data, but there is no data present. For example: - If it reads from the RX FIFO more data than the actual number of bytes in it, the RX FIFO underflow/overflow error occurs for an underflow event. - If the SPIRIT1 receives a lot of data to fill the RX FIFO and exceeds the 96 bytes limit, an RX FIFO underflow/overflow error occurs for an overflow event. - If it sends more data than the actual number of bytes in the TX FIFO, the TX FIFO underflow/overflow error occurs for an underflow event. - If it writes more than 96 bytes in the TX FIFO, a TX FIFO underflow/overflow error occurs for an overflow event. An easy way to clean the FIFOs is to use the flush commands: FLUSHTXFIFO for the TX FIFO and FLUSHRXFIFO for the RX FIFO. The write TX FIFO operation needs an extra SPI transaction to write correctly the last byte into the TX FIFO. Usually, this last SPI transaction is generated from the TX command sent to transmit the data, otherwise a dummy SPI transaction must be done. Using the auto-retransmission feature of the SPIRIT1 (packet format STack), if the packet is more than 96 bytes, the packet must be reloaded into the TX FIFO by the MCU. However, if the payload is 96 bytes or less, the SPIRIT1 handles the payload and it is not necessary to reload the data into the TX FIFO at each retransmission. In addition, if the transmitter does not receive the ACK packet, the payload remains in the TX FIFO. The user can decide to clean the TX FIFO or re-send the data again. If the payload is more than 96 bytes, only the last part of the payload that fits the TX FIFO remains in it. ## 9.10 Receiver quality indicators The following quality indicators are associated to the received signal: - Received signal strength indicator (RSSI) - Preamble quality indicator (PQI) - Synchronization quality indicator (SQI). #### 9.10.1 RSSI The received signal strength indicator (RSSI) is a measurement of the received signal power at the antenna measured in the channel filter bandwidth. RSSI reading is available after the reception of a packet in the RSSI\_LEVEL register. The measured power is reported in steps of 0.5 dB according to the following formula: The RSSI value is updated in the RSSI\_LEVEL register when the SPIRIT1 exits from the RX state by SABORT command, RX timeout expiration or at the SYNC word detected event. #### 9.10.2 Carrier sense The carrier sense functionality can be used to detect if any signal is being received, the detection is based on the measured RSSI value. There are 2 operational modes for carrier sensing: static and dynamic. When static carrier sensing is used (CS\_MODE = 0), the carrier sense signal is asserted when the measured RSSI is above the value specified in the RSSI\_TH register and is deasserted when the RSSI falls 3 dB below the same threshold. When dynamic carrier sense is used (CS\_MODE = 1, 2, 3), the carrier sense signal is asserted if the signal is above the threshold and a fast power increase of 6, 12, or 18 dB is detected; it is de-asserted if a power fall of the same amplitude is detected. The carrier sense signal is also used internally for the demodulator to start the AFC and symbol timing recovery algorithms and for the CSMA procedure (for this use it should be set to CS MODE = 0). The carrier sense function is controlled by the following parameters: RSSI threshold: When the RSSI threshold is exceeded, the AFC and the symbol timing recovery algorithm start to work with the stream of data. To maximize the sensitivity, the RSSI threshold should be set around 3 dB below the expected sensitivity level. The RSSI TH register and the effective RSSI threshold value are linked by the following formula: RSSI TH = $$2 \cdot (RSSI \text{ threshold } dBm + 130)$$ CS mode: this parameter controls the carrier sense operational modes (RSSI\_FLT register, allowed values 0...3): - CS MODE = 0 static carrier sensing - CS\_MODE = 1 dynamic carrier sensing with 6 dB dynamic threshold - CS MODE = 2 dynamic carrier sensing with 12 dB dynamic threshold - CS\_MODE = 3 dynamic carrier sensing with 18 dB dynamic threshold. ### 9.10.3 PQI The preamble quality indicator (PQI) is intended to provide a measurement of the reliability of the preamble detection phase. This indicator counts the number of consecutive bit inversions in the received data stream. The PQI ranges from 0 to 255. It is increased by 1 every time a bit inversion occurs, while it is decreased by 4 every time a bit repetition occurs. It is possible to set a preamble quality threshold in such a way that, if PQI is below the threshold, the packet demodulation is automatically aborted at/after a timeout after the start of RX. If the preamble quality indicator check is enabled (field PQI\_EN of the QI register set to '1'), the running peak PQI is compared to a threshold value and the preamble valid IRQ is asserted as soon as the threshold is passed. The preamble quality threshold is $4\times PQI_TH$ (PQI\_TH = 0...15). #### 9.10.4 SQI The synchronization quality indicator (SQI) is a measurement of the best correlation between the received SYNC word and the expected one. The value representing a perfect match is 8×SYNC LENGTH. This indicator is calculated as the peak cross-correlation between the received data stream and the expected SYNC word. It is possible to set a synchronization quality threshold in such a way that, if SQI is below the threshold, the packet demodulation is automatically aborted. If the synchronization quality indicator check is enabled (field SQI\_EN of the QI register set to '1'), the running peak SQI is compared to a threshold value and the sync valid IRQ is asserted as soon as the threshold is passed. The sync quality threshold is equal to $8 \times SYNC_LEN - 2xSQI_TH$ with SQI\_TH = 0..3. When SQI\_TH is 0, a perfect match is required; when SQI\_TH = 1, 2, 3 then 1, 2, or 3-bit errors are respectively accepted. It is recommended to always enable the SQI check. #### **RX** timeout mechanism In order to reduce power consumption, a few automatic RX timeout modes are supported. RX timeout applies both to normal receive mode and to the LDCR mode. Infinite timeout: in this mode RX is stopped when the packet ends or the SABORT command strobe is issued (default). Carrier sense timeout: RX is aborted if the RSSI never exceeds a programmed threshold within RX timeout. SQI timeout: in this mode RX is aborted if the synchronization quality indicator (SQI) never exceeds a programmed threshold within RX timeout. PQI timeout: in this mode RX is aborted if the preamble quality indicator (PQI) never exceeds a programmed threshold within RX timeout. The value of RX timeout can be programmed ranging from ~1 µs to ~3 sec. # 9.11 Antenna diversity The device implements a switching based antenna diversity algorithm. The switching decision is based on a comparison between the received power level on antenna 1 and antenna 2 during the preamble reception. The antenna switching function allows to control an external switch in order to select the antenna providing the highest measured RSSI. When antenna switching is enabled, the two antennas are repeatedly switched during the reception of the preamble of each packet, until the carrier sense threshold is reached<sup>(c)</sup> (static carrier sense mode must be used). From this point on, the antenna with the highest power is selected and switching is frozen. The switch control signal is available on GPIO and in the MC\_STATE[1] register. c. The user should make sure to provide a preamble sufficiently long to allow the algorithm to choose the final antenna. DocID022758 Rev 10 The algorithm is controlled by the following parameters: AS\_MEAS\_TIME: this parameter controls the time interval for RSSI measurement (ANT\_SELECT\_CONF register, allowed values 0...7). The actual measurement time is: Equation 12 $$T_{meas} = \frac{24 \cdot 2^{CHFLT\_E} \cdot 2^{AS\_meas\_time}}{f_{XO}}$$ AS\_ENABLE: this parameter enables the antenna switching function (ANT\_SELECT\_CONF register: 0: disabled; 1: enabled). The GPIOx to be used as antenna switch should be independently configured through the GPIO\_CONFx register (see *Table 37: Digital outputs* for details). ## 9.12 Frequency hopping In order to ensure good link reliability in an interference corrupted scenario, the device supports frequency hopping, managed by the MCU; in particular, the SPIRIT1 supports slow frequency hopping, meaning that the systems change frequency at a rate slower than the information rate. Depending on the desired blanking interval (the time during a hop), frequency hopping can be done by performing the complete PLL calibration for each channel hop, or reading in the suitable register calibration data calculated at startup and stored in the non-volatile memory of the MCU. The former solution gives a long blanking interval but is more robust compared with supply voltage and temperature variation. The latter provides a shorter blanking time but is sensitive to voltage and temperature variation and requires memory space to store calibration data for each channel involved in hopping. SPIRIT1 MCU interface ### 10 MCU interface Communication with the MCU goes through a standard 4-wire SPI interface and 4 GPIOs. The device is able to provide a system clock signal to the MCU. MCU performs the following operations: - Program the SPIRIT1 in different operating modes by sending commands - Read and write buffered data, and status information from the SPI - Get interrupt requests from the GPIO pins - Apply external signals to the GPIO pins. ### 10.1 Serial peripheral interface The SPIRIT1 is configured by a 4-wire SPI-compatible interface (CSn, SCLK, MOSI, and MISO). More specifically: - CSn: chip select, active low - SCLK: bit clock - MOSI: data from MCU to SPIRIT1 (SPIRIT1 is the slave) - MISO: data from SPIRIT1 to MCU (MCU is the master). As the MCU is the master, it always drives the CSn and SCLK. According to the active SCLK polarity and phase, the SPIRIT1 SPI can be classified as mode 1 (CPOL=0, CPHA=0), which means that the base value of SCLK is zero, data are read on the clock's rising edge and data are changed on the clock's falling edge. The MISO is in tri-state mode when CSn is high. All transfers are done most significant bit first. The SPI can be used to perform the following operations: - Write data (to registers or FIFO queue) - Read data (from registers or FIFO queue) - Write commands. The SPI communication is supported in all the active states, and also during the low power state: STANDBY and SLEEP (see *Table 20: States*). When accessing the SPI interface, the two status bytes of the MC\_STATE[1:0] registers are sent to the MISO pin. The timing diagrams of the three operations above are reported below. MCU interface SPIRIT1 Figure 14. SPI "write" operation Figure 15. SPI "read" operation Figure 16. SPI "command" operation Concerning the first byte, the MSB is an A/C bit (Address/Commands: 0 indicates that the following byte is an address, 1 indicates that the following byte is a command code), while the LSB is a W/R bit (Write/Read: 1 indicates a read operation). All other bits must be zero. 76/104 DocID022758 Rev 10 SPIRIT1 MCU interface Read and write operations are persistently executed while CSn is kept active (low), the address being automatically incremented (burst mode). Accessing the FIFO is done as usual with the read and write commands, by putting, as the address, the code 0xFF. Burst mode is available to access the sequence of bytes in the FIFO. Clearly, RX-FIFO is accessed with a read operation, TX-FIFO with a write operation. Details of the SPI parameters are reported below. Table 35. SPI interface timing requirements | Symbol | Parameter | Min. | Max. | Unit | |-------------------|----------------------------------|------|------|------| | f <sub>SCLK</sub> | SCLK frequency | | 10 | MHz | | t <sub>sp</sub> | CSn low to positive edge on SCLK | 2 | | μs | ## 10.2 Interrupts In order to notify the MCU of a certain number of events an interrupt signal is generated on a selectable GPIO. The following events trigger an interrupt to the MCU: Table 36. Interrupts | Bit | Events group Interrupt event | | | | | | | |-----|------------------------------|--------------------------------------|--|--|--|--|--| | 0 | | RX data ready | | | | | | | 1 | | RX data discarded (upon filtering) | | | | | | | 2 | | TX data sent | | | | | | | 3 | | Max. re-TX reached | | | | | | | 4 | | CRC error | | | | | | | 5 | Daakot oriented | TX FIFO underflow/overflow error | | | | | | | 6 | Packet oriented | RX FIFO underflow/overflow error | | | | | | | 7 | | TX FIFO almost full | | | | | | | 8 | | TX FIFO almost empty | | | | | | | 9 | | RX FIFO almost full | | | | | | | 10 | | RX FIFO almost empty | | | | | | | 11 | | Max. number of backoff during CCA | | | | | | | 12 | | Valid preamble detected | | | | | | | 13 | Signal quality related | Sync word detected | | | | | | | 14 | | RSSI above threshold (carrier sense) | | | | | | MCU interface SPIRIT1 | Bit | Events group | Interrupt event | |-----|-----------------------|---------------------------------------------| | Бк | Events group | interrupt event | | 15 | | Wake-up timeout in LDCR mode <sup>(1)</sup> | | 16 | | READY <sup>(2)</sup> | | 17 | Device status related | STANDBY state switching in progress | | 18 | | Low battery level | | 19 | | Power-on reset | | 20 | | Brownout event | | 21 | | LOCK | | 29 | Timer related | RX operation timeout | | 30 | Others | AES end-of-operation | Table 36. Interrupts (continued) All interrupts are reported on a set of interrupt status registers and are individually maskable. The interrupt status register must be cleared upon a read event from the MCU. The status of all the interrupts is reported on the IRQ\_STATUS[3:0] registers: bits are high for the events that have generated any interrupts. The interrupts are individually maskable using the IRQ\_MASK[3:0] registers: if the mask bit related to a particular event is programmed at 0, that event does not generate any interrupt request. #### 10.3 GPIOs The total number of GPIO pins is 4. Each pin is individually configurable. Digital outputs can be selected from the following (see GPIOx\_CONF register): Table 37. Digital outputs | I/O selection | Output signal | |---------------|------------------------------------------------------------------------------| | 0 | nIRQ (interrupt request, active low) | | 1 | POR inverted (active low) | | 2 | Wake-up timer expiration: '1' when WUT has expired | | 3 | Low battery detection: '1' when battery is below threshold setting | | 4 | TX data internal clock output (TX data are sampled on the rising edge of it) | | 5 | TX state indication: '1' when the SPIRIT1 is transiting in the TX state | | 6 | TX FIFO almost empty flag | | 7 | TX FIFO almost full flag | | 8 | RX data output | The interrupt flag n.15 is set (and consequently the interrupt request) only when the XO clock is available for the state machine. This time may be delayed compared to the actual timer expiration. However, the real time event can be sensed putting the end-of-counting signal on a GPIO output. <sup>2.</sup> The interrupt flag n.16 is set each time the SPIRIT1 goes to READY state and the XO has completed its setting transient (XO ready condition detected). SPIRIT1 MCU interface Table 37. Digital outputs (continued) | I/O selection | Output signal | |---------------|-----------------------------------------------------------------------------------------------| | 9 | RX clock output (recovered from received data) | | 10 | RX state indication: '1' when SPIRIT1 is transiting in the RX state | | 11 | RX FIFO almost full flag | | 12 | RX FIFO almost empty flag | | 13 | Antenna switch used for antenna diversity | | 14 | Valid preamble detected flag | | 15 | Sync word detected flag | | 16 | RSSI above threshold (same indication as bit CS in the LINK_QUALIF[1] register) | | 17 | MCU clock | | 18 | TX or RX mode indicator (to enable an external range extender) | | 19 | VDD (to emulate an additional GPIO of the MCU, programmable by SPI) | | 20 | GND (to emulate an additional GPIO of the MCU, programmable by SPI) | | 21 | External SMPS enable signal (active high) | | 22 | Device in SLEEP or STANDBY states | | 23 | Device not in SLEEP and not in STANDBY states | | 24 | Device in LOCK state | | 25 | Device waiting for a high level of the lock-detector output signal | | 26 | Device waiting for timer expiration before starting to sample the lock-detector output signal | | 27 | Device waiting for a high level of the READY2 signal from XO | | 28 | Device waiting for timer expiration to allow PM block settling | | 29 | Device waiting for end of VCO calibration | | 30 | Device enables the full circuitry of the SYNTH block | | 31 | Device waiting for a high level of the RCCAL_OK signal from the RCO calibrator | All interrupts are reported on a set of interrupt status registers and are individually maskable. The interrupt status register must be cleared upon a read event from the MCU. The status of all the interrupts is reported on the IRQ\_STATUS[3:0] registers: bits are high for the events that have generated any interrupts. The interrupts are individually maskable using the IRQ\_MASK[3:0] registers: if the mask bit related to a particular event is programmed at 0, that event does not generate any interrupt request. Digital inputs can be selected from the following (see GPIOx\_CONF register): MCU interface SPIRIT1 Table 38. Digital inputs | I/O selection | Input signal | | | | | | | |---------------|-------------------------------------------------------|--|--|--|--|--|--| | 0 | 1 >> TX command | | | | | | | | 1 | 1 >> RX command | | | | | | | | 2 | TX data input for direct modulation | | | | | | | | 3 | Wake-up from external input (sensor output) | | | | | | | | 4 | External clock @ 34.7 kHz (used for LDC modes timing) | | | | | | | | From 5 to 31 | Not used | | | | | | | The only available analog output is the temperature sensor, see Section 8.12. #### 10.4 MCU clock SPIRIT1 can directly provide the system clock to the MCU in order to avoid the use of an additional crystal. The clock signals for the MCU can be available on the GPIO pins. The source oscillator can be the internal RCO or the XO depending on the active state. When XO is active, it is the source clock (the RCO is not available in this condition). In addition, different ratios are available and programmable through the MCU\_CK\_CONF configuration register, as described in *Table 39*. Table 39. MCU\_CK\_CONF configuration register | MCU_CK | (_CONF[4:0] | Claskasumas | Division vetic | | |------------|-------------|--------------|----------------|--| | XO_RATIO | RCO_RATIO | Clock source | Division ratio | | | Don't care | 0 | RCO | 1 | | | | 1 | | 1/128 | | | 0 | Don't care | XO | 1 | | | 1 | | | 2/3 | | | 2 | | | 1/2 | | | 3 | | | 1/3 | | | 4 | | | 1/4 | | | 5 | | | 1/6 | | | 6 | | | 1/8 | | | 7 | | | 1/12 | | | 8 | | | 1/16 | | | 9 | | | 1/24 | | | 10 | | | 1/36 | | | 11 | | | 1/48 | | | 12 | | | 1/64 | | SPIRIT1 MCU interface | WCU_CF | (_CONF[4:0] | - Clock source | Division ratio | | |----------|-------------|----------------|----------------|--| | XO_RATIO | RCO_RATIO | Clock Source | DIVISION FALIO | | | 13 | | | 1/96 | | | 14 | | | 1/128 | | | 15 | | | 1/192 | | Table 39. MCU\_CK\_CONF configuration register (continued) In STANDBY state, no oscillator is available as the clock source. In order to allow the MCU to better handle this event, and avoid a potential dead state situation, a dedicated procedure is forecasted when the SPIRIT1 enters STANDBY state. A few extra clock cycles can be provided to the MCU before actually stopping the clock (an interrupt is generated to notify the MCU of this event). The number of extra cycles can be programmed through the MCU\_CK\_CONF configuration register to 0, 64, 256, or 512. The MCU can make use of these cycles to prepare to standby or to switch on any auxiliary clock generator. The maximum transition time from READY to STANDBY is then: #### **Equation 13** $$\Delta T_{\text{READY STANDBY}} = \frac{1}{f_{\text{clk}}} \cdot \frac{512}{1/192} = \frac{98304}{f_{\text{clk}}}$$ where f<sub>clk</sub> is the digital clock frequency (typically 26 MHz). The transition to SLEEP state causes the MCU clock source to change from XO to RCO. Similarly, when the SPIRIT1 exits SLEEP to any active state, the source is the XO. Both these transitions are implemented in order to be glitch-free. This is guaranteed by synchronizing both transitions, switching on the rising or falling edge of the RCO clock. The clock provided to the MCU depends on the current state: Table 40. MCU clock vs. state | State | Source oscillator | MCU clock | |-----------------------------|-------------------|----------------| | SHUTDOWN | N/A | N/A | | STANDBY | N/A | Tail | | SLEEP | RC Osc | RC/1 or RC/128 | | READY<br>TUNING<br>RX<br>TX | XTAL | XTAL/N | # 11 Register table This section describes all the registers used to configure the SPIRIT1. The description is structured in sections according to the register usage. SPIRIT1 has three types of registers: - Read and write (R/W), which can be completely managed by SPI using READ and WRITE operations - Read-only (R) - Read-and-reset (RR), is automatically cleared after a READ operation. A further category of special registers collects the ones which cannot be categorized in any of the three mentioned above R/W, R, or RR. The fields named as "Reserved" must not be overridden by the user, otherwise, behavior is not guaranteed. The memory map is shown in the following table: Table 41. General configuration registers | Register | Address | Bit | Field name | Reset | R/W | Description | |------------------|---------|-----|------------------|-------|-----|----------------------------------------------------------------------------| | | - | 7:5 | Reserved | 000 | | | | | | 4:2 | GM_CONF[2:0] | 011 | | Sets the driver gm of the XO at startup | | ANA_FUNC_CONF[1] | 0x00 | 1:0 | SET_BLD_LVL[1:0] | 00 | R/W | Sets the BLD threshold<br>00: 2.7 V<br>01: 2.5 V<br>10: 2.3 V<br>11: 2.1 V | Table 41. General configuration registers (continued) | Register | Address | Bit | Field name | Reset | R/W | Description | |------------------|---------|-----|------------------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------| | | | 7 | Reserved | 1 | | | | | | 6 | 24_26MHz_SELECT | 1 | - | 1: 26 MHz configuration 0: 24 MHz configuration (impact only RCO calibration reference and loop filter tuning) | | | | 5 | AES_ON | 0 | | 1: AES engine enabled | | ANA_FUNC_CONF[0] | 0x01 | 4 | EXT_REF | 0 | R/W | 0: reference signal from XO circuit 1: reference signal from XIN pin | | | | 3 | Reserved | 0 | | | | | | 2 | BROWN_OUT | 0 | | 1: enables accurate brownout detection | | | | 1 | BATTERY_LEVEL | 0 | | 1: enables battery level detector circuit | | | | 0 | TS | 0 | | 1: enables the "temperature sensor" function | | | | 7:3 | GPIO_SELECT[4:0] | 10100 | | GPIO3 configuration (default: digital GND) | | | | 2 | Reserved | 0 | | | | GPIO3_CONF | 0x02 | 1:0 | GPIO_MODE[1:0] | 10 | R/W | GPIO3 mode: 01b: digital input 10b: digital output low power 11b: digital output high power (default: digital output low power) | | | | 7:3 | GPIO_SELECT[4:0] | 10100 | | GPIO2 configuration (default: digital GND) | | | 0x03 | 2 | Reserved | 0 | | | | GPIO2_CONF | | 1:0 | GPIO_MODE | 10 | R/W | GPIO2 mode: 01b: digital input 10b: digital output low power 11b: digital output high power (default: digital output low power) | Table 41. General configuration registers (continued) | Register | Address | Bit | Field name | Reset | R/W | Description | | | |-------------|---------|-----|------------------|-----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------| | | | 7:3 | GPIO_SELECT[4:0] | 10100 | | GPIO1 configuration (default: digital GND) | | | | | | 2 | Reserved | 0 | | | | | | GPIO1_CONF | 0x04 | 1:0 | GPIO_MODE | 10 | R/W | GPIO1 mode: 01b: digital input 10b: digital output low power 11b: digital output high power (default: digital output low power) | | | | | | 7:3 | GPIO_SELECT[4:0] | 00001 | | GPIO0 configuration (default: power-on reset signal) | | | | | | 2 | Reserved | 0 | | | | | | GPIO0_CONF | 0x05 | 1:0 | GPIO_MODE | 10 | R/W | GPIO0 mode: 00b: analog 01b: digital input 10b: digital output low power 11b: digital output high power (default: digital output low power) | | | | | 0x06 | | | 7 | EN_MCU_CLK | 0 | | 1: The internal divider logic is running, so the MCU clock is available (but proper GPIO configuration is needed) | | MCU_CK_CONF | | 6:5 | CLOCK_TAIL[1:0] | 0 | R/W | Number of extra clock cycles provided to the MCU before switching to STANDBY state: 00: 0 extra clock cycle 01: 64 extra clock cycles 10: 256 extra clock cycles 11: 512 extra clock cycles | | | | | | 4:1 | XO_RATIO[3:0] | 0 | | Divider for the XO clock output | | | | | | | 0 | RCO_RATIO | 0 | | Divider for the RCO clock<br>output<br>0: 1<br>1: 1/128 | | | | | 7:4 | Reserved | 0010 | | | | | | XO_RCO_TEST | 0xB4 | 3 | PD_CLKDIV | 0 | | 1: disable both dividers of the digital clock (and reference clock for the SMPS) and IF-ADC clock. | | | | | | 2:0 | Reserved | 001 | | | | | Table 41. General configuration registers (continued) | Register | Address | Bit | Field name | Reset | R/W | Description | |-----------------|---------|-----|---------------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------| | SYNTH_CONFIG[0] | 0x9F | 7 | SEL_TSPLIT | 0 | R/W | 0: split time: 1.75 ns<br>1: split time: 3.47 ns | | | | 6:0 | Reserved | 0100000 | | | | | | 7 | REFDIV | 0 | | Enable division by 2 on the reference clock: 0: f <sub>REF</sub> = f <sub>XO</sub> frequency 1: f <sub>REF</sub> = f <sub>XO</sub> frequency / 2 | | SYNTH_CONFIG[1] | 0x9E | 6:3 | Reserved | 1011 | R/W | | | | | 2 | VCO_L_SEL | 0 | | 1: enable VCO_L | | | | 1 | VCO_H_SEL | 1 | | 1: enable VCO_H | | | | 0 | Reserved | 1 | | | | IF_OFFSET_ANA | 0x07 | 7:0 | IF_OFFSET_ANA | 0xA3 | R/W | Intermediate frequency setting for the analog RF synthesizer. (see Section 9.4) | Table 42. Radio configuration registers (analog blocks) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|-------------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 7:5 | WCP[2:0] | 000 | | Set the charge pump current according to the VCO frequency. See <i>Table 26</i> . | | SYNT3 | 0x08 | 4:0 | SYNT[25:21] | 01100 | R/W | SYNT[25:21], highest 5 bits of<br>the PLL programmable divider<br>The valid range depends on<br>$f_{XO}$ and REFDIV settings; for<br>$f_{XO}$ =26MHz. See <i>Equation 3</i> | | SYNT2 | 0x09 | 7:0 | SYNT[20:13] | 0x84 | R/W | SYNT[20:13], intermediate bits of the PLL programmable divider. See <i>Equation 3</i> | | SYNT1 | 0x0A | 7:0 | SYNT[12:5] | 0xEC | R/W | SYNT[12:5], intermediate bits of the PLL programmable divider. See <i>Equation 3</i> | Table 42. Radio configuration registers (analog blocks) (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | | |---------------|---------|-----|-----------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | 7:3 | SYNT[4:0] | 01010 | R/W | SYNT[4:0], lowest bits of the PLL programmable divider. See <i>Equation 3</i> | | | SYNT0 | 0x0B | 2:0 | BS | 001 | R/W | Synthesizer band select. This parameter selects the out-of-loop divide factor of the synthesizer (B in <i>Equation 3</i> ). 1: 6 Band select factor for high band 3: 12 Band select factor for middle band 4: 16 Band select factor for low band 5: 32 Band select factor for very low band | | | CHSPACE | 0x0C | 7:0 | CH_SPACING | 0xFC | R/W | Channel spacing in steps of $f_{XO}/2^{15}$ (~793 for $f_{XO}$ = 26 MHz, ~732 for $f_{XO}$ = 24 MHz). | | | IF_OFFSET_DIG | 0x0D | 7:0 | IF_OFFSET_DIG | 0xA3 | R/W | Intermediate frequency setting for the digital shift-to-baseband (see Section 9.4) | | | FC_OFFSET[1] | 0x0E | 7:4 | Reserved | 0 | R/W | Carrier offset in steps of f <sub>XO</sub> /2 <sup>18</sup> | | | 10_011021[1] | OXOL | 3:0 | FC_OFFSET[11:8] | 0 | 1000 | and represented as 12 bits 2-<br>complement integer. It is added | | | FC_OFFSET[0] | 0x0F | 7:0 | FC_OFFSET[7:0] | 0 | R/W | / subtracted to the carrier frequency set by the SYNTx register. This register can be used to set a fixed correction value obtained e.g. from crystal measurements. | | | | | 7 | Reserved | 0 | | Output power level for 8 <sup>th</sup> slot | | | PA_POWER[8] | 0x10 | 6:0 | PA_LEVEL_7 | 000001<br>1 | R/W | (+12 dBm) | | | | | 7 | Reserved | 0 | | Output power level for 7 <sup>th</sup> slot | | | PA_POWER[7] | 0x11 | 6:0 | PA_LEVEL_6 | 000111<br>0 | R/W | (+6 dBm) | | | | | 7 | Reserved | 0 | | Output power level for 6 <sup>th</sup> slot | | | PA_POWER[6] | 0x12 | 6:0 | PA_LEVEL_5 | 001101<br>0 | R/W | (0 dBm) | | | | | 7 | Reserved | 0 | | Output power level for 5th alat ( | | | PA_POWER[5] | 0x13 | 6:0 | PA_LEVEL_4 | 010010<br>1 | R/W | Output power level for 5 <sup>th</sup> slot (6 dBm) | | | | | 7 | Reserved | 0 | | Output power level for 4 <sup>th</sup> slot (- | | | PA_POWER[4] | 0x14 | 6:0 | PA_LEVEL_3 | 011010<br>1 | R/W | 12 dBm) | | Table 42. Radio configuration registers (analog blocks) (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|-----------------------------|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------| | | | 7 | Reserved | 0 | | Output power level for 3 <sup>rd</sup> slot | | PA_POWER[3] | 0x15 | 6:0 | PA_LEVEL_2 | 100000<br>0 | R/W | (-18 dBm) | | | | 7 | Reserved | 0 | | Output power level for 2 <sup>nd</sup> slot | | PA_POWER[2] | 0x16 | 6:0 | PA_LEVEL_1 | 100111<br>0 | R/W | (-24 dBm) | | | | 7 | Reserved | 0 | | Output nower level for first slot | | PA_POWER[1] | 0x17 | 6:0 | PA_LEVEL_0 | 000000 | R/W | Output power level for first slot (-30 dBm) | | PA_POWER[0] | 0x18 | 7:6 | CWC[1:0] | 00 | R/W | Output stage additional load capacitors bank (to be used to optimize the PA for different sub-bands): 00: 0 pF 01: 1.2 pF 10: 2.4 pF 11: 3.6 pF | | | | 5 | PA_RAMP_ENABLE | 0 | | 1: enable the power ramping | | | | 4:3 | PA_RAMP_STEP_W<br>IDTH[1:0] | 00 | | Step width (unit: 1/8 of bit period) | | | | 2:0 | PA_LEVEL_MAX_IN<br>DEX | 111 | | Final level for power ramping or selected output power index. | Table 43. Radio configuration registers (digital blocks) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|---------------|-------|-----|------------------------------------------------------------------------| | MOD1 | 0x1A | 7:0 | DATARATE_M | 0x83 | R/W | The mantissa value of the data rate equation (see <i>Equation 11</i> ) | | | | 7 | CW | 0 | | 1: enable the CW transmit mode | | | | 6 | BT_SEL | 0 | R/W | Select BT value for GFSK<br>0: BT = 1<br>1: BT = 0.5 | | MOD0 | 0x1B | 5:4 | MOD_TYPE[1:0] | 01 | | Modulation type 0: 2-FSK 1: GFSK 2: ASK/OOK 3: MSK | | | | 3:0 | DATARATE_E | 1010 | | The exponent value of the data rate equation (see Equation 11) | Table 43. Radio configuration registers (digital blocks) (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|-----------------------------|-------|---------|---------------------------------------------------------------------------------------------| | | | 7:4 | FDEV_E[3:0] | 0100 | | The exponent value of the frequency deviation equation (see <i>Equation 10</i> ) | | FDEV0 | 0x1C | 3 | CLOCK_REC_ALGO<br>_SEL | 0 | R/W | Select PLL or DLL mode for symbol timing recovery | | | | 2:0 | FDEV_M | 101 | | The mantissa value of the frequency deviation equation (see <i>Equation 10</i> ) | | CHFLT | 0x1D | 7:4 | CHFLT_M[3:0] | 0010 | R/W | The mantissa value of the channel filter according to Table 32 | | CHILI | OXID | 3:0 | CHFLT_E | 0011 | - IV/VV | The exponent value of the channel filter according to Table 32 | | | 0x1E | 7 | AFC_FREEZE_ON_<br>SYNC | 0 | R/W | 1: enable the freeze AFC correction upon sync word detection | | .= | | 6 | AFC_ENABLE | 1 | | 1: enable AFC(see Section 8.8: AFC) | | AFC2 | | 5 | AFC_MODE | 0 | | Select AFC mode: 0: AFC loop closed on slicer 1: AFC loop closed on second conversion stage | | | | 4:0 | AFC_PD_LEAKAGE | 01000 | | Peak detector leakage | | AFC1 | 0x1F | 7:0 | AFC_FAST_PERIOD | 0x18 | R/W | Length of the AFC fast period | | AFC0 | 0x20 | 7:4 | AFC_FAST_GAIN_L<br>OG2[3:0] | 0010 | R/W | AFC loop gain in fast mode (log2) | | AFGU | 0,20 | 3:0 | AFC_SLOW_GAIN_L<br>OG2 | 0101 | IN/VV | AFC loop gain in slow mode (log2) | | | | 7:4 | RSSI_FLT[3:0] | 1110 | R/W | Gain of the RSSI filter | | RSSI_FLT | 0x21 | 3:2 | CS_MODE | 00 | | Carrier sense mode (see Section 9.10.2) | | | | 1:0 | OOK_PEAK_DECAY | 11 | | Peak decay control for OOK: 3 slow decay; 0 fast decay | | RSSI_TH | 0x22 | 7:0 | RSSI_THRESHOLD | 0x24 | R/W | Signal detect threshold in 0.5 dB steps, -120 dBm corresponds to 0x14. (see Section 9.10.1) | Table 43. Radio configuration registers (digital blocks) (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |-----------------|---------|-----|-------------------------|-------------|-------|-------------------------------------------------------------------------------------------------| | | | 7:5 | CLK_REC_P_GAIN[<br>2:0] | 2 | | Clock recovery loop gain (log2) | | CLOCKREC | 0x23 | 4 | PSTFLT_LEN | 1 | R/W | Post-filter: 0: 8 symbols, 1: 16 symbols | | | | 3:0 | CLK_REC_I_GAIN | 8 | | Integral gain for the clock recovery loop (used in PLL mode) | | AGCCTRL2 | 0x24 | 7:4 | Reserved | 0010 | R/W | | | AGCCTRLZ | 0.7.2.4 | 3:0 | MEAS_TIME | 0010 | IN VV | Measure time | | AGCCTRL1 | 0x25 | 7:4 | THRESHOLD_HIGH[ 3:0] | 0110 | R/W | High threshold for the AGC | | | | 3:0 | THRESHOLD_LOW | 0101 | | Low threshold for the AGC | | | | 7 | AGC ENABLE | 1 | | 1: enable AGC. | | AGCCTRL0 | 0x26 | 6:0 | Reserved | 000101<br>0 | R/W | | | | | 7:5 | Reserved | 000 | | | | ANT_SELECT_CONF | 0x27 | 4 | CS_BLANKING | 0 | R/W | 1: do not fill the RX FIFO with<br>the data received if the signal is<br>below the CS threshold | | | | 3 | AS_ENABLE | 0 | | 1: enable antenna switching | | | | 2:0 | AS_MEAS_TIME | 101 | | Measurement time | Table 44. Packet/protocol configuration registers | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|------------------|-------|-----|----------------------------------------------------------| | | | 7:5 | Reserved | 000 | | | | PCKTCTRL4 | 0x30 | 4:3 | ADDRESS_LEN[1:0] | 00 | R/W | Length of address field in bytes: 0 or 1: Basic 2: STack | | | | 2:0 | CONTROL_LEN | 000 | | Length of control field in bytes | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----|-----------------------|-------|-----|-------------------------------------------------------------------------------------------------------------------------| | | | 7:6 | PCKT_FRMT[1:0] | 00 | | Format of packet. 0: basic, 2: WM-Bus, 3: STack (see Section 9.7) | | PCKTCTRL3 | 0x31 | 5:4 | RX_MODE[1:0] | 00 | R/W | RX mode: 0: normal mode, 1: direct through FIFO, 2: direct through GPIO | | | | 3:0 | LEN_WID | 0111 | | Size in number of binary digit of length field | | | | 7:3 | PREAMBLE_LENGTH[4 :0] | 00011 | | Length of preamble field in bytes (from 1 to 32) | | | | 2:1 | SYNC_LENGTH[1:0] | 11 | | Length of sync field in bytes (from 1 to 4) | | PCKTCTRL2 | 0x32 | 0 | FIX_VAR_LEN | 0 | R/W | Packet length mode. 0: fixed, 1: variable (in variable mode the field LEN_WID of PCKTCTRL3 register must be configured) | | | | 7:5 | CRC_MODE[2:0] | 001 | | CRC:<br>0: No CRC,<br>1: 0x07,<br>2: 0x8005,<br>3: 0x1021,<br>4: 0x864CBF | | | | 4 | WHIT_EN[0] | 0 | | 1: enable the whitening mode on the data (see Section 9.6.3) | | PCKTCTRL1 | 0x33 | 3:2 | TXSOURCE[1:0] | 00 | R/W | TX source data: 0: normal mode, 1: direct through FIFO, 2: direct through GPIO, 3: PN9 | | | | 1 | Reserved | 0 | | | | | | 0 | FEC_EN | 0 | | 1: enable the FEC encoding in TX or enable the Viterbi decoding in RX (see Section 9.6.1) | | PCKTLEN1 | 0x34 | 7:0 | PCKTLEN1 | 0 | R/W | Length of packet in bytes (MSB) | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------------|---------|-----|-------------------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | PCKTLEN0 | 0x35 | 7:0 | PCKTLEN0 | 0x14 | R/W | Length of packet in bytes (LSB) | | SYNC4 | 0x36 | 7:0 | SYNC4 | 0x88 | R/W | Sync word 4 | | SYNC3 | 0x37 | 7:0 | SYNC3 | 0x88 | R/W | Sync word 3 | | SYNC2 | 0x38 | 7:0 | SYNC2 | 0x88 | R/W | Sync word 2 | | SYNC1 | 0x39 | 7:0 | SYNC1 | 0x88 | R/W | Sync word 1 | | | | 7:6 | SQI_TH[1:0] | 00 | | SQI threshold (see Section 9.10.4) | | QI | 0x3A | 5:2 | PQI_TH[3:0] | 0000 | R/W | PQI threshold (see Section 9.10.3) | | | | 1 | SQI_EN[0] | 1 | | 1: enable SQI | | | | 0 | PQI_EN[0] | 0 | | 1: enable PQI | | MBUS_PRMBL | 0x3B | 7:0 | MBUS_PRMBL[7:0] | 0x20 | R/W | MBUS preamble length in chip sequence '01' | | MBUS_PSTMBL | 0x3C | 7:0 | MBUS_PSTMBL[7:0] | 0x20 | R/W | MBUS postamble length in chip sequence '01' | | | 0x3D | 7:4 | Reserved | 00000 | | | | MBUS_CTRL | | 3:1 | MBUS_SUBMODE[2:0] | 000 | R/W | MBUS sub mode: allowed values are 0, 1, 3 and 5 WM-BUS sub mode: 0: S1 S2 long header, 1: S1m S2 T2 other to meter, 3: T1 T2 meter to other, 5: R2 short header | | | | 0 | Reserved | 0 | | | | | | 7 | Reserved | 0 | R/W | | | FIFO_CONFIG[3] | 0x3E | 6:0 | RXAFTHR [6:0] | 110000 | R/W | FIFO almost full threshold for RX FIFO | | | | 7 | Reserved | 0 | R/W | | | FIFO_CONFIG[2] | 0x3F | 6:0 | RXAETHR [6:0] | 110000 | R/W | FIFO almost empty threshold for RX FIFO | | | | 7 | Reserved | 0 | R/W | | | FIFO_CONFIG[1] | 0x40 | 6:0 | TXAFTHR [6:0] | 110000 | R/W | FIFO almost full threshold for TX FIFO | | | | 7 | Reserved | 0 | R/W | | | FIFO_CONFIG[0] | 0x41 | 6:0 | TXAETHR [6:0] | 110000 | R/W | FIFO almost empty threshold for TX FIFO | | PCKT_FLT_GOALS[1<br>2] | 0x42 | 7:0 | CONTROLO_MASK | 0 | R/W | For received packet only: all 0s: no filtering on control field | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------------|---------|-----|----------------|-------|-----|-----------------------------------------------------------------| | PCKT_FLT_GOALS[1<br>1] | 0x43 | 7:0 | CONTROL1_MASK | 0 | R/W | For received packet only: all 0s: no filtering on control field | | PCKT_FLT_GOALS[1<br>0] | 0x44 | 7:0 | CONTROL2_MASK | 0 | R/W | For received packet only: all 0s: no filtering on control field | | PCKT_FLT_GOALS[9] | 0x45 | 7:0 | CONTROL3_MASK | 0 | R/W | For received packet only: all 0s: no filtering on control field | | PCKT_FLT_GOALS[8] | 0x46 | 7:0 | CONTROL0_FIELD | 0 | R/W | Control field (byte 3) to be used as reference for receiver | | PCKT_FLT_GOALS[7] | 0x47 | 7:0 | CONTROL1_FIELD | 0 | R/W | Control field (byte 2) to be used as reference for receiver | | PCKT_FLT_GOALS[6] | 0x48 | 7:0 | CONTROL2_FIELD | 0 | R/W | Control field (byte 1) to be used as reference for receiver | | PCKT_FLT_GOALS[5] | 0x49 | 7:0 | CONTROL3_FIELD | 0 | R/W | Control field (byte 0) to be used as reference for receiver | | PCKT_FLT_GOALS[4] | 0x4A | 7:0 | RX_SOURCE_MASK | 0 | R/W | For received packet only: all 0s: no filtering | | PCKT_FLT_GOALS[3] | 0x4B | 7:0 | RX_SOURCE_ADDR | 0 | R/W | RX packet source / TX packet destination fields | | PCKT_FLT_GOALS[2] | 0x4C | 7:0 | BROADCAST | 0 | R/W | Broadcast address | | PCKT_FLT_GOALS[1] | 0x4D | 7:0 | MULTICAST | 0 | R/W | Multicast address | | PCKT_FLT_GOALS[0] | 0x4E | 7:0 | TX_SOURCE_ADDR | 0 | R/W | TX packet source / RX packet destination fields | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------|---------|-----------|------------------------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 7 | Reserved | 0 | | | | | | 6 | RX_TIMEOUT_AND_O<br>R_SELECT | 1 | | 1: 'OR' logical function<br>applied to CS/SQI/PQI values<br>(masked by 7:5 bits in<br>PROTOCOL register:<br>CS_TIMEOUT_MASK,<br>SQI_TIMEOUT_MASK,<br>PQI_TIMEOUT_MASK) | | | | 5 | CONTROL_FILTERING | 1 | | RX packet accepted if its control fields match with masked CONTROLx_FIELD registers | | PCKT_FLT_OPTIONS | 0x4F | 4 | SOURCE_FILTERING | 1 | R/W | 1: RX packet accepted if its source field matches with masked RX_SOURCE_ADDR register | | | | 3 | DEST_VS_SOURCE<br>_ADDR | 0 | | 1: RX packet accepted if its destination address matches with TX_SOURCE_ADDR reg. | | | | 2 | DEST_VS_MULTICAST<br>_ADDR | 0 | | RX packet accepted if its destination address matches with MULTICAST register | | | | 1 | DEST_VS_<br>BROADCAST_ADDR | 0 | | 1: RX packet accepted if its destination address matches with BROADCAST reg. | | | | 0 | CRC_CHECK | 0 | | 1: packet discarded if CRC not valid. | | | | 23 | CS_TIMEOUT_MASK | 0 | | 1: CS value contributes to timeout disabling | | | | 22 | SQI_TIMEOUT_MASK | 0 | | 1: SQI value contributes to timeout disabling | | | | 21 | PQI_TIMEOUT_MASK | 0 | | 1: PQI value contributes to timeout disabling | | PROTOCOL[2] | 0x50 | 20:1<br>9 | TX_SEQ_NUM_RELOA<br>D[1:0] | 0 | R/W | TX sequence number to be used when counting reset is required using the related command. | | | | 18 | RCO_CALIBRATION | 0 | | 1: enable the automatic RCO calibration | | | | 17 | VCO_CALIBRATION | 1 | | 1: enable the automatic VCO calibration | | | | 16 | LDC_MODE | 0 | | 1: LDC mode on | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |---------------|---------|-----------|-------------------------------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 15 | LDC_RELOAD_ON_SY<br>NC | 0 | | 1: LDC timer is reloaded with<br>the value stored in the<br>LDC_RELOAD registers | | | | 14 | PIGGYBACKING | 0 | | 1: PIGGYBACKING enabled | | | | 13:1<br>2 | Reserved | 00 | | | | PROTOCOL[1] | 0x51 | 11 | SEED_RELOAD | 0 | R/W | 1: reload the back-off random<br>generator seed using the<br>value written in the<br>BU_COUNTER_SEED_MSB<br>YTE / LSBYTE registers | | | | 10 | CSMA_ON | 0 | | 1: CSMA channel access mode enabled | | | | 9 | CSMA_PERS_ON | 0 | | 1: CSMA persistent (no back-<br>off) enabled | | | | 8 | AUTO_PCKT_FLT | 0 | | 1: automatic packet filtering mode enabled | | | 0x52 | 7:4 | NMAX_RETX[3:0] | 0 | | Max. number of re-TX (from 0 to 15). 0: re-transmission is not performed | | | | 3 | NACK_TX | 1 | | 1: field NO_ACK=1 on transmitted packet | | PROTOCOL[0] | | 2 | AUTO_ACK | 0 | R/W | 1: automatic acknowledgement after correct packet reception | | | | 1 | PERS_RX | 0 | | 1: persistent reception enabled | | | | 0 PERS_TX | PERS_TX | 0 | | 1: persistent transmission enabled | | TIMERS[5] | 0x53 | 47:4<br>0 | RX_TIMEOUT_PRESC<br>ALER[7:0] | 1 | R/W | Prescaler value of the RX<br>TIMEOUT timer. When this<br>timer expires the SPIRIT1<br>exits RX state. Can be<br>controlled using the quality<br>indicator (SQI, PQI, CS). | | TIMERS[4] | 0x54 | 39:3<br>2 | RX_TIMEOUT_COUNT<br>ER[7:0] | 0 | R/W | Counter value of the RX<br>TIMEOUT timer. When this<br>timer expires the SPIRIT1<br>exits RX state. Can be<br>controlled using the quality<br>indicator (SQI, PQI, CS) | 94/104 Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |-------------------|---------|-----------|-------------------------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIMERS[3] | 0x55 | 31:2<br>4 | LDC_PRESCALER[7:0] | 1 | R/W | Prescaler value of the LDC wake-up timer. When this timer expires the SPIRIT1 exits SLEEP state. | | TIMERS[2] | 0x56 | 23:1<br>6 | LDC_COUNTER[7:0] | 0 | R/W | Counter value of the LDC wake-up timer. When this timer expires the SPIRIT1 exits SLEEP state. | | TIMERS[1] | 0x57 | 15:8 | LDC_RELOAD_PRESC<br>ALER[7:0] | 1 | R/W | Prescaler value of the LDC reload timer. When this timer expires the SPIRIT1 exits SLEEP state. The reload timer value is used if the SYNC word is detected (by the receiver) or if the LDC_RELOAD command is used. | | TIMERS[0] | 0x58 | 7:0 | LDC_RELOAD_COUNT<br>ER[7:0] | 0 | R/W | Counter part of the LDC reload value timer. When this timer expires the SPIRIT1 exits SLEEP state. The reload timer value is used if the SYNC word is detected (by the receiver) or if the LDC_RELOAD command is used. | | CSMA_CONFIG[3] | 0x64 | 7:0 | BU_COUNTER_SEED_<br>MSBYTE | 0xFF | R/W | The MSB value of the counter of the seed of the random number generator used to apply the BBE algorithm during the CSMA algorithm | | CSMA_CONFIG[2] | 0x65 | 7:0 | BU_COUNTER_SEED_<br>LSBYTE | 0 | R/W | The LSB value of the counter seed of the random number generator used to apply the BBE algorithm during the CSMA algorithm | | | | 7:2 | BU_PRESCALER[5:0] | 00000 | | The prescaler value used to program the back-off unit BU | | CSMA_CONFIG[1] 0: | 0x66 | 1:0 | CCA_PERIOD | 00 | R/W | Used to program the $T_{cca}$ time (64 / 128 / 256 / 512 × $T_{bit}$ ) | | | | 7:4 | CCA_LENGTH[3:0] | 0000 | | Used to program the T <sub>listen</sub> time | | CSMA_CONFIG[0] | 0x67 | 3 | Reserved | 0 | R/W | | | | | 2:0 | NBACKOFF_MAX | 000 | | Max. number of back-off cycles | Table 44. Packet/protocol configuration registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------|---------|-----|----------------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TX_CTRL_FIELD[3] | 0x68 | 7:0 | TX_CTRL3 | 0 | R/W | Control field value to be used in TX packet as byte n.3 | | TX_CTRL_FIELD[2] | 0x69 | 7:0 | TX_CTRL2 | 0 | R/W | Control field value to be used in TX packet as byte n.2 | | TX_CTRL_FIELD[1] | 0x6A | 7:0 | TX_CTRL1 | 0 | R/W | Control field value to be used in TX packet as byte n.1 | | TX_CTRL_FIELD[0] | 0x6B | 7:0 | TX_CTRL0 | 0 | R/W | Control field value to be used in TX packet as byte n.0 | | | | 7 | Reserved | 0 | | | | | | 6 | EN_TS_BUFFER | 0 | | 1: temperature sensor output is buffered | | PM_CONFIG[2] | 0xA4 | 5 | DISABLE_SMPS | 0 | R/W | 0: enable internal SMPS<br>1: disable internal SMPS | | | | 4 | Reserved | 0 | | | | | | 3 | SET_SMPS_VTUNE | 1 | | Sets the SMPS Vtune voltage | | | | 2 | SET_SMPS_PLLBW | 1 | | Sets the SMPS bandwidth | | | | 1:0 | Reserved | 00 | | | | PM_CONFIG[1] | 0xA5 | 7 | EN_RM | 0 | R/W | 0: divider by 4 enabled (SMPS' switching frequency is F <sub>SW</sub> =FOSC/4) 1: rate multiplier enabled (SMPS' switching frequency is F <sub>SW</sub> =KRM*FOSC/(2^15) | | | | 6:0 | KRM[14:8] | 01000<br>00 | | Sets the divider ration of the rate multiplier. | | PM_CONFIG[0] | 0xA6 | 7:0 | KRM[7:0] | 0 | R/W | rate multiplier. | | | | 7:4 | Reserved | 1110 | | | | XO_RCO_CONFIG | 0xA7 | 3 | EXT_RCOSC | 0 | R/W | 1: the 34.7kHz signal must be supplied from a GPIO pin | | | | 2:0 | Reserved | 001 | | | | TEST_SELECT | 0xA8 | 7:0 | Reserved | 0x00 | R/W | | | PM_TEST | 0xB2 | 7:0 | Reserved | 0x42 | 17/7/ | | Table 45. Frequently used registers | Register name | Address | Bit | Field Name | Reset | R/W | Description | |-------------------|---------|-----|------------------------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CHNUM | 0x6C | 7:0 | CH_NUM | 0 | R/W | Channel number. This value is multiplied by the channel spacing and added to the synthesizer base frequency to generate the actual RF carrier frequency. See <i>Equation 3</i> | | VCO_CONFIG | 0xA1 | 7:6 | Reserved | 00 | R/W | | | V00_00N10 | UXAT | 5:0 | VCO_GEN_CURR | 010001 | 10,00 | Set the VCO current | | RCO_VCO_CALIBR_IN | 0x6D | 7:4 | RWT_IN[3:0] | 0111 | R/W | RWT word value for the RCO | | [2] | OXOD | 3:0 | RFB_IN[4:1] | 0000 | 1000 | RFB word value for the RCO | | RCO_VCO_CALIBR_IN | | 7 | RFB_IN[0] | 0 | | THE WORLD VALUE FOR THE FREE | | [1] | 0x6E | 6:0 | VCO_CALIBR_TX[6:<br>0] | 100100<br>0 | R/W | Word value for the VCO to be used in TX mode | | RCO_VCO_CALIBR_IN | | 7 | Reserved | 0 | | | | [0] | 0x6F | 6:0 | VCO_CALIBR_RX[6:<br>0] | 100100<br>0 | R/W | Word value for the VCO to be used in RX mode | | AES_KEY_IN[15] | 0x70 | 7:0 | AES_KEY15 | 0 | R/W | AES engine key input (128 bits) | | AES_KEY_IN[14] | 0x71 | 7:0 | AES_KEY14 | 0 | R/W | AES engine key input (128 bits) | | | | 7:0 | | | | | | AES_KEY_IN[1] | 0x7E | 7:0 | AES_KEY1 | 0 | R/W | AES engine key input (128 bits) | | AES_KEY_IN[0] | 0x7F | 7:0 | AES_KEY0 | 0 | R/W | AES engine key input (128 bits) | | AES_DATA_IN[15] | 0x80 | 7:0 | AES_IN15 | 0 | R/W | AES engine data input (128 bits) | | AES_DATA_IN[14] | 0x81 | 7:0 | AES_IN14 | 0 | R/W | AES engine data input (128 bits) | | | | | | | | | | AES_DATA_IN[1] | 0x8E | 7:0 | AES_IN1 | 0 | R/W | AES engine data input (128 bits) | | AES_DATA_IN[0] | 0x8F | 7:0 | AES_IN0 | 0 | R/W | AES engine data input (128 bits) | | IRQ_MASK[3] | 0x90 | 7:0 | INT_MASKT[31:24] | 0 | R/W | The IRQ mask register to route the IRQ information to a GPIO. See <i>Table 36</i> . | | IRQ_MASK[2] | 0x91 | 7:0 | INT_MASK [23:16] | 0 | R/W | The IRQ mask register to route the IRQ information to a GPIO. See <i>Table 36</i> . | Table 45. Frequently used registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |----------------|---------|-----|----------------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRQ_MASK[1] | 0x92 | 7:0 | INT_MASK[15:8] | 0 | R/W | The IRQ mask register to route the IRQ information to a GPIO. See <i>Table 36</i> . | | IRQ_MASK[0] | 0x93 | 7:0 | INT_MASK [7:0] | 0 | R/W | The IRQ mask register to route the IRQ information to a GPIO. See <i>Table 36</i> . | | | | 7:2 | Reserved | 001101 | | Reserved do not modify | | DEM_CONFIG | 0xA3 | 1 | DEM_ORDER | 1 | R/W | Set it to 0 during radio initialization | | | | 0 | Reserved | 1 | | Reserved do not modify | | | | 7 | Reserved | 0 | | | | PM_CONFIG | 0xA4 | 6 | EN_TS_BUFFER | 0 | R/W | 1: temperature sensor output is buffered | | | | 5 | DISABLE_SMPS | 0 | | 0: enable internal SMPS<br>1: disable internal SMPS | | | | 7:4 | Reserved | 0101 | | | | | | 3 | ANT_SELECT | 0 | | Currently selected antenna | | MC_STATE[1] | 0xC0 | 2 | TX_FIFO_FULL | 0 | R | 1: TX FIFO is full | | | | 1 | RX_FIFO_EMPTY | 0 | | 1: RX FIFO is empty | | | | 0 | ERROR_LOCK | 0 | | 1: RCO calibrator error | | MC_STATE[0] | 0xC1 | 7:1 | STATE[6:0] | 0 | R | Current MC state. See <i>Table 20</i> . | | | | 0 | XO_ON | 0 | | 1: XO is operating | | | | 7:6 | Reserved | 0 | | | | | | 5:4 | TX_SEQ_NUM | 0 | | Current TX packet sequence number | | TX_PCKT_INFO | 0xC2 | 3:0 | N_RETX | 0 | R | Number of transmission done at the end of a TX sequence. The value is updated at the Max. number of retransmission reached or at the reception of an ACK packet. | | | | 7:3 | Reserved | 0 | | | | RX_PCKT_INFO | 0xC3 | 2 | NACK_RX | 0 | R | NACK field of the received packet | | | | 1:0 | RX_SEQ_NUM | 0 | | Sequence number of the received packet | | AFC_CORR | 0xC4 | 7:0 | AFC_CORR[7:0] | 0 | R | AFC word of the received packet | | LINK_QUALIF[2] | 0xC5 | 7:0 | PQI[7:0] | 0 | R | PQI value of the received packet | 98/104 Table 45. Frequently used registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------|---------|-----|--------------|-------|-----|----------------------------------------------------------------------| | | | 7 | CS | 0 | | Carrier sense indication | | LINK_QUALIF[1] | 0xC6 | 6:0 | SQI[6:0] | 0 | R | SQI value of the received packet | | | | 7:4 | Reserved | 0 | | | | LINK_QUALIF[0] | 0xC7 | 3:0 | AGC_WORD | 0 | R | AGC word of the received packet | | RSSI_LEVEL | 0xC8 | 7:0 | RSSI_LEVEL | 0 | R | RSSI level of the received packet | | RX_PCKT_LEN[1] | 0xC9 | 7:0 | RX_PCKT_LEN1 | 0 | R | Length (number of bytes) of | | RX_PCKT_LEN[0] | 0xCA | 7:0 | RX_PCKT_LEN0 | 0 | R | the received packet: RX_PCKT_LEN=RX_PCKT_L EN1 × 256 + RX_PCKT_LEN0 | | CRC_FIELD[2] | 0xCB | 7:0 | CRC2 | 0 | R | CRC field of the received packet, byte 2 | | CRC_FIELD[1] | 0xCC | 7:0 | CRC1 | 0 | R | CRC field of the received packet, byte 1 | | CRC_FIELD[0] | 0xCD | 7:0 | CRC0 | 0 | R | CRC field of the received packet, byte 0 | | RX_CTRL_FIELD[3] | 0xCE | 7:0 | RX_CTRL0 | 0 | R | Control field(s) of the received packet, byte 0 | | RX_CTRL_FIELD[2] | 0xCF | 7:0 | RX_CTRL1 | 0 | R | Control field(s) of the received packet, byte 1 | | RX_CTRL_FIELD[1] | 0xD0 | 7:0 | RX_CTRL2 | 0 | R | Control field(s) of the received packet, byte 2 | | RX_CTRL_FIELD[0] | 0xD1 | 7:0 | RX_CTRL3 | 0 | R | Control field(s) of the received packet, byte 3 | | RX_ADDR_FIELD[1] | 0xD2 | 7:0 | ADDR1 | 0 | R | Source address field of the RX packet. | | RX_ADDR_FIELD[0] | 0xD3 | 7:0 | ADDR0 | 0 | R | Destination address field of the RX packet. | | AES_DATA_OUT[15] | 0xD4 | 7:0 | AES_OUT15 | 0 | R | AES engine data output (128 bits) | | AES_DATA_OUT[14] | 0xD5 | 7:0 | AES_OUT14 | 0 | R | AES engine data output (128 bits) | | | | | | | | | | AES_DATA_OUT[1] | 0xE2 | 7:0 | AES_OUT1 | 0 | R | AES engine data output (128 bits) | | AES_ DATA_OUT[0] | 0xE3 | 7:0 | AES_OUT0 | 0 | R | AES engine data output (128 bits) | Table 45. Frequently used registers (continued) | Register name | Address | Bit | Field Name | Reset | R/W | Description | |------------------------|---------|-----|------------------|-------|-----|---------------------------------------------------------------| | RCO_VCO_CALIBR_O | 0xE4 | 7:4 | RWT_OUT[3:0] | 0 | R | RWT word from internal RCO calibrator | | UT[1] | 0XL4 | 3:0 | RFB_OUT[4:1] | 0 | X | RFB word from internal RCO calibrator | | RCO VCO CALIBR O | | 7 | RFB_OUT[0] | 0 | | | | UT[0] | 0xE5 | 6:0 | VCO_CALIBR_DATA | 0 | R | Output word from internal VCO calibrator | | | | 7 | Reserved | 0 | | | | LINEAR_FIFO_STATUS [1] | 0xE6 | 6:0 | ELEM_TXFIFO | 0 | R | Number of elements in the linear TX FIFO (from 0 to 96 bytes) | | | | 7 | Reserved | 0 | | | | LINEAR_FIFO_STATUS [0] | 0xE7 | 6:0 | ELEM_RXFIFO | 0 | R | Number of elements in the linear RX FIFO (from 0 to 96 bytes) | | IRQ_STATUS[3] | 0xFA | 7:0 | INT_EVENT[31:24] | 0 | RR | The IRQ status register. See <i>Table 36</i> . | | IRQ_STATUS[2] | 0xFB | 7:0 | INT_EVENT[23:16] | 0 | RR | The IRQ status register. See <i>Table 36</i> . | | IRQ_STATUS[1] | 0xFC | 7:0 | INT_EVENT[15:8] | 0 | RR | The IRQ status register. See <i>Table 36</i> . | | IRQ_STATUS[0] | 0xFD | 7:0 | INT_EVENT[7:0] | 0 | RR | The IRQ status register. See <i>Table 36</i> . | #### Table 46. General information | Register | Address | Bit | Field name | Reset | R/W | Description | |------------------|---------|-----|--------------|-------|-----|-----------------------| | DEVICE INFO[1:0] | 0xF0 | 7:0 | PARTNUM[7:0] | 0x01 | R | Device part number | | DEVICE_INFO[1.0] | 0xF1 | 7:0 | VERSION[7:0] | 0x30 | R | Device version number | # 12 Package mechanical data In order to meet environmental requirements, ST offers these devices in different grades of ECOPACK® packages, depending on their level of environmental compliance. ECOPACK specifications, grade definitions, and product status are available at: <a href="www.st.com">www.st.com</a>. ECOPACK is an ST trademark. Table 47. QFN20 (4 x 4 mm.) mechanical data | Dim. | mm. | | | | | | | | | |--------|------|------|------|--|--|--|--|--|--| | Diiii. | Min. | Тур. | Max. | | | | | | | | Α | 0.80 | 0.90 | 1.00 | | | | | | | | A1 | | 0.02 | 0.05 | | | | | | | | A2 | | 0.65 | 1.00 | | | | | | | | A3 | | 0.25 | | | | | | | | | b | 0.18 | 0.23 | 0.30 | | | | | | | | D | 3.85 | 4.00 | 4.15 | | | | | | | | D2 | 2.55 | 2.60 | 2.65 | | | | | | | | E | 3.85 | 4.00 | 4.15 | | | | | | | | E2 | 2.55 | 2.60 | 2.65 | | | | | | | | е | 0.45 | 0.50 | 0.55 | | | | | | | | L | 0.35 | 0.55 | 0.75 | | | | | | | | ddd | | | 0.08 | | | | | | | Figure 17. QFN20 (4 x 4 mm.) drawing dimension SPIRIT1 Revision history # 13 Revision history Table 48. Document revision history | Date | Revision | Changes | |-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 06-Feb-2012 | 1 | Initial release. | | 26-Apr-2012 | 2 | Update RF performance figures in the whole document. Changed pinout for pin 11. Minor text changes. | | 05-Oct-2012 | 3 | Updated tables 4, 8, 11, 13, 20, 13, 23, 34, 40, 41, 44 and 45. Updated Section 9.4: Intermediate frequency setting and Section 12: Package mechanical data. Minor text changes to improve readability. Document status changed from preliminary to production data. | | 13-Feb-2013 | 4 | Updated tables 7, 8, 12, 13, 13, 19, 41, 42, and 45. Updated Section 3.1, Section 6.2.1, Section 7.4 and Section 9.7.5 Inserted Table 9: Power consumption static modes, Figure 3: Application diagram for Tx boost mode, Figure 4: Application diagram for SMPS OFF mode, Section 7.3: Low duty cycle reload mode Section 9.10.1: RSSI and Table 3. Added Section 8.1.1: Switching frequency. Minor text changes to improve readability. | | 06-May-2013 | 5 | Updated tables 3 and 4. Inserted new Section 8.7 and Section 8.9. Minor text changes. | | 11-Feb-2015 | 6 | Updated Features in cover page, Section 7.2: Timer usage, Section 7.3: Low duty cycle reload mode, Table 7: Recommended operating conditions, Table 13: RF receiver characteristics - sensitivity, added Table footnote "3" to Table 20: States, Section 9.1 and Section 9.8. | | 27-May-2015 | 7 | Updated: Chapter 6.2.5: Crystal oscillator, Chapter 8.5: Oscillator and RF synthesizer, and Table 37: Digital outputs. | | 25-Jun-2015 | 8 | Minor text change to improve readability. | | 15-Dec-2015 | 9 | Updated: Features in cover page: removed LQI feature, Section 3.1: Typical application diagram, Section 8.5: Oscillator and RF synthesizer, Section 8.8: AFC, Section 9.7.1: STack packet | | 07-Oct-2016 | 10 | Added footnote in Table 12: RF receiver characteristics. | #### **IMPORTANT NOTICE - PLEASE READ CAREFULLY** STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2016 STMicroelectronics - All rights reserved