# MCR20A 2.4 GHz Low-Power Transceiver Reference Manual

Supports: MCR20AVHM

Document Number: MCR20ARM Rev. 3, July 2016



### Contents

### Section number

Title

Page

#### Chapter 1 Introduction to MCR20A

| 1.1  | Introduction                                             | 13 |
|------|----------------------------------------------------------|----|
| 1.2  | Block Diagram                                            | 14 |
| 1.3  | Modem Features Summary                                   | 15 |
| 1.4  | RF Interface and Usage                                   | 17 |
| 1.5  | Radio Architecture                                       | 17 |
|      | 1.5.1 Packet Structure                                   | 17 |
|      | 1.5.2 Receive Path Description                           | 17 |
|      | 1.5.3 Transmit Path Description                          | 18 |
| 1.6  | IEEE 802.15.4 Acceleration Hardware                      | 18 |
| 1.7  | Advanced Security Module (ASM) Overview                  | 19 |
| 1.8  | MCU Interface with SPI Overview                          | 20 |
|      | 1.8.1 Transceiver Control Overview                       | 21 |
| 1.9  | Clock Output, RF Control, and GPIO Summary               | 22 |
|      | 1.9.1 CLK_OUT Reference                                  | 22 |
|      | 1.9.2 RF Control Signals                                 | 22 |
|      | 1.9.3 Antenna Diversity                                  | 23 |
|      | 1.9.4 General Purpose Input Output (GPIO)                | 23 |
| 1.10 | Modem Operational Modes                                  | 23 |
| 1.11 | External PA and LNA                                      | 24 |
|      | Chapter 2<br>Signal Multiplexing and Signal Descriptions |    |
| 2.1  | Pin assignments                                          | 25 |
| 2.2  | Pin function table                                       | 26 |

#### Chapter 3 System Considerations

| Section number |        | number Title                                                 | Page |
|----------------|--------|--------------------------------------------------------------|------|
| 3.2            | Power  | Connections                                                  |      |
| 3.3            | Moder  | n Reset                                                      |      |
| 3.4            | Moder  | n Interrupt Request to MCU                                   |      |
| 3.5            | MCR2   | 20A Transceiver Interface to MCU                             |      |
|                | 3.5.1  | SPI Command Channel                                          |      |
| 3.6            | System | n Oscillator and Clock Considerations                        |      |
|                | 3.6.1  | Modem Crystal Oscillator                                     |      |
|                | 3.6.2  | System Clock Configurations                                  |      |
|                | 3.6.3  | Single System Crystal with CLK_OUT driving MCU crystal input |      |
| 3.7            | Moder  | n GPIO Characteristics                                       |      |
| 3.8            | MCR2   | 20A Digital Signal Properties Summary                        |      |
| 3.9            | Transc | eiver RF Configurations and External Connections             |      |
|                | 3.9.1  | RF Interface Pins                                            |      |
|                | 3.9.2  | RF Output Power Distribution                                 |      |
|                | 3.9.3  | LQI ED RSSI                                                  |      |
| 3.10           | Timer  | Resources                                                    |      |
|                | 3.10.1 | Modem Event Timer                                            |      |
| 3.11           | Low P  | Power Considerations                                         | 46   |
|                | 3.11.1 | Low-Power Preamble Search (LPPS)                             |      |
|                | 3.11.2 | Recovery Times from Low Power Modes                          |      |
|                | 3.11.3 | Run Time Current                                             |      |
|                |        | Chapter 4<br>Modem: Modes of Operation                       |      |
| 4.1            | Power  | Management Overview                                          |      |

|     | 4.1.1 | Features                      | 52  |
|-----|-------|-------------------------------|-----|
|     | 4.1.2 | Power and Regulation Topology | .52 |
|     | 4.1.3 | Digital Regulator and POR     | 53  |
|     | 4.1.4 | Analog Regulator (AREG)       | .53 |
| 4.2 | Moden | n Operational Modes Summary   | .54 |

|     | 4.2.1  | Power modes                                   |    |
|-----|--------|-----------------------------------------------|----|
| 4.3 | Seque  | nce Manager                                   |    |
|     | 4.3.1  | Modem Sequence Manager Operation              |    |
|     | 4.3.2  | Functional Description                        |    |
| 4.4 | Dual I | PAN ID introduction                           |    |
|     | 4.4.1  | Manual and Automatic Modes                    |    |
|     | 4.4.2  | Source Address Matching                       | 75 |
|     | 4.4.3  | Programming interface                         | 76 |
| 4.5 | Active | e Promiscuous Mode                            | 79 |
|     | 4.5.1  | Functional Description                        | 79 |
|     | 4.5.2  | Special Handling for Broadcast Packets        |    |
|     | 4.5.3  | Special Handling of Rx Acknowledgement Frames |    |
|     | 4.5.4  | Programming Interface                         |    |
| 4.6 | Clock  | System                                        |    |
|     | 4.6.1  | 32 MHz Crystal Oscillator                     |    |
|     | 4.6.2  | Clock output feature overview                 |    |
|     |        | Chapter 5<br>Modem: Advanced Security Module  |    |
| 5.1 | Advar  | nced Security Module                          |    |
| 5.2 | Introd | uction                                        |    |

Title

| 5.2 | muouu |                        |      |  |
|-----|-------|------------------------|------|--|
|     | 5.2.1 | Features               | 83   |  |
|     | 5.2.2 | Modes of Operation     | 83   |  |
|     | 5.2.3 | CTR mode block diagram | 84   |  |
|     | 5.2.4 | CBC mode block diagram | .85  |  |
|     | 5.2.5 | CCM mode               | . 85 |  |
|     | 5.2.6 | AES mode               | 85   |  |
| 5.3 | ASM n | nodule block diagram   | .86  |  |
|     | 5.3.1 | ASM Register Interface | 86   |  |
|     | 5.3.2 | AES Encryption Engine  | 87   |  |
|     |       |                        |      |  |

### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

Section number

Page

|     | 5.3.3  | ASM Logic                               | .87  |
|-----|--------|-----------------------------------------|------|
|     | 5.3.4  | AES encryption engine algorithm         | .88  |
| 5.4 | Counte | er mode encryption                      | .89  |
| 5.5 | AES n  | node encryption                         | . 89 |
| 5.6 | Messa  | ge Authentication Code generation (MAC) | .90  |

Title

#### Chapter 6 Modem: Interrupts

| Introdu | iction                                                                                                                                    | 91                                           |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| Modem   | ı Interrupt Sources                                                                                                                       | . 91                                         |
| Additic | onal Interrupt Mask and Source Descriptions                                                                                               | . 93                                         |
| Functio | onal Description                                                                                                                          | 94                                           |
| 6.4.1   | Interrupt Status Bit Structure                                                                                                            | . 94                                         |
| 6.4.2   | Clearing Interrupts                                                                                                                       | . 95                                         |
| 6.4.3   | Timer Interrupts                                                                                                                          | . 95                                         |
| 6.4.4   | PLL Unlock Interrupt                                                                                                                      | 96                                           |
| 6.4.5   | Filterfail Interrupt                                                                                                                      | 96                                           |
| 6.4.6   | RX Watermark Interrupt                                                                                                                    | 97                                           |
| 6.4.7   | CCA Interrupt                                                                                                                             | . 97                                         |
| 6.4.8   | RX Interrupt                                                                                                                              | 98                                           |
| 6.4.9   | TX Interrupt                                                                                                                              | . 98                                         |
| 6.4.10  | Sequencer Interrupt                                                                                                                       | 98                                           |
| 6.4.11  | Interrupts from Exiting Low Power Modes                                                                                                   | 99                                           |
| 6.4.12  | Packet Buffer Error Interrupt                                                                                                             | 100                                          |
|         | Moden<br>Additio<br>Functio<br>6.4.1<br>6.4.2<br>6.4.3<br>6.4.3<br>6.4.4<br>6.4.5<br>6.4.6<br>6.4.7<br>6.4.8<br>6.4.9<br>6.4.10<br>6.4.11 | <ul> <li>6.4.2 Clearing Interrupts</li></ul> |

### Chapter 7 Modem: Timer Information

| 7.1 | Event Timer Block     | 101 |
|-----|-----------------------|-----|
| 7.2 | Event Timer Time Base | 101 |
| 7.3 | Setting Current Time  | 102 |
| 7.4 | Reading Current Time  | 103 |

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

Page

Section number

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

### Section number

7.5

7.6

7.7

| Latchi | ng the Timestamp                                            |     |
|--------|-------------------------------------------------------------|-----|
| Event  | Timer Comparators                                           |     |
| 7.6.1  | Timer Compare Fields                                        | 104 |
| 7.6.2  | Timer Compare-Enable Bits                                   |     |
| 7.6.3  | Timer Interrupt Status Bits                                 |     |
| 7.6.4  | Timer Interrupt Masks                                       | 105 |
| 7.6.5  | Setting Compare Values                                      |     |
| Intend | ed Event Timer Usage                                        | 106 |
| 7.7.1  | Generating Time-Based Interrupts                            |     |
| 7.7.2  | Using T3CMP to Abort an RX operation                        | 107 |
| 7.7.3  | Using T2CMP or T2PRIMECMP to Trigger Transceiver Operations |     |

Title

### Chapter 8 Modem SPI Interface

| 8.1 | Moden   | n SPI Overview                               | .111 |
|-----|---------|----------------------------------------------|------|
| 8.2 | Moden   | n SPI Basic Operation                        | 111  |
|     | 8.2.1   | SPI Pin Definition                           | 112  |
|     | 8.2.2   | SPI Timing                                   | 113  |
| 8.3 | SPI Tra | ansactions                                   | 114  |
|     | 8.3.1   | SPI Control Word                             | .114 |
|     | 8.3.2   | Direct Register Write Access (single byte)   | 115  |
|     | 8.3.3   | Direct Register Read Access (single byte)    | .115 |
|     | 8.3.4   | Direct Register Write Access (multi byte)    | 116  |
|     | 8.3.5   | Direct Register Read Access (multi byte)     | 116  |
|     | 8.3.6   | Indirect Register Write Access (multi byte)  | 117  |
|     | 8.3.7   | Indirect Register Read Access (multi byte)   | 118  |
|     | 8.3.8   | Synchronous and Asynchronous Operating Modes | 118  |
|     | 8.3.9   | Shifting Out IRQSTS1 During Control Word     | 119  |
|     | 8.3.10  | Packet Buffer                                | .120 |
| 8.4 | Config  | uring MCU for Proper SPI Operation           | .128 |

### Page

| Sec | ction r | number Title                                           | Page |
|-----|---------|--------------------------------------------------------|------|
|     | 8.4.1   | DSPI Mode Configuration                                |      |
|     | 8.4.2   | DSPI Baud Rate                                         |      |
|     | 8.4.3   | DSPI Timing Control                                    |      |
|     |         | Chapter 9<br>Modem: SPI Register Description           | S    |
| 9.1 | Introdu | uction                                                 |      |
| 9.2 | Moder   | m Memory map and register definition                   |      |
|     | 9.2.1   | Interrupt Request Status 1 (Modem_IRQSTS1)             |      |
|     | 9.2.2   | Interrupt Request Status 2 (Modem_IRQSTS2)             |      |
|     | 9.2.3   | Interrupt Request Status 3 (Modem_IRQSTS3)             |      |
|     | 9.2.4   | PHY Control 1 (Modem_PHY_CTRL1)                        |      |
|     | 9.2.5   | PHY Control 2 (Modem_PHY_CTRL2)                        |      |
|     | 9.2.6   | PHY Control 3 (Modem_PHY_CTRL3)                        |      |
|     | 9.2.7   | Receive Frame Length (Modem_RX_FRM_LEN)                |      |
|     | 9.2.8   | PHY Control 4 (Modem_PHY_CTRL4)                        |      |
|     | 9.2.9   | SRC Control (Modem_SRC_CTRL)                           |      |
|     | 9.2.10  | SRC Address SUM LSB (Modem_SRC_ADDRS_SUM_LSB)          |      |
|     | 9.2.11  | SRC Address SUM MSB (Modem_SRC_ADDRS_SUM_MSB)          |      |
|     | 9.2.12  | CCA1 ED FNL (Modem_CCA1_ED_FNL)                        |      |
|     | 9.2.13  | Event Timer LSB (Modem_EVENT_TIMER_LSB)                |      |
|     | 9.2.14  | Event Timer MSB (Modem_EVENT_TIMER_MSB)                |      |
|     | 9.2.15  | Event Timer USB (Modem_EVENT_TIMER_USB)                |      |
|     | 9.2.16  | Timestamp LSB (Modem_TIMESTAMP_LSB)                    |      |
|     | 9.2.17  | Timestamp MSB (Modem_TIMESTAMP_MSB)                    |      |
|     | 9.2.18  | Timestamp USB (Modem_TIMESTAMP_USB)                    |      |
|     | 9.2.19  | Timer 3 Compare Value LSB (Modem_T3CMP_LSB)            |      |
|     | 9.2.20  | Timer 3 Compare Value MSB (Modem_T3CMP_MSB)            |      |
|     | 9.2.21  | Timer 3 Compare Value USB (Modem_T3CMP_USB)            |      |
|     | 9.2.22  | Timer 2-Prime Compare Value LSB (Modem_T2PRIMECMP_LSB) |      |

### Section number

### Title

### Page

|     | 9.2.23  | Timer 2-Prime Compare Value MSB (Modem_T2PRIMECMP_MSB)        | .150  |
|-----|---------|---------------------------------------------------------------|-------|
|     | 9.2.24  | Timer 1 Compare Value LSB (Modem_T1CMP_LSB)                   | . 150 |
|     | 9.2.25  | Timer 1 Compare Value MSB (Modem_T1CMP_MSB)                   | .151  |
|     | 9.2.26  | Timer 1 Compare Value USB (Modem_T1CMP_USB)                   | . 151 |
|     | 9.2.27  | Timer 2 Compare Value LSB (Modem_T2CMP_LSB)                   | . 151 |
|     | 9.2.28  | Timer 2 Compare Value MSB (Modem_T2CMP_MSB)                   | .152  |
|     | 9.2.29  | Timer 2 Compare Value USB (Modem_T2CMP_USB)                   | . 152 |
|     | 9.2.30  | Timer 4 Compare Value LSB (Modem_T4CMP_LSB)                   | . 152 |
|     | 9.2.31  | Timer 4 Compare Value MSB (Modem_T4CMP_MSB)                   | .153  |
|     | 9.2.32  | Timer 4 Compare Value USB (Modem_T4CMP_USB)                   | . 153 |
|     | 9.2.33  | PLL Integer Value for PAN0 (Modem_PLL_INT0)                   | . 153 |
|     | 9.2.34  | PLL Frequency Fractional Value for PAN0 (Modem_PLL_FRAC0_LSB) | . 154 |
|     | 9.2.35  | PLL Frequency Fractional Value for PAN0 (Modem_PLL_FRAC0_MSB) | . 154 |
|     | 9.2.36  | PA Power Control (Modem_PA_PWR) (Modem_PA_PWR)                | 155   |
|     | 9.2.37  | Sequence Manager State (Modem_SEQ_STATE)                      | . 155 |
|     | 9.2.38  | Link Quality Indicator (Modem_LQI_VALUE)                      | 155   |
|     | 9.2.39  | RSSI CCA CNT (Modem_RSSI_CCA_CNT)                             | . 156 |
|     | 9.2.40  | ASM Control 1 (Modem_ASM_CTRL1)                               | .156  |
|     | 9.2.41  | ASM Control 2 (Modem_ASM_CTRL2)                               | .157  |
|     | 9.2.42  | ASM Data (Modem_ASM_DATA <i>n</i> )                           | .158  |
|     | 9.2.43  | Overwrite Version Number (Modem_OVERWRITE_VER)                | . 158 |
|     | 9.2.44  | CLK_OUT Control (Modem_CLK_OUT_CTRL)                          | .159  |
|     | 9.2.45  | Power Modes (Modem_PWR_MODES)                                 | . 160 |
|     | 9.2.46  | IAR Index (Modem_IAR_INDEX)                                   | . 161 |
|     | 9.2.47  | IAR Data (Modem_IAR_DATA)                                     | . 162 |
| 9.3 | Indirec | t registers memory map and register definition                | . 162 |
|     | 9.3.1   | Part Identification (Indirect_Modem_PART_ID)                  | .165  |
|     | 9.3.2   | XTAL 32 MHz Trim (Indirect_Modem_XTAL_TRIM)                   | .165  |
|     | 9.3.3   | MAC PAN ID for PAN0 (Indirect_Modem_MACPANID0n)               | .166  |

### Section number

### Title

### Page

| 9.3.4  | MAC Short Address for PAN0 (Indirect_Modem_MACSHORTADDRS0n)                           | 166 |
|--------|---------------------------------------------------------------------------------------|-----|
| 9.3.5  | MAC Long Address for PAN0 (Indirect_Modem_MACLONGADDRS0n)                             | 167 |
| 9.3.6  | Receive Frame Filter (Indirect_Modem_RX_FRAME_FILTER)                                 | 167 |
| 9.3.7  | Frequency Integer for PAN1 (Indirect_Modem_PLL_INT1)                                  | 168 |
| 9.3.8  | Frequency Fractional Value for PAN1 (Indirect_Modem_PLL_FRAC1n)                       | 169 |
| 9.3.9  | Frequency Fractional Value for PAN1 (Indirect_Modem_MACPANID1n)                       | 169 |
| 9.3.10 | MAC Short Address for PAN1 (Indirect_Modem_MACSHORTADDRS1n)                           | 170 |
| 9.3.11 | MAC Long Address for PAN1 (Indirect_Modem_MACLONGADDRS1n)                             | 170 |
| 9.3.12 | Dual PAN Control (Indirect_Modem_DUAL_PAN_CTRL)                                       | 171 |
| 9.3.13 | Channel Frequency Dwell Time (Indirect_Modem_DUAL_PAN_DWELL)                          | 172 |
| 9.3.14 | Dual PAN Status (Indirect_Modem_DUAL_PAN_STS)                                         | 172 |
| 9.3.15 | Clear Channel Assessment 1 Threshold (Indirect_Modem_CCA1_THRESH)                     | 173 |
| 9.3.16 | Clear Channel Assessment / ED Offset Computation (Indirect_Modem_CCA1_ED_OFFSET_COMP) | 174 |
| 9.3.17 | LQI Offset Computation (Indirect_Modem_LQI_OFFSET_COMP)                               | 174 |
| 9.3.18 | CCA Control (Indirect_Modem_CCA_CTRL)                                                 | 174 |
| 9.3.19 | Clear Channel Assessment 2 Threshold Peak Compare (Indirect_Modem_CCA2_CORR_PEAKS)    | 175 |
| 9.3.20 | Clear Channel Assessment 2 Threshold (Indirect_Modem_CCA2_THRESH)                     | 176 |
| 9.3.21 | TMR PRESCALE (Indirect_Modem_TMR_PRESCALE)                                            | 176 |
| 9.3.22 | GPIO Data (Indirect_Modem_GPIO_DATA)                                                  | 177 |
| 9.3.23 | GPIO Direction Control (Indirect_Modem_GPIO_DIR)                                      | 178 |
| 9.3.24 | GPIO Pullup Enable (Indirect_Modem_GPIO_PUL_EN)                                       | 179 |
| 9.3.25 | GPIO Pullup Select (Indirect_Modem_GPIO_SEL)                                          | 181 |
| 9.3.26 | GPIO Drive Strength (Indirect_Modem_GPIO_DS)                                          | 182 |
| 9.3.27 | Antenna Control (Indirect_Modem_ANT_PAD_CTRL)                                         | 183 |
| 9.3.28 | Miscellaneous Pad Control (Indirect_Modem_MISC_PAD_CTRL)                              | 185 |
| 9.3.29 | RX_BYTE_COUNT (Indirect_Modem_RX_BYTE_COUNT)                                          | 185 |
| 9.3.30 | RX_WTR_MARK (Indirect_Modem_RX_WTR_MARK)                                              | 186 |
| 9.3.31 | TXDELAY (Indirect_Modem_TXDELAY)                                                      | 186 |
| 9.3.32 | ACKDELAY (Indirect_Modem_ACKDELAY)                                                    | 187 |

### 

| 9.3.36 | XTAL | Control ( | Indirect_ | Modem_ | _XTAL_ | _CTRL) | 190 |
|--------|------|-----------|-----------|--------|--------|--------|-----|

## Chapter 1 Introduction to MCR20A

### 1.1 Introduction

The MCR20A transceiver is a 2.4 GHz Industrial, Scientific and Medical (ISM) and Medical Body Area Network (MBAN) transceiver intended for the IEEE® 802.15.4 Standard. The MCR20A device is a standalone transceiver that is normally combined with a software stack and a Kinetis K series, M series or other microcontroller (MCU) to implement an IEEE 802.15.4 Standard platform solution.

The MCR20A transceiver contains a complete 802.15.4 physical layer (PHY) modem designed for the IEEE® 802.15.4 Standard that operates in the 2.4 GHz ISM frequency band and supports 2.36 to 2.4 GHz Medical Band (MBAN) frequencies. The transceiver includes antenna diversity, 1mW nominal output power, hardware acceleration for dual PAN modes, integrated transmit/receive switch, on-board power supply regulation, and full spread-spectrum encoding and decoding. Additionally, the transceiver includes a PA with internal voltage controlled oscillator (VCO), integrated transmit/receive switch, on-board power supply regulation.

The MCR20A transceiver supports peer-to-peer, star, and mesh networking and when combined with an appropriate MCU, the MCR20A transceiver provides a cost-effective solution for short-range data links and networks. Interface with the MCU is accomplished using a four wire serial peripheral interface (SPI) connection and an interrupt request output that allows for the use of a variety of processors. The software and processor can be scaled to fit applications ranging from simple point-to-point systems through complete mesh networking. The MCR20A transceiver provides the IEEE 802.15.4 Standard PHY/MAC for use with the Kinetis K20 or Cortex M0 family of MCUs.

This table lists the MCR20A device ordering, temperature range, and package information.

#### **Block Diagram**

| Table 1-1. | Ordering | Information |
|------------|----------|-------------|
|------------|----------|-------------|

| Device       | Operating Temp Range<br>(TA) | Package                    |
|--------------|------------------------------|----------------------------|
| MCR20AVHM(R) | -40° to 105° C               | MLGA-32 (R: tape and reel) |

Target markets include, but are not limited, to the following:

- Smart Energy
  - Meter
  - ESI (Energy Service Interface)
  - IHD (In Home Display)
  - Gateway
  - Appliance
  - PHEV (Plug-in Hybrid Electric Vehicle)
- Building Control and Home Automation
  - Lighting
  - HVAC
  - Security
- Medical / Personal Health Care
  - Patient Monitoring
  - Institutional Care
- Industrial Control (3rd party stacks (Low PAN, ISA100, Wireless HART)

## 1.2 Block Diagram

This figure shows a simplified block diagram of the MCR20A transceiver, which is an 802.15.4 Standard compatible transceiver that provides functions required in the physical layer (PHY) and media access control (MAC) specifications.



Figure 1-1. Modem Simplified Block Diagram

The modem is used in concert with an MCU. Interface between the devices is accomplished through a 4-wire SPI port and interrupt request line. The media access control (MAC), drivers, and network and application software (as required) reside on the host processor.

### **1.3 Modem Features Summary**

The transceiver has the following features:

• Fully compliant IEEE 802.15.4 Standard 2006 transceiver supports 250 kbps O-QPSK data in 5.0 MHz channels and full spread-spectrum encode and decode, and also extends radio operation to the 2.36 GHz to 2.40 GHz Medical Band (MBAN) frequencies with IEEE 802.15.4j channel, spacing and modulation requirements.

#### Modem Features Summary

- 2.4GHz frequency band of operation (ISM).
- 250kbps data rate with O-QPSK modulation in 5.0 MHz channels with direct sequence spread spectrum (DSSS) encode and decode.
- Operates on one of 16 selectable ISM channels per IEEE 802.15.4 specification.
- Programmable output power
- Supports 2.36 GHz to 2.40 GHz Medical Band (MBAN) frequencies with IEEE 802.15.4j channel, spacing and modulation requirements.
- Small RF foot print
  - Differential input/output port used with external balun for single port operation.
  - Supports antenna diversity operation with external front end (FE).
  - Low external component count.
- Hardware acceleration for IEEE® 802.15.4 Standard
  - Complete 802.15.4 onboard modem
  - IEEE 802.15.4 Standard 2006 packet processor/sequencer with receiver frame filtering
  - Random number generator
  - Support for dual PAN ID mode
  - Internal event timer block with four comparators to assist sequencer and provide timer capability
- 32 MHz crystal reference oscillator with onboard trim capability to supplement external load capacitors
- Programmable frequency clock output (CLK\_OUT) for use by MCU
- SPI Command Channel interface slave port with burst mode operation
- Interrupt request output (IRQ) provides interrupt request capability to MCU
- 128-byte RAM data buffer to store 802.15.4 packet contents for transceiver sequences
- Eight (8) software programmable GPIOs
- Low power operational modes with single SPI command device wake-up (SPI communication is enabled in LP mode)

- 1.8 V to 3.6 V operating voltage with on chip voltage regulators
- -40C to +105C temperature range
- RoHS compliant, 5 mm x 5 mm, 32-pin, MLGA package

## 1.4 RF Interface and Usage

The modem RF interface provides a bidirectional, differential port that connects directly to a balun. The balun connects directly to a single-ended antenna and converts that interface to a fully differential, bidirectional, on-chip interface with transmit/receive switch, LNA, and complementary PA outputs. This combination allows for a small footprint and low cost RF solution.

In additional the modem provides dedicated output signals that can be used to control external RF components. These outputs are hardware switched and also support antenna diversity.

## 1.5 Radio Architecture

The radio structure is built upon the IEEE 802.15.4 Standard packet structure.

### 1.5.1 Packet Structure

The following figure shows the packet structure.

| 4 bytes  | 1 byte | 1 byte | 125 bytes maximum | 2 bytes |
|----------|--------|--------|-------------------|---------|
| Preamble | SFD    | FLI    | Payload Data      | FCS     |

Figure 1-2. MCR20A Transceiver Packet Structure

### 1.5.2 Receive Path Description

The receive path operates in duplex with the transmit mode having an additional feature to operate in a low power run state that can also be considered as a partial power down mode. Architecture is Near Zero IF (NZIF) having front end amplification, one (1) mixed

signal down conversion to IF that is filtered, demodulated and digitally processed. The RF Front End (FE) is differential and shares the same off chip matching network with the transmit path.

### 1.5.3 Transmit Path Description

The modem transmits OQPSK modulation having power and channel selection adjustment per user application. After the channel of operation is determined, coarse and fine tuning is executed within the Frac-N PLL to engage signal lock. After signal lock is established, the modulated buffered signal is then routed to a multi-stage amplifier for transmission. The PA differential outputs share the pins with the front end.

## 1.6 IEEE 802.15.4 Acceleration Hardware

The 802.15.4 transceiver has several hardware features that reduce the software stack size, off-load functions from the CPU, and improve performance:

- Fully supports 2003 & 2006 versions of the IEEE 802.15 Standard.
- Supports slotted and unslotted modes
- Supports beacon enabled and non-beacon enabled networks
- Onboard 128-byte packet data buffering
- Random number generator
- 802.15.4 Sequence support
  - RX (conditionally followed by TXAck)
  - TX
  - CCA (used for CCA and ED cycles)
  - Tx/Rx (Tx followed by unconditional Rx or RCACK)
  - Continuous CCA
- 802.15.4 Receiver Frame filtering.

### 1.7 Advanced Security Module (ASM) Overview

The ASM engine encrypts using the Advanced Encryption Standard (AES). It can perform "Counter" (CTR), Cipher Block Chaining (CBC) and plain AES mode encryption. The combination of CTR and CBC modes of encryption is known as CCM mode encryption. CCM is short for Counter with CBC-MAC. CCM is a generic authenticate and encrypt block cipher mode. CCM is only defined for use with 128 bit block ciphers, such as AES.

The ASM has the following features:

- CTR encryption in 11 bus clock cycles.
- CBC encryption in 11 bus clock cycles
- AES encryption in 11 bus clock cycles.
- Encrypts 128 bits as a unit.

The ASM is designed to be loaded with data and then started with a self-clearing "start" bit. Sixteen 8 bit registers of a key plus sixteen 8 bit registers of a counter plus sixteen 8 bit registers of text are necessary for "Counter" mode encryption. Cipher Block Chaining (CBC) mode needs only a key field and a text field programmed. Typically, only the text fields and counter fields need to be continuously written since the key field won't change.

The module has a built in self test that must be initiated by the software to make the module usable. Until this test is run and passes the ASM module is disabled.

A simple block diagram of the ASM module is shown in the following figure.



Figure 1-3. ASM Block Diagram

## **1.8 MCU Interface with SPI Overview**

The following figure illustrates the microcontroller interface with the modem for the SiP. The typical required signals are:

- 4-wire SPI port slave mode only
  - Maximum bitrate is 16 MHz for writes and 9 MHz for reads
  - Clock phase and polarity CPHA=0 and CPOL=0
  - MSB first shifting
  - Supports Register Access and Packet Buffer accesses in bursts of byte transfers
  - Most registers and Packet Buffer accessible with crystal "on" or "off"
- Interrupt request output active low
- Device asynchronous hardware reset RST\_B active low

The SPI interface provides communication between the MCU and the modem's register set and Packet Buffer. The modem SPI is a slave-only interface; the MCU must drive R\_SSEL\_B, R\_SCLK and R\_MOSI. Write and read access to both Direct and Indirect registers is supported, and transfer length can be single-byte or bursts of unlimited length. Write and read access to the Packet buffer can also be single-byte or a burst mode of unlimited length.

The SPI interface is asynchronous to the rest of the device. No relationship between R\_SCLK and the modem's internal oscillator is assumed. All synchronization of the SPI interface to modem takes place inside the SPI module and is done for both register writes and reads.

The SPI is capable of operation in all power modes except reset. Operation in the Hibernate state means radio's crystal oscillator is disabled; effectively no XTAL connected in hibernate mode. Most radio registers, direct and indirect, can be accessed, both read and write, during Hibernate; and includes the complete Packet Buffer. All GPIO-related registers are accessible in Hibernate. In this state minimal power consumption will be realized especially during the register-initialization phase.

The SPI design features a compact, single-byte control word reducing SPI access latency to a minimum. Most SPI access types require only a single-byte control word with the address embedded in the control word. During control word transfer (the first byte of any

SPI access), the contents of the IRQSTS1 register (highest-priority status register) are are always shifted out so that the MCU gets access to IRQSTS1 with the minimum possible latency on every SPI access.



Figure 1-4. Microcontroller to modem interface block diagram

### **1.8.1 Transceiver Control Overview**

The transceiver is controlled by a bank of registers (Direct Register Space) accessed via the SPI interface. The transmit and receive packet data (stored in a 128-byte buffer) is also accessed via the SPI. The onboard registers provide control and status for the entire device.

### 1.8.1.1 Interrupt Request Overview

The modem has up to 13 individual sources of interrupt request to the MCU. These are all capable of individual control, and are logically OR-combined to drive a single, active low, interrupt request pin (IRQ\_B) to the external MCU.

- The IRQ\_B pin is configured as actively-driven high by the modem.
- Each interrupt source has its own interrupt status bit in Direct Register space.
- Each interrupt can be individually controlled by an interrupt mask The IRQ is issued when the mask is cleared to 0.
- There is also a global interrupt mask, TRCV\_MSK, which can enable/disable all IRQ\_B assertions by programming a single masking bit.

- All status bits use a write-1-to-clear protocol interrupt status bits are not affected by reads.
- IRQ\_B will remain asserted until all active interrupt sources are cleared or masked.

### 1.8.1.2 Event Timer Overview

The modem features a 24-bit Event Timer that can be used in conjunction with the sequencer to provide protocol control as well as timing interrupts. The Event Timer consists of a continuously running counter and four (4) separate 24-bit comparators:

- The Event Timer counter runs at the 802.15.4 bit rate of 250 kHz (programmable).
- Each comparator has an individual interrupt request capability the compare status is set when there is a match between the comparator and the timer counter. Each status can be enabled to generate an IRQ.
- In addition, a separate 16-bit T2PRIMECMP comparator is provided, which uses only the *lower 16 bits* of Event Timer, rather than require a full 24-bit compare.

## 1.9 Clock Output, RF Control, and GPIO Summary

The modem provides a set of I/O pins useful for supplying a system clock to the MCU, controlling external RF LNA/PA or antenna diversity circuitry and GPIO. The following sections discuss these options.

## 1.9.1 CLK\_OUT Reference

The CLK\_OUT digital output can be enabled to drive the system clock to the MCU. This provides a highly accurate clock source based on the transceiver reference oscillator. The clock is programmable over a wide range of frequencies divided down from its 32 MHz reference.

### 1.9.2 RF Control Signals

The modem provides four dedicated signals for control of external RF components. These signals designated as ANT\_A, ANT\_B, RX\_SWITCH, and TX\_SWITCH can be enabled to control external amplifiers, antenna switches, and other modules. When enabled they are switched via an internal hardware state machine. Typical uses include:

- Antenna diversity
- External PA
- External LNA
- T/R switching

## 1.9.3 Antenna Diversity

To improve the reliability of RF connectivity to long range applications, Antenna Diversity feature is supported without using the MCU through use of four dedicated control pins by direct register antenna selection. The digital regulator supplies bias to analog switches for control of external PA/LNA. These switches are programmable to sink and source two levels of current (2-3 mA and 10 mA) or can operate in a high impedance mode.

## 1.9.4 General Purpose Input Output (GPIO)

In addition eight (8) GPIO are provided for general use. Features for these pins include:

- Programmable output drive strength
- Programmable output slew rate
- Hi-Z mode
- Programmable as outputs or inputs (default)
- No IRQ capability

## 1.10 Modem Operational Modes

The modem has six operating modes which include:

#### External PA and LNA

- Reset / Power-down
- Low Power (LP) / Hibernate
- Doze (low power with reference oscillator active)
- Idle
- Receive
- Transmit

The following table describes these modes:

| Mode      | Definition                                                                                                          | Transition Time     |
|-----------|---------------------------------------------------------------------------------------------------------------------|---------------------|
| Mode      |                                                                                                                     | To or From Idle     |
| Off       | All modem functions Off, Leakage only. RST asserted. Digital outputs are tri-stated including IRQ                   | 500 µs              |
| Hibernate | Crystal Reference Oscillator Off. Modem responds to SPI activity.                                                   | 250 µs              |
| Doze      | Crystal reference oscillator ON but CLK_OUT output available only if selected. Digital regulator in Low Power mode. | < 1 µs <sup>1</sup> |
| Reset     | Crystal reference oscillator ON, enable CLK_OUT output at 4 MHz and 32.787 kHz.                                     | 376 µs              |
| Receive   | Crystal reference oscillator ON. Receiver ON.                                                                       | 144 µs              |
| Transmit  | Crystal reference oscillator ON. Transmitter ON.                                                                    | 144 µs              |

Table 1-2. Modem Mode Definitions and Transition Times

1. At 9 MHz, the doze to idle transistion time will be less than 2 SPI writes (1.8  $\mu s).$ 

### 1.11 External PA and LNA

The modem supports features to add either an external PA, LNA or RF switch which can extend the range or add antenna diversity to the target application. The following hardware features aid in the configuration of an FEM:

- Four dedicated programmable pins to sink and source 1mA, 2mA, 4mA and 8mA currents to control FEM (Front End Module) features such as a PA, LNA and RF switches for antenna diversity, etc.
- Balun used to optimize performance and provide a differential RX/TX output to single ended feature. Modem RX/TX outputs are differential "I" and "Q" and can be utilized in that format if desired.

## Chapter 2 Signal Multiplexing and Signal Descriptions

### 2.1 Pin assignments

This figure shows the MCR20A transceiver's package pin assignment.



Figure 2-1. Pin assignment

## 2.2 Pin function table

| Pin<br>number | Pin name  | Туре                 | Function           | Description                                                                             |
|---------------|-----------|----------------------|--------------------|-----------------------------------------------------------------------------------------|
| 1             | VDD_RF    | Analog Power Output  | Analog Voltage     | Analog 1.8 Vdc                                                                          |
| 2             | VBAT      | Power Input          | Battery Voltage    | Connect to system VDD supply                                                            |
| 3             | XTAL_32M  | Analog Output        | RF                 | 32 MHz reference oscillator output                                                      |
| 4             | EXTAL_32M | Analog Input         | RF                 | 32 MHz references oscillator input                                                      |
| 5             | GPIO1     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 6             | GPIO2     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 7             | GPIO3     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 8             | GPIO4     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 9             | GPIO5     | Digital Input/Output | General-Purpose IO | GPIO or CLK_OUT default state select                                                    |
| 10            | RST_B     | Digital Input/Output | Digital            | Device asynchronous hardware reset. Active low.                                         |
| 11            | R_MISO    | Digital Input/Output | Digital            | SPI MISO                                                                                |
| 12            | R_MOSI    | Digital Input/Output | Digital            | SPI MOSI                                                                                |
| 13            | R_SCLK    | Digital Input/Output | Digital            | SPI clock                                                                               |
| 14            | R_SSEL_B  | Digital Input/Output | Digital            | SPI slave select                                                                        |
| 15            | IRQ_B     | Digital Input/Output | Digital            | Interrupt command signal                                                                |
| 16            | CLK_OUT   | Digital Output       | RF                 | Programmable clock source                                                               |
| 17            | VDD_REGD  | Digital Power Ref    | Digital Voltage    | Digital 1.8 Vdc ref. Decouple to ground.                                                |
| 18            | VBAT2     | Power Input          | Battery Voltage    | Connect to system VDD supply.                                                           |
| 19            | GPIO6     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 20            | GPIO7     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 21            | GPIO8     | Digital Input/Output | General-Purpose IO | GPIO                                                                                    |
| 22            | DTM0      | _                    | Factory Test       | Do not connect.                                                                         |
| 23            | ANT_A     | Digital Input/Output | Antenna Diversity  | Programmable sink and source<br>current output with selectable high<br>impedance state. |
| 24            | ANT_B     | Digital Input/Output | Antenna Diversity  | Programmable sink and source<br>current output with selectable high<br>impedance state. |
| 25            | RX_SWITCH | Digital Input/Output | Control Switch     | Programmable sink and source current output with selectable high impedance state.       |
| 26            | TX_SWITCH | Digital Input/Output | Control Switch     | Programmable sink and source current output with selectable high impedance state.       |

### Table 2-1. Pin function

Table continues on the next page...

**Chapter 2 Signal Multiplexing and Signal Descriptions** 

| Pin<br>number | Pin name | Туре               | Function       | Description                            |
|---------------|----------|--------------------|----------------|----------------------------------------|
| 27            | VSSA_PA  | —                  | Gnd            | RF ground                              |
| 28            | RF_OUTP  | RFInput/Output     | RF             | Bidirectional RF input/output positive |
| 29            | RF_OUTN  | RFInput/Output     | RF             | Bidirectional RF input/output negative |
| 30            | VSSA_PA2 | —                  | Gnd            | RFground                               |
| 31            | VDD_PA   | Analog Power Input | Analog Voltage | Analog 1.8 Vdc input                   |
| 32            | VDD_IF   | Analog Power Input | Analog Voltage | Analog 1.8 Vdc input                   |
| 33            | GND_RF   | —                  | _              | Connect to RF ground                   |
| 34            | GND_PA   | —                  | _              | Connect to RF ground                   |
| 35            | GND_RF   | —                  | _              | Connect to RF ground                   |
| 36            | _        | Factory test       | Reserved       | Do not connect                         |
| 37            | _        | Factory test       | Reserved       | Do not connect                         |
| 38            | _        | Factory test       | Reserved       | Do not connect                         |
| 39            | —        | Factory test       | Reserved       | Do not connect                         |
| 40            | _        | Factory test       | Reserved       | Do not connect                         |
| 41            | _        | Factory test       | Reserved       | Do not connect                         |

Table 2-1. Pin function (continued)



MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

## Chapter 3 System Considerations

### 3.1 Introduction

Communication to the modem function is through the common SPI bus, the MCU interrupt request, and several MCU GPIO lines. Primary interface with the modem is through the SPI command structure that allows reading/writing modem registers and provides initialization of parameters, reading of status, and control of modem operation. The modem can ask for real time response through the interrupt request structure, and four GPIO signals allow control of the modem reset and monitoring of some real time status.

This chapter presents information addressing application and operation of the node from a system level. The areas considered here are also covered in greater detail in the following sections of the book. The book is organized such that the first three chapters present the top-level view of the MCR20A device and the following chapters present individual functions in detailed descriptions.

## 3.2 Power Connections

The modem power connections are listed in the following table.

| Pin Name | Туре         | Description                                   | Functionality       |
|----------|--------------|-----------------------------------------------|---------------------|
| VDD_RF   | Power Output | Regulator output for RF circuitry             | Decouple to ground. |
| VBAT     | Power Input  | Main voltage supply                           | Decouple to ground. |
| VDD_REGD | Power Output | Regulated output supply for digital circuitry | Decouple to ground  |
| VBAT2    | Power Input  | Main voltage supply                           | Decouple to ground. |
| GND_PA   | Power Input  | PA supply ground                              | Connect to ground   |
| GND_RF   | Power Input  | RF supply ground                              | Connect to ground   |
| VDD_PA   | Power Input  | Regulated supply for PA                       | Decouple to ground  |

Table 3-1. Power Pin Descriptions

Table continues on the next page...

| Pin Name | Туре        | Description             | Functionality      |
|----------|-------------|-------------------------|--------------------|
| VDD_IF   | Power Input | Regulated supply for IF | Decouple to ground |
| VSSA_PA  | Power Input | Common VSS              | Connect to ground  |
| VSSA_PA2 | Power Input | Common VSS              | Connect to ground  |

 Table 3-1.
 Power Pin Descriptions (continued)

When designing power to the device, the following points need to be considered for the modem:

- There are two modem primary power inputs, which include VBAT for analog power and VBAT2 for digital circuitry.
- For logic level compatibility between the modem and the system MCU, VBAT, and VBAT2 must be connected with the MCU to a common source supply of 1.8–3.6 VDC. It is not recommended to supply the MCU below 1.8V.
- VDD\_PA is the supply of the internal power amplifier and is powered by the VDD\_RF regulator output via the analog regulator.
- VDD\_RF and VDD\_IF are provided to allow bypass of the RF and IF circuitry regulated supplies. The decoupling capacitor is in the range of 220 nF and 470 nF as shown in the figure.
- The VDD\_REGD supply is decoupled externally as shown in the figure. The external decoupling capacitor shall be in the range of 220 nF and 470 nF.

Power supply connections for the modem are shown in the following figure.



Figure 3-1. Modem Power Supply Connections

### NOTE

In addition to the capacitor on the VBATs, there are two separate decoupling capacitors, one on VDD\_RF, VDD\_IF, and VDD\_PA that are tied together, and a standalone on VDD\_REGD.

## 3.3 Modem Reset

The modem active low reset input RST\_B is recommended to be driven from an MCU GPIO pin. In the interest of lowest power, there is no external pull-up resistor on input RST\_B. An MCU GPIO programmed as an output typically also has a software controlled pull-up resistor. However, it would normally not be used because the modem can be held in hardware reset by the MCU for extended periods of time. The transceiver IRQ pullup can also be disabled, and having no resistor makes for lowest power applications.

From a power-on or "cold start" condition, the MCU GPIO normally initiates as a highimpedance input with its internal pullup disabled and the IRQ pullup is enabled, which holds the modem reset input high. As part of the MCU initialization, GPIO must be programmed as an output and then driven low to reset the modem. The RST\_B input is asynchronous and needs to be held low for only a short period.

• The MCU software must configure one of its GPIOs as an output and then drive it low to reset the modem.

During the modem reset procedure,

- The MCU software should also configure the I/O port driving GPIO5 to select the default modem CLK\_OUT frequency (GPIO5 high = 32.787 kHz; GPIO5 low = 4 MHz).
- The modem RST\_B input is asynchronous and needs to be held low for only a short period.

In the reset condition, the modem is totally powered down and no clocks are available. After RST\_B is released, the modem will power up, initialize, and go to its idle condition in less than 1 millisecond, and in turn, this causes an IRQ\_B interrupt request and allows CLK\_OUT to start toggling. Coming out of reset, the WAKE\_IRQ interrupt status bit is set and causes the assertion on the IRQ\_B because the wake interrupt source is not masked by default.

Once the interrupt request is seen by the MCU, the MCU can assume the modem is alive and ready for programming via the SPI bus.

## 3.4 Modem Interrupt Request to MCU

The modem interrupt request IRQ\_B is an active low output that is asserted when an interrupt request is pending. The signal is released to high by writing a 1 to all asserted interrupt status bits in the modem status registers via a SPI transaction.

### 3.5 MCR20A Transceiver Interface to MCU

The modem interacts with the host MCU through its SPI interface, interrupt request, and several status and control signals.

### 3.5.1 SPI Command Channel

Primary interface with the modem is through the SPI command structure that allows reading/writing modem registers and provides initialization of parameters, reading of status, and control of modem operation. The modem is a slave only and the MCU SPI must be programmed and used as a master only. Further, the SPI performance is limited by the modem constraints of 8 MHz maximum SPI clock frequency, and use of the MCU SPI must be programmed to meet the modem SPI protocol. The SPI bus connections for a Kinetis K20-512 typically are:

- MCU MOSI output drives modem R\_MOSI.
- Modem R\_MISO output drives MCU MISO.
- MCU SCLK output drives modem R\_SCLK.
- MCU /SELoutput drives modem R\_SSEL\_B.

## 3.6 System Oscillator and Clock Considerations

### 3.6.1 Modem Crystal Oscillator

The modem oscillator source must always be present and an external crystal is used to implement the oscillator. The source frequency must be 32 MHz with a total accuracy of  $\pm 40$  ppm or greater as required by the IEEE 802.15.4 specification.

In this figure, crystal X1 and capacitors C1 and C2 form the modem crystal oscillator circuit. An onboard feedback resistor of approximately 1 MOhm (not shown) between input EXTAL\_32M and output XTAL\_32M provides DC biasing for the oscillator buffer. An important parameter for the 32 MHz crystal X1 is a load capacitance of less than 9 pF. The oscillator needs to see a balanced load capacitance at each terminal of about 18 pF. As a result, the sum of the stray capacitance of the PCB, device pin (EXTAL or XTAL), and load capacitor (C1 or C2) at each terminal must equal about 18 pF. C1 and C2 are typically values of 6-9 pF. Higher values can load the crystal buffer and cause oscillator start-up problems.

The MCR20A transceiver crystal oscillator frequency can be trimmed by programming modem CLK\_OUT\_CTRL register to the corresponding wanted frequency and trim the frequency with the XTAL\_TRIM register. The trimming procedure varies the frequency by a few Hertz per step, depending on the type of crystal. As xtal\_trim[7:0] is increased, the frequency is decreased. This feature is useful for factory calibration of the crystal frequency to set the accuracy for the radio as required by the IEEE 802.15.4 specification.



Figure 3-2. MCR20A Oscillator and External Connections

## 3.6.2 System Clock Configurations

Because of the multiple clock configurations in an MCU and the CLK\_OUT output from the modem, there are a number of variations for system clock configurations. Key considerations for any system clock configuration are:

- The modem 32 MHz source (typically the crystal oscillator) must always be present. The crystal has special requirements and the reference frequency must meet IEEE 802.15.4 requirements
- Battery-operated application requirements for low power can impact the choices for MCU clock source

- The system clock configuration can impact system initialization procedures
- Software requirements can impact MCU processor and bus speed. The user must be aware of the performance requirements for the MCU.

# 3.6.3 Single System Crystal with CLK\_OUT driving MCU crystal input

The single crystal (modem crystal) with CLK\_OUT driving the MCU external clock input is a common configuration for low cost and excellent frequency accuracy. The CLK\_OUT frequency is programmable from 32.786 kHz to 32 MHz and drives the MCU external source.

### Note

For this system option to be usable, the system MCU must have an alternative (typically onboard) start-up clock.

In this configuration, clock start-up from a reset condition involves:

- MCU reset is released and MCU starts on an internal clock
- Initialization software must reset and then release reset to the modem (MCU still running on start-up clock)
- Wait for modem start-up interrupt request (less than 1 ms). CLK\_OUT default is hardware selectable as either 4 MHz or 32.786 kHz defined by the state of modem GPIO5.
- Program CLK\_OUT to a different frequency (if desired) as shown in the table.
- Wait for the CLK\_OUT source to lock, and then switch MCU clock to external source

Additional considerations for this mode of operation include:

- If the modem is forced to the Off condition and CLK\_OUT is killed, there is a 500 µs wait for the modem CLK\_OUT to start from the Off condition after RST is released
- If the MCU puts the modem into Doze mode, keeping the CLK\_OUT alive is a higher power, but available, option
- If an accurate period is required for longer time delays (such as a beacon period), keeping CLK alive for very long periods is an option, but would be a higher power option typically than using a separate crystal for the MCU

## 3.7 Modem GPIO Characteristics

The modem GPIO hardware consists of eight (8) signals total (GPIO1-GPIO8) though only GPIO1-6 are used in the SIP, and only GPIO1-2 are connected directly to SIP package pins. Immediately after reset, each GPIO has either an internal pull-up (GPIO1-5) or pull-down (GPIO6-8) enabled.

### NOTE

To avoid extra current drain from floating input pins, the reset initialization routine in the application program should change the direction of unused pins to outputs (programmed low) so the pins do not float. Outputs programmed low is the preferred option for lowest power.

The functionality of the modem GPIO is controlled by programming of the modem SPI registers via the SPI interface. For information about controlling all these pins as general purpose I/O pins, see SPI Register Descriptions chapter.

## 3.8 MCR20A Digital Signal Properties Summary

This table summarizes digital I/O pin characteristics. These characteristics are determined by the way the common pin interfaces are hard-wired to internal circuits.

| Pin Name      | Dir | Drive<br>Strength | Output Slew <sup>1</sup> | Pullup/<br>Pulldown <sup>2</sup> | Direction                                                                                                                                                                            |
|---------------|-----|-------------------|--------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQ_B         | 0   | SWC               | Ν                        | Ν                                | Actively Driven output by default. Can be configured<br>as Open-drain (see IRQ_B_OD bit). Drive strength<br>controlled by NON_GPIO_DS bit.                                           |
| XTAL_32M      | I   |                   |                          | N                                |                                                                                                                                                                                      |
| EXTAL_32<br>M | 0   |                   |                          | Ν                                |                                                                                                                                                                                      |
| RST_B         | I   |                   |                          | Ν                                | Pin should not be allowed to float. Must be externally actively driven, or externally pulled up to Vbatt via resistor.                                                               |
| CLK_OUT       | 0   | SWC               | SWC                      | Ν                                | Drive strength controlled by CLK_OUT_DS bit. Slew<br>Rate controlled by CLK_OUT_SR bit. Tri-state<br>controlled by CLK_OUT_HIZ bit. Frequency controlled<br>by CLK_OUT_DIV[2:0] bits |
| R_SCLK        | I   |                   |                          | SWC                              | Pullup device controlled by SPI_PUL_EN bit                                                                                                                                           |
| R_MOSI        | I   |                   |                          | SWC                              | Pullup device controlled by SPI_PUL_EN bit                                                                                                                                           |
| R_MISO        | 0   | SWC               | N                        | Ν                                | Drive strength controlled by NON_GPIO_DS bit                                                                                                                                         |
| R_SSEL_B      | I   |                   |                          | SWC                              | Pullup device controlled by SPI_PUL_EN bit                                                                                                                                           |
| GPIO1         | I/O | SWC               | N                        | SWC                              | Drive strength controlled by GPIO_DS[1] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[1] and<br>GPIO_PUL_SEL[1] bits.                                                       |

 Table 3-2.
 MCR20A Digital Signals Properties

Table continues on the next page ...

| Pin Name | Dir | Drive<br>Strength | Output Slew <sup>1</sup> | Pullup/<br>Pulldown <sup>2</sup> | Direction                                                                                                                      |
|----------|-----|-------------------|--------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| GPIO2    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[2] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[2] and<br>GPIO_PUL_SEL[2] bits. |
| GPIO3    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[3] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[3] and<br>GPIO_PUL_SEL[3] bits. |
| GPIO4    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[4] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[4] and<br>GPIO_PUL_SEL[4] bits. |
| GPIO5    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[5] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[5] and<br>GPIO_PUL_SEL[5] bits. |
| GPIO6    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[6] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[6] and<br>GPIO_PUL_SEL[6] bits. |
| GPIO7    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[7] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[7] and<br>GPIO_PUL_SEL[7] bits. |
| GPIO8    | I/O | SWC               | Ν                        | SWC                              | Drive strength controlled by GPIO_DS[8] bit. Pull<br>Enable/Polarity controlled by GPIO_PUL_EN[8] and<br>GPIO_PUL_SEL[8] bits. |

### Table 3-2. MCR20A Digital Signals Properties (continued)

1. Slew Rate Controlled: N=No; SWC=software-controlled

2. Internal pullup/pulldown device: N=No; SWC=software-controlled

## 3.9 Transceiver RF Configurations and External Connections

The MCR20A transceiver radio has features that enable a flexible and low cost RF interface:

- Programmable output power from -35 dBm to +8 dBm. This allows the user to set the power based on their specific applications minimizing current consumption while maximizing battery life.
- -102 dBm (typical) receive sensitivity At 1% PER, 20-byte packet (well above IEEE 802.15.4 specification of -85 dBm).
- Integrated transmit/receive (T/R) switch for low cost operation With internal PAs and LNA, the internal T/R switch allows a minimal part count radio interface using only a single balun to interface to a single-ended antenna.

## 3.9.1 RF Interface Pins

The following figure shows the RF interface pins and the associated analog blocks. The MCR20A radio is a differential transceiver architecture that has two (2) I/Os that support both receive and transmit functionality. Specifically, these I/Os are opposite in phase and will require off-chip matching for optimal performance. Because RF\_OUTP and RF\_OUTN ports are shared and duplexed, matching networks will need to accommodate both modes of operation.



Figure 3-3. RF Interface Pins

### 3.9.1.1 Antenna Diversity

Fast Antenna diversity (FAD) is supported in hardware through use of the four (4) dedicated control pins by register setup and control selection. They are ANT\_A, ANT\_B, RX\_SWITCH, and TX\_SWITCH. These switches, powered by VBAT, are programmable to sink and source two (2) levels of current (2 - 3 mA and 10 mA) or can operate in a high impedance mode. Each I/O will have a buffered feature with adjustable slew rate capability. Unless overridden by software, the last-good-antenna-selection (based on a successful preamble detect), is locked in place for TX sequences, as well as CCA and Energy Detect sequences. The hardware-selected antenna will not change again until the next RX preamble detection.

# 3.9.1.2 Fast Antenna Diversity (FAD)

The following system factors can be considered when configuring FAD for end applications:

#### Transceiver RF Configurations and External Connections

- With Fast Antenna Diversity, sensitivity performance increases the low-end limit of the dynamic range of the system.
- There is little cost of FAD which is essentially enabling the functionality and adding the circuitry for situations where the application runs the possibility of operating at the limits of RX sensitivity.

The next figure shows a simplified block diagram of the two port antenna control topology.



Figure 3-4. FAD control simplified block diagram

FAD Control Register Setup

The following registers allow setup, control and enable of the Fast Antenna Diversity (FAD) feature:

Antenna PAD Control (Indirect Modem\_ANT\_PAD\_CTRL, 0x30): This register sets the action on the pads ANTA, ANTB, RX\_SWITCH and TX\_SWITCH.

Set bit field ANTX\_EN [1:0] to proper selection for end application (default is 0).

- ANTA and ANTB switch signal during the preamble phase of the receive cycle.
- RX\_SWITCH and TX\_SWITCH switch during the receive and transmit cycle respectively.

Miscellaneous Pad Control (Indirect Modem\_MISC\_PAD\_CTRL, 0x31): This register sets the pad drive strength for ANTA, ANTB, RX\_SWITCH and TX\_SWITCH.

Bit[0] = 0 (default) for normal drive strength.

Antenna AGC and FAD Control (Indirect Modem\_ANT\_AGC\_CTRL, 0x51): This register controls the FAD feature.

Enable bit field [0] to 1 - Turns FAD on (default is 0).

The following figure shows the flow and timing diagram from the idle state when the receiver takes either the FAD RX flow or the standard RX flow:



Figure 3-5. FAD flow and timing diagram

### FAD and Packet Timing

Packet timing with FAD enabled with two external antenna's A and B.

During the time period t1 - t0, the antenna's are switching at a rate of 28 µs.

- The circular region shows the timing variation while detecting 1.5 symbol '0's and is a function of system sensitivity level.
- At t1, the 'first' antenna meeting the 1.5 symbol '0' criteria is selected ... 3 more symbol '0's are then detected to complete the preamble search.

Normal packet processing follows a good preamble match

• The preamble period  $t^2 - t^0$  is fixed at 128 µs of the total packet cycle time – if a valid preamble is not found during this period, the receiver will start a new RX cycle.

**Transceiver RF Configurations and External Connections** 



Figure 3-6. FAD preamble and packet timing

The next figure shows a typical FAD control pin design topology



### Figure 3-7. Typical circuitry for a two-antenna external switch design

The following figure shows a simulated out of range antenna scenario when using the isolation through an RF switch to offset the RF signal by 21 dBm. The following sensitivity performance summary explains non-FAD and FAD Enabled Sensitivity Improvement.

**Chapter 3 System Considerations** 



Figure 3-8. Sensitivity FAD mode at 2450 MHz

Sensitivity Performance Summary

Non-FAD mode

- By purposely choosing the bad antenna (out of range RF signal) it can be seen (orange curve) that the sensitivity is shifted to -78 dBm.
- By purposely choosing the good antenna (RF signal in range) it can be seen (blue curve) that the sensitivity is normal.
- The sensitivity delta is due to the isolation characteristics of the external RF switch component. This is the basic limitation of the system. The isolation of the RF switch ports in most cases is between 20-25 dB.

With FAD enabled (purple curve): With one antenna out of range and the other antenna good, the sensitivity is NOW in the normal range (about -99 dBm or better).

- Sensitivity performance is impacted by 1-2 dB in FAD mode vs. an ideally placed antenna but overall PER performance is significantly increased vs. having a single antenna with poor placement.
- Within the dynamic range of the receiver, sensitivity in FAD mode does not impact performance and therefore is not discernible to the user.

#### Transceiver RF Configurations and External Connections

- Outside the dynamic range of the receiver is where FAD will help system performance and will have noticeable improvements to the system.
- Unless overridden by software, the last-good-antenna-selection (based on a successful preamble detect), is locked in place for TX sequences as well as CCA and Energy Detect sequences. The hardware-selected antenna will not change again until the next RX sequence.

## 3.9.2 **RF Output Power Distribution**

The following figure shows the linear region of the output and the typical power distribution of the radio as a function of PA\_PWR [4:0] range. The PA\_PWR [4:0] is the lower 5 bits of the PA\_PWR 0x23 direct register and has a usable range of 3 to 31 decimal.



Figure 3-9. MCR20A transmit power vs. PA\_PWR step

# 3.9.3 LQI ED RSSI

The following figure shows the devices reported Energy Detect (ED) as a function of input power. The figure also shows the Link Quality Indication (LQI)/RSSI\_CONT (continuous) and the RSSI (Received Signal Strength Indication) as a function of a unitless numeric register reading. LQI is available 64 µs after the preamble is detected. RSSI\_CONT can be used to read LQI if a continuous value averaged over the entire received packet is desired. This value may be read as LQI if continuous update of LQI is desired during packet reception (both scaled the same but averaged differently). The curves are measured using the default offset compensation value and can be changed to center the curve if desired.

The following sequeces are performed in test software to create curves in the figure otherwise similar sequences are incorporated into our software stacks:

- For ED, device is configured to perform an ED via write to the register 0x7 with 0x00
  - ED/CCA sequence is started via write to register 0x3 with 0x3
  - Register 0 is polled for bit 3 to be set
  - RSSI\_CONT\_EN bit is disabled in Indirect 0x25 (CCA\_CTRL) all other bits are reset/overwrite values
  - direct register 0x0B is read (CCA Final)
  - direct register 0x25 is read (LQI)
  - indirect register 0x5B is read (RSSI)
  - direct register 0x26 is read (RSSI\_CONT) [not enabled in ED case so ignored]
- For LQI, device is configured to perform an LQI via write to the register 0x7 with 0x00
  - Device is configured to perform an LQI via write to the register 0x7 with 0x00
  - RX sequence is started via write to register 0x3 with 0x1
  - Register 0 is polled for bit 2 to be set
  - RSSI\_CONT\_EN bit is Enabled in Indirect 0x25
  - RSSI\_CONT\_EN bit is disabled in Indirect 0x25 (CCA\_CTRL) all other bits are reset/overwrite values
  - Direct register 0x0B is read (CCA Final)

- Direct register 0x25 is read (LQI)
- Indirect register 0x5B is read (RSSI)
- Direct register 0x26 is read (RSSI\_CONT) [Valid for LQI]

For both LQI and ED the input power is swept with a modulated input signal from -100 dBm to -20 dBm in steps of 1 dBm and the above sequences are called for each step and results recorded.





From the figure above, an equation can be derived as follows. Using Y(LQI) and X(RF), the minimum and maximum values from the figures secondary axis are determined as:

| LQI                             | Y(LQI) | X(RF) |
|---------------------------------|--------|-------|
| Maximum                         | 225    | -25   |
| Minimum                         | 12     | -100  |
| Point near middle Dynamic Range | 125    | -60   |

### Table 3-3. Minimum and Maximum Values

Therefore the slope = 2.84 and B = 295.4. So to convert the 8-bit unitless number read from direct register 0x25 to an ideal RF equivalent, use the following equation:

RF = (LQI - 295.4) / 2.84

# 3.10 Timer Resources

When writing software applications, the user should be aware of the set of timer resources available.

## 3.10.1 Modem Event Timer

The MCR20A transceiver contains an internal Event Timer block whose clock is derived from a programmable prescaler which is driven by the 32 MHz crystal source. The Event Timer consists of the prescaler and a 24-bit counter which increment whenever the modem crystal clock is operating. The Event Timer provides the following functions:

- The 24-bit counter generates "current" system time The counter runs continuously when the modem is not in a low power mode and provides a local "current" time. The present value can be read from the EVENT\_TMR\_USB/MSB/LSB registers. A counter frequency of 250 kHz is used. The counter value is used to generate a time stamp for received frames and is also used for comparison to four different comparators that allow up to four different time delays
- Interrupt generation at pre-determined system times There are four comparator functions that can generate an interrupt to the MCU when the value of the comparator matches the system counter. These function as timers to generate time delays or trigger events and can augment the MCU timers for generating time delays required within the 802.15.4 application software
- Exit from Doze Mode at pre-determined system time Timer comparator Tmr\_Cmp2 can be used to wake-up the modem from low power Doze Mode
- Latches "timestamp" value during packet reception With every received frame, there is a timestamp generated and stored in a modem SPI register. The timestamp is taken from the counter when the frame length indicator (FLI) is received
- Initiates timer-triggered sequences The modem has three basic active modes of RX, TX, and CCA. Each of these sequences can be timer-triggered to become active after a set delay based on timer comparator Tmr\_Cmp2. This feature can be useful for implementing 802.15.4 application sequences

# 3.11 Low Power Considerations

Many IEEE 802.15.4 applications such as sensor End Devices are required to be battery operated. As expected, long battery life is highly desirable and is very dependent on application parameters. Over-the-air operation uses RX, TX, and CCA modes, where power is highest. As a result, the time between radio operations should be kept at the longest possible period that the application will allow.

When designing for low power operation consider:

- The modem and the MCU each have several low power options
- The modem is entirely controlled by the MCU; the low power options/combinations will be determined by MCU programming
- The power down control of the modem must be maintained by the MCU in the MCU's power down configuration
- All unused port GPIO must be configured to a known state (preferably output low) to prevent unwanted leakage current.

Lowest power in a system is more than just putting the modem and/or the MCU in a low power mode. The relationship between the functions, the timing between them, and clock management must all be considered. The duty cycle between active operations is also very important as it can impact whether sleep operation or active operation will have the biggest impact over an extended time period.

## 3.11.1 Low-Power Preamble Search (LPPS)

The Low Power Preamble Search (LPPS) feature of the radio allows the user to effectively save receiver current while maintaining adequate system performance. Attributes of the the LPPS feature are described as follows:

- When enabling the LPPS feature the demodulator and other sub-sections of the receiver can be independently duty cycled at 50%.
- The receiver current consumption is reduced approximately 4 mA.
- Sensitivity performance decreases slightly due to time delta in the correlator while searching for an additional s0 before entering normal preamble search.
- There is no added cost of using the LPPS feature since no extra components are required. In fact, enabling LPPS mode all the time has little system design impact and the current savings is 20%.

LPPS Control Register Setup

There is one register that allows setup, control and enabling of the Low-Power Preamble Search (LPPS) feature:

- LPPS Control (Indirect Modem\_LPPS\_CTRL, 0x56) This is the control register and has this bit field definition: LPPS\_EN [bit 0] (Master Enable for Low-Power Preamble Search (LPPS) mode) the Buffer, LIM, RSSI and LNA can be controlled independently. See section LPPS\_CTRL (Indirect\_Modem\_LPPS\_CTRL)
- 1: Enable Low-Power Preamble Search mode
- 0: Normal operation



Figure 3-11. LPPS flow diagram

Low Power Considerations



Figure 3-12. LPPS enabled sensitivity performance

Sensitivity Performance Summary

Normal (non-LPPS) PER mode

• Sensitivity in normal PER mode is -102 dBm as shown by the blue curve

LPPS enabled (purple curve)

- Sensitivity is slightly reduced by 1 2 dBm due to time delta the receiver requires to search for the s0 symbol defined by the mode
- The current is reduce by 4mA in LPPS mode with no additional system cost
- There is no discernible disadvantage of enabling LPPS all the time and taking advantage of the current savings

## 3.11.2 Recovery Times from Low Power Modes

This section discusses use cases and summarizes the modes of operation of the transceiver.

## 3.11.3 Run Time Current

As previously stated, the modem is fully under control of the MCU. For lowest power, the modem should be kept in a low power mode as much as possible. However, it is also important to understand the current profile of the modem under active operation. In a similar sense, the MCU can use varying levels of current depending primarily on the clock sources and frequencies used.

### 3.11.3.1 Modem Active Currents

In normal operational mode the modem's rest state in the Idle Mode. All active sequences originate from the Idle or Doze Mode and return to the Idle or Doze Mode. The three active sequences are Clear Channel Assessment (CCA), RX, and TX, and each has a separate current profile. The following table lists the typical currents while in the listed modes, but does not show the transition profiles when moving between modes.

| Mode                          | Current           |
|-------------------------------|-------------------|
|                               | (typ @ 2.7V)      |
| Idle (No CLK_OUT)             | 700 µA            |
| Hibernate / Doze (No CLK_OUT) | <1 μA / 500 μA    |
| CCA/ED                        | 19 mA             |
| RX / RX LPPS Mode             | 19 mA, 15 mA LPPS |
| ТХ                            | 17 mA             |
| (0 dBm nominal output power)  |                   |

| Table 3-4. | Modem | Active | State | Currents |
|------------|-------|--------|-------|----------|
|------------|-------|--------|-------|----------|

A normal sequence of events may include a 802.15.4 node performing first a CCA to see if the channel is clear, second transmitting a frame (assuming the channel is clear), and finally after the TX, going into to Receive Mode to look for an acknowledge. The modem has built-in complex autosequences to manage different operation modes.

Low Power Considerations

# Chapter 4 Modem: Modes of Operation

# 4.1 Power Management Overview

The power management structure provides the biasing and the framework to power manage the MCR20A.

The power management includes:

- A 1.8V digital regulator with POR
- A 1.8V analog regulator
- Biasing block

The supply strategy block diagram is provided in the following figure.



Figure 4-1. Supply strategy block diagram

## 4.1.1 Features

The modems power management structure has the following features:

- 1.8V voltage regulation for internal analog circuitry.
- Power on Reset (POR) for global digital reset.
- 1.8V voltage regulation for internal digital circuitry
- Centralized biasing

# 4.1.2 Power and Regulation Topology

The following blocks are sourced by the battery supply:

- XTAL
- Digital regulator 1.8 V
- Analog regulator 1.8 V
- The RF blocks are supplied by dedicated supplies:
- VDDPA for the PA that source high current at the Frontend (PA is not used at the same time)

- VDDRF for the PLL block (mainly VCO), clean supply regulated by the LDO directly
- VDDIF for the other analog blocks and also used potentially by the XOR.

VDDPA and VDDIF are connected externally such that decoupling between supplies is easy

# 4.1.3 Digital Regulator and POR

The digital regulator provides the 1.8 V supply to the digital logic. It is always turned on when the RST\_B pin has been released. For VDDREGD, the external decoupling capacitor is in the range of 220 nF and 470 nF. As the figure below shows, the VDDREGD supply is decoupled externally. The digital regulator includes three modes of operation:

- Off mode controlled by the active low RST\_B pin, and active when reset is active
- On mode with maximum current capability required in RUN mode and during startup
- Low power mode (in LP/HB and DOZE) The current capability in this mode is limited but retains register contents and SPI functionality. The current consumption is max  $300 \mu$ A.

POR block provides reset if VBAT is low (</=1.4 V). POR comes out of reset if VBAT is high (>/=1.65 V). The POR is used to hold the digital logic in reset and then release the xtal oscillator when the power is going up.

### Note

- The POR is disabled during loose mode. (See "Modes and start up process" Table).
- There is no battery monitoring

# 4.1.4 Analog Regulator (AREG)

The analog regulator is a low drop linear regulator that regulates to 1.8 V typical from the battery voltage 3.6 V-1.8 V. When the battery is low the regulated supply VDDRF follows the battery voltage (max 150 mV drop). This LDO provides the supply to the RF

(including PA) and analog circuitry of the modem. The decoupling capacitor is in the range of 220 nF and 470 nF. As this figure shows, the three VDDA supplies (VDDRF, VDDIF and VDDPA) are decoupled externally.

# 4.2 Modem Operational Modes Summary

The modem has a number of passive operational modes that allow for low-current operation as well as modes where the transceiver is active. These modes are summarized in the following table.

| Mode                | Definition                                                               |
|---------------------|--------------------------------------------------------------------------|
| Off                 | RST asserted. All IC functions Off, Leakage only.                        |
| Hibernate           | Crystal Reference Oscillator Off.                                        |
| Doze                | Crystal Reference Oscillator On but CLK_OUT is available only if enabled |
| Idle                | Crystal Reference Oscillator On with CLK_OUT output available.           |
| Receive             | Crystal Reference Oscillator On. Receiver On.                            |
| Transmit            | Crystal Reference Oscillator On. Transmitter On.                         |
| CCA / Energy Detect | Crystal Reference Oscillator On. Receiver On.                            |

Table 4-1. Modem Mode Definitions

## 4.2.1 Power modes

The RESET/power down mode is the mode used to turn everything off in the circuit. All the blocks supplied by VBAT are controlled directly by the RST\_B pin for the power consumption of the circuit to be minimal.

### Note

The GPIO pins must not remain floating.

When RST\_B is released, the digital regulator will automatically startup. When the digital supply is sufficiently high the POR signal is released. During startup, the RSTB high must be ensured for proper startup (pullup)

When POR is released, it starts automatically where the XTAL and a wake up interrupt is generated. The circuit is then set in IDLE mode.

All the other modes can be accessed through SPI generation by programming the blocks independently. For example, the RUN mode (TX or RX) is activated through the xcvseq setting. Care must be taken that before going to this mode the XTAL is enabled and the digital regulator is in full mode. The analog regulator will be automatically turned "on" then by the state machine.

The LP/hibernate mode is a specific mode where the XTAL is disabled. Going out of this mode via the SPI means that the XTAL needs to be started up again, the digital regulator forced to high power mode and a new wake up interrupt is generated.

The following figure provides the power state flow diagram for the modem and the "Modes and start up process" Table, summarizes power mode and start up processes.



•At any time RST/ will go back to RESET mode •VREGD can be disable in external mode in LP/DOZE/ RUN

Figure 4-2. Power State Diagram

| Table 4-2. | Modes a | nd start | up | process |
|------------|---------|----------|----|---------|
|------------|---------|----------|----|---------|

| Mode <sup>1</sup> | VREGD/POR  | XTAL | VREGA | XTAL_out     | Timer  | Registers | GPIO  | Current consumption              |
|-------------------|------------|------|-------|--------------|--------|-----------|-------|----------------------------------|
| IDLE              | ON         | ON   | OFF   | Programmable | ON     | Normal    | Known | 700 μA, typical<br>(no clockout) |
| DOZE              | Loose mode | ON   | OFF   | Programmable | ON/OFF | Retained  | Known | 500 µA, typical                  |

Table continues on the next page...

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

#### Sequence Manager

| Mode <sup>1</sup>           | VREGD/POR  | XTAL | VREGA | XTAL_out     | Timer | Registers | GPIO  | Current consumption |
|-----------------------------|------------|------|-------|--------------|-------|-----------|-------|---------------------|
|                             |            |      |       |              |       |           |       | (no clockout)       |
| Low<br>power /<br>Hibernate | Loose mode | OFF  | OFF   | OFF          | OFF   | Retained  | Known | <1 µA²              |
| Reset /<br>Powerdow<br>n    | OFF        | OFF  | OFF   | OFF          | OFF   | Reseted   | Known | <30 nA              |
| RUN <sup>3</sup>            | ON         | ON   | ON    | Programmable | ON    | Normal    | Known | 15 mA               |

 Table 4-2.
 Modes and start up process (continued)

1. Values identified in this table reflect nominal voltage and temperature.

2. Value does not include SPI activity in LPPS mode.

3. Current of 15 mA refers to radio current.

### Note

Providing a clock output signal on CLK\_OUT will add some power consumption depending on the capacitive load and frequency.

# 4.3 Sequence Manager

The Sequence Manager (also known as the RF digital manager), is a hardware state machine that controls the timing of all transmit, receive, and CCA operations in the modem. The Sequence Manager interfaces directly with 3 lower level managers (RX digital manager, TX digital manager, and PLL digital manager). For each digital and analog element in the modem's transceiver, these 4 state machines operate collaboratively, to perform some or all of the following functions:

- Activation
- Deactivation
- Initialization
- Mode transitions
- Calibration routines
- Clock enabling and disabling
- Interrupt triggering and status generation

Designed into the sequence manager are a variety of complex sequences (called autosequences), which are sequential concatenations of simpler, building-block sequences. The hardware autosequences provide the following advantages:

• Smaller S/W memory footprint: H/W automates operations previously done by S/W

- Increases MCU sleep times, reducing current consumption
- Handles timing-critical sequences (rx-to-tx), e.g., data-polling, not possible in S/W

Sequences can be initiated by software directly, or alternatively, can be initiated automatically at the expiration of a hardware timer. The general parameters of the sequences can be programmed by software prior to initiating the sequences. Such parameters allow software to select:

- Whether CCA is required ahead of a transmit sequence
- Whether an automatic Ack frame should be transmitted after a receive sequence
- Slotted vs. unslotted mode
- Type of CCA (e.g., Energy Detect, CCA mode 2)
- Whether the device is a PAN Coordinator or not
- Whether the device resides on 2 networks simultaneously (Dual PAN mode)

The modem's Sequence Manager also includes support for Dual PAN mode, and Active Promiscuous mode.

# 4.3.1 Modem Sequence Manager Operation

The Sequence Manager controls, coordinates, and automates all transceiver sequences within the modem. Software selects the desired sequence, sets the general parameters, and (optionally) configures a hardware timer to trigger the sequence at a precise time in the future. Subsequently, the MCU can enter a low-power state, or tend to other activities, while the sequence manager state machine conducts the programmed transceiver operations. When the sequence completes, an interrupt alerts the MCU. At this point the MCU can check the completion status of the sequence, download received data from the packet buffer, and then prepare the next sequence.

Sequences can be simple transceiver operations. For example, transmit one frame, or, perform a CCA on a channel. Alternatively, the sequence manager supports complex sequences, which use simple operations as building blocks, strung together in a back-to-back fashion, with precise timing intervals between operations. For example, a "TR" sequence calls for a transmit frame followed by a receive frame. For complex sequences, interrupts can optionally be generated at the completion of each stage of the sequence, providing greater visibility for the MCU into the timeline of the sequence. Software can determine the precise state of the sequence manager state machine at any time. Software can opt to abort a sequence at any time; when this happens, the sequence manager will return to its IDLE state in an orderly fashion.

The sequence manager is responsible for the implementation of the Wireless Physical Layer (PHY) specifications described in the IEEE 802.15.4 standard, in the modem. This is accomplished by activating and deactivating the key digital and analog elements in the

#### Sequence Manager

transmit or receive chain, at precisely the right times, and for precisely the right durations. Most of the low-level timing parameters are hardwired within the state machine, and thus are not programmable. The time resolution of the sequence manager is 2  $\mu$ s (1/8 of a transmitted symbol), so this is the granularity of the individual steps. The higher-level timing parameters, such as the interval between operations in a complex sequence, are largely programmable, except for those defined as constants in the IEEE 802.15.4 standard.

### 4.3.2 Functional Description

This section describes the supported sequences in more detail. All sequences can be initiated by software directly (instantaneously) by writing the desired sequence to the XCVSEQ register, with the TMRTRIGEN bit deasserted. Alternatively, software can schedule the initiation of a sequence at a precise time in the future, by programming the desired start time into the TC2 timer compare register, and setting the TMRTRIGEN bit. The XCVSEQ register field is writable and readable, so software can read this register to determine which sequence it had programmed earlier. After the sequence completes (SEQIRQ interrupt), software must set the XCVSEQ to IDLE (0x0), before initiating a new sequence. This prevents the undesired, inadvertent re-triggering of the sequence manager on the next TC2 match. If the sequence-complete interrupt (SEQIRQ) is masked, software can determine when the sequence is complete by polling the SEQ\_STATE register, until it returns to idle (0x0). While a sequence is ongoing, software can abort the sequence at any time by writing IDLE (0x0) to XCVSEQ; the sequence manager state machine will respond with an orderly return to the SEQ\_IDLE state, and a SEQIRQ will be generated. While a sequence is underway, software should not attempt to change XCVSEQ (other than aborting the sequence as previously described); the sequence manager will ignore all mid-sequence attempts to change XCVSEQ. As mentioned previously, software must write the IDLE value to XCVSEQ before changing sequences.

The supported sequences are shown in the following table.

| XCVSEQ | Sequence | Description                                             |
|--------|----------|---------------------------------------------------------|
| 0      | 1        | Idle                                                    |
| 1      | R        | Receive Sequence - conditionally<br>followed by a TxAck |
| 2      | Т        | Transmit Sequence                                       |
| 3      | С        | Standalone CCA                                          |

### Table 4-3. Transceiver supported sequences

Table continues on the next page...

| XCVSEQ | Sequence | Description                                                                                  |
|--------|----------|----------------------------------------------------------------------------------------------|
| 4      | TR       | Transmit /Receive Sequence - transmit<br>unconditionally followed by either an R<br>or RxAck |
| 5      | CCCA     | Continuous CCA - sequence completes when channel is idle                                     |
| 6      | Reserved |                                                                                              |
| 7      | Reserved |                                                                                              |

Table 4-3. Transceiver supported sequences (continued)

All sequences can be aborted by a PLL unlock detection. In the modem, this is referred to as PLL unlock. The unlock detection is qualified by the sequence manager; in other words, an unlock detection during the early stages of the PLL warmup is expected, and is not allowed to abort the sequence at that point. The primary rationale for the PLL unlock abort, is to prevent transmission on an incorrect, or unstable, frequency during a transmit operation, or to increase battery life by not prolonging a receive or CCA operation that is bound to fail. Software can disable the PLL unlock auto-abort altogether by asserting the PLL\_ABORT\_OVERRIDE bit.

### 4.3.2.1 Supported Sequences

### 4.3.2.1.1 Sequence (Idle)

When the IDLE value is written to XCVSEQ, the sequence manager goes to its SEQ\_IDLE state. If not already in SEQ\_IDLE, the sequence manager executes an orderly warmdown to return to SEQ\_IDLE. A SEQIRQ interrupt is then issued. Writing IDLE value to XCVSEQ is the proper way to abort a sequence.

### 4.3.2.1.2 Sequence R (Receive)

Sequence R is the basic receive sequence. Sequence R can be used to receive all types of 802.15.4 PHY- and MAC-compliant frames, including reserved frame types. However, reception of Acknowledge frames is not recommended using Sequence R. This is because reception of an Acknowledge frame, usually follows a transmitted frame, with a designated Sequence Number, so that the received Acknowledge frame can be verified for the matching Sequence Number. In a standalone Sequence R, there is no Sequence Number to verify against, so any Acknowledge frame is merely transferred to the Packet Buffer. (Note: the appropriate way to receive Acknowledge frames is with Sequence TR, with the RXACKRQD bit asserted). Using Sequence R, all frames that pass frame-filtering rules and CRC check, are transferred to the Packet Buffer.

The basic execution of a successful Sequence R is as follows:

### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

#### Supported Sequences

- MCU writes TC2 compare value to the desired initiation time, and sets TMRTRIGEN (optional)
- MCU writes XCVSEQ=R
- Wait for TC2 match (if TMRTRIGEN=1)
- SEQ\_MGR executes RxWarmup
- Preamble Detected
- SFD Detected
- FrameLength octet received, transferred to Packet Buffer
- N additional octets received (N = FrameLength), transferred to Packet Buffer. Note if (FrameLength > 127), then N = 127.
- If frame-filtering rules and CRC check pass
  - RXIRQ interrupt issued
  - SEQ\_MGR executes RxWarmdown
  - If received Frame Control Field indicates AckRequest=1
    - SEQ\_MGR executes TxWarmup
    - an Ack frame is transmitted using the received Sequence Number
    - SEQ\_MGR executes TxWarmdown
- SEQIRQ interrupt issued

When Sequence R is initiated, the sequence manager warms up the receiver (analog and digital elements). This process takes 144  $\mu$ s. From this point forward, timer TMR3 can be enabled as a "bracketing" timer (software option). If a TMR3 timer match occurs, and software has asserted the TC3TMOUT bit, the sequence manager will warm down the receiver and return to SEQ\_IDLE state. Assuming no TMR3 timeout, reception proceeds in preamble-search mode. After a preamble is detected, reception continues in SFD-search mode. At this point, the sequence manager's slot timer is activated. This is because a slotted "transmit acknowledge" frame (TxAck) may be required later in this sequence. The slot timer is loaded with the following value (in  $\mu$ s):

Slot Timer Preload = 160 + TXWARMUPTIME + (2\*ACKDELAY).

The 160 term arises because, at the point of SFD detect, we are exactly 10 symbols into the backoff slot, and the symbol period is 16 µs. (The slot timer timebase is actually 2 µs, half the time-resolution of the equation shown above). The slot timer will count up and eventually rollover at 319, to 0. (There are 320 µs in a backoff slot). The receiver receives the next octet (FrameLength). Starting with this octet, and continuing through the remainder of the frame, each octet that is received is transferred to Packet Buffer. After each octet is transferred to Packet Buffer, the Packet Buffer address is incremented by 1. The next 2 octets (Frame Control Field) are then received, which are parsed to obtain the AckRequest field, and the FrameVersion field. The next octet is then received (SequenceNumber), and stored. The remainder of the frame, determined by FrameLength, is then received. As the octets are received, the packet data is parsed and subjected to packet-filtering rules. If any of the packet-filtering rules fail, or if the CRC check on the FCS field fails, the sequence manager will return the receiver to preamblesearch mode, after the last octet has been received and transferred to Packet Buffer. Assuming the packet-filtering rules and CRC pass, an interrupt (RXIRQ) is issued to the MCU. At this point, the sequence manager must determine whether a TxAck is required. A TxAck is required if the following 3 conditions are all met:

- AUTOACK=1 (register bit)
- PROMISCUOUS=0 (register bit)
- The received FrameControlField has AckRequest=1

If these conditions are met, and SLOTTED mode is not in effect, the sequence manager loads its TxAck timer with the following value (in  $\mu$ s):

TxAck Timer Preload = 192 - TXWARMUPTIME - 2\*ACKDELAY + 16\*ACKPOSTPONE. Note: ACKPOSTPONE is not supported in the modem and is hardwired to 0.

The 192  $\mu$ s is the non-slotted RX-to-TX turnaround requirement in the 802.15.4 standard. The TXWARMUPTIME takes into account the fact that the TxAck timer must expire early for the Tx warmup to be complete at exactly the 192  $\mu$ s point. The ACKDELAY is a signed, fine-tune adjustment to the TxAck transmission time (± 62  $\mu$ s), and the ACKPOSTPONE allows the TxAck to be delayed an additional 255 symbols, if necessary.

If SLOTTED mode is in effect, the slot timer was previously loaded (at SFD detect), but the sequence manager needs to determine how much time is left in the current backoff slot. If less than 192  $\mu$ s remain, the sequence manager must wait an additional backoff slot before initiating the Ack transmission. So it sets a flag indicating it must allow the slot counter to rollover an additional iteration.

Finally, at TxAck timer expiration (in non-SLOTTED mode), or at the qualified rollover of the slot timer (in SLOTTED mode), a Tx warmup is initiated. The conclusion of the Tx warmup will coincide precisely with a backoff slot boundary if SLOTTED mode is in effect. The sequence manager will then initiate the transmission of the Ack frame. The entire Ack frame will be built up by hardware; the Packet Buffer is not used for the auto-TxAck feature. The hardware will insert the following parameters into the Ack frame's Frame Control Field:

| Table 4-4. | . Frame Control Field for Hardware-generated Auto-TxAck Frame |
|------------|---------------------------------------------------------------|
|------------|---------------------------------------------------------------|

| FCF Field       | Value       |
|-----------------|-------------|
| FrameType       | Acknowledge |
| SecurityEnabled | 0           |

Table continues on the next page ...

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

| FCF Field           | Value                                                                                                                                                                            |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FramePending        | If SRCADDR_EN=1, FramePending gets the value of FramePendingFlag from Source Address Matching accelerator hardware. If SRCADDR_EN=0, FramePending gets the value of ACK_FRM_PND. |
| AckRequest          | 0                                                                                                                                                                                |
| PanIDCompression    | 0                                                                                                                                                                                |
| Reserved (bits 7-9) | 000                                                                                                                                                                              |
| DstAddrMode         | 0                                                                                                                                                                                |
| FrameVersion        | copy FrameVersion from the previously-received frame                                                                                                                             |
| SrcAddrMode         | 0                                                                                                                                                                                |

### Table 4-4. Frame Control Field for Hardware-generated Auto-TxAck Frame (continued)

The Sequence Number for the Ack packet, will be the Sequence Number obtained from the previously received frame.

After the Ack frame has been transmitted, the sequence manager will issue a TXIRQ interrupt, and then perform a Tx warmdown. Finally, a SEQIRQ interrupt will be issued, and the sequence manager returns to SEQ\_IDLE state.

### 4.3.2.1.3 Sequence T (Transmit)

Sequence T is the basic, standalone transmit sequence. Sequence T can be used to transmit all types of 802.15.4 PHY- and MAC-compliant frames. However, transmission of Acknowledge frames is not recommended using Sequence T. This is because transmission of an Acknowledge frame, usually follows a received frame, with a designated Sequence Number. The sequence manager automates the transmission of an Ack frame that follows a received frame, using Sequence R with the AUTOACK bit asserted. This is the recommended method for transmitting an Ack frame. This is especially beneficial, because the transmitted Ack frame octets are generated by hardware, and so no setup of a transmit packet in Packet Buffer, is required. However, sequence manager hardware does not prohibit Ack frames using Sequence T.

Sequence T allows for the insertion of 1 or 2 CCA (clear channel assessment) measurements prior to transmission, to ensure that the selected channel is idle. The CCAbefore-TX feature is governed by two register bits, CCABFRTX and SLOTTED. All CCA measurements must indicate channel-idle, in order for the sequence manager to proceed to transmission; if the channel is determined by CCA to be busy, the sequence manager will terminate the sequence without a transmission. The number of CCA measurements attempted by the sequence manager, and the timing of the measurements, is shown in the following table.

**Chapter 4 Modem: Modes of Operation** 

| CCABFRTX | SLOTTED | Number of CCA<br>measurements | Timing of<br>Initiation of CCA<br>measurement #1 | Timing of<br>Initiation of CCA<br>measurement #2    | Timing of First<br>Bit of<br>Transmitted<br>Frame (assumes<br>channel idle) |
|----------|---------|-------------------------------|--------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------|
| 0        | Х       | 0                             | —                                                |                                                     | Immediately follows<br>TxWarmup                                             |
| 1        | 0       | 1                             | Immediately follows<br>RxWarmup                  | _                                                   | Immediately follows<br>RxPartialWarmdow<br>n and<br>TxPartialWarmup         |
| 1        | 1       | 2                             | Immediately follows<br>RxWarmup                  | 320 µs after<br>Initiation of CCA<br>measurement #2 | 320 µs after<br>Initiation of CCA<br>measurement #2                         |

Any CCA mode can be used for Sequence T and Sequence TR (CCA modes 1, 2, and 3 are available). Software must configure the CCATYPE bits prior to initiating the autosequence, to select the CCA mode.

The basic execution of a successful Sequence T is as follows:

- MCU writes TC2 compare value to the desired initiation time, and sets TMRTRIGEN (optional)
- MCU sets CCABFRTX if one or more CCA's are required prior to transmi
- MCU sets SLOTTED if in slotted mode (2 CCA's will be attempted)
- MCU writes XCVSEQ=T
- Wait for TC2 match (if TMRTRIGEN=1)
- If CCABFRTX=1 :
  - SEQ\_MGR executes RxWarmup
  - SEQ\_MGR initiates CCA measurement (takes 128 µs)
  - if CCA indicates channel busy, sequence terminates, CCAIRQ & SEQIRQ issued
  - otherwise, if CCA indicates channel idle:
    - if SLOTTED=0, SEQ\_MGR executes a RxPartialWarmdown
    - if SLOTTED=1, SEQ\_MGR initiates a 2nd CCA, 320 µs after initiating 1st CCA.
    - if SLOTTED=1, and channel busy, sequence terminates, CCAIRQ & SEQIRQ issued
    - if SLOTTED=1, and channel idle, SEQ\_MGR executes a RxPartialWarmdown
- If SLOTTED=1, SEQ\_MGR waits until 320 µs elapse after 2nd CCA initiation
- SEQ\_MGR executes TxPartialWarmup
- Preamble transmitted
- SFD transmitted
- FrameLength octet is obtained from Packet Buffer Address 0, and transmitted

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

#### Supported Sequences

- CRC engine is reset
- N additional octets are obtained from Packet Buffer and transmitted (N = FrameLength - 2)
- Each octet that is transmitted, is shifted through the CRC engine
- After Nth octet transmitted, FCS is available from CRC engine.
- FCS lower octet transmitted
- FCS upper octet transmitted
- SEQ\_MGR issues TXIRQ
- SEQ\_MGR executes TxWarmdown
- SEQ\_MGR issues SEQIRQ

When Sequence T is initiated, the sequence manager first must determine whether one or more CCA measurements are required. If CCABFRTX bit is asserted, the sequence manager warms up the receiver (analog and digital elements). This process takes 144 µs. Immediately after the conclusion of the warmup, a CCA measurement is initiated. The CCA measurement takes 128 ms. If CCA indicates the channel is busy, the sequence manager warms down the receiver, issues CCAIRQ and SEQIRQ interrupts, and terminates the sequence. If, however, CCA indicates the channel is idle, the sequence manager inspects the SLOTTED bit to determine what to do next. If the SLOTTED bit is clear, the sequence manager issues a CCAIRQ interrupt, and then executes a partial warmdown of the receiver. If, however, the SLOTTED bit is set, the sequence manager does not issue a CCAIRQ interrupt; instead, the sequence manager initiates a second CCA measurement, precisely 320 µs after the initiation of the first CCA. This 320 µs interval is timed by the slot timer, which had been preloaded with 320 µs at the instant that Rx warmup was complete. At the conclusion of the second CCA, the sequence manager issues a CCAIRQ. If the second CCA indicates the channel is busy, the sequence manager warms down the receiver, issues a SEQIRQ interrupt, and terminates the sequence. If, however, CCA indicates the channel is idle, the sequence manager executes a warmdown of the receiver. Prior to executing the warmdown, the sequence manager reloads the slot timer, in order to precisely schedule the ensuing transmission. This time, the slot timer is loaded with a smaller value, in order to account for the fact that the timer must expire early in order to trigger the Tx warmup, which must complete at precisely the next backoff slot boundary. Thus, this time the slot timer is preloaded with:

Slot Timer Preload = 320 - TXWARMUPTIME + (2\*TXDELAY).

The 320  $\mu$ s is the duration of the backoff slot. The TXWARMUPTIME takes into account the fact that the TxAck timer must expire early for the Tx warmup to be complete at exactly the 320  $\mu$ s point. The TXDELAY is a signed, fine-tune adjustment to the TxAck transmission time (± 62  $\mu$ s).

#### Chapter 4 Modem: Modes of Operation

If the SLOTTED bit is asserted, after the slot timer expires, the sequence manager executes a Tx warmup. The conclusion of this warmup coincides with the backoff slot boundary. If the SLOTTED bit is deasserted, the sequence manager does not wait for the slot timer, and instead executes the partial Tx warmup immediately after the partial Rx warmdown.

At this point, the sequence manager begins the transmit operation. The preamble and SFD are transmitted first. The preamble and SFD octets are generated by hardware, and are not included in the Packet Buffer. Then, the FrameLength octet is obtained from the Packet Buffer (address 0), and the buffer address pointer is incremented by one. The FrameLength octet is transmitted. The CRC engine is reset at this point. The FrameLength octet is used to determine how many more octets remain in the Packet Buffer. The number of remaining octets is:

```
Number of octets remaining in Tx buffer = FrameLength - 2
```

This is because the final 2 octets of the transmit frame constitute the FCS (Frame Check Sequence), and this value is hardware-computed. Thus, FCS is not part of the Tx buffer. Each of the octets in the Tx buffer is transmitted, and simultaneously shifted through CRC, to generate the FCS field. After the Tx buffer is drained and all of its octets transmitted, the 2 FCS octets are transmitted, starting with the least significant octet. At this point, the transmit operation is complete. The sequence manager issues a TXIRQ interrupt. The sequence manager then executes a complete Tx warmdown, and follows up with a SEQIRQ interrupt. The sequence manager returns to SEQ\_IDLE state.

### 4.3.2.1.4 Sequence C (Standalone CCA)

Sequence C is the standalone CCA sequence. During Sequence C, the sequence manager executes a Clear Channel Assessment (CCA). The result of the CCA measurement is reported back to software in the CCA bit of the IRQSTS2 Register. The CCA bit indicates either a busy channel (1), or an idle channel (0).

The basic execution of a Sequence C is as follows:

- MCU writes TC2 compare value to the desired initiation time, and sets TMRTRIGEN (optional)
- MCU writes XCVSEQ=C
- Wait for TC2 match (if TMRTRIGEN=1)
- SEQ\_MGR asserts one of {cca1\_en, cca2\_en, cca3\_en, ed\_en} to CCA\_DIG
- SEQ\_MGR executes RxWarmup
- SEQ\_MGR waits an additional 26 µs for RSSI/AGC settling
- SEQ\_MGR initiates CCA measurement by asserting rx\_cca\_en to CCA\_DIG
- SEQ\_MGR waits for CCA to complete
- CCA bit is set to the CCA status (1=busy 0=idle)

### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

Supported Sequences

- CCAIRQ interrupt issued
- SEQ\_MGR executes RxWarmdown
- SEQIRQ interrupt issued

When Sequence C is initiated, the sequence manager asserts one of 4 control signals to CCA\_DIG, based on which CCA or ED mode is programmed into CCATYPE. The mapping of CCATYPE to control signal is shown in the following table:

| ССАТУРЕ | CCA Control Signal |
|---------|--------------------|
| 00      | ed_en              |
| 01      | cca1_en            |
| 10      | cca2_en            |
| 11      | cca3_en            |

The asserted control signal will remain asserted for the duration of the Sequence C. The sequence manager warms up the receiver (analog and digital elements). This process takes 144 µs. The TC3 "bracketing" timer has no effect on the sequence manager during Sequence C, so it cannot abort the sequence. At the completion of the warmup, the sequence manager initiates the CCA by asserting the rx\_cca\_en signal to CCA\_DIG. While CCA is enabled, the CCA\_DIG measures and averages the energy or signal on the channel. At the completion of the CCA process, the CCA bit is set to the status of the channel (idle or busy). The CCAIRQ is issued, the receiver is warmed down, the SEQIRQ is issued, and the sequence manager returns to SEQ\_IDLE state.

Any CCATYPE setting may be used for Sequence C.

### 4.3.2.1.5 Sequence TR (Transmit/Receive)

Sequence TR is a combination Transmit/Receive sequence. The sequence is executed as a concatenation of 1 transmit operation followed by 1 receive operation, with a minimum TX-to-RX turnaround time in between. There are 2 permutations of Sequence TR, depending on the RXACKRQD bit. For both permutations, the Sequence T that constitutes the first half of a Sequence TR, is identical to the standalone Sequence T (XCVSEQ=2). This means that the transmit operation can be slotted or unslotted, and can be preceded by 1 or 2 CCA measurements, depending on the state of the CCABFRTX and SLOTTED bits.

If RXACKRQD=0, then Sequence TR is executed as a Sequence T followed by a Sequence R, with a minimum TX-to-RX turnaround time in between. The Sequence R, which constitutes the second half of the Sequence TR, is identical to the standalone Sequence R (XCVSEQ=1). This means that the receive operation can be followed by an

#### Chapter 4 Modem: Modes of Operation

automatic, hardware-generated transmit Acknowledge frame, if all the necessary conditions are met. As with basic Sequence R, data for a successful receive operation is always transferred to Packet Buffer.

If RXACKRQD=1, then Sequence TR is executed as a Sequence T followed by a Receive-Acknowledge-Only frame. This type of receive operation is special, and not the same as a standalone Sequence R. The Ack-only receive operation filters all incoming frames, looking only for an Acknowledge frame whose Sequence Number matches the Sequence Number that was transmitted in the Sequence T portion of the sequence. All non-matching frames are discarded, and after each non-matching frame, the sequence manager will return the receiver to preamble-detect mode. This receive operation will continue until the matching Ack frame is received. Because this is a Receive-Acknowledge-Only operation, and not a Sequence R, there will be no receive octets transferred to Packet Buffer (an exception is made if ACTIVE\_PROMISCUOUS=1; if so, all receive octets are transferred to the Packet Buffer, even for the Receive-Acknowledge-Only frame). The sequence will end with a RXIRQ interrupt, which indicates that the matching Ack frame was successfully received.

Needless to say, if during the transmit operation of a Sequence TR, an Acknowledge frame is being requested of the receiving end device (Frame Control Field: AckRequest=1), then Sequence TR with RXACKRQD=1 is the appropriate procedure. (Using Sequence TR with RXACKREQ=0 is not recommended for this scenario, because there is no Sequence Number matching.)

Conversely, if during the transmit operation of a Sequence TR, an Acknowledge frame is not being requested of the receiving end device (Frame Control Field: AckRequest=0), then Sequence TR with RXACKRQD=1 should never be used, because a receive acknowledge frame will not be forthcoming. Instead, use Sequence TR with RXACKRQD=0, or simply Sequence T, if no followup receive frame is expected.

### 4.3.2.1.6 Sequence CCCA (Continuous CCA)

Sequence CCCA is the Continuous CCA sequence. This sequence is designed to accommodate situations where channel availability may be infrequent, or low-duty-cycle, and a device needs to be able to transmit at the earliest available opportunity. During Sequence CCCA, the sequence manager repeats CCA measurements continuously until a channel-idle condition is found. The interval between the end of one CCA measurement, and the start of the next, is 126  $\mu$ s. The actual interval between consecutive CCA measurements (i.e., from measurement-start to measurement-start), in the CCCA sequence, is 126 + 128 = 254  $\mu$ s. After each CCA iteration, the CCA bit (IRQSTS2 Register) is set to the result of the measurement. As long as the CCA bit is high (busy) at the end of the iteration, the sequence manager will initiate a new measurement. Unlike Sequence C (standalone CCA), there is no CCAIRQ interrupt generated at the end of

#### Supported Sequences

each CCA measurement, until the channel-idle condition is detected, at which point CCAIRQ is issued. The SLOTTED bit has no effect on this sequence. A Sequence CCCA will be aborted by the Sequence Manager if a TMR3 match occurs, and TC3TMOUT=1. CCA modes 1, 2, or 3, can be used for Continuous CCA.

The basic execution of a Sequence CCCA is as follows:

- MCU writes TC2 compare value to the desired initiation time, and sets TMRTRIGEN (optional)
- MCU writes XCVSEQ=CCCA
- Wait for TC2 match (if TMRTRIGEN=1)
- SEQ\_MGR asserts one of {cca1\_en, cca2\_en, cca3\_en} to CCA\_DIG
- SEQ\_MGR executes RxWarmup
- SEQ\_MGR waits for 26 µs for RSSI/AGC settling
- SEQ\_MGR initiates CCA measurement by asserting rx\_cca\_en to CCA\_DIG
- SEQ\_MGR waits for CCA to complete
- CCA bit is set to the CCA status (1=busy 0=idle)
- If CCA=1, initiate a new CCA measurement immediately and repeat the previous 4 steps
- If CCA=0, CCAIRQ is issued
- SEQ\_MGR executes RxWarmdown
- SEQIRQ interrupt issued

The CCA bit (IRQSTS2 register) may change dynamically during the CCA measurement, and are considered valid (and sampled by the Sequence Manager), only at the end of the CCA measurement; therefore the user should not continuously poll CCA during CCCA and be expecting continuously-valid results.

The user can continuously monitor progress of the Sequence CCCA by reading the CCCA\_BUSY\_CNT register.

## 4.3.2.2 Sequence Manager Warmup Timing

The Sequence Manager not only controls autosequence timing, but also controls the warmup and warmdown timing of the digital and analog transceiver elements. The Sequence Managers executes warmups, in concert with the 3 lower-level managers:

- RX Digital Manager, or RSM
- TX Digital Manager, or TSM
- PLL Digital Manager, or PSM

For each low-level manager, the Sequence Manager has a single enable. The 3 managerenables are:

- RXON (activates the RSM)
- TXON (activates the TSM)
- PLLON (activates the PSM)

After activation, the lower level managers take responsibility for carrying out the enabling and calibration of the individual transceiver blocks, both digital and analog. The lower level managers remain in their active states for as long as the Sequence Manager holds the corresponding manager-enable high. Normally, the Sequence Manager will hold the signals high for the duration of an operation (i.e., a packet reception, or a CCA measurement as part of a larger autosequence). After the Sequence Manager deasserts a manager enable, the lower-level manager shall return to its "off" or idle state, within 2 µs. In the case of an abnormal termination (i.e., a software abort, PLL unlock abort, or a TMR3 timeout), the Sequence Manager will deassert all manager enables, and all 4 state machines will return to idle. For aborts that occur during TX sequences, the Sequence Manager will perform a staged warmdown, to ensure the PLL and other analog elements remain stable while the PA gradually powers off. Aside from enabling and disabling of the lower-level managers by the top-level Sequence Manager, the 3 lower-level managers run autonomously of the top-level manager; there is no feedback, or other information, conveyed from the satellite managers to the Sequence Manager. All 4 managers run synchronously, using the same 2MHz clock. There are no clock domain crossings amongst them.

## 4.3.2.3 Dual PAN Mode Sequencing

The Sequence Manager supports Dual PAN mode, which allows the modem to reside on 2 networks simultaneously, switching back and forth between the 2 networks under software, or hardware control.

In Automatic Dual PAN mode, the modem must switch from one network to another under hardware control, at a software-programmed rate. Because the 2 networks often occupy different channels (frequencies), the sequence manager supports an "on-the-fly channel change", whereby, during a Sequence R, in preamble-search state (RX\_PRE), the sequence manager will toggle PLLON and switch to a new set of programmed channel-select registers, wait out a PLL settling time, and then resume preamble search on the new channel. The entire on-the-fly channel change consumes 68 µs, and 2 sequence manager states. The first state (RX\_PAN1) deasserts PLLON and switches the PLL\_INT and PLL\_FRAC outputs to PHY\_DIG to select the new PAN's channel. The RX\_PAN1 state also deasserts pll\_lock\_en so that unlock events that would naturally occur during the channel-change process, will not trigger a PLL\_UNLOCK\_IRQ or abort a sequence. The duration of RX\_PAN1 is 4 µs. The Sequence Manager then transitions to RX\_PAN2, which re-asserts PLLON. This initiates the PLL on the new channel, and PLL calibration

#### **Dual PAN ID introduction**

and locking begins (controlled by PSM). The pll\_lock\_en remains deasserted during RX\_PAN2 so that unlock events continue to be ignored. The duration of RX\_PAN2 is 52  $\mu$ s. After RX\_PAN2, the Sequence Manager returns to preamble-search (RX\_PRE). Note: the RSM takes a few microseconds beyond this, to return to its preamble-search state, bringing the total "on-the-fly channel change" duration to 68  $\mu$ s. This 68  $\mu$ s represents a short "blind spot" during which preamble detection cannot occur, while the modem switches from one network to another. The following diagram depicts Dual PAN "on-the-fly channel change".

# 4.4 Dual PAN ID introduction

The modem represents a high performance platform/radio that includes hardware support for a device to reside in two networks simultaneously. In optional Dual PAN mode, the device will alternate between the two (2) PANs under hardware or software control. Hardware support for Dual PAN operation consists of two (2) sets of PAN and IEEE addresses for the device, two (2) different channels (one for each PAN), a programmable timer to automatically switch PANs (including on the fly channel changing) without software intervention. There are control bits to configure and enable Dual PAN mode and read only bits to monitor status in Dual PAN mode. A device can be configured to be a PAN coordinator on either network, both networks or neither.

For the purpose of defining "PAN" in the content of Dual PAN mode, two (2) sets of network parameters are maintained. In this chapter, "PAN0" and "PAN1" will be used to refer to the two (2) PANs. Each parameter set uniquely identifies a PAN for Dual PAN mode. These parameters are described in the following table.

| PANO                             | PAN1                             |  |
|----------------------------------|----------------------------------|--|
| Channel0 (PHY_INT0, PHY_FRAC0)   | Channel1 (PHY_INT1, PHY_FRAC1)   |  |
| MacPANID0 (16-bit register)      | MacPANID1 (16-bit register)      |  |
| MacShortAddrs0 (16-bit register) | MacShortAddrs1 (16-bit register) |  |
| MacLongAddrs0 (64-bit registers) | MacLongAddrs1 (64-bit registers) |  |
| PANCORDNTR0 (1-bit register)     | PANCORDNTR1 (1-bit register)     |  |

Table 4-5. PAN0 and PAN1 descriptions

During device initialization if Dual PAN mode is used, software will program both parameter sets to configure the hardware for operation on two(2) networks.

## 4.4.1 Manual and Automatic Modes

Two (2) modes are available for Dual PAN operation:

- Manual
- Automatic

## 4.4.1.1 Manual Dual PAN Mode

In manual Dual PAN mode software controls which PAN is selected for transmission and reception at all times. Software populates both PAN network parameter-set-registers listed in Table 4-5 where software selects a PAN to begin transmission of reception. A single control bit ACTIVE\_NETWORK selects the PAN. To select PAN0, ACTIVE NETWORK should be set to 0; to select PAN1, ACTIVE NETWORK should be set to 1. Software then initiates an auto sequence by writing the appropriate value to XCVSEQ. At any point software can elect to switch to the alternate PAN. To switch, software aborts the sequence (if one is active) by writing XCVSEQ = IDLE. Software then toggles ACTIVE\_NETWORK and restarts a new sequence with XCVSEQ. Software is responsible for aborting and initiating sequences. Hardware is responsible for warming up the transceiver on the selected channel (CHANNEL0 or CHANNEL1) and performing address-filtering on the selected network's address parameters. (PANCORDNTR, MacPanID, Short Address and/or IEEE address). Software overhead is significantly reduced in this mode because there is no need to re-program all of the PANselect registers every time the PAN is toggled in Dual PAN mode where only a single bit (ACTIVE\_NETWORK) needs to be written. For manual Dual PAN operation, DUAL PAN AUTO should be set to 0.

The diagram shown in the next figure depicts Dual PAN operation in manual mode. In this example, software populates both PAN parameter sets during initialization. Also, software elects to initiate packet reception on PAN1, so ACTIVE\_NETWORK is set to 1. Software initiates the Sequence R by writing to XCVSEQ. Hardware warms up the receiver on CHANNEL1 and enters preamble-search. In this example no packet is received but a data request from higher level software requires a switch to PAN0. Software responds by aborting the reception by writing Sequence 1 to XCVSEQ. Software then sets ACTIVE\_NETWORK to 0 to select PAN0. In the example, software initiates a Sequence TR. The hardware warms up the receiver for CCA on CHANNEL0, performs CCA (channel is idle), warms down the receiver and warms up the transmitter on CHANNEL0. Then, transmits the requested packet, warms down the transmitter and warms up the receiver again (as per the auto sequence) on CHANNEL0 in order to receive the acknowledge packet. The acknowledge packet is received and the auto

#### **Dual PAN ID introduction**

sequence completes successfully with the RXIRQ and SEQIRQ. Software elects to resume packet reception on PAN1) which was in progress before the data request). Software toggles ACTIVE\_NETWORK back to 1 and re-initiates Sequence R.



Figure 4-3. MCR20A Dual PAN (Manual Mode) hardware / software diagram

### 4.4.1.2 Auto Dual PAN

In automatic Dual PAN mode hardware is responsible for alternating the selected PAN at a pre-programmed interval. Software programs a "PAN dwell time", which determines the amount of time during which the hardware will receive on a given PAN. This is done by programming the DUAL\_PAN\_DWELL register. Software sets the DUAL\_PAN\_AUTO bit to "1" for automatic Dual PAN operation and sets ACTIVE\_NETWORK to correspond to the PAN on which it desires packet reception to begin. Software then initiates a Sequence R. Hardware warms up the receiver on the selected PAN and begins preamble search. When the dwell time expires, assuming preamble and SFD have not been detected, hardware will switch to the alternate PAN including on-the-fly channel change. After it is switched to the alternate PAN, hardware will use the address filtering parameters (PANCORDNTR, MacPanID, Short Address and/or IEEE) programmed for the alternate PAN. After the dwell time expires on the alternate PAN, assuming preamble and SFD have not been detected, hardware will switch back to the original PAN. This process will repeat indefinitely until one of the following occurs:

- 1. A packet is successfully received (address match and CRC valid).
- 2. Software aborts the Sequence R.
- 3. A TMR3 RX timeout which automatically aborts the Sequence R.

4. A PLL unlock automatically aborts the Sequence R.

If the hardware PAN dwell timer expires during a packet reception (i.e., preamble and SFD have been detected during a Sequence R), the PAN-switch will be delayed until the packet is completely received. If the packet was received successfully (address match and CRC valid), the receive sequence will terminate with RXIRQ and SEQIRQ (if an auto-Acknowledge was requested and enabled, the sequence will complete after the Acknowledge packet was transmitted, and TXIRQ will also be set, in addition to RXIRQ and SEQIRQ); the PAN switch will occur at this point, after the Sequence has returned to IDLE. If the received packet fails FCS (CRC check), or, if the packet was not intended for the device (address mismatch), the hardware will toggle the PAN, and return to preamble-search on the new PAN.

If the hardware PAN dwell timer expires during a state *other* than RX preamble search during Sequence R (i.e., if expiration occurs during TX, CCA, ED, Sequence TR, or any warm-up or transitional state), PAN-switch will be delayed until either:

- 1. Preamble Search state is reached during a Sequence R (not Sequence TR).
- 2. Sequence returns to IDLE.

At any point, software can elect to interrupt the automatic Dual PAN operation, by aborting the sequence with a XCVSEQ=IDLE, and the setting the DUAL\_PAN\_AUTO bit to 0. In response, hardware will freeze the current state of the dwell timer, and capture the currently-selected PAN, so that hardware-controlled PAN alternation can resume where it left off, later. Software can then tend to that tasks that caused the Dual PAN interruption. When software wants to resume Dual PAN operation, it then sets DUAL\_PAN\_AUTO=1, and re-initiates Sequence R. Hardware will resume the dwell timer from the point it was frozen earlier, on the same PAN, and will warm-up the receiver to receive on the PAN that was being monitored before the interruption. Hardware will dwell on that PAN until the timer expires, and then switch PAN's (assuming no preamble and SFD detected, subject to the conditions listed above). Software can always determine the selected PAN at any time, in any mode, by reading CURRENT\_NETWORK bit. If DUAL\_PAN\_AUTO=1, then CURRENT\_NETWORK is controlled by hardware.

To initiate auto Dual PAN operation for the first time, or to reset the dwell timer to its programmed value and allow software to select the initial PAN for auto Dual PAN operation, software should program the desired initial PAN to ACTIVE\_NETWORK (0 for PAN0, 1 for PAN1), and then program the desired dwell time into the DUAL\_PAN\_DWELL register. Hardware always responds to a write to DUAL\_PAN\_DWELL, by resetting the dwell timer to its programmed value, and

#### **Dual PAN ID introduction**

selecting the initial PAN for auto Dual PAN operation, based on the state of ACTIVE\_NETWORK. A write to DUAL\_PAN\_DWELL, always re-initializes the DWELL TIMER to the programmed value. If a write to DUAL\_PAN\_DWELL occurs during an auto sequence, the DWELL TIMER will begin counting down immediately. If a write to DUAL\_PAN\_DWELL occurs when there is no auto sequence underway, the DWELL TIMER will not begin counting until the next auto sequence begins; it will begin counting at the start of the auto sequence warm-up. Under all circumstances, DUAL\_PAN\_AUTO must be asserted to allow the DWELL TIMER to count. If DUAL\_PAN\_AUTO=0, the DWELL TIMER will freeze and hold its state, until DUAL\_PAN\_AUTO=1. However, a write to DUAL\_PAN\_DWELL will still initialize the DWELL TIMER to its programmed value, regardless of the state of DUAL\_PAN\_AUTO.

At any point during auto Dual PAN mode, software can ascertain the PAN currently being serviced by hardware by reading the CURRENT\_NETWORK bit. Software can also determine the time remaining in the current dwell by reading the DUAL\_PAN\_REMAIN register.

In the auto Dual PAN mode, software retains responsibility for initiating and aborting sequences. There is no provision for hardware initiated sequences. TMR2 may be used to initiate an auto sequence at a future time. TMR3 may be used as an RX hardware abort mechanism.

The following figure depicts Dual PAN operation in automatic mode. In this example software populates both PAN parameter sets during initialization. Software wants to initiate packet reception in auto Dual PAN mode on PAN1, so ACTIVE NETWORK is set to "1". For auto Dual PAN operation software programs the desired PAN-switching interval into DUAL\_PAN\_DWELL register, in this case 4 ms. Software initiates the Sequence R by writing to XCVSEQ. The dwell timer begins counting as soon as the receiver warm-up begins. Hardware warms up the receiver on CHANNEL1 where PAN was selected as the initial PAN shown in Figure 4-4 and begins preamble search. If a packet is received during this interval, hardware applies PAN1 address filtering. No preamble is detected at the point where the dwell timer expires so hardware executes a PAN-switch to PAN0 that includes an on-the-fly-change. On-the-fly changes require approximately 68 us to execute and no preamble detection is possible during this "blind spot". After the PAN switch, hardware assumes preamble search on CHANNEL0 and applies PAN0 address filtering if a packet is received. No preamble is detected at the point which the dwell timer expires, therefore hardware performs a PAN-switch back to PAN1 and so on and so forth.



Figure 4-4. MCR20A transceiver dual PAN auto mode diagram

#### 4.4.1.3 Two-PAN-one-channel

A special case occurs if a device is operating in Dual PAN mode (either Auto or Manual mode), and both PAN's occupy the same channel; in other words,

CHANNEL0=CHANNEL1. In this case, hardware will detect this condition, and apply both sets of address-filtering parameters simultaneously. Hardware will provide Data Indication if the received packet matches either the PAN0 address parameter set {MacPanID0, MacShortAddrs0, MacLongAddrs0, PANCORDNTR0}, or the PAN1 address parameter set {MacPanID1, MacShortAddrs1, MacLongAddrs1, PANCORDNTR1}. At Data Indication, two status bits can be queried by software to quickly determine on which PAN the packet was received, RECD\_ON\_PAN0 or RECD\_ON\_PAN1. In the "Two-PAN-one-channel" scenario, it is possible for a packet to satisfy both sets of addressing parameters (PAN0 and PAN1). When this happens, both RECD\_ON\_PAN0 and RECD\_ON\_PAN1 will be set. In the "Two-PAN-one-channel" scenario, the CURRENT\_NETWORK bit should be ignored, because both networks are simultaneously active.

If Dual PAN mode is not to be used, ACTIVE\_NETWORK should be maintained at 0 (default) to select the PAN0 parameters for transceiving. In single PAN operation, the PAN1 parameter registers need not be programmed, and can be used as scratchpad. (PLL\_INT1 and PLL\_FRAC1 should not be programmed, and should instead be left in their default state, if Dual PAN mode is not in use).

#### **Dual PAN ID introduction**

#### 4.4.2 Source Address Matching

This section describes interaction between Dual PAN mode and the modem packet Processors Source Address Matching function. The Source Address Matching Table is two (2) entries deep and 16 bits wide. In Dual PAN mode, entries from both networks will need to be stored in the table. It is highly undesirable to add a 17th bit to each table entry merely to identify the network on which the packet containing the Source Address was received. In order to keep the Source Address table width at 16 bits, the table will be split into two (2) sections:

- Lower section shall hold "PAN0" source address checksums
- Upper section shall hold "PAN1" source address checksums

In Dual PAN mode when software populates the table with a new Source Address Checksum, it will deposit the new checksum in the appropriate section of the table based upon whether the packet was received on PAN0 or PAN1. When the Packet Processor interrogates the table for a matching checksum, it will only search the section of the table corresponding to the PAN on which the current packet is being received. The dividingline between the PAN0 and PAN1 sections in the table shall be programmability with a 4-bit register DUAL\_PAN\_SAM\_LVL (SAM is an acronym for "Source Address Matching"). The register identifies the first PAN1 entry in the table (indices below this level apply to PAN0). For single-PAN operation, software should set this register to "12" or above which dedicates the entire table to PAN0. The hardware shall reset-default this register to "12". Figure 4-5 shows the effect of setting the PAN dividing line to "8":



Figure 4-5. Source Address table set to "8"

### 4.4.3 Programming interface

This section describes registers associated with the Dual PAN ID. All writable registers read back what was previously written by software. Register addresses within the MCR20A tranceiver's memory map and bit assignments are shown below.

| Register Name   | Access<br>Mode | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|-----------------|----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DUAL_PAN_AUTO   | rw             | 1     | Activates automatic Dual PAN operating mode. In this mode, PAN-<br>switching is controlled by hardware at a pre-programmed rate, determined<br>by DUAL_PAN_DWELL.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                 |                |       | 1: Auto Dual PAN Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                 |                |       | 0: Manual Dual PAN mode (or Single PAN mode). Default.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                 |                |       | Whenever DUAL_PAN_AUTO=0,<br>CURRENT_NETWORK=ACTIVE_NETWORK at all times. In other words,<br>software directly controls which PAN is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                 |                |       | Whenever DUAL_PAN_AUTO=1, CURRENT_NETWORK is controlled by HW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| ACTIVE_NETWORK  | rw             | 1     | Selects the PAN on which to transceiver, by activating a PAN parameter set (PAN0 or PAN1). In Manual Dual PAN mode (or Single PAN mode), this bit selects the active PAN parameter set (channel and addressing parameters) that governs all auto sequences. In Auto Dual PAN mode, this bit selects the PAN on which to begin transceiving, latched at the point at which DUAL_PAN_DWELL register is written.                                                                                                                                                                                                                   |  |
|                 |                |       | 0: Select PAN0 (Default)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| CURRENT_NETWORK | r              | 1     | This read only bit indicates which PAN is currently selected by hardware in automatic Dual PAN mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                 |                |       | 1: PAN1 is selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|                 |                |       | 0: PAN0 is selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| DUAL_PAN_DWELL  | rw             | 8     | Channel Frequency Dwell Time. In Auto Dual PAN mode, hardware will toggle the PAN, after dwelling on the current PAN for the interval described below (assuming Preamble/SFD not detected). A write to DUAL_PAN_DWELL, always re-initializes the DWELL TIMER to the programmed value. If a write to DUAL_PAN_DWELL occurs during an auto sequence, the DWELL TIMER will begin counting down immediately. If a write to DUAL_PAN_DWELL occurs when there is no auto sequence underway, the DWELL TIMER will not begin counting until the next auto sequence begins; it will begin counting at the start of the sequence warm-up. |  |
|                 |                |       | PRESCALERTIMEBASERANGEbits [1:0](min) - (max)(2 bits)(6 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                 |                |       | 00         0.5 ms         0.5 - 32 ms           01         2.5 ms         2.5 - 160 ms           10         10 ms         10 - 640 ms           11         50 ms         50 - 3.2 seconds                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

 Table 4-6.
 MCR20A memory map and bit assignments

Table continues on the next page ...

| Table 4-6. | MCR20A memor | y map and bit assignments (o | continued) |
|------------|--------------|------------------------------|------------|
|------------|--------------|------------------------------|------------|

| Register Name    | Access<br>Mode | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|------------------|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                  |                |       | A write to DUAL_PAN_DWELL also causes the value of<br>ACTIVE_NETWORK to get latched into the hardware. This latched value<br>will be the starting point for the automatic dual-pan mode (i.e., start on<br>PAN0 or on PAN1). The starting value takes effect immediately (if<br>sequence is underway and DUAL_PAN_AUTO=1), or is otherwise delayed<br>until sequence starts and DUAL_PAN_AUTO=1.                                                                   |  |  |
| DUAL_PAN_REMAIN  | r              | 6     | This read only register indicates time remaining before next PAN switch in auto Dual PAN mode. The units for this register depend on the PRESCALAR setting in the DUAL_PAN_DWELL register according to the following table                                                                                                                                                                                                                                         |  |  |
|                  |                |       | DUAL_PAN_DWELL     DUAL_PAN_REMAIN       PRESCALAR     UNITS       00     0.5 ms       01     2.5 ms       10     10 ms       11     50 ms       The readback value indicates that between N-1 and N timebase units remain until the next PAN switch. For example, a DUAL_PAN_REMAIN readback value of 3, with a DUAL_PAN_DWELL PRESCALER setting of 2 (10ms), indicates that between 20ms (2*10ms) and 30ms (3*10ms), remain until the next automatic PAN switch. |  |  |
| RECD_ON_PAN0     | r              | 1     | Indicates the packet which was just received was received on PAN0                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| RECD_ON_PAN1     | r              | 1     | Indicates the packet which was just received was received on PAN1                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| DUAL_PAN_SAM_LVL | rw             | 4     | For the Source Address Matching Table, sets the dividing line between PAN0 and PAN1 sections of the table. Table indices at or above this level belong to PAN1. Table entries below this level belong to PAN0. Default = 12 (entire table is PAN0).                                                                                                                                                                                                                |  |  |
| CHANNEL0         | rw             | 4     | Channel selector for PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| MACPANID0        | rw             | 16    | MAC PAN ID for PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| MACSHORTADDRS0   | rw             | 16    | MAC Short Address fro PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| MACLONGADDRS0    | rw             | 64    | MAC Long Address fro PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| PANCORDNTR0      | rw             | 1     | 1: Device is a PAN Coordinator on PAN0                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                  |                |       | 0: Device is not a PAN Coordinator on PAN0                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| CHANNEL1         | rw             | 4     | Channel selector for PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| MACPANID1        | rw             | 16    | MAC PAN ID for PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| MACSHORTADDRS1   | rw             | 16    | MAC Short Address fro PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| MACLONGADDRS1    | rw             | 64    | MAC Long Address fro PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| PANCORDNTR1      | rw             | 1     | 1: Device is a PAN Coordinator on PAN1                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                  |                |       | 0: Device is not a PAN Coordinator on PAN1                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |

# 4.5 Active Promiscuous Mode

This section describes the Active Promiscuous mode for the MCR20A transceiver high performance 2.4 GHz IEEE 802.15.4 radio.

# 4.5.1 Functional Description

The 802.15.4 Wireless Medium Access Control (MAC) and Physical Layer (PHY) specifications for Low-Rate Wireless Personal Area Networks (WPAN's) prescribes the following behavior for Promiscuous mode operation.

In promiscuous mode, the MAC sublayer passes all frames received after the first filter directly to the upper layers without applying and more filtering or processing.

Where the first level is described as:

For the first level of filtering, the MAC sublayer shall disregard all received frames that do not contain a correct value in their FCS field in the MFR (see section 7.2.1.9 in the standard specification).

Promiscuous mode allows a device to receive and process all 802.15.4 frames that pass FCS check (CRC), regardless of whether or not they are addressed to the device. This allows a device to receive and process all valid traffic on the network. In Promiscuous mode, the modem packet processor will provide Data Indication on all packets. This capability allows a simple network sniffer to be constructed, which can display comprehensive packet data for all packets transmitted on a network within receiving range of the device.

Because a device operating in Promiscuous mode is designed to do so discretely, automatic acknowledgement of all received packets is inhibited regardless of the state of the ACK request in the Frame Control Field of the received packet. Otherwise, the sniffing device would be acknowledging received frames for which it was not the address.

In Active Promiscuous mode the packet processor will process packets according to the same rules that it applies to Promiscuous mode, except that it will automatically transmit an acknowledgement packet for frames that were addressed to the device. In other words, in Active Promiscuous mode if the received frame meets all the address and packet filtering requirements that would have been applied in non-promiscuous mode an acknowledgment packet will be transmitted; a Data Indication will still be provided for all packets (those that pass FCS check).

#### Active Promiscuous Mode

The packet processor can also be programmed to provide Data Indication for packets that fail FCS check. Received packets that fail FCS check are never acknowledged under any circumstances.

#### 4.5.2 Special Handling for Broadcast Packets

Special rules apply to received packets that contain a broadcast PAN identifier (0xffff) and/or a broadcast short address (0xffff) according to the 802.15.4 standard.

#### Note

For valid frames that are not broadcast, if the Frame Type subfield indicates a data or MAC command frame and the Acknowledgement Request subfield of the Frame Control Field is set to one, the MAC sublayer shall send an acknowledgement frame.

An exception is made for received packets thatcontain a broadcast PAN identifier and a long address that matches the device's IEEE address. Such packets are acknowledged because the IEEE address uniquely identifies the device regardless of the PAN. This special case will also apply in "Active Promiscuous" mode where such packets will be acknowledged. The following table describes the "acknowledgement decision" for all permutations of broadcast indicators in the received packets addressing fields.

Table 4-7. Acknowledge-on-Broadcast (all permutations)

| Destination     | PAN ID =  BROADCAST      | PAN ID =  BROADCAST    | PAN ID = BROADCAST     | PAN ID =  BROADCAST      |
|-----------------|--------------------------|------------------------|------------------------|--------------------------|
| Address<br>Mode | DSTADDR =  <br>BROADCAST | DSTADDR =<br>BROADCAST | DSTADDR =<br>BROADCAST | DSTADDR =  <br>BROADCAST |
| Short           | ACK                      | NO ACK                 | NO ACK                 | NO ACK                   |
| Long            | ACK                      | -                      | -                      | ACK                      |

## 4.5.3 Special Handling of Rx Acknowledgement Frames

The modem features an auto sequence to automatically receive and verify Acknowledgment Frames after a Transmit Frame has been sent. This accomplished by programming a "Sequence TR with RXACKRQD=1". During normal operation the receive Acknowledgement Frames are not stored in the packet buffer. They are merely checked for matching Sequence Number and Frame Version with a Data Indication issued for a valid match on both. In Active Promiscuous mode, receive Acknowledgement Frames will be stored into the Packet Buffer just like any other receive frame. This saves software from having to re-construct the contents of the Acknowledgement packet from the contents of the packet that was originally transmitted.

#### 4.5.4 Programming Interface

This section describes registers associated with Active Promiscuous Mode. The definition and functionality of the PROMISCUOUS bit, which will be maintained for the modem is identical to existing FSL 802.15.4 transceivers. The ACTIVE\_PROMISCUOUS bit is new for the modem as shown in the following table.

Table 4-8. ACTIVE\_PROMISCUOUS register

| Register Name      | Access Mode | Width | Description                                                                                                                                                                                                                                                |
|--------------------|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACTIVE_PROMISCUOUS | rw          | 1     | <ol> <li>Provide Data Indication on all received packets under the<br/>same rules that apply in PROMISCUOUS mode, however<br/>acknowledge those packets under rules that apply in non-<br/>PROMISCUOUS mode</li> <li>normal operation (Default)</li> </ol> |

## 4.6 Clock System

## 4.6.1 32 MHz Crystal Oscillator

The 32 MHz crystal oscillator (XTAL32m) is composed of the following features:

- Amplifier it associates with an external crystal and tuning capacitors creating the main oscillator loop.
- Hysteresis comparator it creates a logic-level signal from the sine wave developed across the crystal terminals.
- Clock gate timer it waits for a delay before passing the clock signal.
- Clock divider that contains a divider by two and divide by eight circuitry.

The XTAL32m frequency is 32 MHz. It can be trimmed with some internal capacitances connected on both pads. The XTAL32m is supplied by the VBAT. An external clock generator can be connected to XTAL32Mout. In this case, the clock is directly connected to the output in bypass mode. A 1.8 V square clock can be connected as required.

The crystal oscillator block can work in 2 modes:

- Low power mode /RFoff mode where the comparator works with lower current. The clock is used only by the digital manager and provided to the clock output pin. This is the mode by default
- High performance mode/RFon mode where clocks are also sent to the RF part.

#### 4.6.2 Clock output feature overview

The modem has the capability to output various clock frequencies as shown in this table by register selection. This feature allows the user to make adjustments per their application requirements.

- XTAL domain to minimize dynamic current consumption based on power mode selected.
- XTAL domain can be completely gated off (HIBERNATE mode)
- SPI communication allowed in HIBERNATE

| CLK_OUT_DIV [2:0] | CLK_Out frequency | Comments           |
|-------------------|-------------------|--------------------|
| 0                 | 32 MHz            |                    |
| 1                 | 16 MHz            |                    |
| 2                 | 8 MHz             |                    |
| 3                 | 4 MHz             | DEFAULT if GPIO5=0 |
| 4                 | 2 MHz             |                    |
| 5                 | 1 MHz             |                    |
| 6                 | 62.5 kHz          |                    |
| 7                 | 32.786 kHz        | DEFAULT if GPIO5=1 |

Table 4-9. CLOCK\_OUT Frequencies

There will be an enable and disable bit for CLK\_OUT. When disabling, the clock output will optionally continue to run for 128 clock cycles after disablement. There will also be one(1) bit available to adjust the CLK\_OUT I/O pad drive strength. Bits described in the table above will reside in the 8 bit CLK\_OUT\_CTRL register. Default setting is 32.787kHz with a strap option to select a default of 4MHz.

# Chapter 5 Modem: Advanced Security Module

## 5.1 Advanced Security Module

## 5.2 Introduction

The ASM engine encrypts using the Advanced Encryption Standard (AES). It can perform Counter (CTR), Cipher Block Chaining (CBC), and plain AES mode encryption. The combination of CTR and CBC modes of encryption is known as CCM mode encryption. CCM is short for Counter with CBC-MAC. CCM is a generic authenticate and encrypt block cipher mode. CCM is defined for use only with 128 bit block ciphers, such as AES.

#### 5.2.1 Features

The ASM has the following features:

- CTR encryption.
- CBC encryption.
- AES encryption.
- Encrypts 128 bits as a unit.

## 5.2.2 Modes of Operation

The ASM is designed to be loaded with data and then started with a self-clearing START bit. Sixteen 8 bit registers of a key plus sixteen 8 bit registers of a counter plus sixteen 8 bit registers of text are necessary for Counter mode encryption. Cipher Block Chaining (CBC) mode needs only a key field and a text field programmed. Typically, only the text fields and counter fields need to be continuously written since the key field won't change.

The module has a built in self test. This test must be initiated by the software to make the module usable. Until this test is run and passes, the ASM module is disabled. Typical usage would require that this test be run once when the module is powered up. The software can re-run this test at any time it becomes necessary to verify the operation of the encryption engine.

If the test passes, the bit TSTPAS, in the ASM\_CTRL2 register will be high. If the test fails the bit will be low and the module will disable itself from being used. This self test can be initiated by the software by writing a "1" to the SELFTST bit to set the mode to self test. Then write a "1" to the START bit. If self test passes then the TSTPAS bit will be set to a 1. If self test fails then the TSTPAS bit will be cleared to a 0 and the ASM module will be disabled and all outputs will be held to constant 0. Be sure and write a "0" to the SELFTST bit to get out of self test mode.

# 5.2.3 CTR mode block diagram



Figure 5-1. CTR Block

Counter mode encryption (CTR) is done by using the AES engine as shown in the block diagram above. The 128 bit key, text and counter value is written to the data register by configuring the ASM\_CTRL2[7:5]. The START bit is set and the encrypted data can be read from the data register 11 clocks after the START bit is set by configuring the ASM\_CTRL2[7:5]. The IRQSTS2 has an ASM\_IRQ bit that the software can read to determine when the result is ready to be read. Decryption still uses the same AES encryption engine. The data to be decrypted is written to the data register. The decrypted result can be read from the data register after configuring the ASM\_CTRL2 [7:5].

## 5.2.4 CBC mode block diagram



Cipher block chaining message authentication code

Figure 5-2. CBC Block

The CBC-MAC generation is done by using the AES engine as shown in the block diagram above. The 128 bit key and data is written to data register by configuring the ASM\_CTRL2[7:5]. The start bit is set and the MAC value can be read from the data register 11 clocks after the start bit is set after configuring the ASM\_CTRL2[7:5]. The ASM\_IRQ bit can be read from the IRQSTS2 to determine when the result is complete.

### 5.2.5 CCM mode

CCM mode is the combination of using CTR mode for protecting the privacy of data, and using CBC mode to generate a MAC to protect the data from unauthorized modifications. In this mode both CTR and CBC bits in the ASM\_CTRL1 are set and the START bit is set. The ASM first performs a CTR encryption followed by a CBC conversion. The results of CTR and CBC conversion are stored in separate registers which can be read by configuring the DATA\_REG\_TYPE\_SELECT bits in ASM\_CTRL2.

# 5.2.6 AES mode

AES mode is the most simple method of encryption in which there is no feedback of result to input in any form. The user simply writes the inputs required to the data registers and reads the result from the result register. For this mode, the user must clear both the CTR and CBC bits in the ASM\_CTRL1 and set the AES bit followed by START bit to begin the conversion process. After 11 clock cycles the result is available in the result register, which can be read by configuring the DATA\_REG\_TYPE\_SELECT bits from the ASM\_CTRL2.

#### Note

The ASM block cannot do simple AES decryption.



Figure 5-3. Plain AES Block

# 5.3 ASM module block diagram



Figure 5-4. ASM Block Diagram

# 5.3.1 ASM Register Interface

The ASM register interface is used for writing and reading of the Control registers and Result registers of the module. There are separate result registers for the CTR and CBC results but use the same CBC result register for storing the result of plain AES mode of encryption, therefore it is important that the AES result should be read as soon as the conversion is completed else it is overwritten if another CBC mode encryption is initiated before reading it.

### 5.3.2 AES Encryption Engine

The encryption engine does not have any knowledge of CBC, CTR, or CCM mode - it only performs simple AES encrytion on the text provided to it using the key value. There is a wrapper around the engine which enables the conversion of the plain cipher data to CTR, CBC, and so on. When a start pulse is received, the engine begins the conversion after exactly 11 clock cycles, then gives a data\_ready pulse, followed by a level-signal complete to indicate that the conversion is finished. It is at this point that the data from the asm\_engine should be latched to flip-flops because the data changes in subsequent clock cycles.

### 5.3.3 ASM Logic

There is a wrapper around the AES encryption engine which performs the conversion of plain AES cipher text output from the engine into CTR and CBC data according to the control signals. The scheme of the wrapper is shown logically in the MCR20A asm\_logic block implementation diagram. The explanation for various modes is given below:

AES mode: The text written by the user is directly fed into the AES engine, and after conversion, the data is written directly to the result register. The CBC result is used to store the AES result and also to save 128 flip-flops area.

CTR mode: The data input to the engine is the counter value entered by the user, the output by the engine is XOR'ed with the text written by the user - this is then stored in the CTR result register.

CBC mode: The input plain text data is XOR'ed with the previous state output data. There is also an option of preloading the feedback data with some value using LOAD\_MAC bit in the ASM\_CTRL1 register. The new output data is directly stored in the CBC result register.

Self test mode: In this mode the CBC output is muxed back to the key input value.

ASM module block diagram





### 5.3.4 AES encryption engine algorithm



MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

The above diagram documents the encryption process for a single round. Each 128 bit data block is iterated though this structure 10 times. Each time though the round key is updated with a new value.

## 5.4 Counter mode encryption

11 clocks to complete

- Program ASM\_CTRL2[7:5] to 3'b000. Write the key value in the data registers.
- Set the bit "CTR" in ASM\_CTRL1. The "CTR" bit is static.
- Program ASM\_CTRL2 [7:5] to 3'b001. Write the text value in data registers.
- Program ASM\_CTRL2 [7:5] to 3'b010. Write the counter value in data registers.
- Set the START bit in ASM\_CTRL1. The START bit is a self clearing bit.
- Poll for the ASM\_IRQ bit to be set to a "1", or wait for the ASM\_IRQ interrupt signal.
- Program ASM\_CTRL2 [7:5] to 3'b011. Read the encrypted text from data registers.
- Repeat steps 3-7 for each 128 bits block.

# 5.5 AES mode encryption

11 clocks to complete

- Program ASM\_CTRL2[7:5] to 3'b000. Write the key value in the data registers.
- Clear both CTR and CBC bit in ASM\_CTRL1 and set AES bit.
- Program ASM\_CTRL2 [7:5] to 3'b001. Write the text value in data registers.
- Program ASM\_CTRL2 [7:5] to 3'b010. Write the counter value in data registers.
- Set the START bit in ASM\_CTRL1. The START bit is a self clearing bit.
- Poll for the ASM\_IRQ bit to be set to a "1", or wait for the ASM\_IRQ interrupt signal.
- Program ASM\_CTRL2[7:5] to 3'b110. Read the encrypted text from data registers.
- Repeat steps 3-7 for each 128 bits block.

# 5.6 Message Authentication Code generation (MAC)

11 clocks to complete

- Program ASM\_CTRL2 [7:5] to 3'b000. Program the key value in registers
- Set the bit CBC in ASM\_CTRL1.
- Program ASM\_CTRL2 [7:5] to 3'b001.Program the text value in registers
- Set the START bit in ASM\_CTRL1. The START bit is a self clearing bit.
- Poll for the ASM\_IRQ bit to be set to a "1", or wait for the ASM\_IRQ interrupt signal.
- Repeat steps 3-6 for each 128 bits block.
- When all blocks have been processed, program ASM\_CTRL2 [7:5] to 3'b100 and read the final MAC (authentication code) from data registers.
- The MAC accumulator should be cleared to prepare for the next payload. Writing a 1 to the clear bit will set the MAC accumulator back to all 0. The clear bit is self clearing. If for some reason the software needs to continue a MAC calculation from a previously saved value, the MAC accumulator can be pre-loaded with a initial value. Program ASM\_CTRL2 [7:5] to 3'b101 now the value you wish to load into the accumulator is written to data registers and then a 1 is written to the LOAD\_MAC bit. The LOAD\_MAC bit is self clearing.
- After self-test the CBC result register will have some initial value, so if the user wants to start a fresh transaction then the CBC result register has to be cleared by setting the CLEAR bit in the ASM\_CTRL1 register. It will clear all the contents of the CTR and CBC result register.

# Chapter 6 Modem: Interrupts

## 6.1 Introduction

Interrupts provide a way for the radio to inform the host microcontroller (MCU) of onboard events without requiring the MCU to query for status. The following sections describe the interrupt features and sources of the modem.

- 13 interrupt sources (interrupt status bits)
- Each interrupt source individually maskable
- Each interrupt source is individually write-1-to-clear.
- Interrupts remain asserted until cleared.

# 6.2 Modem Interrupt Sources

The radio has a single, active low, interrupt pin (IRQ\_B) provided to the MCU. The interrupt pin is configured as actively-driven by the radio. Internally, the radio has 13 interrupt sources as shown in this table:

| ltem | Interrupt Sources | Mask Bit       | Description                                                                                                                                                                                                                               | Interrupt Clear  |
|------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|      | Status Bit        |                |                                                                                                                                                                                                                                           | Mechanism        |
| 1    | PLL_UNLOCK_IRQ    | PLL_UNLOCK_MSK | PLL Unlock Interrupt. A '1' indicates an unlock event has occurred in the PLL.                                                                                                                                                            | write-1-to-clear |
| 2    | FILTERFAIL_IRQ    | FILTERFAIL_MSK | RX Packet has Failed Filtering. A '1'<br>indicates the most-recently received<br>packet has been rejected due to<br>elements within the packet.<br>In Dual PAN mode, FILTERFAIL_IRQ<br>applies to either or both networks, as<br>follows: | write-1-to-clear |

Table 6-1. Modem Interrupt Sources

Table continues on the next page ....

| Item | Interrupt Sources | Mask Bit    | Description                                                                                                                                                                                                      | Interrupt Clear  |
|------|-------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|      | Status Bit        |             |                                                                                                                                                                                                                  | Mechanism        |
|      |                   |             | A: If PAN0 and PAN1 occupy different<br>channels and CURRENT_NETWORK=0,<br>FILTERFAIL_IRQ applies to PAN0.                                                                                                       |                  |
|      |                   |             | B: If PAN0 and PAN1 occupy different channels and CURRENT_NETWORK=1, FILTERFAIL_IRQ applies to PAN1.                                                                                                             |                  |
|      |                   |             | C: If PAN0 and PAN1 occupy the same channel, FILTERFAIL_IRQ is the logical 'AND' of the individual PANs' Filter Fail status.                                                                                     |                  |
| 3    | RXWTRMRKIRQ       | RX_WMRK_MSK | RX Byte Count Watermark Interrupt. A '1'<br>indicates the number of bytes specified<br>in the RX_WTR_MARK register has<br>been reached.                                                                          | write-1-to-clear |
| 4    | CCAIRQ            | CCAMSK      | CCA Interrupt. A '1' indicates the completion of a CCA operation.                                                                                                                                                | write-1-to-clear |
| 5    | RXIRQ             | RXMSK       | RX Interrupt. A '1' indicates the completion of a receive operation.                                                                                                                                             | write-1-to-clear |
| 6    | TXIRQ             | TXMSK       | TX Interrupt. A '1' indicates the completion of a transmit operation.                                                                                                                                            | write-1-to-clear |
| 7    | SEQIRQ            | SEQMSK      | Sequence Complete Interrupt. A '1'<br>indicates the completion of an<br>autosequence. This interrupt will assert<br>whenever the Sequence Manager<br>transitions from non-idle to idle state, for<br>any reason. | write-1-to-clear |
| 8    | PB_ERR_IRQ        | PB_ERR_MSK  | Packet Buffer Error Interrupt.                                                                                                                                                                                   | write-1-to-clear |
|      |                   |             | 1: Packet Buffer Underrun Error has<br>occurred since the last time this bit was<br>cleared by software                                                                                                          |                  |
|      |                   |             | 0: Packet Buffer Underrun Error has not occurred since the last time this bit was cleared by software.                                                                                                           |                  |
|      |                   |             | <b>Note</b> : PB_ERR_IRQ will occur only<br>when the SPI Packet Buffer access is<br>BURST mode (not BYTE mode)                                                                                                   |                  |
| 9    | WAKE_IRQ          | WAKE_MSK    | Wake Interrupt. Indicates either a Wake-<br>from-POR or Wake-from-HIBERNATE<br>event has occurred.                                                                                                               | write-1-to-clear |
|      |                   |             | The WAKE_FROM_HIB/TMRSTATUS bit indicates which type of wake event occurred, as long as WAKE_IRQ=1.                                                                                                              |                  |
| 10   | TMR1IRQ           | TMR1MSK     | TMR1 Interrupt. Indicates T1CMP comparator value matched event timer counter.                                                                                                                                    | write-1-to-clear |

#### Table 6-1. Modem Interrupt Sources (continued)

Table continues on the next page...

| Item | Interrupt Sources | Mask Bit | Description                                                                                                                                                                    | Interrupt Clear  |
|------|-------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|      | Status Bit        |          |                                                                                                                                                                                | Mechanism        |
| 11   | TMR2IRQ           | TMR2MSK  | TMR2 Interrupt. Indicates comparator<br>value matched event timer counter. This<br>flag is shared between the T2CMP (24-<br>bit) and T2PRIMECMP (16-bit) compare<br>registers. | write-1-to-clear |
| 12   | TMR3IRQ           | TMR3MSK  | TMR3 Interrupt. Indicates T3CMP comparator value matched event timer counter.                                                                                                  | write-1-to-clear |
| 13   | TMR4IRQ           | TMR4MSK  | TMR4 Interrupt. Indicates T4CMP comparator value matched event timer counter.                                                                                                  | write-1-to-clear |

Table 6-1. Modem Interrupt Sources (continued)

Each interrupt can be controlled by an interrupt mask. All interrupts are OR- combined with the external pin IRQ\_B. The IRQ is issued when IRQ\_B is set to 0.

Any or all of the interrupt sources, can be enabled to cause an assertion on IRQ\_B. Each interrupt source has its own interrupt status bit in modems Direct Register space. Each interrupt source is individually maskable (each has its own MASK bit) so that each interrupt source can be individual enabled to trigger an assertion on IRQ\_B.

There is also a global interrupt mask, TRCV\_MSK (PHY\_CTRL4 register), which can enable/disable all IRQ\_B assertions by programming a single masking bit. All 13 interrupt status bits use a write-1-to-clear protocol. Interrupt status bits are not affected by reads. The IRQ\_B pin is a level-sensitive interrupt indicator to the MCU; on an interrupt, IRQ\_B will remain asserted until all active interrupt sources are cleared or masked.

## 6.3 Additional Interrupt Mask and Source Descriptions

Numerous register bits are provided to control interrupt behavior within the modem as shown in the table below. These are described in more detail in the subsequent sections and in the SPI Register Description chapter.

| Field       | R/W | Description                                                                                 | Default |
|-------------|-----|---------------------------------------------------------------------------------------------|---------|
| TRCV_MSK    | rw  | 1: Mask all Interrupts from asserting IRQ_B                                                 | 0       |
|             |     | 0: Enable any Interrupt to assert IRQ_B                                                     |         |
| T1CMP[23:0] | rw  | TMR1 compare value. If TMR1CMP_EN=1 and the Event Timer matches this value, TMR1IRQ is set. | 0xFFF   |
| T2CMP[23:0] | rw  | TMR2 compare value. If TMR2CMP_EN=1 and the Event Timer matches this value, TMR2IRQ is set. | 0xFFF   |

Table 6-2. Interrupt Control Summary

Table continues on the next page ...

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

**Functional Description** 

| Field               | R/W | Description                                                                                                                                                                                                                                                            | Default |
|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| T2PRIMECMP[15:0] rw |     | TMR2-prime compare value. If TMR2CMP_EN=1 and TC2PRIME_EN=1 and the lower 16 bits of Event Timer matches this value, TMR2IRQ is set.                                                                                                                                   | 0xFF    |
| T3CMP[23:0]         | rw  | TMR3 compare value. If TMR3CMP_EN=1 and the Event Timer matches this value, TMR3IRQ is set.                                                                                                                                                                            |         |
| T4CMP[23:0]         | rw  | TMR4 compare value. If TMR4CMP_EN=1 and the Event Timer matches this value, TMR4IRQ is set.                                                                                                                                                                            | 0xFFF   |
| TMR1CMP_EN          | rw  | 1: Allow an Event Timer Match to T1CMP to set TMR1IRQ                                                                                                                                                                                                                  | 0       |
|                     |     | 0: Don't allow an Event Timer Match to T1CMP to set TMR1IRQ                                                                                                                                                                                                            |         |
| TMR2CMP_EN          | rw  | 1: Allow an Event Timer Match to T2CMP or T2PRIMECMP to set TMR2IRQ                                                                                                                                                                                                    | 0       |
|                     |     | 0: Don't allow an Event Timer Match to T2CMP or T2PRIMECMP to set TMR2IRQ                                                                                                                                                                                              |         |
| TMR3CMP_EN          | rw  | 1: Allow an Event Timer Match to T3CMP to set TMR3IRQ                                                                                                                                                                                                                  | 0       |
|                     |     | 0: Don't allow an Event Timer Match to T3CMP to set TMR3IRQ                                                                                                                                                                                                            |         |
| TMR4CMP_EN          | rw  | 1: Allow an Event Timer Match to T4CMP to set TMR4IRQ                                                                                                                                                                                                                  | 0       |
|                     |     | 0: Don't allow an Event Timer Match to T4CMP to set TMR4IRQ                                                                                                                                                                                                            |         |
| TC2PRIME_EN         | rw  | 1: Allow a match of the lower 16 bits of Event Timer to<br>T2PRIMECMP to set TMR2IRQ                                                                                                                                                                                   | 0       |
|                     |     | 0: Don't allow a match of the lower 16 bits of Event Timer to T2PRIMECMP to set TMR2IRQ                                                                                                                                                                                |         |
| RX_WTR_MARK[7:0]    | rw  | Receive byte count (octets) needed to trigger a RXWTRMRKIRQ<br>interrupt. A setting of 0 generates an interrupt at end of the Frame<br>Length field (first byte after SFD). A setting of 1 generates an<br>interrupt after the first byte of Frame Control Field, etc. | 0xFF    |

Table 6-2. Interrupt Control Summary (continued)

# 6.4 Functional Description

# 6.4.1 Interrupt Status Bit Structure

The modem has 13 interrupt sources, each represented in the register map by an interrupt status bit. All interrupt status bits share a common, generic structure. If a particular interrupt source is enabled, a "TRIGGERING EVENT" for that interrupt source will always set the status bit. A write-1-to-clear input from the SPI module will clear the status bit, but only if there is not a simultaneous triggering event. The triggering event will take priority (occur) over a software clear attempt if both events coincide.

The CLK and CLK\_EN are provided by the SPI. This allows interrupt status bits to be read and cleared in the HIBERNATE state, when the modem's crystal oscillator is disabled and the SPI SCLK is the only "clock" available in the IC. The clock gate

guarantees that the status bit sees a clock only when either a triggering event occurs or a write-1-to-clear pulse arrives from the SPI. This reduces interrupt status bit power consumption to an absolute minimum. The common interrupt status bit structure is shown in this figure.





#### NOTE

For any modem interrupt source, if the triggering event occurs, the Interrupt Status Bit will be set regardless of the state of the corresponding MASK bit. If any of the 13 interrupts is to be ignored, software should set the corresponding MASK bit and apply the appropriate bit mask when reading the IRQSTS1, IRQSTS2, or IRQSTS3 register to mask out the unwanted status bit.

## 6.4.2 Clearing Interrupts

All interrupt status bits use a write-1-to-clear protocol. Writing a '1' to the interrupt status bit in any one of the IRQSTS1, IRQSTS2, or IRQSTS3 registers clears the offending interrupt. Writing a '0' to an interrupt status bit has no effect on the bit. Interrupt status bits are not affected by reads.

## 6.4.3 Timer Interrupts

The modem features a 24-bit Event Timer which runs at the 802.15.4 bit rate of 250 kHz. The modem has four timer interrupts (TMR1IRQ, TMR2IRQ, TMR3IRQ, and TMR4IRQ), each with its own 24-bit compare register (T1CMP, T2CMP, T3CMP, and T4CMP) and each with its own compare enable (TMR1CMP\_EN, TMR2CMP\_EN, TMR3CMP\_EN, and TMR4CMP\_EN).

For each timer compare enable:

- If the compare enable bit is set A match on the respective 24-bit compare value to the Event Timer will cause the corresponding interrupt status bit to become set.
- If the compare enable is low Event Timer matches will not cause the corresponding interrupt status bit to become set.

In addition, a 16-bit T2PRIMECMP compare value is provided along with a compareenable bit TC2PRIME\_EN.

• When TC2PRIME\_EN is set and TMR2CMP\_EN is also set - A match on T2PRIMECMP with the *lower 16 bits* of Event Timer will cause TMR2IRQ to become set rather than a full 24-bit compare.

## 6.4.4 PLL Unlock Interrupt

The PLL\_UNLOCK\_IRQ status bit indicates the PLL has come out of lock during a TX, RX or CCA transceiver operation. The modems Sequence Manager will begin monitoring for PLL unlocks only after a complete transceiver warm-up has occurred; unlocks that occur during warm-up will not cause a PLL unlock. A PLL unlock that occurs after the warm-up period will cause a sequence abort.

# 6.4.5 Filterfail Interrupt

The modems Packet Processor performs filtering on all received packets to determine whether the packet is intended for the device based on rules which if violated, will cause a Filterfail interrupt. A Filterfail interrupt will occur during packet reception when a packet fails filtering rules. On a Filterfail interrupt, the FILTERFAIL\_CODE register can be read to ascertain more information about the nature of the filter failure.

#### NOTE

A Filterfail interrupt is not expected to be widely used in mission modes; it has been provided primarily for debug purposes.

#### NOTE

If a packet is received and First-Stage filtering fails (i.e., one or more of bits filterfail\_code[0-3] is set, the Second-Stage filterfail\_code bits, 3-9, should be ignored since the modem's packet processor will not know where to search for PAN ID and address fields in the incoming byte stream for illegal addressing modes.

This table indicates each Filterfail code bit and it respective reason the packet was rejected.

| FILTERFAIL CODE BIT | REASON FOR FILTERFAIL                                                                              |
|---------------------|----------------------------------------------------------------------------------------------------|
| filterfail_code[0]  | Fails Stage 1 Frame Length Checking (FL < 5 or FL > MAXFRAMELENGTH)                                |
| filterfail_code[1]  | Fails Stage 1 Section 7.2.1.1.6 or Section 7.2.1.1.8 Checking (DST_ADDR_MODE or SRC_ADDR_MODE = 1) |
| filterfail_code[2]  | Fails Stage 1 Section 7.2.1.1.5 Checking (Illegal PAN_ID_COMPRESSION Usage)                        |
| filterfail_code[3]  | Fails Stage 1 Frame Version Checking                                                               |
| filterfail_code[4]  | Fails Stage 2 Auto-RxAck Checking (Illegal Ack Frame Format in Sequence TR)                        |
| filterfail_code[5]  | Fails Stage 2 Frame Type Checking (Incorrect Frame Filter Bit setting)                             |
| filterfail_code[6]  | Fails Stage 2 Frame Length Checking (Illegal Beacon, Data, or Cmd FL)                              |
| filterfail_code[7]  | Fails Stage 2 Addressing Mode Checking (Illegal Addressing Mode for Beacon, Data, or Cmd)          |
| filterfail_code[8]  | Fails Stage 2 Sequence Number Matching (Sequence TR Only)                                          |
| filterfail_code[9]  | Fails Stage 2 PAN ID or Address Checking (Beacon, Data, or Cmd)                                    |

#### Table 6-3. Filterfail Codes

### 6.4.6 RX Watermark Interrupt

During packet reception, a RX Watermark interrupt will occur when the number of received bytes matches the contents of the RX\_WTR\_MARK register minus 1.

#### NOTE

For the purpose of defining RX\_WTR\_MARK, the first byte received is the Frame Length field (PHR). The second byte received is the least-significant byte of Frame Control Field, etc.

For example, to cause an RX Watermark Interrupt to occur after the 10th received byte, set RX\_WTR\_MARK=11.

# 6.4.7 CCA Interrupt

The modems Clear Channel Assessment (CCA) has been completed; CCA interrupts occur at the end of both CCA and Energy Detect (ED) measurement intervals. For TX and Slotted (beacon-enabled networks) TX modes, the CCAIRQ is asserted indicating the CCA determined the channel is busy. The result of the CCA measurement is reported back to software in the CCA bit of the IRQSTS2 Register. The CCA bit indicates either a busy channel (1) or an idle channel (0).

# 6.4.8 RX Interrupt

RX interrupts occur at the end of the transceivers RX operation. An RXIRQ in combination with a SEQIRQ is considered a "Data Indication". RX interrupts are not generated on packets which fail FCS (CRC check) or fail packet filtering.

To receive a Data Indication (including RXIRQ) on packets which fail CRC, clear the CRC\_MSK bit of the PHY\_CTR2 register to 0. To inhibit packet filtering and enable Data Indication on packets which would otherwise fail packet filtering rules, set the PROMISCUOUS bit of the PHY\_CTRL4 register to 1.

# 6.4.9 TX Interrupt

TX interrupts (TX\_IRQ) occur at the end of the transceivers TX operation.

# 6.4.10 Sequencer Interrupt

The Sequencer Interrupt (SEQIRQ), indicates that an autosequence has completed and the Sequence Manager has returned to its idle state. A SEQIRQ will always occur at the end of an autosequence even if the autosequence terminated abnormally, such as a Software Abort, a TC3 Timeout or a PLL Unlock Abort.

#### NOTE

The ABORT\_STS register can be read to determine which of these abnormal terminations occurred, if any (see the registers section for more details).

The SEQIRQ always occurs whenever the Sequence Manager transitions from non-idle to idle state. When SEQIRQ occurs, software can be sure that the Sequence Manager is in its idle state and a new sequence can be programmed immediately.

### 6.4.11 Interrupts from Exiting Low Power Modes

The modem has two low power modes which generate an 'Wake' interrupt. A Wake interrupt (WAKE\_IRQ) occurs from either of these two conditions:

- 1. Exit from RESET
- 2. Exit from HIBERNATE

A transition out of RESET or HIBERNATE will always cause a WAKE\_IRQ when unmasked. WAKE\_IRQ is the only modem interrupt whose default state is "unmasked" so the MCU can expect this interrupt without any prior programming of the device. The MCU can interpret the WAKE\_IRQ interrupt as a "Modem Ready" indication.

#### 6.4.11.1 Exiting from RESET

The modem is put into reset and will stay in reset through the assertion of RST\_B (reset bar or RESET). In the interest of lowest power, there is no external pull-up resistor on input RST\_B. As part of the MCU initialization, an internal GPIO is programmed as an output and then driven low to reset the modem. The RST\_B input is asynchronous and needs to be held low for only a short period. In the reset condition, the modem is totally powered down and no clocks are available. Coming out of reset, the WAKE\_IRQ interrupt status bit is set and causes an assertion on IRQ\_B because WAKE\_MSK is 0 by default. After the interrupt request is seen by the MCU, the modem is alive and ready for SPI transactions.

### 6.4.11.2 Exiting from HIBERNATE

The hibernate or low power mode is a specific mode where the XTAL is disabled. The SPI is capable of operation in modem low power modes, except Reset. Going out of hibernate mode through SPI means that the XTAL needs to be start up again, the digital regulator forced to high power mode and a new wake up interrupt (WAKE\_IRQ) is generated as a result.

Operation in Hibernate mode allows most modem registers and the complete Packet Buffer to be accessed in radio's lowest-power operational state thereby, enabling minimal power consumption especially during the register-initialization phase of the IC's software.

#### **Functional Description**

In Hibernate, the SPI operates in "asynchronous mode". To write a register, the SPI module generates both clock and clock enable to the Register block since the crystal oscillator is disabled; for reads, no latching of read-back data takes place since the oscillator is disabled therefore, read-back data cannot change.

#### 6.4.12 Packet Buffer Error Interrupt

A Packet Buffer Error Interrupt, PB\_ERR\_IRQ, indicates that a Packet Buffer Underrun Error has occurred. This condition can occur if a SPI burst read access to the Packet Buffer begins before the incoming packet has been completely received and the SPI Packet Buffer read address overtakes the RX demodulator write address.

Packet Buffer data obtained from a SPI transfer which results in a PB\_ERR\_IRQ has been corrupted and should be discarded. However, the packet contents have not been lost; the PB\_ERR\_IRQ should be cleared and the SPI transfer should then be restarted.

# Chapter 7 Modem: Timer Information

# 7.1 Event Timer Block

The modem contains an internal Event Timer block that manages system timing.

The Event Timer consists of a prescaler and a 24-bit counter which increment whenever the crystal clock is operating (i.e. the modem is not in Hibernate mode). Interrupts to the MCU may be generated when the "current time" of the counter matches several predetermined values set in registers via SPI write operations. The current time is accessible at any time via a SPI read operation as well as programmable via a SPI write operation.

The Event Timer provides the following functions:

- Timer to generate current system time
- Interrupt generation at pre-determined system times
- Abort an RX sequence at pre-determined system time
- Latches "timestamp" value during packet reception
- Initiates timer-triggered sequences

# 7.2 Event Timer Time Base

The Event Timer's base clock (tmr\_clk) is derived from a programmable prescaler that is clocked by the 32 MHz crystal source. The prescaler provides counter input frequencies from 500 kHz down to 15.625 kHz, which sets the granularity and resolution of the current time. The prescaler, and thus the Event Timer only increment when the crystal oscillator is active. The field TMR\_PRESCALE[2:0] at Indirect Access Register 0x28 establishes the tmr\_clk frequency as shown in the following table.

Setting Current Time

| Indirect Access Register 0x28<br>TMR_PRESCALE[2:0] | Event Timer Time Base | Maximum Event Timer Duration |
|----------------------------------------------------|-----------------------|------------------------------|
| 000                                                | Reserved              | Reserved                     |
| 001                                                | Reserved              | Reserved                     |
| 010                                                | 500 kHz               | 33.554 seconds               |
| 011 (default)                                      | 250 kHz               | 67.109 seconds               |
| 100                                                | 125 kHz               | 134.218 seconds              |
| 101                                                | 62.5 kHz              | 268.436 seconds              |
| 110                                                | 31.25 kHz             | 536.871 seconds              |
| 111                                                | 15.625 kHz            | 1073.742 seconds             |

 Table 7-1.
 Event Timer Prescaler Settings

The 24-bit counter automatically rolls over upon reaching its maximum value at the corresponding maximum Event Timer durations also provided in the table.

## 7.3 Setting Current Time

"Current Time" is defined as the value of the Event Timer internal counter. The current time is programmable, but does not have to be programmed. In the reset condition, the modem current time is set to zero. Current time advances from zero at the tmr\_clk clock rate and rolls over to zero after reaching its maximum value.

Programming "current time" is accomplished by using four SPI registers:

- 1. T1CMP\_LSB, Direct Register 0x17, T1CMP[7:0]
- 2. T1CMP\_MSB, Direct Register 0x18, T1CMP[15:8]
- 3. T1CMP\_USB, Direct Register 0x19, T1CMP[23:16]
- 4. PHY\_CTRL4, Direct Register 0x07, Bit 2, TMRLOAD

When field TMRLOAD is programmed to high, the value of "current time" is set to the value in T1CMP[23:0]. Thus, T1CMP[23:0] is first programmed to the desired current time value, then TMRLOAD is programmed to 1, which initiates the timer load. The change to the "current time" value occurs within 3 crystal clock cycles, after which normal incrementing resumes on the next rising tmr\_clk edge. TMRLOAD is not required to be programmed to zero for the Event Timer to resume normal operation. TMRLOAD is a write-only, self-clearing bit. Writing a 0 to TMRLOAD has no effect. The readback value of TMRLOAD is always 0.

# 7.4 Reading Current Time

The current value of the Event Timer can be read via the SPI by reading EVENT\_TMR\_LSB (Direct Register 0x0C) for EVENT\_TMR[7:0], EVENT\_TMR\_MSB (Direct Register 0x0D) for EVENT\_TMR[15:8], and EVENT\_TMR\_USB (Direct Register 0x0E) for EVENT\_TMR[23:16].

The "current time" may be obtained using three single-byte SPI reads or a 3-byte SPI burst read (or as part of a longer burst read operation). It is important to realize that the Event Timer may increment during these SPI read operations or between successive SPI reads if single-byte SPI reads are used. To counter this during such an access, the modem latches the "current time" to protect the MCU from obtaining an incorrect value. The "current time" most significant 16 bits (MSB, USB) are latched when the least significant 8 bits (LSB) SPI location is read. This guarantees a stable value until the MCU completes a read of all 3 bytes constituting the "current time" before it is allowed to update. If such latching is undesired, it can be turned off by setting the

EVENT\_TMR\_DO\_NOT\_LATCH bit to 1. The EVENT\_TMR\_DO\_NOT\_LATCH bit resides in the SEQ\_MGR\_CTRL register (Indirect Access Register 0x3A, bit 3).

#### NOTE

The preferred procedure to obtain the "current time" value from the modem is to perform a 3-byte burst read of the "current time" starting at the LSB address.

# 7.5 Latching the Timestamp

The modem has the ability generate a Timestamp, or to latch a copy of the "current time" while continuing to increment its internal counter. This timestamp value latched within the Event Timer corresponds to the beginning of a receive packet where the actual packet data begins after the SFD (Start-of-Frame-Delimiter) has been received. The timestamp[23:0] can be accessed via SPI by reading TIMESTAMP\_LSB (Direct Register 0x0F) for timestamp[7:0], TIMESTAMP\_MSB (Direct Register 0x10) for timestamp[15:8], and TIMESTAMP\_USB (Direct Register 0x11) for timestamp[23:16]. The timestamp remains latched until another packet is received at which point the timestamp[23:0] value is updated and re-latched.

# 7.6 Event Timer Comparators

The modem incorporates four full 24-bit programmable fields that compare to the Event Timer's "current time". The intent of these compares are to enable the host to schedule events relative to the "current time". When a match between the "current time" and any one of the four timer compare values occurs, a corresponding flag is sent to internal interrupt logic. This causes the appropriate bit in the IRQSTS3 register (Direct register 0x2) to be set and depending on the interrupt mask control bit, generate an interrupt event on the IRQ\_B pin.

### 7.6.1 Timer Compare Fields

There are four 24-bit timer compare fields and one 16-bit timer compare field:

- 1. T1CMP[23:0], (T1CMP\_LSB, T1CMP\_MSB, T1CMP\_USB), Direct Address 0x17, 0x18, 0x19 respectively.
- 2. T2CMP[23:0], (T2CMP\_LSB, T2CMP\_MSB, T2CMP\_USB), Direct Address 0x1A, 0x1B, 0x1C respectively.
- 3. T3CMP[23:0], (T3CMP\_LSB, T3CMP\_MSB, T3CMP\_USB), Direct Address 0x12, 0x13, 0x14 respectively.
- 4. T4CMP[23:0], (T4CMP\_LSB, T4CMP\_MSB, T4CMP\_USB), Direct Address 0x1D, 0x1E, 0x1F respectively.

Additionally, there is a special 16-bit timer compare field for situations where the upper byte of EVENT\_TMR is a 'don't care' case.

1. T2PRIMECMP[15:0], (T2PRIMECMP\_LSB, T2PRIMECMP\_MSB), Direct Address 0x15 and 0x16 respectively.

The TMR2IRQ status bit can be set by a match to T2CMP or T2PRIMECMP:

- If register bit TC2PRIME\_EN=1 (PHY\_CTRL4 register, Direct Address 0x7, bit 0), then TMR2IRQ becomes set by a match to T2PRIMECMP (16-bit compare).
- If TC2PRIME\_EN=0, then TMR2IRQ becomes set by a match to T2CMP (24-bit compare).

## 7.6.2 Timer Compare-Enable Bits

Each timer comparator has a enable bit that enables or disables the compare function. To enable, write a "1" to the corresponding comparator. The default condition is the timer disabled (reset to "0"):

- 1. TMR1CMP\_EN, PHY\_CTRL3 Register, Direct Address 0x05, bit 4
- 2. TMP2CMP\_EN, PHY\_CTRL3 Register, Direct Address 0x05, bit 5
- 3. TMR3CMP\_EN, PHY\_CTRL3 Register, Direct Address 0x05, bit 6
- 4. TMR4CMP\_EN, PHY\_CTRL3 Register, Direct Address 0x05, bit 7

If a timer comparator is enabled using its associated bit, the corresponding interrupt status bit (TMRxIRQ) will be set by a timer compare match to its respective TxCMP register. If a timer comparator is disabled using its associated bit, the corresponding interrupt status bit (TMRxIRQ) will not be set by a timer compare match to its respective TxCMP register.

# 7.6.3 Timer Interrupt Status Bits

When enabled, all four fields can be continuously compared to the current value of the Event Timer counter. When a match occurs, the following corresponding internal status flags assert:

- 1. TMR1IRQ, IRQSTS3 Register, Direct Address 0x02, bit 0
- 2. TMR2IRQ, IRQSTS3 Register, Direct Address 0x02, bit 1
- 3. TMR3IRQ, IRQSTS3 Register, Direct Address 0x02, bit 2
- 4. TMR4IRQ, IRQSTS3 Register, Direct Address 0x02, bit 3

The four interrupt status bits are write-1-to-clear. The status bit remains set until a 1 is written to the bit location in the IRQSTS3 register. Writing 0 to the bit or reading the bit will not change its state.

# 7.6.4 Timer Interrupt Masks

When a comparator match occurs and the internal status flag asserts, the following interrupt masks can enable an interrupt on the IRQ pin:

- 1. TMR1MSK, IRQSTS3 Register, Direct Address 0x02, bit 4
- 2. TMR2MSK, IRQSTS3 Register, Direct Address 0x02, bit 5
- 3. TMR3MSK, IRQSTS3 Register, Direct Address 0x02, bit 6
- 4. TMR4MSK, IRQSTS3 Register, Direct Address 0x02, bit 7

If the interrupt mask is set to "1" (masked), the respective interrupt status bit, TMRxIRQ, will not cause an interrupt on the IRQ\_B pin. If the interrupt mask is set to "0" (enabled), the respective interrupt status bit, TMRxIRQ, will cause an interrupt on the IRQ\_B pin. Timer mask bits, TMRxMSK, have no effect on the state of the TMRxIRQ interrupt status bits; they only allow (or prevent) the respective TMRxIRQ bit from generating an interrupt on IRQ\_B.

### 7.6.5 Setting Compare Values

Because the primary timer compare fields are 24-bit values, they are each shared across 3 sequential SPI register addresses. The timer compare value can be changed using 3 single-byte SPI writes, one 3-byte SPI burst write or as part of a longer multi-byte write operation.

#### Note

Not all bits of the timer compare value are updated simultaneously by the SPI. To prevent the Event Timer from generating a false match to a partially updated timer compare value, software should clear the respective TMRxCMP\_EN bit prior to changing the timer compare register TxCMP. Once TxCMP has been updated, software can re-enable the respective TMRxCMP\_EN bit.

# 7.7 Intended Event Timer Usage

It is intended that the system use the "current time" value and the timer compare functions of the Event Timer to schedule system events, including:

- Generating time-based interrupts
- Abort an RX operation
- Triggering transceiver operations

### 7.7.1 Generating Time-Based Interrupts

Generating time-based interrupts is accomplished by setting timer compare values relative to the "current time" allowing the Event Timer counter to increment until a timer compare match is generated, and using this match to generate an interrupt to the host. The general procedure is as follows:

- 1. Disable the timer compare.
- 2. Enable the timer compare interrupt mask.
- 3. Read the "current time" value from event\_tmr[23:0].
- 4. Add an offset to the "current time" value to equal the desired "future time".
- 5. Program the appropriate timer\_compare value (TxCMP) to "future time".
- 6. Program the appropriate TMRxCMP\_EN bit to enable the compare.
- 7. Allow a timer compare match to set the status register bit and generate an interrupt (see the Timer Interrupt Status Bits section). The appropriate internal status register bit is always set upon a TxCMP match. An external interrupt is generated when the corresponding SPI interrupt mask bit, TMRxMSK, is clear.
- 8. Program the appropriate TMRxCMP\_EN bit to disable the compare function. If this is not done, the compare function will continue to run and generate another interrupt every time the counter rolls over and again matches the comparator.

### 7.7.2 Using T3CMP to Abort an RX operation

The Event Timer provides a timer-based mechanism to automatically abort an RX operation. The modem is put into an RX operation when XCVSEQ[2:0] (PHY\_CTRL1 register, Direct Address 0x03) is set to 0x01. An RX autosequence will commence and will begin a search for preamble. Software can program, in advance, a hardware timeout to occur such that the RX autosequence can be automatically aborted by hardware after a certain amount of time elapses without a packet being detected.

The general procedure is as follows:

- 1. Read the "current time" value from EVENT\_TMR[23:0].
- 2. Add an offset to the "current time" value to equal desired "future time" to abort the RX operation.

#### Intended Event Timer Usage

- 3. Program register T3CMP[23:0] to value "future time".
- 4. Program TC3TMOUT, (PHY\_CTRL4 Register, Direct Address 0x07, bit 6) to 1, to enable the hardware aborting of the RX operation.
- 5. Program XCVSEQ=1, to start the RX autosequence.
- 6. When "current time" equals T3CMP[23:0], the modem aborts the RX autosequence and the Sequence Manager returns to SEQ\_IDLE state. The SEQIRQ interrupt status bit (IRQSTS1 Register, Direct Address 0, bit 0) will be set, and the TMR3IRQ interrupt status bit will also be set. The RXIRQ interrupt status bit (IRQSTS1 Direct Address 0, bit 2) will not be set since no packet was received before the timeout.

#### 7.7.3 Using T2CMP or T2PRIMECMP to Trigger Transceiver Operations

The Event Timer provides a timer-based mechanism to automatically launch a transceiver autosequence. Using this method, a sequence can be "scheduled" for time in the future, and the MCU can be put into a reduced power state, without the need to wake up at the appropriate time to start the autosequence.

The general procedure is as follows:

- 1. Read the "current time" value from EVENT\_TMR[23:0].
- 2. Add an offset to the "current time" value to equal desired "future time" to launch the autosequence.
- 3. For either a 24-bit or a 16-bit compare:
  - For a 24-bit compare: program register T2CMP[23:0] to value "future time", and set TC2PRIME\_EN=0.
  - For a 16-bit compare: program register T2PRIMECMP[15:0] to value "future time", and set TC2PRIME\_EN=1.
- 4. Set TMRTRIGEN=1 and program the desired autosequence into XCVSEQ[2:0]. Both TMRTRIGEN and XCVSEQ fields reside in the PHY\_CTRL1 register (Direct Address 0x03).
- 5. When "current time" equals T2CMP[23:0] (for a 24-bit compare), or T2PRIMECMP[15:0] (for a 16-bit compare), the modem will launch the scheduled autosequence in accordance with the XCVSEQ[2:0] field. The TMR2IRQ interrupt status bit will become set.

6. The MCU can wake up at this point (if TMR2MSK=0), or can elect to continue in low-power mode until the autosequence completes, at which time SEQIRQ will become set. If SEQMSK=0, then SEQIRQ will interrupt the MCU at the completion of the transceiver operation.

Intended Event Timer Usage

# Chapter 8 Modem SPI Interface

# 8.1 Modem SPI Overview

The modem's SPI interface allows an MCU to communicate with the modem's register set and Packet Buffer. The modem's SPI is a slave-only interface; the MCU must drive R\_SSEL\_B, R\_SCLK and R\_MOSI. Write and read access to both Direct and Indirect registers is supported, and transfer length can be single-byte, or bursts of unlimited length. Write and read access to the Packet buffer can also be single-byte, or a burst mode of unlimited length. The modem's SPI interface is asynchronous to the rest of the IC. No relationship between R\_SCLK and the modem's internal oscillator is assumed. And no relationship between R SCLK and the CLK OUT pin is assumed. All synchronization of the SPI interface to the modem IC takes place inside the SPI module, alleviating the burden on other block designers to provide this synchronization internal to their modules. SPI synchronization takes place in both directions: SPI-to-IC (register writes), and IC-to-SPI (register reads). The SPI is capable of operation in all modem Power Modes, except Reset. Operation in Hibernate mode allows most modem registers, and the complete Packet Buffer, to be accessed in the modem's lowest-power operational state, enabling minimal power consumption, especially during the register-initialization phase of the IC. The SPI design features a compact, single-byte control word, reducing SPI access latency to a minimum. Most SPI access types require only a single-byte control word, with the address embedded in the control word. During control word transfer (the first byte of any SPI access), the contents of the IRQSTS1 register (the modem's highest-priority status register) are are always shifted out, so that the MCU gets access to IRQSTS1, with the minimum possible latency, on every SPI access.

# 8.2 Modem SPI Basic Operation

The modem operates as a SPI slave only. The microcontroller supplies the interface clock and acts as SPI master.

# 8.2.1 SPI Pin Definition

## 8.2.1.1 Radio Select SEL (R\_SSEL\_B)

The MCU Master SPI selects and activates the modem's Slave SPI by asserting R\_SSEL\_B (low).

## 8.2.1.2 Radio SPI Clock (R\_SCLK)

The MCU Master SPI provides a serial bit clock to the modem's Slave SPI on R\_SCLK.

## 8.2.1.3 Radio MOSI - Master Data Out Slave Data In (R\_MOSI)

The MCU Master SPI transmits Control, Address and Write data to the modem's SPI Slave on R\_MOSI.

## 8.2.1.4 Radio MISO - Master Data In, Slave Data Out (R\_MISO)

The modem's Slave SPI transmits readback data to the MCU Master SPI on R\_MISO.

## 8.2.1.4.1 Setting R\_MISO Off Impedance

MISO\_HIZ\_EN - Determines the output state of the modem's R\_MISO output when R\_SSEL\_B is deasserted (high).

- 1: R\_MISO output is tristated (default)
- 0: R\_MISO output is driven low by the SPI slave

## 8.2.1.4.2 R\_MISO Pull-up Requirement

Because the modem tri states its R\_MISO output when a SPI transfer is not in progress (R\_SSEL\_B deasserted), a pull-up is required to ensure that the SPI Master does not see a floating MISO input.

In a configuration consisting of only a single Master (MCU) and single Slave (the modem), this pull-up can be an internal pull-up on the MCU's MISO input. Moreover, after initialization, the modem's MISO\_HIZ\_EN bit can be cleared (enabling the modem to drive R\_MISO at all times), and the MCU pull-up can be disabled.

In a configuration consisting of more than just 1 SPI master and 1 SPI slave, the pull-up on R\_MISO should be external, and the MISO\_HIZ\_EN bit should be left in its default state.

# 8.2.2 SPI Timing

### 8.2.2.1 SPI Transfer Protocol

The modem's SPI is a slave-only interface, and follows a CPHA=0 and CPOL=0 protocol. Taken together, CPHA and CPOL determine the clock polarity and clock edge used to transfer data between the SPI master and slave, in both communication directions. CPHA=0 (clock phase) indicates that data is captured on the leading edge of SCK and changed on the following edge. CPOL=0 (clock polarity) indicates the inactive state value of R\_SCLK is low. All data is transferred MSB-first. The following diagram depicts the transfer protocol of the modem's SPI.



Figure 8-1. Transfer Protocol of the modem's SPI

## 8.2.2.2 SPI Timing: R\_SSEL\_B to R\_SCLK

The following diagram describes timing constraints that must be guaranteed by the system designer.



Figure 8-2. SPI Timing of R\_SSEL to R\_SCLK

tCSC (CS-to-SCK delay): 31.25ns

tASC (After SCK delay): 31.25ns

tDT (Minimum CS idle time): 62.5ns

tCKH (Minimum SCLK high time): 31.25ns (for SPI writes); 55ns (for SPI reads)

tCKL (Minimum SCKH high time): 31.25ns (for SPI writes); 55ns (for SPI reads)

### NOTE

The SPI Master device shall only deassert R\_SSEL\_B on byte boundaries, and only after guaranteeing the tASC constraint shown above.

# 8.3 SPI Transactions

# 8.3.1 SPI Control Word

Every SPI transaction begins with one single-byte control word. The control word consists of the address, direction (write or read), transaction target (register or Packet Buffer), and for the Packet Buffer, the access mode (burst or byte). For most transactions, data transfer follows immediately after the control word. However, for Indirect Access Register transactions, and for Packet Buffer byte-mode transactions, an additional address byte follows the control word, before data transfer begins. Bit 7 of the control word selects the transfer direction (1=READ, 0=WRITE). Bit 6 selects the transfer target (1=PACKET BUFFER, 0=REGISTER). For Register accesses, the remaining bits select the register address. For Packet Buffer Access, bit 5 selects the access mode (1=BYTE, 0=BURST). For Packet Buffer Access, the remaining bits in the control word are reserved and ignored by the modem. Details and examples of control word usage appear in the following sections. The following table depicts an overview of the control word.

| Bit 7 | Bit 6 | Bit 5 | Bit 4                  | Bit 3    | Bit 2  | Bit 1 | Bit 0 | Access Mode                | Access Type |
|-------|-------|-------|------------------------|----------|--------|-------|-------|----------------------------|-------------|
| 1     | 0     |       | Reg                    | ister ad | dress  | [5:0] |       | Pogistor Accoss            | Read        |
| 0     | 0     |       | Register address [5:0] |          |        |       |       | Register Access            | Write       |
| 1     | 1     | 0     | Reserved               |          |        |       |       | Packet Buffer Burst access | Read        |
| 0     | 1     | 0     |                        | Reserved |        |       |       | Packet Burler Burst access | Write       |
| 1     | 1     | 1     |                        | R        | eserve | d     |       | Packet Buffer Byte access  | Read        |
| 0     | 1     | 1     |                        | R        | eserve | d     |       | Packet burler byte access  | Write       |

Figure 8-3. Control Word Overview

## 8.3.2 Direct Register Write Access (single byte)

The following diagram depicts a single-byte write access to a Direct Register in the modem.



Figure 8-4. Single-Byte Write Access to a Direct Register

# 8.3.3 Direct Register Read Access (single byte)

The following diagram depicts a single-byte read access to a Direct Register in the modem.



Figure 8-5. Single-Byte read Access to a Direct Register

# 8.3.4 Direct Register Write Access (multi byte)

The following diagram depicts a multi-byte write access to Direct Register space in the modem.



Figure 8-6. Multi-Byte Write Access to a Direct Register Space

# 8.3.5 Direct Register Read Access (multi byte)

The following diagram depicts a multi-byte read access to Direct Register space in the modem.



Figure 8-7. Multi-Byte Read Access to a Direct Register Space

# 8.3.6 Indirect Register Write Access (multi byte)

The following diagram depicts a multi-byte write access to Indirect Register space in the modem.



Figure 8-8. Multi-Byte Write Access to an Indirect Register Space

### NOTE

Multi-byte SPI transactions to an Indirect Address space are not permitted in Hibernate state. Use single-byte transactions only.

# 8.3.7 Indirect Register Read Access (multi byte)

The following diagram depicts a multi-byte read access to Indirect Register space in the modem.



Figure 8-9. Multi-Byte Read Access to an Indirect Register Space

**NOTE** Multi-byte SPI transactions to Indirect Address space are not permitted in Hibernate state. Use single-byte transactions only.

# 8.3.8 Synchronous and Asynchronous Operating Modes

The SPI module is designed to be fully operational in all modem power states, except reset. Operation in the Hibernate state means the modem's crystal oscillator is disabled. Most modem registers, direct and indirect, can be accessed, both read and write, during HibernateIn all non-Hibernate states, the SPI operates in "synchronous mode"; to write a register, the SPI module generates a clock enable to the Register block, where the enable is used to gate the 32MHz oscillator to each individual register; for reads, the readback data is registered using the 32MHz clock at the end of the SPI address phase, so that readback data cannot change during shift-out on R\_MISO. In Hibernate, the SPI operates in "asynchronous mode"; to write a register, the SPI module generates both clock and clock enable to the Register block (because the crystal oscillator is disabled); for reads, no latching of readback data takes place, since the oscillator is disabled, readback data cannot change.

The SPI module automatically determines its operating state, based on the xtal\_ready signal from the crystal oscillator. This signal is captured by the SPI module during the SPI address phase, during the first R\_SCLK period. If it is high, the SPI operates in synchronous mode (as described above) for the duration of the SPI transaction. If xtal\_ready is captured low, the SPI operates in asynchronous mode (as described above) for the duration ends when R\_SSEL\_B is deasserted.

Transitions on xtal\_ready are triggered by a SPI write access to the PWR\_MODES register. A SPI write to clear the XTALEN bit of the PWR\_MODES register will cause an immediate high-to-low transition of xtal\_ready; this transition occurs at the end of the SPI transfer, after the last data bit is shifted in on R\_MOSI. No further registers can be written during this transfer, even if the transaction is multi-byte, because the PWR\_MODES registers is at the end of Direct Address space. A SPI write to set the XTALEN bit of PWR\_MODES register will cause a delayed low-to-high transition on xtal\_ready, because there is a finite crystal warm-up time. The SPI module will continue to operate in asynchronous mode, until a new SPI transaction starts with xtal\_ready asserted.

# 8.3.9 Shifting Out IRQSTS1 During Control Word

During each SPI transaction, while the control word is being shifted in on R\_MOSI (SPI address phase), the SPI module always shifts out the contents of Direct Register 0 "IRQSTS1" on R\_MISO. The IRQSTS1 register is the highest-priority register in the modem; it contains the transceiver interrupt status bits, and must be accessed with low latency on any 802.15.4 interrupt. Because multiple registers must be accessed on transceiver interrupts, Direct Register space has been designed to put the highest-priority registers at the beginning of address space. A single, multi-byte transfer can be performed to access all of these registers. For such interrupt-driven SPI transfers, software can take advantage of the automatic shifting of IRQSTS1 during the SPI address phase, by programming a multi-byte SPI transfer to begin at Address 1 (not Address 0), because Address 0 data is provided "for free" on R\_MISO during the control word phase. Thus, a 7-byte SPI transfer (to read Direct Registers 0 through 6) would require only 7 x 8 = 56 SPI clock periods, instead of 64 clock periods, which would be the case if Register 0 had to be addressed explicitly during such a transaction. The following diagram depicts the latency advantage that can be gained using this approach.



Figure 8-10. IRQSTS1 on R\_MISO During Control Word

# 8.3.10 Packet Buffer

The Packet Buffer is a 128-byte Random Access Memory (RAM) dedicated to the storage of 802.15.4 packet contents for both TX and RX sequences. For TX sequences, software stores the contents of the packet buffer starting with the Frame Length byte at Packet Buffer Address 0, followed by the packet contents at the subsequent Packet Buffer Addresses. For RX sequences the incoming packet's Frame Length is stored in a register, external to the Packet Buffer.Software will read this register to determine the number of bytes of Packet Buffer to read. This facilitates DMA transfer through the SPI. For receive packets, an LQI byte is stored at the byte immediately following the last byte of the packet (Frame Length +1).

The Packet Buffer is not a FIFO. It is a byte-addressable memory capable of burst-mode transfers. Reading from the Packet Buffer does not destroy its contents. As long as no subsequent received packets are received, the Packet Buffer may be downloaded as many times as desired and the contents will not change.

## 8.3.10.1 Packet Buffer Architecture

The 802.15.4 standard specifies a maximum packet size of 127 bytes. The Packet Buffer is sized to accommodate a maximum-length packet, plus one additional byte. For TX, this additional byte is the "Frame Length" byte, or PHR, as it is known in 802.15.4

nomenclature. Software loads the Frame Length byte into address 0 of the Packet Buffer (the first data phase of a multi-byte SPI burst). The packet contents (PSDU) follow. The following diagram depicts the 802.15.4 packet structure, detailing the PHR and PSDU.





The last 2 bytes of PSDU are CRC bytes for the 802.15.4 FCS (Frame Check Sequence). The radio hardware computes and transmits these 2 bytes automatically, so software need not load them into the Packet Buffer. Thus, for TX sequences, the number of bytes to load into the buffer, after Frame Length, is "Frame Length - 2". For RX, the received Frame Length is routed to a SPI-readable register, RX FRAME LENGTH, not the Packet Buffer. The remainder of the packet's PSDU, is stored in the Packet Buffer, starting at address 0. At Data Indication, software should read the RX FRAME LENGTH register to determine the number of bytes of Packet Buffer it needs to read, in order to download the entire packet via SPI transfer. A DMA transfer can be set up to perform the transfer, if the MCU is so equipped. The PSDU includes the 2 received FCS bytes. For RX packets, after the last packet FCS byte, an LQI byte is stored. Therefore, to download the entire packet plus LQI from the packet buffer, the number of bytes (data phases) in the SPI burst will be RX\_FRAME\_LENGTH+1, where RX FRAME LENGTH is the contents of the register of the same name. The following diagram depicts the contents of a TX buffer containing a maximum-length packet (just prior to transmission), and an RX buffer containing a maximum length packet (just after a data indication).

Packet Buffer SPI Transactions



Figure 8-12. Packet buffer architecture

# 8.3.10.2 Packet Buffer SPI Transactions

## 8.3.10.2.1 Packet Buffer Access Modes: Burst Mode vs Byte Mode

Burst mode is recommended for Packet Buffer uploading (TX) and downloading (RX). For Packet Buffer Burst mode, no Packet Buffer address need be provided by the SPI. SPI hardware will always start the burst at Packet Buffer address 0. A single SPI transfer of up to 128 bytes can be used for either uploading or downloading in burst mode. This, in combination with DMA, reduces SPI latency to an absolute minimum.

In case the user desires to access an individual byte within the Packet Buffer, and not the entire buffer, a "Byte" access mode has also been provided. In this mode, the SPI transfer's second byte indicates the starting Packet Buffer address for the transfer. The subsequent bytes write (or read) Packet Buffer contents, starting at the indicated address. Byte mode is less efficient than Burst mode, because an address byte must follow the SPI control word.

In both Byte and Burst modes, there is no hardware limit to the number of bytes that can be uploaded or downloaded through the SPI. If a SPI transfer of greater than 128 bytes is attempted, the Packet Buffer address will wrap around to 0 after Packet Buffer address 127 has been accessed.



Figure 8-13. Packet Buffer Write (Burst Mode)

### 8.3.10.2.2 Packet Buffer Write Access (Burst Mode)

The following diagram depicts a SPI burst-mode write access to the Packet Buffer.



Figure 8-14. Packet Buffer Write (Burst Mode)

### 8.3.10.2.3 Packet Buffer Read Access (Burst Mode)

The following diagram depicts a SPI burst-mode read access to the Packet Buffer.



Figure 8-15. Packet Buffer Read (Burst Mode)

### 8.3.10.2.4 Packet Buffer Write Access (Byte Mode)

The following diagram depicts a SPI byte-mode write access to the Packet Buffer.



Figure 8-16. Packet Buffer Write (Byte Mode)

### 8.3.10.2.5 Packet Buffer Read Access (Byte Mode)

The following diagram depicts a SPI byte-mode read access to the Packet Buffer.



Figure 8-17. Packet Buffer Read (Byte Mode)

## 8.3.10.3 Handling of Auto-RXACK Packets

According to 802.15.4 protocol, when a packet is transmitted by a device, an acknowledge packet is often expected from the intended recipient. The radio features a hardware autosequence to transmit a packet, and wait for an acknowledge packet. This autosequence is initiated by programming a "Sequence TR" with RXACKRQD=1. During this autosequence, the received acknowledge packet is not stored in the Packet Buffer. The Packet Processor (hardware) merely checks the incoming packet for correct Sequence Number and FCS, and notifies software when the correct Acknowledge packet is received.

However, in Active Promiscuous mode, all received packets must be made available to software. Therefore in Active Promiscuous mode, auto-RXACK packets will be stored in the Packet Buffer.

Packet Buffer SPI Transactions

## 8.3.10.4 Downloading Packet Buffer Contents During Reception

For packet reception, it is recommended that software wait for Data Indication prior to downloading Packet Buffer contents. This approach takes full advantage of the radio's Packet Processor hardware to check if the incoming packet was intended for the device, and for the FCS-check logic to verify CRC. However, hardware does not prohibit reading of Packet Buffer content while a packet is being received. Early downloading can mean earlier software access to packet contents for software processing, which can be advantageous during periods of high software workload or short turnaround requirements. To download the Packet Buffer during reception, the following steps should be followed:

- 1. Set the RX\_WTR\_MARK register to trigger a RXWTRMRKIRQ interrupt after the Nth byte of the packet has been received. The RX\_WTR\_MARK threshold corresponds directly to Packet Buffer address, plus 1. So, if an RXWTRMRKIRQ is desired after Packet Buffer address 7 has been loaded with receive data, set RX\_WTR\_MARK=8.
- 2. Unmask the RXWTRMRKIRQ by programming RX\_WMRK\_MSK=0 in the PHY\_CTRL2 register.
- 3. Unmask the PB\_ERR\_IRQ by programming PB\_ERR\_MSK=0 in the PHY\_CTRL3 register.
- 4. At the RXWTRMRKIRQ interrupt, read the RX\_FRAME\_LENGTH register to determine the ultimate length of the packet. At this point, the entire Packet Buffer has not been loaded with receive data, but the first "N" bytes (at least) are available, where N = RX\_WTR\_MARK-1.
- 5. Begin the SPI burst transfer of length "RX\_FRAME\_LENGTH", (or "RX\_FRAME\_LENGTH+1" to also get LQI) to download the Packet Buffer contents.

Caution must be used when using early downloading:

- 1. At Data Indication (which will occur some time after RXWTRMRKIRQ), software must check the validity of the received packet. At SEQIRQ, if RXIRQ is also asserted (IRQSTS1 register), then the packet passed filtering and FCS. Otherwise, it failed either filtering, CRC, or both.
- 2. It is responsibility of the user to select a combination of SPI Transfer Rate, and RX\_WTR\_MARK threshold, to ensure that the SPI does not attempt to read from Packet Buffer addresses that have not yet been loaded with receive data (i.e., an underrun condition). The SPI transfer rate is determined by the SCLK frequency of the SPI Master. Receive data is loaded into the Packet Buffer at a constant rate of 1 byte every 32 µs, so in general the SPI transfer rate will be considerably faster than the buffer loading rate. Software must calculate the number of bytes to be

downloaded (based on RX\_FRAME\_LENGTH), and then set the RX\_WTR\_MARK threshold based on the ratio of SPI transfer rate to buffer loading rate.

If the steps above have not been followed correctly, and a Packet Buffer underrun occurs, this means the SPI read address of the Packet Buffer has overtaken the RX demodulator write address. A PB\_ERR\_IRQ interrupt will be raised to indicate this condition. A PB\_ERR\_IRQ is not catastrophic. The following steps should be taken to recover from a PB\_ERR\_IRQ:

- 1. Abort the SPI transfer in progress, and discard the data received so far, because the SPI transfer has been corrupted.
- 2. Clear the PB\_ERR\_IRQ by writing a '1' to the PB\_ERR\_IRQ bit in the IRQSTS2 register.
- 3. Restart the SPI transfer to download the Packet Buffer again. The design of the Packet Buffer ensures that read data has not been lost.

# 8.3.10.5 Registers Related to Packet Buffer Operation

PB\_ERR\_IRQ - Indicates that a Packet Buffer Underrun Error has occurred. This condition can occur if a SPI burst read access to the Packet Buffer begins before the incoming packet is completely received, and the SPI PB read address overtakes the RX demodulator write address. (See Downloading Packet Buffer Contents During Reception for information on how to avoid this condition, and what to do if it does occur). Software must write a '1' to this bit to clear the interrupt. The PB\_ERR\_IRQ interrupt can occur only during SPI BURST accesses to Packet Buffer; SPI BYTE mode accesses to Packet Buffer will not trigger a PB\_ERR\_IRQ even if the SPI address is greater than the RX Demodulator address.

1: Packet Buffer Underrun Error has occurred since the last time this bit was cleared by software

0: Packet Buffer Underrun Error has not occurred since the last time this bit was cleared by software

ACTIVE\_PROMISCUOUS - Normally, received packets that are of Frame Type "Acknowledge", received in response to a packet transmitted by the radio, are not stored in the Packet Buffer. Such packets are expected during a Sequence TR with RXACKRQD=1. In Active Promiscuous mode, software must have access to all receive packet data, even "auto-RXACK" packets. This bit allows such packets to be stored in the Packet Buffer.

1: Allow "auto-RXACK" packets to be stored in the Packet Buffer

0: Don't allow "auto-RXACK" packets to be stored in the Packet Buffer (default)

# 8.4 Configuring MCU for Proper SPI Operation

The MCU port control must be configured as follows to operate with the modem SPI:

- PTB10 should be configured as SPI1\_PCS0
- PTB11 should be configured as SPI1\_SCK
- PTB16 should be configured as SPI1\_SOUT
- PTB17 should be configured as SPI1\_SIN. Also, the default configuration of the modem R\_MISO is that the modem tri-states this output when the R\_SSEL\_B is not asserted. The PTB17 pad should be configured with a pull-up or pull-down enabled.

The MCU DSPI module must also be configured for proper operation to meet the modem SPI transaction format. The following conditions must be met:

- MCU is master
- Maximum baud rate is 9 MHz for reads, and 16 MHz for writes
- Proper clock format must be selected, i.e., CPHA=0 and CPOL=0
- SPI data must be transferred MSB first
- The following modem SPI timings parameters must not be violated:
  - t<sub>CSC</sub> (R\_SSEL\_B assertion to SCK delay) must be no less than 31.25ns
  - t<sub>ASC</sub> (SCK to R\_SSEL\_B deassertion delay) must be no less than 31.25ns
  - t<sub>DT</sub> (R\_SSEL\_B deasserted idle time) must be no less than 62.5ns

The following sections describe the DSPI configuration in more detail. Refer to the MCU: Serial Peripheral Interface (SPI) chapter.

# 8.4.1 DSPI Mode Configuration

The following DSPI1 register settings are required to communicate correctly with the modem SPI:

- MSTR (SPI1\_MCR, bit 31). MSTR =1 to configure the DSPI for master mode
- PCSIS[0] (SPI1\_MCR, bit 16). PCSIS[0]=1 must be set to indicate that the inactive state of PCS0 is high
- CPOL (SPI1\_CTARn, bit 26) CPOL=0 to select the correct clock polarity (active high / inactive low)
- CPHA (SPI1\_CTARn, bit 25) CPHA=0 to select the correct clock phase (data captured on rising edge, changed on falling edge)
- LSBFE (SPI1\_CTARn, bit 24) LSBFE=0 to transfer data MSB first

# 8.4.2 DSPI Baud Rate

The DSPI baud rate needs to be configured so that it is no more than 9MHz for modem SPI reads and 16MHz for modem SPI writes. The DSPI baud rate is determined by the MCU bus clock frequency, as well as by several programmable register bits in the DSPI.

- PBR (SPI1\_CTARn, bits 17:16) selects the baud rate prescaler value
- BR (SPI1\_CTARn, bits 3:0) select the baud rate scaler
- DBR (SPI1\_CTARn, bit 31) selects a double baud rate mode

As an example, assuming a 50MHz bus clock, PBR could be programmed for a divideby-3 value, BR could be programmed for a divide-by-2 value, and DBR could be programmed to 0 to achieve an 8.3MHz SPI clock rate. For SPI writes, the PBR could be changed to a divide-by-2 value to realize a 12.5MHz SPI clock rate.

If a 32MHz bus clock is used, PBR could be programmed for a divide-by-2 value, BR could be programmed for a divide-by-2 value, and DBR could be programmed to 0 to achieve an 8MHz SPI clock rate. For SPI writes, the DBR could be changed to 1 to realize a 16MHz SPI clock rate.

Refer to the MCU: Serial Peripheral Interface (SPI) chapter for more information on baud rate.

# 8.4.3 DSPI Timing Control

The DSPI provides the following programmable control relating to the SPI timing parameters  $t_{CSC}$ ,  $t_{ASC}$ , and  $t_{DT}$ :

- PCSSCK (SPI1\_CTARn, bits 23:22) and CSSCK (SPI1\_CTARn, bits 15:12) these control the delay from PCS assertion to the first SCK edge, that is, t<sub>CSC</sub>
- PASC (SPI1\_CTARn, bits 21:20) and ASC (SPI1\_CTARn, bits 11:8) these control the delay from the last SCK edge to the negation of PCS, that is, t<sub>ASC</sub>
- PDT (SPI1\_CTARn, bits 19:18) and DT (SPI1\_CTARn, bits 7:4) these control the delay from the negation of PCS to the assertion of PCS for the next SPI frame, that is, t<sub>DT</sub>

Since the maximum bus clock in the MCU is 50MHz,  $t_{CSC}$  can be no more than 40ns regardless of programming. So PCSSCK and CSSCK can be programmed to their default values (device-by-1 and divide-by-2 respectively) to minimize this delay and still meet the requirement that  $t_{CSC}$  be no less than 32.5ns.

#### Configuring MCU for Proper SPI Operation

Likewise,  $t_{ASC}$  can be no more than 40ns regardless of programming since the MCU bus clock 50MHz limit. So PASC and ASC can also be programmed to their default values (device-by-1 and divide-by-2 respectively) to minimize this delay and still meet the requirement that  $t_{ASC}$  be no less than 32.5ns.

However, depending on the bus frequency, the PDT and DT may need to be programmed to ensure that  $t_{DT}$  is no less than 62.5ns. If the bus clock is 32MHz or less, the default programming for PDT and DT can be used, since then  $t_{DT}$  will be no more than 62.5ns. However, with a 50MHz bus clock, the default programming for PDT and DT would cause  $t_{DT}$  to be 40ns, which does not meet the modem requirement. Programming DT to a divide-by-4 value (instead of default divide-by-2) when the bus clock is 50MHz would increase  $t_{DT}$  to 80ns to meet the modem timing requirement.

Refer to the MCU: Serial Peripheral Interface (SPI) chapter for more information on baud rate and clock delay generation.

# Chapter 9 Modem: SPI Register Descriptions

# 9.1 Introduction

This section provides a complete listing of all the modem registers, including register address, access modes, descriptions, and references to other documents for more complete information.

The transceiver registers allow the MCU to communicate and control the radio as well as receive feedback and status information. All radio registers are accessible via a SPI interface only. No other means of accessing the transceiver registers is possible. The registers are divided into two categories; direct and indirect. The first 64 registers are "Direct Access", meaning only a single SPI control word is required to identify the register to be accessed. The remaining registers are "Indirect Access" and use a pointer register followed by a data register as discussed following.

Indirect access registers use a pointer register and a window register for access in the indirect space. The pointer register (IAR\_INDEX) and the data register (IAR\_DATA) occupy the last two registers slots in Direct Space; addresses 0x3E and 0x3F respectively. Both direct- and indirect-access registers can be accessed in SPI burst mode, in which the SPI control word addresses the first register in the burst. After the first register in the burst is accessed, the hardware will auto-increment the register address so that subsequent sequential registers can be accessed during a single multi-byte SPI transaction. The length of the burst is not limited by hardware.

Direct access burst mode is available in all power states, including HIBERNATE. Indirect access burst mode is restricted to states during which the crystal oscillator is running (e.g., DOZE, IDLE, RUN); this excludes HIBERNATE state. Indirect register access in HIBERNATE state is restricted to single-byte.

A few registers, which control special functions within the IC, should not be accessed in HIBERNATE state; these are identified in the "Register Description" tables later in this document. However, most registers are 100% accessible in all power states, including HIBERNATE.

#### Modem Memory map and register definition

In the following Register Summary table, registers are listed in ascending address order, starting with direct address space (direct addresses 0x00 - 0x3F), followed by indirect address space (addresses 0x00 - 0xFF). For each register, address (direct or indirect) appears in the left-hand column. The register bits are then listed horizontally from left to right, bit 7 ... bit 0. The right-hand column contains the register mnemonic. For each bit, an access mode is shown (r = read-only; rw = read/write; w1tc=write-1-to-clear; sc=self-clearing; etc.). And for all read/write registers, a default value is provided. Unpopulated registers, or unpopulated register bits within a partially-populated register, are indicated by empty cells in the table, and should be considered reserved; these bit positions read back 0, and only 0 should be written to them.

# 9.2 Modem Memory map and register definition

NOTE

The Direct and Indirect registers can be accessed only through the SPI interface. Direct access by a single SPI control word and Indirect using the pointer register (IAR\_INDEX) and the data register (IAR\_DATA), which occupy the last two registers in direct access; addresses 0x3E and 0x3F respectively.

| Absolute<br>address<br>(hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| 0                            | Interrupt Request Status 1 (Modem_IRQSTS1)       | 8                  | w1c    | 00h         | 9.2.1/134        |
| 1                            | Interrupt Request Status 2 (Modem_IRQSTS2)       | 8                  | R      | 01h         | 9.2.2/136        |
| 2                            | Interrupt Request Status 3 (Modem_IRQSTS3)       | 8                  | R/W    | F0h         | 9.2.3/137        |
| 3                            | PHY Control 1 (Modem_PHY_CTRL1)                  | 8                  | R/W    | 00h         | 9.2.4/139        |
| 4                            | PHY Control 2 (Modem_PHY_CTRL2)                  | 8                  | R/W    | FFh         | 9.2.5/140        |
| 5                            | PHY Control 3 (Modem_PHY_CTRL3)                  | 8                  | R/W    | 06h         | 9.2.6/141        |
| 6                            | Receive Frame Length (Modem_RX_FRM_LEN)          | 8                  | R      | 00h         | 9.2.7/142        |
| 7                            | PHY Control 4 (Modem_PHY_CTRL4)                  | 8                  | R/W    | 08h         | 9.2.8/143        |
| 8                            | SRC Control (Modem_SRC_CTRL)                     | 8                  | R/W    | 0Ch         | 9.2.9/144        |
| 9                            | SRC Address SUM LSB<br>(Modem_SRC_ADDRS_SUM_LSB) | 8                  | R/W    | 00h         | 9.2.10/145       |
| А                            | SRC Address SUM MSB<br>(Modem_SRC_ADDRS_SUM_MSB) | 8                  | R/W    | 00h         | 9.2.11/145       |
| В                            | CCA1 ED FNL (Modem_CCA1_ED_FNL)                  | 8                  | R      | 00h         | 9.2.12/146       |
| С                            | Event Timer LSB (Modem_EVENT_TIMER_LSB)          | 8                  | R      | 00h         | 9.2.13/146       |
| D                            | Event Timer MSB (Modem_EVENT_TIMER_MSB)          | 8                  | R      | 00h         | 9.2.14/147       |
| E                            | Event Timer USB (Modem_EVENT_TIMER_USB)          | 8                  | R      | 00h         | 9.2.15/147       |

### Modem memory map

Table continues on the next page...

### Modem memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                                    |   | Access | Reset value | Section/<br>page |
|------------------------------|------------------------------------------------------------------|---|--------|-------------|------------------|
| F                            | Timestamp LSB (Modem_TIMESTAMP_LSB)                              | 8 | R      | 00h         | 9.2.16/147       |
| 10                           | Timestamp MSB (Modem_TIMESTAMP_MSB)                              | 8 | R      | 00h         | 9.2.17/148       |
| 11                           | Timestamp USB (Modem_TIMESTAMP_USB)                              | 8 | R      | 00h         | 9.2.18/148       |
| 12                           | Timer 3 Compare Value LSB (Modem_T3CMP_LSB)                      | 8 | R/W    | FFh         | 9.2.19/149       |
| 13                           | Timer 3 Compare Value MSB (Modem_T3CMP_MSB)                      | 8 | R/W    | FFh         | 9.2.20/149       |
| 14                           | Timer 3 Compare Value USB (Modem_T3CMP_USB)                      | 8 | R/W    | FFh         | 9.2.21/149       |
| 15                           | Timer 2-Prime Compare Value LSB<br>(Modem_T2PRIMECMP_LSB)        | 8 | R/W    | FFh         | 9.2.22/150       |
| 16                           | Timer 2-Prime Compare Value MSB<br>(Modem_T2PRIMECMP_MSB)        | 8 | R/W    | FFh         | 9.2.23/150       |
| 17                           | Timer 1 Compare Value LSB (Modem_T1CMP_LSB)                      | 8 | R/W    | FFh         | 9.2.24/150       |
| 18                           | Timer 1 Compare Value MSB (Modem_T1CMP_MSB)                      | 8 | R/W    | FFh         | 9.2.25/151       |
| 19                           | Timer 1 Compare Value USB (Modem_T1CMP_USB)                      | 8 | R/W    | FFh         | 9.2.26/151       |
| 1A                           | Timer 2 Compare Value LSB (Modem_T2CMP_LSB)                      | 8 | R/W    | FFh         | 9.2.27/151       |
| 1B                           | Timer 2 Compare Value MSB (Modem_T2CMP_MSB)                      | 8 | R/W    | FFh         | 9.2.28/152       |
| 1C                           | Timer 2 Compare Value USB (Modem_T2CMP_USB)                      | 8 | R/W    | FFh         | 9.2.29/152       |
| 1D                           | Timer 4 Compare Value LSB (Modem_T4CMP_LSB)                      | 8 | R/W    | FFh         | 9.2.30/152       |
| 1E                           | Timer 4 Compare Value MSB (Modem_T4CMP_MSB)                      | 8 | R/W    | FFh         | 9.2.31/153       |
| 1F                           | Timer 4 Compare Value USB (Modem_T4CMP_USB)                      | 8 | R/W    | FFh         | 9.2.32/153       |
| 20                           | PLL Integer Value for PAN0 (Modem_PLL_INT0)                      | 8 | R/W    | 0Ch         | 9.2.33/153       |
| 21                           | PLL Frequency Fractional Value for PAN0<br>(Modem_PLL_FRAC0_LSB) | 8 | R/W    | 00h         | 9.2.34/154       |
| 22                           | PLL Frequency Fractional Value for PAN0<br>(Modem_PLL_FRAC0_MSB) | 8 | R/W    | 90h         | 9.2.35/154       |
| 23                           | PA Power Control (Modem_PA_PWR) (Modem_PA_PWR)                   | 8 | R/W    | 18h         | 9.2.36/155       |
| 24                           | Sequence Manager State (Modem_SEQ_STATE)                         | 8 | R      | 00h         | 9.2.37/155       |
| 25                           | Link Quality Indicator (Modem_LQI_VALUE)                         | 8 | R      | 00h         | 9.2.38/155       |
| 26                           | RSSI CCA CNT (Modem_RSSI_CCA_CNT)                                | 8 | R      | 00h         | 9.2.39/156       |
| 28                           | ASM Control 1 (Modem_ASM_CTRL1)                                  | 8 | R/W    | 00h         | 9.2.40/156       |
| 29                           | ASM Control 2 (Modem_ASM_CTRL2)                                  | 8 | R/W    | 00h         | 9.2.41/157       |
| 2A                           | ASM Data (Modem_ASM_DATA_0)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 2B                           | ASM Data (Modem_ASM_DATA_1)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 2C                           | ASM Data (Modem_ASM_DATA_2)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 2D                           | ASM Data (Modem_ASM_DATA_3)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 2E                           | ASM Data (Modem_ASM_DATA_4)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 2F                           | ASM Data (Modem_ASM_DATA_5)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 30                           | ASM Data (Modem_ASM_DATA_6)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 31                           | ASM Data (Modem_ASM_DATA_7)                                      | 8 | R/W    | 00h         | 9.2.42/158       |
| 32                           | ASM Data (Modem_ASM_DATA_8)                                      | 8 | R/W    | 00h         | 9.2.42/158       |

Table continues on the next page...

Modem Memory map and register definition

| Absolute<br>address<br>(hex) | Register name                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|------------------------------------------------|--------------------|--------|-------------|------------------|
| 33                           | ASM Data (Modem_ASM_DATA_9)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 34                           | ASM Data (Modem_ASM_DATA_A)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 35                           | ASM Data (Modem_ASM_DATA_B)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 36                           | ASM Data (Modem_ASM_DATA_C)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 37                           | ASM Data (Modem_ASM_DATA_D)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 38                           | ASM Data (Modem_ASM_DATA_E)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 39                           | ASM Data (Modem_ASM_DATA_F)                    | 8                  | R/W    | 00h         | 9.2.42/158       |
| 3B                           | Overwrite Version Number (Modem_OVERWRITE_VER) | 8                  | R/W    | 00h         | 9.2.43/158       |
| 3C                           | CLK_OUT Control (Modem_CLK_OUT_CTRL)           | 8                  | R/W    | 88h         | 9.2.44/159       |
| 3D                           | Power Modes (Modem_PWR_MODES)                  | 8                  | R/W    | 11h         | 9.2.45/160       |
| 3E                           | IAR Index (Modem_IAR_INDEX)                    | 8                  | W      | 00h         | 9.2.46/161       |
| 3F                           | IAR Data (Modem_IAR_DATA)                      | 8                  | R/W    | 00h         | 9.2.47/162       |

### Modem memory map (continued)

## 9.2.1 Interrupt Request Status 1 (Modem\_IRQSTS1)

This register provides IRQ status information.

Address: 0h base + 0h offset = 0h

| Bit   | 7           | 6              | 5              | 4           |  |  |
|-------|-------------|----------------|----------------|-------------|--|--|
| Read  | RX_FRM_PEND | PLL_UNLOCK_IRQ | FILTERFAIL_IRQ | RXWTRMRKIRQ |  |  |
| Write |             | w1c            | w1c            | w1c         |  |  |
| Reset | 0           | 0              | 0              | 0           |  |  |
| Bit   | 3           | 2              | 1              | 0           |  |  |
| Read  | CCAIRQ      | RXIRQ          | TXIRQ          | SEQIRQ      |  |  |
| Write | w1c         | w1c            | w1c            | w1c         |  |  |
| Reset | 0           | 0              | 0              | 0           |  |  |

### Modem\_IRQSTS1 field descriptions

| Field              | Description                                                                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7                  | Frame Pending Interrupt Status                                                                                                       |
| RX_FRM_PEND        | Shows the status of the frame pending bit of the frame control field for the most-recently received packet. This is a read-only bit. |
|                    | 0 Indicates that an unlock event has not occurred in the PLL.                                                                        |
|                    | 1 Indicates that an unlock event has not occurred in the PLL.                                                                        |
| 6                  | PLL Unlock Interrupt Status                                                                                                          |
| PLL_UNLOCK_<br>IRQ | Shows whether an unlock event has occurred in the PLL. This is write a 1 to clear bit.                                               |

Table continues on the next page...

### Modem\_IRQSTS1 field descriptions (continued)

| Field               | Description                                                                                                                                              |  |  |  |  |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                     | 0 Indicates that an unlock event has not occurred in the PLL.                                                                                            |  |  |  |  |
|                     | 1 Indicates that an unlock event has not occurred in the PLL.                                                                                            |  |  |  |  |
| 5<br>FILTERFAIL_IRQ | Receiver Packet Filter Fail Interrupt Status                                                                                                             |  |  |  |  |
|                     | Shows whether the most-recently received packet has been rejected due to elements within the packet. This is write a 1 to clear bit.                     |  |  |  |  |
|                     | <ul> <li>If PAN0 and PAN1 occupy different channels and CURRENT_NETWORK=0, FILTERFAIL_IRQ applies to PAN0.</li> </ul>                                    |  |  |  |  |
|                     | <ul> <li>If PAN0 and PAN1 occupy different channels and CURRENT_NETWORK=1, FILTERFAIL_IRQ<br/>applies to PAN1.</li> </ul>                                |  |  |  |  |
|                     | <ul> <li>If PAN0 and PAN1 occupy the same channel, FILTERFAIL_IRQ is the logical 'AND' of the individual<br/>PANs' Filter Fail status.</li> </ul>        |  |  |  |  |
| 4<br>RXWTRMRKIRQ    | Receiver Byte Count Water Mark Interrupt Status                                                                                                          |  |  |  |  |
|                     | Shows whether the number of bytes specified in the RX_WTR_MARK register has been reached. This is write a 1 to clear bit.                                |  |  |  |  |
|                     | 0 Indicates that the number of bytes specified in the RX_WTR_MARK register has not been reached                                                          |  |  |  |  |
|                     | 1 Indicates that the number of bytes specified in the RX_WTR_MARK register has been reached                                                              |  |  |  |  |
| 3<br>CCAIRQ         | Clear Channel Assessment Interrupt Status                                                                                                                |  |  |  |  |
|                     | Shows the status of a CCA operation. This is write a 1 to clear bit. See the sequence manager section for a description of the timing of this interrupt. |  |  |  |  |
|                     | 0 Indicates that the completion of a CCA operation has not occurred.                                                                                     |  |  |  |  |
|                     | 1 Indicates that the completion of a CCA operation has occurred.                                                                                         |  |  |  |  |
| 2<br>RXIRQ          | Receiver Interrupt Status                                                                                                                                |  |  |  |  |
| rivan e             | Shows the status of a receive operation. This is write a 1 to clear bit.                                                                                 |  |  |  |  |
|                     | 0 Indicates that the completion of a receive operation has not occurred.                                                                                 |  |  |  |  |
|                     | 1 Indicates that the completion of a receive operation has occurred.                                                                                     |  |  |  |  |
| 1<br>TXIRQ          | Transmitter Interrupt Status                                                                                                                             |  |  |  |  |
|                     | Shows the status of a transmit operation. This is write a 1 to clear bit.                                                                                |  |  |  |  |
|                     | 0 Indicates that the completion of a transmit operation has not occurred.                                                                                |  |  |  |  |
|                     | 1 Indicates that the completion of a transmit operation has occurred.                                                                                    |  |  |  |  |
| 0<br>SEQIRQ         | Sequence-end Interrupt Request Status                                                                                                                    |  |  |  |  |
|                     | This interrupt will assert whenever the Sequence Manager transitions from non-idle to idle state, for any reason. This is write a 1 to clear bit.        |  |  |  |  |
|                     | 0 Indicates that the completion of an autosequence has not occurred.                                                                                     |  |  |  |  |
|                     | 1 Indicates that the completion of an autosequence has occurred.                                                                                         |  |  |  |  |

# 9.2.2 Interrupt Request Status 2 (Modem\_IRQSTS2)

This register provides IRQ status information.

Address: 0h base + 1h offset = 1h

| Bit   | 7                           | 6       | 5          | 4        |
|-------|-----------------------------|---------|------------|----------|
| Read  | CRCVALID                    | CCA     | SRCADDR    | PI       |
| Write |                             |         |            |          |
| Reset | 0                           | 0       | 0          | 0        |
| Bit   | 3                           | 2       | 1          | 0        |
| Read  | TMRSTATUS/WAKE_<br>FROM_HIB | ASM_IRQ | PB_ERR_IRQ | WAKE_IRQ |
| Write |                             | w1c     | w1c        | w1c      |
| Reset | 0                           | 0       | 0          | 1        |

### Modem\_IRQSTS2 field descriptions

| Field        | Description                                                                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | Code Redundancy Check Valid                                                                                                                                                         |
| CRCVALID     | Indicates the compare result between the FCS field, in the most-recently received frame, and the internally calculated CRC value. This flag is cleared at the next receiver warmup. |
|              | 0 Rx FCS != calculated CRC (incorrect)                                                                                                                                              |
|              | 1 Rx FCS = calculated CRC (correct)                                                                                                                                                 |
| 6<br>CCA     | Channel Idle/Busy                                                                                                                                                                   |
|              | This indicator is valid at CCAIRQ and also at SEQIRQ. This flag is cleared at next receiver warmup.                                                                                 |
|              | 0 Channel is idle.                                                                                                                                                                  |
|              | 1 Channel is busy.                                                                                                                                                                  |
| 5<br>SRCADDR | Source Address Match                                                                                                                                                                |
| ShCADDh      | Shows whether all three of these conditions are true: The incoming packet was a data request.                                                                                       |
|              | Source address matching is enabled, SCRADDR_EN=1.                                                                                                                                   |
|              | Source address checksum computed by packet processor matched at least one entry in the source address table.                                                                        |
|              | 0 At least one of these conditions is not true.                                                                                                                                     |
|              | 1 All three of these conditions are true.                                                                                                                                           |
| 4            | Poll Indication                                                                                                                                                                     |
| PI           | Indicates whether the received packet was a data request.                                                                                                                           |

Table continues on the next page...

### Modem\_IRQSTS2 field descriptions (continued)

| Field                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                  | <ul> <li>Indicates that the received packet was not a data request.</li> <li>Indicates that the received packet was a data request, regardless of whether a source address table match occurred, or whether source address matching is enabled. (See SRCADDR_EN in direct register 0x08, MODEM_SRC_CTRL.)</li> </ul>                                                                                                                                                                                                                                 |  |  |  |  |
| 3<br>TMRSTATUS/WAKE_<br>FROM_HIB | Timer Status/Wake from Hibernate<br>This is a dual-purpose, read-only status bit. Its value is dependent on the WAKE_IRQ bit. Used to<br>indicate either wakeup status or timer status.                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                                  | <ul> <li>If WAKE_IRQ=1, a 0 indicates that a wakeup from POR has occurred.</li> <li>If WAKE_IRQ=0, a 0 indicates that no TMRxIRQ is asserted. See the IRQST3 register for the individual timer interrupt status bits.</li> <li>If WAKE_IRQ=1, a 1 indicates that a wakeup from Hibernate has occurred.</li> </ul>                                                                                                                                                                                                                                    |  |  |  |  |
|                                  | If WAKE_IRQ=0, a 1 indicates that at least one of the TMRxIRQ is asserted. See the IRQST3 register for the individual timer interrupt status bits.                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 2<br>ASM_IRQ                     | AES Interrupt Flag<br>A 1 indicates the completion of a AES operation completed. This is write a 1 to clear bit.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 1<br>PB_ERR_IRQ                  | <ul> <li>Packet Buffer Underrun Error Interrupt Status</li> <li>Shows whether a packet buffer underrun error has occurred since the last time this bit was cleared by software. This is a write 1 to clear bit. PB_ERR_IRQ will occur only when the SPI packet buffer access is Burst mode (not Byte mode).</li> <li>0 A packet buffer underrun error has not occurred since the last time this bit was cleared by software.</li> <li>1 A packet buffer underrun error has occurred since the last time this bit was cleared by software.</li> </ul> |  |  |  |  |
| 0<br>WAKE_IRQ                    | Wake Interrupt Status<br>Indicates that either a wake-from-POR or a wake-from-Hibernate event has occured. This is write a<br>1 to clear bit.                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                                  | <ul> <li>Indicates that neither wake event has occurred.</li> <li>Indicates that one of these wake events has occurred. See the WAKE_FROM_HIB/<br/>TMRSTATUS bit to see which type of wake has occurred.</li> </ul>                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

## 9.2.3 Interrupt Request Status 3 (Modem\_IRQSTS3)

This register provides IRQ status information.

Address: 0h base + 2h offset = 2h

| Bit   | 7       | 6           | 5         | 4        | 3       | 2       | 1       | 0       |
|-------|---------|-------------|-----------|----------|---------|---------|---------|---------|
| Read  | TMR4MSK | TMR3MSK     | TMR2MSK   | TMR1MSK  | TMR4IRQ | TMR3IRQ | TMR2IRQ | TMR1IRQ |
| Write |         | TIVINGIVIGR | TWINZIWOR | TWINTWOK | w1c     | w1c     | w1c     | w1c     |
| Reset | 1       | 1           | 1         | 1        | 0       | 0       | 0       | 0       |

#### Field Description 7 Timer Comparator 4 Interrupt Mask TMR4MSK 0 Allows interrupt when comparator matches event timer count. 1 Disables interrupt generation, but allows a TMR4IRQ flag to be set. 6 Timer Comparator 3 Interrupt Mask **TMR3MSK** 0 Allows interrupt when comparator matches event timer count. 1 Disables interrupt generation, but allows a TMR3IRQ flag to be set. 5 Timer Comparator 2 Interrupt Mask TMR2MSK 0 Allows interrupt when comparator matches event timer count. 1 Disables interrupt generation, but allows a TMR2IRQ flag to be set. 4 Timer Comparator 1 Interrupt Mask TMR1MSK 0 Allows interrupt when comparator matches event timer count. 1 Disables interrupt generation, but allows a TMR1IRQ flag to be set. З **Timer Comparator 4 Interrupt Status** TMR4IRQ Indicates whether the T4CMP comparator value matched the event timer counter. This is a write 1 to clear bit. Indicates that the T4CMP comparator value does not match the event timer counter. 0 1 Indicates that the T4CMP comparator value does match the event timer counter. 2 **Timer Comparator 3 Interrupt Status TMR3IRQ** Indicates whether the T1CMP comparator value matched the event timer counter. This is a write 1 to clear bit. 0 Indicates that the T3CMP comparator value does not match the event timer counter. 1 Indicates that the T3CMP comparator value does match the event timer counter. **Timer Comparator 2 Interrupt Status** 1 TMR2IRQ Indicates whether the T2CMP comparator value matched the event timer counter. This is a write 1 to clear bit. Indicates that the T2CMP comparator value does not match the event timer counter. 0 1 Indicates that the T2CMP comparator value does match the event timer counter. 0 Timer Comparator 1 Interrupt Status TMR1IRQ Indicates whether the T1CMP comparator value matched the event timer counter. This is a write 1 to clear bit. 0 Indicates that the T1CMP comparator value does not match the event timer counter. 1 Indicates that the T1CMP comparator value does match the event timer counter.

### Modem\_IRQSTS3 field descriptions

# 9.2.4 PHY Control 1 (Modem\_PHY\_CTRL1)

This register is used to control the PHY.

Address: 0h base + 3h offset = 3h

| Bit   | 7        | 6       | 5        | 4        | 3       | 2 | 1      | 0 |
|-------|----------|---------|----------|----------|---------|---|--------|---|
| Read  | TMRTRIGE | SLOTTED | COAREDTY | RXACKRQD |         |   | XCVSEQ |   |
| Write | N        | SLOTIED | CCABENIA | NACKNUD  | AUTOACK |   | XCV3EQ |   |
| Reset | 0        | 0       | 0        | 0        | 0       | 0 | 0      | 0 |

### Modem\_PHY\_CTRL1 field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TMRTRIGEN | Timer 2 Trigger Enable                                                                                                                                                                                                                                                                                                                                                            |
|                | This control bit allows the transceivers programmed sequence to be immediate or delayed by T2CMP or T2PRIMECMP count.                                                                                                                                                                                                                                                             |
|                | 0 Programmed sequence initiates immediately upon write to XCVSEQ.                                                                                                                                                                                                                                                                                                                 |
|                | 1 Allow timer TC2 (or TC2') to initiate a preprogrammed sequence (see XCVSEQ register).                                                                                                                                                                                                                                                                                           |
| 6              | Slotted Mode                                                                                                                                                                                                                                                                                                                                                                      |
| SLOTTED        | For beacon-enabled networks. Applies only to Sequences T, TR, and R, ignored during all other sequences. Used, in concert with CCABFRTX, to determine how many CCA measurements are required prior to a transmit operation. Also used during R sequence to determine whether the ensuing transmit acknowledge frame (if any) needs to be synchronized to a backoff slot boundary. |
|                | 0 Non-slotted                                                                                                                                                                                                                                                                                                                                                                     |
|                | 1 Slotted                                                                                                                                                                                                                                                                                                                                                                         |
| 5<br>CCABFRTX  | CCA Before TX                                                                                                                                                                                                                                                                                                                                                                     |
|                | Applies only to sequences T and TR. Ignored during all other sequences.                                                                                                                                                                                                                                                                                                           |
|                | 0 No CCA required. Transmit operation begins immediately.                                                                                                                                                                                                                                                                                                                         |
|                | 1 At least one CCA measurement is required prior to the transmit operation (see also SLOTTED).                                                                                                                                                                                                                                                                                    |
| 4<br>RXACKRQD  | Receive Acknowledge Frame Required                                                                                                                                                                                                                                                                                                                                                |
|                | Applies only to Sequence TR, ignored during all other sequences.                                                                                                                                                                                                                                                                                                                  |
|                | 0 An ordinary receive frame (any type of frame) follows the transmit frame.                                                                                                                                                                                                                                                                                                       |
|                | 1 A receive acknowledge frame is expected to follow the transmit frame (non-acknowledge frames are rejected).                                                                                                                                                                                                                                                                     |
| 3<br>AUTOACK   | Auto Acklowledge Enable                                                                                                                                                                                                                                                                                                                                                           |
| AUTOACK        | Applies only to sequence R and sequence TR. Ignored during other sequences.                                                                                                                                                                                                                                                                                                       |
|                | 0 The sequence manager will not follow a receive frame with a Tx Ack frame, under any condition. The autosequence will terminate after the receive frame.                                                                                                                                                                                                                         |
|                | 1 The sequence manager will follow a receive frame with an automatic hardware-generated Tx Ack frame, assuming other necessary conditions are met.                                                                                                                                                                                                                                |
| XCVSEQ         | Transceiver Sequence Selector                                                                                                                                                                                                                                                                                                                                                     |

Table continues on the next page ...

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|       | Selects an autosequence for the sequence manager to execute. Sequence initiation can be immediate, or scheduled (see TMRTRIGEN). A write of XCVSEQ=IDLE will abort any ongoing sequence. A write of XCVSEQ=IDLE must always be performed after a sequence is complete, and before a new sequence is programmed. Any write to XCVSEQ other than XCVSEQ=IDLE during an ongoing sequence, shall be ignored. The mapping of XCVSEQ to sequence types is as follows: |  |  |  |  |  |
|       | 000 Idle (sequence I)                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|       | 001 Receive (sequence R)                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|       | 010 Transmit (sequence T)                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|       | 011 CCA (sequence C)                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|       | 100 Transmit/Receive (sequence TR)                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | 101 Continuous CCA (sequence CCCA)                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | 110 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|       | 111 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

### Modem\_PHY\_CTRL1 field descriptions (continued)

# 9.2.5 PHY Control 2 (Modem\_PHY\_CTRL2)

This register is used to control the PHY.

Address: 0h base + 4h offset = 4h

| Bit   | 7       | 6              | 5          | 4   | 3      | 2     | 1     | 0      |
|-------|---------|----------------|------------|-----|--------|-------|-------|--------|
| Read  |         | PLL_           | FILTERFAIL |     |        |       |       |        |
| Write | CRC_MSK | UNLOCK_<br>MSK |            | MSK | CCAMSK | RXMSK | TXMSK | SEQMSK |
| Reset | 1       | 1              | 1          | 1   | 1      | 1     | 1     | 1      |

### Modem\_PHY\_CTRL2 field descriptions

| Field       | Description                                                                                                                                                                                                                                                       |  |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7           | CRC Mask                                                                                                                                                                                                                                                          |  |  |  |  |  |
| CRC_MSK     |                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|             | 0 The sequence manager ignores CRCVALID and considers the receive operation complete after the<br>last octet of the frame has been received.                                                                                                                      |  |  |  |  |  |
|             | 1 The sequence manager requires CRCVALID=1 at the end of the received frame in order for the receive operation to complete successfully; if CRCVALID=0, sequence manager will return to preamble-detect mode after the last octet of the frame has been received. |  |  |  |  |  |
| 6           | PLL Unlock Mask                                                                                                                                                                                                                                                   |  |  |  |  |  |
| PLL_UNLOCK_ |                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| MSK         | 0 Allows PLL unlock event to generate an interrupt on IRQ_B.                                                                                                                                                                                                      |  |  |  |  |  |
|             | <ol> <li>A PLL unlock event will set the PLL_UNLOCK_IRQ status bit, but an interrupt is not generated on<br/>IRQ_B.</li> </ol>                                                                                                                                    |  |  |  |  |  |
| 5           | Filter Fail Mask                                                                                                                                                                                                                                                  |  |  |  |  |  |
| FILTERFAIL_ |                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| MSK         | 0 Allows packet processor filtering Failure to generate an interrupt on IRQ_B.                                                                                                                                                                                    |  |  |  |  |  |
|             | 1 A packet processor filtering failure will set the FILTERFAIL_IRQ status bit, but an interrupt is not<br>generated on IRQ_B.                                                                                                                                     |  |  |  |  |  |

Table continues on the next page...

| Modem_PHY_ | _CTRL2 field descriptio | ns (continued) |
|------------|-------------------------|----------------|
|------------|-------------------------|----------------|

| Field            | Description                                                                                                                                          |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 4<br>RX_WMRK_MSK | Recieve Watermark Mask                                                                                                                               |  |  |  |
|                  | 0 Allows a Received Byte Count match to the RX_WTR_MARK threshold register to generate an interrupt on IRQ_B.                                        |  |  |  |
|                  | 1 A Received Byte Count match to the RX_WTR_MARK threshold register will set the RXWTRMRKIRQ status bit, but an interrupt is not generated on IRQ_B. |  |  |  |
| 3<br>CCAMSK      | Clear Channel Assessment Mask                                                                                                                        |  |  |  |
|                  | 0 Allows completion of a CCA operation to generate an interrupt on IRQ_B.                                                                            |  |  |  |
|                  | <ol> <li>Completion of a CCA operation will set the CCAIRQ status bit, but an interrupt is not generated on<br/>IRQ_B.</li> </ol>                    |  |  |  |
| 2<br>RXMSK       | Receive Mask                                                                                                                                         |  |  |  |
|                  | 0 Allows completion of a RX operation to generate an interrupt on IRQ_B.                                                                             |  |  |  |
|                  | <ol> <li>Completion of a RX operation will set the RXIRQ status bit, but an interrupt is not generated on<br/>IRQ_B.</li> </ol>                      |  |  |  |
| 1<br>TXMSK       | Transmit Mask                                                                                                                                        |  |  |  |
|                  | 0 Allows completion of a TX operation to generate an interrupt on IRQ_B.                                                                             |  |  |  |
|                  | 1 Completion of a TX operation will set the TXIRQ status bit, but an interrupt is not generated on IRQ_B.                                            |  |  |  |
| 0<br>SEQMSK      | Sequence Mask                                                                                                                                        |  |  |  |
|                  | 0 Allows completion of an autosequence to generate an interrupt on IRQ_B.                                                                            |  |  |  |
|                  | <ol> <li>Completion of an autosequence will set the SEQIRQ status bit, but an interrupt is not generated on<br/>IRQ_B.</li> </ol>                    |  |  |  |

## 9.2.6 PHY Control 3 (Modem\_PHY\_CTRL3)

This register is used to control the PHY.

Address: 0h base + 5h offset = 5h

| Bit           | 7          | 6          | 5          | 4          |
|---------------|------------|------------|------------|------------|
| Read<br>Write | TMR4CMP_EN | TMR3CMP_EN | TMR2CMP_EN | TMR1CMP_EN |
| Reset         | 0          | 0          | 0          | 0          |
| Bit           | 3          | 2          | 1          | 0          |
| Read<br>Write | Reserved   | ASM_MSK    | PB_ERR_MSK | WAKE_MSK   |
| Reset         | 0          | 1          | 1          | 0          |

### Modem\_PHY\_CTRL3 field descriptions

| Field      | Description                                                 |  |  |  |  |
|------------|-------------------------------------------------------------|--|--|--|--|
| 7          | Timer 4 Comparator Enable                                   |  |  |  |  |
| TMR4CMP_EN |                                                             |  |  |  |  |
|            | 0 Don't allow an event timer match to T4CMP to set TMR4IRQ. |  |  |  |  |
|            | 1 Allow an event timer match to T4CMP to set TMR4IRQ.       |  |  |  |  |

Table continues on the next page ...

| Field         | Description                                                 |  |  |  |  |  |
|---------------|-------------------------------------------------------------|--|--|--|--|--|
| 6             | Timer 3 Comparator Enable                                   |  |  |  |  |  |
| TMR3CMP_EN    | 0 Don't allow an event timer match to T3CMP to set TMR3IRQ. |  |  |  |  |  |
|               | Allow an event timer match to T3CMP to set TMR3IRQ.         |  |  |  |  |  |
| 5             | Timer 2 Comparator Enable                                   |  |  |  |  |  |
| TMR2CMP_EN    |                                                             |  |  |  |  |  |
|               | 0 Don't allow an event timer match to T2CMP to set TMR2IRQ. |  |  |  |  |  |
|               | 1 Allow an event timer match to T2CMP to set TMR2IRQ.       |  |  |  |  |  |
| 4             | Timer 1 Comparator Enable                                   |  |  |  |  |  |
| TMR1CMP_EN    | 0 Don't allow an event timer match to T1CMP to set TMR1IRQ. |  |  |  |  |  |
|               | 1 Allow an event timer match to T1CMP to set TMR1IRQ.       |  |  |  |  |  |
| 3             | Reserved.                                                   |  |  |  |  |  |
| Reserved      |                                                             |  |  |  |  |  |
|               | his field is reserved.                                      |  |  |  |  |  |
| 2             | ASM Mask                                                    |  |  |  |  |  |
| ASM_MSK       | 0 Enable AES Interrupt to assert IRQ_B.                     |  |  |  |  |  |
|               | 1 Mask AES Interrupt from asserting IRQ_B.                  |  |  |  |  |  |
| 1             | Packet Buffer Error Mask                                    |  |  |  |  |  |
| PB_ERR_MSK    |                                                             |  |  |  |  |  |
|               | 0 Enable packet buffer error interrupt to assert IRQ_B.     |  |  |  |  |  |
|               | 1 Mask Packet Buffer Error Interrupt from asserting IRQ_B.  |  |  |  |  |  |
| 0<br>WAKE_MSK | Wake Mask                                                   |  |  |  |  |  |
|               | 0 Enable Wake Interrupt to assert IRQ_B                     |  |  |  |  |  |
|               | 1 Mask Wake Interrupt from asserting IRQ_B.                 |  |  |  |  |  |

### Modem\_PHY\_CTRL3 field descriptions (continued)

## 9.2.7 Receive Frame Length (Modem\_RX\_FRM\_LEN)

Contents of the PHR (PHY header), or FrameLength field, of the most recently received packet.



Modem\_RX\_FRM\_LEN field descriptions

| Field         | Description             |
|---------------|-------------------------|
| 7<br>Reserved | Reserved.               |
| Teserveu      | This field is reserved. |

Table continues on the next page...

| Field               | Description                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------|
| RX_FRAME_<br>LENGTH | Receive Frame Length                                                                                                            |
|                     | This read-only field contains the contents of the PHR (PHY header), or FrameLength field, of the most recently received packet. |

### Modem\_RX\_FRM\_LEN field descriptions (continued)

## 9.2.8 PHY Control 4 (Modem\_PHY\_CTRL4)

This register is used to control the PHY.

Address: 0h base + 7h offset = 7h

| Bit   | 7        | 6        | 5           | 4           |
|-------|----------|----------|-------------|-------------|
| Read  |          | TOOTMOUT |             |             |
| Write | TRCV_MSK | TC3TMOUT | PANCORDNTR0 | CCATYPE     |
| Reset | 0        | 0        | 0           | 0           |
| Bit   | 3        | 2        | 1           | 0           |
| Read  | COATVDE  |          | PROMISSIONS |             |
| Write | CCATYPE  | TMRLOAD  | PROMISCUOUS | TC2PRIME_EN |
| Reset | 1        | 0        | 0           | 0           |

### Modem\_PHY\_CTRL4 field descriptions

| Field            | Description                                                                                                                  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TRCV_MSK    | Transceiver IRQ_B All interrupt Mask                                                                                         |
|                  | 0 Enable any interrupt to assert IRQ_B.                                                                                      |
|                  | 1 Mask all interrupts from asserting IRQ_B.                                                                                  |
| 6<br>TC3TMOUT    | Timer 3 Function Control                                                                                                     |
|                  | 0 TMR3 is a software timer only.                                                                                             |
|                  | 1 Enable TMR3 to abort Rx or CCCA operations.                                                                                |
| 5<br>PANCORDNTR0 | PAN Coordinator on PAN0 Device Enable                                                                                        |
|                  | Device is a PAN Coordinator on PAN0. Allows device to receive packets with no destination address, if source PAN ID matches. |
| 4–3<br>CCATYPE   | Clear Channel Assessment Type                                                                                                |
|                  | Selects one of four possible functions for CCA or ED, listed below.                                                          |
|                  | 00 Energy detect                                                                                                             |
|                  | 01 CCA mode 1                                                                                                                |
|                  | 10 CCA mode 2                                                                                                                |
|                  | 11 CCA mode 3                                                                                                                |
| 2                | Timer Load                                                                                                                   |
| TMRLOAD          |                                                                                                                              |

Table continues on the next page ...

| Field       | Description                                                                                                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | A low to high transition of this bit causes the contents of register 'T1CMP[23:0]' to be loaded into the Event Timer. This is a self clearing bit and always reads zero. |
| 1           | Promiscuous                                                                                                                                                              |
| PROMISCUOUS |                                                                                                                                                                          |
|             | Bypasses most packet filtering.                                                                                                                                          |
|             | 0 Normal mode.                                                                                                                                                           |
|             | <ol> <li>All packet filtering except frame length checking (FrameLength =5 or greater and FrameLength =127<br/>or less) is bypassed.</li> </ol>                          |
| 0           | TMR2-prime Compare Match Enable                                                                                                                                          |
| TC2PRIME_EN |                                                                                                                                                                          |
|             | 0 Don't allow a match of the lower 16 bits of the event timer to T2PRIMECMP to set TMR2IRQ.                                                                              |
|             | 1 Allow a match of the lower 16 bits of Event Timer to T2PRIMECMP to set TMR2IRQ.                                                                                        |

### Modem\_PHY\_CTRL4 field descriptions (continued)

# 9.2.9 SRC Control (Modem\_SRC\_CTRL)

This register is used to control the SRC.

Address: 0h base + 8h offset = 8h



### Modem\_SRC\_CTRL field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>INDEX     | Index<br>If SRCADDR_EN=0, the value of ACK_FRM_PND is copied into the FramePending subfield of the Frame<br>Control field of an auto-TxAck frame, if conditions are met for such a frame to be sent following a receive<br>frame (see sequence manager section, sequence R and sequence TR). If SRCADDR_EN=1,<br>ACK_FRM_PND is ignored, and the result of the Source Address Matching table-lookup determines the<br>setting of the FramePending subfield of the Frame Control Field.                     |
| 3<br>ACK_FRM_PND | Acknowledge Frame Pending<br>If SRCADDR_EN=0, the value of ACK_FRM_PND is copied into the FramePending subfield of the Frame<br>Control field of an auto-TxAck frame, if conditions are met for such a frame to be sent following a receive<br>frame (see sequence manager section, sequence R and sequence TR). If SRCADDR_EN=1,<br>ACK_FRM_PND is ignored, and the result of the Source Address Matching table-lookup determines the<br>setting of the FramePending subfield of the Frame Control Field. |
| 2<br>SRCADDR_EN  | Source Address Matching Enable<br>Part of the Source Address Matching feature. Enables the source address matching feature.                                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>INDEX_EN    | Source Address Matching Index Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Table continues on the next page ...

#### Modem\_SRC\_CTRL field descriptions (continued)

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Part of the Source Address Matching feature. Setting INDEX_EN activates the selected INDEX in the Source Address Table. Source Address Matching logic will be allowed to compare against the stored checksum associated with this index when an incoming MAC Command data request packet is received. The INDEX_EN bit is write-only, and self-clearing. Writing a 1 to INDEX_EN will enable the selected INDEX. Writing a 0 to this bit has no effect. Reads of INDEX_EN always return zero.                                                                                          |
| 0<br>INDEX_DISABLE | Source Address Matching Index Disable<br>Part of the source address matching feature. Setting INDEX_DISABLE deactivates (invalidates) the<br>selected INDEX in the Source Address Table. Source Address Matching logic will no longer compare<br>against the stored checksum associated with this index when an incoming MAC Command data request<br>packet is received. The INDEX_DISABLE bit is write-only, and self-clearing. Writing a 1 to<br>INDEX_DISABLE will disable the selected INDEX. Writing a 0 to this bit has no effect. Reads of<br>INDEX_DISABLE always return zero. |

# 9.2.10 SRC Address SUM LSB (Modem\_SRC\_ADDRS\_SUM\_LSB)

| Address: 0h base + 9h offset | = 9h |
|------------------------------|------|
|------------------------------|------|

Address: 0h base + Ah offset = Ah

| Bit           | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|---------------|---|---|---|---------|---------|---|---|---|
| Read<br>Write |   |   |   | SRC_ADE | DRS_SUM |   |   |   |
| Reset         | 0 | 0 | 0 | 0       | 0       | 0 | 0 | 0 |

#### Modem\_SRC\_ADDRS\_SUM\_LSB field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRC_ADDRS_<br>SUM | Source Address Checksum LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | Part of the Source Address Matching feature. Software loads a specific index of the Source Address Table with its software-computed checksum by writing to this register, having previously selected the desired index by writing to the INDEX field of the SRC_CTRL Register. This is a 16 bit register. The 2 bytes can be written in any order. Software then activates the selected table index by asserting the INDEX_EN bit of the SRC_CTRL Register return the 16-bit value from the source address table selected by the INDEX field of the SRC_CTRL register. |

# 9.2.11 SRC Address SUM MSB (Modem\_SRC\_ADDRS\_SUM\_MSB)

| Bit           | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|---------------|---|---|---|---------|---------|---|---|---|
| Read<br>Write |   |   |   | SRC_ADE | DRS_SUM |   |   |   |
| Reset         | 0 | 0 | 0 | 0       | 0       | 0 | 0 | 0 |

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRC_ADDRS_<br>SUM | Source Address Checksum MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | Part of the Source Address Matching feature. Software loads a specific index of the Source Address Table with its software-computed checksum by writing to this register, having previously selected the desired index by writing to the INDEX field of the SRC_CTRL Register. This is a 16 bit register. The 2 bytes can be written in any order. Software then activates the selected table index by asserting the INDEX_EN bit of the SRC_CTRL Register return the 16-bit value from the source address table selected by the INDEX field of the SRC_CTRL register. |

#### Modem\_SRC\_ADDRS\_SUM\_MSB field descriptions

# 9.2.12 CCA1 ED FNL (Modem\_CCA1\_ED\_FNL)



#### Modem\_CCA1\_ED\_FNL field descriptions

| Field       | Description                                                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------------|
| CCA1_ED_FNL | CCA1/ED Final Average Value                                                                                              |
|             | Output register to show final averaged RSSI value or compensated value of the same at the end CCA mode1/ED computations. |

# 9.2.13 Event Timer LSB (Modem\_EVENT\_TIMER\_LSB)



# Modem\_EVENT\_TIMER\_LSB field descriptions

# Field Description EVENT\_TIMER Event Timer LSB Holds the current value of the 24-bit event timer. The hardware latches the upper 2 bytes of EVENT\_TMR on each read of least significant byte.

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

Address: 0h base + Ch offset = Ch

# 9.2.14 Event Timer MSB (Modem\_EVENT\_TIMER\_MSB)



#### Modem\_EVENT\_TIMER\_MSB field descriptions

| Field       | Description                                                                                                                                   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| EVENT_TIMER | Event Timer MSB                                                                                                                               |
|             | Holds the current value of the 24-bit event timer. The hardware latches the upper 2 bytes of EVENT_TMR on each read of least signifcant byte. |

# 9.2.15 Event Timer USB (Modem\_EVENT\_TIMER\_USB)

| Bit   | 7 | 6 | 5 | 4      | 3        | 2 | 1 | 0 |
|-------|---|---|---|--------|----------|---|---|---|
| Read  |   |   |   | EVENT_ | TIMER    |   |   |   |
| Write |   |   |   |        |          |   |   |   |
| Reset | 0 | 0 | 0 | 0      | 0        | 0 | 0 | 0 |
|       |   |   |   |        | fold doo |   |   |   |

#### Modem\_EVENT\_TIMER\_USB field descriptions

| Field       | Description                                                                                                                                   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| EVENT_TIMER | Event Timer USB                                                                                                                               |
|             | Holds the current value of the 24-bit event timer. The hardware latches the upper 2 bytes of EVENT_TMR on each read of least signifcant byte. |

# 9.2.16 Timestamp LSB (Modem\_TIMESTAMP\_LSB)



#### Address: 0h base + Fh offset = Fh

Address: 0h base + Eh offset = Eh

Address: 0h base + 10h offset = 10h

| Field     | Description                                                                                                                           |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------|
| TIMESTAMP | Timestamp LSB                                                                                                                         |
|           | Holds the latched value of the event timer current time corresponding to the beginning of the just received Rx packet, at SFD detect. |

#### Modem\_TIMESTAMP\_LSB field descriptions

# 9.2.17 Timestamp MSB (Modem\_TIMESTAMP\_MSB)

Bit 7 6 5 4 3 2 1 0 TIMESTAMP Read Write Reset 0 0 0 0 0 0 0 0

#### Modem\_TIMESTAMP\_MSB field descriptions

| Field     | Description                                                                                                                           |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------|
| TIMESTAMP | Timestamp MSB                                                                                                                         |
|           | Holds the latched value of the event timer current time corresponding to the beginning of the just received Rx packet, at SFD detect. |

# 9.2.18 Timestamp USB (Modem\_TIMESTAMP\_USB)



#### Modem\_TIMESTAMP\_USB field descriptions

| Field     | Description                                                                                                                           |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------|
| TIMESTAMP | Timestamp USB                                                                                                                         |
|           | Holds the latched value of the event timer current time corresponding to the beginning of the just received Rx packet, at SFD detect. |

# 9.2.19 Timer 3 Compare Value LSB (Modem\_T3CMP\_LSB)

Address: 0h base + 12h offset = 12h

| Bit           | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|-------|---|---|---|---|---|---|---|
| Read<br>Write | T3CMP |   |   |   |   |   |   |   |
| Reset         | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

#### Modem\_T3CMP\_LSB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T3CMP | TMR3 Compare Value                                                      |
|       | If TMR3CMP_EN=1 and the event timer matches this value, TMR3IRQ is set. |

# 9.2.20 Timer 3 Compare Value MSB (Modem\_T3CMP\_MSB)

Address: 0h base + 13h offset = 13h

| Bit           | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|-------|---|---|---|---|---|---|---|
| Read<br>Write | T3CMP |   |   |   |   |   |   |   |
| Reset         | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

#### Modem\_T3CMP\_MSB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T3CMP | TMR3 Compare Value                                                      |
|       | If TMR3CMP_EN=1 and the event timer matches this value, TMR3IRQ is set. |

# 9.2.21 Timer 3 Compare Value USB (Modem\_T3CMP\_USB)

Address: 0h base + 14h offset = 14h



#### Modem\_T3CMP\_USB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T3CMP | TMR3 Compare Value                                                      |
|       | If TMR3CMP_EN=1 and the event timer matches this value, TMR3IRQ is set. |

# 9.2.22 Timer 2-Prime Compare Value LSB (Modem\_T2PRIMECMP\_LSB)

Address: 0h base + 15h offset = 15h

| Bit           | 7 | 6 | 5 | 4      | 3     | 2 | 1 | 0 |
|---------------|---|---|---|--------|-------|---|---|---|
| Read<br>Write |   |   |   | T2PRIN | MECMP |   |   |   |
| Reset         | 1 | 1 | 1 | 1      | 1     | 1 | 1 | 1 |

#### Modem\_T2PRIMECMP\_LSB field descriptions

| Field      | Description                                                                                                                                   |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| T2PRIMECMP | TMR2-Prime Compare Value<br>If TMR2CMP_EN=1 and TC2PRIME_EN=1 and the lower 16 bits of the event timer matches this value,<br>TMR2IRQ is set. |

# 9.2.23 Timer 2-Prime Compare Value MSB (Modem\_T2PRIMECMP\_MSB)

Address: 0h base + 16h offset = 16h

| Bit           | 7 | 6 | 5 | 4     | 3     | 2 | 1 | 0 |
|---------------|---|---|---|-------|-------|---|---|---|
| Read<br>Write |   |   |   | T2PRI | MECMP |   |   |   |
| Reset         | 1 | 1 | 1 | 1     | 1     | 1 | 1 | 1 |

#### Modem\_T2PRIMECMP\_MSB field descriptions

| Field | Description                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|       | TMR2-Prime Compare Value<br>If TMR2CMP_EN=1 and TC2PRIME_EN=1 and the lower 16 bits of the event timer matches this value,<br>TMR2IRQ is set. |

# 9.2.24 Timer 1 Compare Value LSB (Modem\_T1CMP\_LSB)



#### **Chapter 9 Modem: SPI Register Descriptions**

| Field | Description        |
|-------|--------------------|
| T1CMP | TMR1 Compare Value |

#### Modem\_T1CMP\_LSB field descriptions

If TMR1CMP\_EN=1 and the event timer matches this value, TMR1IRQ is set.

# 9.2.25 Timer 1 Compare Value MSB (Modem\_T1CMP\_MSB)

Address: 0h base + 18h offset = 18h

| Bit           | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|---------------|---|---|---|-----|-----|---|---|---|
| Read<br>Write |   |   |   | T1( | CMP |   |   |   |
| Reset         | 1 | 1 | 1 | 1   | 1   | 1 | 1 | 1 |

#### Modem\_T1CMP\_MSB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T1CMP | TMR1 Compare Value                                                      |
|       | If TMR1CMP_EN=1 and the event timer matches this value, TMR1IRQ is set. |

# 9.2.26 Timer 1 Compare Value USB (Modem\_T1CMP\_USB)

Address: 0h base + 19h offset = 19h



#### Modem\_T1CMP\_USB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T1CMP | TMR1 Compare Value                                                      |
|       | If TMR1CMP_EN=1 and the event timer matches this value, TMR1IRQ is set. |

# 9.2.27 Timer 2 Compare Value LSB (Modem\_T2CMP\_LSB)

Address: 0h base + 1Ah offset = 1Ah 7 Bit 6 5 4 3 2 1 0 Read T2CMP Write 1 1 1 1 1 1 1 1 Reset

| Modem | _T2CMP_ | LSB field | descriptions |
|-------|---------|-----------|--------------|
|-------|---------|-----------|--------------|

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T2CMP | TMR2 Compare Value                                                      |
|       | If TMR2CMP_EN=1 and the event timer matches this value, TMR2IRQ is set. |

# 9.2.28 Timer 2 Compare Value MSB (Modem\_T2CMP\_MSB)

Address: 0h base + 1Bh offset = 1Bh

| Bit           | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|---------------|---|---|---|-----|-----|---|---|---|
| Read<br>Write |   |   |   | T20 | CMP |   |   |   |
| Reset         | 1 | 1 | 1 | 1   | 1   | 1 | 1 | 1 |

#### Modem\_T2CMP\_MSB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T2CMP | TMR2 Compare Value                                                      |
|       | If TMR2CMP_EN=1 and the event timer matches this value, TMR2IRQ is set. |

# 9.2.29 Timer 2 Compare Value USB (Modem\_T2CMP\_USB)

Address: 0h base + 1Ch offset = 1Ch



#### Modem\_T2CMP\_USB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T2CMP | TMR2 Compare Value                                                      |
|       | If TMR2CMP_EN=1 and the event timer matches this value, TMR2IRQ is set. |

# 9.2.30 Timer 4 Compare Value LSB (Modem\_T4CMP\_LSB)

Address: 0h base + 1Dh offset = 1Dh 7 Bit 6 5 4 3 2 1 0 Read T4CMP Write Reset 1 1 1 1 1 1 1 1

#### **Chapter 9 Modem: SPI Register Descriptions**

| Description         |
|---------------------|
| TMD4 Compare Vielus |

| Field | Description                                                             |  |  |  |
|-------|-------------------------------------------------------------------------|--|--|--|
| T4CMP | TMR4 Compare Value                                                      |  |  |  |
|       | If TMR4CMP_EN=1 and the event timer matches this value, TMR4IRQ is set. |  |  |  |

#### Timer 4 Compare Value MSB (Modem\_T4CMP\_MSB) 9.2.31

Address: 0h base + 1Eh offset = 1Eh

| Bit           | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|---------------|---|---|---|-----|-----|---|---|---|
| Read<br>Write |   |   |   | T40 | CMP |   |   |   |
| Reset         | 1 | 1 | 1 | 1   | 1   | 1 | 1 | 1 |

#### Modem\_T4CMP\_MSB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T4CMP | TMR4 Compare Value                                                      |
|       | If TMR4CMP_EN=1 and the event timer matches this value, TMR4IRQ is set. |

#### Timer 4 Compare Value USB (Modem\_T4CMP\_USB) 9.2.32

Address: 0h base + 1Fh offset = 1Fh



#### Modem\_T4CMP\_USB field descriptions

| Field | Description                                                             |
|-------|-------------------------------------------------------------------------|
| T4CMP | TMR4 Compare Value                                                      |
|       | If TMR4CMP_EN=1 and the event timer matches this value, TMR4IRQ is set. |

#### PLL Integer Value for PAN0 (Modem\_PLL\_INT0) 9.2.33

Address: 0h base + 20h offset = 20h 6 7 Bit 5 4 3 2 1 0 Read Reserved PLL\_INT0 Write Reset 0 0 0 1 1 0 0 0

| Field           | Description                                                                         |
|-----------------|-------------------------------------------------------------------------------------|
| 7–5<br>Reserved | This field is reserved.                                                             |
| PLL_INT0        | PLL Frequency Integer Value for PAN0                                                |
|                 | The equation for PLL freqency is: F = ((PLL_INT0+64) + (PLL_FRAC0/65536)) * 32 MHz. |

#### Modem\_PLL\_INT0 field descriptions

# 9.2.34 PLL Frequency Fractional Value for PAN0 (Modem\_PLL\_FRAC0\_LSB)

Address: 0h base + 21h offset = 21h

| Bit           | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|---------------|---|---|---|---------|---------|---|---|---|
| Read<br>Write |   |   |   | PLL_FRA | AC0_LSB |   |   |   |
| Reset         | 0 | 0 | 0 | 0       | 0       | 0 | 0 | 0 |

#### Modem\_PLL\_FRAC0\_LSB field descriptions

| Field             | Description                                                                          |
|-------------------|--------------------------------------------------------------------------------------|
| PLL_FRAC0_<br>LSB | PLL Frequency Fractional Value for PAN0                                              |
|                   | The equation for PLL frequency is: F = ((PLL_INT0+64) + (PLL_FRAC0/65536)) * 3 2MHz. |

# 9.2.35 PLL Frequency Fractional Value for PAN0 (Modem\_PLL\_FRAC0\_MSB)

Address: 0h base + 22h offset = 22h

| Bit           | 7 | 6 | 5 | 4       | 3      | 2 | 1 | 0 |
|---------------|---|---|---|---------|--------|---|---|---|
| Read<br>Write |   |   |   | PLL_FRA | C0_MSB |   |   |   |
| Reset         | 1 | 0 | 0 | 1       | 0      | 0 | 0 | 0 |

#### Modem\_PLL\_FRAC0\_MSB field descriptions

| Field             | Description                                                                          |
|-------------------|--------------------------------------------------------------------------------------|
| PLL_FRAC0_<br>MSB | PLL Frequency Fractional Value for PAN0                                              |
|                   | The equation for PLL frequency is: F = ((PLL_INT0+64) + (PLL_FRAC0/65536)) * 32 MHz. |

# 9.2.36 PA Power Control (Modem\_PA\_PWR) (Modem\_PA\_PWR)



#### Modem\_PA\_PWR field descriptions

| Field           | Description                                                                         |
|-----------------|-------------------------------------------------------------------------------------|
| 7–5<br>Reserved | This field is reserved.                                                             |
| PA_PWR          | PA Power Control<br>Adjusts the PA's output power. Linear range is 3 to 31 decimal. |

# 9.2.37 Sequence Manager State (Modem\_SEQ\_STATE)

Bit 7 6 5 4 3 2 1 0 SEQ\_STATE Read Write Reset 0 0 0 0 0 0 0 0

#### Modem\_SEQ\_STATE field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SEQ_STATE | Sequence Manager State                                                                                                                                                                                                                                                                                            |
|           | This read-only register reflects the status of the sequence manager, RX manager, TX manager, and PLL manager state machines. The SEQ_STATE_CTRL[1:0] field of the SEQ_MGR_CTRL register, determines which sequence manager state is monitored by this register. See the sequence manager section for the mapping. |

# 9.2.38 Link Quality Indicator (Modem\_LQI\_VALUE)



#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

Address: 0h base + 23h offset = 23h

Address: 0h base + 24h offset = 24h

| Field     | Description                                                                                                                                                                                                                                                  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LQI_VALUE | Link Quality Indicator                                                                                                                                                                                                                                       |
|           | This is the link quality indicator for the most recently received packet. (LQI is also available in the packet buffer, at the end of the received packet data; see packet buffer section for details). See the CCA section for details on the LQI algorithm. |

#### Modem\_LQI\_VALUE field descriptions

# 9.2.39 RSSI CCA CNT (Modem\_RSSI\_CCA\_CNT)



#### Modem\_RSSI\_CCA\_CNT field descriptions

| Field        | Description                                                                     |
|--------------|---------------------------------------------------------------------------------|
| RSSI_CCA_CNT | RSSI/CCA Continuous Value                                                       |
|              | Continuous update of average RSSI value, available throughout packet reception. |

# 9.2.40 ASM Control 1 (Modem\_ASM\_CTRL1)

Address: 0h base + 28h offset = 28h

| Bit   | 7     | 6     | 5        | 4   | 3   | 2   | 1        | 0        |
|-------|-------|-------|----------|-----|-----|-----|----------|----------|
| Read  | 0     | 0     | SELFTST  | CTR | CBC | AES | 0        | Reserved |
| Write | CLEAR | START | SELI ISI | om  | ОВС | ALG | LOAD_MAC | Heselveu |
| Reset | 0     | 0     | 0        | 0   | 0   | 0   | 0        | 0        |

#### Modem\_ASM\_CTRL1 field descriptions

| Field        | Description                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>CLEAR   | Clear<br>Write 1 to clear all memory in ASM. Writing a 0 does nothing. See the ASM section for programming<br>details.                  |
| 6<br>START   | Start<br>Write 1 to start the CBC or CTR or CCM or AES mode encryption. If SELFTST is set to 1, then start will<br>start selftest mode. |
| 5<br>SELFTST | Self Test                                                                                                                               |

Table continues on the next page ...

| Field         | Description                                                     |
|---------------|-----------------------------------------------------------------|
|               | Write 1 to start set mode to self test (not self clearing).     |
|               | 0 Module not in selftest mode.                                  |
|               | 1 Module in selftest mode.                                      |
| 4             | Need Name                                                       |
| CTR           | Write 1 to put ASM into counter encryption mode.                |
|               | 0 Counter mode encryption will not be performed.                |
|               | 1 Counter mode encryption will be performed.                    |
| 3             | Need Name                                                       |
| CBC           | Write 1 to put ASM into CBC-MAC mode.                           |
|               | 0 CBC-MAC generation will not be performed.                     |
|               | 1 CBC-MAC generation will be performed.                         |
| 2             | Need Name                                                       |
| AES           | Write 1 to put ASM into AES mode.                               |
|               | 0 AES mode encrption will not be performed.                     |
|               | 1 AES mode encrption will be performed.                         |
| 1<br>LOAD_MAC | Need Name                                                       |
|               | Write 1 to pre-load MAC with a value. Writing a 0 does nothing. |
| 0             | Reserved                                                        |
| Reserved      | This field is reserved.                                         |

#### Modem\_ASM\_CTRL1 field descriptions (continued)

# 9.2.41 ASM Control 2 (Modem\_ASM\_CTRL2)

Address: 0h base + 29h offset = 29h



#### Modem\_ASM\_CTRL2 field descriptions

| Field                    | Description                                                                                        |  |  |  |
|--------------------------|----------------------------------------------------------------------------------------------------|--|--|--|
|                          | ata Register Type Select                                                                           |  |  |  |
| DATA_REG_<br>TYPE_SELECT | This register selects the type of data to be written to or read from the 16x8 Data register field. |  |  |  |
|                          | 000 Key: The 16 AES Data register holds the key used for encryption.                               |  |  |  |
|                          | 001 Data: The 16 AES Data register hold the data to be encrypted or decrypted                      |  |  |  |
|                          | 010 CTR: The 16 AES Data register hold the counter value used to encrypt the data in counter mode. |  |  |  |
|                          |                                                                                                    |  |  |  |

Table continues on the next page ...

| Field    | Description                                                                                                                                                                                                                                                |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 011 CTR Result: The 16 AES Data register hold the counter mode encyption result                                                                                                                                                                            |
|          | 100 CBC Result: The 16 AES Data register hold CBC-MAC generated results.                                                                                                                                                                                   |
|          | 101 MAC: The 16 AES Data register hold the starting value for CBC-MAC generation.                                                                                                                                                                          |
|          | 110 AES Result: The 16 AES Data register hold the plain AES mode encryption result.                                                                                                                                                                        |
|          | 111 Reserved.                                                                                                                                                                                                                                              |
| 4–2      | Reserved                                                                                                                                                                                                                                                   |
| Reserved |                                                                                                                                                                                                                                                            |
|          | This field is reserved.                                                                                                                                                                                                                                    |
| 1        | Test Pass                                                                                                                                                                                                                                                  |
| LOAD_MAC |                                                                                                                                                                                                                                                            |
|          | If this bit is 1 then the hardware passed the self test. If self test fails then the module is not usable and the outputs will be set to all 0. The default state for this bit is 0. The software must initiate a self test before the module can be used. |
| 0        | Reserved                                                                                                                                                                                                                                                   |
| Reserved |                                                                                                                                                                                                                                                            |
|          | This field is reserved.                                                                                                                                                                                                                                    |

#### Modem\_ASM\_CTRL2 field descriptions (continued)

# 9.2.42 ASM Data (Modem\_ASM\_DATAn)

Address: 0h base + 2Ah offset +  $(1d \times i)$ , where i=0d to 15d

| Bit           | 7 | 6 | 5 | 4    | 3    | 2 | 1 | 0 |
|---------------|---|---|---|------|------|---|---|---|
| Read<br>Write |   |   |   | ASM_ | DATA |   |   |   |
| Reset         | 0 | 0 | 0 | 0    | 0    | 0 | 0 | 0 |

#### Modem\_ASM\_DATAn field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ASM_DATA | ASM Data                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | The 16x8 AES Data registers (128 bits) block serve as the interface between the ASM's internal memory segments and the external MCU. The destination or source of the data in these registers is controlled through the DATA_REG_TYPE_SELECT field in ASM_CTRL2. See the ASM section for programming detail. Register ASM_DATA_0 contains the fields ASM_DATA[7] through ASM_DATA_[0], ASM_DATA_1 contains the fields ASM_DATA[15] through ASM_DATA[8]. |

# 9.2.43 Overwrite Version Number (Modem\_OVERWRITE\_VER)

Address: 0h base + 3Bh offset = 3Bh



|     | Field | Description                                                                                                                             |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| OVE | VER   | Overwrite Version Number<br>Contains the version number of the overwrites.h file, used by stack software to write non-default values    |
|     |       | Contains the version number of the overwrites.h file, used by stack software to write non-default values into the radio's register map. |

#### Modem\_OVERWRITE\_VER field descriptions

# 9.2.44 CLK\_OUT Control (Modem\_CLK\_OUT\_CTRL)

This register provides control for CLK\_OUT.

Address: 0h base + 3Ch offset = 3Ch

| Bit           | 7              | 6           | 5           | 4          |
|---------------|----------------|-------------|-------------|------------|
| Read<br>Write | CLK_OUT_EXTEND | CLK_OUT_HIZ | CLK_OUT_SR  | CLK_OUT_DS |
| Reset         | 1              | 0           | 0           | 0          |
| Bit           | 3              | 2           | 1           | 0          |
| Read<br>Write | CLK_OUT_EN     |             | CLK_OUT_DIV |            |
| Reset         | 1              | 0           | 0           | 0          |

#### Modem\_CLK\_OUT\_CTRL field descriptions

| Field              | Description                                                                                                               |
|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 7                  | CLK_OUT Extend                                                                                                            |
| CLK_OUT_<br>EXTEND | Briefly extend CLK_OUT after deassertion of CLK_OUT_EN.                                                                   |
|                    | 0 Extends CLK_OUT for 128 clock cycles after the deassertion of CLK_OUT_EN.                                               |
|                    | 1 Deassertion of CLK_OUT_EN immediately stops CLK_OUT.                                                                    |
| 6                  | CLK_OUT High Impedence Select                                                                                             |
| CLK_OUT_HIZ        | Selects whether CLK_OUT is placed into high-impedence mode or output mode.                                                |
|                    | 0 CLK_OUT pad is in output mode (Output Buffer Enable=1, and Input Buffer Enable=0).                                      |
|                    | <ol> <li>Place the CLK_OUT pad in high-impedence mode (Output Buffer Enable=0, and Input Buffer<br/>Enable=0).</li> </ol> |
| 5                  | CLK_OUT Slew Rate                                                                                                         |
| CLK_OUT_SR         | Enables or disables slew rate limiting for CLK_OUT pad.                                                                   |
|                    | 0 Disable slew rate limiting for CLK_OUT pad.                                                                             |
|                    | 1 Enable slew rate limiting for CLK_OUT pad.                                                                              |
| 4<br>CLK_OUT_DS    | CLK_OUT Drive Strength                                                                                                    |
|                    | Selects the drive strength for CLK_OUT.                                                                                   |
|                    | 0 Normal drive strength for CLK_OUT pad.                                                                                  |
|                    | 1 High drive strength for CLK_OUT pad.                                                                                    |

Table continues on the next page ...

| Field       | Description                                                                                                                                                       |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 3           | Transmitter Interrupt Status                                                                                                                                      |  |  |  |
| CLK_OUT_EN  | Shows the status of a transmit operation. This is write a 1 to clear bit.                                                                                         |  |  |  |
|             | 0 CLK_OUT pad is held at 0 (assuming CLK_OUT_HIZ=0).                                                                                                              |  |  |  |
|             | 1 CLK_OUT pad is driven with a clock whose frequency is determined by the CLK_OUT_DIV setting.                                                                    |  |  |  |
| CLK_OUT_DIV | CLK_OUT Divide                                                                                                                                                    |  |  |  |
|             | If programming CLK_OUT to >8 MHz, it is advisable to set CLK_OUT_DS=1. (High drive strength CLK_OUT pad.) The CLK_OUT frequency (if CLK_OUT_EN=1), is as follows: |  |  |  |
|             | 000 32 MHz                                                                                                                                                        |  |  |  |
|             | 001 16 MHz                                                                                                                                                        |  |  |  |
|             | 010 8 MHz                                                                                                                                                         |  |  |  |
|             | 011 4 MHz                                                                                                                                                         |  |  |  |
|             | 100 1 MHz                                                                                                                                                         |  |  |  |
|             | 101 250 kHz                                                                                                                                                       |  |  |  |
|             | 110 62.5 kHz                                                                                                                                                      |  |  |  |
|             | 111 32.787 kHz (32M Hz / 976)                                                                                                                                     |  |  |  |

#### Modem\_CLK\_OUT\_CTRL field descriptions (continued)

# 9.2.45 Power Modes (Modem\_PWR\_MODES)

This register determines the power modes.

Address: 0h base + 3Dh offset = 3Dh

| Bit   | 7          | 6        | 5          | 4        |
|-------|------------|----------|------------|----------|
| Read  | Deer       | un cond  | XTAL_READY |          |
| Write | Rese       | erved    |            | XTALEN   |
| Reset | 0          | 0        | 0          | 1        |
| Bit   | 3          | 2        | 1          | 0        |
| Read  |            | Deserved |            |          |
| Write | ASM_CLK_EN | Reserved | AUTODOZE   | PMC_MODE |
| Reset | 0          | 0        | 0          | 1        |

#### Modem\_PWR\_MODES field descriptions

| Field      | Description                                                                                                                      |
|------------|----------------------------------------------------------------------------------------------------------------------------------|
| 7–6        | Reserved                                                                                                                         |
| Reserved   |                                                                                                                                  |
|            | This field is reserved.                                                                                                          |
| 5          | XTAL Ready                                                                                                                       |
| XTAL_READY |                                                                                                                                  |
|            | Indicates whether the 32 MHz crystal oscillator has completed its warmup and is supplying clocks to the digital core. Read-only. |

Table continues on the next page...

| Modem_PWR_MODES field descriptions (continued) |
|------------------------------------------------|
| Description                                    |

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|               | 0 The 32 MHz crystal oscillator has not completed its warmup and is supplying clocks to the digital                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|               | CORe                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|               | 1 The 32 MHz crystal oscillator has completed its warmup and is supplying clocks to the digital core.                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| 4<br>XTALEN   | CLK_OUT Slew Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|               | HIBERNATE mode can be entered by setting XTALEN=0 and PMC_MODE=0. DOZE mode can be entered by setting XTALEN=1 and PMC_MODE=0. IDLE mode can be entered by setting XTALEN=1 and PMC_MODE=1. A programmed low-to-high transition on XTALEN will cause the WAKE_IRQ and WAKE_FROM_HIB status bits to become set, after the oscillator warmup has completed (see IRQSTS2 register). XTALEN=1 is mandatory for all transceiver operations, including transceiver timers. |  |  |  |  |  |  |
|               | 0 Disable the 32 MHz crystal oscillator.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|               | 1 Enable the 32 MHz crystal oscillator.                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 3             | ASM Clock Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| ASM_CLK_EN    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 2<br>Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|               | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 1<br>AUTODOZE | Automatic Doze Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|               | Automatic Doze mode allows the PMC operating mode to be controlled automatically by the sequence manager. In this mode, the PMC will be in high-power mode during all transceiver sequences (i.e., Run state), and in low power mode at all other times (i.e., Doze state). If AUTODOZE=0, then PMC operating mode is under direct software control (PMC_MODE bit)                                                                                                   |  |  |  |  |  |  |
|               | 0 Disable Automatic Doze mode.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|               | 1 Enable Automatic Doze mode.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| 0<br>PMC_MODE | PMC Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|               | Selects whether the PMC is in high-power mode or low-power mode.                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|               | 0 PMC is in low-power mode.                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|               | 1 PMC is in high-power mode.                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |

# 9.2.46 IAR Index (Modem\_IAR\_INDEX)



#### Modem\_IAR\_INDEX field descriptions

| Field     | Description |
|-----------|-------------|
| IAR_INDEX | IAR Index   |

#### MCR20A 2.4 GHz Low-Power Transceiver Reference Manual, Rev. 3, July 2016

. .

#### Modem\_IAR\_INDEX field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | A pointer into Indirect Access address space. During an SPI register access, when IAR_INDEX appears as the address in the control word (first SPI byte), the following byte will be loaded into IAR_INDEX, and the byte after that will write (or read) a byte from the indirect access register pointed to by IAR_INDEX. Hardware will automatically increment the pointer for subsequent byte accesses within the SPI burst transfer. See the SPI chapter for more information. Indirect Access auto-incrementing is not available in Hibernate state and should not be attempted; only single-access indirect register transfers are available in Hibernate. Direct address auto-incrementing is available in all power states. IAR_INDEX is not affected by any soft reset bit (see SOFT_RESET register). |

# 9.2.47 IAR Data (Modem\_IAR\_DATA)

Address: 0h base + 3Fh offset = 3Fh

| Bit           | 7 | 6 | 5 | 4     | 3    | 2 | 1 | 0 |
|---------------|---|---|---|-------|------|---|---|---|
| Read<br>Write |   |   |   | IAR_[ | DATA |   |   |   |
| Reset         | 0 | 0 | 0 | 0     | 0    | 0 | 0 | 0 |

#### Modem\_IAR\_DATA field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IAR_DATA | IAR DATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          | Window into Indirect Access Space. Data byte to be written (or read) to (from) this address during an Indirect Register Access will be written to (or read from) the Indirect Register pointed to by IAR_INDEX for the first data phase of the transfer, and the Indirect Address pointer will be automatically incremented for subsequent data phases during the SPI burst transfer. Indirect Access auto-incrementing is not available in Hibernate state and should not be attempted. Only single-access indirect register transfers are available in Hibernate. Direct address auto-incrementing is available in all power states. IAR_INDEX is not affected by any soft reset bit (see SOFT_RESET register). |
|          | The read-write access of this register is determined by the read-write access of the register in Indirect Access space to which the IAR_INDEX is pointing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# 9.3 Indirect registers memory map and register definition

The Indirect radio registers contains many bitfields for communicating with the radio.

#### NOTE

The Direct and Indirect registers can be accessed only through the SPI interface. Direct access by a single SPI control word and Indirect using the pointer register (IAR\_INDEX) and the data register (IAR\_DATA), which occupy the last two registers in direct access; addresses 0x3E and 0x3F, respectively.

| Indirect_M | odem | memory | map |
|------------|------|--------|-----|
|------------|------|--------|-----|

| Absolute<br>address<br>(hex) | Register name                                                         |                                   | Access | Reset value | Section/<br>page |
|------------------------------|-----------------------------------------------------------------------|-----------------------------------|--------|-------------|------------------|
| 0                            | Part Identification (Indirect_Modem_PART_ID)                          | 8                                 | R      |             | 9.3.1/165        |
| 1                            | XTAL 32 MHz Trim (Indirect_Modem_XTAL_TRIM)                           | 8                                 | R/W    | 77h         | 9.3.2/165        |
| 3                            | MAC PAN ID for PAN0<br>(Indirect_Modem_MACPANID0_LSB)                 | 8                                 | R/W    | FFh         | 9.3.3/166        |
| 4                            | MAC PAN ID for PAN0<br>(Indirect_Modem_MACPANID0_MSB)                 | 8                                 | R/W    | FFh         | 9.3.3/166        |
| 5                            | MAC Short Address for PAN0<br>(Indirect_Modem_MACSHORTADDRS0_LSB)     | 8                                 | R/W    | FFh         | 9.3.4/166        |
| 6                            | MAC Short Address for PAN0<br>(Indirect_Modem_MACSHORTADDRS0_MSB)     | 8                                 | R/W    | FFh         | 9.3.4/166        |
| 7                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_0)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| 8                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_1)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| 9                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_2)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| А                            | MAC Long Address for PAN0 8 R/W                                       |                                   | FFh    | 9.3.5/167   |                  |
| В                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_4)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| С                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_5)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| D                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_6)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| E                            | MAC Long Address for PAN0<br>(Indirect_Modem_MACLONGADDRS0_7)         | 8                                 | R/W    | FFh         | 9.3.5/167        |
| F                            | Receive Frame Filter<br>(Indirect_Modem_RX_FRAME_FILTER)              | 8                                 | R/W    | 0Fh         | 9.3.6/167        |
| 10                           | Frequency Integer for PAN1 (Indirect_Modem_PLL_INT1)                  | 8                                 | R/W    | 1Fh         | 9.3.7/168        |
| 11                           | Frequency Fractional Value for PAN1<br>(Indirect_Modem_PLL_FRAC1_LSB) | 8                                 | R/W    | FFh         | 9.3.8/169        |
| 12                           | Frequency Fractional Value for PAN1<br>(Indirect_Modem_PLL_FRAC1_MSB) | 8                                 | R/W    | FFh         | 9.3.8/169        |
| 13                           | Frequency Fractional Value for PAN1<br>(Indirect_Modem_MACPANID1_LSB) | equency Fractional Value for PAN1 |        | FFh         | 9.3.9/169        |
| 14                           | Frequency Fractional Value for PAN1<br>(Indirect_Modem_MACPANID1_MSB) | 8                                 |        | FFh         | 9.3.9/169        |
| 15                           | MAC Short Address for PAN1<br>(Indirect_Modem_MACSHORTADDRS1_LSB)     | 8 R/W                             |        | FFh         | 9.3.10/170       |
| 16                           | MAC Short Address for PAN1<br>(Indirect_Modem_MACSHORTADDRS1_MSB)     | 8                                 | R/W    | FFh         | 9.3.10/170       |
| 17                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_0)         | 8                                 | R/W    | FFh         | 9.3.11/170       |

Table continues on the next page ...

#### Indirect registers memory map and register definition

| Absolute<br>address<br>(hex) | Register name                                                                            |            | Access | Reset value | Section/<br>page |
|------------------------------|------------------------------------------------------------------------------------------|------------|--------|-------------|------------------|
| 18                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_1)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 19                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_2)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1A                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_3)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1B                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_4)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1C                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_5)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1D                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_6)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1E                           | MAC Long Address for PAN1<br>(Indirect_Modem_MACLONGADDRS1_7)                            | 8          | R/W    | FFh         | 9.3.11/170       |
| 1F                           | Dual PAN Control (Indirect_Modem_DUAL_PAN_CTRL)                                          | 8          | R/W    | FFh         | 9.3.12/171       |
| 20                           | Channel Frequency Dwell Time<br>(Indirect_Modem_DUAL_PAN_DWELL)                          | 8          | R/W    | 00h         | 9.3.13/172       |
| 21                           | Dual PAN Status (Indirect_Modem_DUAL_PAN_STS)                                            |            | R      | 00h         | 9.3.14/172       |
| 22                           | Clear Channel Assessment 1 Threshold<br>(Indirect_Modem_CCA1_THRESH)                     | 8          | R/W    | 4Bh         | 9.3.15/173       |
| 23                           | Clear Channel Assessment / ED Offset Computation<br>(Indirect_Modem_CCA1_ED_OFFSET_COMP) | tion 8 R/W |        | 6Dh         | 9.3.16/174       |
| 24                           | LQI Offset Computation<br>(Indirect_Modem_LQI_OFFSET_COMP)                               | 8          | R/W    | 24h         | 9.3.17/174       |
| 25                           | CCA Control (Indirect_Modem_CCA_CTRL)                                                    | 8          | R/W    | 5Fh         | 9.3.18/174       |
| 26                           | Clear Channel Assessment 2 Threshold Peak Compare<br>(Indirect_Modem_CCA2_CORR_PEAKS)    | 8          | R/W    | 60h         | 9.3.19/175       |
| 27                           | Clear Channel Assessment 2 Threshold<br>(Indirect_Modem_CCA2_THRESH)                     | 8          | R/W    | 82h         | 9.3.20/176       |
| 28                           | TMR PRESCALE (Indirect_Modem_TMR_PRESCALE)                                               | 8          | R/W    | 03h         | 9.3.21/176       |
| 2A                           | GPIO Data (Indirect_Modem_GPIO_DATA)                                                     | 8          | R/W    | 00h         | 9.3.22/177       |
| 2B                           | GPIO Direction Control (Indirect_Modem_GPIO_DIR)                                         | 8          | R/W    | 00h         | 9.3.23/178       |
| 2C                           | GPIO Pullup Enable (Indirect_Modem_GPIO_PUL_EN)                                          | 8          | R/W    | FFh         | 9.3.24/179       |
| 2D                           | GPIO Pullup Select (Indirect_Modem_GPIO_SEL)                                             | 8          | R/W    | FFh         | 9.3.25/181       |
| 2E                           | GPIO Drive Strength (Indirect_Modem_GPIO_DS)                                             | 8          | R/W    | FFh         | 9.3.26/182       |
| 30                           | Antenna Control (Indirect_Modem_ANT_PAD_CTRL)                                            | 8          | R/W    | 08h         | 9.3.27/183       |
| 31                           | Miscellaneous Pad Control<br>(Indirect_Modem_MISC_PAD_CTRL)                              | 8          | R/W    | 1Ah         | 9.3.28/185       |
| 35                           | RX_BYTE_COUNT (Indirect_Modem_RX_BYTE_COUNT)                                             | 8          | R      | 00h         | 9.3.29/185       |
| 36                           | RX_WTR_MARK (Indirect_Modem_RX_WTR_MARK)                                                 | 8          | R/W    | FFh         | 9.3.30/186       |
| 38                           | TXDELAY (Indirect_Modem_TXDELAY)                                                         | 8          | R/W    | 00h         | 9.3.31/186       |
| 39                           | ACKDELAY (Indirect_Modem_ACKDELAY)                                                       | 8          | R/W    | 3Dh         | 9.3.32/187       |

#### Indirect\_Modem memory map (continued)

Table continues on the next page...

| Absolute<br>address<br>(hex) | Register name                                                |   | Access | Reset value | Section/<br>page |
|------------------------------|--------------------------------------------------------------|---|--------|-------------|------------------|
| 51                           | Antenna AGC and FAD Control<br>(Indirect_Modem_ANT_AGC_CTRL) |   |        |             | 9.3.33/187       |
| 56                           | 6 LPPS_CTRL (Indirect_Modem_LPPS_CTRL)                       |   | R/W    | 1Eh         | 9.3.34/188       |
| 5B                           | B RSSI (Indirect_Modem_RSSI)                                 |   | R      | 00h         | 9.3.35/189       |
| 6E                           | XTAL Control (Indirect_Modem_XTAL_CTRL)                      | 8 | R/W    | 03h         | 9.3.36/190       |

Indirect\_Modem memory map (continued)

# 9.3.1 Part Identification (Indirect\_Modem\_PART\_ID)

The Part Identification register contains information on the mask set, the version, and the manufacturer of the transceiver.

Address: 0h base + 0h offset = 0h

| Bit   | 7    | 6     | 5 | 4       | 3 | 2        | 1 | 0 |
|-------|------|-------|---|---------|---|----------|---|---|
| Read  | MANU | JF_ID |   | VERSION |   | MASK_SET |   |   |
| Write |      |       |   |         |   |          |   |   |
| Reset |      |       |   |         |   |          |   |   |

#### Indirect\_Modem\_PART\_ID field descriptions

| Field           | Description                                                                                                                                                                                                                                                   |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>MANUF_ID | Manufacturer ID                                                                                                                                                                                                                                               |
| 5–3<br>VERSION  | <ul> <li>Version</li> <li>This field contains information about the quadrature version of the LNA mixer and VCO.</li> <li>001 Single quadrature version of the LNA mixer and VCO.</li> <li>010 Double quadrature version of the LNA mixer and VCO.</li> </ul> |
| MASK_SET        | Mask Set<br>This field contains information about the mask set of the transceiver.                                                                                                                                                                            |

# 9.3.2 XTAL 32 MHz Trim (Indirect\_Modem\_XTAL\_TRIM)



| Indirect_N | lodem_XT | AL_TRIM | field desc | riptions |
|------------|----------|---------|------------|----------|
|------------|----------|---------|------------|----------|

| Field     | Description                                                         |
|-----------|---------------------------------------------------------------------|
| XTAL_TRIM | XTAL 32 MHz Trim                                                    |
|           | XTAL 32 MHz trimming. See the XTAL32M section for more information. |

# 9.3.3 MAC PAN ID for PAN0 (Indirect\_Modem\_MACPANID0n)

Address: 0h base + 3h offset +  $(1d \times i)$ , where i=0d to 1d

| Bit           | 7 | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|---------------|---|---|---|------|-------|---|---|---|
| Read<br>Write |   |   |   | MACP | ANID0 |   |   |   |
| Reset         | 1 | 1 | 1 | 1    | 1     | 1 | 1 | 1 |

#### Indirect\_Modem\_MACPANID0n field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACPANID0 | MAC PAN ID for PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | The packet processor compares the incoming packet's destination PAN ID against the contents of this register to determine whether the packet is addressed to this device. Or, if the incoming packet is a Beacon frame, the packet processor compares the incoming packet source PAN ID against this register. Also, if PANCORDNTR0=1, and the incoming packet has no Destination Address field, and if the incoming packet is a Data or MAC Command frame, the packet processor compares the incoming packet source PAN ID against this register. |

# 9.3.4 MAC Short Address for PAN0 (Indirect\_Modem\_MACSHORTADDRS0*n*)

| Address: 0h base + 5h offset + $(1d \times i)$ , where i=0d to 1d |   |   |   |         |          |   |   |   |
|-------------------------------------------------------------------|---|---|---|---------|----------|---|---|---|
| Bit                                                               | 7 | 6 | 5 | 4       | 3        | 2 | 1 | 0 |
| Read<br>Write                                                     |   |   |   | MACSHOR | T_ADDRS0 |   |   |   |
| Reset                                                             | 1 | 1 | 1 | 1       | 1        | 1 | 1 | 1 |

#### Indirect\_Modem\_MACSHORTADDRS0n field descriptions

| Field               | Description                                                                                                                                                                                                                                    |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACSHORT_<br>ADDRS0 | MAC Short Address for PAN0                                                                                                                                                                                                                     |
|                     | MAC Short Address for PAN0, for 16-bit destination addressing mode. The packet processor compares the incoming packet's Destination Address against the contents of this register to determine whether the packet is addressed to this device. |

# 9.3.5 MAC Long Address for PAN0 (Indirect\_Modem\_MACLONGADDRS0*n*)

Address: 0h base + 7h offset +  $(1d \times i)$ , where i=0d to 7d

| Bit           | 7 | 6 | 5 | 4      | 3       | 2 | 1 | 0 |
|---------------|---|---|---|--------|---------|---|---|---|
| Read<br>Write |   |   |   | MACLON | GADDRS0 |   |   |   |
| Reset         | 1 | 1 | 1 | 1      | 1       | 1 | 1 | 1 |

#### Indirect\_Modem\_MACLONGADDRS0n field descriptions

| Field         | Description                                                                                                                                                                                                                                   |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACLONGADDRS0 | MAC Long Address for PAN0                                                                                                                                                                                                                     |
|               | MAC Long Address for PAN0, for 64-bit destination addressing mode. The packet processor compares the incoming packet's Destination Address against the contents of this register to determine whether the packet is addressed to this device. |

# 9.3.6 Receive Frame Filter (Indirect\_Modem\_RX\_FRAME\_FILTER)

Address: 0h base + Fh offset = Fh

| Bit           | 7      | 6      | 5                      | 4         |
|---------------|--------|--------|------------------------|-----------|
| Read<br>Write | FRM_   | _VER   | ACTIVE_<br>PROMISCUOUS | NS_FT     |
| Reset         | 0      | 0      | 0                      | 0         |
| Bit           | 3      | 2      | 1                      | 0         |
| Read<br>Write | CMD_FT | ACK_FT | DATA_FT                | BEACON_FT |
| Reset         | 1      | 1      | 1                      | 1         |

#### Indirect\_Modem\_RX\_FRAME\_FILTER field descriptions

| Field                       | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6                         | Frame Version Selector                                                                                                                                                                                                                                                                                                                                                                                  |
| FRM_VER                     | The incoming packet's Frame Control Field is parsed to obtain the FrameVersion subfield, and that value is compared against this register, in accordance with the following. Frames received with FrameVersion 2 or 3 will be treated identically to FrameVersion 1, with respect to parsing of the Auxiliary Security Header. Other than this Header, all 4 frame versions will be treated identically |
|                             | 00 Any FrameVersion accepted (0, 1, 2 and 3).                                                                                                                                                                                                                                                                                                                                                           |
|                             | 01 Accept only FrameVersion 0 packets (2003 compliant).                                                                                                                                                                                                                                                                                                                                                 |
|                             | 10 Accept only FrameVersion 1 packets (2006 compliant).                                                                                                                                                                                                                                                                                                                                                 |
|                             | 11 Accept FrameVersion 0 and 1 packets; reject all others.                                                                                                                                                                                                                                                                                                                                              |
| 5<br>ACTIVE_<br>PROMISCUOUS | Active Promiscuous                                                                                                                                                                                                                                                                                                                                                                                      |

Table continues on the next page ...

#### Indirect\_Modem\_RX\_FRAME\_FILTER field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                        |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <ul> <li>Normal operation (default).</li> <li>Provide data indication on all received packets under the same rules that apply in Promiscuous mode, however acknowledge those packets under rules that apply in non-Promiscuous mode</li> </ul>                     |
| 4<br>NS_FT     | Not-Specified (Reserved) Frame Type<br>Field determines whether Not-Specified (Reserved) frame types are enabled.                                                                                                                                                  |
|                | <ul> <li>Reject all reserved frames.</li> <li>Not-Specified (reserved) frame type enabled. No packet filtering is performed, except for frame length checking (FrameLength is greater than or equal to 5 and FrameLength is less than or equal to 127).</li> </ul> |
| 3<br>CMD_FT    | MAC Command Frame Type<br>Field determines whether MAC Command frame types are enabled.                                                                                                                                                                            |
|                | <ul><li>0 Reject all MAC Command frames.</li><li>1 MAC Command frame type enabled.</li></ul>                                                                                                                                                                       |
| 2<br>ACK_FT    | Acknowledge Frame Type<br>Field determines whether Acknowledge frame types are enabled.                                                                                                                                                                            |
|                | <ul><li>0 Reject all Acknowledge frames.</li><li>1 Acknowledge frame type enabled.</li></ul>                                                                                                                                                                       |
| 1<br>DATA_FT   | Data Frame Type<br>Field determines whether Data frame types are enabled.                                                                                                                                                                                          |
|                | <ul><li>0 Reject all Data frames.</li><li>1 Data frame type enabled.</li></ul>                                                                                                                                                                                     |
| 0<br>BEACON_FT | Beacon Frame Type<br>Field determines whether Beacon frame types are enabled.                                                                                                                                                                                      |
|                | <ul><li>0 Reject all Beacon frames.</li><li>1 Beacon frame type enabled.</li></ul>                                                                                                                                                                                 |

# 9.3.7 Frequency Integer for PAN1 (Indirect\_Modem\_PLL\_INT1)

Address: 0h base + 10h offset = 10h



#### Indirect\_Modem\_PLL\_INT1 field descriptions

| Field           | Description             |
|-----------------|-------------------------|
| 7–5<br>RESERVED | This field is reserved. |

Table continues on the next page...

| Field    | Description                                                                                                                                                                                      |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_INT1 | Frequency Integer for PAN1                                                                                                                                                                       |
|          | F = ((PLL_INT1+64) + (PLL_FRAC1/65536)) * 32 MHz. See PLL section for more details. This register should not be programmed (should be left in its default state) if Dual PAN mode is not in use. |

#### Indirect\_Modem\_PLL\_INT1 field descriptions (continued)

# 9.3.8 Frequency Fractional Value for PAN1 (Indirect\_Modem\_PLL\_FRAC1*n*)

Address: 0h base + 11h offset +  $(1d \times i)$ , where i=0d to 1d

| Bit           | 7 | 6 | 5 | 4     | 3    | 2 | 1 | 0 |
|---------------|---|---|---|-------|------|---|---|---|
| Read<br>Write |   |   |   | PLL_F | RAC1 |   |   |   |
| Reset         | 1 | 1 | 1 | 1     | 1    | 1 | 1 | 1 |

#### Indirect\_Modem\_PLL\_FRAC1n field descriptions

| Field     | Description                                                                                                                                                    |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_FRAC1 | Frequency Fractional Value for PAN1                                                                                                                            |
|           | F = ((PLL_INT1+64) + (PLL_FRAC1/65536)) * 32 MHz. This register should not be programmed (should be left in its default state) if Dual PAN mode is not in use. |

# 9.3.9 Frequency Fractional Value for PAN1 (Indirect\_Modem\_MACPANID1*n*)

| Address: 0h bas | Address: 0h base + 13h offset + (1d × i), where i=0d to 1d |   |   |       |       |   |   |   |
|-----------------|------------------------------------------------------------|---|---|-------|-------|---|---|---|
| Bit             | 7                                                          | 6 | 5 | 4     | 3     | 2 | 1 | 0 |
| Read<br>Write   |                                                            |   |   | MACPA | ANID1 |   |   |   |
| Reset           | 1                                                          | 1 | 1 | 1     | 1     | 1 | 1 | 1 |

#### Indirect\_Modem\_MACPANID1n field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACPANID1 | MAC PAN ID for PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | The packet processor compares the incoming packet's Destination PAN ID against the contents of this register to determine if the packet is addressed to this device; or if the incoming packet is a Beacon frame, the packet processor compares the incoming packet source PAN ID against this register. Also, if PANCORDNTR0=1, and the incoming packet has no Destination Address field, and if the incoming packet is a Data or MAC Command frame, the packet processor compares the incoming packet processor compares the incoming packet processor compares the incoming packet source PAN ID against this register. |

Indirect registers memory map and register definition

# 9.3.10 MAC Short Address for PAN1 (Indirect\_Modem\_MACSHORTADDRS1*n*)

Address: 0h base + 15h offset +  $(1d \times i)$ , where i=0d to 1d

| Bit           | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|----------------|---|---|---|---|---|---|---|
| Read<br>Write | MACSHORTADDRS1 |   |   |   |   |   |   |   |
| Reset         | 1              | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

#### Indirect\_Modem\_MACSHORTADDRS1n field descriptions

| Field          | Description                                                                                                                                                                                                   |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACSHORTADDRS1 | MAC Short Address for PAN1                                                                                                                                                                                    |
|                | For 16-bit destination addressing mode. The packet processor compares the incoming packet's Destination Address against the contents of this register to determine if the packet is addressed to this device. |

# 9.3.11 MAC Long Address for PAN1 (Indirect\_Modem\_MACLONGADDRS1*n*)

Address: 0h base + 17h offset +  $(1d \times i)$ , where i=0d to 7d

| Bit           | 7 | 6 | 5 | 4      | 3       | 2 | 1 | 0 |
|---------------|---|---|---|--------|---------|---|---|---|
| Read<br>Write |   |   |   | MACLON | GADDRS1 |   |   |   |
| Reset         | 1 | 1 | 1 | 1      | 1       | 1 | 1 | 1 |

#### Indirect\_Modem\_MACLONGADDRS1*n* field descriptions

| Field         | Description                                                                                                                                                                                                        |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACLONGADDRS1 | MAC Long Address for PAN1                                                                                                                                                                                          |
|               | For 64-bit destination addressing mode. The packet processor compares the incoming packet's Destination Address against the contents of this register to determine whether the packet is addressed to this device. |

# 9.3.12 Dual PAN Control (Indirect\_Modem\_DUAL\_PAN\_CTRL)

Address: 0h base + 1Fh offset = 1Fh

| Bit   | 7               | 6            | 5             | 4              |
|-------|-----------------|--------------|---------------|----------------|
| Read  |                 |              |               |                |
| Write |                 | DOAL_PAN     | I_SAM_LVL     |                |
| Reset | 1               | 1            | 1             | 1              |
| Bit   | 3               | 2            | 1             | 0              |
| Read  | CURRENT_NETWORK | PANCORDNTR1  | DUAL_PAN_AUTO | ACTIVE_NETWORK |
| Write |                 | FANCONDINTET | DUAL_FAN_AUTO | ACTIVE_NETWORK |
| Reset | 1               | 1            | 1             | 1              |

#### Indirect\_Modem\_DUAL\_PAN\_CTRL field descriptions

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4                     | Source Address Matching Level                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DUAL_PAN_<br>SAM_LVL    | For the Source Address Matching Table, sets the dividing line between the PAN0 and PAN1 sections of the table. Table indeces at or above this level belong to PAN1. Table entries below this level belong to PAN0. Default = 12 (entire table is PAN0). In Dual PAN mode, if both PANs occupy the same channel, hardware detects this and makes the entire Source Address Matching Table available to both PANs simultaneously; in this case, DUAL_PAN_SAM_LVL has no effect.            |
| 3                       | Current Network                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CURRENT_<br>NETWORK     | This read-only bit indicates which PAN is currently selected by hardware in automatic Dual PAN mode.                                                                                                                                                                                                                                                                                                                                                                                     |
|                         | 0 PAN0 is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                         | 1 PAN1 is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2<br>PANCORDNTR1        | PAN Coordinator on PAN1                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PANCORDNIRI             | Device is a PAN Coordinator on PAN1. Allows device to receive packets with no destination address, if Source PAN ID matches.                                                                                                                                                                                                                                                                                                                                                             |
| 1                       | Dual Pan Automatic Operating Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DUAL_PAN_<br>AUTO       | Activates automatic Dual PAN operating mode. In this mode, PAN-switching is controlled by hardware at a pre-programmed rate, determined by DUAL_PAN_DWELL. Whenever DUAL_PAN_AUTO=0, CURRENT_NETWORK=ACTIVE_NETWORK at all times. In other words, software directly controls which PAN is selected. Whenever DUAL_PAN_AUTO=1, CURRENT_NETWORK is controlled by hardware. See the packet processor section for more detail.                                                               |
|                         | 0 Manual Dual PAN mode (or Single PAN mode).                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                         | 1 Auto Dual PAN Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0<br>ACTIVE_<br>NETWORK | Active Network<br>Selects the PAN on which to transceive, by activating a PAN parameter set (PAN0 or PAN1). In Manual<br>Dual PAN mode (or Single PAN mode), this bit selects the active PAN parameter set (channel and<br>addressing parameters) which governs all autosequences. In Auto Dual PAN mode, this bit selects the<br>PAN on which to begin transceiving, latched at the point at which DUAL_PAN_DWELL register is written.<br>See packet processor section for more detail. |

Table continues on the next page ...

| Field | Description    |
|-------|----------------|
|       | 0 Select PAN0. |
|       | 1 Select PAN1. |

# 9.3.13 Channel Frequency Dwell Time (Indirect\_Modem\_DUAL\_PAN\_DWELL)

Address: 0h base + 20h offset = 20h

| Bit           | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|---------------|---|---|---|---------|---------|---|---|---|
| Read<br>Write |   |   |   | DUAL_PA | N_DWELL |   |   |   |
| Reset         | 0 | 0 | 0 | 0       | 0       | 0 | 0 | 0 |

#### Indirect\_Modem\_DUAL\_PAN\_DWELL field descriptions

| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Channel Frequency Dwell Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| In Auto Dual PAN mode, hardware will toggle the PAN, after dwelling on the current PAN for the interval described below (assuming Preamble/SFD not detected). A write to DUAL_PAN_DWELL, always re-<br>initilizes the DWELL TIMER to the programmed value. If a write to DUAL_PAN_DWELL occurs during an autosequence, the DWELL TIMER will begin counting down immediately. If a write to DUAL_PAN_DWELL occurs during an autosequence begins; it will begin counting at the start of the sequence warmup. In Auto Dual PAN mode, hardware will toggle the PAN, after dwelling on the current PAN for the interval described below (assuming Preamble/SFD not detected). A write to DUAL_PAN_DWELL, always re-initilizes the DWELL TIMER to the programmed value. If a write to DUAL_PAN_DWELL, always re-initilizes the DWELL TIMER to the programmed value. If a write to DUAL_PAN_DWELL, always re-initilizes the DWELL TIMER to the programmed value. If a write to DUAL_PAN_DWELL occurs during an autosequence, the DWELL TIMER will begin counting down immediately. If a write to DUAL_PAN_DWELL occurs when there is no autosequence underway, the DWELL TIMER will not begin counting an autosequence, the DWELL TIMER will begin counting down immediately. If a write to DUAL_PAN_DWELL occurs when there is no autosequence underway, the DWELL TIMER will not begin counting until the next autosequence begins; it will begin counting at the start of the sequence warmup. |
| A write to DUAL_PAN_DWELL also causes the value of ACTIVE_NETWORK to get latched into the hardware. This latched value will be the starting point for the automatic dual-pan mode (i.e., start on PAN0 or on PAN1). The starting value takes effect immediately (if sequence is underway and DUAL_PAN_AUTO=1), or is otherwise delayed until sequence starts and DUAL_PAN_AUTO=1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

# 9.3.14 Dual PAN Status (Indirect\_Modem\_DUAL\_PAN\_STS)



Address: 0h base + 21h offset = 21h

#### Indirect\_Modem\_DUAL\_PAN\_STS field descriptions

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>RECD_ON_<br>PAN1 | Received on PAN1<br>Indicates the packet that was just received, was received on PAN1. In Dual PAN mode operating on 2<br>different channels, RECD_ON_PAN0 will be set if CURRENT_NETWORK=0 when the packet was<br>received, regardless of FILTERFAIL status. In Dual PAN mode operating with same channel on both<br>networks, CURRENT_NETWORK will be ignored and RECD_ON_PAN0 will be set only if a valid packet                                                                                                                                                           |
|                       | was received on PAN0 (PAN0's FILTERFAIL_FLAG is deasserted). RECD_ON_PAN0 remains valid until the start of the next autosequence. See the packet processor section for more detail.                                                                                                                                                                                                                                                                                                                                                                                           |
| 6<br>RECD_ON_         | Received on PAN0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PAN0                  | Indicates the packet that was just received, was received on PAN0. In Dual PAN mode operating on 2 different channels, RECD_ON_PAN0 will be set if CURRENT_NETWORK=0 when the packet was received, regardless of FILTERFAIL status. In Dual PAN mode operating with same channel on both networks, CURRENT_NETWORK will be ignored and RECD_ON_PAN0 will be set only if a valid packet was received on PAN0 (PAN0's FILTERFAIL_FLAG is deasserted). RECD_ON_PAN0 remains valid until the start of the next autosequence. See the packet processor section for more detail.    |
| DUAL_PAN_<br>REMAIN   | Dual PAN Remaining Time<br>This read-only register indicates time remaining before next PAN switch in auto Dual PAN mode. The units<br>for this register, depend on the PRESCALER setting (bits [1:0]) in the DUAL_PAN_DWELL register. The<br>readback value indicates that between N-1 and N timebase units remain until the next PAN switch. For<br>example, a DUAL_PAN_REMAIN readback value of 3, with a DUAL_PAN_DWELL PRESCALER setting<br>of 2 (10 ms), indicates that between 20 ms (2 * 10 ms) and 30 ms (3 * 10 ms), remain until the next<br>automatic PAN switch. |
|                       | 00 0.5 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                       | 01 2.5 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                       | 10 10 ms<br>11 50 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## 9.3.15 Clear Channel Assessment 1 Threshold (Indirect\_Modem\_CCA1\_THRESH)

Address: 0h base + 22h offset = 22h

| Bit           | 7 | 6 | 5 | 4      | 3     | 2 | 1 | 0 |
|---------------|---|---|---|--------|-------|---|---|---|
| Read<br>Write |   |   |   | CCA1_T | HRESH |   |   |   |
| Reset         | 0 | 1 | 0 | 0      | 1     | 0 | 1 | 1 |

#### Indirect\_Modem\_CCA1\_THRESH field descriptions

| Field       | Description                                                  |  |  |
|-------------|--------------------------------------------------------------|--|--|
| CCA1_THRESH | lear Channel Assessment 1 Threshold                          |  |  |
|             | Programmable energy threshold register to detect CCA mode 1. |  |  |

# 9.3.16 Clear Channel Assessment / ED Offset Computation (Indirect\_Modem\_CCA1\_ED\_OFFSET\_COMP)

Address: 0h base + 23h offset = 23h

| Bit           | 7 | 6 | 5 | 4          | 3         | 2 | 1 | 0 |
|---------------|---|---|---|------------|-----------|---|---|---|
| Read<br>Write |   |   |   | CCA1_ED_OF | FSET_COMF | ) |   |   |
| Reset         | 0 | 1 | 1 | 0          | 1         | 1 | 0 | 1 |

#### Indirect\_Modem\_CCA1\_ED\_OFFSET\_COMP field descriptions

| Field                   | Description                                        |
|-------------------------|----------------------------------------------------|
| CCA1_ED_<br>OFFSET_COMP | Clear Channel Assessment / ED Offset Computation   |
|                         | Programmable amount to offset CCA/ED computations. |

# 9.3.17 LQI Offset Computation (Indirect\_Modem\_LQI\_OFFSET\_COMP)

Address: 0h base + 24h offset = 24h

| Bit           | 7 | 6 | 5 | 4        | 3       | 2 | 1 | 0 |
|---------------|---|---|---|----------|---------|---|---|---|
| Read<br>Write |   |   |   | LQI_OFFS | ET_COMP |   |   |   |
| Reset         | 0 | 0 | 1 | 0        | 0       | 1 | 0 | 0 |

#### Indirect\_Modem\_LQI\_OFFSET\_COMP field descriptions

| Field               | Description                                         |
|---------------------|-----------------------------------------------------|
| LQI_OFFSET_<br>COMP | LQI Offset Computation                              |
|                     | Programmable amount to offset RSSI based LQI value. |

# 9.3.18 CCA Control (Indirect\_Modem\_CCA\_CTRL)

Address: 0h base + 25h offset = 25h

| Bit           | 7               | 6             | 5               | 4                 |  |
|---------------|-----------------|---------------|-----------------|-------------------|--|
| Read<br>Write | Reserved        | AGC_FRZ_EN    | CONT_RSSI_EN    | LQI_RSSI_NOT_CORR |  |
| Reset         | 0               | 1             | 0               | 1                 |  |
| Bit           | 3               | 2             | 1               | 0                 |  |
| Read          | CCA3_AND_NOT_OR | OWER_COMP_EN_ | OWER_COMP_EN_ED | OWER_COMP_EN_     |  |
| Write         |                 | LQI           |                 | CCA1              |  |
| Reset         | 1               | 1             | 1               | 1                 |  |

#### Indirect\_Modem\_CCA\_CTRL field descriptions

| Field                      | Description                                                                                                                                                                                                |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved              | This field is reserved.                                                                                                                                                                                    |
| 6<br>AGC_FRZ_EN            | AGC Freeze Enable                                                                                                                                                                                          |
|                            | <ul><li>AGC operates continuously during reception.</li><li>Enable the AGC Freeze mode after SFD detection.</li></ul>                                                                                      |
| 5<br>CONT_RSSI_EN          | <ul> <li>Continuous RSSI Averaging Enable</li> <li>0 RSSI averaging stops 64 μs after preamble is detected (for LQI), or after the CCA or Energy Detect operation is completed, for Sequence C.</li> </ul> |
|                            | 1 Enable continuous RSSI averaging.                                                                                                                                                                        |
| 4<br>LQI_RSSI_NOT_<br>CORR | LQI Mode<br>0 LQI based on Correlation peaks.<br>1 LQI based on RSSI.                                                                                                                                      |
| 3<br>CCA3_AND_<br>NOT_OR   | Determines the way CCA3 is required to be detected.<br>0 CCA1 or CCA2.<br>1 CCA1 and CCA2.                                                                                                                 |
| 2<br>OWER_COMP_<br>EN_LQI  | Enable offset compensation and slope correction to averaged RSSI value during LQI computation, when LQI_RSSI_NOT_CORR=1.                                                                                   |
| 1<br>OWER_COMP_<br>EN_ED   | Enable offset compensation and slope correction to averaged RSSI value during Energy Detect mode.                                                                                                          |
| 0<br>OWER_COMP_<br>EN_CCA1 | Enable offset compensation and slope correction to averaged RSSI value during CCA1 mode.                                                                                                                   |

# 9.3.19 Clear Channel Assessment 2 Threshold Peak Compare (Indirect\_Modem\_CCA2\_CORR\_PEAKS)

Address: 0h base + 26h offset = 26h



#### Indirect\_Modem\_CCA2\_CORR\_PEAKS field descriptions

| Field    | Description             |
|----------|-------------------------|
| 7        | This field is reserved. |
| Reserved |                         |

Table continues on the next page...

#### Indirect\_Modem\_CCA2\_CORR\_PEAKS field descriptions (continued)

| Field                    | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CCA2_MIN_<br>NUM_CORR_TH | Programmable threshold to be compared against number of correlation peaks that exceeded cca2_corr_thresh for detecting CCA mode 2. Number of peaks detected = cca2_min_num_corr_th + 1; Example: If it is programmed to 3, CCA2 logic looks for at least 4 correlation peaks that crossed the threshold, to indicate channel is idle or busy. |
| CCA2_NUM_<br>CORR_PEAKS  | Counts of number of peaks that crossed cca2_corr_thresh. Read-only.                                                                                                                                                                                                                                                                           |

# 9.3.20 Clear Channel Assessment 2 Threshold (Indirect\_Modem\_CCA2\_THRESH)

Address: 0h base + 27h offset = 27h

| Bit           | 7 | 6 | 5 | 4      | 3     | 2 | 1 | 0 |
|---------------|---|---|---|--------|-------|---|---|---|
| Read<br>Write |   |   |   | CCA2_T | HRESH |   |   |   |
| Reset         | 1 | 0 | 0 | 0      | 0     | 0 | 1 | 0 |

#### Indirect\_Modem\_CCA2\_THRESH field descriptions

| Field       | Description                                                  |  |  |  |  |
|-------------|--------------------------------------------------------------|--|--|--|--|
| CCA2_THRESH | Clear Channel Assessment 2 Threshold                         |  |  |  |  |
|             | Programmable energy threshold register to detect CCA mode 2. |  |  |  |  |

# 9.3.21 TMR PRESCALE (Indirect\_Modem\_TMR\_PRESCALE)

Address: 0h base + 28h offset = 28h

| Bit           | 7        | 6 | 5 | 4 | 3 | 2  | 1           | 0  |
|---------------|----------|---|---|---|---|----|-------------|----|
| Read<br>Write | Reserved |   |   |   |   | TN | /IR_PRESCAL | _E |
| Reset         | 0        | 0 | 0 | 0 | 0 | 0  | 1           | 1  |

#### Indirect\_Modem\_TMR\_PRESCALE field descriptions

| Field            | Description                                                    |  |  |  |  |
|------------------|----------------------------------------------------------------|--|--|--|--|
| 7–3              | Reserved                                                       |  |  |  |  |
| Reserved         |                                                                |  |  |  |  |
|                  | This field is reserved.                                        |  |  |  |  |
| TMR_<br>PRESCALE | Timer Prescaler                                                |  |  |  |  |
|                  | Establishes the Event Timer lock rate(Maximum timer duration). |  |  |  |  |
|                  | 000 Reserved                                                   |  |  |  |  |
|                  | 001 Reserved                                                   |  |  |  |  |
|                  | 010 500 kHz(33.55 S)                                           |  |  |  |  |

Table continues on the next page...

| Field | Description                  |
|-------|------------------------------|
|       | 011 250 kHZ(67.11 S)-default |
|       | 100 125 kHZ(134.22 S)        |
|       | 101 62.5 kHZ(268.44 S)       |
|       | 110 31.25 kHZ(536.87 S)      |
|       | 111 15.625 kHZ(1073.74 S)    |

#### Indirect\_Modem\_TMR\_PRESCALE field descriptions (continued)

# 9.3.22 GPIO Data (Indirect\_Modem\_GPIO\_DATA)

Address: 0h base + 2Ah offset = 2Ah

| Bit   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Read  | GPIO_ |
| Write | DATA8 | DATA7 | DATA6 | DATA5 | DATA4 | DATA3 | DATA2 | DATA1 |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### Indirect\_Modem\_GPIO\_DATA field descriptions

| Field           | Description                                                                                                                                                                                                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>GPIO_DATA8 | GPIO Data 8                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 6<br>GPIO_DATA7 | GPIO Data 7                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 5<br>GPIO_DATA6 | GPIO Data 6                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 4<br>GPIO_DATA5 | GPIO Data 5                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 3<br>GPIO_DATA4 | GPIO Data 4                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 2<br>GPIO_DATA3 | GPIO Data 3                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |

Table continues on the next page ...

| Field           | Description                                                                                                                                                                                                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>GPIO DATA2 | GPIO Data 2                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
| 0<br>GPIO DATA1 | GPIO Data 1                                                                                                                                                                                                                                                                           |
|                 | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |

#### Indirect\_Modem\_GPIO\_DATA field descriptions (continued)

# 9.3.23 GPIO Direction Control (Indirect\_Modem\_GPIO\_DIR)

Address: 0h base + 2Bh offset = 2Bh

| Bit           | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|---------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Read<br>Write | GPIO_DIR8 | GPIO_DIR7 | GPIO_DIR6 | GPIO_DIR5 | GPIO_DIR4 | GPIO_DIR3 | GPIO_DIR2 | GPIO_DIR1 |
| Reset         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

#### Indirect\_Modem\_GPIO\_DIR field descriptions

| Field          | Description                                                                |
|----------------|----------------------------------------------------------------------------|
| 7              | GPIO Direction Control 8                                                   |
| GPIO_DIR8      | Determines the direction for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}. |
|                | 0 Pin is in input mode.                                                    |
|                | 1 Pin is in output mode.                                                   |
| 6<br>GPIO_DIR7 | GPIO Direction Control 7                                                   |
| _              | Determines the direction for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}. |
|                | 0 Pin is in input mode.                                                    |
|                | 1 Pin is in output mode.                                                   |
| 5              | GPIO Direction Control 6                                                   |
| GPIO_DIR6      | Determines the direction for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}. |
|                | 0 Pin is in input mode.                                                    |
|                | 1 Pin is in output mode.                                                   |
| 4<br>GPIO_DIR5 | GPIO Direction Control 5                                                   |
|                | Determines the direction for each of the GPIO pins (GPIO8, GPIO7,, GPIO1). |
|                | 0 Pin is in input mode.                                                    |
|                | 1 Pin is in output mode.                                                   |
| 3              | GPIO Direction Control 4                                                   |
| GPIO_DIR4      |                                                                            |

Table continues on the next page ...

#### Indirect\_Modem\_GPIO\_DIR field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | Determines the direction for each of the GPIO pins (GPIO8, GPIO7,, GPIO1).                                                                                                                                                                                                            |
|                | 0 Pin is in input mode.                                                                                                                                                                                                                                                               |
|                | 1 Pin is in output mode.                                                                                                                                                                                                                                                              |
| 2<br>GPIO_DIR3 | GPIO Direction Control 3                                                                                                                                                                                                                                                              |
|                | Determines the direction for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}.                                                                                                                                                                                                            |
|                | 0 Pin is in input mode.                                                                                                                                                                                                                                                               |
|                | 1 Pin is in output mode.                                                                                                                                                                                                                                                              |
| 1              | GPIO Direction Control 2                                                                                                                                                                                                                                                              |
| GPIO_DIR2      | Determines the direction for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}.                                                                                                                                                                                                            |
|                | 0 Pin is in input mode.                                                                                                                                                                                                                                                               |
|                | 1 Pin is in output mode.                                                                                                                                                                                                                                                              |
| 0<br>GPIO_DIR1 | GPIO Direction Control 1                                                                                                                                                                                                                                                              |
|                | Write data to this register determines the state of the GPIO pins {GPIO8, GPIO7,, GPIO1}, when the corresponding GPIO_DIR bit for that pin is set to 1. Data read from this register returns the state of the GPIO pins, when the corresponding GPIO_DIR bit for that pin is set to 0 |
|                | 0 Pin is in input mode.                                                                                                                                                                                                                                                               |
|                | 1 Pin is in output mode.                                                                                                                                                                                                                                                              |

# 9.3.24 GPIO Pullup Enable (Indirect\_Modem\_GPIO\_PUL\_EN)

| Address: 0h base + 2C | Ch offset = 2Ch |
|-----------------------|-----------------|
|-----------------------|-----------------|

| Bit           | 7             | 6            | 5            | 4            |
|---------------|---------------|--------------|--------------|--------------|
| Read<br>Write | GPIO_PUL_EN8  | GPIO_PUL_EN7 | GPIO_PUL_EN6 | GPIO_PUL_EN5 |
| Reset         | 1             | 1            | 1            | 1            |
| Bit           | 3             | 2            | 1            | 0            |
| Read<br>Write | GPIO_PUL_EN14 | GPIO_PUL_EN3 | GPIO_PUL_EN2 | GPIO_PUL_EN1 |
| Reset         | 1             | 1            | 1            | 1            |

#### Indirect\_Modem\_GPIO\_PUL\_EN field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>GPIO_PUL_EN8 | <ul> <li>GPIO Pullup Enable 8</li> <li>Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7,, GPIO1}.</li> <li>No pullup or pulldown is engaged on the pin.</li> <li>Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin</li> </ul> |

Table continues on the next page...

### Indirect\_Modem\_GPIO\_PUL\_EN field descriptions (continued)

| GPIO_PUL_EN7 | GPIO Pullup Enable 7                                                                                                   |
|--------------|------------------------------------------------------------------------------------------------------------------------|
| GPIO_PUL_EN7 |                                                                                                                        |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8,<br>GPIO7, , GPIO1}. |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
|              | GPIO Pullup Enable 6                                                                                                   |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7, , GPIO1}.    |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
|              | GPIO Pullup Enable 5                                                                                                   |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7, , GPIO1}.    |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
|              | GPIO Pullup Enable 4                                                                                                   |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7, , GPIO1}.    |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
|              | GPIO Pullup Enable 3                                                                                                   |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7, , GPIO1}.    |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
| 1 (          | GPIO Pullup Enable 2                                                                                                   |
|              | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8, GPIO7, , GPIO1}.    |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |
| 0            | GPIO Pullup Enable 1                                                                                                   |
| GPIO_PUL_EN1 | Determines whether a pull device (pullup or pulldown) is engaged for each of the GPIO pins {GPIO8,<br>GPIO7, , GPIO1}. |
|              | 0 No pullup or pulldown is engaged on the pin.                                                                         |
|              | 1 Pullup or pulldown is engaged (see GPIO_PUL_SEL register) on the pin                                                 |

## 9.3.25 GPIO Pullup Select (Indirect\_Modem\_GPIO\_SEL)

Address: 0h base + 2Dh offset = 2Dh

| Bit   | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|-------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Read  | GPIO_PUL_ |
| Write | SEL8      | SEL7      | SEL6      | SEL5      | SEL4      | SEL3      | SEL2      | SEL1      |
| Reset | 1         | 1         | 1         | 1         | 1         | 1         | 1         | 1         |

#### Indirect\_Modem\_GPIO\_SEL field descriptions

| Field                  | Description                                                                                                                                                                                                                                                                                       |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>GPIO_PUL_<br>SEL8 | GPIO Pullup Select 8<br>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or<br>pulldown is engaged.                                                                                                                                                    |
|                        | <ul> <li>Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> <li>Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul>                                                                                                                                                                |
| 6<br>GPIO_PUL_<br>SEL7 | <ul> <li>GPIO Pullup Select 7</li> <li>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.</li> <li>0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul>                                                              |
|                        | <ul> <li>Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul>                                                                                                                                                                                                                             |
| 5<br>GPIO_PUL_<br>SEL6 | <ul> <li>GPIO Pullup Select 6</li> <li>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.</li> <li>0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> <li>1 Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul> |
| 4<br>GPIO_PUL_<br>SEL5 | <ul> <li>GPIO Pullup Select 5</li> <li>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.</li> <li>0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> <li>1 Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul> |
| 3<br>GPIO_PUL_<br>SEL4 | <ul> <li>GPIO Pullup Select 4</li> <li>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.</li> <li>0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> <li>1 Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul> |
| 2<br>GPIO_PUL_<br>SEL3 | GPIO Pullup Select 3<br>For each pin {GPIO8, GPIO7,, GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.                                                                                                                                                       |

Table continues on the next page...

## Indirect\_Modem\_GPIO\_SEL field descriptions (continued)

| Field             | Description                                                                                                                        |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|
|                   | 0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.                                                                              |
|                   | 1 Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.                                                                                |
| 1                 | GPIO Pullup Select 2                                                                                                               |
| GPIO_PUL_<br>SEL2 | For each pin {GPIO8, GPIO7, , GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.               |
|                   | 0 Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.                                                                              |
|                   | 1 Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.                                                                                |
| 0                 | GPIO Pullup Select 1                                                                                                               |
| GPIO_PUL_<br>SEL1 | For each pin {GPIO8, GPIO7, , GPIO1}, if GPIO_PUL[x]=1, this bit determines whether a pullup or pulldown is engaged.               |
|                   | <ul> <li>Pulldown is engaged on the pin if GPIO_PUL_EN[x]=1.</li> <li>Pullup is engaged on the pin if GPIO_PUL_EN[x]=1.</li> </ul> |

## 9.3.26 GPIO Drive Strength (Indirect\_Modem\_GPIO\_DS)

Address: 0h base + 2Eh offset = 2Eh

| Bit           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|---------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Read<br>Write | GPIO_DS8 | GPIO_DS7 | GPIO_DS6 | GPIO_DS5 | GPIO_DS4 | GPIO_DS3 | GPIO_DS2 | GPIO_DS1 |
| Reset         | 1        | 1        | 1        | 1        | 1        | 1        | 1        | 1        |

### Indirect\_Modem\_GPIO\_DS field descriptions

| Field         | Description                           |
|---------------|---------------------------------------|
| 7             | GPIO Drive Strength 8                 |
| GPIO_DS8      | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 6<br>GPIO_DS7 | GPIO Drive Strength 7                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 5<br>GPIO_DS6 | GPIO Drive Strength 6                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 4             | GPIO Drive Strength 5                 |
| GPIO_DS5      |                                       |

Table continues on the next page ...

## Indirect\_Modem\_GPIO\_DS field descriptions (continued)

| Field         | Description                           |
|---------------|---------------------------------------|
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 3<br>GPIO_DS4 | GPIO Drive Strength 4                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 2<br>GPIO_DS3 | GPIO Drive Strength 3                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 1<br>GPIO_DS2 | GPIO Drive Strength 2                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |
| 0<br>GPIO_DS1 | GPIO Drive Strength 1                 |
|               | For each pin {GPIO8, GPIO7, , GPIO1}: |
|               | 0 Pin uses normal drive strength.     |
|               | 1 Pin uses high drive strength.       |

## 9.3.27 Antenna Control (Indirect\_Modem\_ANT\_PAD\_CTRL)

Address: 0h base + 30h offset = 30h

| Bit   | 7     | 6     | 5     | 4     | 3        | 2       | 1    | 0    |
|-------|-------|-------|-------|-------|----------|---------|------|------|
| Read  | ANTX_ | ANTX_ | ANTX_ | ANTX_ | ANTX_    | ANTX HZ | ANTX | ( EN |
| Write | POL3  | POL2  | POL1  | POL0  | CTRLMODE |         |      |      |
| Reset | 0     | 0     | 0     | 0     | 1        | 0       | 0    | 0    |

### Indirect\_Modem\_ANT\_PAD\_CTRL field descriptions

| Field          | Description                                                                                         |
|----------------|-----------------------------------------------------------------------------------------------------|
| 7<br>ANTX_POL3 | Antenna Polarity Control 3                                                                          |
|                | Control the polarity of the Antenna or Switch control pins.<br>0 Do not invert the RXSWITCH output. |
|                | 1     Invert the RXSWITCH output.                                                                   |

Table continues on the next page ...

#### Indirect registers memory map and register definition

## Indirect\_Modem\_ANT\_PAD\_CTRL field descriptions (continued)

| Field          | Description                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------|
| 6<br>ANTX_POL2 | Antenna Polarity Control 2                                                                                           |
|                | Control the polarity of the Antenna or Switch control pins.                                                          |
|                | 0 Do not invert the TXSWITCH output.                                                                                 |
|                | 1 Invert the TXSWITCH output.                                                                                        |
| 5<br>ANTX_POL1 | Antenna Polarity Control 1<br>Control the polarity of the Antenna or Switch control pins.                            |
|                |                                                                                                                      |
|                | 0 Do not invert the ANT_B output.                                                                                    |
|                | 1 Invert the ANT_B output.                                                                                           |
| 4<br>ANTX_POL0 | Antenna Polarity Control 0                                                                                           |
|                | Control the polarity of the Antenna or Switch control pins.                                                          |
|                | 0 Do not invert the ANT_A output.                                                                                    |
|                | 1 Invert the ANT_A output.                                                                                           |
| 3<br>ANTX_     | Antenna Control Mode                                                                                                 |
| CTRLMODE       | Sets the single/dual mode.                                                                                           |
|                | 0 Single mode: ANT_A=ANTX TX_SWITCH=TXON and RX_SWITCH=(RXON OR TXON).                                               |
|                | 1 Dual mode: ANT_A=ANTX AND (RXON OR TXON) ANT_B=NOT (ANTX) AND (RXON OR TXON)<br>TX_SWITCH=TXON and RX_SWITCH=RXON. |
| 2<br>ANTX_HZ   | Antenna High Impedance                                                                                               |
| ANTA_12        | Antenna controls high impedance.                                                                                     |
|                | 0 ANT_A, ANT_B, RX_SWITCH, and TX_SWITCH are actively driven outputs.                                                |
|                | 1 Set ANT_A, ANT_B, RX_SWITCH and TX_SWITCH in high impedance.                                                       |
| ANTX_EN        | Antenna Controls Enable                                                                                              |
|                | Enable ANT_A, ANT_B, RX_SWITCH, and TX_SWITCH.                                                                       |
|                | 00 All disabled.                                                                                                     |
|                | 01 Only RX_SWITCH/TX_SWITCH enabled.                                                                                 |
|                | 10 Only ANT_A/ANT_B enabled.                                                                                         |
|                | 11 All enabled.                                                                                                      |

## 9.3.28 Miscellaneous Pad Control (Indirect\_Modem\_MISC\_PAD\_CTRL)

Address: 0h base + 31h offset = 31h

| Bit           | 7           | 6        | 5           | 4         |  |
|---------------|-------------|----------|-------------|-----------|--|
| Read<br>Write |             | Rese     | erved       |           |  |
| Reset         | 0           | 0        | 0           | 1         |  |
| Bit           | 3           | 2        | 1           | 0         |  |
| Read<br>Write | MISO_HIZ_EN | IRQ_B_OD | NON_GPIO_DS | ANTX_CURR |  |
| Reset         | 1           | 0        | 1           | 0         |  |

#### Indirect\_Modem\_MISC\_PAD\_CTRL field descriptions

| Field            | Description                                                                                                                                                                          |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7–4<br>Reserved  | This field is reserved.                                                                                                                                                              |  |  |  |  |
| 3<br>MISO_HIZ_EN | Determines the output state of the radio's R_MISO output when R_SSEL_B is deasserted (high).                                                                                         |  |  |  |  |
|                  | <ol> <li>R_MISO output is driven low by the SPI slave.</li> <li>R_MISO output is tristated (default). An external pullup on R_MISO must be employed if<br/>MISO_HIZ_EN=1.</li> </ol> |  |  |  |  |
| 2<br>IRQ_B_OD    | IRQ_B Open Drain                                                                                                                                                                     |  |  |  |  |
|                  | 0 IRQ_B is an actively-driven output.                                                                                                                                                |  |  |  |  |
|                  | 1 IRQ_B is open-drain (external pullup required).                                                                                                                                    |  |  |  |  |
| 1<br>NON_GPIO_DS | Determines the drive strength for the all of the following pins: {IRQ_B, R_MISO, DTM0 DTM6}.                                                                                         |  |  |  |  |
|                  | 0 All the listed pins use normal drive strength.                                                                                                                                     |  |  |  |  |
|                  | 1 All the listed pins use high drive strength.                                                                                                                                       |  |  |  |  |
| 0<br>ANTX_CURR   | Determines the drive strength for the all of the following pins: {ANT_A, ANT_B, RX_SWITCH, TX_SWITCH}.                                                                               |  |  |  |  |
|                  | 0 All the listed pins use normal drive strength.                                                                                                                                     |  |  |  |  |
|                  | 1 All the listed pins use high drive strength.                                                                                                                                       |  |  |  |  |

## 9.3.29 RX\_BYTE\_COUNT (Indirect\_Modem\_RX\_BYTE\_COUNT)



Address: 0h base + 35h offset = 35h

### Indirect\_Modem\_RX\_BYTE\_COUNT field descriptions

| Field | Description                                                                                                                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COUNT | During packet reception, this read-only register is a real-time indicator of the number of bytes that have been received. This register will read 0 until SFD and PHR have been received. It will read 1 after the first byte of Frame Control Field has been received, etc. |

## 9.3.30 RX\_WTR\_MARK (Indirect\_Modem\_RX\_WTR\_MARK)

Address: 0h base + 36h offset = 36h

| Bit           | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|-------------|---|---|---|---|---|---|---|
| Read<br>Write | RX_WTR_MARK |   |   |   |   |   |   |   |
| Reset         | 1           | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

### Indirect\_Modem\_RX\_WTR\_MARK field descriptions

| Field | Description                                                                                                                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Receive byte count (octets) needed to trigger a RXWTRMRKIRQ interrupt . A setting of 0 generates an interrupt at end of the Frame Length field (first byte after SFD). A setting of 1 generates an interrupt after the first byte of Frame Control Field, etc. |

## 9.3.31 TXDELAY (Indirect\_Modem\_TXDELAY)

Address: 0h base + 38h offset = 38h



#### Indirect\_Modem\_TXDELAY field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                          |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                  |
| TXDELAY         | Provides a fine-tune adjustment of the time delay between post-CCA Rx warm-down and the beginning of Tx warm-up for an Tx(non-Ack) packet. TXDELAY register will apply in both SLOTTED and UNSLOTTED modes, but only to T sequences (e.g., T, TR, and T(R)), not TxAck operations. This is a two's complement value. |
|                 | The minimum permissible value is -19(0x2D). Values less than -19 will lead to unexpected results. Resolution = $2\mu$ s. Range = +/- $62\mu$ s.                                                                                                                                                                      |
|                 | Max TXDELAY = 0x1F                                                                                                                                                                                                                                                                                                   |
|                 | Min TXDELAY = 0x2D                                                                                                                                                                                                                                                                                                   |

## 9.3.32 ACKDELAY (Indirect\_Modem\_ACKDELAY)

Address: 0h base + 39h offset = 39h

| Bit           | 7        | 6 | 5        | 4 | 3 | 2 | 1 | 0 |
|---------------|----------|---|----------|---|---|---|---|---|
| Read<br>Write | Reserved |   | ACKDELAY |   |   |   |   |   |
| Reset         | 0        | 0 | 1        | 1 | 1 | 1 | 0 | 1 |

### Indirect\_Modem\_ACKDELAY field descriptions

| Field           | Description                                                                                                                                                                                                                                                                 |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This field is reserved.<br>Reserved                                                                                                                                                                                                                                         |
| ACKDELAY        | Provides a fine-tune adjustment of the time delay between Rx warmdown and the beginning of Tx warmup for an Tx Acknowledge packet. ACKDELAY register will apply to both SLOTTED and UNSLOTTED TxAck, but only to TxAck (not T sequences). This is a two's complement value. |
|                 | The minimum permissible value is -19 (0x2D). Values less than -19 will lead to unexpected results. Values less than -19 will lead to unexpected results. Resolution = $2\mu$ s. Range = +/- $62\mu$ s.                                                                      |
|                 | Max ACKDELAY = 0x1F                                                                                                                                                                                                                                                         |
|                 | Min ACKDELAY = 0x2D                                                                                                                                                                                                                                                         |

## 9.3.33 Antenna AGC and FAD Control (Indirect\_Modem\_ANT\_AGC\_CTRL)

Address: 0h base + 51h offset = 51h

| Bit           | 7      | 6      | 5         | 4 | 3        | 2 | 1    | 0      |
|---------------|--------|--------|-----------|---|----------|---|------|--------|
| Read<br>Write | SNF_EN | AGC_EN | AGC_LEVEL |   | Reserved |   | ANTX | FAD_EN |
| Reset         | 0      | 1      | 0         | 0 | 0        | 0 | 0    | 0      |

#### Indirect\_Modem\_ANT\_AGC\_CTRL field descriptions

| Field       | Description                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 7           | Sniff Enable                                                                                                                          |
| SNF_EN      | Enable the sniff function that allows the symbol demodulator to be started when the RSSI level has crossed the defined SNF threshold. |
| 6<br>AGC_EN | AGC Enable                                                                                                                            |
|             | Enable the AGC function.                                                                                                              |
|             | 0 The AGC function is disabled.                                                                                                       |
|             | 1 The AGC function is enabled.                                                                                                        |
| 5-4         | AGC Level                                                                                                                             |
| AGC_LEVEL   | If AGC_EN=0, forces the attenuation mode AGC_LEVEL_IN[1:0]. For reads:                                                                |

Table continues on the next page ...

## Indirect\_Modem\_ANT\_AGC\_CTRL field descriptions (continued)

| Field           | Description                                                                                                                                        |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | AGC_EN=1: gives the AGC level chosen.                                                                                                              |
|                 | AGC_EN=0: reads back what was last written to the register.                                                                                        |
|                 | 00 FE full gain, CHF full gain.                                                                                                                    |
|                 | 01 FE full gain, CHF low gain.                                                                                                                     |
|                 | 10 Reserved                                                                                                                                        |
|                 | 11 FE low gain, CHF low gain.                                                                                                                      |
| 3–2<br>Reserved | This field is reserved.                                                                                                                            |
| 1<br>ANTX       | ANTX bit selects the initial antenna state when FAD_EN=1, or allows software direct control over the antenna selection at all times when FAD_EN=0. |
|                 | 0 Select ANT_B                                                                                                                                     |
|                 | 1 Select ANT_A                                                                                                                                     |
|                 | FAD Enable                                                                                                                                         |
| FAD_EN          | Enable the FAD function.                                                                                                                           |
|                 | 0 FAD function is disabled.                                                                                                                        |
|                 | 1 FAD function is enabled.                                                                                                                         |

## 9.3.34 LPPS\_CTRL (Indirect\_Modem\_LPPS\_CTRL)

Address: 0h base + 56h offset = 56h

| Bit           | 7           | 6            | 5           | 4              |
|---------------|-------------|--------------|-------------|----------------|
| Read<br>Write |             | Reserved     |             | LPPS_BUFMIX_EN |
| Reset         | 0           | 0            | 0           | 1              |
| Bit           | 3           | 2            | 1           | 0              |
| Read<br>Write | LPPS_LIM_EN | LPPS_RSSI_EN | LPPS_LNA_EN | LPPS_EN        |
| Reset         | 1           | 1            | 1           | 0              |

## Indirect\_Modem\_LPPS\_CTRL field descriptions

| Field                   | Description                                                                                                                                      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–5<br>Reserved         | This field is reserved.                                                                                                                          |
| 4<br>LPPS_BUFMIX_<br>EN | VCO buffer enable during LPPS 0 Normal operation.                                                                                                |
|                         | 1 During preamble search in LPPS mode, the VCO buffer is turned on/off with a 50% DC (Duty Cycle).                                               |
| 3<br>LPPS_LIM_EN        | LIM enable during LPPS                                                                                                                           |
|                         | <ul> <li>0 Normal operation.</li> <li>1 During preamble search in LPPS mode, the limiter is turned on/off with a 50% DC (Duty Cycle).</li> </ul> |

Table continues on the next page...

| Indirect_ | _Modem_ | _LPPS_ | CTRL fi | ield | descriptions ( | continued) |  |
|-----------|---------|--------|---------|------|----------------|------------|--|
|           |         |        |         |      |                |            |  |

| Field        | Description                                                                                  |  |  |  |  |
|--------------|----------------------------------------------------------------------------------------------|--|--|--|--|
| 2            | RSSI enable during LPPS                                                                      |  |  |  |  |
| LPPS_RSSI_EN |                                                                                              |  |  |  |  |
|              | 0 Normal operation.                                                                          |  |  |  |  |
|              | 1 During preamble search in LPPS mode, the RSSI is turned on/off with a 50% DC (Duty Cycle). |  |  |  |  |
| 1            | LNA enable during LPPS                                                                       |  |  |  |  |
| LPPS_LNA_EN  |                                                                                              |  |  |  |  |
|              | 0 Normal operation.                                                                          |  |  |  |  |
|              | 1 During preamble search in LPPS mode, the LNA is turned on/off with a 50% DC (Duty Cycle).  |  |  |  |  |
| 0<br>LPPS_EN | Master Enable for Low-Power Preamble Search (LPPS) mode                                      |  |  |  |  |
|              | 0 Normal operation.                                                                          |  |  |  |  |
|              | 1 Enable Low-Power Preamble Search mode.                                                     |  |  |  |  |
|              | Note: LPPS mode should not be engaged if Fast Antenna Diversity mode is in use (FAN_EN=1).   |  |  |  |  |

## 9.3.35 RSSI (Indirect\_Modem\_RSSI)

| Bit   | 7                | 6                | 5                | 4                | 3                | 2                | 1                | 0                |
|-------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| Read  | RSSI_<br>Level_7 | RSSI_<br>Level_6 | RSSI_<br>Level_5 | RSSI_<br>Level_4 | RSSI_<br>Level_3 | RSSI_<br>Level_2 | RSSI_<br>Level_1 | RSSI_<br>Level_0 |
| Write |                  |                  |                  |                  |                  |                  |                  |                  |
| Reset | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                |

Address: 0h base + 5Bh offset = 5Bh

### Indirect\_Modem\_RSSI field descriptions

| Field             | Description                         |
|-------------------|-------------------------------------|
| 7<br>RSSI_Level_7 | RSSI Level, refreshed every 125 μs. |
| 6<br>RSSI_Level_6 | RSSI Level, refreshed every 125 μs. |
| 5<br>RSSI_Level_5 | RSSI Level, refreshed every 125 μs. |
| 4<br>RSSI_Level_4 | RSSI Level, refreshed every 125 µs. |
| 3<br>RSSI_Level_3 | RSSI Level, refreshed every 125 μs. |
| 2<br>RSSI_Level_2 | RSSI Level, refreshed every 125 μs. |
| 1<br>RSSI_Level_1 | RSSI Level, refreshed every 125 μs. |
| 0<br>RSSI_Level_0 | RSSI Level, refreshed every 125 μs. |

## 9.3.36 XTAL Control (Indirect\_Modem\_XTAL\_CTRL)

Address: 0h base + 6Eh offset = 6Eh



### Indirect\_Modem\_XTAL\_CTRL field descriptions

| Field              | Description                                                                                                                                   |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved    | This field is reserved.                                                                                                                       |
| 5–3<br>XTAL_BYPASS | XTAL Bypass<br>Reset value = 000                                                                                                              |
|                    | Bypass value = 111<br>XTAL32m bypass for external injection.<br>Note: XTALEN must be 0 when XTAL_BYPASS=1. See PWR_MODES register for XTALEN. |
| Reserved           | This field is reserved.                                                                                                                       |

# Appendix A Release Notes for Revision 3

## A.1 General changes throughout

- Updated missing reset values of Modem and Indirect Modem registers.
- Added the following registers to the Indirect Modern memory map: TMR\_PRESCALE, RX\_BYTE\_COUNT, RX\_WTR\_MARK, TXDELAY, ACKDELAY.
- Updated register bit map structure of XTAL Control (Indirect Modem\_XTAL\_CTRL) register.

#### How to Reach Us:

Home Page: nxp.com

Web Support: nxp.com/support Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: <a href="mailto:nxp.com/SalesTermsandConditions">nxp.com/SalesTermsandConditions</a>.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, Freescale, the Freescale logo, and Kinetis are trademarks of NXP B.V. All other product or service names are the property of their respective owners. All rights reserved.

© 2013 – 2016 NXP B.V.

Document Number MCR20ARM Revision 3, July 2016

