

# **mmWaveLink Interface Control Document**

*xWRLx432*

---



Version: 1.2

10<sup>th</sup> July, 2025

|                                                            |           |
|------------------------------------------------------------|-----------|
| <b>List of figures</b>                                     | <b>iv</b> |
| <b>List of tables</b>                                      | <b>v</b>  |
| <b>1 Introduction</b>                                      | <b>1</b>  |
| 1.1 Overview . . . . .                                     | 1         |
| 1.2 mmWave DFP Architecture . . . . .                      | 1         |
| 1.2.1 mmWaveLink Architecture . . . . .                    | 1         |
| 1.2.2 FECSSLib Architecture . . . . .                      | 2         |
| 1.2.3 Supported Devices . . . . .                          | 2         |
| 1.3 Terms and Abbreviations . . . . .                      | 2         |
| 1.4 Scope and Intended Audience . . . . .                  | 4         |
| <b>2 mmWaveLink APIs</b>                                   | <b>5</b>  |
| 2.1 mmWaveLink API Structure and Grouping . . . . .        | 5         |
| 2.2 mmWaveLink Initialization APIs . . . . .               | 7         |
| 2.2.1 mmWaveLink Initialization API . . . . .              | 7         |
| 2.2.2 mmWaveLink De-Initialization API . . . . .           | 14        |
| 2.3 mmWaveLink Device Configuration APIs . . . . .         | 15        |
| 2.3.1 FECSS Device Power On API . . . . .                  | 15        |
| 2.3.2 FECSS Device Power OFF API . . . . .                 | 19        |
| 2.3.3 DFP Version Get API . . . . .                        | 20        |
| 2.3.4 FECSS RF Power On Off API . . . . .                  | 22        |
| 2.3.5 FECSS Factory Calibration API . . . . .              | 25        |
| 2.3.6 FECSS RF Runtime Calibration API . . . . .           | 33        |
| 2.3.7 FECSS RF Clock Bandwidth Configuration API . . . . . | 36        |
| 2.3.8 FECSS GPADC Measurement Configuration API . . . . .  | 39        |
| 2.3.9 FECSS GPADC Measurement Trigger API . . . . .        | 43        |
| 2.3.10 FECSS Temperature Measurement Config API . . . . .  | 44        |
| 2.3.11 FECSS Temperature Measurement Trigger API . . . . . | 46        |
| 2.3.12 FECSS Factory Calibration Data Get API . . . . .    | 47        |
| 2.3.13 FECSS Factory Calibration Data Set API . . . . .    | 48        |
| 2.3.14 FECSS Device Clock Ctrl API . . . . .               | 50        |
| 2.3.15 FECSS Device RDIF Control API . . . . .             | 53        |
| 2.3.16 FECSS Device Status Get API . . . . .               | 57        |
| 2.3.17 FECSS RF Status Get API . . . . .                   | 61        |
| 2.3.18 FECSS RF Fault Status Get API . . . . .             | 62        |
| 2.3.19 FECSS Die Id Get API . . . . .                      | 66        |
| 2.3.20 FECSS Rx-Tx Calibration Data Get API . . . . .      | 67        |
| 2.3.21 FECSS Rx-Tx Calibration Data Set API . . . . .      | 67        |
| 2.3.22 FECSS RFS Debug Configuration API . . . . .         | 70        |
| 2.3.23 FECSS RF Runtime Tx CLPC API . . . . .              | 71        |
| 2.4 mmWave Sensor APIs . . . . .                           | 77        |
| 2.4.1 Sensor Profile Common Configuration API . . . . .    | 79        |

|          |                                                                      |            |
|----------|----------------------------------------------------------------------|------------|
| 2.4.2    | Sensor Chirp Profile Common Configuration Get API . . . . .          | 86         |
| 2.4.3    | Sensor Chirp Profile Time Configuration API . . . . .                | 86         |
| 2.4.4    | Sensor Chirp Profile Time Configuration Get API . . . . .            | 90         |
| 2.4.5    | Sensor Per-Chirp Configuration API . . . . .                         | 91         |
| 2.4.6    | Sensor Per-Chirp Configuration Get API . . . . .                     | 93         |
| 2.4.7    | Sensor Per-Chirp Control API . . . . .                               | 94         |
| 2.4.8    | Sensor Per-Chirp Control Get API . . . . .                           | 96         |
| 2.4.9    | Sensor Frame Configuration API . . . . .                             | 97         |
| 2.4.10   | Sensor Frame Configuration Get API . . . . .                         | 101        |
| 2.4.11   | Sensor Start API . . . . .                                           | 101        |
| 2.4.12   | Sensor Stop API . . . . .                                            | 105        |
| 2.4.13   | Sensor Status Get API . . . . .                                      | 106        |
| 2.4.14   | Sensor Dynamic Power Save Disable Configuration API . . . . .        | 109        |
| 2.4.15   | Sensor Dynamic Power Save Disable Configuration Get API . . . . .    | 111        |
| 2.4.16   | Sensor Loopback Configuration API . . . . .                          | 112        |
| 2.4.17   | Sensor Loopback Enable API . . . . .                                 | 117        |
| 2.5      | mmWaveLink Monitor Configuration APIs . . . . .                      | 119        |
| 2.5.1    | FECSS Monitor Enable Trigger API . . . . .                           | 121        |
| 2.5.2    | FECSS Peak-Detector Debug Monitor API . . . . .                      | 127        |
| 2.5.3    | FECSS Tx Power Debug Monitor API . . . . .                           | 130        |
| 2.5.4    | FECSS Synthesizer Frequency Live Monitor Configuration API . . . . . | 132        |
| 2.5.5    | FECSS Rx Saturation Live Monitor Configuration API . . . . .         | 135        |
| 2.5.6    | FECSS PLL Control Voltage Monitor Configuration API . . . . .        | 136        |
| 2.5.7    | FECSS TxN-Rx Loopback Monitor Configuration API . . . . .            | 140        |
| 2.5.8    | FECSS TxN Power Monitor Configuration API . . . . .                  | 145        |
| 2.5.9    | FECSS Tx Ball-Break Monitor Configuration API . . . . .              | 149        |
| 2.5.10   | FECSS TxN DC Signal Monitor Configuration API . . . . .              | 152        |
| 2.5.11   | FECSS Rx HPF and DC Signal Monitor Configuration API . . . . .       | 156        |
| 2.5.12   | FECSS PM and Clock DC Signals Monitor Configuration API . . . . .    | 161        |
| 2.6      | mmWaveLink Error Codes . . . . .                                     | 165        |
| 2.6.1    | mmWaveLink Interface Error Codes . . . . .                           | 165        |
| 2.6.2    | mmWaveLink Device Error Codes . . . . .                              | 166        |
| 2.6.3    | mmWaveLink Sensor Error Codes . . . . .                              | 167        |
| 2.6.4    | mmWaveLink Monitor Error Codes . . . . .                             | 169        |
| 2.6.5    | mmWaveLink RFS API Error Codes . . . . .                             | 170        |
| 2.6.6    | mmWaveLink RFS Monitor Error Codes . . . . .                         | 171        |
| <b>3</b> | <b>Execution Time and Constraints</b> . . . . .                      | <b>173</b> |
| 3.1      | Chirp, Burst and Frame Timing Constraints . . . . .                  | 173        |
| 3.1.1    | Burst Timing Constraints . . . . .                                   | 173        |
| 3.1.2    | Frame Timing Constraints . . . . .                                   | 173        |
| 3.1.3    | Chirp Idle Time Constraints . . . . .                                | 173        |
| 3.1.4    | Skip Samples Constraints . . . . .                                   | 174        |
| 3.1.5    | Chirp Ramp End Time Constraints . . . . .                            | 174        |
| 3.1.6    | Chirp Periodicity Constraints . . . . .                              | 175        |
| 3.2      | API Execution Time . . . . .                                         | 175        |
| 3.2.1    | mmWaveLink API Execution Time . . . . .                              | 175        |
| 3.2.2    | Calibration Execution Time . . . . .                                 | 178        |

|                                            |            |
|--------------------------------------------|------------|
| 3.2.3 Monitor Execution Time . . . . .     | 179        |
| <b>4 Recommended Sequences</b>             | <b>180</b> |
| 4.1 In-Field Operation sequence . . . . .  | 180        |
| 4.2 Factory Calibration sequence . . . . . | 181        |

## **ICD Revision History**

### **Notice**

|                                                            |     |
|------------------------------------------------------------|-----|
| 2.1 FMCW Chirp Parameters . . . . .                        | 77  |
| 2.2 Frame and Burst Events . . . . .                       | 78  |
| 4.1 Recommended in-field operation API sequence . . . . .  | 180 |
| 4.2 Recommended factory calibration API sequence . . . . . | 181 |

|      |                                                  |     |
|------|--------------------------------------------------|-----|
| 2.1  | T_DFP_CLIENT_CB_DATA . . . . .                   | 8   |
| 2.2  | T_DFP_OSI_CB_DATA . . . . .                      | 9   |
| 2.3  | T_DFP_OSI_MUTEX_CB_DATA . . . . .                | 10  |
| 2.4  | T_DFP_OSI_SEMP_CB_DATA . . . . .                 | 10  |
| 2.5  | T_DFP_OSI_MSGQ_CB_DATA . . . . .                 | 11  |
| 2.6  | T_DFP_PLATFORM_CB_DATA . . . . .                 | 12  |
| 2.7  | T_DFP_DBG_PRINT_CB_DATA . . . . .                | 13  |
| 2.8  | T_DFP_COMIF_CB_DATA . . . . .                    | 14  |
| 2.9  | T_RL_API_FECSS_DEV_PWR_ON_CMD . . . . .          | 16  |
| 2.10 | T_RL_API_FECSS_DEV_PWR_OFF_CMD . . . . .         | 20  |
| 2.11 | T_RL_API_DFP_FW_VER_GET_RSP . . . . .            | 21  |
| 2.12 | T_DFP_COMP_FW_VER . . . . .                      | 21  |
| 2.13 | T_RL_API_FECSS_RF_PWR_CFG_CMD . . . . .          | 23  |
| 2.14 | T_RL_API_FECSS_RF_FACT_CAL_CMD . . . . .         | 27  |
| 2.15 | T_RL_API_FECSS_RF_FACT_CAL_RSP . . . . .         | 27  |
| 2.16 | T_RL_API_FECSS_RF_RUN_CAL_CMD . . . . .          | 34  |
| 2.17 | T_RL_API_FECSS_RF_RUN_CAL_RSP . . . . .          | 34  |
| 2.18 | T_RL_API_FECSS_CLK_BW_CFG_CMD . . . . .          | 38  |
| 2.19 | T_RL_API_FECSS_GPADC_MEAS_CMD . . . . .          | 40  |
| 2.21 | T_RL_API_FECSS_GPADC_MEAS_RSP . . . . .          | 43  |
| 2.22 | T_RL_API_FECSS_TEMP_MEAS_CMD . . . . .           | 45  |
| 2.23 | T_RL_API_FECSS_TEMP_MEAS_RSP . . . . .           | 46  |
| 2.24 | T_RL_API_FECSS_FACT_CAL_DATA . . . . .           | 49  |
| 2.25 | T_RL_API_FECSS_DEV_CLK_CTRL_CMD . . . . .        | 51  |
| 2.26 | T_RL_API_FECSS_RDIF_CTRL_CMD . . . . .           | 55  |
| 2.27 | T_RL_API_FECSS_DEV_STS_RSP . . . . .             | 58  |
| 2.28 | T_RL_API_FECSS_RF_STS_GET_RSP . . . . .          | 61  |
| 2.29 | T_RL_API_RFS_FAULT_STS_GET_RSP . . . . .         | 63  |
| 2.30 | T_RL_API_SENSOR_DIEID_RSP . . . . .              | 67  |
| 2.31 | T_RL_API_FECSS_RXTX_CAL_DATA . . . . .           | 68  |
| 2.32 | T_RL_API_FECSS_RFS_DBG_CFG_CMD . . . . .         | 71  |
| 2.33 | T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_CMD . . . . . | 72  |
| 2.34 | T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_RSP . . . . . | 73  |
| 2.35 | T_RL_API_SENS_CHIRP_PROF_COMM_CFG . . . . .      | 80  |
| 2.37 | T_RL_API_SENS_CHIRP_PROF_TIME_CFG . . . . .      | 87  |
| 2.38 | Sensor Per-Chirp Parameters . . . . .            | 91  |
| 2.39 | T_RL_API_SENS_PER_CHIRP_CFG . . . . .            | 92  |
| 2.40 | T_RL_API_SENS_PER_CHIRP_CTRL . . . . .           | 95  |
| 2.41 | T_RL_API_SENS_FRAME_CFG . . . . .                | 98  |
| 2.43 | T_RL_API_SENSOR_START_CMD . . . . .              | 102 |
| 2.44 | T_RL_API_SENSOR_STOP_CMD . . . . .               | 105 |
| 2.45 | Frame Stop Modes . . . . .                       | 106 |
| 2.46 | T_RL_API_SENSOR_STATUS_RSP . . . . .             | 107 |

|                                                             |     |
|-------------------------------------------------------------|-----|
| 2.47 T_RL_API_SENS_DYN_PWR_SAVE_DIS . . . . .               | 110 |
| 2.48 T_RL_API_SENS_LOOPBACK_CFG . . . . .                   | 112 |
| 2.54 T_RL_API_SENS_LOOPBACK_ENA . . . . .                   | 118 |
| 2.55 mmWaveLink Monitoring Indices . . . . .                | 119 |
| 2.56 T_RL_FE_RFS_IPC_MON_RESULT_DATA_STRUCT . . . . .       | 121 |
| 2.58 T_RL_API_MON_ENABLE_TRIG . . . . .                     | 124 |
| 2.59 T_RL_API_MON_TRIG_RESPONSE . . . . .                   | 124 |
| 2.60 Supported Monitor Enable Masks . . . . .               | 125 |
| 2.62 T_RL_API_MON_DBG_PD_MEAS_CMD . . . . .                 | 128 |
| 2.63 T_RL_API_MON_DBG_PD_MEAS_RSP . . . . .                 | 128 |
| 2.64 T_RL_API_MON_DBG_TXPWR_MEAS_CMD . . . . .              | 131 |
| 2.65 T_RL_API_MON_DBG_TXPWR_MEAS_RSP . . . . .              | 131 |
| 2.66 T_RL_API_MON_LIVE_SYNTH_FREQ_CFG . . . . .             | 133 |
| 2.67 T_RL_API_MON_LIVE_SYNTH_FREQ_RESULT . . . . .          | 134 |
| 2.68 T_RL_API_MON_LIVE_RX_SATURATION_CFG . . . . .          | 136 |
| 2.69 T_RL_API_MON_PLL_CTRL_VOLT_CFG . . . . .               | 137 |
| 2.70 T_RL_API_MON_PLL_CTRL_VOLT_RESULT . . . . .            | 138 |
| 2.71 T_RL_API_MON_TXN_RX_LB_CFG . . . . .                   | 141 |
| 2.72 T_RL_API_MON_TXN_RX_LB_RESULT . . . . .                | 141 |
| 2.73 T_RL_API_MON_TXN_POWER_CFG . . . . .                   | 146 |
| 2.74 T_RL_API_MON_TXN_POWER_RESULT . . . . .                | 147 |
| 2.75 T_RL_API_MON_TXN_BB_CFG . . . . .                      | 150 |
| 2.76 T_RL_API_MON_TXN_BB_RESULT . . . . .                   | 150 |
| 2.77 T_RL_API_MON_TXN_DCSIG_CFG . . . . .                   | 153 |
| 2.78 T_RL_API_MON_TXN_DCSIG_RESULT . . . . .                | 154 |
| 2.79 T_RL_API_MON_RX_HPF_DCSIG_CFG . . . . .                | 157 |
| 2.80 T_RL_API_MON_RX_HPF_DCSIG_RESULT . . . . .             | 157 |
| 2.81 T_RL_API_MON_PMCLK_DCSIG_CFG . . . . .                 | 161 |
| 2.82 T_RL_API_MON_PMCLK_DCSIG_RESULT . . . . .              | 162 |
| <br>3.1 Burst Timing Constraints . . . . .                  | 173 |
| 3.2 Frame Timing Constraints . . . . .                      | 173 |
| 3.3 Minimum Chirp Idle-Time Constraints . . . . .           | 174 |
| 3.4 Skip Samples Constraints . . . . .                      | 174 |
| 3.5 Ramp End Time Constraints . . . . .                     | 175 |
| 3.6 Execution Time for Initialization API . . . . .         | 175 |
| 3.7 Execution Time for Device Control APIs . . . . .        | 175 |
| 3.8 Execution Time for Sensor Configuration APIs . . . . .  | 176 |
| 3.9 Execution Time for Monitor Configuration APIs . . . . . | 177 |
| 3.10 Factory Calibration Execution Time . . . . .           | 178 |
| 3.11 Runtime Calibration Execution Time . . . . .           | 178 |

### 1.1 Overview

mmWave DFP is collection of foundational API software, firmware, drivers, and ROM components associated with mmWave devices. mmWave DFP provides seamless control and configuration of Radar Frontend Controller Sub System (FECSS) in real-time either from an external host device in case of Front End (FE) mmWave sensors or from integrated M4 APPSS core in case of SOC.

The mmWave DFP is responsible to provide API function calls to all RF front end related functionalities and configurations using these APIs application can calibrate the RF device, generate radar waveforms and get functional safety monitoring results from FECSS. These APIs enables the RF transceiver to be self-contained and capable of adapting itself to dynamic conditions, such as temperature changes, functional safety capable and minimize the RF related knowledge/dependencies and algorithms run part of application software.

TI low cost and low power, low end mmWave radar products are highly-integrated 60GHz and 77GHz CMOS millimeter wave devices for Automotive and Industrial applications. The device integrated with all of the RF and Analog functionality, including VCO, PLL, PA, LNA, Mixer and ADC for multiple TX/RX channels into a single chip in a low power digital architecture.

### 1.2 mmWave DFP Architecture

The mmWave DFP Low consists of 3 major components, these components closely associated with the functionality of underlying device sensor front-end hardware IPs and implementation.

#### i. mmWaveLink Library

This is an open-source, OS and device agnostic API functions for user control and configuration of the RF analog FECSS in the device. The mmWaveLink is the user interface to the FECSS. The mmWaveLink layer can be integrated with SDK(SoC)/External Host (Frontend)

#### ii. FECSSLib Library

The FECSS open-source ROM/RAM drivers library is responsible for management and operation of the Radar sensor frontend functions and waveform generation in the device. The mmWaveLink APIs internally call these FECSSLib driver APIs to configure the FECSS.

#### iii. RFS Firmware

The ROM/patch binary is responsible for executing pre-defined TI device specific RF analog sequences, the dedicated FECSS M3 core runs these sequence based on commands from FECSS library or mmWaveLink.

The patch file is loaded in the device patch RAM during boot which is used to implement bug fixes and minor feature additions in RFS ROM.

#### 1.2.1 mmWaveLink Architecture

mmWaveLink APIs are categorized in four sections:

- **mmWaveLink Initialization APIs:** APIs to initialize and de-initialize mmWaveLink interface

- [mmWaveLink Device Configuration APIs](#): APIs to control and configure FECSS
- [mmWave Sensor APIs](#): APIs to control and configure FMCW Chirp, Burst and Frame parameters
- [mmWaveLink Monitor Configuration APIs](#): APIs to control and configure monitors

These APIs require access to application and OS specific interfaces to execute desired functionality. These functions are accessed by callback function pointers configured using the [mmWaveLink Initialization API](#). Callback configurations are categorized in following groups:

- Platform Configuration Details
- Debug Interface Callback Functions
- Communication Interface Callback Functions
- Application Specific Interface Callback Functions
- OS Interface Callback Functions

### 1.2.2 FECSSLib Architecture

FECSSLib drives are categorized in following three sections:

- Device Drivers: Driver function to control front-end hardware modules
- Sensor Drivers: Driver functions to control and configure sensor hardware modules like Frame Timer and Chirp Timer
- RFS Drivers: Driver functions to interact with RFS firmware

### 1.2.3 Supported Devices

APIs defined in this document support following mmWave Low devices

- xWRL6432
  - RF Frequency: 56GHz - 64GHz
  - Package Types: FCCSP, WCSP
- xWRL6432
  - RF Frequency: 56GHz - 63.5GHz
  - Package Types: AOP
- xWRL1432
  - RF Frequency: 76GHz - 81GHz
  - Package Types: FCCSP

## 1.3 Terms and Abbreviations

| Abbreviation / Term | Description              |
|---------------------|--------------------------|
| DFP                 | Device Firmware Package  |
| RFS                 | Radar Front-end Scripter |

| Abbreviation / Term | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------|----------|--------------|----------|-----------|----------|-----------|----------|---------|----|-----------|----------|-----|----|------------|----------|-----|----|---------|
| FECSS               | Front End Controller Sub-System                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| AppSS               | Application Sub-System                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| XTAL                | External Crystal Oscillator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| DIG_PLL             | Digital PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| APLL                | Analog PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| XTAL_FREQ           | External Crystal Oscillator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| DIG_PLL_FREQ        | <p>DIG_PLL_FREQ is designed frequency and derived from the Oscillator frequency.</p> $DIG\_PLL\_FREQ = \frac{M}{2N} \times XTAL\_FREQ$ <p>DIG_PLL_FREQ should be 160MHz and the integers M and N values should be selected accordingly.</p> <p>The recommended values are as follows:</p> <table border="1"> <thead> <tr> <th>XTAL_FREQ</th> <th>M</th> <th>N</th> <th>DIG_PLL_FREQ</th> </tr> </thead> <tbody> <tr> <td>25.0 MHz</td> <td>128</td> <td>10</td> <td>160.0 MHz</td> </tr> <tr> <td>26.0 MHz</td> <td>124</td> <td>10</td> <td>161.2 MHz</td> </tr> <tr> <td>38.4 MHz</td> <td>168</td> <td>20</td> <td>161.28 MHz</td> </tr> <tr> <td>40.0 MHz</td> <td>160</td> <td>20</td> <td>160 MHz</td> </tr> </tbody> </table> | XTAL_FREQ | M            | N        | DIG_PLL_FREQ | 25.0 MHz | 128       | 10       | 160.0 MHz | 26.0 MHz | 124     | 10 | 161.2 MHz | 38.4 MHz | 168 | 20 | 161.28 MHz | 40.0 MHz | 160 | 20 | 160 MHz |
| XTAL_FREQ           | M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | N         | DIG_PLL_FREQ |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 25.0 MHz            | 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10        | 160.0 MHz    |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 26.0 MHz            | 124                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10        | 161.2 MHz    |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 38.4 MHz            | 168                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 20        | 161.28 MHz   |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 40.0 MHz            | 160                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 20        | 160 MHz      |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| FAST clock          | <p>Fast clock is a clock derived out of the DIG_PLL.</p> <p>The frequency of the clock is DIG_PLL_FREQ for the AppSS core and DIG_PLL_FREQ / 2 for the FECSS core.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| APLL_FREQ           | <p>Analog PLL frequency.</p> <p>The frequency of the APLL depends on the input XTAL frequency. Typical output frequencies are as follows:</p> <table border="1"> <thead> <tr> <th>XTAL_FREQ</th> <th>APLL_FREQ</th> </tr> </thead> <tbody> <tr> <td>25.0 MHz</td> <td>400.0 MHz</td> </tr> <tr> <td>26.0 MHz</td> <td>403.0 MHz</td> </tr> <tr> <td>38.4 MHz</td> <td>403.2 MHz</td> </tr> <tr> <td>40.0 MHz</td> <td>400 MHz</td> </tr> </tbody> </table>                                                                                                                                                                                                                                                                           | XTAL_FREQ | APLL_FREQ    | 25.0 MHz | 400.0 MHz    | 26.0 MHz | 403.0 MHz | 38.4 MHz | 403.2 MHz | 40.0 MHz | 400 MHz |    |           |          |     |    |            |          |     |    |         |
| XTAL_FREQ           | APLL_FREQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 25.0 MHz            | 400.0 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 26.0 MHz            | 403.0 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 38.4 MHz            | 403.2 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| 40.0 MHz            | 400 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| CW Mode             | <p>Continuous Waveform Mode</p> <p>This is a special debug mode which enables the transmitters at a constant frequency (<a href="#">w_ChirpRfFreqStart</a>).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| FT                  | Frame Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |
| CT                  | Chirp Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |              |          |              |          |           |          |           |          |         |    |           |          |     |    |            |          |     |    |         |

| Abbreviation / Term           | Description                                                                                                                                                                                     |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PD                            | Peak Detector                                                                                                                                                                                   |
| RDIF                          | Radar Data Interface                                                                                                                                                                            |
| LODIST_BIAS_CODES             | Lo Distribution bias current control codes                                                                                                                                                      |
| FECSS_MON_EVENT               | FECSS Monitoring Done Interrupt Event.<br>This interrupt is mapped to the 4th IRQ channel of the AppSS processor                                                                                |
| IFA_GAIN_CODE & RFA_GAIN_CODE | Rx signal chain contains two amplifiers, one in RF section and another in IF section. Overall Rx gain is sum of gains from these two stages. These codes controls the gain of respective stages |
| TX_PA_CODE                    | Tx Power Amplifiers (PA) control codes<br>This is a 2-byte value which controls the output power                                                                                                |

## 1.4 Scope and Intended Audience

Scope of this document is to describe the mmWaveLink API interface for TI mmWave Low devices.

The intended audience for this document is firmware, application software, and validation engineers needing to understand the format and contents of all API interfaces between the mmWave DFP and the application.



# Chapter 2

## mmWaveLink APIs

mmWaveLink APIs provide seamless API interface to mmWave Sensor FECSS RF Front End. mmWaveLink Library is a high level software API layer in DFP, which interface with FECSS Library, FECSSLib provides low level driver functions to configure/control FECSS hardware. mmWaveLink API internally calls FECSSLlib drivers to perform the API job and returns the status to application.

The Application software or SDK interfaces with mmWave DFP using mmWaveLink APIs. The communication interface between Application software and mmWave DFP in mmWaveLink layer uses command-response protocol, there will be a response for all commands to mmWave DFP (FECSS RF Front End). The command normally contains configuration message data structure and response contains return information.

mmWaveLink APIs can be broadly categorized in two types:

### A. Set APIs

Set APIs are commands which configures the FECSS with some predefined parameters, the response to this command will hold only status info, error codes and few generic API execution information. The Device and sensor configuration APIs are typical SET APIs.

### B. Get APIs

Get APIs are commands which seek certain info from FECSS, command can have predefined parameters, the response to this command will hold status info, error codes, few generic API information along with GET info. The Monitor, GPADC measurement APIs are typical GET APIs.

## 2.1 mmWaveLink API Structure and Grouping

mmWaveLink APIs are defined using following elements:

### A. API Command Id

Each mmWave API has a unique 16-bit unsigned command id which can be used by the external application to implement API based communication.

**Note** Command Ids are not used in the mmWaveLink DFP API functions.

### B. API Function

Unique name of the mmWaveLink API function. All of these function start with prefix `rl_`. Example: `rl_fecssDevPwrOn`

### C. API Configuration Structure

C-structures defined in the mmWaveLink header files to hold the inputs for the API. If applicable, mmWaveLink APIs accept pointer to the corresponding configuration structure.

### D. API Response Structure

C-structures defined in the mmWaveLink header files to return the inputs for the API. If applicable, mmWaveLink APIs accept pointers to the corresponding response structure.

APIs for mmWave Low devices are categorized in four groups:

**A. Initialization APIs**

These APIs initialize and de-initialize mmWaveLink layer in the control application. Initialization involves critical tasks such as registering necessary interrupts, getting call-back functions from the application. De-initialize clears the handles created during the Initialization.

**B. Device Configuration APIs**

Device control APIs provide device level configuration and control options for the mmWave Low front end such as power control, calibrations, clock settings, etc.

**C. Sensor Configuration APIs**

Sensor APIs provide interface to configure and control the FMCW chirp parameters.

**D. Monitor Configuration APIs**

Monitor APIs provide interface to configure and trigger monitors on Functional Safety enabled devices along with few debug APIs.

## 2.2 mmWaveLink Initialization APIs

mmWaveLink initialization APIs configure an interface between the application and mmWaveLink handler. These APIs accept number of call-back functions required for the operation of mmWaveLink in application environment. Link layer assumes correctness of the callback functions provided by application.

**Warning** Incorrect callback function configuration may result in undefined behavior.

mmWaveLink Initialization includes following APIs:

- [mmWaveLink Initialization API](#)
- [mmWaveLink De-Initialization API](#)

### 2.2.1 mmWaveLink Initialization API

This API initializes all the interface call-back function and client context handlers for mmWaveLink and FECSSLib.

**Note** Callback functions are implementation defined and provided by the application. mmWaveLink callback functions just standardize the interface by defining function pointers

#### Assumptions

- Host application should call this API one for every front-end device in multi-chip cascade configuration with same call-back function configuration.
- mmWaveLink callback function structures assumes return type to be `T_RETURNTYPE`, which is a SINT32 number indicating execution status of the API.
  - **0:** Success
  - **Any Negative Number:** Error / Failure

#### API Definition

|                                    |                                   |
|------------------------------------|-----------------------------------|
| <b>API Index</b>                   | 0x0001                            |
| <b>API Function Name</b>           | <code>rl_mmWaveLinkInit</code>    |
| <b>API Configuration Structure</b> | <code>T_DFP_CLIENT_CB_DATA</code> |
| <b>API Response Structure</b>      | None                              |

#### ► API Function

mmWaveLink C function declaration

```
T_RETURNTYPE rl_mmWaveLinkInit(UINT32 w_deviceMap, T_DFP_CLIENT_CB_DATA z_clientCbData);
```

► Configuration C Structure

**Table 2.1:** T\_DFP\_CLIENT\_CB\_DATA

| Field              | Data Type               | Size | Offset |
|--------------------|-------------------------|------|--------|
| c_PlatformType     | UINT8                   | 1    | 0      |
| c_DeviceType       | UINT8                   | 1    | 1      |
| c_ApiErrorCheckDis | UINT8                   | 1    | 2      |
| c_ApiDbglogEn      | UINT8                   | 1    | 3      |
| h_ApiRespTimeoutMs | UINT16                  | 2    | 4      |
| h_Reserved1        | UINT16                  | 2    | 6      |
| z_OsiCb            | T_DFP_OSI_CB_DATA       | 36   | 8      |
| z_PltfCb           | T_DFP_PLATFORM_CB_DATA  | 36   | 44     |
| z_DbxCb            | T_DFP_DBG_PRINT_CB_DATA | 8    | 80     |
| z_ComIfCb          | T_DFP_COMIF_CB_DATA     | 16   | 88     |
| Total              |                         | 104  |        |

### Configuration Fields

► c\_PlatformType

Device Platform Type.

This value defines the mode of operation of the mmWaveLink.

- M\_DFP\_DEVICE\_PLATFORM\_SOC : For mmWaveLink running on the AppSS
- M\_DFP\_DEVICE\_PLATFORM\_FE : For mmWaveLink running on external HOST

Note: mmWave Low devices only support SOC platform and appropriate value of this field is defined in macro M\_DFP\_DEVICE\_PLATFORM\_TYPE.

► c\_DeviceType

Device Type

This field defines the exact device type. Following table shows the list of supported devices:

| Device   | mmWaveLink Macro      |
|----------|-----------------------|
| xWRL6432 | M_DFP_DEVICETYPE_6432 |
| xWRL1432 | M_DFP_DEVICETYPE_1432 |

► `c_ApiErrorCheckDis`

mmWaveLink API Error Check Disable.

Setting odd value (preferably 1) disables the error checks performed in mmWaveLink APIs. This feature can be used to reduce the API delay in production SW on non safety devices.

**Recommendation** It is recommended to do enable check always on safety devices.

► `c_ApiDbglogEn`

mmWaveLink API debug logger enable control.

Setting odd value (preferably 1) enables the debug log prints from mmWaveLink APIs. This feature relies on a callback function provided by the application (configured in `p_Print`) to print the logs.

► `h_ApiRespTimeoutMs`

mmWaveLink API response wait timeout in milliseconds.

mmWaveLink API returns an error if the API fails to execute or generate response in the specified time period.

Valid Range: [0, 65535]

Format: 1LSB = 1ms, Typical value should be 10ms

► `z_OsiCb`

Operating system callbacks.

mmWaveLink APIs require number of interface functions provided by the application operating system. These functions are called via function pointers inside the mmWaveLink and FECSSLlib drivers. Following table defines the structure which holds these OS callbacks.

**Table 2.2: T\_DFP\_OSI\_CB\_DATA**

| Field                | Data Type                            | Size      | Offset |
|----------------------|--------------------------------------|-----------|--------|
| <code>z_Mutex</code> | <code>T_DFP_OSI_MUTEX_CB_DATA</code> | 16        | 0x0    |
| <code>z_Semp</code>  | <code>T_DFP_OSI_SEMP_CB_DATA</code>  | 16        | 0x10   |
| <code>z_Queue</code> | <code>T_DFP_OSI_MSGQQ_CB_DATA</code> | 4         | 0x20   |
| Total                |                                      | <b>36</b> |        |

### `z_Mutex`

OS Mutex callback function data

This Structure hold callback function pointers for the functions required for handling mutexes.

**Table 2.3:** T\_DFP\_OSI\_MUTEX\_CB\_DATA

| Field            | Data Type                                                                   | Size | Offset    |
|------------------|-----------------------------------------------------------------------------|------|-----------|
| p_OsiMutexCreate | T_RETURNTYPE<br>→ (*p_OsiMutexCreate)(T_DFP_OSI_MUTEX_HDL,<br>→ *, UINT8 *) | 4    | 0x0       |
| p_OsiMutexLock   | T_RETURNTYPE<br>→ (*p_OsiMutexLock)(T_DFP_OSI_MUTEX_HDL,<br>→ , UINT32)     | 4    | 0x4       |
| p_OsiMutexUnLock | T_RETURNTYPE<br>→ (*p_OsiMutexUnLock)(T_DFP_OSI_MUTEX_HDL)                  | 4    | 0x8       |
| p_OsiMutexDelete | T_RETURNTYPE<br>→ (*p_OsiMutexDelete)(T_DFP_OSI_MUTEX_HDL)                  | 4    | 0xc       |
| Total            |                                                                             |      | <b>16</b> |

- p\_OsiMutexCreate :

This function should create a mutex object and initialize the handler using reference pointer. The function should accept a pointer to uninitialized mutex handler and name for the mutex and return T\_RETURNTYPE response.

- p\_OsiMutexLock :

This functions should attempt to lock the initialized mutex using the handler and timeout value parameters. The function should return M\_DFP\_RET\_CODE\_RADAR\_OSIF\_ERROR in case of failure to acquire lock.

- p\_OsiMutexUnLock :

This function should unlock the mutex using the handler and return M\_DFP\_RET\_CODE\_RADAR\_OSIF\_ERROR in case of failure.

- p\_OsiMutexDelete :

This function should de-initialize the mutex using the handler and return T\_RETURNTYPE response.

## z\_Semp

OS Semaphore callback function data

This Structure hold callback function pointers for the functions required for handling semaphores.

**Table 2.4:** T\_DFP\_OSI\_SEMP\_CB\_DATA

| Field          | Data Type                                                               | Size | Offset    |
|----------------|-------------------------------------------------------------------------|------|-----------|
| p_OsiSemCreate | T_RETURNTYPE<br>→ (*p_OsiSemCreate)(T_DFP_OSI_SEM_HDL,<br>→ *, UINT8 *) | 4    | 0x0       |
| p_OsiSemWait   | T_RETURNTYPE<br>→ (*p_OsiSemWait)(T_DFP_OSI_SEM_HDL,<br>→ , UINT32)     | 4    | 0x4       |
| p_OsiSemSignal | T_RETURNTYPE<br>→ (*p_OsiSemSignal)(T_DFP_OSI_SEM_HDL)                  | 4    | 0x8       |
| p_OsiSemDelete | T_RETURNTYPE<br>→ (*p_OsiSemDelete)(T_DFP_OSI_SEM_HDL)                  | 4    | 0xc       |
| Total          |                                                                         |      | <b>16</b> |

- p\_OsiSemCreate :

This function should create a semaphore object and initialize the handler using reference pointer. The function should accept a pointer to uninitialized semaphore handler and name for the mutex and return T\_RETURNTYPE response.

- p\_OsiSemWait :

This functions should wait on the initialized semaphore using the handler and timeout value parameters. The function should return after the timeout.

- p\_OsiSemSignal :

This function should perform post on the semaphore using the handler and return M\_DFP\_RET\_CODE\_RADAR\_OSIF\_ERROR in case of failure.

- p\_OsiSemDelete :

This function should de-initialize the semaphore using the handler and return T\_RETURNTYPE response.

## z\_Queue

OS message queue and task spawn data

This Structure hold callback function pointers for the functions required for creating message queues and spawn tasks.

**Table 2.5:** T\_DFP\_OSI\_MSGQ\_CB\_DATA

| Field             | Data Type                                                                           | Size | Offset |
|-------------------|-------------------------------------------------------------------------------------|------|--------|
| <u>p_OsiSpawn</u> | T_RETURNTYPE<br>→ (*p_OsiSpawn) (T_DFP_OSI_SPAWN_HANDLER<br>, const void* , UINT32) | 4    | 0x0    |
| Total             |                                                                                     |      | 4      |

- p\_OsiSpawn :

This function should spawn a totally independent new task. This callback function is reserved for future use.

## ► z\_PltfCb

Platform callback function pointers.

This structure contains callbacks for application platform specific functions like serial interface handlers, delay, etc.

**Table 2.6:** T\_DFP\_PLATFORM\_CB\_DATA

| Field                  | Data Type                                                                                           | Size      | Offset |
|------------------------|-----------------------------------------------------------------------------------------------------|-----------|--------|
| p_Delay                | T_RETURNTYPE (*p_Delay)(UINT32)                                                                     | 4         | 0x0    |
| p_TimeStamp            | UINT32 (*p_TimeStamp)(void)                                                                         | 4         | 0x4    |
| p_RegisterIsr          | T_RETURNTYPE (*p_RegisterIsr)(UINT8 ,<br>↳ T_DFP_PLT_ISR_HANDLER , void* ,<br>↳ T_DFP_PLT_HWI_HDL*) | 4         | 0x8    |
| p_DeRegisterIsr        | T_RETURNTYPE<br>(*p_DeRegisterIsr)(T_DFP_PLT_HWI_HDL)                                               | 4         | 0xc    |
| p_MaskIsr              | T_RETURNTYPE<br>(*p_MaskIsr)(T_DFP_PLT_HWI_HDL)                                                     | 4         | 0x10   |
| p_UnMaskIsr            | T_RETURNTYPE<br>(*p_UnMaskIsr)(T_DFP_PLT_HWI_HDL)                                                   | 4         | 0x14   |
| p_EnterCriticalSection | UINT64 (*p_EnterCriticalSection)(void)                                                              | 4         | 0x18   |
| p_ExitCriticalSection  | void (*p_ExitCriticalSection)(UINT64)                                                               | 4         | 0x1c   |
| w_TimeStampCounterMask | UINT32                                                                                              | 4         | 0x20   |
| Total                  |                                                                                                     | <b>36</b> |        |

- p\_Delay :

This is a function pointer to the delay function which receives delay value with  $1LSB = 1\mu s$ . Application may choose to implementation in non-blocking mode.

- p\_TimeStamp :

This is a function pointer which could be used to get a time-stamp, preferably SysTick based time-stamp.

- p\_RegisterIsr :

This is function pointer to the function which registers the FECSS mailbox interrupt (INT\_FEC\_INTRO) for mmWaveLink APIs to function. [mmWaveLink Initialization API](#) calls this function internally. The function should perform following tasks:

- Register the ISR handler provided by mmWaveLink for FECSS mailbox interrupt
- Configure FECSS mailbox interrupt priority (Priority Recommendation: Highest)
- Clear pending mailbox interrupt
- Enable mailbox interrupt

- p\_DeRegisterIsr :

This is function pointer to the function which de-registers the FECSS mailbox interrupt. This function is called in [mmWaveLink De-Initialization API](#).

- p\_MaskIsr :

Callback function to mask required interrupt. As of now callback is not used in mmWave Low devices.

- p\_UnMaskIsr :

Callback function to un-mask required interrupt. As of now callback is not used in mmWave Low devices.

- p\_EnterCriticalSection :

Callback function to enter a critical region (Uninterrupted mode with all interrupts and task switching disabled). As of now callback is not used in mmWave Low devices.

- p\_ExitCriticalSection :

Callback function to exit a critical region. As of now callback is not used in mmWave Low devices.

- w\_TimeStampCounterMask :

This value represents a 32-bit mask for the timestamp returned from [p\\_TimeStamp](#). The value of this mask should be  $2^w - 1$  where  $w$  is a bit-width of the time-stamp counter.

► **z\_DbgCb**

mmWaveLink debug configuration data

**Table 2.7:** T\_DFP\_DBG\_PRINT\_CB\_DATA

| Field                        | Data Type         | Size | Offset   |
|------------------------------|-------------------|------|----------|
| <a href="#">p_Print</a>      | T_DFP_PRINT_FUNCP | 4    | 0x0      |
| <a href="#">p_RfsdbgData</a> | UINT32*           | 4    | 0x4      |
| Total                        |                   |      | <b>8</b> |

- p\_Print :

`printf` like function to print the debug logs from mmWaveLink and FECSSLib.

Note: Debug logs will be disable if the callback function pointer is NULL.

- p\_RfsdbgData :

Pointer to the 64-byte buffer to store RFS debug log which is read at the every API. This debug data is in TI specific encoded format. Application should provide a separate buffer for every device in a multi-chip configuration.

► **z\_ComIfCb**

Communication interface callback data

This structure holds the callback configuration for communication interfaces such as SPI, UART etc. These callbacks are required only in multi-chip configuration where the mmWaveLink runs on the host.

**Table 2.8:** T\_DFP\_COMIF\_CB\_DATA

| Field        | Data Type                                                                    | Size | Offset |
|--------------|------------------------------------------------------------------------------|------|--------|
| p_ComIfOpen  | T_DFP_COMIF_HDL (*p_ComIfOpen)(UINT8,<br>, UINT32)                           | 4    | 0x0    |
| p_ComIfRead  | SINT32 (*p_ComIfRead)(T_DFP_COMIF_HDL,<br>, UINT8 *, const UINT8 *, UINT32)  | 4    | 0x4    |
| p_ComIfWrite | SINT32 (*p_ComIfWrite)(T_DFP_COMIF_HDL,<br>, UINT8 *, const UINT8 *, UINT32) | 4    | 0x8    |
| p_ComIfClose | T_RETURNTYPE<br>(*p_ComIfClose)(T_DFP_COMIF_HDL)                             | 4    | 0xc    |
|              | Total                                                                        |      | 16     |

- p\_ComIfOpen :  
Callback function to open requested communication interface.
- p\_ComIfRead :  
Callback function to read data using the communication interface handle.
- p\_ComIfWrite :  
Callback function to write data using the communication interface handle.
- p\_ComIfClose :  
Callback function to close the communication interface.

## 2.2.2 mmWaveLink De-Initialization API

This API de-initializes the mmWaveLink call-back function and client context handlers for mmWaveLink and FECSSLib. The API should be called at the end of the application to free-up the resources used by mmWaveLink and FECSSLib.

### API Definition

| API Index              |                                  |
|------------------------|----------------------------------|
| API Function Name      | rl_mmWaveLinkDeInit              |
| API Input              | Device map with 1-bit per device |
| API Response Structure | None                             |

### ► API Function

mmWaveLink C function declaration

```
T_RETURNTYPE rl_mmWaveLinkDeInit(UINT32 w_deviceMap);
```

## 2.3 mmWaveLink Device Configuration APIs

mmWaveLink Device APIs provide interface to configure and control the FECSS. Following diagram shows functional blocks of the device module.

mmWaveLink provides following APIs to control device:

- FECSS Device Power On API
- FECSS Device Power OFF API
- DFP Version Get API
- FECSS RF Power On Off API
- FECSS Factory Calibration API
- FECSS RF Runtime Calibration API
- FECSS RF Clock Bandwidth Configuration API
- FECSS GPADC Measurement Configuration API
- FECSS GPADC Measurement Trigger API
- FECSS Temperature Measurement Config API
- FECSS Temperature Measurement Trigger API
- FECSS Factory Calibration Data Get API
- FECSS Factory Calibration Data Set API
- FECSS Device Clock Ctrl API
- FECSS Device RDIF Control API
- FECSS Device Status Get API
- FECSS RF Status Get API
- FECSS RF Fault Status Get API
- FECSS Die Id Get API
- FECSS Rx-Tx Calibration Data Get API
- FECSS Rx-Tx Calibration Data Set API
- FECSS RFS Debug Configuration API
- FECSS RF Runtime Tx CLPC API

### 2.3.1 FECSS Device Power On API

This API function contains the device power ON control, power modes and clock configuration settings. The application should use this API to powerup the FECSS before issuing other functional APIs.

## API Definition

|                                    |                               |
|------------------------------------|-------------------------------|
| <b>API Index</b>                   | 0x0003U                       |
| <b>API Function Name</b>           | rl_fecssDevPwrOn              |
| <b>API Configuration Structure</b> | T_RL_API_FECSS_DEV_PWR_ON_CMD |
| <b>API Response Structure</b>      | None                          |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_DEV_PWR_ON ((UINT16)0x0003U)
// API Function Definition
T_RETURNTYPE rl_fecssDevPwrOn(UINT8 c_devIndex, const T_RL_API_FECSS_DEV_PWR_ON_CMD
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.9:** T\_RL\_API\_FECSS\_DEV\_PWR\_ON\_CMD

| Field             | Data Type | Size      | Offset |
|-------------------|-----------|-----------|--------|
| h_XtalClkFreq     | UINT16    | 2         | 0      |
| c_ClkSourceSel    | UINT8     | 1         | 2      |
| c_PowerMode       | UINT8     | 1         | 3      |
| c_ChirpTimerResol | UINT8     | 1         | 4      |
| c_FecBootCfg      | UINT8     | 1         | 5      |
| h_Reserved2       | UINT16    | 2         | 6      |
| w_Reserved3       | UINT32    | 4         | 8      |
| Total             |           | <b>12</b> |        |

## Configuration Fields

### ► h\_XtalClkFreq

Device XTAL clock frequency

The RFS software requires operating XTAL frequency to configure front-end and maintain time.

Unit: 1 LSB = 1/256 MHz

| XTAL Frequency | Value |
|----------------|-------|
| 25MHz          | 6400  |
| 26MHz          | 6656  |
| 38.4MHz        | 9830  |
| 40MHz          | 10240 |

**Warning** Following table lists the supported XTAL frequencies per device:

| Device   | Supported XTALs |
|----------|-----------------|
| xWRL6432 | 40 MHz          |
| xWRL1432 | 40 MHz          |

► **c\_ClkSourceSel**

FECSS clock source selection during power up. FECSS can power up on either XTAL for FAST clock. Application choose the desired source based on requirements.

| Value | Definition                                                                                                                                           |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00  | XTAL clock source                                                                                                                                    |
| 0x0A  | Fast clock source, fast clock can be either DIG_PLL or APLL clock set by application.<br>Clock Frequency: DIG_PLL/2 (Typical 80MHz with 40MHz XTAL). |

**Recommendation** Fast Clock should be used to reduce FECSS power-up time

► **c\_PowerMode**

FECSS power up mode, The power up mode can be either cold or warm boot type.

| Value | Definition                                                                                                                                                                                                                                                                                                                                                                                | mmWaveLink Macro            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x00  | <p><b>Cold Boot</b><br/> If c_PowerMode is 0x00, FECSS power up is performed in cold boot and the RFS data memory is re-initialized during power up.<br/> The RFS code memory should be initialized by boot loader/application before calling this API.<br/> Typical use case: First time boot or nReset.</p>                                                                             | M_RL_FECSS_PWR_ON_MODE_COLD |
| 0x0A  | <p><b>Warm Boot</b><br/> If c_PowerMode is 0x0A, FECSS power up is performed in warm boot and the RFS data memory is retained un-initialized during power up.<br/> To support warm boot mode, the FECSS power down must be done with <code>c_RetentionMode = 0x0A</code>, this will retain the FECSS memory in deep sleep.<br/> Typical use case: Deep sleep exit and software reset.</p> | M_RL_FECSS_PWR_ON_MODE_WARM |

**Warning** The warm boot can be done only if power down is done with `c_RetentionMode = 0x0A` to retain the FECSS memory.

#### ► `c_ChirpTimerResol`

The RF start frequency resolution and timing related chirp parameters resolution selection.

| Value | Definition            |
|-------|-----------------------|
| 0x0   | Low resolution mode.  |
| 0x1   | High resolution mode. |

Bit Definition:

| Value | Definition                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | <p>Frequency Resolution</p> <ul style="list-style-type: none"> <li>Low resolution mode supports 16-bit frequency value.</li> <li>High resolution mode supports 24-bit frequency value.</li> </ul> <p>This resolution setting is applicable for <code>w_ChirpRfFreqStart</code>.</p>                                                                                                                                          |
| 1     | <p>Time Resolution</p> <ul style="list-style-type: none"> <li>Low resolution mode supports 1 LSB = 40/APLL_FREQ (Typical 100ns with APPLL_FREQ = 400MHz).</li> <li>High resolution mode supports 1 LSB = 8/APLL_FREQ (Typical 20ns with APPLL_FREQ = 400MHz).</li> </ul> <p>This resolution setting is applicable for <code>h_ChirpIdleTime</code>, <code>h_ChirpRampEndTime</code> and <code>w_BurstPeriodicity</code>.</p> |

**Warning** c\_ChirpTimerResol should configure at boot once per power cycle. RFS subsystem configures the hardware based on the setting so it should not be changed dynamically. Also the profile configuration should be updated accordingly.

### ► c\_FecBootCfg

The FEC RFS M3 boot mode configuration.

Bit definition:

| Bit Field  | Definition                                                                                                                                                               |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bits [0]   | FEC RFS M3 boot self-test disable flag. This field is applicable only for safety enabled devices.<br>Value 0 : Self test enable (default)<br>Value 1 : Self test disable |
| bits [7:1] | Reserved                                                                                                                                                                 |

### 2.3.2 FECSS Device Power OFF API

This API function contains the device power off mode setting. The application should use this API to perform power down of the FECSS before entering deep sleep mode or software reset.

#### API Definition

|                                    |                                |
|------------------------------------|--------------------------------|
| <b>API Index</b>                   | 0x0004U                        |
| <b>API Function Name</b>           | r1_fecssDevPwrOff              |
| <b>API Configuration Structure</b> | T_RL_API_FECSS_DEV_PWR_OFF_CMD |
| <b>API Response Structure</b>      | None                           |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_DEV_PWR_OFF ((UINT16)0x0004U)
// API Function Definition
T_RETURNTYPE r1_fecssDevPwrOff(UINT8 c_devIndex, const T_RL_API_FECSS_DEV_PWR_OFF_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.10:** T\_RL\_API\_FECSS\_DEV\_PWR\_OFF\_CMD

| Field           | Data Type | Size | Offset   |
|-----------------|-----------|------|----------|
| c_RetentionMode | UINT8     | 1    | 0        |
| c_Reserve1      | UINT8     | 1    | 1        |
| h_Reserve2      | UINT16    | 2    | 2        |
| w_Reserve3      | UINT32    | 4    | 4        |
| Total           |           |      | <b>8</b> |

### Configuration Fields

► c\_RetentionMode

FECSS memory retention mode, the mode can be either RETENTION OFF or RETENTION ON type.

**Warning** The warm boot can be done only if power down is done with `c_RetentionMode` = 0x0A to retain the FECSS memory.

| Value | Definition                                                                                                                                                                                                                                                         | mmWaveLink Macro            |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x00  | <b>RETENTION OFF.</b><br>If <code>c_RetentionMode</code> is 0x00, then FECSS RAM is not retained across deep sleep cycle.<br>The successive FEC power up <code>c_PowerMode</code> supposed to be cold boot type.<br>Typical use case: Hibernate.                   | M_RL_FECSS_PWR_DOWN_RET_OFF |
| 0x0A  | <b>RETENTION ON.</b><br>If <code>c_RetentionMode</code> is 0x0A, then FECSS RAM is retained across deep sleep cycle.<br>The successive FEC power up <code>c_PowerMode</code> supposed to be warm boot type.<br>Typical use case: Deep sleep Entry, software reset. | M_RL_FECSS_PWR_DOWN_RET_ON  |

### 2.3.3 DFP Version Get API

This API function returns a data structure containing the version information of mmWaveLink Library, FECSS Library and RFS ROM and Patch firmware.

## API Definition

|                                    |                             |
|------------------------------------|-----------------------------|
| <b>API Index</b>                   | 0x0005U                     |
| <b>API Function Name</b>           | rl_mmWaveDfpVerGet          |
| <b>API Configuration Structure</b> | None                        |
| <b>API Response Structure</b>      | T_RL_API_DFP_FW_VER_GET_RSP |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_DFP_VER_GET ((UINT16)0x0005U)
// API Function Definition
T_RETURNTYPE rl_mmWaveDfpVerGet(UINT8 c_devIndex, T_RL_API_DFP_FW_VER_GET_RSP *p_apiResData);
```

### ► Response C Structure

**Table 2.11:** T\_RL\_API\_DFP\_FW\_VER\_GET\_RSP

| Field             | Data Type         | Size | Offset |
|-------------------|-------------------|------|--------|
| z_MmwLibVersion   | T_DFP_COMP_FW_VER | 8    | 0      |
| z_FecssLibVersion | T_DFP_COMP_FW_VER | 8    | 8      |
| z_RfsRomVersion   | T_DFP_COMP_FW_VER | 8    | 16     |
| z_RfsPatchVersion | T_DFP_COMP_FW_VER | 8    | 24     |
| Total             |                   | 32   |        |

**Table 2.12:** T\_DFP\_COMP\_FW\_VER

| Field         | Data Type | Size | Offset |
|---------------|-----------|------|--------|
| c_GenVerNum   | UINT8     | 1    | 0      |
| c_MajorVerNum | UINT8     | 1    | 1      |
| c_MinorVerNum | UINT8     | 1    | 2      |
| c_BuildVerNum | UINT8     | 1    | 3      |
| c_Year        | UINT8     | 1    | 4      |
| c_Month       | UINT8     | 1    | 5      |
| c_Date        | UINT8     | 1    | 6      |
| c_Reserved    | UINT8     | 1    | 7      |
| Total         |           | 8    |        |

## Response Fields

► **z\_MmwLibVersion**

mmWaveLink Lib version, 8 bytes.

► **z\_FecssLibVersion**

FECSSLib version, 8 bytes.

► **z\_RfsRomVersion**

RFS ROM version, 8 bytes.

► **z\_RfsPatchVersion**

RFS Patch version, 8 bytes.

### 2.3.4 FECSS RF Power On Off API

This API configures the device RF channels and miscellaneous control settings. Application should issue this API before any other functional API which configures the RF settings.

**Warning** All the enabled configurations must be disabled by issuing this API with zero input before FECSS power off. This ensures the correct firmware states after wake up and saves power.

#### API Definition

|                                    |                               |
|------------------------------------|-------------------------------|
| <b>API Index</b>                   | 0x0006U                       |
| <b>API Function Name</b>           | rl_fecssRfPwrOnOff            |
| <b>API Configuration Structure</b> | T_RL_API_FECSS_RF_PWR_CFG_CMD |
| <b>API Response Structure</b>      | None                          |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RF_PWR_ONOFF           ((UINT16)0x0006U)
// API Function Definition
T_RETURNTYPE rl_fecssRfPwrOnOff(UINT8 c_devIndex, const T_RL_API_FECSS_RF_PWR_CFG_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.13:** T\_RL\_API\_FECSS\_RF\_PWR\_CFG\_CMD

| Field             | Data Type | Size | Offset    |
|-------------------|-----------|------|-----------|
| h_RxChCtrlBitMask | UINT16    | 2    | 0         |
| h_TxChCtrlBitMask | UINT16    | 2    | 2         |
| c_Reserve         | UINT8     | 1    | 4         |
| c_MiscCtrl        | UINT8     | 1    | 5         |
| h_Reserved1       | UINT16    | 2    | 6         |
| w_Reserved2       | UINT32    | 4    | 8         |
| Total             |           |      | <b>12</b> |

### Configuration Fields

► h\_RxChCtrlBitMask

FECSS RFS RX channels ON/OFF control, 1 bit per channel.

| Value | Definition                                                                                    |
|-------|-----------------------------------------------------------------------------------------------|
| 0x0   | OFF, RX channel will not be enabled in any functional frame, calibration and monitor trigger. |
| 0x1   | ON, RX channel will be enabled automatically.                                                 |

**Recommendation** The RFS enables the RX channels before executing below functionalities and disables it in the end.

- [FECSS Factory Calibration API](#)
- [FECSS RF Runtime Calibration API](#)
- [FECSS Monitor Enable Trigger API](#)
- [Sensor Start API](#)

In idle state, the Tx, RX channels are by default in power down state. In TX Calibrations, RX Calibrations and Monitors at least one RX channel should be enabled.

| Bit Field   | Definition   | mmWaveLink Macro  |
|-------------|--------------|-------------------|
| bits [0]    | Rx Channel 0 | M_RL_RX_CHANNEL_0 |
| bits [1]    | Rx Channel 1 | M_RL_RX_CHANNEL_1 |
| bits [2]    | Rx Channel 2 | M_RL_RX_CHANNEL_2 |
| bits [15:3] | Reserved     |                   |

► h\_TxChCtrlBitMask

FECSS RFS TX channels ON/OFF control, 1 bit per channel.

**Recommendation** / The RFS enables the TX channels before executing below functionalities and disables it in the end.

- [FECSS Factory Calibration API](#)
- [FECSS RF Runtime Calibration API](#)
- [FECSS Monitor Enable Trigger API](#)
- [Sensor Start API](#)

In idle state, the TX channels are by default in power down state. In TX Calibrations and Monitors, the corresponding TX channel should be enabled. The RFS FW enables corresponding TX channel if this mask value is zero.

| Value | Definition                                                                                    | mmWaveLink Macro  |
|-------|-----------------------------------------------------------------------------------------------|-------------------|
| 0x0   | OFF, TX channel will not be enabled in any functional frame, calibration and monitor trigger. | M_RL_TX_CHANNEL_0 |
| 0x1   | ON, TX channel will be enabled automatically.                                                 | M_RL_TX_CHANNEL_1 |

Bit field definition:

| Bit Field   | Definition                 |
|-------------|----------------------------|
| bits [0]    | Tx Channel 0 Power Control |
| bits [1]    | Tx Channel 1 Power Control |
| bits [15:2] | Reserved                   |

► [c\\_MiscCtrl](#)

FECSS RFS FECSS Miscellaneous block / clock control, 1 bit per control.

| Value | Definition          |
|-------|---------------------|
| 0x0   | Block Disable       |
| 0x1   | Block Enable height |

Bit field definition:

| Bit Field | Definition                                                                                                                                                                                                                                                                              | mmWaveLink Macro                   |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Bit [0]   | <p>RDIF clock enable control.</p> <p>The clock to the RDIF IP block should be enabled using this control before configuring and enabling the RDIF.</p> <p><u>Note:</u> This clock is derived from APLL clock. APLL must be ON while enabling this clock.</p>                            | M_RL_RF_MISC_CTRL_RDIF_CLK         |
| Bit [1]   | <p>RF ANA 1V LDO bypass control.</p> <p>By default the internal LDO is used to drive 1V supply.</p> <p>To bypass the internal LDO, set this bit.</p> <p><u>Note:</u> External 1V supply should be connected in case of bypass.</p> <p><u>Note:</u> Reserved for internal test only.</p> | M_RL_RF_MISC_CTRL_RF_1V_LDO_BYPASS |
| Bit [7:2] | Reserved                                                                                                                                                                                                                                                                                |                                    |

### 2.3.5 FECSS Factory Calibration API

This API function configures and triggers the FECSS RF factory calibrations. The application should use this API to perform one time RF configuration dependent calibrations (factory calibration) and store the results in non-volatile memory with the help of [FECSS Factory Calibration Data Get API](#). The results can be restored in field using [FECSS Factory Calibration Data Set API](#).

Factory calibration API supports following calibrations:

#### i. VCO Delta Trim Calibration

Update Synthesizer VCO C-trim to compensate for temperature and aging

#### ii. PD Offset Calibration

Compensate temperature dependent PD offsets

#### iii. LoDIST LUT Calibration

Update LoDist and other PVT LUT based settings

#### iv. Rx IFA Calibration

Calibrate HPF and LPF in the Rx IFA.

#### v. Rx Gain Calibration

Derive Rx gain codes for desired gain for 3 temperature bins

#### vi. Tx Power Calibration

Derive Tx PA codes for desired backoff(s) for 3 temperature bins

**Assumptions**

- APLL must be enabled before using FECSS Device Clock Ctrl API
- Tx and Rx channel configuration is set using FECSS RF Power On Off API
- Live monitor faults and loopbacks are disabled

**Recommendation**

Factory calibrations are recommended to run within junction temperature range of 10°C to 50°C.

**API Definition**

|                                    |                                |
|------------------------------------|--------------------------------|
| <b>API Index</b>                   | 0x0007U                        |
| <b>API Function Name</b>           | rl_fecssRfFactoryCal           |
| <b>API Configuration Structure</b> | T_RL_API_FECSS_RF_FACT_CAL_CMD |
| <b>API Response Structure</b>      | T_RL_API_FECSS_RF_FACT_CAL_RSP |

**► API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RF_FACTORY_CAL           ((UINT16)0x0007U)
// API Function Definition
T_RETURNTYPE rl_rfcssRfFactoryCal(UINT8 c_devIndex, const
→   T_RL_API_FECSS_RF_FACT_CAL_CMD *p_apiCmdData, T_RL_API_FECSS_RF_FACT_CAL_RSP*
→   p_apiResData);
```

► Configuration C Structure

**Table 2.14:** T\_RL\_API\_FECSS\_RF\_FACT\_CAL\_CMD

| Field                  | Data Type | Size      | Offset |
|------------------------|-----------|-----------|--------|
| h_CalCtrlBitMask       | UINT16    | 2         | 0      |
| c_MiscCalCtrl          | UINT8     | 1         | 2      |
| c_CalRxGainSel         | UINT8     | 1         | 3      |
| c_CalTxBackOffSel      | UINT8[4]  | 4         | 4      |
| w_Reserved0            | UINT32    | 4         | 8      |
| h_CalRfFreq            | UINT16    | 2         | 12     |
| xh_CalRfSlope          | SINT16    | 2         | 14     |
| c_TxPwrCalTxEnaMask    | UINT8[4]  | 4         | 16     |
| w_Reserved1            | UINT32    | 4         | 20     |
| xc_CalTempBinOverrides | SINT8[3]  | 3         | 24     |
| c_Reserved1            | UINT8     | 1         | 27     |
| w_Reserved2            | UINT32[2] | 8         | 28     |
| Total                  |           | <b>36</b> |        |

► Response C Structure

**Table 2.15:** T\_RL\_API\_FECSS\_RF\_FACT\_CAL\_RSP

| Field          | Data Type | Size      | Offset |
|----------------|-----------|-----------|--------|
| h_CalRunStatus | UINT16    | 2         | 0      |
| h_CalResStatus | UINT16    | 2         | 2      |
| xc_CalibTemp   | SINT8     | 1         | 4      |
| c_Reserved1    | UINT8     | 1         | 5      |
| h_Reserved2    | UINT16    | 2         | 6      |
| w_Reserved4    | UINT32    | 4         | 8      |
| Total          |           | <b>12</b> |        |

### Configuration Fields

► h\_CalCtrlBitMask

FECSS RFS factory calibration enable control mask with 1 bit per calibration. Setting the corresponding bit will enable the calibration.

**Recommendation** Tx and Rx calibrations are recommended to run along with the VCO, PD and LoDIST calibrations to get better calibration accuracy.

Bit-definitions are as follows:

| Bit(s) | Definition                                                                                                               | mmWaveLink Macro           |
|--------|--------------------------------------------------------------------------------------------------------------------------|----------------------------|
| Bit[0] | Reserved                                                                                                                 |                            |
| Bit[1] | Enable synthesizer VCO calibration                                                                                       | M_RL_FECSS_DEV_CAL_VCO     |
| Bit[2] | Enable PD calibration                                                                                                    | M_RL_FECSS_DEV_CAL_PD      |
| Bit[3] | Enable LoDIST LUT calibration                                                                                            | M_RL_FECSS_DEV_CAL_LODIST  |
| Bit[4] | Reserved                                                                                                                 |                            |
| Bit[5] | Enable Rx IFA calibration<br><i>Note:</i> Required only for pre-production samples and requires ATE calibration firmware | M_RL_FECSS_DEV_CAL_RX_IFA  |
| Bit[6] | Enable Rx gain calibration                                                                                               | M_RL_FECSS_DEV_CAL_RX_GAIN |
| Bit[7] | Enable Tx power calibration                                                                                              | M_RL_FECSS_DEV_CAL_TX_PWR  |

#### ► c\_MiscCalCtrl

Miscellaneous calibration control bits:

| Bit(s)    | Definition                                                                                                                                                                                                                                                                                            | mmWaveLink Macro                    |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Bit[0]    | Disable RF measurements in the Rx gain calibration and re-use data from previous calibration.<br>DFP stores the measured RF values when Rx gain calibration is executed with this bit disabled.<br>Firmware re-uses the stored data to compute <code>c_RxGainCodes</code> when the feature is enabled | M_RL_FECSS_CAL_RF_GAIN_CAL_DIS      |
| Bit[1]    | Disable Tx closed loop calibration (CLPC) while calibrating Tx's                                                                                                                                                                                                                                      | M_RL_FECSS_CAL_TX_CLPC_CAL_DIS      |
| Bit[2]    | Override bin temperatures for Tx calibration                                                                                                                                                                                                                                                          | M_RL_FECSS_CAL_TX_CAL_TEMP_OVERRIDE |
| Bits[7-3] | Reserved                                                                                                                                                                                                                                                                                              |                                     |

**Recommendation** Use of override bin temperatures is not recommended for xWRLx432 devices

► **c\_CalRxGainSel**

Common Rx channel gain setting for all Rx channels in dB.  $1LSB = 1dB$

Factory calibration API computes **c\_CalRxGainCodes** for the three temperature bins bins to achieve similar RF performance across temperature range.

Valid Range: [30, 40]

Bit-definitions are as follows:

| Bit(s)   | Definition                            | mmWaveLink Macro            |
|----------|---------------------------------------|-----------------------------|
| Bit[5-0] | RX gain selection for each RX channel | M_RL_FECSS_CAL_RX_GAIN_MASK |
| Bit[7-6] | Reserved                              |                             |

► **c\_CalTxBackOffSel**

Chirp Profile TX channels power back-off setting for calibration in dB.  $1LSB = 0.5dB$

Byte definition is as follows:

| Byte Field | Definition                          |
|------------|-------------------------------------|
| Byte[0]    | Output power back-off value for Tx0 |
| Byte[1]    | Output power back-off value for TX1 |
| Byte[3-2]  | Reserved                            |

**Note** Accuracy of the Tx factory calibration may degrade with higher back-off.

| Device   | Backoff-Range |
|----------|---------------|
| xWRL6432 | [0dB, 26dB]   |
| xWRL1432 | [0dB, 20dB]   |

**Warning** Please check DFP release notes for release specific constraints

► **h\_CalRfFreq**

Calibration chirp RF start Frequency.

**Recommendation** Run calibrations around the mid-band frequency with a very small slope

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► `xh_CalRfSlope`

RFS calibration chirp RF Frequency Slope.

**Recommendation** The typical ramp time used in FW for calibration chirps are 55us.

For 60GHz: (APPLL\_FREQ = 400MHz): 2.2MHz/us (0x4D).

For 77GHz: (APPLL\_FREQ = 400MHz): 2.2MHz/us (0x3A).

| RF Slope | Resolution                                                                                                                                                        |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us (APPLL_FREQ = 400MHz)) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us (APPLL_FREQ = 400MHz)) |

► `c_TxPwrCalTxEnaMask`

Per channel Tx enable mask for calibrations.

**Recommendation**

- In case more than 1 TXs are enabled during the chirp, then enabling the same TXs during calibration will result in better TX output power accuracy.
- Recommended Calibration Masks: 0x3, 0x1. This setting will enable both Tx channels while calibrating Tx 0 and copy the results for Tx1 without separately calibrating it.

Calibrated bias code for all Tx channels.

| Byte Field | Definition                                                                                                                                                                                                                                   |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Byte[0]    | Tx enable mask for calibrating Tx0.<br>If Tx0 is disabled in this mask, calibration data from the lowest enabled Tx channel from this mask will be applied to Tx0.<br>Tx0 calibration will be skipped from the calibration if the mask is 0. |
| Byte[1]    | Tx enable mask for calibrating Tx1.<br>If Tx1 is disabled in this mask, calibration data from the lowest enabled Tx channel from this mask will be applied to Tx1.<br>Tx1 calibration will be skipped from the calibration if the mask is 0. |
| Byte[3-2]  | Reserved                                                                                                                                                                                                                                     |

Examples Following list describes the Tx enable masks for a 2 channel device.

- `c_TxPwrCalTxEnaMask = 3, 1`  
Tx0 is calibrated with backoff from `c_CalTxBackOffSel[0]` with both Tx0 and Tx1 enabled during calibration  
Results from Tx0 calibration are copied to Tx1  
This mode is recommended to keep Tx mismatches to minimum
- `c_TxPwrCalTxEnaMask = 2, 3`  
Results from Tx1 calibration are copied to Tx0  
Tx1 is calibrated with backoff from `c_CalTxBackOffSel[1]` with both Tx0 and Tx1 enabled during calibration
- `c_TxPwrCalTxEnaMask = 1, 2`  
Tx0 is calibrated with backoff from `c_CalTxBackOffSel[0]` with Tx1 disabled  
Tx1 is calibrated with backoff from `c_CalTxBackOffSel[1]` with Tx0 disabled  
This mode is not recommended because of higher Tx mismatch
- `c_TxPwrCalTxEnaMask = 3, 3`  
Tx0 is calibrated with backoff from `c_CalTxBackOffSel[0]` with both Tx0 and Tx1 enabled during calibration  
Tx1 is calibrated with backoff from `c_CalTxBackOffSel[1]` with both Tx0 and Tx1 enabled during calibration  
Since both Tx channels are calibrated separately, Tx mismatch will be higher
- `c_TxPwrCalTxEnaMask = 1, 0`  
Tx0 is calibrated with backoff from `c_CalTxBackOffSel[0]` with Tx1 disabled  
Tx1 will not be calibrated (results will not be updated either)  
This mode is recommended if only Tx0 is being used

#### ► `xc_CalTempBinOverrides`

TX temperature override values.

This field is valid if `M_RL_FECSS_CAL_TX_CAL_TEMP_OVERRIDE` bit is set in `c_MiscCalCtrl`.

#### Response Fields

#### ► `h_CalRunStatus`

Status for the current calibration trigger.

This mask indicates pass/ fail status for all the calibrations in the current trigger.

| Value | Definition |
|-------|------------|
| 0x0   | FAIL       |
| 0x1   | PASS       |

Bit field definition:

| Bit Field   | Definition                  |
|-------------|-----------------------------|
| bits [0]    | RESERVED                    |
| bits [1]    | VCO calibration status      |
| bits [2]    | PD calibration status       |
| bits [3]    | LODIST calibration status   |
| bits [4]    | RESERVED                    |
| bits [5]    | RX IFA calibration status   |
| bits [6]    | RX Gain calibration status  |
| bits [7]    | TX power calibration status |
| bits [15:8] | Reserved                    |

#### ► h\_CalResStatus

Calibration data validity status.

This mask indicates the validity of calibration data in `T_RL_API_FECSS_FACT_CAL_DATA`. This mask could remain set even after the corresponding calibration fails in a current run because mmWaveLink calibration APIs retain the previous calibration data in case of failure.

| Value | Definition                             |
|-------|----------------------------------------|
| 0x0   | INVALID - Calibration data is invalid. |
| 0x1   | VALID - Calibration data is valid.     |

Bit field definition:

| Bit Field   | Definition                           |
|-------------|--------------------------------------|
| bits [0]    | APLL calibration validity status     |
| bits [1]    | VCO calibration validity status      |
| bits [2]    | PD calibration validity status       |
| bits [3]    | LODIST calibration validity status   |
| bits [4]    | RESERVED                             |
| bits [5]    | RX IFA calibration validity status   |
| bits [6]    | RX Gain calibration validity status  |
| bits [7]    | TX power calibration validity status |
| bits [15:8] | Reserved                             |

► **xc\_CalibTemp**

The device temperature at which calibration is executed.

1LSB =  $2^{\circ}\text{C}$

Range : -127 to 127 ( $-254^{\circ}\text{C}$  to  $254^{\circ}\text{C}$ )

### 2.3.6 FECSS RF Runtime Calibration API

The FECSS RF runtime calibration API configuration and trigger API. Runtime calibrations primarily compensates for the runtime variations like temperature. The calibration data is updated in the IPC memory directly and can be stored/ restored using the [FECSS Factory Calibration Data Get API](#) and [FECSS Factory Calibration Data Set API](#).

#### Assumptions

- APLL must be enabled before using [FECSS Device Clock Ctrl API](#)
- Tx and Rx channel configuration is set using [FECSS RF Power On Off API](#)
- Live monitor faults and loopbacks are disabled

#### API Definition

|                                    |                                            |
|------------------------------------|--------------------------------------------|
| <b>API Index</b>                   | 0x0008U                                    |
| <b>API Function Name</b>           | <code>rl_fecssRfRuntimeCal</code>          |
| <b>API Configuration Structure</b> | <code>T_RL_API_FECSS_RF_RUN_CAL_CMD</code> |
| <b>API Response Structure</b>      | <code>T_RL_API_FECSS_RF_RUN_CAL_RSP</code> |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
```

```
#define M_RL_API_ID_FECSS_RF_RUN_CAL ((UINT16)0x0008U)
// API Function Definition
T_RETURNTYPE rl_fecssRfRuntimeCal(UINT8 c_devIndex, const T_RL_API_FECSS_RF_RUN_CAL_CMD
→ *p_apiCmdData, T_RL_API_FECSS_RF_RUN_CAL_RSP* p_apiResData);
```

► Configuration C Structure

**Table 2.16:** T\_RL\_API\_FECSS\_RF\_RUN\_CAL\_CMD

| Field            | Data Type | Size | Offset |
|------------------|-----------|------|--------|
| h_CalCtrlBitMask | UINT16    | 2    | 0      |
| h_Reserve0       | UINT16    | 2    | 2      |
| c_TempBinIndex   | UINT8     | 1    | 4      |
| c_Reserve1       | UINT8     | 1    | 5      |
| h_Reserve2       | UINT16    | 2    | 6      |
| w_Reserve3       | UINT32    | 4    | 8      |
| w_Reserve4       | UINT32    | 4    | 12     |
| w_Reserve5       | UINT32    | 4    | 16     |
| Total            |           |      | 20     |

► Response C Structure

**Table 2.17:** T\_RL\_API\_FECSS\_RF\_RUN\_CAL\_RSP

| Field          | Data Type | Size | Offset |
|----------------|-----------|------|--------|
| h_CalRunStatus | UINT16    | 2    | 0      |
| h_CalResStatus | UINT16    | 2    | 2      |
| w_Reserve1     | UINT32    | 4    | 4      |
| w_Reserve4     | UINT32    | 4    | 8      |
| Total          |           |      | 12     |

### Configuration Fields

► h\_CalCtrlBitMask

FECSS RFS runtime calibration control, 1 bit per channel.

Bit-definitions for the fields are as follows:

| Bit Field(s) | Definition                                                                                                                                                       |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bits[0]      | Reserved                                                                                                                                                         |
| bits[1]      | VCO calibration ON/OFF control.                                                                                                                                  |
| bits[2]      | PD calibration ON/OFF control.<br>Enable this calibration only if any PD measurement is done in runtime (TX power and ball break monitors, Tx CLPC calibration). |
| bits[3]      | LODIST calibration ON/OFF control.<br>The LODIST_BIAS_CODES are updated to HW based on <a href="#">c_TempBinIndex</a> .                                          |
| bits[4]      | Reserved                                                                                                                                                         |
| bits[5]      | Reserved                                                                                                                                                         |
| bits[6]      | RX Gain calibration ON/OFF control.<br>The <a href="#">c_CalRxGainCodes</a> are applied to HW based on <a href="#">c_TempBinIndex</a> .                          |
| bits[7]      | TX power OLPC calibration ON/OFF control.<br>The <a href="#">h_CalTxBiasCodes</a> are applied to HW based on <a href="#">c_TempBinIndex</a> .                    |
| bits[15:8]   | Reserved                                                                                                                                                         |

► [c\\_TempBinIndex](#)

FECSS RF calibration temperature bin index.

The application should read the device temperature using [FECSS Temperature Measurement Trigger API](#) and provide the bin index during the calibration. Bit-definitions for the field are as follows:

| Value(s) | Definition                                                                          |
|----------|-------------------------------------------------------------------------------------|
| 0x0      | LOW , The Device temperature is < 0°C (Default Target Temperature: -20°C)           |
| 0x8      | MID, The Device temperature is >= 0°C and < 85°C (Default Target Temperature: 42°C) |
| 0x10     | HIGH, The Device temperature is >= 85°C (Default Target Temperature: 105°C)         |

### Response Fields

► [h\\_CalRunStatus](#)

FECSS RFS runtime calibration run status, 1 bit per calibration.

This is a status of the current calibration command trigger.

| Value(s) | Definition                                                               |
|----------|--------------------------------------------------------------------------|
| 0x0      | FAIL - Calibration trigger is disabled / Enabled calibration has failed. |
| 0x1      | PASS - Enabled calibration has Passed.                                   |

Bit-definitions are as follows:

| Bit Field(s) | Definition                   |
|--------------|------------------------------|
| bits[0]      | Reserved                     |
| bits[1]      | VCO calibration status.      |
| bits[2]      | PD calibration status.       |
| bits[3]      | LODIST calibration status.   |
| bits[4]      | Reserved                     |
| bits[5]      | Reserved                     |
| bits[6]      | RX Gain calibration status.  |
| bits[7]      | TX power calibration status. |
| bits[15:8]   | Reserved                     |

► `h_CalResStatus`

FECSS RFS run-time calibration result validity status, 1 bit per calibration. This is the latest validity status of all the calibrations. The previous validity status is retained if latest calibration trigger fails.

| Value(s) | Definition                             |
|----------|----------------------------------------|
| 0x0      | INVALID - calibration data is invalid. |
| 0x1      | VALID - calibration data is valid.     |

Bit-definitions are as follows:

| Bit Field(s) | Definition                                                               |
|--------------|--------------------------------------------------------------------------|
| bits[0]      | APLL calibration validity status.Updates status of APPLL calibration.    |
| bits[1]      | VCO calibration validity status.                                         |
| bits[2]      | PD calibration validity status.                                          |
| bits[3]      | LODIST calibration validity status.                                      |
| bits[4]      | Reserved                                                                 |
| bits[5]      | RX IFA calibration validity status.Updates status of RX IFA calibration. |
| bits[6]      | RX Gain calibration validity status.                                     |
| bits[7]      | TX power calibration validity status.                                    |
| bits[15:8]   | Reserved                                                                 |

### 2.3.7 FECSS RF Clock Bandwidth Configuration API

This API controls bandwidth for APPLL and Synth clock modules.

**warning** The firmware does not store the bandwidth control settings and applies the default values after every boot. If required, application should re configure the bandwidth control settings after [FECSS Device Power On API](#) and before [FECSS Device Clock Ctrl API](#) API.

Default values for the bandwidth controls are as follows:

| Parameter       | xWRL6432  |       | xWRL1432 |           |
|-----------------|-----------|-------|----------|-----------|
| c_SynthIcpTrim  | 0x5       |       | 0x1      |           |
| c_SynthRzTrim   | 0x4       |       | 0x4      |           |
| c_ApllIcpTrim   | XTAL_FREQ | Value |          | XTAL_FREQ |
|                 | 25 MHz    | 0x12  |          | 25 MHz    |
|                 | 26 MHz    | 0x12  |          | 26 MHz    |
|                 | 38.4 MHz  | 0x1C  |          | 38.4 MHz  |
|                 | 40 MHz    | 0x1C  |          | 40 MHz    |
| c_ApllRzTrim    | 0x11      |       | 0x11     |           |
| c_ApllVcoRtrim  | 0x0C      |       | 0x12     |           |
| Synth Bandwidth | 1.2MHz    |       | 900Hz    |           |
| APLL Bandwidth  | 250kHz    |       | 250kHz   |           |

## API Definition

|                             |                                               |
|-----------------------------|-----------------------------------------------|
| API Index                   | 0x0009U                                       |
| API Function Name           | rl_fecssRfClockBwCfg                          |
| API Configuration Structure | <a href="#">T_RL_API_FECSS_CLK_BW_CFG_CMD</a> |
| API Response Structure      | None                                          |

## ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RF_CLKBW_CFG ((UINT16)0x0009U)
// API Function Definition
T_RETURNTYPE rl_fecssRfClockBwCfg(UINT8 c_devIndex, const T_RL_API_FECSS_CLK_BW_CFG_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.18:** T\_RL\_API\_FECSS\_CLK\_BW\_CFG\_CMD

| Field          | Data Type | Size      | Offset |
|----------------|-----------|-----------|--------|
| c_SynthIcpTrim | UINT8     | 1         | 0      |
| c_SynthRzTrim  | UINT8     | 1         | 1      |
| c_ApllIcpTrim  | UINT8     | 1         | 2      |
| c_ApllRzTrim   | UINT8     | 1         | 3      |
| c_ApllVcoRtrim | UINT8     | 1         | 4      |
| c_Reserved1    | UINT8     | 1         | 5      |
| c_Reserved2    | UINT8     | 1         | 6      |
| c_Reserved3    | UINT8     | 1         | 7      |
| w_Reserved4    | UINT32    | 4         | 8      |
| w_Reserved5    | UINT32    | 4         | 12     |
| Total          |           | <b>16</b> |        |

### Configuration Fields

► c\_SynthIcpTrim

FECSS device RF synth clock ICP trim value.

► c\_SynthRzTrim

FECSS device RF synth clock RZ trim value.

► c\_ApllIcpTrim

FECSS device RF APLL clock ICP trim value.

► c\_ApllRzTrim

FECSS device RF APLL clock RZ LPF trim value.

► c\_ApllVcoRtrim

FECSS device RF APLL clock VCO RTrim value.

### 2.3.8 FECSS GPADC Measurement Configuration API

This API configures GPADC channels to measure the DC signals. GPADC signals are configured using a combination of Param Value and Config Value. The API supports multiple channels which can be enabled/disabled individually. The [FECSS GPADC Measurement Trigger API](#) uses these settings to measure the desired signals.

**Note** Configurations are stored in the FECSS IPC memory and retained if memory retention is enabled in [FECSS Device Power OFF API](#).

GPADC Signals Config and Param Values:

| GPADC signal                         | Param Value                                                                                           | Config Value |
|--------------------------------------|-------------------------------------------------------------------------------------------------------|--------------|
| External GPADC signal 1 buffered     | CHAN_CTRL = 124,<br>NUM_MEAS = 4,<br>SKIP_SAMPLES = 10,<br>SIG_TYPE = 1,<br>OFFSET = 0,<br>ENABLE = 1 | 0x00200000   |
| External GPADC signal 1 non-buffered | CHAN_CTRL = 124,<br>NUM_MEAS = 4,<br>SKIP_SAMPLES = 10,<br>SIG_TYPE = 2,<br>OFFSET = 0,<br>ENABLE = 1 | 0x00008000   |
| External GPADC signal 2 buffered     | CHAN_CTRL = 124,<br>NUM_MEAS = 4,<br>SKIP_SAMPLES = 10,<br>SIG_TYPE = 1,<br>OFFSET = 0,<br>ENABLE = 1 | 0x00010000   |
| External GPADC signal 2 non-buffered | CHAN_CTRL = 124,<br>NUM_MEAS = 4,<br>SKIP_SAMPLES = 10,<br>SIG_TYPE = 2,<br>OFFSET = 0,<br>ENABLE = 1 | 0x00004000   |

#### API Definition

|                                    |                                               |
|------------------------------------|-----------------------------------------------|
| <b>API Index</b>                   | 0x000AU                                       |
| <b>API Function Name</b>           | rl_fecssGpadcMeasCfg                          |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_FECSS_GPADC_MEAS_CMD</a> |
| <b>API Response Structure</b>      | None                                          |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_GPADC_MEAS_CFG           ((UINT16)0x000AU)
// API Function Definition
T_RETURNTYPE rl_fecssGpadcMeasCfg(UINT8 c_devIndex, const T_RL_API_FECSS_GPADC_MEAS_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.19:** T\_RL\_API\_FECSS\_GPADC\_MEAS\_CMD

| Field       | Data Type | Size | Offset |
|-------------|-----------|------|--------|
| w_ParamVal  | UINT32[8] | 32   | 0      |
| w_ConfigVal | UINT32[8] | 32   | 32     |
| w_Reserved1 | UINT32    | 4    | 64     |
| w_Reserved2 | UINT32    | 4    | 68     |
| Total       |           | 72   |        |

Configuration Fields

► w\_ParamVal

FECSS GPADC channel param value, 32bit value per channel. The param value is a unique value includes, channel control , num of collect and skip samples for internal or external signals to measure the corresponding signal in any GPADC channel.

Bit field definition:

| Field Name   | Bits       | Definition                                                                                                                                                                 |
|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHANNEL_CTRL | bits [7:0] | GPADC channel control value, 8bit value per channel.<br>The control value is a unique parameter value for a internal or external signal to link it with the GPADC channel. |

|                 |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COLLECT_SAMPLES | bits [15:8]  | <p>This setting can be used to measure average value of the signal across multiple samples.</p> <ul style="list-style-type: none"> <li>• 1LSB = 1 collect sample<br/>Overall measurement time is <math>(COLLECT\_SAMPLES * GPADC Collect Sample Period)</math></li> <li>• <u>Range:</u> 0 to 255</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SKIP_SAMPLES    | Bit[22:16]   | <p>Clock cycles skipped before the measurement</p> <ul style="list-style-type: none"> <li>• Total skip samples is computed as <math>Mantissa \times 2^{Exponent}</math></li> <li>• where Mantissa = SKIP_SAMPLES[3:0] and Exponent = SKIP_SAMPLES[6:4]</li> <li>• <u>Recommendation:</u> 10</li> </ul> <p>Bit-Field definition:</p> <ul style="list-style-type: none"> <li>• Bits[3:0]: 1LSB = 1 skip sample (Mantissa)</li> <li>• <u>Valid Values:</u> 0</li> <li>• <u>skip samples:</u> 0 to 15</li> <li>• Bits[6:4]: <math>1LSB = 2^N skipsamples(Exponent)</math></li> <li>• <u>Range:</u> 0 to 7</li> <li>• <u>skip samples:</u> 1 to 128</li> <li>• 1 skip sample period = Time period of operating clock frequency</li> </ul> |
| Reserved        | bits [23]    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SIGNAL_TYPE     | bits [26:24] | GPADC signal type, 3 bits value. The GPADC measurement signal type should be appropriately selected to configure the analog and to get accurate measurement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| BUFFER_OFFSET   | Bit[29:27]   | GPADC buffer offset type index, 3 bits value. The GPADC buffer offset index type should be appropriately selected to add device process specific offset to the measurement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Reserved        | bits [30]    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| CHANNEL_EN      | bits [31]    | GPADC channel ON/OFF control, 1 bit control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

The GPADC measurement channel enable control:

| Value | Definition |
|-------|------------|
| 0x0   | OFF        |
| 0x1   | ON         |

The GPADC collect sample period definition:

| XTAL clock Source | GPADC Operating Clock | 1LSB collect sample Period |
|-------------------|-----------------------|----------------------------|
| 25MHz             | 12.5MHz               | 1.28us                     |
| 26MHz             | 13MHz                 | 1.231us                    |
| 38.4MHz           | 12.8MHz               | 1.25us                     |
| 40MHz             | 13.3MHz               | 1.203us                    |

The GPADC skip sample period definition:

| XTAL clock Source | GPADC Operating Clock | 1LSB skip sample Period |
|-------------------|-----------------------|-------------------------|
| 25MHz             | 12.5MHz               | 80ns                    |
| 26MHz             | 13MHz                 | 76.92ns                 |
| 38.4MHz           | 12.8MHz               | 78.125ns                |
| 40MHz             | 13.3MHz               | 75.19ns                 |

The GPADC Signal types:

| Value | Definition                             |
|-------|----------------------------------------|
| 0     | Internal Buffered Signal               |
| 1     | External Buffered Signal               |
| 2     | External Non-Buffered Signal           |
| 3     | Temperature Sensor Differential Signal |
| 4     | Temperature Sensor Single Ended Signal |
| 7-5   | Reserved                               |

The GPADC buffer offset index types:

| Value | Definition          |
|-------|---------------------|
| 0     | NO Offset (Default) |
| 1     | RX Offset           |
| 2     | TX Offset           |
| 3     | CLK Offset          |
| 4     | PM Offset           |
| 7-5   | Reserved            |

#### ► w\_ConfigVal

FECSS GPADC channel config value, 32bit value per channel. Max 8 GPADC signals supported. The config value is a unique value for a internal or external signal to configure and measure the corresponding signal in any

GPADC channel.

### 2.3.9 FECSS GPADC Measurement Trigger API

This API triggers GPADC measurements for the signals configured using the [FECSS GPADC Measurement Configuration API](#).

**Note** FECSS must be in power-on state to trigger GPADC measurement

#### API Definition

|                                    |                               |
|------------------------------------|-------------------------------|
| <b>API Index</b>                   | 0x000BU                       |
| <b>API Function Name</b>           | rl_fecssGpadcMeasTrig         |
| <b>API Configuration Structure</b> | None                          |
| <b>API Response Structure</b>      | T_RL_API_FECSS_GPADC_MEAS_RSP |

#### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_GPADC_MEAS_TRIG ((UINT16)0x000BU)
// API Function Definition
T_RETURNTYPE rl_fecssGpadcMeasTrig(UINT8 c_devIndex, T_RL_API_FECSS_GPADC_MEAS_RSP
→ *p_apiResData);
```

#### ► Response C Structure

**Table 2.21:** T\_RL\_API\_FECSS\_GPADC\_MEAS\_RSP

| Field             | Data Type | Size | Offset |
|-------------------|-----------|------|--------|
| c_GadcChRunStatus | UINT8     | 1    | 0      |
| c_Reserve1        | UINT8     | 1    | 1      |
| h_Reserve2        | UINT16    | 2    | 2      |
| c_GadcMeasVal     | UINT8[8]  | 8    | 4      |
| w_Reserve3        | UINT32    | 4    | 12     |
| w_Reserve4        | UINT32    | 4    | 16     |
| Total             |           |      | 20     |

#### Response Fields

##### ► c\_GadcChRunStatus

**Note** Max 8 GPADC signal channels supported.

| Value | Definition                               |
|-------|------------------------------------------|
| 0x0   | FAIL (Enabled GPADC channel has failed.) |
| 0x1   | PASS (Enabled GPADC channel has Passed.) |

Bit field definition:

| Bit Field | Definition             |
|-----------|------------------------|
| bits [0]  | GPADC channel 0 status |
| bits [1]  | GPADC channel 1 status |
| bits [2]  | GPADC channel 2 status |
| bits [3]  | GPADC channel 3 status |
| bits [4]  | GPADC channel 4 status |
| bits [5]  | GPADC channel 5 status |
| bits [6]  | GPADC channel 6 status |
| bits [7]  | GPADC channel 7 status |

► `c_GpadcMeasVal`

FECSS GPADC measurement average value: 1 LSB = 1.8V / 256.

### 2.3.10 FECSS Temperature Measurement Config API

This API configures on-chip temperature sensor measurements. The [FECSS Temperature Measurement Trigger API](#) uses these settings to measure the desired temperature sensors.

**Note** Configurations are stored in the FECSS IPC memory and retained if memory retention is enabled in [FECSS Device Power OFF API](#).

#### API Definition

|                                    |                                                           |
|------------------------------------|-----------------------------------------------------------|
| <b>API Index</b>                   | 0x000CU                                                   |
| <b>API Function Name</b>           | <code>rl_fecssTempMeasCfg</code>                          |
| <b>API Configuration Structure</b> | <a href="#"><code>T_RL_API_FECSS_TEMP_MEAS_CMD</code></a> |
| <b>API Response Structure</b>      | None                                                      |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_TEMP_MEAS_CFG ((UINT16)0x000CU)
// API Function Definition
```

```
T_RETURNTYPE rl_fecssTempMeasCfg(UINT8 c_devIndex, const T_RL_API_FECSS_TEMP_MEAS_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.22:** T\_RL\_API\_FECSS\_TEMP\_MEAS\_CMD

| Field             | Data Type | Size     | Offset |
|-------------------|-----------|----------|--------|
| h_TempCtrlBitMask | UINT16    | 2        | 0      |
| h_Reserved1       | UINT16    | 2        | 2      |
| w_Reserved2       | UINT32    | 4        | 4      |
| Total             |           | <b>8</b> |        |

### Configuration Fields

► h\_TempCtrlBitMask

FECSS RFS temperature measurement control, 1 bit per channel.

**Notes** Max 4 temperature sensors supported in this device.

| Value | Definition |
|-------|------------|
| 0x0   | OFF        |
| 0x1   | ON         |

Bit field definition:

| Bit Field    | Definition                            |
|--------------|---------------------------------------|
| bits [0]     | RX temperature sensor ON/OFF control  |
| bits [1]     | Reserved                              |
| bits [2]     | Reserved                              |
| bits [3]     | Reserved                              |
| bits [4]     | TX temperature sensor ON/OFF control  |
| bits [5]     | Reserved                              |
| bits [6]     | Reserved                              |
| bits [7]     | Reserved                              |
| bits [8]     | PM temperature sensor ON/OFF control  |
| bits [9]     | DIG temperature sensor ON/OFF control |
| bits [15:10] | Reserved                              |

### 2.3.11 FECSS Temperature Measurement Trigger API

This API triggers temperature sensor measurements configured using the [FECSS Temperature Measurement Config API](#).

#### API Definition

|                                    |                              |
|------------------------------------|------------------------------|
| <b>API Index</b>                   | 0x000DU                      |
| <b>API Function Name</b>           | rl_fecssTempMeasTrig         |
| <b>API Configuration Structure</b> | None                         |
| <b>API Response Structure</b>      | T_RL_API_FECSS_TEMP_MEAS_RSP |

#### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_TEMP_MEAS_TRIG ((UINT16)0x000DU)
// API Function Definition
T_RETURNTYPE rl_fecssTempMeasTrig(UINT8 c_devIndex, T_RL_API_FECSS_TEMP_MEAS_RSP
→ *p_apiResData);
```

#### ► Response C Structure

Table 2.23: T\_RL\_API\_FECSS\_TEMP\_MEAS\_RSP

| Field            | Data Type  | Size      | Offset |
|------------------|------------|-----------|--------|
| h_TempStsBitMask | UINT16     | 2         | 0      |
| h_Reserve1       | UINT16     | 2         | 2      |
| xh_TempValue     | SINT16[10] | 20        | 4      |
| w_Reserve2       | UINT32     | 4         | 24     |
| Total            |            | <b>28</b> |        |

#### Response Fields

##### ► h\_TempStsBitMask

FECSS RFS temperature measurement status, 1 bit per channel.

**Notes** Max 4 temperature sensors supported in this device.

| Value | Definition                                                |
|-------|-----------------------------------------------------------|
| 0x0   | FAIL (Enabled temperature sensor measurement has failed.) |
| 0x1   | PASS (Enabled temperature sensor measurement has passed.) |

Bit field definition:

| Bit Field    | Definition                    |
|--------------|-------------------------------|
| bits [0]     | RX temperature sensor status  |
| bits [1]     | Reserved                      |
| bits [2]     | Reserved                      |
| bits [3]     | Reserved                      |
| bits [4]     | TX temperature sensor status  |
| bits [5]     | Reserved                      |
| bits [6]     | Reserved                      |
| bits [7]     | Reserved                      |
| bits [8]     | PM temperature sensor status  |
| bits [9]     | DIG temperature sensor status |
| bits [15:10] | Reserved                      |

► `xh_TempValue`

FECSS RFS temperature measured value, 1LSB =  $1^{\circ}\text{C}$  signed.

### 2.3.12 FECSS Factory Calibration Data Get API

This API is used to store complete calibration data to flash or external memory. This is an optional API which can be used in the following scenarios:

- Store the TI factory calibration data in external flash during early evaluation.
- Use cases which do not retain FECSS memory during sleep and performs always perform cold boot for FECSS. This API can be used to store the latest calibration data and avoid re-running of all the factory and runtime calibrations including APLL.

#### API Definition

|                                    |                                           |
|------------------------------------|-------------------------------------------|
| <b>API Index</b>                   | 0x000EU                                   |
| <b>API Function Name</b>           | <code>rl_fecssRfFactoryCalDataGet</code>  |
| <b>API Configuration Structure</b> | None                                      |
| <b>API Response Structure</b>      | <code>T_RL_API_FECSS_FACT_CAL_DATA</code> |

► **API Function**

mmWaveLink C function declaration

```

// API Index Macro
#define M_RL_API_ID_FECSS_FACTORY_CAL_DATA_GET ((UINT16)0x000EU)
// API Function Definition
T_RETURNTYPE r1_fecssRfFactoryCalDataGet(UINT8 c_devIndex, T_RL_API_FECSS_FACT_CAL_DATA
→ *p_apiResData);

```

### 2.3.13 FECSS Factory Calibration Data Set API

This API is used to re-store complete calibration data from flash or external memory. This is an optional API which can be used in the following scenarios:

- Restore the TI factory calibration data from external flash during early evaluation.
- Use cases which do not retain FECSS memory during sleep and performs always perform cold boot for FECSS. This API can be used to restore the latest calibration data and avoid re-running of all the factory and runtime calibrations including APLL.

#### API Definition

|                                    |                              |
|------------------------------------|------------------------------|
| <b>API Index</b>                   | 0x000FU                      |
| <b>API Function Name</b>           | r1_fecssRfFactoryCalDataSet  |
| <b>API Configuration Structure</b> | T_RL_API_FECSS_FACT_CAL_DATA |
| <b>API Response Structure</b>      | None                         |

#### ► API Function

mmWaveLink C function declaration

```

// API Index Macro
#define M_RL_API_ID_FECSS_FACTORY_CAL_DATA_SET ((UINT16)0x000FU)
// API Function Definition
T_RETURNTYPE r1_fecssRfFactoryCalDataSet(UINT8 c_devIndex, const T_RL_API_FECSS_FACT_CAL_DATA
→ *p_apiCmdData);

```

► Configuration C Structure

**Table 2.24:** T\_RL\_API\_FECSS\_FACT\_CAL\_DATA

| Field            | Data Type                    | Size       | Offset |
|------------------|------------------------------|------------|--------|
| h_CalResValidity | UINT16                       | 2          | 0      |
| h_CalResValRed   | UINT16                       | 2          | 2      |
| w_ApllCapCodes   | UINT32                       | 4          | 4      |
| h_SynthCapCodes  | UINT16                       | 2          | 8      |
| h_IfaTrimCodes   | UINT16                       | 2          | 10     |
| h_Reserved0      | UINT16                       | 2          | 12     |
| h_PdFactCalTemp  | UINT16                       | 2          | 14     |
| c_PdCalCodes     | UINT8[76]                    | 76         | 16     |
| z_RxTxCalData    | T_RL_API_FECSS_RXTX_CAL_DATA | 36         | 92     |
| Total            |                              | <b>128</b> |        |

### Configuration Fields

► h\_CalResValidity

FECSS RFS factory calibration result validity status, 1 bit per calibration.

Latest validity status of all the calibrations.

| Value | Definition                             |
|-------|----------------------------------------|
| 0x0   | INVALID - Calibration data is invalid. |
| 0x1   | VALID - Calibration data is valid.     |

Bit field definition:

| Bit Field   | Definition                           |
|-------------|--------------------------------------|
| bits [0]    | APLL calibration validity status     |
| bits [1]    | VCO calibration validity status      |
| bits [2]    | PD calibration validity status       |
| bits [3]    | LODIST calibration validity status   |
| bits [4]    | RESERVED                             |
| bits [5]    | RX IFA calibration validity status   |
| bits [6]    | RX Gain calibration validity status  |
| bits [7]    | TX power calibration validity status |
| bits [15:8] | Reserved                             |

► `h_CalResValRed`

FECSS RFS factory calibration result validity status redundancy.

► `w_ApllCapCodes`

FECSS RFS APLL calibrated cap codes

► `h_SynthCapCodes`

FECSS RFS SYNTH calibrated cap codes.

► `h_IfaTrimCodes`

FECSS RFS IFA calibrated trim codes.

► `h_PdFactCalTemp`

FECSS PD β-DC Calibration Temperature

► `c_PdCalCodes`

FECSS RFS PD calibrated codes. Total 76 bytes

► `z_RxTxCalData`

FECSS RFS RX-TX calibration data. Total 36 bytes. Please refer [T\\_RL\\_API\\_FECSS\\_RXTX\\_CAL\\_DATA](#) for details.

### 2.3.14 FECSS Device Clock Ctrl API

This API function configures the device clock source selection setting. The application can use this API to switch the FECSS clock source based on device power state.

#### API Definition

|                                    |                                                 |
|------------------------------------|-------------------------------------------------|
| <b>API Index</b>                   | 0x0010U                                         |
| <b>API Function Name</b>           | <code>r1_fecssDevClockCtrl</code>               |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_FECSS_DEV_CLK_CTRL_CMD</a> |
| <b>API Response Structure</b>      | None                                            |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_DEV_CLK_CTRL ((UINT16)0x0010U)
// API Function Definition
T_RETURNTYPE rl_fecssDevClockCtrl(UINT8 c_devIndex, const T_RL_API_FECSS_DEV_CLK_CTRL_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.25:** T\_RL\_API\_FECSS\_DEV\_CLK\_CTRL\_CMD

| Field         | Data Type | Size | Offset |
|---------------|-----------|------|--------|
| c_DevClkCtrl  | UINT8     | 1    | 0      |
| c_FtClkCtrl   | UINT8     | 1    | 1      |
| c_ApllClkCtrl | UINT8     | 1    | 2      |
| c_Reserved1   | UINT8     | 1    | 3      |
| w_Reserved2   | UINT32    | 4    | 4      |
| Total         |           | 8    |        |

### Configuration Fields

► c\_DevClkCtrl

FECSS run time core clock source selection type.

The application can switch the clock source of FECSS based on power state to XTAL clock or Fast clock or can gate the FECSS system clock.

**Recommendation** FECSS clock state:

- XTAL Clock - Short idle time.
- Fast Clock - Data acquisition mode, calibration or monitoring.
- Clock Gate - Long frame idle time.

This API configures FECSS clock based on this setting.

| Value | Definition                                                                                                                         | mmWaveLink Macro            |
|-------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x00  | XTAL clock source.<br>Application can switch FECSS to the XTAL clock (XTAL_FREQ) in short idle period when FECSS is in idle state. | M_RL_FECSS_DEV_CLK_SRC_XTAL |
| 0x0A  | Fast clock source<br>Fast clock is derived from (DIG_PLL_FREQ/2)                                                                   | M_RL_FECSS_DEV_CLK_SRC_FCLK |
| 0x05  | Clock gate (OFF)<br>The application can gate FECSS clock in inter-frame idle time.                                                 | M_RL_FECSS_DEV_CLK_SRC_OFF  |

► **c\_FtClkCtrl**

FECSS frame timer (FT) clock gate option. The application can gate the FT clock source based on low power state.

**Recommendation** The frame timer always runs on XTAL clock.

- XTAL Clock - Normal operating mode
- Clock Gate - Device idle time (NOT frame idle time)

This API configures FECSS clock based on this setting.

| Value | Definition                                                                                                                                                   | mmWaveLink Macro           |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| 0x00  | XTAL clock source<br>Default operating frequency. Supported clock Frequencies are: 25MHz, 26MHz, 38.4MHz or 40MHz.                                           | M_RL_FECSS_FT_CLK_SRC_XTAL |
| 0x05  | Clock gate (OFF)<br>The FECSS Frame Timer clock can be gated using this option. The application can gate FT clock in device idle state and FT is not active. | M_RL_FECSS_FT_CLK_SRC_OFF  |

► **c\_ApllClkCtrl**

FECSS RF APLL clock block ON / OFF control.

**Warning** The APLL must be ON before:

- [FECSS Factory Calibration API](#)
- [FECSS RF Runtime Calibration API](#)
- [FECSS Monitor Enable Trigger API](#)
- [Sensor Start API](#)

Please refer sequences for more details.

| Value | Definition                                                                                                                                                                                                                                                                                                                                                                                                                         | mmWaveLink Macro            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x00  | <p>Turn OFF APLL clock.</p> <p>Turn OFF APLL before entering deep sleep or APLL functionality is not needed by HOST.</p> <p>Typical use case : After data processing of a frame.</p>                                                                                                                                                                                                                                               | M_RL_FECSS_APLL_CTRL_OFF    |
| 0x0A  | <p>Turn ON APLL clock.</p> <p>Use this ON mode in typical APLL ON after deep sleep exit or whenever APLL functionality is needed by HOST.</p> <p>Typical use case: After deep sleep exit or before analog / sensor functionalities turn ON.</p>                                                                                                                                                                                    | M_RL_FECSS_APLL_CTRL_ON     |
| 0xAA  | <p>Calibrate and turn ON APLL clock.</p> <p>This ON mode should be used in following cases:</p> <ul style="list-style-type: none"> <li>• Device is powered on after a long time. (Typically cold boot)</li> <li>• Significant temperature difference between subsequent boot cycles.</li> <li>• Whenever APLL block needs calibrations.</li> </ul> <p>This API turns the APLL off and returns error code if calibration fails.</p> | M_RL_FECSS_APLL_CTRL_ON_CAL |

### 2.3.15 FECSS Device RDIF Control API

This API is used for RDIF block configuration and enable/disable control.

The application can use this API to collect the radar Data over CMOS interface pins.

- Max 3 channels are supported in RDIF, which are mapped to the 3 RX channels of the sensor.
- it is possible to capture any one or two or all three of the DFE RX channels output.
- `h_RxChCtrlBitMask` is used to program the DFE RX channel enable which is mapped to RDIF channels.
- If less than 3 channels are enabled in DFE then only enabled channels will be mapped to lower RDIF channels without any holes.
- The max bits per sample supported is only 12 bits in RDIF, the number of bits and samples per chirp and per channel should match the DFE profile configuration.
- The DDR clock is 50MHz (APLL\_FREQ/8) and data is sampled at both raising and falling edge of DDR clock.
- The max data rate of RDIF is  $(50M \times 2 \times 4\text{DataLines}) = 400\text{Mbps}$
- The one frame clock duration is 12 DDR clock edges corresponds to 48bits.
- SATURATION\_CNT\_CH3 (sample 4), SATURATION\_CNT\_CH2 (sample 5) and SATURATION\_CNT\_CH1 (sample 6) - each 12b samples.

- In case of less number of enabled DFE channels, lower slots will have valid saturation count and upper slot will be padded with zeros.

#### Sideband Data Format:

The 96 bits (8 samples) sideband data can be appended at end of each chirp data (API enable). The side band data consists of the following information:

| Value                | Definition                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FRAME_CNT[11:0]      | 12bits, 1st sample.                                                                                                                                                                                                                                                                                                                                                                   |
| BURST_CNT[11:0]      | 12bits, 2nd sample.                                                                                                                                                                                                                                                                                                                                                                   |
| CHIRP_CNT[11:0]      | 12bits, 3rd sample.                                                                                                                                                                                                                                                                                                                                                                   |
| SATURATION_CNT[35:0] | 12b per channel, there are three fixed slots named as below: <ul style="list-style-type: none"> <li>• SATURATION_CNT_CH3 (sample 4), SATURATION_CNT_CH2 (sample 5) and SATURATION_CNT_CH1 (sample 6) - each 12b samples.</li> <li>• In case of less number of enabled DFE channels, lower slots will have valid saturation count and upper slot will be padded with zeros.</li> </ul> |
| CRC-16[23:0]         | 16 bits CRC [15:0], MSB 8 bits are padded with zeros.<br>(CRC is calculated for Chirp data + Sideband data) - sample 7 (LSB) and 8 (MSB).                                                                                                                                                                                                                                             |

#### CW Mode:

- In CW mode the DFE output samples will be sent out continuously for all the enabled channels.
- The max data rate supported is 400 Mbps. In case of max 3 enabled RX channels, the max DFE rate can be supported is 11.11 Mbps.
- The sideband data is not supported in CW mode.

#### API Definition

|                                    |                                           |
|------------------------------------|-------------------------------------------|
| <b>API Index</b>                   | 0x0011U                                   |
| <b>API Function Name</b>           | <code>r1_fecssDevRdifCtrl</code>          |
| <b>API Configuration Structure</b> | <code>T_RL_API_FECSS_RDIF_CTRL_CMD</code> |
| <b>API Response Structure</b>      | None                                      |

#### ► API Function

mmWaveLink C function declaration

► Configuration C Structure

**Table 2.26:** T\_RL\_API\_FECSS\_RDIF\_CTRL\_CMD

| Field               | Data Type | Size | Offset    |
|---------------------|-----------|------|-----------|
| c_RdifEnable        | UINT8     | 1    | 0         |
| c_RdifCfg           | UINT8     | 1    | 1         |
| h_RdifSampleCount   | UINT16    | 2    | 2         |
| c_TestPatternEn     | UINT8     | 1    | 4         |
| c_LaneRateCfg       | UINT8     | 1    | 5         |
| h_Reserve2          | UINT16    | 2    | 6         |
| h_TestPatrnInitCode | UINT16[4] | 8    | 8         |
| h_TestPatrnIncrCode | UINT16[4] | 8    | 16        |
| w_Reserve5          | UINT32    | 4    | 24        |
| Total               |           |      | <b>28</b> |

### Configuration Fields

► c\_RdifEnable

FECSS RDIF block ON / OFF control. This control should be used to reset and enable/disable the RDIF data transfer.

**Notes** RDIF IP always goes through reset in every ON command.

| Value | Definition               |
|-------|--------------------------|
| 0x00  | RDIF block is turned OFF |
| 0x0A  | RDIF block is turned ON  |

► c\_RdifCfg

FECSS RDIF configuration settings can be used to enable various modes of operation of the RDIF IP. This API configures RDIF based on below settings.

| Value | Definition |
|-------|------------|
| 0x0   | Disabled   |
| 0x1   | Enabled    |

Bit Definition:

| Bit Fields | Definition                                                                                                                                                                                                                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]     | <p>RDIF sideband data enable control.</p> <ul style="list-style-type: none"> <li>The 96 bits (8 samples) sideband data will be appended at end of each chirp data when this mode is enabled.</li> <li><b>Note:</b> FECSS Rx Saturation Live Monitor Configuration API must be enabled in <code>c_FrameLivMonEn</code> to receive sideband data</li> </ul>                                |
| Bit[1]     | <p>RDIF CW mode enable control.</p> <ul style="list-style-type: none"> <li>The 96 bits (8 samples) sideband data will be appended at end of each chirp data when this mode is enabled.</li> <li>In CW mode the DFE output samples will be sent out continuously for all the enabled channels at max rate of 400 Mbps.</li> <li>The sideband data is not supported in CW mode.</li> </ul> |
| Bit[3:2]   | <p>RDIF data swizzling mode enable control.</p> <ul style="list-style-type: none"> <li>The RDIF channel data and the side band sample 12 bits data swizzling mode.</li> </ul>                                                                                                                                                                                                            |
| Bit[4]     | <p>RDIF Scrambler Mode enable control</p> <p>Scrambler Polynomial: <math>1 = z^{-18} + z^{-23}</math></p>                                                                                                                                                                                                                                                                                |
| Bit[5]     | <p>Enable RDIF lane rate update.</p> <ul style="list-style-type: none"> <li>By default per lane data rate is set to max 100 Mbps.</li> <li>Max 400Mbps for 4 lanes.</li> <li>The lane rate can be updated if this bit is set using <code>RDIF_LANE_RATE</code>.</li> </ul>                                                                                                               |
| Bit[7:6]   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |

**Warning** Rx saturation monitor must be enabled to stream sideband data

**Recommendation** Scrambler should be enabled to avoid spurs during RDIF transmission

RDIF data swizzling mode control:

| Value | Definition            |
|-------|-----------------------|
| b00   | Pin0-bit0-Cycle1 Mode |
| b01   | Pin3-bit0-Cycle1 Mode |
| b10   | Pin0-bit0-Cycle3 Mode |
| b11   | Pin3-bit0-Cycle3 Mode |

► `h_RdifSampleCount`

FECSS RDIF number of samples per channel per chirp. This field should be exactly same as the `h_NumOfAdcSamples`. The config value should be a multiple of 4. This field does not include samples from sideband data.

**Notes**

- Variable chirp size is not supported. All the chirps will have the same size.
- It is not possible to send 512 samples in first chirp and 1024 samples in next chirp.
- Valid Range: 4 to 2048.

▶ **c\_TestPatternEn**

FECSS test pattern block ON / OFF control. This control should be used to enable or disable the test pattern in DFE. This test pattern can be used to validate the RDIF and Data path buffer.

| Value | Definition                        |
|-------|-----------------------------------|
| 0x0   | TEST_PATTERN block is turned OFF. |
| 0xA   | TEST_PATTERN block is turned ON.  |

▶ **c\_LaneRateCfg**

FECSS RDIF lane rate. The max lane rate supported 400 Mbps for 4 lanes (each lane max 100Mbps).

| Value | Definition |
|-------|------------|
| 0     | 400 Mbps   |
| 1     | 320 Mbps   |
| 2     | 200 Mbps   |
| 3     | 160 Mbps   |

**Notes**

- This configuration will be updated only if c\_RdifCfg[bit 5] is set.
- By default Lane rate is set to 400Mbps.
- $[RDIFLaneRate > (RxChannels - (1152/ADC Samples)) \times 12 - bits \times ADCSamplingRate]$

▶ **h\_TestPatrnInitCode**

RX channel [3:0] Test pattern init code. The offset value code to be used for the first sample of the test pattern data. RX3 is reserved.

▶ **h\_TestPatrnIncrCode**

RX channel [3:0] Test pattern increment code. The value to be added for each successive sample for the test pattern data. RX3 is reserved.

### 2.3.16 FECSS Device Status Get API

This API response returns FECSS power and clock status.

## API Definition

|                                    |                            |
|------------------------------------|----------------------------|
| <b>API Index</b>                   | 0x0012U                    |
| <b>API Function Name</b>           | rl_fecssDevStatusGet       |
| <b>API Configuration Structure</b> | None                       |
| <b>API Response Structure</b>      | T_RL_API_FECSS_DEV_STS_RSP |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID FECSS_DEV_STS_GET           ((UINT16)0x0012U)
// API Function Definition
T_RETURNTYPE rl_fecssDevStatusGet(UINT8 c_devIndex, T_RL_API_FECSS_DEV_STS_RSP
→ *p_apiResData);
```

### ► Response C Structure

**Table 2.27:** T\_RL\_API\_FECSS\_DEV\_STS\_RSP

| Field               | Data Type | Size | Offset |
|---------------------|-----------|------|--------|
| h_XtalClkFreq       | UINT16    | 2    | 0      |
| c_DevClkSrcState    | UINT8     | 1    | 2      |
| c_PowerModeState    | UINT8     | 1    | 3      |
| c_ChirpTimerResType | UINT8     | 1    | 4      |
| c_FtClkState        | UINT8     | 1    | 5      |
| c_RfsBootSelfTest   | UINT8     | 1    | 6      |
| c_Reserve1          | UINT8     | 1    | 7      |
| h_RfsFwState        | UINT16    | 2    | 8      |
| c_PatchAndSilEna    | UINT8     | 1    | 10     |
| c_RfAndSensType     | UINT8     | 1    | 11     |
| w_Reserve2          | UINT32    | 4    | 12     |
| w_Reserve3          | UINT32    | 4    | 16     |
| Total               |           | 20   |        |

## Response Fields

### ► h\_XtalClkFreq

FECSS configures device XTAL clock frequency if `c_DevClkCtrl1` =0x00. This value should match the application programmed value. Unit - 1LSB = 1/256 MHz Typical values are: 6400, 6656, 9830 and 10240

► `c_DevClkSrcState`

FECSS clock source state.

Valid configurations are as below:

| Value | Definition                                                                           |
|-------|--------------------------------------------------------------------------------------|
| 0x00  | XTAL clock source.<br>Clock Frequency: 25MHz, 26MHz, 38.4MHz or 40MHz<br>(XTAL_FREQ) |
| 0x0A  | Fast clock source.<br>Clock Frequency: 80MHz (DIG_PLL_FREQ/2).                       |

► `c_PowerModeState`

FECSS `c_PowerMode` type.

► `c_ChirpTimerResType`

The RF start frequency resolution and timing related chirp parameters resolution selection. Please refer it to `c_ChirpTimerResol`

► `c_FtClkState`

FECSS frame timer clock source type. Please refer it to `c_FtClkCtrl`

► `c_RfsBootSelfTest`

RFS core IP boot self test status.

| Value | Definition  |
|-------|-------------|
| 0     | Test Failed |
| 1     | Test Passed |

Bit Field Definition:

| Bit Field | Definition                           |
|-----------|--------------------------------------|
| Bit[0]    | Self test status of RFS M3 core MPU. |
| Bit[1]    | Self test status of RFS BIST FFT IP. |
| Bit[2]    | Self test status of RFS GPADC IP.    |
| Bit[7:3]  | Reserved                             |

► `h_RfsFwState`

RFS FW State.

| Value  | Definition    |
|--------|---------------|
| 0x0000 | Halt          |
| 0x4004 | Booting       |
| 0x8008 | Idle          |
| 0xFFFF | Fault         |
| Cmd Id | API Execution |

► `c_PatchAndSilEna`

RFS patch status in lower nibble:

| Value | Definition |
|-------|------------|
| 0x0   | Disabled   |
| 0xA   | Enabled    |

RFS SIL status in upper nibble:

| Value | Definition |
|-------|------------|
| 0x0   | Disabled   |
| 0xA   | Enabled    |

► `c_RfAndSensType`

RFS RF type in lower nibble:

| Value | Definition |
|-------|------------|
| 0x0   | 60GHz      |
| 0xA   | 77GHz      |

RFS sensor type in upper nibble:

| Value | Definition |
|-------|------------|
| 0x0   | SOC        |
| 0xA   | FE         |

### 2.3.17 FECSS RF Status Get API

This API returns FECSS RF channels and IP modules power state data.

#### API Definition

|                                    |                               |
|------------------------------------|-------------------------------|
| <b>API Index</b>                   | 0x0013U                       |
| <b>API Function Name</b>           | rl_fecssRfStatusGet           |
| <b>API Configuration Structure</b> | None                          |
| <b>API Response Structure</b>      | T_RL_API_FECSS_RF_STS_GET_RSP |

#### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RF_STS_GET ((UINT16)0x0013U)

// API Function Definition
T_RETURNTYPE rl_fecssRfStatusGet(UINT8 c_devIndex, T_RL_API_FECSS_RF_STS_GET_RSP
→ *p_apiResData);
```

#### ► Response C Structure

**Table 2.28:** T\_RL\_API\_FECSS\_RF\_STS\_GET\_RSP

| Field            | Data Type | Size      | Offset |
|------------------|-----------|-----------|--------|
| w_RxChCtrlSts    | UINT16    | 2         | 0      |
| h_TxChCtrlSts    | UINT16    | 2         | 2      |
| c_Reserve0       | UINT8     | 1         | 4      |
| c_MiscCtrlSts    | UINT8     | 1         | 5      |
| c_ApllClkCtrlSts | UINT8     | 1         | 6      |
| c_Reserve1       | UINT8     | 1         | 7      |
| w_Reserve2       | UINT32    | 4         | 8      |
| Total            |           | <b>12</b> |        |

#### Response Fields

##### ► w\_RxChCtrlSts

FECSS RFS RX channels control status, 1 bit per channel. This field contains read-back of information configured in h\_RxChCtrlBitMask.

► [h\\_TxChCtrlSts](#)

FECSS RFS TX channels control status, 1 bit per channel. This field contains read-back of information configured in [h\\_TxChCtrlBitMask](#).

► [c\\_MiscCtrlSts](#)

FECSS RFS miscellaneous block / clock control status, 1 bit per control. This field contains read-back of information configured in [c\\_MiscCtrl](#).

► [c\\_ApllClkCtrlSts](#)

FECSS APLL status.

| Value | Definition         |
|-------|--------------------|
| 0x00  | APLL block is OFF. |
| 0x0A  | APLL block is ON.  |

### 2.3.18 FECSS RF Fault Status Get API

This API returns the CPU Firmware status.

**Notes** Application should read the fault status of the FECSS device when FECSS\_RFS\_FAULT interrupt is received on FEC\_INTR1 (IRQ[3]) in application M4 core.

#### API Definition

|                                    |                                                |
|------------------------------------|------------------------------------------------|
| <b>API Index</b>                   | 0x0014U                                        |
| <b>API Function Name</b>           | rl_fecssRfFaultStatusGet                       |
| <b>API Configuration Structure</b> | None                                           |
| <b>API Response Structure</b>      | <a href="#">T_RL_API_RFS_FAULT_STS_GET_RSP</a> |

► [API Function](#)

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_FAULT_STS_GET ((UINT16)0x0014U)
// API Function Definition
T_RETURNTYPE rl_fecssRfFaultStatusGet(UINT8 c_devIndex, T_RL_API_RFS_FAULT_STS_GET_RSP
→ *p_apiResData);
```

► Response C Structure

**Table 2.29:** T\_RL\_API\_RFS\_FAULT\_STS\_GET\_RSP

| Field            | Data Type | Size      | Offset |
|------------------|-----------|-----------|--------|
| h_RfsFwState     | UINT16    | 2         | 0      |
| c_PatchAndSilEna | UINT8     | 1         | 2      |
| c_RfAndSensType  | UINT8     | 1         | 3      |
| w_Reserved1      | UINT32    | 4         | 4      |
| c_FaultType      | UINT8     | 1         | 8      |
| c_ErrorCode      | UINT8     | 1         | 9      |
| h_LineNum        | UINT16    | 2         | 10     |
| w_AbortPC        | UINT32    | 4         | 12     |
| w_AbortLR        | UINT32    | 4         | 16     |
| w_AbortApsr      | UINT32    | 4         | 20     |
| w_AbortSp        | UINT32    | 4         | 24     |
| w_CfsrReg        | UINT32    | 4         | 28     |
| w_HfsrReg        | UINT32    | 4         | 32     |
| w_MmFarReg       | UINT32    | 4         | 36     |
| w_BFarReg        | UINT32    | 4         | 40     |
| w_ShcsrReg       | UINT32    | 4         | 44     |
| c_ExceptionCount | UINT8     | 1         | 48     |
| c_Reserved2      | UINT8     | 1         | 49     |
| h_Reserved3      | UINT16    | 2         | 50     |
| Total            |           | <b>52</b> |        |

### Response Fields

► h\_RfsFwState

RFS FW state:

| Value  | Definition    |
|--------|---------------|
| 0x0000 | Halt          |
| 0x4004 | Booting       |
| 0x8008 | Idle          |
| 0xFFFF | Fault         |
| Cmd Id | API Execution |

► `c_PatchAndSilEna`

RFS patch status in lower nibble:

| Value | Definition |
|-------|------------|
| 0x0   | Disabled   |
| 0xA   | Enabled    |

RFS SIL status in upper nibble:

| Value | Definition |
|-------|------------|
| 0x0   | Disabled   |
| 0xA   | Enabled    |

► `c_RfAndSensType`

RFS RF type in lower nibble:

| Value | Definition |
|-------|------------|
| 0x0   | 60GHz      |
| 0xA   | 77GHz      |

RFS sensor type in upper nibble:

| Value | Definition |
|-------|------------|
| 0x0   | SOC        |
| 0xA   | FE         |

► `c_FaultType`

RFS CPU fault type:

| Value | Definition |
|-------|------------|
| 0x00  | No fault   |
| 0x81  | CPU Fault  |
| 0x82  | FW ASSERT  |

► `c_ErrorCode`

RFS FW fault error codes. This field is valid only if the `c_FaultType` = FW\_ASSERT.

| <b>Id</b> | <b>Error Code</b>                             |
|-----------|-----------------------------------------------|
| 0x00      | No Fault                                      |
| 0x81      | Stray MBOX Interrupt Error in FEC             |
| 0x82      | FEC Register Read back Error                  |
| 0x83      | Functional Frame triggered in CalMon duration |
| 0x84      | Invalid data                                  |
| 0x85      | Array index out of bound                      |
| 0x86      | Attempted to de reference null pointer        |
| 0x87      | Resource busy                                 |
| 0x88      | Timeout error                                 |
| 0x89      | Stack overflow                                |
| 0x8A      | Undefined error                               |

▶ **h\_LineNum**

RFS firmware fault line number. This field is valid only if the [c\\_FaultType = FW\\_ASSERT](#).

▶ **w\_AbortPC**

RFS PC (Program Counter) value where fault/ assert is detected.

▶ **w\_AbortLR**

RFS LR (Link Register, Typically contains caller's address) register value when fault/ assert is detected.

▶ **w\_AbortApsr**

RFS APSR (Application Program Status Register) register value when fault/ assert is detected.

▶ **w\_AbortSp**

RFS SP (Stack Pointer) when fault/ assert is detected.

▶ **w\_CfsrReg**

RFS CFSR (Configurable Fault Status Register) register value when fault/ assert is detected.

► **w\_HfsrReg**

RFS HFSR (Hard Fault Status Register) register value when fault/ assert is detected.

► **w\_MmfarReg**

RFS MMFAR (Memory Fault Address Status Register) register value when fault/ assert is detected.

► **w\_BfarReg**

RFS BFAR (Bus Fault Status Address Register) register value when fault/ assert is detected.

► **w\_ShcsrReg**

RFS SHCSR (Exception Configuration and Status Register) register value when fault/ assert is detected.

► **c\_ExceptionCount**

RFS exception count.

### 2.3.19 FECSS Die Id Get API

This API returns sensor device die id registers. Die-id can be used to uniquely identify the TI mmWave Radar devices.

#### API Definition

|                                    |                           |
|------------------------------------|---------------------------|
| <b>API Index</b>                   | 0x0015U                   |
| <b>API Function Name</b>           | rl_fecssDieIdGet          |
| <b>API Configuration Structure</b> | None                      |
| <b>API Response Structure</b>      | T_RL_API_SENSOR_DIEID_RSP |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_DIEID_GET ((UINT16)0x0015U)
// API Function Definition
T_RETURNTYPE rl_fecssDieIdGet(UINT8 c_devIndex, T_RL_API_SENSOR_DIEID_RSP *p_apiResData);
```

► Response C Structure

**Table 2.30:** T\_RL\_API\_SENSOR\_DIEID\_RSP

| Field       | Data Type | Size      | Offset |
|-------------|-----------|-----------|--------|
| w_DieIdData | UINT32[4] | 16        | 0      |
| Reserved    | UINT32[4] | 16        | 16     |
| Total       |           | <b>32</b> |        |

**Response Fields**

► w\_DieIdData

Sensor die id data array.

### 2.3.20 FECSS Rx-Tx Calibration Data Get API

This API can be used to store the RX-TX factory calibration data to flash or external memory if calibration is done in the factory. The [FECSS Rx-Tx Calibration Data Set API](#) can be used to restore the stored data back to the device.

**API Definition**

| API Index                   |                              |
|-----------------------------|------------------------------|
| API Function Name           | rl_fecssRfRxTxCalDataGet     |
| API Configuration Structure | None                         |
| API Response Structure      | T_RL_API_FECSS_RXTX_CAL_DATA |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RXTX_CAL_DATA_GET ((UINT16)0x0016U)
// API Function Definition
T_RETURNTYPE rl_fecssRfRxTxCalDataGet(UINT8 c_devIndex, T_RL_API_FECSS_RXTX_CAL_DATA
→ *p_apiResData);
```

### 2.3.21 FECSS Rx-Tx Calibration Data Set API

This API can be used to restore/ update the Rx-Tx calibration data stored using the [FECSS Rx-Tx Calibration Data Get API](#). The update can be done dynamically or at the FECSS power up.

Use [FECSS Rx-Tx Calibration Data Get API](#) and [FECSS Rx-Tx Calibration Data Set API](#) to update `c_CalRxGainCodes` and `h_CalTxBiasCodes` to support dynamic update of multiple chirp profiles in inter-frame time.

**Warning** This API **does not** apply the calibration data to the hardware registers. Please use the [FECSS RF Runtime Calibration API](#) to apply the updated calibration data.

## API Definition

|                                    |                                           |
|------------------------------------|-------------------------------------------|
| <b>API Index</b>                   | 0x0017                                    |
| <b>API Function Name</b>           | <code>rl_fecssRfRxTxCalDataSet</code>     |
| <b>API Configuration Structure</b> | <code>T_RL_API_FECSS_RXTX_CAL_DATA</code> |
| <b>API Response Structure</b>      | None                                      |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RXTX_CAL_DATA_SET      ((UINT16)0x0017U)
// API Function Definition
T_RETURNTYPE rl_fecssRfRxTxCalDataSet(UINT8 c_devIndex, const
→   T_RL_API_FECSS_RXTX_CAL_DATA *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.31:** `T_RL_API_FECSS_RXTX_CAL_DATA`

| Field                             | Data Type    | Size | Offset    |
|-----------------------------------|--------------|------|-----------|
| <code>c_CalRxTxResValidity</code> | UINT8        | 1    | 0         |
| <code>c_CalRxGainCodes</code>     | UINT8[3]     | 3    | 1         |
| <code>c_CalTxBackOffMap</code>    | UINT8[4]     | 4    | 4         |
| <code>h_CalTxBiasCodes</code>     | UINT16[4][3] | 24   | 8         |
| <code>w_Reserved</code>           | UINT32       | 4    | 32        |
| Total                             |              |      | <b>36</b> |

### Configuration Fields

Rx and Tx calibration data structure. This structure is sub-structure in the `T_RL_API_FECSS_FACT_CAL_DATA`.

#### ► `c_CalRxTxResValidity`

Rx and Tx calibration data validity status bits. This field also includes duplicate validity bits for data redundancy.

| Value | Definition                             |
|-------|----------------------------------------|
| 0x0   | INVALID - Calibration data is invalid. |
| 0x1   | VALID - Calibration data is valid.     |

bit definitions are as follows:

| Bit Field  | Definition                                     |
|------------|------------------------------------------------|
| bits [0]   | RX Gain calibration validity status            |
| bits [1]   | TX power calibration validity status           |
| bits [3:2] | RESERVED                                       |
| bits [4]   | RX Gain calibration redundant validity status  |
| bits [5]   | TX power calibration redundant validity status |
| bits [7:6] | Reserved                                       |

► [c\\_CalRxGainCodes](#)

Calibrated Rx gain codes for all temperature bins. Rx gain codes byte contains following fields:

| Bit Field  | Definition                                                                                                                                                   |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bits [4:0] | <b>IFA_GAIN_CODE</b><br>IFA gain code to achieve desired overall Rx gain<br>$IFA\_GAIN(dB) = IFA\_GAIN\_CODE \times 2dB - 10dB$<br>Valid Code Range: [0, 10] |
| bits [7:5] | <b>RFA_GAIN_CODE</b><br>Optimal RFA gain code for the calibrated Rx Gain in respective temperature bin.<br>Valid Range: [0, 3]                               |

► [c\\_CalTxBackOffMap](#)

Calibrated backoff value for each Tx channel. This map is updated based on the [c\\_TxPwrCalTxEnaMask](#). The backoff information is used by various monitoring and internal configuration APIs to derive control parameters. Hence this information must be coherent with the [h\\_CalTxBiasCodes](#).

- 1 LSB = 0.5 dB backoff
- Valid Range: [0, 56] i.e. [0dB , 26dB]

The array stored 1-byte per Tx channel as follows:

| Byte        | Definition       |
|-------------|------------------|
| Byte [0]    | Tx0 Backoff Code |
| Byte [1]    | Tx1 Backoff Code |
| Bytes [3:2] | Reserved         |

► **h\_CalTxBiasCodes**

2-Byte TX\_PA\_CODE for each Tx channel per temperature bin for given `c_CalTxBackOffMap`. Each TX\_PA\_CODE field contains a byte per Tx PA stage, which are packed as follows:

| Byte     | Definition           |
|----------|----------------------|
| Byte [0] | PA stage 1 bias code |
| Byte [1] | PA stage 2 bias code |

and the overall TX\_PA\_CODE array is as follows:

| Bytes         | Definition                                        |
|---------------|---------------------------------------------------|
| Bytes [1:0]   | <code>h_CalTxBiasCodes[Tx0][LOW_TEMP_BIN]</code>  |
| Bytes [3:2]   | <code>h_CalTxBiasCodes[Tx0][MID_TEMP_BIN]</code>  |
| Bytes [5:4]   | <code>h_CalTxBiasCodes[Tx0][HIGH_TEMP_BIN]</code> |
| Bytes [7:6]   | <code>h_CalTxBiasCodes[Tx1][LOW_TEMP_BIN]</code>  |
| Bytes [9:8]   | <code>h_CalTxBiasCodes[Tx1][MID_TEMP_BIN]</code>  |
| Bytes [11:10] | <code>h_CalTxBiasCodes[Tx1][HIGH_TEMP_BIN]</code> |
| Bytes [23:12] | Reserved                                          |

### 2.3.22 FECSS RFS Debug Configuration API

This is an optional API which can be used to configure the RFS internal debug data dump for calibrations and monitors.

#### API Definition

|                                    |                                             |
|------------------------------------|---------------------------------------------|
| <b>API Index</b>                   | 0x0018U                                     |
| <b>API Function Name</b>           | <code>rl_fecssRfsDbgCfg</code>              |
| <b>API Configuration Structure</b> | <code>T_RL_API_FECSS_RFS_DBG_CFG_CMD</code> |
| <b>API Response Structure</b>      | None                                        |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RFS_DBG_CFG ((UINT16)0x0018U)

// API Function Definition
T_RETURNTYPE rl_fecssRfsDbgCfg(UINT8 c_devIndex, const T_RL_API_FECSS_RFS_DBG_CFG_CMD
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.32:** T\_RL\_API\_FECSS\_RFS\_DBG\_CFG\_CMD

| Field              | Data Type | Size      | Offset |
|--------------------|-----------|-----------|--------|
| w_RfsDbgLogAddress | UINT32    | 4         | 0      |
| w_Reserved0        | UINT32    | 4         | 4      |
| w_Reserved1        | UINT32    | 4         | 8      |
| Total              |           | <b>12</b> |        |

**Configuration Fields**

► w\_RfsDbgLogAddress

FECSS RFS debug log address. A non-zero value of address of format 0x224XXXXX enables the debug data store and 0x0 disables the debug data dump.

**Warning**

- Application must allocate at least 4kB and address aligned data buffer starting from this address
- FECSS does not retain this configuration across power cycles, hence the debug data will be disabled after every FECSS power-up.

### 2.3.23 FECSS RF Runtime Tx CLPC API

This API can be used to calibrate the Tx channels during in-field operation. The API calibrates Tx channels using CLPC algorithm and immediately applies the results to the hardware registers.

**Assumptions**

- APLL must be enabled before using [FECSS Device Clock Ctrl API](#)
- Tx and Rx channel configuration is set using [FECSS RF Power On Off API](#)
- Live monitor faults and loopbacks are disabled

## API Definition

|                                    |                                                     |
|------------------------------------|-----------------------------------------------------|
| <b>API Index</b>                   | 0x0019U                                             |
| <b>API Function Name</b>           | <code>r1_fecssR1RuntimeTxClpcCal</code>             |
| <b>API Configuration Structure</b> | <code>T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_CMD</code> |
| <b>API Response Structure</b>      | <code>T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_RSP</code> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_FECSS_RUNTIME_TX_CLPC_CAL ((UINT16)0x0019U)
// API Function Definition
T_RETURNTYPE r1_fecssR1RuntimeTxClpcCal(UINT8 c_devIndex, const
→ T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_CMD *p_apiCmdData,
→ T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_RSP* p_apiResData);
```

### ► Configuration C Structure

**Table 2.33:** `T_RL_API_FECSS_RUNTIME_TX_CLPC_CAL_CMD`

| Field                             | Data Type | Size      | Offset |
|-----------------------------------|-----------|-----------|--------|
| <code>c_CalMode</code>            | UINT8     | 1         | 0      |
| <code>xc_OverrideCalTemp</code>   | SINT8     | 1         | 1      |
| <code>c_Reserve0</code>           | UINT8[2]  | 2         | 2      |
| <code>c_CalTxBackOffSel</code>    | UINT8[4]  | 4         | 4      |
| <code>w_Reserve1</code>           | UINT32    | 4         | 8      |
| <code>h_CalRfFreq</code>          | UINT16    | 2         | 12     |
| <code>xh_CalRfSlope</code>        | SINT16    | 2         | 14     |
| <code>c_TxPwrCalTxEnaMask</code>  | UINT8[4]  | 4         | 16     |
| <code>w_Reserve2</code>           | UINT32    | 4         | 20     |
| <code>h_TxStgOverrideCodes</code> | UINT16[4] | 8         | 24     |
| <code>w_Reserve3</code>           | UINT32[4] | 16        | 32     |
| Total                             |           | <b>48</b> |        |

► Response C Structure

**Table 2.34:** T\_RL\_API\_FECSS\_RUNTIME\_TX\_CLPC\_CAL\_RSP

| Field              | Data Type | Size | Offset    |
|--------------------|-----------|------|-----------|
| c_CalRunStatus     | UINT8     | 1    | 0         |
| xc_CalibrationTemp | SINT8     | 1    | 1         |
| h_Reserved0        | UINT16    | 2    | 2         |
| h_TxStgCodes       | UINT16[4] | 8    | 4         |
| w_Reserved1        | UINT32[3] | 12   | 12        |
| Total              |           |      | <b>24</b> |

### Configuration Fields

Tx CLPC calibration API configuration Structure.

► c\_CalMode

TX CLPC calibration mode flags. The API supports following modes of operations:

| Mode           | Description                                                                                                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Calibrate Mode | This mode performs Tx CLPC calibration immediately and applies results to the hardware registers.<br>The API returns calibration results as a response to the API and are not stored. |
| Override Mode  | This mode can be used to skip the calibrations and apply the results provided in the configuration directly                                                                           |

The bitwise details of the flags is as follows:

| Bits       | Description                                                                                                                |
|------------|----------------------------------------------------------------------------------------------------------------------------|
| bit 0      | Calibration Mode <ul style="list-style-type: none"> <li>• 0: [Default] Calibrate Mode</li> <li>• 1: Bypass Mode</li> </ul> |
| bits [7:1] | Reserved                                                                                                                   |

► xc\_OverrideCalTemp

Override mode calibration temperature value. This field is applicable only when Override Mode is enabled. The information is used to correctly set the internal temperature dependent parameters.

- 1 LSB =  $2^{\circ}\text{C}$
- Valid Range:  $[-40^{\circ}\text{C}, 120^{\circ}\text{C}]$

► `c_CalTxBackOffSel`

Tx backoff value per Tx channel. This field is used in both calibration and override modes. Functionally it is similar to the `c_CalTxBackOffSel` in [FECSS Factory Calibration API](#).

Byte definition is as follows, where 1LSB = 0.5dB:

| Byte Field | Definition                          |
|------------|-------------------------------------|
| Byte[0]    | Output power back-off value for Tx0 |
| Byte[1]    | Output power back-off value for TX1 |
| Byte[3-2]  | Reserved                            |

► `h_CalRfFreq`

Calibration chirp RF start Frequency.

**Recommendation** Configuration of the operating band should be Mid frequency .

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► `xh_CalRfSlope`

RFS calibration chirp RF Frequency Slope.

**Recommendation** The typical ramp time used in FW for calibration chirps are 55us.

For 60GHz: (APPLL\_FREQ = 400MHz): 2.2MHz/us (0x4D).

For 77GHz: (APPLL\_FREQ = 400MHz): 2.2MHz/us (0x3A).

| RF Slope | Resolution                                                                                                                                                        |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us (APPLL_FREQ = 400MHz)) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us (APPLL_FREQ = 400MHz)) |

► `c_TxPwrCalTxEnaMask`

Per channel Tx enable mask for calibrations.

**Recommendation**

- In case more than 1 TXs are enabled during the chirp, then enabling the same TXs during calibration will result in better TX output power accuracy.
- Recommended Calibration Masks: 0x3, 0x1. This setting will enable both Tx channels while calibrating Tx 0 and copy the results for Tx1 without separately calibrating it.

Calibrated bias code for all Tx channels.

| Byte Field | Definition                                                                                                                                                                                                                                   |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Byte[0]    | Tx enable mask for calibrating Tx0.<br>If Tx0 is disabled in this mask, calibration data from the lowest enabled Tx channel from this mask will be applied to Tx0.<br>Tx0 calibration will be skipped from the calibration if the mask is 0. |
| Byte[1]    | Tx enable mask for calibrating Tx1.<br>If Tx1 is disabled in this mask, calibration data from the lowest enabled Tx channel from this mask will be applied to Tx1.<br>Tx1 calibration will be skipped from the calibration if the mask is 0. |
| Byte[3-2]  | Reserved                                                                                                                                                                                                                                     |

**Warning** This mask is applicable even in the override mode. This helps to selectively update Tx stage codes.

► `h_TxStgOverrideCodes`

Override mode TX\_PA\_CODE for each Tx channel.

**Response Fields**

Tx Runtime CLPC calibration API response Structure.

► `c_CalRunStatus`

Calibration run status.

► `xc_CalibrationTemp`

Tx CLPC calibration temperature in 1 LSB = 2°C. In override mode, `xc_OverrideCalTemp` is reported back in this field.

► `h_TxStgCodes`

Calibrated TX\_PA\_CODE for each Tx channel. In override mode, this table is updated according to the `c_TxPwrCalTxEnaMask`.

## 2.4 mmWave Sensor APIs

mmWave sensor APIs provide interface to configure, verify and control the FMCW chirp, burst and frame parameters. Following diagram describes various chirp configuration parameters for the mmWave Low devices.



**Figure 2.1: FMCW Chirp Parameters**

| Parameter           | Description and Notes                                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chirp Idle Time     | Time period between end of one chirp's frequency ramp and next chirp's frequency ramp                                                                |
| Chirp Start         | Start of a chirp idle time                                                                                                                           |
| ADC Start Time      | Time from the knee of the ramp after which ADC samples are captured in the Rx buffer                                                                 |
| Tx Start Time       | Time from knee of the ramp after which transmitters are enabled<br>This time could be negative, i.e. transmitters can be enabled in idle time itself |
| Chirp Ramp End Time | Time period of frequency ramp in a chirp                                                                                                             |
| Chirp End           | End of the FMCW RAMP<br>This event coincides with the chirp start of the following chirp<br>CRD is included in the chirp idle time of the next chirp |
| Chirp Period        | Sum of chirp idle time and chirp ramp time                                                                                                           |
| Chirp Bandwidth     | Difference between the start frequency and end frequency of a chirp                                                                                  |

mmWave devices pack multiple chirps in a single transmission called burst. A set of bursts in called as frame. Sensor APIs allow transmission of multiple frames with a single trigger. Following diagram and table describes important terms and parameters related to bursts and frames.



**Figure 2.2: Frame and Burst Events**

| Parameter         | Description and Notes                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chirp             | Single FMCW transmission with defined slope and start frequency                                                                                                                                                                                                                                                                                                            |
| Burst             | Set of consecutive chirps                                                                                                                                                                                                                                                                                                                                                  |
| Frame             | Set of bursts                                                                                                                                                                                                                                                                                                                                                              |
| Burst Start (BS)  | Start of a burst<br>This event is periodically generated by the Chirp Timer hardware module. RFS firmware powers up and configures analog front end upon receiving this event.                                                                                                                                                                                             |
| Burst End (BE)    | End of a burst<br>This event is generated at the end of the last chirp of a burst. The RFS firmware powers down the analog front end components enabled during Burst Start upon receiving this event.                                                                                                                                                                      |
| Burst Idle Time   | Time between the Chirp End of the last chirp in a burst and the first Chirp Start of the next burst.<br>This time should be sufficient to execute Burst Start (for next burst) and Burst End sequences.                                                                                                                                                                    |
| Burst Periodicity | Time period between two consecutive Burst Start events in a frame                                                                                                                                                                                                                                                                                                          |
| Frame Start (FS)  | Start of a frame<br>This event is periodically generated by the Frame Timer hardware module. RFS firmware powers up and configures minimal set of front end modules required for Chirp Timer upon receiving this event.                                                                                                                                                    |
| Frame End (FE)    | End of a frame<br>This event is generated by the Chirp Timer hardware module upon completion of the last chirp of a last burst in a frame. RFS firmware turns off all the front end modules enabled during frame start.<br>The actual hardware event coincides with the Burst End of the last burst in a frame, but the Burst End takes higher priority and executes first |
| Frame Idle Time   | Idle time between end of the last burst in first burst to the start of the first burst in following frame<br>This time should be sufficient to execute Frame Start (for the following frame) and Frame End sequences.                                                                                                                                                      |
| Frame Periodicity | Time between two consecutive Frame Start events                                                                                                                                                                                                                                                                                                                            |

**Note** Chirp timing parameters like chirp idle time, skip samples, and chirp ramp end time, along with parameters such as burst and frame times are to be set according to conditions mentioned as in [Chirp, Burst and Frame Timing Constraints](#).

The sensor module provides following APIs to configure and control the mmWave Low sensors:

- [Sensor Profile Common Configuration API](#)
- [Sensor Chirp Profile Common Configuration Get API](#)
- [Sensor Chirp Profile Time Configuration API](#)
- [Sensor Chirp Profile Time Configuration Get API](#)
- [Sensor Per-Chirp Configuration API](#)
- [Sensor Per-Chirp Configuration Get API](#)
- [Sensor Per-Chirp Control API](#)
- [Sensor Per-Chirp Control Get API](#)
- [Sensor Frame Configuration API](#)
- [Sensor Frame Configuration Get API](#)
- [Sensor Start API](#)
- [Sensor Stop API](#)
- [Sensor Status Get API](#)
- [Sensor Dynamic Power Save Disable Configuration API](#)
- [Sensor Dynamic Power Save Disable Configuration Get API](#)
- [Sensor Loopback Configuration API](#)
- [Sensor Loopback Enable API](#)

**Warning** Sensor configuration APIs must be issued outside the frame active time (Outside Frame Start and Frame End event boundaries). The application should issue [Sensor Stop API](#) if reconfiguration is required in frame active time.

#### 2.4.1 Sensor Profile Common Configuration API

This API function configures the FMCW radar chirp profile common parameters like sample rate, num of samples, ramp end time, TX/RX gain, etc. These parameters will be common for all the chirps in a frame.

**Warning** Profile configurations are directly written to the hardware registers and hence will not be retained across deep-sleep. Application must re-issue this API after waking up from deep sleep.

##### API Definition

|                                    |                                                |
|------------------------------------|------------------------------------------------|
| <b>API Index</b>                   | 0x0040U                                        |
| <b>API Function Name</b>           | <code>rl_sensChirpProfComnCfg</code>           |
| <b>API Configuration Structure</b> | <code>T_RL_API_SENS_CHIRP_PROF_COMM_CFG</code> |
| <b>API Response Structure</b>      | None                                           |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PROF_COMM_CFG           ((UINT16)0x0040U)
// API Function Definition
T_RETURNTYPE rl_sensChirpProfCommCfg(UINT8 c_devIndex, const
→ T_RL_API_SENS_CHIRP_PROF_COMM_CFG *p_apiCmdData)
```

► Configuration C Structure

**Table 2.35:** T\_RL\_API\_SENS\_CHIRP\_PROF\_COMM\_CFG

| Field                 | Data Type | Size | Offset    |
|-----------------------|-----------|------|-----------|
| c_DigOutputSampRate   | UINT8     | 1    | 0         |
| c_DigOutputBitsSel    | UINT8     | 1    | 1         |
| c_DfeFirSel           | UINT8     | 1    | 2         |
| c_VcoMultiChipMode    | UINT8     | 1    | 3         |
| h_NumOfAdcSamples     | UINT16    | 2    | 4         |
| c_ChirpTxMimoPatSel   | UINT8     | 1    | 6         |
| c_MiscSettings        | UINT8     | 1    | 7         |
| c_HpfFastInitDuration | UINT8     | 1    | 8         |
| c_Reserved            | UINT8     | 1    | 9         |
| h_CrdNSlopeMag        | UINT16    | 2    | 10        |
| w_Reserved            | UINT32    | 4    | 12        |
| h_ChirpRampEndTime    | UINT16    | 2    | 16        |
| c_ChirpRxHpfSel       | UINT8     | 1    | 18        |
| c_Reserved2           | UINT8     | 1    | 19        |
| w_Reserved3           | UINT32[4] | 16   | 20        |
| Total                 |           |      | <b>36</b> |

Configuration Fields

► c\_DigOutputSampRate

Digital output sampling rate of the Rx ADC.

The ADC sample rate depends on the APLL clock and is computed uses the following formula:

$$ADC\_SAMPLING\_RATE(MSPS) = \frac{APLL\_FREQ(MHz)}{c\_DigOutputSampRate \times 4}$$

Valid Range: [8, 100]

recommended sampling rates are as follows (assuming APLL\_FREQ = 400MHz):

| c_DigOutputSampRate | sampling Rate (MSPS) |
|---------------------|----------------------|
| 8                   | 12.5                 |
| 10                  | 10                   |
| 13                  | 7.692                |
| 15                  | 6.667                |
| 20                  | 5                    |
| 25                  | 4                    |
| 40                  | 2.5                  |
| 50                  | 2                    |
| 60                  | 1.667                |
| 80                  | 1.25                 |
| 100                 | 1                    |

► **c\_DigOutputBitsSel**

Digital ADC output bit width select control.

This field controls the section of bits from the internal 16-bit output, which will be stored to the ADC buffer. Rx ADC always sends 16-bits to the output, depending on the configuration up to 4-bits are dropped from the result and the result is sign extended to map to a valid signed 16-bit number. xWRLx432 devices support following output options:

| c_DigOutputBitsSel | Description                                                               |
|--------------------|---------------------------------------------------------------------------|
| 0                  | Digital sample output is 12 MSB bits of DFE after rounding 4 LSBs         |
| 1                  | Digital sample output is 12 bits after rounding 3 LSBs and clipping 1 MSB |
| 2                  | Digital sample output is 12 bits after rounding 2 LSBs and clipping 2 MSB |
| 3                  | Digital sample output is 12 bits after rounding 1 LSBs and clipping 3 MSB |
| 4                  | Digital sample output is 12 LSB bits after clipping 4 MSB                 |
| 5                  | Digital sample output is 16 bits                                          |

Valid Range: [0,5]

► **c\_DfeFirSel**

DFE FIR filter selection.

This option selects the configuration of the final DFE FIR filter. The options are as follows:

| c_DfeFirSel | Description                                                                                                                                                                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | <p>Long Filter (90% visibility)</p> <p>This provides visibility to a larger range of IF frequencies: 0 to <math>0.45 \times</math> Sampling Rate. Beyond that, the filter response starts drooping and enters filter transition band.</p>               |
| 1           | <p>Short Filter (80% visibility)</p> <p>This provides faster settled outputs but the IF frequency range visible is 0 to <math>0.40 \times</math> Sampling Rate. Beyond that, the filter response starts drooping and enters filter transition band.</p> |

► **c\_VcoMultiChipMode**

Sensor VCO selection control.

| c_VcoMultiChipMode | Description                                                                                                                  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0                  | <p>SINGLE_CHIP_VCO</p> <p><b>Default Mode:</b> The device is in non-cascaded configuration</p>                               |
| 1                  | <p>MULTI_CHIP_PRIMARY_VCO</p> <p>The device is controlling the VCOs in cascaded mode</p>                                     |
| 2                  | <p>MULTI_CHIP_SECONDARY_VCO</p> <p>The device is controlled by the VCO from a primary device in a cascaded configuration</p> |

**Warning** xWRLx432 devices **do not** support cascaded configuration

► **h\_NumOfAdcSamples**

Number of ADC samples to capture in a chirp for each RX channels.

Valid Range: [2, 2048]

► **c\_ChirpTxMimoPatSel**

Tx output MIMO pattern control.

This field controls the various BPM, TDMA output patterns supported by the device.

| c_ChirpTxMimoPatSel | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                   | <u>Disabled</u><br>Tx enable and BPM is controlled by <a href="#">h_ChirpTxEnSel</a> and <a href="#">h_ChirpTxBpmEnSel</a> registers respectively for all the chirps.                                                                                                                                                                                                                                        |
| 1                   | <u>TDMA_2TX</u><br><a href="#">h_ChirpTxEnSel</a> register or settings corresponding to the bit M_RL_SENS_PER_CHIRP_PARAM_INDEX_IDLE_TIME enabled in <a href="#">h_PerChirpParamCtrl</a> are ignored and internally varied as [01; 10; 01; 10; ...] in chirp 0, 1, 2, 3, ... and so on in the frame.<br><a href="#">h_ChirpTxBpmEnSel</a> register continues to control the BPM for all enabled Tx channels. |
| 4                   | <u>BPM_2TX</u><br><a href="#">h_ChirpTxBpmEnSel</a> register or settings corresponding to the bit M_RL_SENS_PER_CHIRP_PARAM_INDEX_TX_START_TIME enabled in <a href="#">h_PerChirpParamCtrl</a> are ignored and is internally varied as [00; 10; 00; 10; ...] in chirp 0, 1, 2, 3, ... and so on in the frame.<br><a href="#">h_ChirpTxEnSel</a> register continues to control Tx enable for all Tx channels. |

### ► c\_MiscSettings

Miscellaneous chirp control settings bit-mask.

| Bit Index | Description                                                                                                                                                                                                                                                                                                                                                                                                          | mmWaveLink Macro                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| 0         | <b>HPF Fast Init Disable</b><br>This bit <b>Disables</b> HPF fast init for all the chirps. When HPF fast init is enabled, Chirp Timer initializes the HPF by temporarily increasing HPF bandwidth (20X BW) for faster settling at the start of the ramp. Width of the initialization window is controlled by <a href="#">c_HpfFastInitDuration</a> and starts 100ns before the <a href="#">xh_ChirpTxStartTime</a> . | M_RL_SENS_MISC_HPF_FAST_INIT_DIS_BIT |

| Bit Index | Description                                                                                                                                                                                                                                                                                                                                                         | mmWaveLink Macro                  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| 1         | <p><b>CRD Disable</b><br/> This bit <b>Disables</b> the CRD for all chirps. When CRD is enabled, synthesizer is controlled in the ramp down portion of the chirp to avoid undershoot / overshoot of synthesizer and mitigate the fixed frequency RF spurs. Magnitude of the CRD ramp slope is controlled by <a href="#">h_CrdNSlopeMag</a></p>                      | M_RL_SENS_MISC_CRD_DIS_BIT        |
| 2         | <p><b>CRD Dither Disable</b><br/> This bit <b>Disables</b> the CRD dither. The field is applicable only if the CRD is enabled.</p>                                                                                                                                                                                                                                  | M_RL_SENS_MISC_CRD_DITHER_DIS_BIT |
| 3         | <p><b>PA Blanking Enable</b><br/> This bit enables PA Blanking. Device supports PA blanking through an input signal to the device in order to stop the transmission from the device instantaneously. This feature can be particularly useful, when the device is used in presence of other RF transceiver devices for various purposes (e.g. 5G communication).</p> | M_RL_SENS_MISC_PA_BLANK_EN_BIT    |

Recommended and Default Value: 0x00

► [c\\_HpfFastInitDuration](#)

This field controls the width of the HPF fast initialization pulse generated by the Chirp Timer. The pulse starts 100ns before [xh\\_ChirpTxStartTime](#) and the timing should be chosen in accordance to [h\\_ChirpAdcStartTime](#).

- Unit: 1 LSB =  $40/APLL\_FREQ$ , typically 100ns with 40MHz XTAL
- Range: [5, 100]
- Recommended Value: 15 (1.5us for 40MHz XTAL)

► [h\\_CrdNSlopeMag](#)

Magnitude if the CRD slope. The sign of the ramp is detected automatically based on the start frequency.

| Device RF Type | Resolution                                                                                                                                                    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz          | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{20} \approx 457.763kHz/us$ , unsigned number<br>Valid Range: 0x0 to 0xC00 (1406 MHz/us with APPLL_FREQ = 400MHz) |
| 77GHz          | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{20} \approx 610.351kHz/us$ , unsigned number<br>Valid Range: 0x0 to 0x925 (1428 MHz/us with APPLL_FREQ = 400MHz) |

### Recommendation

- Recommended method to compute the CRD slope magnitude is

$$CRD\_Slope = Chirp\_Ramp\_End\_Time \times Chirp\_Slope / \min(Chirp\_Idle\_Time - 1\mu s, 6\mu s)$$

where Chirp\_Ramp\_End\_Time, Chirp\_Slope and Chirp\_Idle\_Time are controlled by `h_ChirpRampEndTime`, `xh_ChirpRfFreqSlope` and `h_ChirpIdleTime` fields respectively,

- CRD Ramp down time must be  $\leq \min(Chirp\_Idle\_Time - 1U, 6\mu s)$

### ▶ `h_ChirpRampEndTime`

Chirp ramp end time.

This is a common ramp end time for all the chirps in the frame. The time value of the ramp end time depends on the Time Resolution selected by `c_ChirpTimerResol` during the FECSS powerup.

| Time Resolution | Ramp End Time Resolution                                                                              |
|-----------------|-------------------------------------------------------------------------------------------------------|
| High            | 1 LSB = 8/APLL_FREQ (Typically 20ns with 40MHz XTAL)<br>Valid Range: [1, 65535 ( $\approx 1.3ms$ )]   |
| Low             | 1 LSB = 40/APLL_FREQ (Typically 100ns with 40MHz XTAL)<br>Valid Range: [1, 65535 ( $\approx 6.5ms$ )] |

### Warning

User should ensure that the complete frequency sweep is within the valid frequency range.

DFP does not perform checks on the end frequency to detect frequency overflow. Valid frequency ranges are as follows:

- 60 GHz Device: 57 GHz - 64 GHz
- 77 GHz Device: 76 GHz - 81 GHz

### Note

This field is not applicable for M\_RL\_SENS\_FRAME\_CW\_CZ\_TRIG mode.

### ▶ `c_ChirpRxHpfSel`

DFE HPF cut-off frequency control. This is a common HPF cutoff frequency for all the chirps.

| c_ChirpRxHpfSel | HPF Cutoff Frequency |
|-----------------|----------------------|
| 0               | 175kHz               |
| 1               | 350kHz               |
| 2               | 700kHz               |
| 3               | 1400kHz              |

## 2.4.2 Sensor Chirp Profile Common Configuration Get API

This API reads the hardware registers and returns the configuration done using the [Sensor Profile Common Configuration API](#).

### API Definition

|                                    |                                                   |
|------------------------------------|---------------------------------------------------|
| <b>API Index</b>                   | 0x0041                                            |
| <b>API Function Name</b>           | rl_sensChirpProfComnCfgGet                        |
| <b>API Configuration Structure</b> | None                                              |
| <b>API Response Structure</b>      | <a href="#">T_RL_API_SENS_CHIRP_PROF_COMM_CFG</a> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PROF_COMM_CFG_GET           ((UINT16)0x0041U)
// API Function Definition
T_RETURNTYPE rl_sensChirpProfComnCfgGet(UINT8 c_devIndex,
                                         T_RL_API_SENS_CHIRP_PROF_COMM_CFG *p_apiResData);
```

## 2.4.3 Sensor Chirp Profile Time Configuration API

This API function configures the FMCW radar chirp profile timing parameters like idle time, ADC start time, TX start time, RF Slope, RF start freq, TX and BPM enable. These parameters are common for all chirps in a frame. [Sensor Per-Chirp Configuration API](#) can be used to dither/ vary certain parameters in every chirp.

**Warning** Profile configurations are directly written to the hardware registers and hence will not be retained across deep-sleep. Application must re-issue this API after waking up from deep sleep.

### API Definition

|                                    |                                                   |
|------------------------------------|---------------------------------------------------|
| <b>API Index</b>                   | 0x0042U                                           |
| <b>API Function Name</b>           | rl_sensChirpProfTimeCfg                           |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_SENS_CHIRP_PROF_TIME_CFG</a> |
| <b>API Response Structure</b>      | None                                              |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PROF_TIME_CFG           ((UINT16)0x0042U)

// API Function Definition
T_RETURNTYPE rl_sensChirpProfTimeCfg(UINT8 c_devIndex, const
→ T_RL_API_SENS_CHIRP_PROF_TIME_CFG *p_apiCmdData);
```

► Configuration C Structure

**Table 2.37:** T\_RL\_API\_SENS\_CHIRP\_PROF\_TIME\_CFG

| Field               | Data Type | Size | Offset    |
|---------------------|-----------|------|-----------|
| h_ChirpIdleTime     | UINT16    | 2    | 0         |
| h_ChirpAdcStartTime | UINT16    | 2    | 2         |
| xh_ChirpTxStartTime | SINT16    | 2    | 4         |
| xh_ChirpRfFreqSlope | SINT16    | 2    | 6         |
| w_ChirpRfFreqStart  | UINT32    | 4    | 8         |
| h_ChirpTxEnSel      | UINT16    | 2    | 12        |
| h_ChirpTxBpmEnSel   | UINT16    | 2    | 14        |
| w_Reserve1          | UINT32    | 4    | 16        |
| w_Reserve2          | UINT32[4] | 16   | 20        |
| Total               |           |      | <b>36</b> |

Configuration Fields

► h\_ChirpIdleTime

Chirp idle time code

The time value of the chirp idle time depends on the timer resolution ([c\\_ChirpTimerResol](#)) selected during the FECSS boot.

This value will be ignored if the bit [M\\_RL\\_SENS\\_PER\\_CHIRP\\_PARAM\\_INDEX\\_IDLE\\_TIME](#) is enabled in [h\\_PerChirpParamCtrl](#). Refer [Sensor Per-Chirp Configuration API](#) and [Sensor Per-Chirp Control API](#) for more details.

| Time Resolution Mode                                       | Resolution Definition                                                         |
|------------------------------------------------------------|-------------------------------------------------------------------------------|
| High Resolution ( <a href="#">c_ChirpTimerResol</a> :b1=1) | 1LSB = $8/APLL\_FREQ$ , unsigned number.<br>Valid Range: 1 to 65535 ( 1.3ms)  |
| Low Resolution ( <a href="#">c_ChirpTimerResol</a> :b1=0)  | 1LSB = $40/APLL\_FREQ$ , unsigned number.<br>Valid Range: 1 to 65535 ( 6.5ms) |

► **h\_ChirpAdcStartTime**

Rx ADC start time from the knee of the ramp

This parameter configures the number of samples to be skipped at the start of the chirp. These samples are addition to the [h\\_NumOfAdcSamples](#) and should be considered while computing [h\\_ChirpRampEndTime](#).

This value will be ignored if the bit [M\\_RL\\_SENS\\_PER\\_CHIRP\\_PARAM\\_INDEX\\_TX\\_START\\_TIME](#) is enabled in [h\\_PerChirpParamCtrl](#). Refer [Sensor Per-Chirp Configuration API](#) and [Sensor Per-Chirp Control API](#) for more details.

| Bit Field   | Definition                                                                                                                                                                     |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits[9:0]   | Reserved                                                                                                                                                                       |
| Bits[15:10] | <p><i>AdcSkipSamples</i><br/> Number of ADC Samples to be Skipped.</p> <ul style="list-style-type: none"> <li>• 1 LSB= 1 ADC sample</li> <li>• Valid range: 0 to 63</li> </ul> |

► **xh\_ChirpTxStartTime**

Tx start time from the knee of the ramp.

This value determines when the Tx transmission is enabled with respect to the knee of the ramp. Negative values could be used to start the Tx transmissions before the FMCW chirp ramp starts.

This value will be ignored if the bit [M\\_RL\\_SENS\\_PER\\_CHIRP\\_PARAM\\_INDEX\\_TX\\_START\\_TIME](#) is enabled in [h\\_PerChirpParamCtrl](#). Refer [Sensor Per-Chirp Configuration API](#) and [Sensor Per-Chirp Control API](#) for more details.

- Format: 16-bit signed number with 1 LSB = 8/APLL\_FREQ (Typical 20us with 40MHz XTAL)
- Recommended Range: -150 to 150 (+/- 3us)

**Notes** The [c\\_ChirpTimerResol](#) is **NOT** applicable for this parameter.

► **xh\_ChirpRfFreqSlope**

Chirp frequency ramp slope.

This parameter controls the slope of the FMCW ramp. The signed slope value code and range depend on the operating frequency range of the device. This value will be ignored if the bit [M\\_RL\\_SENS\\_PER\\_CHIRP\\_PARAM\\_INDEX\\_FREQ\\_SLOPE](#) is enabled in [h\\_PerChirpParamCtrl](#). Refer [Sensor Per-Chirp Configuration API](#) and [Sensor Per-Chirp Control API](#) for more details.

| RF Frequency | Resolution                                                                                                                                     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = 3 \times 400 \times APPLL\_FREQ/2^{24} \approx 28.610 \text{ kHz/us}$ , signed number.<br>Valid range: -13972 to 13972 (+/- 399MHz/us) |
| 77GHz        | $1LSB = 4 \times 400 \times APPLL\_FREQ/2^{24} \approx 38.147 \text{ kHz/us}$ , signed number.<br>Valid range: -13972 to 13972 (+/- 533MHz/us) |

**Warning**

- Firmware does not check validity of the ramp end frequency of a chirp. Application should ensure that `h_ChirpRampEndTime`, `w_ChirpRfFreqStart` and `xh_ChirpRfFreqSlope` are configured without exceeding the operating frequency range of the device.
- Chirp slope will be forced to 0 internally in CW mode.

▶ `w_ChirpRfFreqStart`

Starting frequency of the FMCW chirp ramp.

This parameter controls the start frequency of the FMCW chirp or the wave transmitted in CW mode. The code value of the start frequency depends on the `c_ChirpTimerResol` in the FECSS boot and operating frequency of the device.

This value will be ignored if the bit `M_RL_SENS_PER_CHIRP_PARAM_INDEX_FREQ_START` is enabled in `h_PerChirpParamCtrl`. Refer [Sensor Per-Chirp Configuration API](#) and [Sensor Per-Chirp Control API](#) for more details.

| RF Frequency | Encoding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60 GHz       | <p><b>High Frequency Resolution</b> (<code>c_ChirpTimerResol</code>:b0=1)</p> <ul style="list-style-type: none"> <li><math>1LSB = (3 \times APPLL\_FREQ / 2^{24}) \times 2^6 \approx 4.578 \text{ kHz}</math></li> <li><u>Valid Range:</u> 0x00BE0000 (57GHz) to 0X00D55555 (64GHz)*<br/>*Variant specific limitations in Release Notes</li> <li>24-bit unsigned format</li> </ul> <p><b>Low Frequency Resolution</b> (<code>c_ChirpTimerResol</code>:b0=0)</p> <ul style="list-style-type: none"> <li><math>1LSB = (3 \times APPLL\_FREQ / 2^{16}) \times 2^6 \approx 1.172 \text{ MHz}</math></li> <li><u>Valid Range:</u> 0x0000BE00 (57GHz) to 0x0000D555 (64GHz)*<br/>*Variant specific limitations in Release Notes</li> <li>16-bit unsigned format</li> </ul> |
| 77 GHz       | <p><b>High Frequency Resolution</b> (<code>c_ChirpTimerResol</code>:b0=1)</p> <ul style="list-style-type: none"> <li><math>1LSB = (4 \times APPLL\_FREQ / 2^{24}) \times 2^6 \approx 6.103 \text{ kHz}</math></li> <li><u>Valid Range:</u> 0x00BE0000 (76GHz) to 0x00CA8000 (81GHz)</li> <li>24-bit unsigned format</li> </ul> <p><b>Low Frequency Resolution</b> (<code>c_ChirpTimerResol</code>:b0=0)</p> <ul style="list-style-type: none"> <li><math>1LSB = (4 \times APPLL\_FREQ / 2^{16}) \times 2^6 \approx 1.562 \text{ MHz}</math></li> <li><u>Valid Range:</u> 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)</li> <li>16-bit unsigned format</li> </ul>                                                                                                         |

▶ `h_ChirpTxEnSel`

Tx enable control bit mask with 1 bit per Tx.

This parameter controls which Tx channels are enabled during the transmission. This parameter will be ignored if either `c_ChirpTxMimoPatSel=1` or `M_RL_SENS_PER_CHIRP_PARAM_INDEX_TX_EN` is enabled in `h_PerChirpParamCtrl`. The application should also ensure that all the required channels are also enabled in `h_TxChCtrlBitMask`.

| Bit Field   | Definition                  |
|-------------|-----------------------------|
| bits [0]    | Tx Channel 0 Enable Control |
| bits [1]    | Tx Channel 1 Enable Control |
| bits [15:2] | Reserved                    |

► `h_ChirpTxBpmEnSel`

Tx BPM enable control bit mask with 1 bit per Tx.

This parameter controls binary phase inversion for enabled Tx channels during the transmission. This parameter will be ignored if either `c_ChirpTxMimoPatSel=4` or `M_RL_SENS_PER_CHIRP_PARAM_INDEX_BPM_EN` is enabled in `h_PerChirpParamCtrl`. The application should also ensure that all the required channels are also enabled in `h_TxChCtrlBitMask`.

| Bit Field   | Definition               |
|-------------|--------------------------|
| bits [0]    | Tx Channel 0 BPM Control |
| bits [1]    | Tx Channel 1 BPM Control |
| bits [15:2] | Reserved                 |

#### 2.4.4 Sensor Chirp Profile Time Configuration Get API

This API reads the hardware registers and returns the configuration done using the [Sensor Chirp Profile Time Configuration API](#).

##### API Definition

|                                    |                                                |
|------------------------------------|------------------------------------------------|
| <b>API Index</b>                   | 0x0043                                         |
| <b>API Function Name</b>           | <code>rl_sensChirpProfTimeCfgGet</code>        |
| <b>API Configuration Structure</b> | None                                           |
| <b>API Response Structure</b>      | <code>T_RL_API_SENS_CHIRP_PROF_TIME_CFG</code> |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PROF_TIME_CFG_GET ((UINT16)0x0043U)
// API Function Definition
T_RETURNTYPE rl_sensChirpProfTimeCfgGet(UINT8 c_devIndex,
                                         T_RL_API_SENS_CHIRP_PROF_TIME_CFG *p_apiResData);
```

## 2.4.5 Sensor Per-Chirp Configuration API

mmWave sensors provide option to dither/ vary selected set of parameters for every chirp. These parameters are stored in a dedicated memory section, referred as PER\_CHIRP\_RAM, in a look-up-table (LUT) format. Each of the per-chirp parameters' LUT is stored in the memory as an array of contiguous values in a specific format. Chirp timer hardware automatically updates the enabled parameters from the LUT corresponding to that parameter. mmWave Low devices support following per-chirp parameters which override the configurations from [Sensor Chirp Profile Time Configuration API](#).

**Table 2.38:** Sensor Per-Chirp Parameters

| Parameter                                                               | Description                                                                                                                                                            |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chirp Start Frequency<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_FREQ_START (0) | LUT entries are stored as <b>32-bit unsigned</b> numbers similar to the <a href="#">w_ChirpRfFreqStart</a>                                                             |
| Chirp Slope<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_FREQ_SLOPE (1)           | LUT entries are stored as <b>16-bit signed</b> numbers similar to the <a href="#">xh_ChirpRfFreqSlope</a>                                                              |
| Chirp Idle Time<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_IDLE_TIME (2)        | LUT entries are stored as <b>16-bit unsigned</b> numbers similar to the <a href="#">h_ChirpIdleTime</a>                                                                |
| ADC Start Time<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_ADC_START_TIME (3)    | LUT entries are stored as <b>16-bit unsigned</b> numbers similar to the <a href="#">h_ChirpAdcStartTime</a>                                                            |
| Tx Start Time<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_TX_START_TIME (4)      | LUT entries are stored as <b>16-bit signed</b> numbers similar to the <a href="#">xh_ChirpTxStartTime</a>                                                              |
| Tx Enable Mask<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_TX_EN (5)             | LUT entries are stored as <b>4-bit masks</b> with 1-bit per Tx channel, i.e. each byte contains 2 LUT entries with upper nibble representing the latter configuration. |
| Tx BPM Enable Mask<br>M_RL_SENS_PER_CHIRP_PARAM_INDEX_BPM_EN (6)        | LUT entries are stored as <b>4-bit masks</b> with 1-bit per Tx channel, i.e. each byte contains 2 LUT entries with upper nibble representing the latter configuration. |

All the LUT arrays are stored in PER\_CHIRP\_RAM, which is a generic memory buffer accessible by the front end. The application can directly access the PER\_CHIRP\_RAM and update the LUTs on the boot or in frame idle time. Following table defines the various attributes of the PER\_CHIRP\_RAM.

| Attribute                         | xWRL6432   | xWRL1432   |
|-----------------------------------|------------|------------|
| Start Address                     | 0x21880000 | 0x21880000 |
| Size                              | 8192 Bytes | 8192 Bytes |
| Address Offset Alignment for LUTs | 4 Bytes    | 4 Bytes    |

This API should be used along with the [Sensor Per-Chirp Control API](#) to control and enable per-chirp configurations.

**Warning**

- Application must not modify the PER\_CHIRP\_RAM in active frame duration.
- If application requires dynamic configuration of the PER\_CHIRP\_RAM, it should split the buffer in two sections and use it in ping-pong manner.
- PER\_CHIRP\_RAM could be retained across deep sleep, but not the configuration. Application has to re-issue the per-chirp configuration command after waking up from the deep sleep.
- This API configurations will be ignored in CW Mode

**API Definition**

|                                    |                             |
|------------------------------------|-----------------------------|
| <b>API Index</b>                   | 0x0044U                     |
| <b>API Function Name</b>           | rl_sensPerChirpCfg          |
| <b>API Configuration Structure</b> | T_RL_API_SENS_PER_CHIRP_CFG |
| <b>API Response Structure</b>      | None                        |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PER_CHIRP_CFG           ((UINT16)0x0044U)
// API Function Definition
T_RETURNTYPE rl_sensPerChirpCfg(UINT8 c_devIndex, const T_RL_API_SENS_PER_CHIRP_CFG
→ *p_apiCmdData);
```

► **Configuration C Structure**

**Table 2.39:** T\_RL\_API\_SENS\_PER\_CHIRP\_CFG

| Field           | Data Type  | Size      | Offset |
|-----------------|------------|-----------|--------|
| h_ParamArrayLen | UINT16[12] | 24        | 0      |
| h_ParamRptCount | UINT16[12] | 24        | 24     |
| w_Reserve1      | UINT32     | 4         | 48     |
| Total           |            | <b>52</b> |        |

**Configuration Fields**► **h\_ParamArrayLen**

Array of the Per-Chirp LUT lengths for all the supported per-chirp parameters.

Each entry in this array represents number of configurations (not memory size) for the corresponding per-chirp LUT parameter.

Valid Range: [1, 4096]

Byte-wise description is as follows:

| Bytes        | Description                                        |
|--------------|----------------------------------------------------|
| Bytes[1:0]   | Number of entries in Start Frequency Per-Chirp LUT |
| Bytes[3:2]   | Number of entries in Chirp Slope Per-Chirp LUT     |
| Bytes[5:4]   | Number of entries in Chirp Idle Time Per-Chirp LUT |
| Bytes[7:6]   | Number of entries in ADC Start Time Per-Chirp LUT  |
| Bytes[9:8]   | Number of entries in Tx Start Time Per-Chirp LUT   |
| Bytes[11:10] | Number of entries in Tx Enable Per-Chirp LUT       |
| Bytes[13:12] | Number of entries in Tx BPM Enable Per-Chirp LUT   |
| Bytes[23:14] | Reserved                                           |

LUT length should be 0 for the disable per-chirp parameters.

#### ► h\_ParamRptCount

Array of repetition count for each entry in the per-chirp LUT for all the supported per-chirp parameters.

This parameter defines the number of time a particular entry in the LUT will be repeated before reading a new value from the buffer. This feature can be used to reduce the LUT size if same configuration is used for N consecutive chirps.

Valid Range: [1, 32768]

Byte-wise description is as follows:

| Bytes        | Description                                        |
|--------------|----------------------------------------------------|
| Bytes[1:0]   | Repetition count for Start Frequency Per-Chirp LUT |
| Bytes[3:2]   | Repetition count for Chirp Slope Per-Chirp LUT     |
| Bytes[5:4]   | Repetition count for Chirp Idle Time Per-Chirp LUT |
| Bytes[7:6]   | Repetition count for ADC Start Time Per-Chirp LUT  |
| Bytes[9:8]   | Repetition count for Tx Start Time Per-Chirp LUT   |
| Bytes[11:10] | Repetition count for Tx Enable Per-Chirp LUT       |
| Bytes[13:12] | Repetition count for Tx BPM Enable Per-Chirp LUT   |
| Bytes[23:14] | Reserved                                           |

Repetition count should be 0 for the disable per-chirp parameters.

#### 2.4.6 Sensor Per-Chirp Configuration Get API

This API reads the hardware registers and returns the per-chirp LUT configuration done using the [Sensor Per-Chirp Configuration API](#).

## API Definition

|                                    |                             |
|------------------------------------|-----------------------------|
| <b>API Index</b>                   | 0x0045                      |
| <b>API Function Name</b>           | rl_sensPerChirpCfgGet       |
| <b>API Configuration Structure</b> | None                        |
| <b>API Response Structure</b>      | T_RL_API_SENS_PER_CHIRP_CFG |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PER_CHIRP_CFG_GET           ((UINT16)0x0045U)
// API Function Definition
T_RETURNTYPE rl_sensPerChirpCfgGet(UINT8 c_devIndex, T_RL_API_SENS_PER_CHIRP_CFG
→ *p_apiResData);
```

### 2.4.7 Sensor Per-Chirp Control API

This API defines which per-chirp parameters are controlled using the LUTs. Refer [Sensor Per-Chirp Configuration API](#) for more details about the per-chirp LUTs and configurations.

#### Warning

- Per-chirp configurations are directly written to the hardware registers and hence will not be retained across deep-sleep. Application must re-issue this API after waking up from deep sleep.
- This API configurations will be ignored in CW Mode

## API Definition

|                                    |                              |
|------------------------------------|------------------------------|
| <b>API Index</b>                   |                              |
| <b>API Function Name</b>           | rl_sensPerChirpCtrl          |
| <b>API Configuration Structure</b> | T_RL_API_SENS_PER_CHIRP_CTRL |
| <b>API Response Structure</b>      | None                         |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PER_CHIRP_CTRL           ((UINT16)0x0046U)
// API Function Definition
T_RETURNTYPE rl_sensPerChirpCtrl(UINT8 c_devIndex, const T_RL_API_SENS_PER_CHIRP_CTRL
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.40:** T\_RL\_API\_SENS\_PER\_CHIRP\_CTRL

| Field                | Data Type  | Size | Offset    |
|----------------------|------------|------|-----------|
| h_PerChirpParamCtrl  | UINT16     | 2    | 0         |
| h_Reserved1          | UINT16     | 2    | 2         |
| h_ParamArrayStartAdd | UINT16[12] | 24   | 4         |
| w_Reserved2          | UINT32     | 4    | 28        |
| w_Reserved3          | UINT32     | 4    | 32        |
| Total                |            |      | <b>36</b> |

### Configuration Fields

► h\_PerChirpParamCtrl

Per-chirp parameter enable control mask.

This is a bit-mask to select which per-chirps parameters should be read from the LUTs.

| Bit Value | Description                                                                                                                                                  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | Per-chirp parameter is disabled and the parameter value will be used from <a href="#">Configuration Fields</a>                                               |
| 1         | Per-chirp parameter is enabled and the parameter value will be picked from the PER_CHIRP_RAM based on configurations in <a href="#">Configuration Fields</a> |

Bitwise description of the field is as follows:

| Bit        | Description                                      |
|------------|--------------------------------------------------|
| Bit[0]     | Enable control for Start Frequency Per-Chirp LUT |
| Bit[1]     | Enable control for Chirp Slope Per-Chirp LUT     |
| Bit[2]     | Enable control for Chirp Idle Time Per-Chirp LUT |
| Bit[3]     | Enable control for ADC Start Time Per-Chirp LUT  |
| Bit[4]     | Enable control for Tx Start Time Per-Chirp LUT   |
| Bit[5]     | Enable control for Tx Enable Per-Chirp LUT       |
| Bit[6]     | Enable control for Tx BPM Enable Per-Chirp LUT   |
| Bits[15:7] | Reserved                                         |

► `h_ParamArrayStartAdd`

Array of LUT offset offsets for all supported per-chirp parameters.

Entries in this array defines the starting memory location of the per-chirp LUT of the corresponding parameter. These offsets must be multiple of 4 and defined with respect to the start of the PER\_CHIRP\_RAM.

Byte-wise description of the array is as follows:

| Bytes        | Description                              |
|--------------|------------------------------------------|
| Bytes[1:0]   | Offset for Start Frequency Per-Chirp LUT |
| Bytes[3:2]   | Offset for Chirp Slope Per-Chirp LUT     |
| Bytes[5:4]   | Offset for Chirp Idle Time Per-Chirp LUT |
| Bytes[7:6]   | Offset for ADC Start Time Per-Chirp LUT  |
| Bytes[9:8]   | Offset for Tx Start Time Per-Chirp LUT   |
| Bytes[11:10] | Offset for Tx Enable Per-Chirp LUT       |
| Bytes[13:12] | Offset for Tx BPM Enable Per-Chirp LUT   |
| Bytes[23:14] | Reserved                                 |

Offset count should be 0 for the disable per-chirp parameters.

#### 2.4.8 Sensor Per-Chirp Control Get API

This API reads the hardware registers and returns the per-chirp LUT configuration done using the [Sensor Per-Chirp Control API](#).

##### API Definition

|                                    |                                                           |
|------------------------------------|-----------------------------------------------------------|
| <b>API Index</b>                   | 0x0047                                                    |
| <b>API Function Name</b>           | <code>rl_sensPerChirpCtrlGet</code>                       |
| <b>API Configuration Structure</b> | None                                                      |
| <b>API Response Structure</b>      | <a href="#"><code>T_RL_API_SENS_PER_CHIRP_CTRL</code></a> |

► `API Function`

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_PER_CHIRP_CTRL_GET ((UINT16)0x0047U)
// API Function Definition
T_RETURNTYPE rl_sensPerChirpCtrlGet(UINT8 c_devIndex, T_RL_API_SENS_PER_CHIRP_CTRL
→ *p_apiResData);
```

## 2.4.9 Sensor Frame Configuration API

Frame configuration defines how the chirps are grouped in a transmission. The API configures parameters like number of chirps, burst and frames and timings. Please refer the important terms and descriptions in the [mmWave Sensor APIs](#) for more details.

**Warning** Profile configurations are directly written to the hardware registers and hence will not be retained across deep-sleep. Application must re-issue this API after waking up from deep sleep.

### API Definition

|                                    |                                         |
|------------------------------------|-----------------------------------------|
| <b>API Index</b>                   | 0x0048                                  |
| <b>API Function Name</b>           | rl_sensFrameCfg                         |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_SENS_FRAME_CFG</a> |
| <b>API Response Structure</b>      | None                                    |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_FRAME_CFG ((UINT16)0x0048U)
// API Function Definition
T_RETURNTYPE rl_sensFrameCfg(UINT8 c_devIndex, const T_RL_API_SENS_FRAME_CFG
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.41:** T\_RL\_API\_SENS\_FRAME\_CFG

| Field                             | Data Type | Size      | Offset |
|-----------------------------------|-----------|-----------|--------|
| <code>h_NumOfChirpsInBurst</code> | UINT16    | 2         | 0      |
| <code>c_NumOfChirpsAccum</code>   | UINT8     | 1         | 2      |
| <code>c_MiscSetupMask</code>      | UINT8     | 1         | 3      |
| <code>w_BurstPeriodicity</code>   | UINT32    | 4         | 4      |
| <code>h_NumOfBurstsInFrame</code> | UINT16    | 2         | 8      |
| <code>h_Reserved1</code>          | UINT16    | 2         | 10     |
| <code>w_FramePeriodicity</code>   | UINT32    | 4         | 12     |
| <code>h_NumOfFrames</code>        | UINT16    | 2         | 16     |
| <code>h_Reserved2</code>          | UINT16    | 2         | 18     |
| <code>w_FrameEvent0TimeCfg</code> | UINT32    | 4         | 20     |
| <code>w_FrameEvent1TimeCfg</code> | UINT32    | 4         | 24     |
| <code>w_Reserved3</code>          | UINT32    | 4         | 28     |
| Total                             |           | <b>32</b> |        |

### Configuration Fields

► `h_NumOfChirpsInBurst`

Number of chirps in a burst.

Valid Range: [1, 65535]

► `c_NumOfChirpsAccum`

Number of chirp accumulations per chirp.

mmWave Low devices provide hardware level time domain accumulation for the chirps. When this feature is enabled, the hardware internally triggers multiple chirps with identical configurations and sums the corresponding ADC samples before storing them to ADC buffer. This feature can be used to increase the SNR without increasing the number of chirps to be processed.

Valid values for the chirp accumulation are as follows:

| Value       | Description                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0 (Default) | Chirp accumulation is disabled                                                                                                       |
| [2,64]      | Chirp accumulation is enabled<br>The hardware is internally trigger multiple chirps, same as this value, and accumulate the ADC data |
| 1 (INVALID) | Invalid Value                                                                                                                        |

**Warning** Actual number of chirps in a burst is `h_NumOfChirpsInBurst`  $\times$  `max(1, c_NumOfChirpsAccum)`.

#### ► `c_MiscSetupMask`

##### Miscellaneous Setup Mask

This mask controls the following miscellaneous features:

| Bit        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit [0]    | <p><b>Skip Frame Timer Configuration</b></p> <ul style="list-style-type: none"> <li><u>Value 0</u> (Default): Configure both Frame Timer and Chirp Timer</li> <li><u>Value 1</u>: Configure only Chirp Timer and skip Frame Timer</li> </ul> <p><u>Use Case</u>: Frame configuration API configures burst related information to Chirp Timer, which is responsible for triggering bursts and chirps. This peripheral is associated with FECSS Sub-system. All the frame related parameters are passed to a separate peripheral called Frame Timer which is associated with AppSS. Since frame timer runs on the XTAL, it can run in background even when FECSS and AppSS are powered down in inter-framer duration. Chirp timer (CT) runs on the APLL clock and hence loses all the configurations ones FECSS is powered off. CT must be reconfigured after exit from sleep. This option should be enabled only to configure CT while FT is still running</p> |
| Bits [7:1] | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### ► `w_BurstPeriodicity`

Burst periodicity count.

This parameter configures the 24-bit counter which generates the Burst Start event. Tick duration of this counter depends on the time resolution configured in [FECSS Device Power On API](#).

| Timer Resolution                                           | Burst Periodicity Definition                                                                                        |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| High Resolution<br>( <code>c_ChirpTimerResol:b1=1</code> ) | $1LSB = 8/APLL\_FREQ$ , (20ns With 40 MHz XTAL).<br>Valid Range: [10, 16777215] ([0.2 us, 335 ms] for 40 MHz XTAL)  |
| Low Resolution<br>( <code>c_ChirpTimerResol:b1=0</code> )  | $1LSB = 40/APLL\_FREQ$ , (100ns With 40 MHz XTAL).<br>Valid Range: [10, 16777215] ([1 us, 1677 ms] for 40 MHz XTAL) |

#### ► `h_NumOfBurstsInFrame`

Number of bursts in a frame.

Valid Range: [1, 4096]

► **w\_FramePeriodicity**

Frame periodicity count.

This parameters configures the 32-bit counter running on XTAL which generates the Frame Start event.

| XTAL_FREQ | 1 LSB of Frame Periodicity Timer |
|-----------|----------------------------------|
| 25.0 MHz  | 40 ns                            |
| 26.0 MHz  | 38.461 ns                        |
| 38.4 MHz  | 26.042 ns                        |
| 40.0 MHz  | 25 ns                            |

Valid Range: [100, 2<sup>32</sup>)

**Note** This parameter is not applicable for hardware triggered frames

► **h\_NumOfFrames**

Number of frames in a trigger.

Valid Range: [0, 65535]

Setting number of frames to 0 results in infinite frames.

► **w\_FrameEvent0TimeCfg**

Frame Timer Event 0 Interrupt Time Period.

Frame timer hardware modules two user configurable events generated periodically with respect to the Frame Start event. These events can be used to schedule tasks with respect to the Frame Start of current frame, e.g. waking up FECSS from sleep just before the next frame starts and re-configure it.

These event counters, just like Frame Start run on XTAL. The application should disable these interrupts in AppSS core if they are not being used.

Valid Range: [100, 2<sup>32</sup>)

► **w\_FrameEvent1TimeCfg**

Frame Timer Event 1 Interrupt Time Period.

Please refer [w\\_FrameEvent0TimeCfg](#) for detailed explanation.

### Calculating Burst and Frame Period

Following table describes the recommended method to calculate burst and frame periods.

**Note** All the time variables used in the following table represent absolute time values in us and should be scaled appropriately.

e.g. [h\\_ChirpRampEndTime](#) represents the Ramp End Time in us, the actual variable value which is passed to the API depends on timer resolution.

| Variable                                                   | Calculation Steps                                                              |
|------------------------------------------------------------|--------------------------------------------------------------------------------|
| Total Number of Chirps in a Burst<br><i>TotalNumChirps</i> | <code>h_NumOfChirpsInBurst × max(1, c_NumOfChirpsAccum)</code>                 |
| Burst Idle Time<br><i>BurstIdleTime</i>                    | <u>Note:</u> This time should be grater then the <i>MinBurstIdleTime</i>       |
| Burst Periodicity<br><i>w_BurstPeriodicity</i>             | $TotalNumChirps \times (h_ChirpRampEndTime + h_ChirpIdleTime) + BurstIdleTime$ |
| Frame Idle Time<br><i>FrameIdleTime</i>                    | <u>Note:</u> This time should be grater then the <i>MinFrameIdleTime</i>       |
| Frame Period<br><i>w_FramePeriodicity</i>                  | $(h_NumOfBurstsInFrame \times w_BurstPeriodicity) + FrameIdleTime$             |

## 2.4.10 Sensor Frame Configuration Get API

This API reads the hardware registers and returns the frame configuration done using the [Sensor Frame Configuration API](#).

### API Definition

|                                    |                                      |
|------------------------------------|--------------------------------------|
| <b>API Index</b>                   | 0x0049                               |
| <b>API Function Name</b>           | <code>rl_sensFrameCfgGet</code>      |
| <b>API Configuration Structure</b> | None                                 |
| <b>API Response Structure</b>      | <code>T_RL_API_SENS_FRAME_CFG</code> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_FRAME_CFG_GET ((UINT16)0x0049U)
// API Function Definition
T_RETURNTYPE rl_sensFrameCfgGet(UINT8 c_devIndex, T_RL_API_SENS_FRAME_CFG *p_apiCmdData);
```

## 2.4.11 Sensor Start API

This API controls the frame trigger logic and associated configurations. The mmWave Low devices support three categories of trigger modes:

- Software Trigger Mode: Frames are triggered by the API call itself.
- Hardware Trigger Mode: Frame Timer waits for a rising edge on a DIG\_SYNC\_IN input pin to start the frames. This feature can be used to synchronize frames with external host. The mode `h_NumOfFrames`

is ignored and the hardware trigger only one frame at a time and the application software has to re-issue the command.

- CW Mode: In this mode enables the transmission in CW mode.

**Warning** Application should not issue this API while frames are running. [Sensor Status Get API](#) should be used to determine the current state.

Further details are mentioned in the API parameters.

### API Definition

|                                    |                                           |
|------------------------------------|-------------------------------------------|
| <b>API Index</b>                   | 0x004A                                    |
| <b>API Function Name</b>           | rl_sensSensorStart                        |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_SENSOR_START_CMD</a> |
| <b>API Response Structure</b>      | None                                      |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_START ((UINT16)0x004AU)
// API Function Definition
T_RETURNTYPE rl_sensSensorStart(UINT8 c_devIndex, const T_RL_API_SENSOR_START_CMD
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.43:** T\_RL\_API\_SENSOR\_START\_CMD

| Field               | Data Type | Size | Offset |
|---------------------|-----------|------|--------|
| c_FrameTrigMode     | UINT8     | 1    | 0      |
| c_ChirpStartSigLbEn | UINT8     | 1    | 1      |
| c_FrameLivMonEn     | UINT8     | 1    | 2      |
| c_Reserved          | UINT8     | 1    | 3      |
| w_FrameTrigTimerVal | UINT32    | 4    | 4      |
| w_Reserved1         | UINT32    | 4    | 8      |
| Total               |           | 12   |        |

## Configuration Fields

### ► c\_FrameTrigMode

Frame Trigger Mode Control.

The mmWave Low devices support following types of trigger mode:

| Trigger Mode                       | mmWaveLink Macro                | Value |
|------------------------------------|---------------------------------|-------|
| Software Immediate Trigger Mode    | M_RL_SENS_FRAME_SW_TRIG         | 0     |
| Software Timer Trigger Mode        | M_RL_SENS_FRAME_SW_TIMER_TRIG   | 1     |
| Hardware Triggered Mode            | M_RL_SENS_FRAME_HW_LOW_PWR_TRIG | 2     |
| Hardware Triggered Low Jitter Mode | M_RL_SENS_FRAME_HW_LOW_JIT_TRIG | 3     |
| CW Trigger Mode                    | M_RL_SENS_FRAME_CW_CZ_TRIG      | 4     |
| Chirp Timer Override Mode          | M_RL_SENS_FRAME_CT_OVRD_TRIG    | 5     |

#### **Software Immediate Trigger Mode**

In this mode, Frame Start event is generated immediately after receiving the API. Frame Trimer starts the Chirp Timer after RFS completes the first Frame Start event (*FrameStartTime*). First chirp starts after the RFS completes the first Burst Start event (*BurstStartTime*).

#### **Software Timer Trigger Mode**

This mode is almost same as the software trigger mode, except for the additional delay in the first Frame Start event. The Frame Timer waits for the internal free running counter to reach the value defined by *w\_FrameTrigTimerVal* before generating the first Frame Start. This provides a controlled way to delay frame trigger. Subsequent Frame Starts are generated according to the *w\_FramePeriodicity*.

#### **Hardware Triggered Mode**

In Hardware triggered mode, Frame Timer waits for a rising edge on the DIG\_SYNC\_IN input pin and then generates the Frame Start event. After that the burst and chirps are scheduled similar to the software triggered mode.

Low power mode samples the rising edge on the XTAL clock resulting into higher frame start jitter.

#### **Warnings**

- Application should ensure that the sensor start API is issued at least 10us before the rising edge on the DIG\_SYNC\_IN input pin.
- w\_FramePeriodicity* and *h\_NumOfFrames* are not applicable in this mode.
- FECSS and APPLL clocks must be powered on and configured before calling the sensor start API.

#### **Hardware Triggered Low Jitter Mode**

This mode is similar to the Hardware Triggered mode, except that the high frequency APPLL clock is used to sample the DIG\_SYNC\_IN input pin. Higher sampling clock reduces frame start jitter.

**Warnings**

- Application should ensure that the sensor start API is issued at least 35us before the rising edge on the DIG\_SYNC\_IN input pin.
- `w_FramePeriodicity` and `h_NumOfFrames` are not applicable in this mode.
- FECSS and APLL clocks must be powered on and configured before calling the sensor start API.

**CW Trigger Mode**

This mode enables the CW mode transmission at a constant frequency defined by `w_ChirpRfFreqStart` with 0 slope. [Sensor Stop API](#) must be issued to stop the transmission.

**Warnings**

- This mode should be used only for debugging and testing purpose.
- Minimum 100us setup time is required before the transmission begins.

**Chirp Timer Override Mode**

This is an internal test mode in which a single frame triggered directly using the Chirp Timer. Application should not use this mode.

► `c_ChirpStartSigLbEn`

This field is reserved in Single Chirp mode.

► `c_FrameLivMonEn`

Live monitor enable control.

This field controls which live monitors are enabled during the frame trigger. The mask contains 1-bit per live monitor, setting the corresponding bit high in the mask will enable the monitor. mmWave Low devices support following live monitors:

| Bit      | Description                                                                                                                                                                                                                                              |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]   | <b>Synthesizer Frequency Live Monitor</b><br>The monitor must be configured using <a href="#">FECSS Synthesizer Frequency Live Monitor Configuration API</a> before calling sensor start<br>mmWaveLink Macro: <code>M_RL_SENS_LIVE_MON_SYNTH_FREQ</code> |
| Bit[1]   | <b>Rx ADC Saturation Live Monitor</b><br>The monitor must be configured using <a href="#">FECSS Rx Saturation Live Monitor Configuration API</a> before calling sensor start.<br>mmWaveLink Macro: <code>M_RL_SENS_LIVE_MON_RX_SATURATION</code>         |
| Bit[7:2] | Reserved                                                                                                                                                                                                                                                 |

► `w_FrameTrigTimerVal`

Frame trigger delay timer value.

This value is applicable only in Software Timer Trigger Mode. The Frame Timer hardware contains a reference free running 32-bit up-counter which runs on XTAL clock. The counter starts at value 0 at device power-up and rolls over after counting till  $2^{32} - 1$ . In timer trigger mode, Frame Timer waits for the internal reference

counter to reach the value specified in `w_FrameTrigTimerVal` before issuing first Frame Start. Current value of the reference counter can be read using [Sensor Status Get API](#).

Valid Range: [0, 2<sup>32</sup>)

## 2.4.12 Sensor Stop API

Sensor stop API stops the device transmission by sending stop signals to the Frame Timer and Chirp Timer modules. The application should issue this API only after verifying the status of the Sensor using [Sensor Status Get API](#).

### API Definition

|                                    |                                          |
|------------------------------------|------------------------------------------|
| <b>API Index</b>                   | 0x004B                                   |
| <b>API Function Name</b>           | <code>rl_sensSensorStop</code>           |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_SENSOR_STOP_CMD</a> |
| <b>API Response Structure</b>      | None                                     |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_STOP ((UINT16)0x004BU)
// API Function Definition
T_RETURNTYPE rl_sensSensorStop(UINT8 c_devIndex, const T_RL_API_SENSOR_STOP_CMD
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.44:** T\_RL\_API\_SENSOR\_STOP\_CMD

| Field                        | Data Type | Size | Offset |
|------------------------------|-----------|------|--------|
| <code>c_FrameStopMode</code> | UINT8     | 1    | 0      |
| <code>c_Reserve</code>       | UINT8     | 1    | 1      |
| <code>h_Reserve1</code>      | UINT16    | 2    | 2      |
| <code>w_Reserve2</code>      | UINT32    | 4    | 4      |
| Total                        |           | 8    |        |

### Configuration Fields

#### ► `c_FrameStopMode`

mmWave Low devices support stopping frames in following modes:

**Table 2.45:** Frame Stop Modes

| Value | mmWaveLink Macro           | Description                                                                                                                                                                                                                                                                                   |
|-------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | M_RL_SENS_STOP_FRAME       | <b>Stop at Frame Boundary</b><br>This mode stops the transmission after completion of currently on-going frame. Essentially it stops the Frame Timer from generating more Frame Start events. Application can use this mode to stop the frames early or interrupt infinite frame transmission |
| 1     | M_RL_SENS_STOP_CWCZ_MODE   | <b>Stop CW Mode</b><br>This mode is used to stop the CW mode transfer.                                                                                                                                                                                                                        |
| 2     | M_RL_SENS_FORCE_STOP_FRAME | <b>Forced Stop</b><br>This is an error-recovery mode which immediately resets the Frame Timer and Chirp Timer. Chirp and Frame events may not be generated in this mode.                                                                                                                      |

**Warning**

- Application should use the [Sensor Status Get API](#) API to verify after stopping the frames in M\_RL\_SENS\_STOP\_FRAME to verify the frames have stopped. The application may have to wait for one complete frame period before getting frame stop.
- Unnecessary Sensor Stop API should be avoided. The Frame Timer latches Frame Stop command in hardware registers which takes effect at the end of current frame. Frame Stop API issued when Frame Timer has already stopped will result in un-intended stop in the next frame trigger because of the latched stop bit.
- Application should wait for FECSS to complete Burst End ([BurstEndTime](#)) and Frame End ([FrameEndTime](#)) activities after receiving the Frame Stop conformation in any mode.

Most reliable method to stop the frames without going in deep sleep is as follows:

1. Stop the frames using M\_RL\_SENS\_STOP\_FRAME mode.
2. Wait for 1 frame period or poll for the status using [Sensor Status Get API](#).
3. Reset the Frame Timer and Burst Timer IP forcefully using M\_RL\_SENS\_FORCE\_STOP\_FRAME mode.

The last step ensures that the hardware registers are free of any latched signals which could impact the next transmission. The last step could be ignored if the device enters in a sleep before next transmission (As power cycle will automatically reset the hardware registers).

### 2.4.13 Sensor Status Get API

This API returns current values of various sensor state parameters such as frame count, chirp count, etc. The API could also be used to get time stamp from the Frame Timer reference counter. It is recommended to read the status using this API before issuing [Sensor Start API](#).

#### API Definition

|                                    |                                            |
|------------------------------------|--------------------------------------------|
| <b>API Index</b>                   | 0x004C                                     |
| <b>API Function Name</b>           | rl_sensStatusGet                           |
| <b>API Configuration Structure</b> | None                                       |
| <b>API Response Structure</b>      | <a href="#">T_RL_API_SENSOR_STATUS_RSP</a> |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_STATUS_GET ((UINT16)0x004CU)
// API Function Definition
T_RETURNTYPE rl_sensStatusGet(UINT8 c_devIndex, T_RL_API_SENSOR_STATUS_RSP
    → *p_apiResData);
```

► Response C Structure

**Table 2.46:** T\_RL\_API\_SENSOR\_STATUS\_RSP

| Field                  | Data Type | Size | Offset    |
|------------------------|-----------|------|-----------|
| w_ChirpCount           | UINT32    | 4    | 0         |
| h_BurstCount           | UINT16    | 2    | 4         |
| h_FrameCount           | UINT16    | 2    | 6         |
| w_FrameRefTimerVal     | UINT32    | 4    | 8         |
| w_BurstPeriodTimerVal  | UINT32    | 4    | 12        |
| w_FramePeriodTimerVal  | UINT32    | 4    | 16        |
| c_FrameStartStopStatus | UINT8     | 1    | 20        |
| c_Reserved1            | UINT8     | 1    | 21        |
| h_Reserved2            | UINT16    | 2    | 22        |
| w_Reserved3            | UINT32[2] | 8    | 24        |
| Total                  |           |      | <b>32</b> |

**Response Fields**

► w\_ChirpCount

Number of Chirps Triggered.

This value indicates the number of chirps triggered in the current burst so far. The value starts at 0 for the first chirp and counts up to [h\\_NumOfChirpsInBurst](#) – 1 for the current burst.

Valid Range: [0, 65534]

► h\_BurstCount

Number of Bursts Triggered.

This value indicates the number of bursts triggered in the current frame so far. The value starts at 0 for the first burst and counts up to [h\\_NumOfBurstsInFrame](#) – 1 for the current frame.

Valid Range: [0, 4095]

► **h\_FrameCount**

Number of Frames Triggered.

This value indicates the number of frames triggered in the current trigger so far. The value starts at 0 for the first frame and counts up to [h\\_NumOfFrames](#) – 1 for the current trigger.

In case of infinite frames, the counter will roll over after reaching the maximum value.

Valid Range: [0,65534]

► **w\_FrameRefTimerVal**

Frame Timer Reference Counter Value.

This value indicates the current count of the free running 32-bit up-counter present in the Frame Timer hardware module which runs on XTAL clock. The counter starts at value 0 at device power-up and rolls over after counting till  $2^{32} - 1$ .

| XTAL_FREQ | 1 LSB of the Counter |
|-----------|----------------------|
| 25.0 MHz  | 40 ns                |
| 26.0 MHz  | 38.461 ns            |
| 38.4 MHz  | 26.042 ns            |
| 40.0 MHz  | 25 ns                |

► **w\_BurstPeriodTimerVal**

Remaining Burst Period Timer Value.

The Chirp Timer hardware contains a decrementing counter to track the burst period. This counter runs on a APLL derived clock which runs at *APLL/4* (same as Rx ADC). The counter loads the start value according to the following table upon receiving Burst Start event and counts down to 0. Running value of this field indicates remaining time for the current burst (including idle time). If applicable, new Burst Start event will be generated once the counter reaches zero indicating start of a new burst.

Resolution:  $1LSB = 4/APLL\_FREQ$

| Time Resolution                                               | Starting Value of the Counter        |
|---------------------------------------------------------------|--------------------------------------|
| High Resolution<br>( <a href="#">c_ChirpTimerResol</a> :b1=1) | $(2 \times w_BurstPeriodicity) - 1$  |
| Low Resolution<br>( <a href="#">c_ChirpTimerResol</a> :b1=0)  | $(10 \times w_BurstPeriodicity) - 1$ |

► **w\_FramePeriodTimerVal**

Remaining Frame Period Timer Value.

The Frame Timer hardware contains a decrementing counter to track the frame period. This counter runs on a XTAL clock. The counter loads the counter with [w\\_FramePeriodicity](#) – 1 upon receiving Frame Start event and

counts down to 0. Running value of this field indicates remaining time for the current frame (including idle time). If applicable, new Frame Start event will be generated one the counter reaches zero indicating start of a new burst.

#### ► c\_FrameStartStopStatus

Frame Start and Stop Status.

These bits indicate if the frame start and stop commands are honored by the hardware modules. These bits are cleared in [Sensor Start API](#) before starting Frame Timer.

| Bit        | Description                                                                                                                                                                               |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit [0]    | <b>Frame Start Status</b><br>High value of this bit indicates that the Frame Timer has started after receiving frame <a href="#">Sensor Start API</a> in Software Immediate Trigger Mode. |
| Bit [1]    | <b>Frame Stop Status</b><br>High value of this indicates that the frames have been stopped after receiving the <a href="#">Sensor Stop API</a> .                                          |
| Bits [7:2] | Reserved                                                                                                                                                                                  |

#### ► Detecting Burstand Frame Boundaries

There are two methods to detect burst and frame boundaries

- Polling Method: Application can poll on the [Sensor Status Get API](#) to determine current state
- Interrupt Method: The Application can enable following interrupts to detect required events.
  - Burst Start or Burst End Interrupt IRQ\_31
  - Frame End Interrupt IRQ\_32
  - Frame Start Interrupt IRQ\_33

Note: Burst Start and Burst End interrupts are Muxed. Please refer Technical Reference manual for more details

**Note** The RFS firmware also keep track of the burst and frame events and updates the count in shared memory. These counts can be accessed directly using mmWaveLink macro M\_FE\_RFS\_SENS\_STATUS\_START\_ADDRESS. These counts also include the calibration and monitoring events and hence should be used only for debug.

#### 2.4.14 Sensor Dynamic Power Save Disable Configuration API

This API configures the dynamic power save disable settings. By default the Chirp Timer module turns off high power consuming modules in the inter-chirp idle time to save power. This API provides interface to override that feature.

mmWave Low devices do not provide option to disable inter-burst and inter-frame power saving, these features are enabled by default maximizing the power savings.

## API Definition

|                                    |                                |
|------------------------------------|--------------------------------|
| <b>API Index</b>                   | 0x004D                         |
| <b>API Function Name</b>           | rl_sensDynPwrSaveDis           |
| <b>API Configuration Structure</b> | T_RL_API_SENS_DYN_PWR_SAVE_DIS |
| <b>API Response Structure</b>      | None                           |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_DYN_PS_DIS ((UINT16)0x004DU)

// API Function Definition
T_RETURNTYPE rl_sensDynPwrSaveDis(UINT8 c_devIndex, const T_RL_API_SENS_DYN_PWR_SAVE_DIS
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.47:** T\_RL\_API\_SENS\_DYN\_PWR\_SAVE\_DIS

| Field             | Data Type | Size | Offset |
|-------------------|-----------|------|--------|
| c_InterChirpPsDis | UINT8     | 1    | 0      |
| c_Reserved        | UINT8     | 1    | 1      |
| h_Reserved        | UINT16    | 2    | 2      |
| w_Reserved1       | UINT32    | 4    | 4      |
| Total             |           | 8    |        |

## Configuration Fields

### ► c\_InterChirpPsDis

Inter-Chirp Dynamic Power Save Disable Mask.

Each bit in the mask represents a rapid enable signal controlled by the Chirp Timer. Setting the corresponding bit High will disable power saving associated with that signal. By default, all signals are enabled (Value: 0).

| Bit        | Description                    |
|------------|--------------------------------|
| Bit [0]    | Tx PA Power Save Disable       |
| Bit [1]    | Tx LO Power Save Disable       |
| Bit [2]    | Rx RF Power Save Disable       |
| Bit [3]    | Rx BaseBand Power Save Disable |
| Bit [4]    | Rx LO Power Save Disable       |
| Bits [7:5] | Reserved                       |

**Recommendation** Following table shows the recommended value of the `c_InterChirpPsDis` across use cases. Please note that the variables used in the following table represent absolute time values in us and should be scaled appropriately.

| Use Case                                                                             | <code>c_InterChirpPsDis</code>                          |
|--------------------------------------------------------------------------------------|---------------------------------------------------------|
| IF<br><code>(h_ChirpIdleTime &gt;= max(6us - xh_ChirpTxStartTime, 3.1us))</code>     | 0x00<br>Power Save Enabled                              |
| ELSEIF<br><code>(h_ChirpIdleTime &gt;= max(4us - xh_ChirpTxStartTime, 3.1us))</code> | 0x1C<br>Rx Power Save Disabled<br>Tx Power Save Enabled |
| ELSE                                                                                 | Unsupported Idle Time                                   |

Please refer [Burst Timing Constraints](#) for more details.

## 2.4.15 Sensor Dynamic Power Save Disable Configuration Get API

This API reads the hardware registers and returns the frame configuration done using the [Sensor Dynamic Power Save Disable Configuration API](#).

### API Definition

|                                    |                                             |
|------------------------------------|---------------------------------------------|
| <b>API Index</b>                   | 0x004E                                      |
| <b>API Function Name</b>           | <code>rl_sensDynPwrSaveStsGet</code>        |
| <b>API Configuration Structure</b> | None                                        |
| <b>API Response Structure</b>      | <code>T_RL_API_SENS_DYN_PWR_SAVE_DIS</code> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_DYN_PS_DIS_GET ((UINT16)0x004EU)

// API Function Definition
T_RETURNTYPE rl_sensDynPwrSaveStsGet(UINT8 c_devIndex, T_RL_API_SENS_DYN_PWR_SAVE_DIS
→ *p_apiResData);
```

## 2.4.16 Sensor Loopback Configuration API

This API configures the parameters required for various analog and digital loopbacks in the mmWave Low devices. This configuration is retained across deep sleep in the FECSS memory. Hence application can avoid reconfiguring it across deep sleep.

[Gray]Note Digital loopback uses a full-scale amplitude square wave signal generated from the loopback signal generator. This signal has inherent delay of 80ns and 180ns for Rx1 and Rx2 with respect to the Rx0, which results into phase shift across Rx channels.

### API Definition

|                                    |                            |
|------------------------------------|----------------------------|
| <b>API Index</b>                   | 0x004F                     |
| <b>API Function Name</b>           | rl_sensLoopBackCfg         |
| <b>API Configuration Structure</b> | T_RL_API_SENS_LOOPBACK_CFG |
| <b>API Response Structure</b>      | None                       |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_LB_CFG ((UINT16)0x004FU)
// API Function Definition
T_RETURNTYPE rl_sensLoopBackCfg(UINT8 c_devIndex, const T_RL_API_SENS_LOOPBACK_CFG
→ *p_apiCmdData);
```

### ► Configuration C Structure

Table 2.48: T\_RL\_API\_SENS\_LOOPBACK\_CFG

| Field                | Data Type | Size | Offset |
|----------------------|-----------|------|--------|
| c_LbFreqSel          | UINT8     | 1    | 0      |
| c_IfaLbGainIndex     | UINT8     | 1    | 1      |
| c_LoPaLbCmnGainIndex | UINT8     | 1    | 2      |
| c_LoLbGainIndex      | UINT8     | 1    | 3      |
| c_PaLbGainIndex      | UINT8     | 1    | 4      |
| c_Reserve1           | UINT8     | 1    | 5      |
| h_ExtLbTxBpmEnSel    | UINT16    | 2    | 6      |
| w_Reserve3           | UINT32[2] | 8    | 8      |
| Total                |           |      | 16     |

## Configuration Fields

► [c\\_LbFreqSel](#)

Loopback Signal Frequency Select.

This parameter controls the frequency of the loopback signal in IF domain across all loopbacks. The signal is derived from APLL clock according the following formula:

$$f_{LoopBack} = \frac{APLL\_FREQ}{16 \times c\_LbFreqSel}$$

Valid Range: [2, 200]

Following table shows the recommended loopback frequencies:

| c_LbFreqSel | Loopback Frequency |
|-------------|--------------------|
| 2           | 12.5 MHz           |
| 4           | 6.25 MHz           |
| 5           | 5 MHz              |
| 8           | 3.125 MHz          |
| 9           | 2.778 MHz          |
| 10          | 2.5 MHz            |
| 20          | 1.25 MHz           |
| 25          | 1 MHz              |
| 40          | 625 kHz            |
| 50          | 500 kHz            |
| 80          | 312.5 kHz          |
| 100         | 250 kHz            |
| 200         | 125 kHz            |

► [c\\_IfaLbGainIndex](#)

IFA Loopback Gain Index.

This parameter selects the IFA loopback gain and is applied only if IFA loopback is enabled using [c\\_LbEnable](#).

Following table lists the recommended values of the gain index for various gains.

| IFA Gain (dB) | c_IfaLbGainIndex | Low Bias Enable<br>c_IfaLbGainIndex[7] | Loopback DAC Code<br>c_IfaLbGainIndex[6:0] |
|---------------|------------------|----------------------------------------|--------------------------------------------|
| -10           | 40               | 0                                      | 40                                         |
| -8            | 191              | 1                                      | 63                                         |
| -6            | 178              | 1                                      | 50                                         |
| -4            | 167              | 1                                      | 39                                         |
| -2            | 159              | 1                                      | 31                                         |
| 0             | 153              | 1                                      | 25                                         |
| 2             | 148              | 1                                      | 20                                         |
| 4             | 144              | 1                                      | 16                                         |
| 6             | 140              | 1                                      | 12                                         |
| 8             | 138              | 1                                      | 10                                         |
| 10            | 136              | 1                                      | 8                                          |

► **c\_LoPaLbCmnGainIndex**

LO and PA Loopback Common Loopback Buffer Gain Index.

This parameter determines the gain of the common buffer in PA and LO loopback paths. This field is applicable for both PA and LO loopbacks. Following table shows the buffer gain in dB for nominal process corner and temperature.

| Common Loopback Gain (dB) | c_LoPaLbCmnGainIndex |
|---------------------------|----------------------|
| 0                         | 48                   |
| -1                        | 29                   |
| -2                        | 25                   |
| -3                        | 24                   |
| -5                        | 23                   |
| -6                        | 22                   |
| -7                        | 21                   |
| -8                        | 20                   |
| -10                       | 19                   |
| -11                       | 18                   |
| -13                       | 17                   |

| Common Loopback Gain (dB) | c_LoPaLbCmnGainIndex |
|---------------------------|----------------------|
| -14                       | 16                   |
| -18                       | 15                   |
| -19                       | 0                    |

► **c\_LoLbGainIndex**

LO Loopback Buffer Gain Index.

This parameter controls the gain of the LO loopback buffer which follows the common buffer. The parameter is applicable only in LO loopback mode. Following table shows the buffer gain in dB for nominal process corner and temperature.

| LO Loopback Gain (dB) | c_LoLbGainIndex |
|-----------------------|-----------------|
| 0                     | 96              |
| -1                    | 51              |
| -2                    | 47              |
| -3                    | 44              |
| -4                    | 42              |
| -5                    | 40              |
| -6                    | 38              |
| -7                    | 36              |
| -8                    | 35              |
| -9                    | 34              |
| -10                   | 33              |
| -11                   | 32              |
| -12                   | 31              |
| -13                   | 30              |
| -14                   | 29              |
| -15                   | 28              |
| -16                   | 27              |
| -17                   | 26              |
| -18                   | 25              |

| LO Loopback Gain (dB) | c_LoLbGainIndex |
|-----------------------|-----------------|
| -19                   | 24              |
| -21                   | 23              |
| -22                   | 22              |
| -23                   | 21              |
| -25                   | 20              |
| -26                   | 19              |
| -27                   | 18              |
| -30                   | 0               |

► **c\_PaLbGainIndex**

PA Loopback Buffer Gain Index.

This parameter controls the gain of the LO loopback buffer which follows the common buffer. The parameter is applicable only in PA loopback mode. Following table shows the buffer gain in dB for nominal process corner and temperature.

| PA Loopback Gain (dB) | c_PaLbGainIndex |
|-----------------------|-----------------|
| 0                     | 48              |
| -1                    | 27              |
| -2                    | 25              |
| -3                    | 24              |
| -4                    | 23              |
| -5                    | 22              |
| -6                    | 21              |
| -7                    | 20              |
| -10                   | 19              |
| -11                   | 18              |
| -13                   | 17              |
| -15                   | 16              |
| -17                   | 15              |
| -18                   | 14              |

| PA Loopback Gain (dB) | c_PaLbGainIndex |
|-----------------------|-----------------|
| -19                   | 0               |

### ► h\_ExtLbTxBpmEnSel

External Waveguide Loopback Tx BPM Enable Mask.

This bit-mask controls channels on which Tx channels loopback signals drives the BPM bit. This parameter is applicable only when external waveguide loopback is enabled using [c\\_LbEnable](#) ans sensor is started in CW mode.

Each bit controls BPM enable on corresponding Tx channel.

| Bit        | Description                        |
|------------|------------------------------------|
| Bit [0]    | Enables CW Mode BPM on Tx0 Channel |
| Bit [1]    | Enables CW Mode BPM on Tx1 Channel |
| Bits [7:2] | Reserved                           |

### 2.4.17 Sensor Loopback Enable API

This API enables a selected loopback. The API assumes that the loopback settings are already configured using the [Sensor Loopback Configuration API](#).

#### Warning

- Loopback enable settings are not retained across FECSS power cycles. Hence loopback must be disabled before [FECSS Device Power OFF API](#).
- Loopback should be disabled before running all calibrations and monitors as well.

#### API Definition

|                                    |                                            |
|------------------------------------|--------------------------------------------|
| <b>API Index</b>                   | 0x0050                                     |
| <b>API Function Name</b>           | r1_sensLoopBackEna                         |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_SENS_LOOPBACK_ENA</a> |
| <b>API Response Structure</b>      | None                                       |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_SENS_LB_ENA ((UINT16)0x0050U)
// API Function Definition
T_RETURNTYPE r1_sensLoopBackEna(UINT8 c_devIndex, const T_RL_API_SENS_LOOPBACK_ENA
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.54:** T\_RL\_API\_SENS\_LOOPBACK\_ENA

| Field      | Data Type | Size | Offset   |
|------------|-----------|------|----------|
| c_LbEnable | UINT8     | 1    | 0        |
| c_Reserve1 | UINT8     | 1    | 1        |
| h_Reserve2 | UINT16    | 2    | 2        |
| w_Reserve3 | UINT32    | 4    | 4        |
| Total      |           |      | <b>8</b> |

**Configuration Fields**

► c\_LbEnable

Loopback Enable Control.

This parameter selects the loopback mode which should be applied in the front end.

| c_LbEnable | mmWaveLink Macro               | Description                        |
|------------|--------------------------------|------------------------------------|
| 0          | M_RL_SENS_LOOPBACK_DISABLE     | Disable All Loopbacks<br>(Default) |
| 1          | M_RL_SENS_LOOPBACK_DIG         | Enable Digital Loopback            |
| 2          | M_RL_SENS_LOOPBACK_IFA         | Enable IFA Loopback                |
| 3          | M_RL_SENS_LOOPBACK_LO          | Enable LO Loopback                 |
| 4          | M_RL_SENS_LOOPBACK_PA          | Enable PA Loopback                 |
| 5          | M_RL_SENS_LOOPBACK_EXTERNAL_WG | Enable External Waveguide Loopback |

## 2.5 mmWaveLink Monitor Configuration APIs

mmWaveLink Monitor APIs provide interface to configure and run the various monitoring features supported by the mmWave Radar devices.

**Note** Only selected set of monitors are enabled on non-functional safety enabled devices. Please refer [w\\_MonitorEnable](#) for more details.

The mmWaveLink Monitor module provides following APIs:

- FECSS Monitor Enable Trigger API
- FECSS Peak-Detector Debug Monitor API
- FECSS Tx Power Debug Monitor API
- FECSS Synthesizer Frequency Live Monitor Configuration API
- FECSS Rx Saturation Live Monitor Configuration API
- FECSS PLL Control Voltage Monitor Configuration API
- FECSS TxN-Rx Loopback Monitor Configuration API
- FECSS TxN Power Monitor Configuration API
- FECSS Tx Ball-Break Monitor Configuration API
- FECSS TxN DC Signal Monitor Configuration API
- FECSS Rx HPF and DC Signal Monitor Configuration API
- FECSS PM and Clock DC Signals Monitor Configuration API

Firmware assigns a unique monitor index to all the monitors. All monitor trigger and status fields use the same indices to map the monitors. mmWaveLink monitoring indices are as follows:

**Table 2.55:** mmWaveLink Monitoring Indices

|   | <b>mmWaveLink Macro</b> | <b>Definition</b>           |
|---|-------------------------|-----------------------------|
| 0 | M_RL_MON_PLL_CTRL_VOLT  | PLL Control Voltage Monitor |
| 1 | M_RL_MON_TX0_RX_LB      | Tx0 Rx-Tx Loopback Monitor  |
| 2 | M_RL_MON_TX1_RX_LB      | Tx1 Rx Loopback Monitor     |
| 3 | M_RL_MON_TX2_RX_LB      | Tx2 Rx Loopback Monitor     |
| 4 | M_RL_MON_TX3_RX_LB      | Tx3 Rx Loopback Monitor     |
| 5 | M_RL_MON_TX4_RX_LB      | Tx4 Rx Loopback Monitor     |
| 6 | M_RL_MON_TX5_RX_LB      | Tx5 Rx Loopback Monitor     |
| 7 | M_RL_MON_TX6_RX_LB      | Tx6 Rx Loopback Monitor     |
| 8 | M_RL_MON_TX7_RX_LB      | Tx7 Rx Loopback Monitor     |
| 9 | M_RL_MON_TX0_POWER      | Tx0 Power Monitor           |

|    | <b>mmWaveLink Macro</b>        | <b>Definition</b>                 |
|----|--------------------------------|-----------------------------------|
| 10 | M_RL_MON_TX1_POWER             | Tx1 Power Monitor                 |
| 11 | M_RL_MON_TX2_POWER             | Tx2 Power Monitor                 |
| 12 | M_RL_MON_TX3_POWER             | Tx3 Power Monitor                 |
| 13 | M_RL_MON_TX4_POWER             | Tx4 Power Monitor                 |
| 14 | M_RL_MON_TX5_POWER             | Tx5 Power Monitor                 |
| 15 | M_RL_MON_TX6_POWER             | Tx6 Power Monitor                 |
| 16 | M_RL_MON_TX7_POWER             | Tx7 Power Monitor                 |
| 17 | M_RL_MON_TX0_BB                | Tx0 Ball-Break Monitor            |
| 18 | M_RL_MON_TX1_BB                | Tx1 Ball-Break Monitor            |
| 19 | M_RL_MON_TX2_BB                | Tx2 Ball-Break Monitor            |
| 20 | M_RL_MON_TX3_BB                | Tx3 Ball-Break Monitor            |
| 21 | M_RL_MON_TX4_BB                | Tx4 Ball-Break Monitor            |
| 22 | M_RL_MON_TX5_BB                | Tx5 Ball-Break Monitor            |
| 23 | M_RL_MON_TX6_BB                | Tx6 Ball-Break Monitor            |
| 24 | M_RL_MON_TX7_BB                | Tx7 Ball-Break Monitor            |
| 25 | M_RL_MON_TX0_INTRNAL_DC_SIG    | Tx0 Internal DC Signal Monitor    |
| 26 | M_RL_MON_TX1_INTRNAL_DC_SIG    | Tx1 Internal DC Signal Monitor    |
| 27 | M_RL_MON_TX2_INTRNAL_DC_SIG    | Tx2 Internal DC Signal Monitor    |
| 28 | M_RL_MON_TX3_INTRNAL_DC_SIG    | Tx3 Internal DC Signal Monitor    |
| 29 | M_RL_MON_TX4_INTRNAL_DC_SIG    | Tx4 Internal DC Signal Monitor    |
| 30 | M_RL_MON_TX5_INTRNAL_DC_SIG    | Tx5 Internal DC Signal Monitor    |
| 31 | M_RL_MON_TX6_INTRNAL_DC_SIG    | Tx6 Internal DC Signal Monitor    |
| 32 | M_RL_MON_TX7_INTRNAL_DC_SIG    | Tx7 Internal DC Signal Monitor    |
| 33 | M_RL_MON_RX_HPF_INTRNAL_DC_SIG | Rx HPF and DC Signal Monitor      |
| 34 | M_RL_MON_PM_CLK_INTRNAL_DC_SIG | PM and Clock DC Signal Monitor    |
| 35 | M_RL_MON_DFE_BIST_FFT_CHECK    | DFE and BIST-FFT Monitor          |
| 36 | M_RL_MON_STATIC_REG_READBACK   | Static Register Read-Back Monitor |

Monitor responses are stored at a fixed address location in a shared memory between FECSS and AppSS cores. Application should read this memory upon monitor completion to get the results. Following structure shows the details about the response.

**Table 2.56:** T\_RL\_FE\_RFS\_IPC\_MON\_RESULT\_DATA\_STRUCT

| Field                               | Data Type                           | Size | Offset     |
|-------------------------------------|-------------------------------------|------|------------|
| T_RL_API_MON_TRIG_RESPONSE          | T_RL_API_MON_TRIG_RESPONSE          | 20   | 0x21200500 |
| T_RL_API_MON_LIVE_SYNTH_FREQ_RESULT | T_RL_API_MON_LIVE_SYNTH_FREQ_RESULT | 24   | 0x21200514 |
| T_RL_API_MON_PLL_CTRL_VOLT_RESULT   | T_RL_API_MON_PLL_CTRL_VOLT_RESULT   | 28   | 0x2120052c |
| T_RL_API_MON_TXN_RX_LB_RESULT       | T_RL_API_MON_TXN_RX_LB_RESULT[4]    | 224  | 0x21200548 |
| T_RL_API_MON_TXN_POWER_RESULT       | T_RL_API_MON_TXN_POWER_RESULT[4]    | 64   | 0x21200628 |
| T_RL_API_MON_TXN_BB_RESULT          | T_RL_API_MON_TXN_BB_RESULT[4]       | 64   | 0x21200668 |
| T_RL_API_MON_TXN_DCSIG_RESULT       | T_RL_API_MON_TXN_DCSIG_RESULT[4]    | 64   | 0x212006a8 |
| T_RL_API_MON_RX_HPF_DCSIG_RESULT    | T_RL_API_MON_RX_HPF_DCSIG_RESULT    | 36   | 0x212006e8 |
| T_RL_API_MON_PMCLK_DCSIG_RESULT     | T_RL_API_MON_PMCLK_DCSIG_RESULT     | 24   | 0x2120070c |
| w_Reserved1                         | UINT32[39]                          | 156  | 0x21200724 |
| Total                               |                                     |      | 704        |

**Note**

- All monitor configurations are stored in the FECSS IPC memory and will be retained across deep sleep if `c_RetentionMode` is enabled. Application can reduce overhead by avoiding reconfiguration in warm boot (`c_PowerMode`).
- DFE and BIST-FFT Monitor and Static Register Read-Back Monitor do not have any configuration or generate any response. Their pass/fail status is indicated in `w_MonitorStatus`.

### 2.5.1 FECSS Monitor Enable Trigger API

This API is used to trigger the monitors.

The API triggers all the enabled monitors and stores results in a predefined IPC RAM with fixed address location. The API immediately returns a response by acknowledging the trigger to unblock the Application. The RFS generates an interrupt to the application core upon completion to indicate monitoring done event. Application should call this API in inter-frame idle time and enable `FEC_MON_EVENT` (IRQ 4) to receive and respond to this event.

The API also provides mask to inject faults. RFS firmware automatically injects the all supported and enabled faults before running the corresponding monitor and removes it immediately, except for the faults enabled for live monitors. These faults must be disabled explicitly by calling the API again.

**Note**

- The collective execution status of all the monitors are stored in the address 0x21200500, upon receiving `FEC_MON_EVENT`, the APPSS can read this collective status before reading each of the individual results.
- RFS Firmware will not generate `FEC_MON_EVENT` (IRQ 4) if the API is issued with all monitors disabled.

**Warning**

- The application is responsible for reading out all the results from the predefined address.
- Faults supported by live monitors are not removed automatically.
- All loopbacks must be disabled before triggering monitors.
- Application must ensure sufficient idle is present in the idle time to complete all the enabled monitors.  
Refer [Monitor Execution Time](#) for execution time required per monitor.
- Live monitor faults must be disabled before running calibrations.

Following table shows the supported faults for the monitors: [Notation](#):

- X:** Recommended fault
- O:** Optional fault
- Blank Cell: Unsupported fault

| Monitor       | Synth Fault | Rx IFA Gain Fault | Rx High Noise Fault | HPF Cutoff Fault | Tx Gain Fault | Tx Phase Inversi Fault | GPAD Fault | BIST FFT Gain Fault | Static Reg Read-back Fault |
|---------------|-------------|-------------------|---------------------|------------------|---------------|------------------------|------------|---------------------|----------------------------|
| PLL_CTRL_VOLT | X           |                   |                     |                  |               |                        |            |                     |                            |
| TX0_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX1_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX2_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX3_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX4_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX5_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX6_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX7_RX_LB     |             | X                 |                     | O                | X             | X                      |            |                     |                            |
| TX0_POWER     |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX1_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX2_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX3_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX4_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX5_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX6_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX7_POWER     |             |                   |                     |                  |               | X                      |            |                     |                            |
| TX0_BB        |             |                   |                     |                  |               | X                      |            |                     |                            |

| Monitor               | Synth Fault | Rx IFA Gain Fault | Rx High Noise Fault | HPF Cutoff Fault | Tx Gain Fault | Tx Phase Inversi Fault | GPAD Fault | BIST FFT Gain Fault | Static Reg Read-back Fault |
|-----------------------|-------------|-------------------|---------------------|------------------|---------------|------------------------|------------|---------------------|----------------------------|
| TX1_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX2_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX3_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX4_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX5_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX6_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX7_BB                |             |                   |                     |                  | X             |                        |            |                     |                            |
| TX0_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX1_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX2_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX3_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX4_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX5_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX6_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| TX7_INTRNAL_DC_SIG    |             |                   |                     |                  |               |                        | X          |                     |                            |
| RX_HPF_INTRNAL_DC_SIG | O           |                   | X                   |                  |               |                        | X          |                     |                            |
| PM_CLK_INTRNAL_DC_SIG |             |                   |                     |                  |               |                        | X          |                     |                            |
| DFE_BIST_FFT_CHECK    |             |                   |                     |                  |               |                        |            | X                   |                            |
| STATIC_REG_READBACK   |             |                   |                     |                  |               |                        |            |                     | X                          |
| RX_SATURATION_LIVE    |             |                   | X                   |                  |               |                        |            |                     |                            |
| SYNTH_FREQUENCY_LIVE  | X           |                   |                     |                  |               |                        |            |                     |                            |

**API Definition**

|                                    |                            |
|------------------------------------|----------------------------|
| <b>API Index</b>                   | 0x0080U                    |
| <b>API Function Name</b>           | rl_monEnableTrig           |
| <b>API Configuration Structure</b> | T_RL_API_MON_ENABLE_TRIG   |
| <b>API Response Structure</b>      | None                       |
| <b>Monitor Response Structure</b>  | T_RL_API_MON_TRIG_RESPONSE |

## ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_ENABLE_TRIG           ((UINT16)0x0080U)
// API Function Definition
T_RETURNTYPE rl_monEnableTrig(UINT8 c_devIndex, const T_RL_API_MON_ENABLE_TRIG
→ *p_apiCmdData);
```

## ► Configuration C Structure

**Table 2.58:** T\_RL\_API\_MON\_ENABLE\_TRIG

| Field            | Data Type | Size      | Offset |
|------------------|-----------|-----------|--------|
| w_MonitorEnable  | UINT32[2] | 8         | 0      |
| w_FaultInjEnable | UINT32    | 4         | 8      |
| w_Reserve1       | UINT32    | 4         | 12     |
| w_Reserve2       | UINT32    | 4         | 16     |
| w_Reserve3       | UINT32    | 4         | 20     |
| Total            |           | <b>24</b> |        |

## ► Monitor Response C Structure

**Table 2.59:** T\_RL\_API\_MON\_TRIG\_RESPONSE

| Field           | Data Type | Size      | Offset |
|-----------------|-----------|-----------|--------|
| w_MonitorStatus | UINT32[2] | 8         | 0      |
| w_FrameCount    | UINT32    | 4         | 8      |
| w_Reserve2      | UINT32    | 4         | 12     |
| w_Reserve3      | UINT32    | 4         | 16     |
| Total           |           | <b>20</b> |        |

## Configuration Fields

### ► w\_MonitorEnable

FECSS Monitors enable control, 1-bit per monitor. Refer [mmWaveLink Monitoring Indices](#) for the bit indices.

| Value | Definition        |
|-------|-------------------|
| 0     | Monitor Disabled. |
| 1     | Monitor Enabled.  |

Following table shows the supported monitor enable mask for different devices:

**Table 2.60:** Supported Monitor Enable Masks

| Device Type              | Supported Monitor Mask                                             | Description                                                           |
|--------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------|
| Safety Enabled xWRL1432  | $w\_MonitorEnable[1] = 0x1E$<br>$w\_MonitorEnable[0] = 0x06060607$ | Tx[2:7] monitors are reserved                                         |
| Safety Enabled xWRL6432  | $w\_MonitorEnable[1] = 0x1E$<br>$w\_MonitorEnable[0] = 0x06060607$ | Tx[2:7] monitors are reserved                                         |
| Safety Disabled xWRL1432 | $w\_MonitorEnable[1] = 0x00$<br>$w\_MonitorEnable[0] = 0x00060006$ | Only Tx[0:1]-BallBreak and Tx[0:2]-Rx loopback monitors are supported |
| Safety Disabled xWRL6432 | $w\_MonitorEnable[1] = 0x00$<br>$w\_MonitorEnable[0] = 0x00060006$ | Only Tx[0:1]-BallBreak and Tx[0:2]-Rx loopback monitors are supported |

### ► w\_FaultInjEnable

FECSS monitors fault injection enable control, 1 bit control per monitor.

| Value | Definition                |
|-------|---------------------------|
| 0     | Fault Injection Disabled. |
| 1     | Fault Injection Enabled.  |

Bit Field Definition:

| Fault Index | mmWaveLink Macro                | Description                                                                                                  |
|-------------|---------------------------------|--------------------------------------------------------------------------------------------------------------|
| 0           | M_RL_MON_FAULT_SYNTH            | Synthesizer fault<br>This fault affects output frequency of the Synthesizer                                  |
| 1           | M_RL_MON_FAULT_RX_IFA_GAIN_DROP | Rx IFA gain drop fault                                                                                       |
| 2           | M_RL_MON_FAULT_RX_HIGH_NOISE    | Rx high noise fault<br>This fault injects high noise in the Rx chain which could result in Rx ADC saturation |

| Fault Index | mmWaveLink Macro                  | Description                                                                        |
|-------------|-----------------------------------|------------------------------------------------------------------------------------|
| 3           | M_RL_MON_FAULT_RX_HPF_HIGH_CUTOFF | Rx HPF cutoff fault                                                                |
| 4           | M_RL_MON_FAULT_TX_GAIN_DROP       | Tx gain drop fault                                                                 |
| 5           | M_RL_MON_FAULT_TX_PHASE_INVERSION | Tx phase inversion fault<br>This fault enforces BPM for all monitoring chirps      |
| 6           | M_RL_MON_FAULT_GPADC              | GPADC fault<br>This fault affects only the first measurement in DC signal monitors |
| 7           | M_RL_MON_FAULT_BIST_FFT_GAIN      | BIST FFT gain drop fault                                                           |
| 8           | M_RL_MON_FAULT_FECSS_STATIC_REG   | FECSS static register read-back fault                                              |

**Warning**

`M_RL_MON_FAULT_RX_IFA_GAIN_DROP` and `M_RL_MON_FAULT_TX_GAIN_DROP` should not be enabled together.

Tx gain drop fault causes a drop in both input power (`xh_RxInputPower`) as well as output powers (`xh_TxNRxLbPower` and `xh_TxNRxLbBpmPower`). Rx gain (computed by application software as the difference between output and input powers) may not necessarily show a fault with `M_RL_MON_FAULT_TX_GAIN_DROP`. For seeing a deterministic fault in computed Rx gain, both fault should not be enabled together.

### Monitor Response Fields

Monitor trigger response is stored in the IPC response structure. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the details.

► [w\\_MonitorStatus](#)

FECSS Monitors run status, 1 bit status per monitor. This is the response status of the current monitor enable command trigger. Application should check this response upon receiving the `FEC_MON_EVENT` (IRQ 4) event to check trigger stratus of the monitors.

| Value | Definition                                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Not Updated / Failed<br>Cleared bit indicated monitor run failed if the monitor is enabled in <a href="#">w_MonitorEnable</a> or monitored is not enabled |
| 1     | Monitor is triggered<br>Enabled Monitor has successfully executed and result in updated.                                                                  |

Refer [mmWaveLink Monitoring Indices](#) for the monitor indices.

► **w\_FrameCount**

Monitor report frame count.

RFS firmware maintains internal 32-bit count of the number of frames triggered from Cold Boot. This count is reported in this field to uniquely identify monitor triggers.

**Warning** Application has to handle the roll-over of the 32-bit counter, if any.

### 2.5.2 FECSS Peak-Detector Debug Monitor API

This API provides interface to measure RF power at various points in the RF signal chain using on-chip peak-detectors (PD) when issued in CW mode. PDs are uniquely identified using two parameters, PD LNA index and PD LNA Mux index. RFS firmware maintains the mapping for frequently used PDs (critical PDs). The API provides options to measure critical PDs directly using the internal mapping. Non-critical PD measurements require inputs from the API to identify PD.

**Warning**

- This API is only meant for debug purpose and must not be used to measure/estimate Tx power or achieve functional safety objectives.
- PD measurements could be unpredictable if sensor is not enabled in CW mode or not properly calibrated.

**Note** This API does not update the sensor state. Use rlsensSensorStart and [Sensor Stop API](#) to enable or disable the CW mode transmission.

#### API Definition

|                                    |                                              |
|------------------------------------|----------------------------------------------|
| <b>API Index</b>                   | 0x0081U                                      |
| <b>API Function Name</b>           | rl_monDbgPdMeas                              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_DBG_PD_MEAS_CMD</a> |
| <b>API Response Structure</b>      | <a href="#">T_RL_API_MON_DBG_PD_MEAS_RSP</a> |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_DBG_PD_PWR_MEAS           ((UINT16)0x0081U)
// API Function Definition
T_RETURNTYPE rl_monDbgPdMeas(UINT8 c_devIndex, const T_RL_API_MON_DBG_PD_MEAS_CMD
    → *p_apiCmdData, T_RL_API_MON_DBG_PD_MEAS_RSP *p_apiResData);
```

► Configuration C Structure

**Table 2.62:** T\_RL\_API\_MON\_DBG\_PD\_MEAS\_CMD

| Field               | Data Type | Size      | Offset |
|---------------------|-----------|-----------|--------|
| c_PdId              | UINT8     | 1         | 0      |
| c_PdLnaIndx         | UINT8     | 1         | 1      |
| c_PdLnaGainIndx     | UINT8     | 1         | 2      |
| c_PdType            | UINT8     | 1         | 3      |
| c_PdSelect          | UINT8     | 1         | 4      |
| c_PdLnaOffsetDacVal | UINT8     | 1         | 5      |
| c_PdNAccum          | UINT8     | 1         | 6      |
| c_PdNSamples        | UINT8     | 1         | 7      |
| w_Reserved1         | UINT32    | 4         | 8      |
| w_Reserved2         | UINT32    | 4         | 12     |
| Total               |           | <b>16</b> |        |

► Response C Structure

**Table 2.63:** T\_RL\_API\_MON\_DBG\_PD\_MEAS\_RSP

| Field       | Data Type | Size      | Offset |
|-------------|-----------|-----------|--------|
| w_SumRfON   | UINT32    | 4         | 0      |
| w_SumRfOff  | UINT32    | 4         | 4      |
| h_DeltaSum  | UINT16    | 2         | 8      |
| xh_PdPwrDb  | SINT16    | 2         | 10     |
| w_VpdRmsSqr | UINT32    | 4         | 12     |
| c_PdMeasSts | UINT8     | 1         | 16     |
| c_Reserved0 | UINT8     | 1         | 17     |
| h_Reserved1 | UINT16    | 2         | 18     |
| w_Reserved2 | UINT32    | 4         | 20     |
| Total       |           | <b>24</b> |        |

### Configuration Fields

► c\_PdId

Unique firmware assigned index to PD. This index is assigned only to critical PDs.

- Applicable only for critical PDs.

- Use `0xFF` for non-critical PDs.

► `c_PdLnaIndx`

Unique index assigned to the LNA to which PD is connected. The field will be ignored for the critical PDs.

► `c_PdLnaGainIndx`

PD LNA gain index for measurement.

- 1LSB = 4dB
- Range: [1, 9]

► `c_PdType`

PD Type

- 0 - HPPD
- 1 - LPPD

► `c_PdSelect`

This field selects the PD from the LNA selected using `c_PdLnaIndx`. The field will be ignored for the critical PDs.

► `c_PdLnaOffsetDacVal`

PD offset DAC value in 7-bit sign magnitude format. The field will be ignored for the critical PDs.

► `c_PdNAccum`

Number of GPADC measurements used for PD measurement (Software Accumulation).

► `c_PdNSamples`

Number of samples used in each GPADC measurement (Hardware Accumulation).

### Response Fields

► `w_SumRfON`

Accumulated GPADC value across all RF on measurements in GPADC codes.

► **w\_SumRfOff**

Accumulated GPADC value across all RF off measurements in GPADC codes.

► **h\_DeltaSum**

Difference between **w\_SumRfON** and **w\_SumRfOff**. This value is used to compute power measured by the PD.

► **xh\_PdPwrDb**

Power measured by the PD.  $1LSB = 0.1dBm$ .

► **w\_VpdRmsSqr**

Square of RMS voltage of the signal measured by the PD.  $1LSB = (31.25\mu v)^2$

► **c\_PdMeasSts**

PD measurement status.

- 0 - Fail
- 1 - Pass

### 2.5.3 FECSS Tx Power Debug Monitor API

This API provides interface to measure Tx power in CW mode.

**Warning**

- This API is only meant for debug purpose and must not be used to achieve functional safety objectives.
- Tx measurements could be unpredictable if sensor is not enabled in CW mode or not properly calibrated.

**Note** This API does not update the sensor state. Use [rlsensSensorStart](#) and [Sensor Stop API](#) to enable or disable the CW mode transmission.

**API Definition**

|                                    |                                                 |
|------------------------------------|-------------------------------------------------|
| <b>API Index</b>                   | 0x0082U                                         |
| <b>API Function Name</b>           | <a href="#">rl_monDbgTxPwrMeas</a>              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_DBG_TXPWR_MEAS_CMD</a> |
| <b>API Response Structure</b>      | <a href="#">T_RL_API_MON_DBG_TXPWR_MEAS_RSP</a> |

► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_DBG_TX_PWR_MEAS ((UINT16)0x0082U)
// API Function Definition
T_RETURNTYPE rl_monDbgTxPwrMeas(UINT8 c_devIndex, const T_RL_API_MON_DBG_TXPWR_MEAS_CMD
→ *p_apiCmdData, T_RL_API_MON_DBG_TXPWR_MEAS_RSP *p_apiResData)
```

► Configuration C Structure

**Table 2.64:** T\_RL\_API\_MON\_DBG\_TXPWR\_MEAS\_CMD

| Field         | Data Type | Size      | Offset |
|---------------|-----------|-----------|--------|
| c_TxIndex     | UINT8     | 1         | 0      |
| c_TxPwrNAccum | UINT8     | 1         | 1      |
| c_TxBackoff   | UINT8     | 1         | 2      |
| c_Reserved0   | UINT8     | 1         | 3      |
| w_Reserved1   | UINT32    | 4         | 4      |
| w_Reserved2   | UINT32    | 4         | 8      |
| Total         |           | <b>12</b> |        |

► Response C Structure

**Table 2.65:** T\_RL\_API\_MON\_DBG\_TXPWR\_MEAS\_RSP

| Field             | Data Type | Size      | Offset |
|-------------------|-----------|-----------|--------|
| xh_TxIncidentPwr  | SINT16    | 2         | 0      |
| xh_TxReflectedPwr | SINT16    | 2         | 2      |
| w_TxIncidentVolt  | UINT32    | 4         | 4      |
| w_TxReflectedVolt | UINT32    | 4         | 8      |
| xh_TxPower        | SINT16    | 2         | 12     |
| h_Reserved1       | UINT16    | 2         | 14     |
| w_Reserved2       | UINT32    | 4         | 16     |
| Total             |           | <b>20</b> |        |

### Configuration Fields

► c\_TxIndex

Index of the Tx channel to be measured.

▶ **c\_TxPwrNAccum**

Number of GPADC measurements (Software accumulations) used to compute Tx power.

▶ **c\_TxBackoff**

Tx backoff of the measured channel. This field is used only to configure and compute the PD parameters, it does not update the output power.

- 1LSB: 0.5d
- Valid Range: Even values (1dB step) from 0 (0dB) to 52 (26dB)

**Response Fields**▶ **xh\_TxIncidentPwr**

Power measured at incident PD in dBm.  $1LSB = 0.1dBm$ .

▶ **xh\_TxReflectedPwr**

Power measured at reflected PD in dBm.  $1LSB = 0.1dBm$ .

This is valid only for certain back-off ranges. Please refer monitoring application note for more details.

▶ **w\_TxIncidentVolt**

Square of RMS voltage of signal measured by the incident Tx PD.  $1LSB = (31.25\mu v)^2$

▶ **w\_TxReflectedVolt**

Square of RMS voltage of signal measured by the reflected Tx PD.  $1LSB = (31.25\mu v)^2$ .

This is valid only for certain back-off ranges. Please refer monitoring application note for more details.

▶ **xh\_TxPower**

Total Tx power measured by the PD.  $1LSB = 0.1dBm$ .

## 2.5.4 FECSS Synthesizer Frequency Live Monitor Configuration API

This API configures the Synthesizer frequency live monitor.

Live monitor runs in background when functional frames are running and can be enabled in [Sensor Start API](#). Monitor results are updated to the [T\\_RL\\_API\\_MON\\_LIVE\\_SYNTH\\_FREQ\\_RESULT](#) at the end of every frame.

**Notes**

- The application can avoid configuring the monitor repeatedly in every deep sleep cycle as this configuration is retained in FEC RAM during deep sleep.
- The result is updated in IPC RAM at the end of every frame (At the end of *FrameEndTime*), the application must read the results before the next Frame End Event.

**API Definition**

|                                    |                                                     |
|------------------------------------|-----------------------------------------------------|
| <b>API Index</b>                   | 0x0090U                                             |
| <b>API Function Name</b>           | rl_monLiveSynthFreqCfg                              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_LIVE_SYNTH_FREQ_CFG</a>    |
| <b>API Response Structure</b>      | None                                                |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_LIVE_SYNTH_FREQ_RESULT</a> |

## ► API Function

mmWaveLink C function declaration

## ► Configuration C Structure

**Table 2.66:** T\_RL\_API\_MON\_LIVE\_SYNTH\_FREQ\_CFG

| Field                                | Data Type | Size | Offset |
|--------------------------------------|-----------|------|--------|
| <a href="#">xc_ChirpMonStartTime</a> | SINT8     | 1    | 0      |
| c_Reserved1                          | UINT8     | 1    | 1      |
| <a href="#">h_FreqErrThreshold</a>   | UINT16    | 2    | 2      |
| w_Reserved2                          | UINT32    | 4    | 4      |
| w_Reserved3                          | UINT32    | 4    | 8      |
| Total                                |           | 12   |        |

► Response C Structure

**Table 2.67:** T\_RL\_API\_MON\_LIVE\_SYNTH\_FREQ\_RESULT

| Field              | Data Type | Size | Offset |
|--------------------|-----------|------|--------|
| c_MonStatus        | UINT8     | 1    | 0      |
| c_Reserve1         | UINT8     | 1    | 1      |
| h_Reserve2         | UINT16    | 2    | 2      |
| xw_MaxSynthFreqErr | SINT32    | 4    | 4      |
| w_FreqErrFailCount | UINT32    | 4    | 8      |
| w_Reserve3         | UINT32    | 4    | 12     |
| w_FrameCount       | UINT32    | 4    | 16     |
| w_Reserve4         | UINT32    | 4    | 20     |
| Total              |           |      | 24     |

### Configuration Fields

► xc\_ChirpMonStartTime

Synth frequency monitor start time.

- This field determines when the monitoring starts in each chirp relative to the start of the ramp.
- $1LSB = 80/APLL\_FREQ$  (Typical 0.2  $\mu s$  with 40MHz XTAL), signed number.
- Valid range: -125 to +125 (-25 to 25  $\mu s$ )
- Recommended value: 4 $\mu s$  or above.

► h\_FreqErrThreshold

Synth frequency monitor error threshold.

In synth freq monitor the error of the measured instantaneous chirp frequency with respect to the desired value is continuously compared against this threshold during the chirp.

The result of the comparison is reported in the monitor result. An Error bit is set if the measurement ever exceeds the above threshold anytime during the active chirp.

| RF Frequency | Resolution                                                       |
|--------------|------------------------------------------------------------------|
| 60 GHz       | $1LSB = 3 \times (APLL\_FREQ) / (144 \times 2^8) = 32.552 kHz$ . |
| 77 GHz       | $1LSB = 4 \times (APLL\_FREQ) / (144 \times 2^8) = 43.408 kHz$ . |

### Response Fields

Monitor response is stored in IPC memory for each Tx channel. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► **c\_MonStatus**

Monitor PASS/ FAIL status. Response status flag indicating pass fail results corresponding to threshold checks under this monitor.

| Value | Definition |
|-------|------------|
| 0     | Fail       |
| 1     | Pass       |

► **xw\_MaxSynthFreqErr**

Signed max synth frequency error value.

- This field indicates the maximum instantaneous frequency error measured during the last monitoring frame period for which frequency monitoring has been enabled.
- In Synth freq monitor the error of the measured instantaneous chirp frequency with respect to the desired value.

| RF Frequency | Resolution                                                               |
|--------------|--------------------------------------------------------------------------|
| 60 GHz       | $1LSB = 3 \times (\text{APLL\_FREQ}) / (144 \times 2^{13}) = 1.017kHz$ . |
| 77 GHz       | $1LSB = 4 \times (\text{APLL\_FREQ}) / (144 \times 2^{13}) = 1.356kHz$ . |

Valid Range:  $[-2^{21}, 2^{21})$

► **w\_FreqErrFailCount**

Frequency error failure count.

This field indicates the number of times during chirping in the previous monitoring frame period in which the measured frequency error violated the allowed threshold.

- Frequency error threshold violation is counted every 10 ns.
- Valid range: [0, 524287]

► **w\_FrameCount**

RFS frame count when the monitor report is updated.

**note** Value of this counter lags by 1 with respect to other monitors as the results are generated before the Frame End Event

## 2.5.5 FECSS Rx Saturation Live Monitor Configuration API

This API configures Rx saturation live monitor. This monitor reports number of saturated Rx ADC samples per Rx channel for every chirp. Live monitor runs in background when functional frames are running and can be enabled in [Sensor Start API](#). Monitor results are updated at a programmable offset in PER\_CHIRP\_LUT RAM.

API Definition

|                                    |                                     |
|------------------------------------|-------------------------------------|
| <b>API Index</b>                   | 0x0091U                             |
| <b>API Function Name</b>           | rl_monLiveRxSaturationCfg           |
| <b>API Configuration Structure</b> | T_RL_API_MON_LIVE_RX_SATURATION_CFG |
| <b>API Response Structure</b>      | None                                |

## ► API Function

mmWaveLink C function declaration

## ► Configuration C Structure

**Table 2.68:** T\_RL\_API\_MON\_LIVE\_RX\_SATURATION\_CFG

| Field                 | Data Type | Size | Offset |
|-----------------------|-----------|------|--------|
| h_PerChirpRamStartAdd | UINT16    | 2    | 0      |
| h_Reserved1           | UINT16    | 2    | 2      |
| w_Reserved2           | UINT32    | 4    | 4      |
| Total                 |           | 8    |        |

Configuration Fields

## ► h\_PerChirpRamStartAdd

The per chirp RAM start offset address for saturation monitor result storage. This field is used to program the start offset address of saturation monitor result ARRAY in PER\_CHIRP\_LUT RAM.

- The start address offset should be multiple of 4 bytes.
- The max addressable space 8kB.
- The size of this ARRAY should be sufficient to hold all chirp data in a frame.
- Total size of RAM = 4 bytes per chirp × num of chirps in a burst × num of bursts in frame.
- Each chirp will have 1 byte data for each RX, max 4 RXs are supported (Adding is added if device supports less number of Rx channels).
- Valid range: 0, 4, 8 to 8188.

### 2.5.6 FECSS PLL Control Voltage Monitor Configuration API

This API configures PLL control voltage monitor. The monitor measures control voltages for APLL and Synthesizer PLLs. The monitor can be triggered using [FECSS Monitor Enable Trigger API](#). The measured values

of the PLL control voltages are reported in the response Structure [T\\_RL\\_API\\_MON\\_PLL\\_CTRL\\_VOLT\\_RESULT](#) in memory mapped monitor response [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) .

### API Definition

|                                    |                                                   |
|------------------------------------|---------------------------------------------------|
| <b>API Index</b>                   | 0x0093U                                           |
| <b>API Function Name</b>           | r1_monPllCtrlVoltCfg                              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_PLL_CTRL_VOLT_CFG</a>    |
| <b>API Response Structure</b>      | None                                              |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_PLL_CTRL_VOLT_RESULT</a> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_PLL_CTRL_VOLT_CFG ((UINT16)0x0093U)
// API Function Definition
T_RETURNTYPE r1_monPllCtrlVoltCfg(UINT8 c_devIndex, const T_RL_API_MON_PLL_CTRL_VOLT_CFG
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.69:** [T\\_RL\\_API\\_MON\\_PLL\\_CTRL\\_VOLT\\_CFG](#)

| Field           | Data Type | Size | Offset |
|-----------------|-----------|------|--------|
| c_PllMonEnaMask | UINT8     | 1    | 0      |
| c_Reserve1      | UINT8     | 1    | 1      |
| h_Reserve2      | UINT16    | 2    | 2      |
| w_Reserve3      | UINT32    | 4    | 4      |
| Total           |           | 8    |        |

► Response C Structure

**Table 2.70:** T\_RL\_API\_MON\_PLL\_CTRL\_VOLT\_RESULT

| Field              | Data Type | Size | Offset    |
|--------------------|-----------|------|-----------|
| xh_ErrorCode       | SINT16    | 2    | 0         |
| h_Reserved1        | UINT16    | 2    | 2         |
| h_ApllCtrlVolt     | UINT16    | 2    | 4         |
| h_SynthMinCtrlVolt | UINT16    | 2    | 6         |
| h_SynthMaxCtrlVolt | UINT16    | 2    | 8         |
| h_Reserved2        | UINT16    | 2    | 10        |
| w_Reserved3        | UINT32    | 4    | 12        |
| w_Reserved4        | UINT32    | 4    | 16        |
| w_Reserved5        | UINT32    | 4    | 20        |
| w_FrameCount       | UINT32    | 4    | 24        |
| Total              |           |      | <b>28</b> |

### Configuration Fields

► c\_PllMonEnaMask

APLL Synth control voltage monitor enable mask.

| Value | Definition       |
|-------|------------------|
| 0     | Monitor Disabled |
| 1     | Monitor Enabled  |

Bit Field Definition:

| Bit-Field | Definition                                     |
|-----------|------------------------------------------------|
| Bit[0]    | APLL control voltage monitor enable            |
| Bit[1]    | Synthesizer VCO control voltage monitor enable |
| Bit[7:2]  | RESERVED                                       |

### Monitor Response Fields

Monitor response is stored in the IPC response structure. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the details.

► xh\_ErrorCode

Monitor Error code. 2's complement signed number.

| Value                          | Definition                    |
|--------------------------------|-------------------------------|
| 0                              | Monitor executed successfully |
| 2's complement negative number | Monitor execution failed      |

► **h\_ApllCtrlVolt**

APLL control voltage value in 10-bit unsigned code.

- This field is valid only if the APPLL control voltage monitor is enabled.
- 1LSB = 1.8V / 1024.
- Valid range: 0 to 1023.

► **h\_SynthMinCtrlVolt**

Synthesizer control voltage for the minimum supported RF frequency. The voltage is reported as 10-bit unsigned code.

| Device Type  | Min RF Frequency |
|--------------|------------------|
| 60GHz Device | 57GHz            |
| 77GHz Device | 76GHz            |

- This field is valid only if the Synth control voltage monitor is enabled.
- 1LSB = 1.8V / 1024.
- Valid range: 0 to 1023.

► **h\_SynthMaxCtrlVolt**

Synthesizer control voltage for the maximum supported RF frequency. The voltage is reported as 10-bit unsigned code.

| Device Type  | Max RF Frequency                                       |
|--------------|--------------------------------------------------------|
| 60GHz Device | 64GHz* (Variant specific limitations in Release Notes) |
| 77GHz Device | 81GHz                                                  |

- Only the fields corresponding to the enabled monitors are valid.
- 1LSB = 1.8V / 1024.
- Valid range: 0 to 1023.

► **w\_FrameCount**

RFS frame count when the monitor report is updated.

## 2.5.7 FECSS TxN-Rx Loopback Monitor Configuration API

This API configures the Tx-Rx loopback monitor for all Tx channels. Application should call this API multiple times to configure monitor for different Tx channels. The monitor enables PA loopback from the selected Tx channel to all enabled Rx channels and measures various tone parameters with IF mid-band tone of frequency  $2.77MHz$ . It also includes options to measure and BPM. Rx input power and loopback power with BPM enabled.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [T\\_RL\\_API\\_MON\\_TXN\\_RX\\_LB\\_RESULT](#).

**Note**

- This monitor enables corresponding Tx channel with transmission enabled.
- This monitor also enables Rx channels, hence results are susceptible to external interference.

### API Definition

|                                    |                                               |
|------------------------------------|-----------------------------------------------|
| <b>API Index</b>                   | 0x0094U                                       |
| <b>API Function Name</b>           | rl_monTxNRxLbCfg                              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_TXN_RX_LB_CFG</a>    |
| <b>API Response Structure</b>      | None                                          |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_TXN_RX_LB_RESULT</a> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_TXn_RX_LB_CFG ((UINT16)0x0094U)
// API Function Definition
T_RETURNTYPE rl_monTxNRxLbCfg(UINT8 c_devIndex, const T_RL_API_MON_TXN_RX_LB_CFG
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.71:** T\_RL\_API\_MON\_TXN\_RX\_LB\_CFG

| Field             | Data Type | Size | Offset |
|-------------------|-----------|------|--------|
| c_TxIndSel        | UINT8     | 1    | 0      |
| c_MonEnaCtrl      | UINT8     | 1    | 1      |
| c_MonRxTxCodesSel | UINT8     | 1    | 2      |
| c_MonRxGainCode   | UINT8     | 1    | 3      |
| h_MonTxBiasCodes  | UINT16    | 2    | 4      |
| h_RfFreqStart     | UINT16    | 2    | 6      |
| xh_RfFreqSlope    | SINT16    | 2    | 8      |
| h_Reserved1       | UINT16    | 2    | 10     |
| w_Reserved2       | UINT32    | 4    | 12     |
| Total             |           | 16   |        |

► Response C Structure

**Table 2.72:** T\_RL\_API\_MON\_TXN\_RX\_LB\_RESULT

| Field              | Data Type | Size | Offset |
|--------------------|-----------|------|--------|
| xh_ErrorCode       | SINT16    | 2    | 0      |
| xh_RxInputPower    | SINT16    | 2    | 2      |
| xh_TxNRxLbPower    | SINT16[4] | 8    | 4      |
| h_TxNRxLbPhase     | UINT16[4] | 8    | 12     |
| xh_TxNRxLbBpmPower | SINT16[4] | 8    | 20     |
| h_TxNRxLbBpmPhase  | UINT16[4] | 8    | 28     |
| xc_TxNRxLbNoise    | SINT8[4]  | 4    | 36     |
| xc_TxNRxLbBpmNoise | SINT8[4]  | 4    | 40     |
| w_Reserved2        | UINT32    | 4    | 44     |
| w_Reserved3        | UINT32    | 4    | 48     |
| w_FrameCount       | UINT32    | 4    | 52     |
| Total              |           | 56   |        |

### Configuration Fields

► c\_TxIndSel

Index of the Tx channel for which the configuration is applied.

| Value    | Definition                                            |
|----------|-------------------------------------------------------|
| 0        | The Monitor configuration will be applicable for TX0. |
| 1        | The Monitor configuration will be applicable for TX1. |
| 2 to 255 | Reserved                                              |

**Note** Tx channel will be enabled irrespective of the `h_TxChCtrlBitMask` if corresponding monitor is enabled in `w_MonitorEnable`. Rx channels will be enabled according to the `h_RxChCtrlBitMask`.

#### ► c\_MonEnaCtrl

TxN-Rx loopback monitor control.

The monitor supports measuring QPSK PD along with the  $BPM = 0^\circ$  and  $BPM = 180^\circ$  in a signal iteration. This field controls the enable masks for the required measurements.

| Value | Definition |
|-------|------------|
| 0     | Disabled   |
| 1     | Enabled    |

| Bit Field | Definition                                                                         |
|-----------|------------------------------------------------------------------------------------|
| Bit[0]    | TxN_LB_MON Enable bit<br>Enable $Txn_{RxLoopbackMonitor}$ with $BPM = 0^\circ$     |
| Bit[1]    | TxN_BPM_MON enable bit.<br>Enable $Txn_{RxLoopbackMonitor}$ with $BPM = 180^\circ$ |
| Bit[2]    | Rx input power measurement enable bit.                                             |

**Warning**

- Accuracy of the reported Rx input power degrades with higher backoff.
- Either TxN\_LB\_MON or TxN\_BPM\_MON monitors must be enabled to measure Rx input power.

#### ► c\_MonRxTxCodesSel

Monitor RX gain and TX bias code selection controls.

| Bit Field | Definition                                                                                                                                                                                                   |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]    | RX_GAIN_CODE override enable. <ul style="list-style-type: none"> <li>Value 0: Use calibrated Rx gain codes</li> <li>Value 1: Use Rx gain codes from <a href="#">c_MonRxGainCode</a></li> </ul>               |
| Bit[1]    | TX_PA_CODE override enable. <ul style="list-style-type: none"> <li>Value 0: Use calibrates TX_PA_CODE</li> <li>Value 1: Use TX_PA_CODE from <a href="#">h_MonTxBiasCodes</a>.</li> </ul>                     |
| Bit[2]    | Monitor loopback gain select. <ul style="list-style-type: none"> <li>Value 0: Use low PA loopback gain (-10 dB).</li> <li>Value 1: Use loopback gain (0 dB).</li> <li>Recommended value: 1 (0 dB)</li> </ul> |
| Bit[7:3]  | Reserved                                                                                                                                                                                                     |

**Recommendation** Recommended value for [c\\_MonRxTxCodesSel](#) is 0x5

► [c\\_MonRxGainCode](#)

Monitor RX channels gain code override setting. This is a common IFA code value for all chirps used in this monitor. The monitor compensates for the overridden IFA gain code internally and reports the tone powers for the currently applied calibrated values. The IFA gain code value should be chosen appropriately to avoid Rx chain saturation.

Bit definition:

| Bit Field  | Definition                                                                                                                                                                                   |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bits [4:0] | IFA_GAIN_CODE. <ul style="list-style-type: none"> <li>Override IFA gain code.</li> <li>Valid range: [0, 10]</li> <li><math>IFA\_GAIN(dB) = IFA\_GAIN\_CODE \times 2 - 10dB</math></li> </ul> |
| bits [7:5] | Reserved                                                                                                                                                                                     |

**Recommendation** Recommended value for IFA gain code is:  $c\_MonRxGainCode = 2 + (c\_CalTxBackOffSel/2)$

► [h\\_MonTxBiasCodes](#)

Override value for TX\_PA\_CODES.

► [h\\_RfFreqStart](#)

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► **xh\_RfFreqSlope**

RF Slope of the monitoring chirp.

| RF Slope | Resolution                                                                                                                                                          |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |

**Warning** Application should ensure that the Monitor chirp's end frequency is within the operating range of a respective device.

### Response Fields

Monitor response is stored in IPC memory for each Tx channel. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► **xh\_ErrorCode**

Monitor Error code. 2's complement signed number.

| Value                          | Definition                    |
|--------------------------------|-------------------------------|
| 0                              | Monitor executed successfully |
| 2's complement negative number | Monitor execution failed      |

► **xh\_RxInputPower**

Rx input power measured using PD at the loopback buffer in dB.  $1LSB = 0.1dBm$ .

This field is valid only if Rx input measurement is enabled and at least one of the TxN\_LB\_MON TxN\_BPM\_MON is enabled.

**Note** Accuracy of the Rx Input power will degrade with higher Tx back-off. It is recommended to measure this power with least backoff possible (preferably 0dB).

► `xh_TxNRxLbPower`

Array of loopback tone powers measured with  $BPM = 0^\circ$  across Rx channels.  $1LSB = 0.1dBm$   
These values are valid only if the bit `TxN_LB_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `h_TxNRxLbPhase`

Array of loopback tone phases measured with  $BPM = 180^\circ$  across Rx channels.  $1LSB = 360^\circ/2^16$   
These values are valid only if the bit `TxN_LB_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `xh_TxNRxLbBpmPower`

Array of loopback tone powers measured with  $BPM = 180^\circ$  across Rx channels.  $1LSB = 0.1dBm$   
These values are valid only if the bit `TxN_BPM_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `h_TxNRxLbBpmPhase`

Array of loopback tone phases measured with  $BPM = 180^\circ$  across Rx channels.  $1LSB = 360^\circ/2^16$   
These values are valid only if the bit `TxN_BPM_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `xc_TxNRxLbNoise`

Array of noise powers measured with  $BPM = 0^\circ$  across Rx channels.  $1LSB = 1dBm$   
These values are valid only if the bit `TxN_LB_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `xc_TxNRxLbBpmNoise`

Array of noise powers measured with  $BPM = 180^\circ$  across Rx channels.  $1LSB = 1dBm$   
These values are valid only if the bit `TxN_BPM_MON` is enabled in `c_MonEnaCtrl` and corresponding Rx channel is enabled in `h_RxChCtrlBitMask`.

► `w_FrameCount`

RFS frame count when the monitor report is updated.

### 2.5.8 FECSS TxN Power Monitor Configuration API

This API configures the Tx power monitor for all Tx channels. Application should call this API multiple times to configure monitor for different Tx channels. The API enables the selected Tx channel and measures transmitted power using the on-chip PDs.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [T\\_RL\\_API\\_MON\\_TXN\\_POWER\\_RESULT](#).

**Note** This monitor enables corresponding Tx channel with transmission enabled.

## API Definition

|                                    |                                               |
|------------------------------------|-----------------------------------------------|
| <b>API Index</b>                   | 0x0095U                                       |
| <b>API Function Name</b>           | <code>rl_monTxNPowerCfg</code>                |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_TXN_POWER_CFG</a>    |
| <b>API Response Structure</b>      | None                                          |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_TXN_POWER_RESULT</a> |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_TXn_PWR_CFG ((UINT16)0x0095U)

// API Function Definition
T_RETURNTYPE rl_monTxNPowerCfg(UINT8 c_devIndex, const T_RL_API_MON_TXN_POWER_CFG
→ *p_apiCmdData);
```

### ► Configuration C Structure

**Table 2.73:** `T_RL_API_MON_TXN_POWER_CFG`

| Field                         | Data Type | Size | Offset    |
|-------------------------------|-----------|------|-----------|
| <code>c_TxIndSel</code>       | UINT8     | 1    | 0         |
| <code>c_MonTxCodesSel</code>  | UINT8     | 1    | 1         |
| <code>h_MonTxBiasCodes</code> | UINT16    | 2    | 2         |
| <code>h_RfFreqStart</code>    | UINT16    | 2    | 4         |
| <code>xh_RfFreqSlope</code>   | SINT16    | 2    | 6         |
| <code>c_TxBackoffMap</code>   | UINT8     | 1    | 8         |
| <code>c_Reserved1</code>      | UINT8     | 1    | 9         |
| <code>h_Reserved2</code>      | UINT16    | 2    | 10        |
| <code>w_Reserved3</code>      | UINT32    | 4    | 12        |
| Total                         |           |      | <b>16</b> |

► Response C Structure

**Table 2.74:** T\_RL\_API\_MON\_TXN\_POWER\_RESULT

| Field        | Data Type | Size | Offset    |
|--------------|-----------|------|-----------|
| xh_ErrorCode | SINT16    | 2    | 0         |
| h_Reserved1  | UINT16    | 2    | 2         |
| xh_TxNPwrVal | SINT16    | 2    | 4         |
| h_Reserved2  | UINT16    | 2    | 6         |
| w_Reserved3  | UINT32    | 4    | 8         |
| w_FrameCount | UINT32    | 4    | 12        |
| Total        |           |      | <b>16</b> |

### Configuration Fields

► c\_TxIndSel

Index of the Tx channel for which the configuration is applied.

| Value    | Definition                                            |
|----------|-------------------------------------------------------|
| 0        | The Monitor configuration will be applicable for TX0. |
| 1        | The Monitor configuration will be applicable for TX1. |
| 2 to 255 | Reserved                                              |

**Note** Tx channel will be enabled irrespective of the [h\\_TxChCtrlBitMask](#) if corresponding monitor is enabled in [w\\_MonitorEnable](#).

► c\_MonTxCodesSel

Tx monitor code select control

| Bit Field | Definition                                                                                                                                                                                   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]    | Reserved                                                                                                                                                                                     |
| Bit[1]    | TX_PA_CODE override enable. <ul style="list-style-type: none"> <li>• Value 0: Use calibrates TX_PA_CODE</li> <li>• Value 1: Use TX_PA_CODE from <a href="#">h_MonTxBiasCodes</a>.</li> </ul> |
| Bit[7:1]  | Reserved                                                                                                                                                                                     |

► **h\_MonTxBiasCodes**

Override value for TX\_PA\_CODES.

► **h\_RfFreqStart**

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► **xh\_RfFreqSlope**

RF Slope of the monitoring chirp.

| RF Slope | Resolution                                                                                                                                                          |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |

**Warning** Application should ensure that the Monitor chirp's end frequency is within the operating range of a respective device.

► **c\_TxBackoffMap**

Backoff applied to the Tx channels when TX\_PA\_CODE override is enabled.  $1LSB = 0.5dB$

This value is required to correctly setup PDs and compute internal variables when override mode is enabled.

**Response Fields**

Monitor response is stored in IPC memory for each Tx channel. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► **xh\_ErrorCode**

Monitor Error code. 2's complement signed number.

| Value                          | Definition |
|--------------------------------|------------|
| 0                              | Success    |
| 2's complement negative number | Failure    |

► `xh_TxNPwrVal`

Measured Tx output power in dB.  $1LSB = 0.1dBm$

► `w_FrameCount`

RFS frame count when the monitor report is updated.

### 2.5.9 FECSS Tx Ball-Break Monitor Configuration API

This API configures the Tx ball-break monitor for all Tx channels. Application should call this API multiple times to configure monitor for different Tx channels. The API enables the selected Tx channel and measures both incident and reflected PDs. Ratio of powers measured by these two PDs can be used to check if contact with the Tx antenna.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [`T\_RL\_API\_MON\_TXN\_BB\_RESULT`](#).

**Note**

- Accuracy of the ball-break monitor degrades with back-off. It is recommended to run this monitor with least backoff possible (preferably 0dB) for the most reliable results.
- This monitor enables corresponding Tx channel with transmission enabled.

#### API Definition

|                                    |                                                         |
|------------------------------------|---------------------------------------------------------|
| <b>API Index</b>                   | 0x0096U                                                 |
| <b>API Function Name</b>           | <code>rl_monTxNBbCfg</code>                             |
| <b>API Configuration Structure</b> | <a href="#"><code>T_RL_API_MON_TXN_BB_CFG</code></a>    |
| <b>API Response Structure</b>      | None                                                    |
| <b>Monitor Response Structure</b>  | <a href="#"><code>T_RL_API_MON_TXN_BB_RESULT</code></a> |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_TXn_BB_CFG ((UINT16)0x0096U)

// API Function Definition
T_RETURNTYPE rl_monTxNBbCfg(UINT8 c_devIndex, const T_RL_API_MON_TXN_BB_CFG
    *p_apiCmdData);
```

► Configuration C Structure

**Table 2.75:** T\_RL\_API\_MON\_TXN\_BB\_CFG

| Field            | Data Type | Size | Offset    |
|------------------|-----------|------|-----------|
| c_TxIndSel       | UINT8     | 1    | 0         |
| c_MonTxCodesSel  | UINT8     | 1    | 1         |
| h_MonTxBiasCodes | UINT16    | 2    | 2         |
| h_RfFreqStart    | UINT16    | 2    | 4         |
| xh_RfFreqSlope   | SINT16    | 2    | 6         |
| c_TxBackoffMap   | UINT8     | 1    | 8         |
| c_Reserved1      | UINT8     | 1    | 9         |
| h_Reserved2      | UINT16    | 2    | 10        |
| w_Reserved2      | UINT32    | 4    | 12        |
| Total            |           |      | <b>16</b> |

► Response C Structure

**Table 2.76:** T\_RL\_API\_MON\_TXN\_BB\_RESULT

| Field            | Data Type | Size | Offset    |
|------------------|-----------|------|-----------|
| xh_ErrorCode     | SINT16    | 2    | 0         |
| h_Reserved1      | UINT16    | 2    | 2         |
| xh_TxNIcidPwrVal | SINT16    | 2    | 4         |
| xh_TxNRef1PwrVal | SINT16    | 2    | 6         |
| w_Reserved2      | UINT32    | 4    | 8         |
| w_FrameCount     | UINT32    | 4    | 12        |
| Total            |           |      | <b>16</b> |

### Configuration Fields

► c\_TxIndSel

Index of the Tx channel for which the configuration is applied.

| Value    | Definition                                            |
|----------|-------------------------------------------------------|
| 0        | The Monitor configuration will be applicable for TX0. |
| 1        | The Monitor configuration will be applicable for TX1. |
| 2 to 255 | Reserved                                              |

**Note** Tx channel will be enabled irrespective of the [h\\_TxChCtrlBitMask](#) if corresponding monitor is enabled in [w\\_MonitorEnable](#).

► [c\\_MonTxCodesSel](#)

Tx monitor code select control

| Bit Field | Definition                                                                                                                                                                                   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]    | Reserved                                                                                                                                                                                     |
| Bit[1]    | TX_PA_CODE override enable. <ul style="list-style-type: none"> <li>• Value 0: Use calibrates TX_PA_CODE</li> <li>• Value 1: Use TX_PA_CODE from <a href="#">h_MonTxBiasCodes</a>.</li> </ul> |
| Bit[7:1]  | Reserved                                                                                                                                                                                     |

► [h\\_MonTxBiasCodes](#)

Override value for TX\_PA\_CODES.

► [h\\_RfFreqStart](#)

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► [xh\\_RfFreqSlope](#)

RF Slope of the monitoring chirp.

| RF Slope | Resolution                                                                                                                                                          |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |

**Warning** Application should ensure that the Monitor chirp's end frequency is within the operating range of a respective device.

► `c_TxBackoffMap`

Backoff applied to the Tx channels when `TX_PA_CODE` override is enabled.  $1LSB = 0.5dB$   
This value is required to correctly setup PDs and compute internal variables when override mode is enabled.

**Response Fields**

Monitor response is stored in IPC memory for each Tx channel. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► `xh_ErrorCode`

Monitor error code. 2's complement signed number.

| Value                          | Definition |
|--------------------------------|------------|
| 0                              | Success    |
| 2's complement negative number | Failure    |

► `xh_TxNIncidPwrVal`

Measured Tx incident power in dB.  $1LSB = 0.1dBm$

► `xh_TxNRef1PwrVal`

Measured Tx reflected power in dB.  $1LSB = 0.1dBm$

► `w_FrameCount`

RFS frame count when the monitor report is updated.

### 2.5.10 FECSS TxN DC Signal Monitor Configuration API

This API configures the Tx DC-Signal monitor for all the Tx channels. Application should call this API multiple times to configure monitor for different Tx channels. The monitor measures set of DC signals in the Tx chain for the selected channel and compares the results with known thresholds. 1-bit pass/ fail result is stored in the calibration result for every signal.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [T\\_RL\\_API\\_MON\\_TXN\\_DCSIG\\_RESULT](#).

**Note** This monitor enables corresponding Tx channel with transmission enabled.

## API Definition

|                                    |                               |
|------------------------------------|-------------------------------|
| <b>API Index</b>                   | 0x0097U                       |
| <b>API Function Name</b>           | rl_monTxNDcSigCfg             |
| <b>API Configuration Structure</b> | T_RL_API_MON_TXN_DCSIG_CFG    |
| <b>API Response Structure</b>      | None                          |
| <b>Monitor Response Structure</b>  | T_RL_API_MON_TXN_DCSIG_RESULT |

### ► API Function

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_TXn_DCSIG_CFG           ((UINT16)0x0097U)
// API Function Definition
T_RETURNTYPE rl_monTxNDcSigCfg(UINT8 c_devIndex, const T_RL_API_MON_TXN_DCSIG_CFG
→ *p_apiCmdData);
```

### ► Configuration C Structure

Table 2.77: T\_RL\_API\_MON\_TXN\_DCSIG\_CFG

| Field            | Data Type | Size      | Offset |
|------------------|-----------|-----------|--------|
| c_TxIndSel       | UINT8     | 1         | 0      |
| c_MonTxCodesSel  | UINT8     | 1         | 1      |
| h_MonTxBiasCodes | UINT16    | 2         | 2      |
| h_RfFreqStart    | UINT16    | 2         | 4      |
| xh_RfFreqSlope   | SINT16    | 2         | 6      |
| w_Reserved1      | UINT32    | 4         | 8      |
| w_Reserved2      | UINT32    | 4         | 12     |
| Total            |           | <b>16</b> |        |

► Response C Structure

**Table 2.78:** T\_RL\_API\_MON\_TXN\_DCSIG\_RESULT

| Field           | Data Type | Size | Offset |
|-----------------|-----------|------|--------|
| xh_ErrorCode    | SINT16    | 2    | 0      |
| h_TxDcMonStatus | UINT16    | 2    | 2      |
| w_Reserve1      | UINT32    | 4    | 4      |
| w_Reserve2      | UINT32    | 4    | 8      |
| w_FrameCount    | UINT32    | 4    | 12     |
| Total           |           | 16   |        |

### Configuration Fields

► c\_TxIndSel

Index of the Tx channel for which the configuration is applied.

| Value    | Definition                                            |
|----------|-------------------------------------------------------|
| 0        | The Monitor configuration will be applicable for TX0. |
| 1        | The Monitor configuration will be applicable for TX1. |
| 2 to 255 | Reserved                                              |

**Note** Tx channel will be enabled irrespective of the [h\\_TxChCtrlBitMask](#) if corresponding monitor is enabled in [w\\_MonitorEnable](#).

► c\_MonTxCodesSel

Tx monitor code select control

| Bit Field | Definition                                                                                                                               |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0]    | Reserved                                                                                                                                 |
| Bit[1]    | TX_PA_CODE override enable.<br>• Value 0: Use calibrates TX_PA_CODE<br>• Value 1: Use TX_PA_CODE from <a href="#">h_MonTxBiasCodes</a> . |
| Bit[7:2]  | Reserved                                                                                                                                 |

► h\_MonTxBiasCodes

Override value for TX\_PA\_CODES.

► **h\_RfFreqStart**

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► **xh\_RfFreqSlope**

RF Slope of the monitoring chirp.

| RF Slope | Resolution                                                                                                                                                          |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz    | $1LSB = (3 \times 400 \times APPLL\_FREQ)/2^{24} \approx 28.610kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |
| 77GHz    | $1LSB = (4 \times 400 \times APPLL\_FREQ)/2^{24} \approx 38.147kHz/us$ , signed number<br><u>Valid Range:</u> -3495 to 3495 (+/- 100MHz/us for APPLL_FREQ = 400MHz) |

**Warning** Application should ensure that the Monitor chirp's end frequency is within the operating range of a respective device.

### Response Fields

Monitor response is stored in IPC memory for each Tx channel. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► **xh\_ErrorCode**

Monitor error code. 2's complement signed number.

| Value                          | Definition |
|--------------------------------|------------|
| 0                              | Success    |
| 2's complement negative number | Failure    |

► **h\_TxDcMonStatus**

The measured TX supply GPADC DC signals for selected monitor configuration is compared with internal thresholds and result status (Pass/fail) are stored for each signal.

| Bit Field | Definition                          |
|-----------|-------------------------------------|
| Bit[0]    | TXn_VDDA_SUPPLY signal Status       |
| Bit[1]    | TXn_1V_CLUSTER_SUPPLY signal Status |
| Bit[15:2] | Reserved                            |

► **w\_FrameCount**

RFS frame count when the monitor report is updated.

### 2.5.11 FECSS Rx HPF and DC Signal Monitor Configuration API

This API configures the Rx DC-Signal and HPF monitor. The DC-signal monitor measures set of DC signals from all the Rx chains and compares the results with known thresholds. 1-bit pass/ fail result is stored in the calibration result for every signal. HPF monitor enables IFA loopback and measures tone power at in-band IF frequency and selected HPF's cutoff IF frequency.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [T\\_RL\\_API\\_MON\\_RX\\_HPF\\_DCSIG\\_RESULT](#) .

#### API Definition

|                                    |                                                  |
|------------------------------------|--------------------------------------------------|
| <b>API Index</b>                   | 0x0098U                                          |
| <b>API Function Name</b>           | r1_monRxHpfDcSigCfg                              |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_RX_HPF_DCSIG_CFG</a>    |
| <b>API Response Structure</b>      | None                                             |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_RX_HPF_DCSIG_RESULT</a> |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_RX_HPF_DCSIG_CFG ((UINT16)0x0098U)
// API Function Definition
T_RETURNTYPE r1_monRxHpfDcSigCfg(UINT8 c_devIndex, const T_RL_API_MON_RX_HPF_DCSIG_CFG
→ *p_apiCmdData);
```

► Configuration C Structure

**Table 2.79:** T\_RL\_API\_MON\_RX\_HPF\_DCSIG\_CFG

| Field         | Data Type | Size      | Offset |
|---------------|-----------|-----------|--------|
| h_RfFreqStart | UINT16    | 2         | 0      |
| c_MonEnaCtrl  | UINT8     | 1         | 2      |
| c_RxHpfSel    | UINT8     | 1         | 3      |
| w_Reserved1   | UINT32    | 4         | 4      |
| w_Reserved2   | UINT32    | 4         | 8      |
| Total         |           | <b>12</b> |        |

► Response C Structure

**Table 2.80:** T\_RL\_API\_MON\_RX\_HPF\_DCSIG\_RESULT

| Field             | Data Type | Size      | Offset |
|-------------------|-----------|-----------|--------|
| xh_ErrorCode      | SINT16    | 2         | 0      |
| h_Reserved1       | UINT16    | 2         | 2      |
| w_RxDcMonStatus   | UINT32    | 4         | 4      |
| xh_RxHpfInBandPwr | SINT16[4] | 8         | 8      |
| xh_RxHpfCutOffPwr | SINT16[4] | 8         | 16     |
| w_Reserved2       | UINT32    | 4         | 24     |
| w_Reserved3       | UINT32    | 4         | 28     |
| w_FrameCount      | UINT32    | 4         | 32     |
| Total             |           | <b>36</b> |        |

Configuration Fields

► h\_RfFreqStart

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br>Valid Range: 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br>Valid Range: 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

► **c\_MonEnaCtrl**

Monitor enable control.

| Value | Definition |
|-------|------------|
| 0     | Disabled   |
| 1     | Enabled    |

Bit Field Definition:

| Value  | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit[0] | RX_DC_MON enable bit.<br>A monitor chirp is triggered to measure the DC signals using GPADC.                                                                                                                                                                                                                                                                                                                                                          |
| Bit[1] | HPF_CUTOFF_MON enable bit. <ul style="list-style-type: none"> <li>Two monitor chirps with IFA loopback are triggered to measure the powers at in-band frequency and HPF cutoff frequency.</li> <li>The first chirp for the in-band power measurement uses an IF signal frequency of 2.77MHz.</li> <li>The second chirp for the HPF cutoff power measurement uses an IF signal frequency matching the user programmed HPF corner frequency.</li> </ul> |

► **c\_RxHpfSel**

The HPF\_CUTOFF\_MON monitor Chirp HPF corner frequency.

| Value | Definition                   |
|-------|------------------------------|
| 0     | 175kHz HPF corner frequency  |
| 1     | 350kHz HPF corner frequency  |
| 2     | 700kHz HPF corner frequency  |
| 3     | 1400kHz HPF corner frequency |

Valid Range: 0 to 3.

## **Response Fields**

Monitor response is stored in IPC memory. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► **xh\_ErrorCode**

Monitor error code. 2's complement signed number.

| Value                          | Definition |
|--------------------------------|------------|
| 0                              | Success    |
| 2's complement negative number | Failure    |

► **w\_RxDcMonStatus**

ALI measured RX channels supply and bias GPADC DC signals for selected monitor configuration is compared with internal thresholds and result (pass/fail) will be sent out for each signal type.

DC-BIST results are valid only for enabled RX channels in [h\\_RxChCtrlBitMask](#) and [RX\\_DC\\_MON = 1](#) in configuration API.

| Bit Field   | Definition                          |
|-------------|-------------------------------------|
| Bit [0]     | RX0_ADC_I_DIG_LDO_VOUT_SENSE status |
| Bit [1]     | RX0_ADC_I_DIG_LDO_VIN_SENSE status  |
| Bit [2]     | RX0_IFA_I_LDO_VOUT_SENSE status     |
| Bit [3]     | RX0_IFA_I_LDO_VIN_SENSE status      |
| Bit [4]     | RX0_VDD_LNA status                  |
| Bit [5]     | LODIST_RX01_VDDA_1POV_SUPPLY status |
| Bit [6]     | RX1_ADC_I_DIG_LDO_VOUT_SENSE status |
| Bit [7]     | RX1_ADC_I_DIG_LDO_VIN_SENSE status  |
| Bit [8]     | RX1_IFA_I_LDO_VOUT_SENSE status     |
| Bit [9]     | RX1_IFA_I_LDO_VIN_SENSE status      |
| Bit [10]    | RX1_VDD_LNA status                  |
| Bit [11]    | RX2_ADC_I_DIG_LDO_VOUT_SENSE status |
| Bit [12]    | RX2_ADC_I_DIG_LDO_VIN_SENSE status  |
| Bit [13]    | RX2_IFA_I_LDO_VOUT_SENSE status     |
| Bit [14]    | RX2_IFA_I_LDO_VIN_SENSE status      |
| Bit [15]    | RX2_VDD_LNA status                  |
| Bit [16]    | LODIST_RX23_VDDA_1POV_SUPPLY status |
| Bit [31:17] | Reserved status                     |

► `xh_RxHpfInBandPwr`

Array of measured tone power for in-band IFA frequency measured in the Rx HPF monitor per Rx channel.  
 $1LSB = 0.1dB$ .

DC-BIST results are valid only for enabled RX channels in `h_RxChCtrlBitMask` and `HPF_CUTOFF_MON = 1` in configuration API.

► `xh_RxHpfCutOffPwr`

Array of measured tone power for cutoff IFA frequency measured in the Rx HPF monitor per Rx channel.  $1LSB = 0.1dB$ .

DC-BIST results are valid only for enabled RX channels in `h_RxChCtrlBitMask` and `HPF_CUTOFF_MON = 1` in configuration API.

► **w\_FrameCount**

RFS frame count when the monitor report is updated.

### 2.5.12 FECSS PM and Clock DC Signals Monitor Configuration API

This API configures the PM-clock DC-Signal monitor. The monitor measures set of DC signals in the Power Management and Clock modules and compares the results with known thresholds. 1-bit pass/ fail result is stored in the calibration result for every signal.

The monitor can be triggered using [FECSS Monitor Enable Trigger API](#) and the response is stored in memory mapped response [T\\_RL\\_API\\_MON\\_PMCLK\\_DCSIG\\_RESULT](#).

#### API Definition

|                                    |                                                 |
|------------------------------------|-------------------------------------------------|
| <b>API Index</b>                   | 0x0099U                                         |
| <b>API Function Name</b>           | r1_monPmClkDcSigCfg                             |
| <b>API Configuration Structure</b> | <a href="#">T_RL_API_MON_PMCLK_DCSIG_CFG</a>    |
| <b>API Response Structure</b>      | None                                            |
| <b>Monitor Response Structure</b>  | <a href="#">T_RL_API_MON_PMCLK_DCSIG_RESULT</a> |

► **API Function**

mmWaveLink C function declaration

```
// API Index Macro
#define M_RL_API_ID_MON_PMCLK_DCSIG_CFG ((UINT16)0x0099U)
// API Function Definition
T_RETURNTYPE r1_monPmClkDcSigCfg(UINT8 c_devIndex, const T_RL_API_MON_PMCLK_DCSIG_CFG
→ *p_apiCmdData);
```

► **Configuration C Structure**

**Table 2.81:** [T\\_RL\\_API\\_MON\\_PMCLK\\_DCSIG\\_CFG](#)

| Field                         | Data Type | Size | Offset |
|-------------------------------|-----------|------|--------|
| <a href="#">h_RfFreqStart</a> | UINT16    | 2    | 0      |
| <a href="#">h_Reserved1</a>   | UINT16    | 2    | 2      |
| <a href="#">w_Reserved2</a>   | UINT32    | 4    | 4      |
| <a href="#">w_Reserved3</a>   | UINT32    | 4    | 8      |
| Total                         |           | 12   |        |

► Response C Structure

**Table 2.82:** T\_RL\_API\_MON\_PMCLK\_DCSIG\_RESULT

| Field              | Data Type | Size | Offset    |
|--------------------|-----------|------|-----------|
| xh_ErrorCode       | SINT16    | 2    | 0         |
| h_Reserve1         | UINT16    | 2    | 2         |
| w_PmClkDcMonStatus | UINT32    | 4    | 4         |
| c_VRef1Val         | UINT8     | 1    | 8         |
| c_VRef2Val         | UINT8     | 1    | 9         |
| c_VRef3Val         | UINT8     | 1    | 10        |
| c_VRef4Val         | UINT8     | 1    | 11        |
| w_Reserve2         | UINT32    | 4    | 12        |
| w_Reserve3         | UINT32    | 4    | 16        |
| w_FrameCount       | UINT32    | 4    | 20        |
| Total              |           |      | <b>24</b> |

### Configuration Fields

► h\_RfFreqStart

Monitor chirp start frequency in low resolution.

| RF Frequency | Resolution                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60GHz        | $1LSB = (3 \times APPLL\_FREQ)/2^{10} \approx 1.172MHz$<br><u>Valid Range:</u> 57 GHz to 64 GHz<br>for APPLL_FREQ = 400MHz: 0xBE00U (57GHz) to 0xD555U (64 GHz)*<br>*Variant specific limitations in Release Notes |
| 77GHz        | $1LSB = (4 \times APPLL\_FREQ)/2^{10} \approx 1.562MHz$<br><u>Valid Range:</u> 76 GHz to 81 GHz<br>for APPLL_FREQ = 400MHz: 0x0000BE00 (76GHz) to 0x0000CA80 (81GHz)                                               |

### Response Fields

Monitor response is stored in IPC memory. Refer [T\\_RL\\_FE\\_RFS\\_IPC\\_MON\\_RESULT\\_DATA\\_STRUCT](#) for the memory addresses.

► xh\_ErrorCode

Monitor error code. 2's complement signed number.

| Value                          | Definition |
|--------------------------------|------------|
| 0                              | Success    |
| 2's complement negative number | Failure    |

► `w_PmClkDcMonStatus`

`PM_CLK_DC_MON` status.

The measured all PM, CLK supply and bias GPADC DC signals for selected monitor configuration is compared with internal thresholds and result (pass/fail) will be sent out for each signal type.

| Value       | Definition                                                              |
|-------------|-------------------------------------------------------------------------|
| Bit [0]     | <code>PM_TOP_RF_LDO_1P2V_1POV_VIN</code> status                         |
| Bit [1]     | <code>PM_TOP_RF_LDO_1P2V_1POV_VOUT</code> status                        |
| Bit [2]     | <code>PM_TOP_VBG1P22V</code> status                                     |
| Bit [3]     | <code>CLK_TOP_VIN_1P8VCO_SENSE_SCALED_OP5</code> status                 |
| Bit [4]     | <code>CLK_TOP_VIN_1P8CLK_SENSE_SCALED_OP5</code> status                 |
| Bit [5]     | <code>CLK_TOP_VDDA_LDO_CLKTOP_IOBUF_1P4V_APPLL_SCALED_OP6</code> status |
| Bit [6]     | <code>CLK_TOP_VDDA_LDO_APPLL_VCO_1P4V_SCALED_OP6</code> status          |
| Bit [7]     | <code>CLK_TOP_VDDA_LDO_APPLL_CP_1P0_SCALED_OP6</code> status            |
| Bit [8]     | <code>CLK_TOP_VDDD_LDO_SDM_1P4V_SCALED_OP6</code> status                |
| Bit [9]     | <code>CLK_TOP_VDDA_LDO_SYNTH_VCO_SCALED_OP6</code> status               |
| Bit [10]    | <code>CLK_TOP_VDDA_LDO_SYNTH_DIV_SCALED_OP6</code> status               |
| Bit [11]    | <code>CLK_TOP_VDDA_LDO_SLICER_1P4V_SCALED_OP6</code> status             |
| Bit [12]    | <code>LODIST_COM_VDDA_1POV_SUPPLY</code> status                         |
| Bit [13]    | <code>LODIST_COM_LO_MULT_LDO_VOUT_SENSE_LOVV</code> status              |
| Bit [14]    | <code>PM_TOP_VREFOP45</code> status                                     |
| Bit [15]    | <code>PM_TOP_VFB_OP6V</code> status                                     |
| Bit [16]    | <code>PM_TOP_VREF_OP9V</code> status                                    |
| Bit [17]    | <code>PM_TOP_SCALED_VIOIN</code> status                                 |
| Bit [18]    | <code>CLK_TOP_SYNTH_DIVIDER_COMMON_MODE</code> status                   |
| Bit [19]    | <code>PM_TOP_DBC_REFSYS</code> status                                   |
| Bit [31:20] | Reserved status status                                                  |

▶ **c\_VRef1Val**

The REF1\_0P45V reference voltage GPADC measurement value. 1LSB = 1.8V/256

▶ **c\_VRef2Val**

The REF2\_0P6V reference voltage GPADC measurement value. 1LSB = 1.8V/256

▶ **c\_VRef3Val**

The REF3\_0P9V reference voltage GPADC measurement value. 1LSB = 1.8V/256.

▶ **c\_VRef4Val**

The REF4\_VION\_IN reference voltage GPADC measurement value. 1LSB = 1.8V/256.

▶ **w\_FrameCount**

RFS frame count when the monitor report is updated.

## 2.6 mmWaveLink Error Codes

mmWaveLink APIs use data type T\_RETURNTYPE to return the error code. Negative value of the T\_RETURNTYPE indicates error in the API execution and 0 indicates success. This section describes all the error codes supported by mmWaveLink APIs.

mmWaveLink Error Codes are grouped in following categories. Categories are assigned with a non-overlapping range of values for ease of use. Application should define error code **excluding range**  $[-2000, 0]$  to avoid overlap with mmWaveLink error codes.

- [mmWaveLink Interface Error Codes](#)
- [mmWaveLink Device Error Codes](#)
- [mmWaveLink Sensor Error Codes](#)
- [mmWaveLink Monitor Error Codes](#)
- [mmWaveLink RFS API Error Codes](#)
- [mmWaveLink RFS Monitor Error Codes](#)

### 2.6.1 mmWaveLink Interface Error Codes

This group defines the errors associated with mmWaveLink and application interface.

Range:  $[-100, 0]$

| T_RETURNTYPE | mmWaveLink Error Code and Description                   |
|--------------|---------------------------------------------------------|
| 0            | M_DFP_RET_CODE_OK<br>No-Error (Success)                 |
| 0            | M_DFP_OSI_RET_CODE_OK<br>No-Error (Success)             |
| 0            | M_DFP_CIF_RET_CODE_OK<br>No-Error (Success)             |
| -1           | M_DFP_RET_CODE_INVALID_INPUT<br>Invalid input - General |
| -2           | M_DFP_RET_CODE_RESP_TIMEOUT<br>API response timeout     |
| -3           | M_DFP_RET_CODE_FATAL_ERROR<br>Fatal error in DFP        |
| -4           | M_DFP_RET_CODE_RADAR_OSIF_ERROR<br>OS interface failure |
| -5           | M_DFP_RET_CODE_INVALID_API<br>Invalid API call          |
| -6           | M_DFP_RET_CODE_NULL_PTR_ERROR<br>NULL pointer error     |

| T_RETURNTYPE | mmWaveLink Error Code and Description                             |
|--------------|-------------------------------------------------------------------|
| -7           | M_DFP_RET_CODE_INTERFACE_CB_NULL<br>Interface callback is NULL    |
| -8           | M_DFP_RET_CODE_INVALID_DEVICE<br>Invalid device map/id            |
| -9           | M_DFP_RET_CODE_RADAR_PLTIF_ERROR<br>Platform interface failure    |
| -10          | M_DFP_RET_CODE_RADAR_CIF_ERROR<br>Communication interface failure |
| -11          | M_DFP_RET_CODE_MMWL_INIT_NOT_DONE<br>mmWaveLink Init not done     |
| -12          | M_DFP_RET_CODE_RFS_DBG_BUF_CB_NULL<br>RFS debug buffer is NULL    |
| [-100:-13]   | Reserved                                                          |

## 2.6.2 mmWaveLink Device Error Codes

This group defines the errors associated with [mmWaveLink Device Configuration APIs](#).

Range: [-300, -101]

| T_RETURNTYPE | mmWaveLink Error Code and Description                                 |
|--------------|-----------------------------------------------------------------------|
| -101         | M_DFP_RET_CODE_RFS_BOOT_ERROR<br>RFS boot failure                     |
| -102         | M_DFP_RET_CODE_RFS_MB_INIT_ERROR<br>RFS MB Init failure               |
| -103         | M_DFP_RET_CODE_RFS_MB_BUSY_ERROR<br>RFS MB busy while sending command |
| -104         | M_DFP_RET_CODE_RFS_MB_RESP_ERROR<br>RFS MB empty while reading result |
| -105         | M_DFP_RET_CODE_RFS_PROTOCOL_ERROR<br>RFS Protocol error               |
| -106         | M_DFP_RET_CODE_RFS_API_SIZE_ERR<br>RFS cmd/res API size error         |
| -107         | M_DFP_RET_CODE_DEVICE_NOT_POWERED<br>FECSS device is not powered up   |
| -108         | M_DFP_RET_CODE_REG_READBACK_ERROR<br>Register readback error          |

| T_RETURNTYPE | mmWaveLink Error Code and Description                           |
|--------------|-----------------------------------------------------------------|
| -109         | M_DFP_RET_CODE_RFS_RESP_TIMEOUT<br>RFS Response timeout         |
| -110         | M_DFP_RET_CODE_RFS_CMDID_MISMATCH<br>RFS cmd id mismatch        |
| -111         | M_DFP_RET_CODE_MEM_INIT_TIMEOUT<br>Device Mem init failure      |
| -112         | M_DFP_RET_CODE_RFS_BOOT_TIMEOUT<br>RFS boot timeout error       |
| -113         | M_DFP_RET_CODE_INVAL_DEV_PWR_MODE<br>Invalid Device power mode  |
| -114         | M_DFP_RET_CODE_INVAL_DEV_CLK_SRC<br>Invalid Device clock source |
| -115         | M_DFP_RET_CODE_INVAL_FT_CLK_SRC<br>Invalid FT clock source      |
| -116         | M_DFP_RET_CODE_INVAL_XTAL_CLK_SRC<br>Invalid XTAL clock         |
| -117         | M_DFP_RET_CODE_INVAL_CT_RESOL<br>Invalid CT resolution          |
| -118         | M_DFP_RET_CODE_FEC_POWERUP_TIMEOUT<br>FECSS powerup timeout     |
| -119         | M_DFP_RET_CODE_FEC_PWRDOWN_TIMEOUT<br>FECSS power down timeout  |
| -120         | M_DFP_RET_CODE_INVAL_APPL_CLK_CTRL<br>Invalid APLL clock ctrl   |

### 2.6.3 mmWaveLink Sensor Error Codes

This group defines the errors associated with [mmWave Sensor APIs](#)

Range: [-500, -301]

| T_RETURNTYPE | mmWaveLink Error Code and Description                          |
|--------------|----------------------------------------------------------------|
| -301         | M_DFP_RET_CODE_SENS_INVAL_SAMP_RATE<br>Invalid sample rate     |
| -302         | M_DFP_RET_CODE_SENS_INVAL_DIG_BITS<br>Invalid Digout bits      |
| -303         | M_DFP_RET_CODE_SENS_INVAL_DFEFIR_SEL<br>Invalid DFE FIR select |

| T_RETURNTYPE | mmWaveLink Error Code and Description                                |
|--------------|----------------------------------------------------------------------|
| -304         | M_DFP_RET_CODE_SENS_INVAL_VCO_MC_SEL<br>Invalid VCO Multichip select |
| -305         | M_DFP_RET_CODE_SENS_INVAL_NUMADC_SAMP<br>Invalid num ADC samples     |
| -306         | M_DFP_RET_CODE_SENS_INVAL_TX_MIMO<br>Invalid TX MIMO pattern         |
| -307         | M_DFP_RET_CODE_SENS_INVAL_RAMPEND<br>Invalid rampend time            |
| -308         | M_DFP_RET_CODE_SENS_INVAL_HPF_SEL<br>Invalid HPF select              |
| -309         | M_DFP_RET_CODE_SENS_INVAL_RX_GAIN<br>Invalid RX gain select          |
| -310         | M_DFP_RET_CODE_SENS_INVAL_RF_GAIN<br>Invalid RF gain select          |
| -311         | M_DFP_RET_CODE_SENS_INVAL_TX_BO<br>Invalid TX Back off               |
| -312         | M_DFP_RET_CODE_SENS_INVAL_IDLE_TIME<br>Invalid idle time             |
| -313         | M_DFP_RET_CODE_SENS_INVAL_ADCFRAC_TIME<br>Invalid adc fract time     |
| -314         | M_DFP_RET_CODE_SENS_INVAL_ADCSKIP_SAMP<br>Invalid adc skip samples   |
| -315         | M_DFP_RET_CODE_SENS_INVAL_TXSTART_TIME<br>Invalid TX start time      |
| -316         | M_DFP_RET_CODE_SENS_INVAL_RF_SLOPE<br>Invalid RF slope               |
| -317         | M_DFP_RET_CODE_SENS_INVAL_RF_FREQ<br>Invalid RF Frequency            |
| -318         | M_DFP_RET_CODE_SENS_INVAL_TX_EN<br>Invalid TX enable                 |
| -319         | M_DFP_RET_CODE_SENS_INVAL_TXBPM_EN<br>Invalid TX BPM enable          |
| -320         | M_DFP_RET_CODE_SENS_INVAL_NUM_CHIRPS<br>Invalid Num of chirps        |
| -321         | M_DFP_RET_CODE_SENS_INVAL_NUM_ACCUM<br>Invalid Num of accumulation   |

| T_RETURNTYPE | mmWaveLink Error Code and Description                                     |
|--------------|---------------------------------------------------------------------------|
| -322         | M_DFP_RET_CODE_SENS_INVAL_BURST_PERD<br>Invalid Burst period              |
| -323         | M_DFP_RET_CODE_SENS_INVAL_NUM_BURST<br>Invalid Num of bursts              |
| -324         | M_DFP_RET_CODE_SENS_INVAL_FRAME_PERD<br>Invalid Frame period              |
| -325         | M_DFP_RET_CODE_SENS_INVAL_NUM_FRAME<br>Invalid num of frames              |
| -326         | M_DFP_RET_CODE_SENS_INVAL_FRAME_TRIG<br>Invalid frame trigger mode        |
| -327         | M_DFP_RET_CODE_SENS_INVAL_CT_START_LB<br>Invalid frame signal LB enable   |
| -328         | M_DFP_RET_CODE_SENS_INVAL_FRAME_STOP<br>Invalid frame stop                |
| -329         | M_DFP_RET_CODE_SENS_INVAL_PERCHRP_LEN<br>Invalid Per chirp array length   |
| -330         | M_DFP_RET_CODE_SENS_INVAL_PERCHRP_RPCNT<br>Invalid per chirp repeat count |
| -331         | M_DFP_RET_CODE_SENS_INVAL_PERCHRP_CTRL<br>Invalid per chirp control       |
| -332         | M_DFP_RET_CODE_SENS_INVAL_PERCHRP_ADDR<br>Invalid per chirp address       |
| -333         | M_DFP_RET_CODE_SENS_INVAL_HPF_FI_TIME<br>Invalid HPF Fast Init Tlme       |
| -334         | M_DFP_RET_CODE_SENS_INVAL_CRD_NSLOPE<br>Invalid CRD Nslope                |
| -335         | M_DFP_RET_CODE_SENS_INVAL_LIVE_MON_CFG<br>Inavlid Live Mon cfg            |
| -336         | M_DFP_RET_CODE_SENS_INVAL_LB_FREQ<br>Inavlid LB freq                      |

## 2.6.4 mmWaveLink Monitor Error Codes

This group defines the errors associated with [mmWaveLink Monitor Configuration APIs](#).

Range: [-700, -501]

| T_RETURNTYPE | mmWaveLink Error Code and Description                                  |
|--------------|------------------------------------------------------------------------|
| -501         | M_DFP_RET_CODE_MON_INVAL_SYNTH_START<br>Invalid SYNTH mon start time   |
| -502         | M_DFP_RET_CODE_MON_INVAL_SYNTH_THRSH<br>Invalid SYNTH mon threshold    |
| -503         | M_DFP_RET_CODE_MON_INVAL_PERCHRP_ADDR<br>Invalid Rx Sat mon result add |
| -504         | M_DFP_RET_CODE_MON_INVAL_GPADC_INST<br>Invalid GPADC num instructions  |
| -505         | M_DFP_RET_CODE_MON_INVAL_TX_IND<br>Invalid TX index select             |

## 2.6.5 mmWaveLink RFS API Error Codes

This group defines error codes returned by the RFS firmware for mailbox APIs. Range: [-1500, -1000]

| T_RETURNTYPE | mmWaveLink Error Code and Description            |
|--------------|--------------------------------------------------|
| -1000        | M_DFP_RET_CODE_RFS_INVALID_CMDID                 |
| -1002        | M_DFP_RET_CODE_RFS_INVALID_MSG_LEN               |
| -1003        | M_DFP_RET_CODE_RFS_INVALID_RX_MASK               |
| -1004        | M_DFP_RET_CODE_RFS_INVALID_TX_MASK               |
| -1005        | M_DFP_RET_CODE_RFS_INVALID_APPL_CTRL             |
| -1006        | M_DFP_RET_CODE_RFS_INVALID_RF_CTRL_OVERRIDE_MASK |
| -1007        | M_DFP_RET_CODE_RFS_INVALID_CAL_TEMP_BIN          |
| -1008        | M_DFP_RET_CODE_RFS_INVALID_CAL_FREQ              |
| -1009        | M_DFP_RET_CODE_RFS_INVALID_CAL_FREQ_SLOPE        |
| -1010        | M_DFP_RET_CODE_RFS_INVALID_CAL_EN_MASK           |
| -1011        | M_DFP_RET_CODE_RFS_INVALID_CHIRP_PS_DIS_MASK     |
| -1012        | M_DFP_RET_CODE_RFS_INVALID_BURST_PS_DIS_MASK     |
| -1013        | M_DFP_RET_CODE_RFS_INVALID_RFS_SENS_START_MODE   |
| -1014        | M_DFP_RET_CODE_RFS_INVALID_RFS_SENS_STOP_MODE    |
| -1015        | M_DFP_RET_CODE_RFS_INVALID_SENS_LB_CTRL          |
| -1016        | M_DFP_RET_CODE_RFS_INVALID_SENS_LB_ENA           |
| -1017        | M_DFP_RET_CODE_RFS_GPADC_BUSY                    |

| T_RETURNTYPE | mmWaveLink Error Code and Description         |
|--------------|-----------------------------------------------|
| -1018        | M_DFP_RET_CODE_RFS_INVALID_RDIF_ENA_CTRL      |
| -1019        | M_DFP_RET_CODE_RFS_INVALID_RDIF_SAMP_COUNT    |
| -1020        | M_DFP_RET_CODE_RFS_INVALID_ORBIT_RECORD       |
| -1021        | M_DFP_RET_CODE_RFS_APPLL_ON_FAILED            |
| -1022        | M_DFP_RET_CODE_RFS_APPLL_OFF_IN_CAL           |
| -1023        | M_DFP_RET_CODE_RFS_INVALID_TESTPATRN_ENA_CTRL |
| -1024        | M_DFP_RET_CODE_RFS_INVALID_TEMP_MEAS_CHANNEL  |
| -1025        | M_DFP_RET_CODE_RFS_LOOPBACK_ACTIVE            |
| -1026        | M_DFP_RET_CODE_RFS_GPADC_IFM_CONV_ERROR       |
| -1027        | M_DFP_RET_CODE_RFS_GPADC_IFM_INVAL_SAMPLS     |
| -1028        | M_DFP_RET_CODE_RFS_GPADC_IFM_INVAL_BUF_INDX   |
| -1029        | M_DFP_RET_CODE_RFS_INVALID_MON_EN_MASK        |
| -1030        | M_DFP_RET_CODE_RFS_INVALID_MON_FAULT_MASK     |
| -1031        | M_DFP_RET_CODE_RFS_MON_MANAGER_BUSY           |
| -1032        | M_DFP_RET_CODE_RFS_INVALID_DEBUG_DATA_ADDRESS |
| -1033        | M_DFP_RET_CODE_RFS_INVALID_TX_INDEX           |
| -1034        | M_DFP_RET_CODE_RFS_INVALID_PD_INDEX           |
| -1035        | M_DFP_RET_CODE_RFS_INVALID_SUM_SAMPLES        |
| -1036        | M_DFP_RET_CODE_RFS_INVALID_PD_LNA_INDEX       |
| -1037        | M_DFP_RET_CODE_RFS_GPADC_CTM_MEM_INIT_TIMEOUT |
| -1038        | M_DFP_RET_CODE_RFS_INVALID_BOOT_CAL_DATA      |

## 2.6.6 mmWaveLink RFS Monitor Error Codes

This group defines the errors associated with RFS monitors and calibrations. These errors could be reported in the monitor results (e.g. [xh\\_ErrorCode](#)) and calibration APIs. Range: [-1099, -1500]

| T_RETURNTYPE | mmWaveLink Error Code and Description     |
|--------------|-------------------------------------------|
| -1500        | M_CALMON_ERROR_FFT_CHIRP_MEAS_FAILED      |
| -1501        | M_CALMON_ERROR_PD_MEAS_FAILED             |
| -1502        | M_CAL_ERROR_RXGAIN_OPTIMAL_PGA_CFG_FAILED |

| T_RETURNTYPE | mmWaveLink Error Code and Description       |
|--------------|---------------------------------------------|
| -1503        | M_CAL_ERROR_RXGAIN_RF_GAIN_THRES_CHK_FAILED |
| -1504        | M_CALMON_ERROR_SETUP_FAILED                 |
| -1505        | M_CALMON_ERROR_DCBIST_MEAS_FAILED           |
| -1506        | M_CALMON_ERROR_INVALID_HPF_SEL              |

# Chapter 3

## Execution Time and Constraints

This section describes API and important event execution timings. The section also includes timing restrictions which must be honored by the application across different APIs. mmWaveLink APIs may not report error for violating these settings. These values are also device specific.

### 3.1 Chirp, Burst and Frame Timing Constraints

Chirp timing parameters like chirp idle time, skip samples, and chirp ramp end time, along with parameters such as burst and frame times are to be set according to conditions mentioned in this section. Hardware functionality can be affected if these conditions are violated.

#### 3.1.1 Burst Timing Constraints

**Table 3.1:** Burst Timing Constraints

| Variable                                           | Description                                                     | xWRL6432<br>xWRL1432 |
|----------------------------------------------------|-----------------------------------------------------------------|----------------------|
| Burst Start Time<br><i>BurstStartTime</i>          | Time required for RFS firmware to process the Burst Start event | 65 us                |
| Burst End Time<br><i>BurstEndTime</i>              | Time required for RFS firmware to process the Burst End event   | 50 us                |
| Minimum Burst Idle Time<br><i>MinBurstIdleTime</i> | <i>BurstStartTime + BurstEndTime</i>                            | 115us                |

#### 3.1.2 Frame Timing Constraints

**Table 3.2:** Frame Timing Constraints

| Variable                                           | Description                                                     | xWRL6432<br>xWRL1432 |
|----------------------------------------------------|-----------------------------------------------------------------|----------------------|
| Frame Start Time<br><i>FrameStartTime</i>          | Time required for RFS firmware to process the Frame Start event | 25 us                |
| Frame End Time<br><i>FrameEndTime</i>              | Time required for RFS firmware to process the Frame End event   | 15 us                |
| Minimum Frame Idle Time<br><i>MinFrameIdleTime</i> | <i>FrameStartTime + FrameEndTime</i>                            | 40 us                |

#### 3.1.3 Chirp Idle Time Constraints

Test

**Table 3.3:** Minimum Chirp Idle-Time Constraints

| Inter-Chirp Power Save Configuration                         | Minimum Inter-Chirp Idle-Time                                                                                                                                                                                    |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power Save Enabled<br><code>c_InterChirpPsDis</code> = 0x00  | $\max(6\mu s - \text{xh\_ChirpTxStartTime}, 3.1\mu s)$<br><b>Example:</b> <ul style="list-style-type: none"> <li><code>xh_ChirpTxStartTime</code> = 4us</li> <li><code>h_ChirpIdleTime</code> = 3.1us</li> </ul> |
| Power Save Disabled<br><code>c_InterChirpPsDis</code> = 0x1C | $\max(4\mu s - \text{xh\_ChirpTxStartTime}, 3.1\mu s)$<br><b>Example:</b> <ul style="list-style-type: none"> <li><code>xh_ChirpTxStartTime</code> = 0us</li> <li><code>h_ChirpIdleTime</code> = 4us</li> </ul>   |

### 3.1.4 Skip Samples Constraints

**Note** The term "skip samples" refers to the number of RX ADC samples at the beginning of each chirp which are skipped (i.e. not collected for radar processing) by programming the hardware via `h_ChirpAdcStartTime`.

In each chirp, the initial samples exhibit settling behavior, which arises in the synthesizer PLL and RX baseband high-pass and low-pass filters (analog and digital). It is mandatory to program skip samples parameter (see `h_ChirpAdcStartTime`) high enough to wait out these (potentially abrupt) initial transients.

Specifically,

**Table 3.4:** Skip Samples Constraints

| Chirp Start frequency |                | <code>c_DfeFirSel</code> | Recommended <code>AdcSkipSamples</code>                          |
|-----------------------|----------------|--------------------------|------------------------------------------------------------------|
| 60GHz devices         | 77GHz devices  |                          |                                                                  |
| [57.5, 64] GHz        | [76.5, 81] GHz | 0 (long filter)          | $\geq 12 + \max((1.5\mu s \times F_s) + 4, (2\mu s \times F_s))$ |
|                       |                | 1 (short filter)         | $\geq 8 + \max((1.5\mu s \times F_s) + 3, (2\mu s \times F_s))$  |
| Otherwise             | Otherwise      | 0 (long filter)          | $\geq 12 + \max((1.5\mu s \times F_s) + 4, (3\mu s \times F_s))$ |
|                       |                | 1 (short filter)         | $\geq 8 + \max((1.5\mu s \times F_s) + 3, (3\mu s \times F_s))$  |

**Note** 1.5us in the above table corresponds to the recommended HPF Fast Init Duration (see `c_HpfFastInitDuration`). The other parameters correspond to the group delay and settling delay of LPFs (which depend on the user's filter type selection) and synthesizer PLL settling delay (which depends on RF start frequency (see `w_ChirpRfFreqStart`)).

### 3.1.5 Chirp Ramp End Time Constraints

The user should program Ramp End Time higher than the time necessary for RX ADC sampling and filtering. The time necessary is a function of the sampling rate,  $F_s$ , in Hz (`c_DigOutputSampRate`), as well as the number of skip samples (`AdcSkipSamples`) and number of ADC samples (`h_NumOfAdcSamples`) as per the following table:

**Table 3.5:** Ramp End Time Constraints

| <b>RX sampling rate (<math>F_s</math>)</b> | <b>c_DfeFirSel</b> | <b>Ramp End Time (in s)</b>                                       |
|--------------------------------------------|--------------------|-------------------------------------------------------------------|
| < 1.5 MHz                                  | 0 (long filter)    | $\geq (\text{AdcSkipSamples} + \text{h_NumOfAdcSamples} - 4)/F_s$ |
|                                            | 1 (short filter)   |                                                                   |
| >= 1.5 MHz                                 | 0 (long filter)    | $\geq (\text{AdcSkipSamples} + \text{h_NumOfAdcSamples} - 8)/F_s$ |
|                                            | 1 (short filter)   | $\geq (\text{AdcSkipSamples} + \text{h_NumOfAdcSamples} - 5)/F_s$ |

### 3.1.6 Chirp Periodicity Constraints

In setting the chirp timing parameters and sample counts, the user should ensure that the programmed chirp periodicity, i.e., Ramp End Time + Idle Time (set by fields: `h_ChirpRampEndTime`, `h_ChirpIdleTime`) always exceeds the time necessary for RX ADC sampling.

Specifically, ensure that  $(\text{RampEndTime} + \text{IdleTime}) \geq (\text{AdcSkipSamples} + \text{h_NumOfAdcSamples} + 4) / F_s$

**Warning** Chirp and burst timing restrictions must be satisfied for all the chirps while using per chirp LUTs

## 3.2 API Execution Time

### 3.2.1 mmWaveLink API Execution Time

Following tables list the worst case execution times for all the mmWaveLink APIs measured.

**Note**

- Execution time also depend on the implementation of call-back functions and Application interrupt processing latencies
- API timings are measured with AppSS and FECSS clocked using Fast Clock

**Table 3.6:** Execution Time for Initialization API      `timings:apiTimings:apis:init`

| <b>mmWaveLink API</b>                         | <b>Execution Time (us)</b> |
|-----------------------------------------------|----------------------------|
| <code>mmWaveLink Initialization API</code>    | 30                         |
| <code>mmWaveLink De-Initialization API</code> | 5                          |

**Table 3.7:** Execution Time for Device Control APIs      `timings:apiTimings:apis:init`

| <b>mmWaveLink API</b>                   | <b>Execution Time (us)</b>       |
|-----------------------------------------|----------------------------------|
| <code>FECSS Device Power On API</code>  | Cold Boot: 850<br>Warm Boot: 450 |
| <code>FECSS Device Power OFF API</code> | 125                              |
| <code>DFP Version Get API</code>        | 10                               |
| <code>FECSS RF Power On Off API</code>  | 20                               |

| mmWaveLink API                             | Execution Time (us)                                                           |
|--------------------------------------------|-------------------------------------------------------------------------------|
| FECSS Factory Calibration API              | xWRL6432: 1500<br>xWRL1432: 1900<br>with <code>h_CalCtrlBitMask</code> = 0xCE |
| FECSS RF Runtime Calibration API           | xWRL6432: 450<br>xWRL1432: 450<br>with <code>h_CalCtrlBitMask</code> = 0xCE   |
| FECSS RF Clock Bandwidth Configuration API | 20                                                                            |
| FECSS GPADC Measurement Configuration API  | 10                                                                            |
| FECSS GPADC Measurement Trigger API        | 40<br>(Configuration dependent)                                               |
| FECSS Temperature Measurement Config API   | 5                                                                             |
| FECSS Temperature Measurement Trigger API  | 65<br><code>h_TempCtrlBitMask</code> = 0x311                                  |
| FECSS Factory Calibration Data Get API     | 20                                                                            |
| FECSS Factory Calibration Data Set API     | 15                                                                            |
| FECSS Device Clock Ctrl API                | APLL On: 125<br>APLL Cal: 280<br>APLL Off: 10                                 |
| FECSS Device RDIF Control API              | 20                                                                            |
| FECSS Device Status Get API                | 20                                                                            |
| FECSS RF Status Get API                    | 20                                                                            |
| FECSS RF Fault Status Get API              | 10                                                                            |
| FECSS Die Id Get API                       | 5                                                                             |
| FECSS Rx-Tx Calibration Data Get API       | 10                                                                            |
| FECSS Rx-Tx Calibration Data Set API       | 10                                                                            |
| FECSS RFS Debug Configuration API          | 20                                                                            |
| FECSS RF Runtime Tx CLPC API               | 710 (per Tx channel)                                                          |

**Table 3.8:** Execution Time for Sensor Configuration APIs    `timings:apiTimings:apis:init`

| mmWaveLink API                          | Execution Time (us) |
|-----------------------------------------|---------------------|
| Sensor Profile Common Configuration API | 15                  |

| mmWaveLink API                                          | Execution Time (us) |
|---------------------------------------------------------|---------------------|
| Sensor Chirp Profile Common Configuration Get API       | 15                  |
| Sensor Chirp Profile Time Configuration API             | 10                  |
| Sensor Chirp Profile Time Configuration Get API         | 10                  |
| Sensor Per-Chirp Configuration API                      | 15                  |
| Sensor Per-Chirp Configuration Get API                  | 15                  |
| Sensor Per-Chirp Control API                            | 10                  |
| Sensor Per-Chirp Control Get API                        | 10                  |
| Sensor Frame Configuration API                          | 10                  |
| Sensor Frame Configuration Get API                      | 10                  |
| Sensor Start API                                        | 10                  |
| Sensor Stop API                                         | 5                   |
| Sensor Status Get API                                   | 10                  |
| Sensor Dynamic Power Save Disable Configuration API     | 20                  |
| Sensor Dynamic Power Save Disable Configuration Get API | 20                  |
| Sensor Loopback Configuration API                       | 5                   |
| Sensor Loopback Enable API                              | 20                  |

**Table 3.9:** Execution Time for Monitor Configuration APIs    timings:apiTimings:apis:init

| mmWaveLink API                                             | Execution Time (us)              |
|------------------------------------------------------------|----------------------------------|
| FECSS Monitor Enable Trigger API                           | 20                               |
| FECSS Peak-Detector Debug Monitor API                      | 350<br>(Configuration dependent) |
| FECSS Tx Power Debug Monitor API                           | 450<br>(Configuration dependent) |
| FECSS Synthesizer Frequency Live Monitor Configuration API | 5                                |
| FECSS Rx Saturation Live Monitor Configuration API         | 5                                |

| mmWaveLink API                                          | Execution Time (us) |
|---------------------------------------------------------|---------------------|
| FECSS PLL Control Voltage Monitor Configuration API     | 5                   |
| FECSS TxN-Rx Loopback Monitor Configuration API         | 5                   |
| FECSS TxN Power Monitor Configuration API               | 5                   |
| FECSS Tx Ball-Break Monitor Configuration API           | 5                   |
| FECSS TxN DC Signal Monitor Configuration API           | 5                   |
| FECSS Rx HPF and DC Signal Monitor Configuration API    | 5                   |
| FECSS PM and Clock DC Signals Monitor Configuration API | 5                   |

### 3.2.2 Calibration Execution Time

**Table 3.10:** Factory Calibration Execution Time

| Calibration                                        | Execution Time (us) |          |
|----------------------------------------------------|---------------------|----------|
|                                                    | xWRL6432            | xWRL1432 |
| Synth                                              | 180                 | 180      |
| PD                                                 | 250                 | 250      |
| LoDist                                             | 10                  | 10       |
| Rx IFA                                             | 425                 | 800      |
| Tx PA<br><i>c_TxPwrCalTxEnaMask = 0x3,<br/>0x1</i> | 650                 | 650      |

**Table 3.11:** Runtime Calibration Execution Time

| Calibration | Execution Time (us) |          |
|-------------|---------------------|----------|
|             | xWRL6432            | xWRL1432 |
| Synth       | 180                 | 180      |
| PD          | 250                 | 250      |
| LoDist      | 10                  | 10       |
| Rx IFA      | 2                   | 2        |
| Tx PA       | 2                   | 2        |

### 3.2.3 Monitor Execution Time

Following table tabulates **Worst Case** monitoring time for all the monitors supported by mmWave devices.

**Note** Monitoring durations are Configuration dependent

| Monitor                  | Execution Time (us) |          |
|--------------------------|---------------------|----------|
|                          | xWRL6432            | xWRL1432 |
| PLL V-Control            | 170                 | 170      |
| Tx-Rx Loopback           | 650                 | 650      |
| Tx Power (per Tx)        | 250                 | 250      |
| Tx Ball-Break (per Tx)   | 250                 | 250      |
| Tx DC Signal (per Tx)    | 250                 | 250      |
| Rx HPF and DC Signal     | 650                 | 650      |
| PM Clock DC Signal       | 250                 | 250      |
| DFE-FFT Monitor          | 300                 | 300      |
| Static Register Readback | 50                  | 50       |

# Chapter 4



## Recommended Sequences

### 4.1 In-Field Operation sequence

Following diagram describes a recommended mmWaveLink API sequence for in-field application which retains FECSS data memories across deep sleep cycles.

**Figure 4.1:** Recommended in-field operation API sequence



#### Notes:

- DFP Version Get API and FECSS RFS Debug Configuration API could be used immediately after FECSS Device Power On API for debug

- Monitor config and [FECSS Monitor Enable Trigger API](#) are required only on Safety Enabled devices.

## 4.2 Factory Calibration sequence

Following diagram describes a recommended mmWaveLink API sequence for factory calibration application.

**Figure 4.2:** Recommended factory calibration API sequence



## ICD Version 1.0

Release Date: 11<sup>th</sup> January, 2024

Description: xWRL6432 RTM Release

This is a baseline ICD for low end radar devices. All the API changes after this release will be tracked after this release.

## ICD Version 1.1

Release Date: 11<sup>th</sup> June, 2024

Description: xWRL1432 RTM Release

**Changes:** xWRL1432 RTM Release

- Updated default value for [`c\_SynthIcpTrim`](#) from 0x1 to 0x5
- MMWAVE\_DFP\_LOW-588: Added more details on minimum ramp end time in [`Skip Samples Constraints`](#)
- Added device specific backoff ranges in [`c\_CalTxBackOffSel`](#).

## ICD Version 1.2

Release Date: 10<sup>th</sup> July, 2025

Description: xWRL6432 AOP RTM Release

**Changes:** xWRL6432 AOP RTM Release

- Called out variant specific constraints where applicable (To be referred to using Release notes).
- MMWAVE\_DFP\_LOW-813: Updated Per-Chirp and MIMO priorities in [`c\_ChirpTxMimoPatSel`](#)



# Notice

Texas Instruments Incorporated ("TI") technical, application or other design advice, services or information, including, but not limited to, reference designs and materials relating to evaluation modules, (collectively, "TI Resources") are intended to assist designers who are developing applications that incorporate TI products; by downloading, accessing or using any particular TI Resource in any way, you (individually or, if you are acting on behalf of a company, your company) agree to use it solely for this purpose and subject to the terms of this Notice.

TI's provision of TI Resources does not expand or otherwise alter TI's applicable published warranties or warranty disclaimers for TI products, and no additional obligations or liabilities arise from TI providing such TI Resources. TI reserves the right to make corrections, enhancements, improvements and other changes to its TI Resources.

You understand and agree that you remain responsible for using your independent analysis, evaluation and judgment in designing your applications and that you have full and exclusive responsibility to assure the safety of your applications and compliance of your applications (and of all TI products used in or for your applications) with all applicable regulations, laws and other applicable requirements. You represent that, with respect to your applications, you have all the necessary expertise to create and implement safeguards that (1) anticipate dangerous consequences of failures, (2) monitor failures and their consequences, and (3) lessen the likelihood of failures that might cause harm and take appropriate actions. You agree that prior to using or distributing any applications that include TI products, you will thoroughly test such applications and the functionality of such TI products as used in such applications. TI has not conducted any testing other than that specifically described in the published documentation for a particular TI Resource.

You are authorized to use, copy and modify any individual TI Resource only in connection with the development of applications that include the TI product(s) identified in such TI Resource. NO OTHER LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE TO ANY OTHER TI INTELLECTUAL PROPERTY RIGHT, AND NO LICENSE TO ANY TECHNOLOGY OR INTELLECTUAL PROPERTY RIGHT OF TI OR ANY THIRD PARTY IS GRANTED HEREIN, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information regarding or referencing third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of TI Resources may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

TI RESOURCES ARE PROVIDED "AS IS" AND WITH ALL FAULTS. TI DISCLAIMS ALL OTHER WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED, REGARDING TI RESOURCES OR USE THEREOF, INCLUDING BUT NOT LIMITED TO ACCURACY OR COMPLETENESS, TITLE, ANY EPIDEMIC FAILURE WARRANTY AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT OF ANY THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

TI SHALL NOT BE LIABLE FOR AND SHALL NOT DEFEND OR INDEMNIFY YOU AGAINST ANY CLAIM, INCLUDING BUT NOT LIMITED TO ANY INFRINGEMENT CLAIM THAT RELATES TO OR IS BASED ON ANY COMBINATION OF PRODUCTS EVEN IF DESCRIBED IN TI RESOURCES OR OTHERWISE. IN NO EVENT SHALL TI BE LIABLE FOR ANY ACTUAL, DIRECT, SPECIAL, COLLATERAL, INDIRECT, PUNITIVE, INCIDENTAL, CONSEQUENTIAL OR EXEMPLARY DAMAGES IN CONNECTION WITH OR ARISING OUT OF TI RESOURCES OR USE THEREOF, AND REGARDLESS OF WHETHER TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

You agree to fully indemnify TI and its representatives against any damages, costs, losses, and/or liabilities arising out of your noncompliance with the terms and provisions of this Notice.

This Notice applies to TI Resources. Additional terms apply to the use and purchase of certain types of materials, TI products and services. These include; without limitation, TI's standard terms for semiconductor products (<http://www.ti.com/sc/docs/stdterms.htm>), evaluation modules, and samples (<http://www.ti.com/sc/docs/samptersms.htm>).

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265  
Copyright © 2023, Texas Instruments Incorporated