

# BQ79600-Q1 Automotive SPI/UART Communication Interface Functional-Safety Compliant With Automatic Host Wakeup

# 1 Features

- · Qualified for automotive applications
- AEC-Q100 Qualified with the following results:
  - Device temperature grade 1: -40°C to +125°C ambient operating temperature range
  - Device HBM ESD classification level 2
  - Device CDM ESD classification level C4B
- Functional Safety-Compliant
  - Developed for functional safety applications
  - Documentation available to aid ISO 26262 system design
    - Safety Manual
    - Functional Safety Analysis Report
  - Systematic capability up to ASIL-D
  - Hardware capability up to ASIL-D
- Automatic wake up of BMS/BMU system when fault is detected in ring architecture
- Support supply from 4.75-V to 40-V
- UART/SPI Host interface
- Compatible with 3.3-V/5-V logic
- Isolated differential daisy chain
  - Support ring architecture with one device
  - Support transformer/ capacitor isolation
- Designed for BCI/EMI/EMC robustness
- Supports BQ7961X-Q1 family, BQ7965X, BQ7963X and future products

# 2 Applications

- Battery management system (BMS)
- Other HEV/EV
- Fuel cell
- Energy storage

# **3 Description**

The BQ79600-Q1 is a communication (bridge) IC designed to interface between a microcontroller (MCU) and TI battery monitoring ICs, for example the BQ7961X-Q1. The information from the MCU is translated by the device to signals recognized by TI's battery management daisy chain protocol, and transmitted out. And signals from daisy chain are decoded to bit stream and then sent back to MCU.

When the MCU and PMIC are in SHUTDOWN/ SLEEP, the BQ79600-Q1 can wake them up if any unmasked fault is detected when using ring architecture.

## **Device Information**

| PART NUMBER <sup>(1)</sup> | PACKAGE        | BODY SIZE (NOM) |
|----------------------------|----------------|-----------------|
| BQ79600-Q1                 | TSSOP (16-pin) | 6.6 mm × 5.1 mm |

(1) For all available packages, see the orderable addendum at the end of the data sheet.



everse wakeup realure

# Simplified System Diagram



# **Table of Contents**

| 1 Features                           | 1<br>1         |
|--------------------------------------|----------------|
| 4 Revision History                   | 2              |
| 5 Pin Configuration and Functions    | 3              |
| Pin Functions                        | 3              |
| 6 Specifications                     | 4              |
| 6.1 Absolute Maximum Ratings         | 4              |
| 6.2 ESD Ratings                      | 4              |
| 6.3 Recommended Operating Conditions | 4              |
| 6.4 Thermal Information              | 4              |
| 6.5 Electrical Characteristics       | <mark>5</mark> |
| 6.6 Timing Requirements              | <mark>6</mark> |
| 6.7 Typical Characteristics          | 9              |
| 7 Detailed Description               | 10             |
| 7.1 Overview                         | 10             |
| 7.2 Functional Block Diagram         | 10             |
| 7.3 Feature Description              | 10             |
| 7.4 Device Functional Modes          | 36             |
|                                      |                |

| 7.5 Register Maps                                     | .37  |
|-------------------------------------------------------|------|
| 8 Application and Implementation                      | . 55 |
| 8.1 Application Information                           | 55   |
| 8.2 Typical Applications                              | 55   |
| 9 Power Supply Recommendations                        | .59  |
| 10 Layout                                             | .60  |
| 10.1 Layout Guidelines                                | . 60 |
| 10.2 Layout Example                                   | . 60 |
| 11 Device and Documentation Support                   | .63  |
| 11.1 Device Support                                   | .63  |
| 11.2 Third-Party Products Disclaimer                  | 63   |
| 11.3 Receiving Notification of Documentation Updates. | . 63 |
| 11.4 Support Resources                                | 63   |
| 11.5 Trademarks                                       | .63  |
| 11.6 Electrostatic Discharge Caution                  | .63  |
| 11.7 Glossary                                         | .63  |
| 12 Mechanical, Packaging, and Orderable               |      |
| Information                                           | 64   |
|                                                       |      |

# **4 Revision History**

| Cł | nanges from Revision * (November 2019) to Revision A (June 2020) | Page |
|----|------------------------------------------------------------------|------|
| •  | Changed from Advance Information to Production Data              | 1    |



# **5** Pin Configuration and Functions



Figure 5-1. PW Package 16-Pin TSSOP Top View

## **Pin Functions**

| PIN                    |     |        | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|------------------------|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| NAME                   | NO. |        | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| VIO                    | 3   | Р      | Power supply input for UART/SPI input/output pins. Decouple with a 0.1µF capacitor to GND. VIO should be powered before SCLK, nCS, RX/MOSI, TX/MISO, NFAULT, nUART/SPI (SPI_RDY) is driven.                                                                                                                                                                                                                                                                                  |  |  |
| SCLK                   | 6   | DI     | SPI clock input. If SPI interface is used, this pin is connected to SPI master controller. Connect to GND with a 10-100kohm pull-down resistor. If not used, connect to GND.                                                                                                                                                                                                                                                                                                 |  |  |
| nCS                    | 7   | DI     | Active low chip select pin for SPI interface. Connect to VIO with 10-100kohm pull-up resistor in SPI mode. Cannot hardwire to GND in SPI mode. Connect to GND in UART mode.                                                                                                                                                                                                                                                                                                  |  |  |
| RX/MOSI                | 4   | DI     | UART receiver input or SPI master out slave in. Connect to VIO with a 10-100kohm pull-up resistor. Don't leave it unconnected.                                                                                                                                                                                                                                                                                                                                               |  |  |
| TX/MISO                | 5   | DO     | UART transmitter output or SPI master in slave out. Pull up to VIO with a 10-100kohm pull-up resistor at MCU side. MISO pin drives high in SPI idle mode, cannot directly support SPI multidrop, if multidrop is needed, add a tri-state buffer between BQ79600-Q1 and MCU.                                                                                                                                                                                                  |  |  |
| NFAULT                 | 2   | DO     | Fault indication output. Open drain active low. Pull up to VIO with 100kohm resistor. Connect NFAULT to host MCU GPIO. If not used, connect to GND.                                                                                                                                                                                                                                                                                                                          |  |  |
| nUART/SPI<br>(SPI_RDY) | 8   | DI/O   | If used as UART mode, connect this pin to GND. If used as SPI mode, connect to VIO through 10-100kohm pull up resistor and connect this pin to MCU GPIO. This pin is used as an input pin to select SPI or UART interface before device finishes wakeup/reset initialization (SPI communication is ready). If SPI mode is selected, SPI_RDY has to be used by host to decide if read/write can be initiated or needing further wait. Refer to Section 7.3.2.1.2.2.1 details. |  |  |
| DVDD                   | 1   | Р      | 1.8V regulated output. DVDD supplies the internal digital circuits. Bypass DVDD with a $0.22\mu$ F (recommended) or a $0.47\mu$ F capacitor to GND.                                                                                                                                                                                                                                                                                                                          |  |  |
| GND                    | 9   | Р      | Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| CVDD                   | 14  | Р      | Dedicated 5V supply used for the daisy chain communications. Decouple with a $0.22\mu$ F (recommended) or a $0.47\mu$ F to GND.                                                                                                                                                                                                                                                                                                                                              |  |  |
| COMHN                  | 12  | AC-I/O | This is an AC coupled bi-directional I/O pin for daisy chain (VIF) communication. Do not apply                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| СОМНР                  | 13  | AC-I/O | external DC voltage to this pin. Shall connect to COMLN/P of adjacent device through proper isolation, see Section 7.3.2.1.1. Leave unconnected if (Ring Architecture) not used.                                                                                                                                                                                                                                                                                             |  |  |
| COMLN                  | 11  | AC-I/O | This is an AC coupled bi-directional I/O pin for daisy chain (VIF) communication. Do not apply                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| COMLP                  | 10  | AC-I/O | external DC voltage to this pin. Shall connect to COMHN/P of adjacent device through proper isolation, see Section 7.3.2.1.1. Leave unconnected if (Ring Architecture) not used.                                                                                                                                                                                                                                                                                             |  |  |
| INH                    | 16  | HV-O   | Inhibit pin (PMOS open drain) to control system voltage regulators, connect 100kohm resistor to GND. If reverse wake up feature is not used, connect this pin to BAT pin. Don't leave this pin floating.                                                                                                                                                                                                                                                                     |  |  |
| BAT                    | 15  | HV-P   | Battery supply Input. Supply internal LDOs and wakeup circuit. Connect to external supply through 10ohm resistor. Bypass to GND with 0.1µF.                                                                                                                                                                                                                                                                                                                                  |  |  |

(1) DI = digital input, DO = digital output, HV = high voltage

# 6 Specifications

## 6.1 Absolute Maximum Ratings

over operating free-air temperature range (unless otherwise noted)<sup>(1)</sup>

|                  |                                                                | MIN  | MAX     | UNIT |
|------------------|----------------------------------------------------------------|------|---------|------|
|                  | BAT to GND                                                     | -0.3 | 40      | V    |
|                  | INH to GND (INH is lower than BAT)                             | -0.3 | 40      | V    |
|                  | VIO, CVDD to GND                                               | -0.3 | 5.5     | V    |
| Input Voltage    | DVDD to GND                                                    | -0.3 | 1.98    | V    |
| input voitage    | MISO/TX, MOSI/RX, nCS, SCLK, NFAULT, nUART/SPI(SPI_RDY) to GND | -0.3 | VIO+0.3 | V    |
|                  | COMHP, COMHN, COMLP, COMLN to GND                              | -10  | 10      | V    |
|                  | COMHP to COMHN, COMLP to COMLN                                 | -6.5 | 6.5     | V    |
| INH current      |                                                                |      | 4       | mA   |
| I/O current      | MISO/TX current (100pF load, VIO=5V, 10ns transition-time)     |      | 8       | mA   |
| T <sub>A</sub>   | Ambient temperature                                            | -40  | 125     | °C   |
| TJ               | Junction temperature                                           | -40  | 150     | °C   |
| T <sub>stg</sub> | Storage temperature                                            | -65  | 150     | °C   |

(1) Stresses beyond those listed under Absolute Maximum Rating may cause permanent damage to the device. These are stress ratings only, which do not imply functional operation of the device at these or any other conditions beyond those indicated under Recommended Operating Condition. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## 6.2 ESD Ratings

|                       |                                      |                                                         |                              | VALUE | UNIT   |
|-----------------------|--------------------------------------|---------------------------------------------------------|------------------------------|-------|--------|
| V <sub>(ESD)</sub> El | Electrostatic discharge Charged devi | Human body model (HBM), per AEC Q100-002 <sup>(1)</sup> |                              | ±2000 |        |
|                       |                                      | Charged device model (CDM), per                         | Corner pins (1, 8, 9 and 16) | ±750  | ±750 V |
|                       |                                      | AEC Q100-011                                            | Other pins                   | ±500  |        |

(1) AEC Q100-002 indicates that HBM stressing shall be in accordance with the ANSI/ESDA/JEDEC JS-001 specification.

## 6.3 Recommended Operating Conditions

over operating free-air temperature range (unless otherwise noted)

|                        |                                                                                    | MIN   | TYP MAX | UNIT |
|------------------------|------------------------------------------------------------------------------------|-------|---------|------|
| V <sub>BAT, INH</sub>  | BAT, INH (INH is equal to or lower than BAT) (Powered by 12V Battery)              | 5.5   | 24      | V    |
| V <sub>VIO_RANGE</sub> | VIO input (applies to nCS, MOSI/RX, MISO/TX, SLCK, nUART/SPI<br>(SPI_RDY), NFAULT) | 3.135 | 5.25    | V    |
| I <sub>MISO/TX</sub>   | MISO/TX current                                                                    |       | 3       | mA   |
| I <sub>INH</sub>       | INH output current                                                                 |       | 2       | mA   |
| T <sub>A</sub>         | Operation temperature                                                              | -40   | 125     | °C   |

## 6.4 Thermal Information

|                       |                                            | BQ79600-Q1 |      |  |
|-----------------------|--------------------------------------------|------------|------|--|
|                       | THERMAL METRIC <sup>(1)</sup>              | PW(TSSOP)  | UNIT |  |
|                       |                                            | 16 PINS    |      |  |
| R <sub>0JA</sub>      | Junction-to-ambient thermal resistance     | 102        | °C/W |  |
| R <sub>0JC(top)</sub> | Junction-to-case (top) thermal resistance  | 28.9       | °C/W |  |
| R <sub>0JB</sub>      | Junction-to-board thermal resistance       | 49         | °C/W |  |
| $\Psi_{JT}$           | Junction-to-top characterization parameter | 14         | °C/W |  |



|             |                                              | BQ79600-Q1 |      |  |
|-------------|----------------------------------------------|------------|------|--|
|             | THERMAL METRIC <sup>(1)</sup>                | PW(TSSOP)  | UNIT |  |
|             |                                              | 16 PINS    |      |  |
| $\Psi_{JB}$ | Junction-to-board characterization parameter | 48.2       | °C/W |  |

(1) For more information about traditional and new thermal metrics, see the Semiconductor and IC Package Thermal Metrics application report.

# **6.5 Electrical Characteristics**

VIO = 3.3V, over operating free-air temperature range (unless otherwise noted)

|                             | PARAMETER                                                                    | TEST CONDITIONS                                                                                                              | MIN  | TYP  | MAX  | UNIT |  |  |  |
|-----------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|--|--|--|
| OPERATI                     | OPERATION VOLTAGE                                                            |                                                                                                                              |      |      |      |      |  |  |  |
| V <sub>BAT</sub>            |                                                                              | When reverse wakeup feature is used,<br>BAT pin is powered by "12V battery"                                                  | 5.5  |      | 24   | V    |  |  |  |
| V <sub>BAT</sub>            |                                                                              | When reverse wakeup feature is not<br>used, BAT/CVDD are powered by<br>regulated 5V                                          | 4.75 |      | 5.25 | V    |  |  |  |
| THERMA                      | L SHUTDOWN                                                                   |                                                                                                                              |      |      |      |      |  |  |  |
| T <sub>SHUT_R</sub>         | Thermal shutdown (rising direction)                                          | DieTemp sensor                                                                                                               | 126  | 138  | 150  | °C   |  |  |  |
| T <sub>SHUT_F</sub>         | Thermal shutdown (falling direction)                                         | DieTemp sensor                                                                                                               | 116  |      | 141  | °C   |  |  |  |
| SUPPLY                      | CURRENTS                                                                     |                                                                                                                              |      |      |      |      |  |  |  |
| I <sub>SHDN_1</sub>         | Supply current in SHUTDOWN mode device powered by regulated 5V supply        | VBAT shorted to CVDD, both equal to 5V, measured through GND pin                                                             |      |      | 7    | μA   |  |  |  |
| I <sub>SHDN_2</sub>         | Supply current in SHUTDOWN mode<br>powered by "12V" battery directly         | VBAT= 17V, CVDD self<br>powered, measured through GND pin                                                                    |      |      | 9    | μA   |  |  |  |
| IVALIDATE                   | Supply current in VALIDATE mode                                              | Current on BAT pin                                                                                                           |      |      | 168  | μA   |  |  |  |
| I <sub>SLP(IDLE)</sub>      | Baseline supply current in SLEEP mode                                        | Current on BAT pin, no fault, COMH and COML RX disabled, no HB TX                                                            |      |      | 110  | μA   |  |  |  |
| I <sub>SLP_RX_O</sub><br>N  | Additional supply current to SLEEP mode base line                            | When COML OR COMH RX is on                                                                                                   |      | 35   |      | μA   |  |  |  |
| I <sub>SLP_TX_O</sub><br>N  | Additional supply current to SLEEP mode base line                            | When COML or COMH tone transmiter is on (HB tone)                                                                            |      | ·    | 8    | μA   |  |  |  |
| I <sub>ACT(IDLE)</sub>      | Baseline supply current in ACTIVE mode                                       | Current on BAT pin, no fault, no communication, Tone RX/TX is off                                                            |      | 3    | 4    | mA   |  |  |  |
| I <sub>COMT</sub>           | Additional average current for one of BQ79600 daisy chain transmitters is on | Average current into VBAT when<br>BQ79600 transmits 14 bytes of data<br>(brdcast write 8 bytes of 0x00 into<br>address 0X1B) |      | 10   |      | mA   |  |  |  |
| Supplies                    | (AVAO_REF, always on internal supply)                                        |                                                                                                                              |      |      |      |      |  |  |  |
| V <sub>AVAORE</sub><br>G    | AVAOREG voltage                                                              | VBAT > min VBAT                                                                                                              |      | 2.45 |      | V    |  |  |  |
| V <sub>AVDDREF</sub><br>_OV | AVDDREF OV threshold                                                         | VBAT > min VBAT, hys = 130mV                                                                                                 | 2.8  |      | 3.1  | V    |  |  |  |
| Supplies                    | (CVDD)                                                                       |                                                                                                                              |      |      |      |      |  |  |  |
| V <sub>CVDD</sub>           | CVDD output voltage                                                          | No external load, C <sub>SUPPLIES</sub> = 0.22µF,<br>ACTIVE mode                                                             | 4.9  | 5    | 5.1  | V    |  |  |  |
| V <sub>CVDD_O</sub><br>v    | CVDD OV rising threshold                                                     | Hys = 140mV                                                                                                                  | 5.3  | 5.5  | 5.65 | V    |  |  |  |
| V <sub>CVDD_U</sub><br>v_f  | CVDD UV falling threshold                                                    |                                                                                                                              | 4.35 | 4.5  | 4.65 | V    |  |  |  |
| V <sub>CVDD_U</sub><br>v_r  | CVDD UV rising threshold                                                     |                                                                                                                              | 4.45 | 4.6  | 4.75 | V    |  |  |  |
| V <sub>CVDD_ILI</sub>       | CVDD current limit                                                           |                                                                                                                              | 53   |      | 81   | mA   |  |  |  |
| C <sub>CVDD</sub>           | Capacitance range on CVDD pin                                                | Not capacitor value                                                                                                          | 0.1  |      | 0.8  | μF   |  |  |  |

Copyright © 2020 Texas Instruments Incorporated

#### VIO = 3.3V, over operating free-air temperature range (unless otherwise noted)

|                              | PARAMETER                                                                     | TEST CONDITIONS                                                  | MIN                        | TYP | MAX                        | UNIT |
|------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------|----------------------------|-----|----------------------------|------|
| Supplies                     | (DVDD)                                                                        |                                                                  |                            |     | ¥                          |      |
| V <sub>DVDD</sub>            | DVDD output voltage                                                           | No external load, C <sub>SUPPLIES</sub> = 0.22µF,<br>ACTIVE mode | 1.75                       | 1.8 | 1.85                       | V    |
| V <sub>DVDD_O</sub><br>v     | DVDD OV rising threshold                                                      | Hys = 65mV                                                       | 1.9                        |     | 2.1                        | V    |
| V <sub>DVDD_U</sub><br>V_F   | DVDD UV falling threshold                                                     |                                                                  | 1.63                       |     | 1.69                       | V    |
| V <sub>DVDD_U</sub><br>V_R   | DVDD UV rising threshold                                                      |                                                                  | 1.68                       |     | 1.75                       | V    |
| V <sub>DVDD_ILI</sub><br>MIT | DVDD current limit                                                            |                                                                  | 20                         |     | 57                         | mA   |
| D <sub>DVDD</sub>            | Load capacitance on DVDD pin                                                  | Not capacitor value                                              | 0.1                        |     | 0.8                        | μF   |
| SNIFF DE                     | TECTOR                                                                        |                                                                  |                            |     |                            |      |
| V <sub>VAL_THR</sub><br>_P   | Sniffer detector threshold, rising swing on COMHP has to be larger than value | Sniffer is enabled, and device is in SHUTDOWN mode               | 3.2                        |     | 3.6                        | V    |
| INH Drive                    | r                                                                             |                                                                  |                            |     |                            |      |
| V <sub>DROP_IN</sub><br>H    | When INH is pulled up, voltage drop from BAT to INH                           | I <sub>INH</sub> = -0.5mA                                        |                            | 0.5 | 1                          | V    |
| V <sub>INH_DET</sub>         | Threshold to set [INH_STAT] to '1'                                            |                                                                  | 2.2                        |     |                            | V    |
| Reference                    | e Voltages                                                                    |                                                                  |                            |     |                            |      |
| Digital I/C                  | Ds (TX, RX, NFAULT)                                                           |                                                                  |                            |     |                            |      |
| V <sub>VIO_UV_</sub><br>R    | VIO UV rising                                                                 | Hys = 200mV                                                      | 2.5                        |     | 3.1                        | V    |
| V <sub>OH</sub>              | Output as logic level high (TX)                                               | FET pull up, lout=1mA, VIO = 3.3V or 5V                          | V <sub>VIO</sub> –0.1      |     |                            | V    |
| V <sub>OL</sub>              | Output as logic level low (TX)                                                | FET pull down, lout=1mA, VIO = 3.3V or 5V                        |                            |     | 0.1                        | V    |
| VIH                          | Input as logic level high (RX), requirement for user                          | VIO = 3.3V or 5V                                                 | 0.75 x<br>V <sub>VIO</sub> |     |                            | V    |
| VIL                          | Input as logic level low (RX), requirement for user                           | VIO = 3.3V or 5V                                                 |                            |     | 0.25 x<br>V <sub>VIO</sub> | V    |
| R <sub>NFAULT</sub>          | NFAULT pull down impedance                                                    | Use 100kohm external pull up                                     |                            |     | 1000                       | Ω    |
| Daisy-cha                    | ain Communication Bus                                                         |                                                                  |                            |     |                            |      |
| V <sub>DCCM_1</sub>          | Common mode voltage (COML and COMH)                                           | ACTIVE mode                                                      |                            | 2.2 |                            | V    |
| V <sub>DCCM_2</sub>          | Common mode voltage (COML and COMH)                                           | SLEEP or VALIDATE mode                                           |                            | 1   |                            | V    |
| V <sub>COMM_D</sub><br>ata   | COMM port data receiver threshold range $(V_{COMP}-V_{COMN})$                 |                                                                  | 1.04                       |     | 1.75                       | V    |
| V <sub>COMM_T</sub><br>ONE   | COMM port HB/FAULT tone receiver threshold range ( $V_{COMP}$ - $V_{COMN}$ )  |                                                                  | 1.13                       |     | 1.94                       | V    |

## 6.6 Timing Requirements

over operating free-air temperature range (unless otherwise noted)

| PARAMETER                 | TEST CONDITIONS                                                                                        | MIN | TYP | MAX | UNIT |
|---------------------------|--------------------------------------------------------------------------------------------------------|-----|-----|-----|------|
| POWER STATE TIMING        |                                                                                                        |     |     |     |      |
| t <sub>POR2COM</sub><br>м | From $V_{BAT}$ (rising) > $V_{POR}$ to device ready to receive WAKE ping, ramp up VBAT and VIO in 10µs |     |     | 1   | ms   |



#### over operating free-air temperature range (unless otherwise noted)

| PARAMETER                      |                                                                                   | TEST CONDITIONS                                                                                                                                                                  | MIN              | ТҮР | MAX   | UNIT   |
|--------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----|-------|--------|
| t <sub>SU(WAKE_</sub><br>SHUT) | Startup from SHUTDOWN/VALIDATE to ACTIVE mode                                     | From receiving WAKE ping (RX ping<br>going low-to-high) to device in ACTIVE<br>mode (ready to do µART /SPI<br>communication) (CVDD= 0.22µF<br>capacitor DVDD = 0.22µF capacitor) |                  | 2   | 3.5   | ms     |
| t <sub>su(slp2a</sub><br>ct)   | Startup from SLEEP to ACTIVE mode<br>(with Sleep2active ping)                     | From receiving SLP2ACT ping (RX ping<br>going low-to-high) to device in ACTIVE<br>mode (ready to do UART /<br>SPIcommunication)                                                  |                  | 260 | μs    |        |
| t <sub>SU(WAKE_</sub><br>SLP)  | Startup from SLEEP to ACTIVE mode (with WAKE ping)                                | From receiving WAKE ping (RX ping<br>going low-to-high) to device in ACTIVE<br>mode (ready to do UART /<br>SPIcommunication)                                                     | 6                |     |       | μs     |
| t <sub>RST</sub>               | Reset time from ACTIVE mode to<br>ACTIVE mode                                     | From receiving WAKE ping (RX ping<br>going low-to-high) or<br>CONTROL1[SOFT_RESET]=1 to device<br>in ACTIVE mode (ready to do UART /SPI<br>communication)                        |                  |     | 600   | μs     |
| t <sub>SLP</sub>               | From ACTIVE to SLEEP mode                                                         | From receiving SLEEP entry condition to<br>enter in SLEEP mode                                                                                                                   |                  |     | 100   | μs     |
| t <sub>SHTDN</sub>             | From ACTIVE/SLEEP/VALIDATE to<br>SHUTDOWN mode                                    | From receiving SHUTDOWN entry<br>condition to enter in SHUTDOWN mode<br>(CVDD<1.2V)                                                                                              |                  |     | 5     | ms     |
| t <sub>VALID_EN</sub><br>TRY   | From SHUTDOWN to VALIDATE                                                         | From fault tone toggling on COM port to<br>DVDD hit above 1.75V                                                                                                                  |                  |     | 10    | ms     |
| t <sub>VALID_TIM</sub>         | time to validate fault tone before transition to SHUTDOWN state                   | Start from DVDD out of reset                                                                                                                                                     | 150              |     |       | ms     |
| INH Drive                      | r TIMING                                                                          |                                                                                                                                                                                  | 1                |     |       |        |
| t <sub>INH_DLY</sub>           | After device enters VALIDATE, from first couplet of fault tone to INH pulled high |                                                                                                                                                                                  |                  | 720 |       | μs     |
| PING SIG                       | NAL TIMING                                                                        |                                                                                                                                                                                  | 1                |     |       |        |
| t <sub>HLD_WAK</sub><br>E      | From user perspective, WAKE ping low time on MOSI/RX pin                          | VBAT > VPOR, RX pin (low-pulse width)<br>VIO = 3.3 or 5V                                                                                                                         | 2.5              |     | 3     | ms     |
| t <sub>HLD_SD</sub>            | From user perspective, SHUTDOWN ping low time on MOSI/RX pin                      | VBAT > VPOR, RX pin (low-pulse<br>width) VIO = 3.3 or 5V                                                                                                                         | 12.5             |     |       | ms     |
| t <sub>StA</sub>               | From user perspective, SLEEPtoACTIVE ping low time on MOSI/RX pin                 | VBAT > VPOR                                                                                                                                                                      | 250              |     | 300   | μs     |
| Daisy-cha                      | ain Communication Bus TIMING                                                      |                                                                                                                                                                                  |                  |     |       |        |
| t <sub>PW_DC</sub>             | COMM data Pulse width of data (half bit time) for communiction                    |                                                                                                                                                                                  | 230              | 250 | 270   | ns     |
| t <sub>COMTONE</sub>           | Time between pulses within a comm tone (HFO based).                               | Transmit. From the beginning of a pulse until the beginning of the next pulse.                                                                                                   | 10.67            | 11  | 11.33 | μs     |
| t <sub>COMTONE</sub><br>_PLS   | Comm tone pulse width(HFO based)                                                  | Transmit                                                                                                                                                                         | 0.97             | 1   | 1.03  | μs     |
| t <sub>FLTTONE</sub>           | Time between pulses within a fault tone (LFO based).                              | Only transmit HB tone, not FAULT<br>tone. From the beginning of a pulse until<br>the beginning of the next pulse.                                                                | til 10.3 11.5 12 |     | 12.7  | μs     |
| t <sub>FLTTONE_</sub><br>PLS   | Fault tone or HB tone pulse width (analog delay based)                            |                                                                                                                                                                                  |                  | 1   |       | μs     |
| n <sub>HBDET</sub>             | HEARTBEAT: Number of pulses to detect as a valid tone (dig counter)               | Detect                                                                                                                                                                           |                  | 16  |       | pulses |
| n <sub>FTONEDE</sub><br>T      | FAULT TONE: Number of pulses to detect as a valid tone (dig counter)              | Detect                                                                                                                                                                           |                  | 64  |       | pulses |



#### over operating free-air temperature range (unless otherwise noted)

| PARAMETER                      |                                                                                                                                    | TEST CONDITIONS                                                                                            | MIN                       | TYP | MAX | UNIT       |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------|-----|-----|------------|
| t <sub>HB_PERIO</sub><br>D     | HEARTBEAT: Period between<br>HEARTBEAT Burst (from the beginning of<br>a HEARTBEAT to the beginning of the<br>next HEARTBEAT)      |                                                                                                            | 360                       | 400 | 440 | ms         |
| t <sub>HB_TIMEO</sub><br>UT    | HEARTBEAT: Timeout to considered as not receving HEARTBEAT                                                                         |                                                                                                            | 0.9                       | 1   | 1.1 | s          |
| t <sub>HB_FAST</sub>           | HEARTBEAT: If HEARTBEAT is received<br>within this time, it is considered receving<br>HEARTBEAT too fast                           |                                                                                                            |                           | 200 |     | ms         |
| t <sub>FTONE_PE</sub><br>RIOD  | Defined by BQ7961X, FAULT TONE:<br>Period between FAULT TONE Burst                                                                 | From the beginning of a FAULT TONE to the beginning of the next FAULT TONE                                 |                           | 50  |     | ms         |
| t <sub>ft_laten</sub>          | Fault Tone latency in Base Device                                                                                                  | From the time device receives the tone to the time asserts NFAULT                                          |                           | 24  |     | μs         |
| I/O TIMIN                      | G (TX, RX, NFAULT)                                                                                                                 | II                                                                                                         |                           |     |     |            |
| t <sub>RISE_TX</sub>           | Rise Time                                                                                                                          | C <sub>LOAD</sub> = 100pF, VIO=3.3V or 5V                                                                  |                           | 15  |     | ns         |
| t <sub>FALL_TX</sub>           | Fall Time                                                                                                                          | C <sub>LOAD</sub> = 100pF, VIO=3.3V or 5V                                                                  |                           | 15  |     | ns         |
| t <sub>FALL/</sub><br>RISE RX  | RX pin rise/fall time                                                                                                              |                                                                                                            |                           |     | 100 | ns         |
|                                | AING                                                                                                                               |                                                                                                            |                           |     |     |            |
| UARTER<br>R_BAUD               | UART TX/RX baud rate (either 250K or 1Mbps) error                                                                                  |                                                                                                            | -1.5                      |     | 1.5 | %          |
| t <sub>UART(CLR</sub><br>)     | UART Comm Clear low time                                                                                                           |                                                                                                            | 15                        |     | 20  | bit period |
| t <sub>UART(RX_</sub><br>HIGH) | UART high time after Comm Clear, before sending Clear or Reset                                                                     |                                                                                                            | 1                         |     |     | bit period |
| SPI TIMIN                      | IG                                                                                                                                 |                                                                                                            |                           |     |     |            |
| SCLK                           | SPI clock freq                                                                                                                     |                                                                                                            | 2                         |     | 6   | MHz        |
| n <sub>SPI(CLR)</sub>          | SPI Comm Clear low time                                                                                                            |                                                                                                            |                           | 8   |     | bit        |
| t <sub>SPI_R</sub>             | SPI clock rising edge                                                                                                              | 25% to 75%                                                                                                 |                           |     | 10  | ns         |
| t <sub>SPI_F</sub>             | SPI clock falling edge                                                                                                             | 25% to 75%                                                                                                 |                           |     | 10  | ns         |
| t <sub>SPI_CLKH</sub>          | SPI clock high time                                                                                                                |                                                                                                            | 70                        |     |     | ns         |
| t <sub>SPI_CLKL</sub>          | SPI clock low time                                                                                                                 |                                                                                                            | 70                        |     |     | ns         |
| t <sub>8</sub>                 | Max SPI_RDY service interval. This time<br>doesn't apply if total response bytes<br>(payload + overhead) is less than 256<br>bytes | Read SCLK = 6MHz, with 30% SPI BUS idle time                                                               |                           | 1   |     | ms         |
| t <sub>9</sub>                 | From nCS (25%) to SCLK rising (75%)                                                                                                |                                                                                                            | 500                       |     |     | ns         |
| t <sub>10</sub>                | From SCLK falling (25%) to nCS (75%)                                                                                               |                                                                                                            | 500                       |     |     | ns         |
| t <sub>11</sub>                | From nCS rising(75%) to nCS falling(25%)                                                                                           | Don't drop nCS while SPI_RDY is low                                                                        | 1                         |     |     | μs         |
| t <sub>12</sub>                | From nCS falling (25%) to stable<br>MISO(L:20% H:80%)                                                                              | Timing is defined at device pins, exclude<br>propergation delay of PCB traces (from<br>device perspective) | ns, exclude<br>aces (from |     | 42  | ns         |
| t <sub>13</sub>                | From SCLK falling (25%) to stable<br>MISO(L:20% H:80%)                                                                             | Timing is defined at device pins, exclude<br>propergation delay of PCB traces (from<br>device perspective) | exclude<br>s (from        |     | 42  | ns         |
| t <sub>14</sub>                | From nCS rising (75%) to MISO drive to<br>'1' (80%)                                                                                | Timing is defined at device pins, exclude<br>propergation delay of PCB traces (from<br>device perspective) |                           |     | 42  | ns         |
| t <sub>SU</sub>                | Setup time, refer to 75% of SCLK rising                                                                                            |                                                                                                            | 20                        |     |     | ns         |
| t <sub>H</sub>                 | Hold time, refer to 75% of SCLK rising                                                                                             |                                                                                                            | 20                        |     |     | ns         |
| SNIFF DE                       | TECTOR                                                                                                                             |                                                                                                            |                           |     |     |            |



over operating free-air temperature range (unless otherwise noted)

|                                                                                                        | PARAMETER                                                                | TEST CONDITIONS                                                      | MIN   | TYP | MAX   | UNIT   |
|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------|-------|-----|-------|--------|
| NVALIDATE                                                                                              | Number of pulses needed (digital counter) to transition to validate mode | Sniffer is enabled, and device is in SHUTDOWN mode                   |       | 64  |       | pulses |
| t <sub>SNIFFIDLE</sub> Timer length. Once timer expired, it resets Sniffer is enabled, a SHUTDOWN mode |                                                                          | Sniffer is enabled, and device is in SHUTDOWN mode                   | 20    |     | 52    | μs     |
| OSCILLATOR                                                                                             |                                                                          |                                                                      |       |     |       |        |
| f <sub>HFO</sub>                                                                                       | HFO frequency                                                            |                                                                      | 31.52 | 32  | 32.48 | MHz    |
| t <sub>HFOWDG</sub>                                                                                    | HFO watchdog time                                                        | Reset digital if HFO is stuck or period is > than the watchdog timer |       |     | 35    | μs     |
| f <sub>LFO</sub>                                                                                       | LFO frequency                                                            |                                                                      | 235.8 | 262 | 288.2 | kHz    |
| t <sub>LFOWDG</sub>                                                                                    | LFO watchdog time                                                        | Reset digital if LFO is stuck or period is > than the watchdog timer |       |     | 35    | μs     |

# 6.7 Typical Characteristics



Figure 6-1. Typical COMHN and COMHP characteristic



# 7 Detailed Description

# 7.1 Overview

The BQ79600-Q1 is a bridge IC designed to interface between microcontroller (MCU) and TI battery monitoring ICs (BQ7961X-Q1 family). It translates between daisy chain interface and SPI/UART interface. It is fully compatible with BQ7961X-Q1 family. When working with BQ7961X-Q1 family, BQ79600-Q1 supports automatic host wakeup through INH pin when unmask fault is detected in high voltage battery pack. Details can be found in Section 7.3.5 and Section 7.3.4. For convenience of traceability, each device is marked by DIE IDs and PARTID which could be found in Section 7.5 Register Summary Table.

## 7.2 Functional Block Diagram



Figure 7-1. Functional Block Diagram

# 7.3 Feature Description

## 7.3.1 Functional Modes and Power Supply

## 7.3.1.1 Power Mode

The device has four power modes plus an Complete Off state. The functions supported under each power modes are summarized in Table 7-1 and the power state diagram is shown in Figure 7-2.

- COMPLETE OFF: The voltage at the BAT pin is less than V<sub>BAT</sub> min, and all circuits are powered off.
- SHUTDOWN: The lowest power mode. Without VIO, device can only transition to VALIDATE. (If Sniffer used)
- SLEEP: A low power mode. Transition to ACTIVE is much faster compared to SHUTDOWN.
- ACTIVE: Full power mode. Device can communicate between MCU and daisy chain.
- VALIDATE: This state is to validate if there is real fault tone from stack devices. If fault tone is validated, drive INH pin towards VBAT (INH pin is latched until cleared by user). Device goes back to SHUTDOWN if t<sub>VALID\_TIMEOUT</sub> or sleep timer expires. (t<sub>VALID\_TIMEOUT</sub> timer is reset if fault tone is detected, detecting Heartbeat tone doesn't reset timer.) This state is bypassed if Section 7.3.5 is disabled (by default). Once entered this state, a status bit [VALIDATE\_DET] is set in next ACTIVE such that host knows what happened. Without VIO, device can only transition to SHUTDOWN. NFAULT pin is low in this mode.



| Table 7-1. Functions Summary                               |                                             |                         |                                        |                                      |  |  |  |  |
|------------------------------------------------------------|---------------------------------------------|-------------------------|----------------------------------------|--------------------------------------|--|--|--|--|
| FUNCTIONAL BLOCK <sup>(1)</sup>                            | SHUTDOWN                                    | VALIDATE <sup>(3)</sup> | SLEEP                                  | ACTIVE                               |  |  |  |  |
| Data Communication RX/TX                                   |                                             |                         |                                        | If VIO_UV_R = 1                      |  |  |  |  |
| Time out                                                   |                                             | Sleep Timeout           | Sleep Timeout                          | Comm Timeout                         |  |  |  |  |
| Tone RX (HB/Fault)                                         |                                             | $\checkmark$            | Depends on [DIR_SEL                    | ] and [TONE_RX_EN]                   |  |  |  |  |
| Tone TX (WAKE/ SLP2ACT/<br>SHUTDOWN/ HWRST) <sup>(5)</sup> |                                             |                         |                                        | $\checkmark$                         |  |  |  |  |
| Tone TX (HB)                                               |                                             |                         | Depends on [DIR_SEL]<br>and [HB_TX_EN] |                                      |  |  |  |  |
| COM embedded fault                                         |                                             |                         |                                        | [FCOMM_EN] =1                        |  |  |  |  |
| Sniff detector on COM*                                     | If host enables this feature <sup>(2)</sup> |                         |                                        |                                      |  |  |  |  |
| Wake/Shutdown Ping                                         | If VIO_UV_R = 1                             | If VIO_UV_R = 1         | If VIO_UV_R = 1                        | If VIO_UV_R = 1                      |  |  |  |  |
| SLP2ACT Ping                                               |                                             |                         | $\checkmark$                           |                                      |  |  |  |  |
| NFAULT Driver                                              |                                             | $\checkmark$            | $\checkmark$                           | $\checkmark$                         |  |  |  |  |
| LFO                                                        |                                             | $\checkmark$            | $\checkmark$                           | $\checkmark$                         |  |  |  |  |
| HFO                                                        |                                             |                         |                                        | $\checkmark$                         |  |  |  |  |
| INH Driver                                                 | Holds State                                 | $\checkmark$            | INH_DIS[1:0] != 2'b11                  | INH_DIS[1:0] != 2'b11 <sup>(4)</sup> |  |  |  |  |
| CVDD/DVDD                                                  |                                             | $\checkmark$            | $\checkmark$                           | $\checkmark$                         |  |  |  |  |
| Thermal Shutdown                                           |                                             | $\checkmark$            | $\checkmark$                           | $\checkmark$                         |  |  |  |  |

(1) Once device in SLEEP/ACTIVE, losing VIO doesn't directly cause change of state, it causes loss of data communication to MCU.

(2) If host writes [SNIFDET\_EN] =1 & [SNIFDET\_DIS] = 0 in ACTIVE mode, even device shuts down, enable signal is still valid. Sniff detector is enabled or disabled by a latch powered by always on power supply.

(3) This mode is bypassed if sniff detector is not enabled, see register DEV\_CONF1.

(4) INH can only be triggered by [INH\_SET\_GO] bit in ACTIVE.

(5) Device does not recognize WAKE/ SLP2ACT/ SHUTDOWN/ HWRST tone sent by stack devices.



Figure 7-2. Power State Diagram



## 7.3.1.2 Pings

A "ping" is a specific signal pattern to change power mode of BQ79600-Q1. There are total of 3 different pings:



Figure 7-3. Communication Pings

- In SPI mode, ping can be sent without SCLK toggling or host can treat sending a ping like sending a series of logic '0' (drive nCS and SCLK properly, refer to SPI physical layer requirement, Section 7.3.2.1.2.2).
- Device does not transmit any tones to stack devices due to the receiving of pings.
- After sending in SHUTDOWN ping, host has to wait t<sub>SHTDN</sub> before sending another ping.
- If nCS = '1', all of the pings above are ignored by the device.

#### Note

.

If device is shut down through SHUTDOWN ping (COMH RX and COML RX are disabled at next wake up), host needs to send 1<sup>st</sup> WAKE ping, wait t<sub>SU(WAKE SHUT)</sub>, and then send 2<sup>nd</sup> WAKE ping.

- -

|        | Table 7-2. Device Benavior when SLP2ACT Ping is Sent          |                                                                   |                                                                                |  |  |  |  |  |
|--------|---------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|
|        | UART                                                          | SPI WITH SCLK TOGGLING                                            | SPI WITHOUT SCLK TOGGLING                                                      |  |  |  |  |  |
| ACTIVE | [COMMCLR_DET]=1, [STOP_DET] =1                                | [COMCLR_ERR]=1,<br>[COMMCLR_DET]=0                                | [FMT_ERR]=1, [COMCLR_ERR]=0,<br>[COMMCLR_DET]=0                                |  |  |  |  |  |
| SLEEP  | [COMMCLR_DET]=1, [STOP_DET] =0,<br>transitions to active mode | [COMCLR_ERR]=0,<br>[COMMCLR_DET]=0, transitions to<br>active mode | [FMT_ERR]=0, [COMCLR_ERR]=0,<br>[COMMCLR_DET]=0, transitions to active<br>mode |  |  |  |  |  |

## 7.3.1.3 SPI/UART Selection

The SPI or UART interface is selected through hardware: connect pin nUART/SPI to VIO through resistor for SPI or connect to GND for UART. Device determines UART or SPI mode every time it transitions from SHUTDOWN to ACTIVE mode. Before transitioning to ACTIVE, the mode selected is locked in. VIO has to be above  $V_{VIO\_UV\_R}$ . nUART/SPI pin is used as output indication of SPI\_RDY once in ACTIVE mode. See Section 7.3.2.1.2.2.1 for more information.



## 7.3.1.4 Digital Reset

Digital reset is when digital core of the device in reset mode. It is not a power mode. Once device comes out of digital reset, [DRST] bit is set to '1', registers that are not included in NVM are set to RESET VALUE, registers included in NVM would be NVM program value. There are several conditions in which the device will go through a digital reset:

- A WAKE ping is received.
- The CONTROL1 [SOFT\_RESET] = 1 command is sent in ACTIVE mode.
- Power supply faults. DVDD UV or CVDD UV is detected.
- A HFO or LFO watchdog fault will reset the digital.

#### 7.3.1.5 Power Mode in BMS System

It is recommended to follow the power state combinations below to save system level power.

| Table 7-5. Fower mode combination Summary |            |                 |  |  |  |  |
|-------------------------------------------|------------|-----------------|--|--|--|--|
| STACK MONITORING IC                       | BQ79600-Q1 | COMMENT         |  |  |  |  |
| ACTIVE                                    | ACTIVE     | Recommended     |  |  |  |  |
| SLEEP                                     | SLEEP      | Recommended     |  |  |  |  |
| SLEEP                                     | SHUTDOWN   | Recommended     |  |  |  |  |
| SHUTDOWN                                  | SHUTDOWN   | Recommended     |  |  |  |  |
| Other combinations                        |            | Not recommended |  |  |  |  |

### Table 7-3. Power Mode Combination Summary

#### 7.3.1.6 Power Supply

This section provides an overview of each supplies for both user cases: without using Reverse Wakeup and with using Reverse Wakeup. See the Section 7.3.6 for diagnostic control and fault detection on the power supplies block.

#### Table 7-4. Power Supply Summary

| NAME    | W/O REVERSE WAKEUP USER CASE                                                                                                                                                                                        | W/ REVERSE WAKEUP USER CASE                                                                                                                                                                                                                                     |  |  |  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| VIO     | This supply is powered by regulated 3.3V or 5V from SBC (F                                                                                                                                                          | PMIC), it powers UART/SPI interface pins.                                                                                                                                                                                                                       |  |  |  |
| BAT     | This supply is powered by regulated 5V from SBC (PMIC).                                                                                                                                                             | This supply is powered by unregulated 12V battery.                                                                                                                                                                                                              |  |  |  |
| AVAOREF | his supply is generated from VBAT. It is always on if VBAT exists. It powers REFSYS and Power mode control<br>lock.                                                                                                 |                                                                                                                                                                                                                                                                 |  |  |  |
| AVDDREF | This supply is derived from AVAOREF. AVDDREF and AVAOREF are connected by a switch, the switch is open in SHUTDOWN mode.                                                                                            |                                                                                                                                                                                                                                                                 |  |  |  |
| DVDD    | This supply is generated by the internal DVDD LDO. It is the supply for the digital circuits. It takes the input voltage from CVDD and generates a nominal 1.8V. It will not be used to power any external circuit. |                                                                                                                                                                                                                                                                 |  |  |  |
| CVDD    | This supply is powered by regulated 5V from SBC(PMIC). It is the supply for daisy chain interface.                                                                                                                  | This supply is generated by the internal CVDD LDO.<br>It is the supply for the daisy chain interface (or vertical<br>interface, VIF). It takes the input voltage from VBAT<br>and generates a nominal 5V. It will not be used to<br>power any external circuit. |  |  |  |

#### 7.3.1.7 Shutdown

Power Mode Transition Example

#### BQ79600-Q1 SLUSDS1A – NOVEMBER 2019 – REVISED AUGUST 2020













## 7.3.2 Communication

This device is used as a bridge (base) device in daisy chain configuration, as showed in figure below. It communicates with MCU through UART or SPI and communicates with stack devices through daisy chain (proprietary interface). MCU always initiates communication with a Command frame. In the system, BQ devices would never send data back to MCU before MCU requests. And MCU needs to wait all expected response frames before sending next command frame. Thus, communication scenarios can be put into 2 categories:

- MCU sends Write Command frames to BQ devices. Write Command frames don't incur Response frame.
- MCU sends one Read Command frame to BQ devices and waits till all Response frames are received.



Figure 7-6. System Communication Diagram

Rest of the section talks about how data and tone are communicated among host, bridge, and stack devices: Section 7.3.2.1 (Section 7.3.2.1.1 and Section 7.3.2.1.2 protocol), Section 7.3.2.2. It also talks about Section 7.3.2.3 and Section 7.3.2.4.

# 7.3.2.1 Data Communication Protocol

## 7.3.2.1.1 Frame Layer

The communication frame is defined in figure below. It is made up of 5 types of information: initialization character (INIT), device address characters, register address character, data character(s) and CRC characters. Each character is transmitted at UART/ SPI/ Daisy Chain physical level, whose format is defined in following Section 7.3.2.1.2 section. There are 3 types of transaction frames: **Read Command Frames**, **Write Command Frames** and **Response Frames**. They follow the structure in the figure below.

| INIT [7:0] DEV ADR [7:0] REG ADR [15:0] DATA byte(s) CRC [15:0] |
|-----------------------------------------------------------------|
|-----------------------------------------------------------------|

|                | Frames                                    | INIT             | DEV ADR | <b>REG ADR</b>   | DATA                           | CRC |
|----------------|-------------------------------------------|------------------|---------|------------------|--------------------------------|-----|
| Read           | Single Device Read                        | Always 0x80      | Y       | Y                | # of byte requested (max value | Y   |
| Command        | Stack Read                                | Always 0xA0      | Ν       | Y                | 127, meaning 128)              | Y   |
| Frame          | Broadcast Read                            | Always 0xC0      | N       | Y                |                                | Y   |
| Write          | Single Device Write                       | Y                | Y       | Y                | Actual payload (1-8 bytes)     | Y   |
| Command        | Stack Write                               | Y                | N       | Y                |                                | Y   |
| Frame          | Broadcast Write                           | Y                | N       | Y                |                                | Y   |
|                | Broadcast Write<br>Reverse <sup>(5)</sup> | Y <sup>(5)</sup> | N       | Y <sup>(5)</sup> | Y <sup>(5)</sup>               | Y   |
| Response Frame |                                           | Y                | Y       | Y                | Actual payload (1-128 bytes)   | Y   |

| Figure 7-7. | Command/Response | Frame | Structure |
|-------------|------------------|-------|-----------|
|-------------|------------------|-------|-----------|

Notes:

- When BQ79600-Q1 is used as bridge device, to read BQ devices information, host SHALL NOT use Broadcast Read command but only Single Device Read or Stack Read. The reason is BQ79600-Q1 register address does not overlap with stack devices, it would only return 0x00 to Broadcast Read command.
- For Stack Read command, the response is broken into individual response frames from each device addressed. Each device (address N) in the stack waits until the device above it (address N+1) responds before device N sends its own data back.
- After a read command frame is transmitted, the host must wait for all expected responses to return (or timeout: t<sub>WAIT\_READ\_MAX</sub>) before initiating a new command frame.
- A response frame is not mandatary. A response frame is only received after a read command frame.



- Broadcast Write Reverse command frame should only be used to config [DIR\_SEL] bit, not for any other purposes. INIT byte is 0xE0, Reg address byte is 0x309 (BQ7961X-Q1), data byte is 0x80.
- Bytes received on COMH/COML are NOT propagated up to the stack; while bytes received on the SPI/UART are propagated to COMH or COML depending on [DIR\_SEL].
- Even if there is a byte error, data is still forwarded from VIF to SPI (buffer)/UART; if there is a byte error, data doesn't forward from SPI/UART to VIF.

|   |     |                        | Command Frame                                                                      |                     | Response Frame                    |     |              | [            |                           | Command/Beenonse Frame                         |                                                   |
|---|-----|------------------------|------------------------------------------------------------------------------------|---------------------|-----------------------------------|-----|--------------|--------------|---------------------------|------------------------------------------------|---------------------------------------------------|
|   | Bit | Bit Name               | Description                                                                        | Bit Name            | Description                       |     |              | Bit          | Bit Name                  | Description                                    |                                                   |
|   | 7   | FRAME_TYPE             | 1 = Command Frame                                                                  | FRAME_TYPE          | 0 = Response                      |     |              | 7            | RSVD                      | Should always write "0"                        |                                                   |
|   | _   |                        |                                                                                    |                     | Frame                             |     | 2.6          | 6            | RSVD                      | Should always write "0"                        |                                                   |
|   | 6   | REQ_TYPE               | 000 = Single Device Read<br>001 = Single Device Write                              | RESPONSE_BYTE       | Number of the data<br>bytes       |     | AC           | AC           | 5:0                       | Device Address                                 | Set the device address range from<br>0x00 to 0x3F |
|   | 5   |                        | 010 = Stack Read                                                                   |                     | 0,000 1 bute                      |     |              |              |                           | •                                              |                                                   |
|   |     | 4 101 = Broadcast Read | 100 = Broadcast Read                                                               |                     | 0x00 = 1  byte<br>0x01 = 2  bytes |     |              | l            |                           | Command/Response Frame                         |                                                   |
|   | 4   |                        |                                                                                    | :<br>0v7E 100 butes |                                   |     | Bit          | Bit Name     | Description               |                                                |                                                   |
| Į |     | PSVD                   | 110 = Diradicast write Reverse<br>$111 = \text{RSVD}^{(1)}$<br>$\text{RSVD}^{(1)}$ |                     | 0x7F = 126 bytes                  |     | یا تو<br>ا   | 7:0          | Register<br>Address (MSB) | Target or beginning of the register<br>address |                                                   |
|   | 2   | DATA_SIZE              | Number of data bytes, excluding                                                    |                     |                                   |     | AD           | 7:0          | Register<br>Address (LSB) | Target or beginning of the register<br>address |                                                   |
|   | 1   |                        | address, register                                                                  |                     |                                   |     |              |              |                           |                                                |                                                   |
|   | 0   |                        |                                                                                    |                     |                                   |     |              | Bit          | Bit Name                  | Description                                    |                                                   |
|   |     |                        | 000 = 1 byte                                                                       |                     | 7:0                               | 7:0 | Data Byte[0] | Data Byte[0] |                           |                                                |                                                   |
|   |     |                        | 001 = 2 bytes                                                                      |                     |                                   |     | AT           |              |                           |                                                |                                                   |
|   |     |                        | 111 = 8 bytes                                                                      |                     |                                   |     |              | 7:0          | Data Byte [n]             | Data Byte[n]                                   |                                                   |

|   |     |           | Command/Response Frame                                                                             |
|---|-----|-----------|----------------------------------------------------------------------------------------------------|
|   | Bit | Bit Name  | Description                                                                                        |
| ç | 7:0 | CRC (MSB) | CRC-16-IBM polynomial (x16<br>+ x15 + x2 + 1 or<br>1100000000000101)<br>with 0xFFFF initialization |
| ö | 7:0 | CRC (LSB) | CRC-16-IBM polynomial (x16<br>+ x15 + x2 + 1 or<br>1100000000000101)<br>with 0xFFFF initialization |

Figure 7-8. Frame Byte Definition

Notes:

- INIT character: (1) No function to this selection, but this selection sets the [RC\_IERR] error flag.
- Device Address character: Bit 6 and 7 are reserved; 0x4F to 0xFF is decoded as 0x3F by device.
- Register Address characters: Register addresses are two bytes in length. They indicate the targeted register address on a single byte read/write, or the beginning of the register address on a multi-byte read/write. If an invalid register address is set on a write command, the command will be ignored. If an invalid register address is set on a read command, a 0x00 will be returned as response.
- Data characters can be:
  - Single data byte, it represents number of registers requested in Read Command Frame. The BQ79600-Q1 supports up to 128 byte reads. The valid data byte for read command frame is 0b0000000 0b1111111. The MSB of the data byte is ignored for read command frames. For example, 0b10011001 is read as 0b00011001 and returns data from 26 registers.

- Actual payload in Write Command Frame (max 8 byte) or Response Frame (max 128 byte).

- CRC characters:
  - The CRC value is checked as the first step (assume no physical layer error, no [RC\_IERR], no [RC\_SOF], no [RC\_BYTE\_ERR]) after receiving the communication frame. If the CRC is incorrect, the entire frame is discarded and not processed. Any additional frame errors are not checked.
  - The frame with CRC error is still transferred up/down the stack. Every device processing this frame will also detect a CRC error. Hence, it is possible to have multiple devices indicating CRC fault on the same communication frame. If a CRC error occurs in the response frame from address N+1, device N does NOT append its own message and an invalid CRC fault is generated. For example, if device 15 finds response frame from device 16 has invalid CRC, device 15 doesn't send its own response frame.



 The device uses a CRC (cyclic redundancy check) to protect data integrity during transmission. The device uses the CRC-16-IBM polynomial (x<sup>16</sup> + x<sup>15</sup> + x<sup>2</sup> + 1) with 0xFFFF initialization.

#### 7.3.2.1.1.1 Calculating Frame CRC Value

The CRC calculation by the transmitter is in bit-stream order across the entire transmission frame (except for the CRC). When determining bit-stream order for implementing the CRC algorithm, it is important to note that protocol bytes transmit serially, least-significant bit first. Figure 7-9 illustrates the bit-stream order concept.



Figure 7-9. Bit-Stream Order Explanation

The CRC (0x0000) is appended to the end of the bit-stream. This bit-stream is then initialized by XOR'ing with 0xFFFF to catch any leading 0 errors. This new bit-stream is then divided by the polynomial (0xC002) until only the 2-byte CRC remains. During this process, the most significant 17 bits of the bit stream are XOR'd with the polynomial. The leading zeroes of the result are removed and that result is XOR'd with the polynomial once again. The process is repeated until only the 2-byte CRC remains. For example:

Example 1: CRC Calculation Using Polynomial Division

```
Command Frame = 0x80 00 02 0F 0B (0b1000 0000 0000 0000 0010 0000 1111 0000 1011)
Command Frame in bit stream order = 0x01 00 40 F0 D0 (0b0000 0001 0000 0100 0000 1111 0000 1101
0000)
After Initialization (XOR with 0xFFFF) = 0b1111 1110 1111 1111 0100 0000 1111 0000 1101 0000
1111 1110 1111 1111 0100 0000 1111 0000 1101 0000 0000 0000 0000 #append 0x0000 for CRC
1100 0000 0000 0010 1 #XOR with polynomial
0011 1110 1111 1101 1100 0000 1111 0000 1101 0000 0000 0000 0000 0000
11 1110 1111 1101 1100 0000 1111 0000 1101 0000 0000 0000 0000 #delete leading zeros from
previous result
11 0000 0000 0000 101 #XOR with polynomial
00 1110 1111 1101 0110 0000 1111 0000 1101 0000
.....
.....
1100 0110 0000 0001 0000 0000
1100 0000 0000 0010 1 #XOR with polynomial
0000 0110 0000 0011 1000 0000
110 0000 0011 1000 0000
110 0000 0000 0001 01 #XOR with polynomial
000 \ 0000 \ 0011 \ 1001 \ 0100
0000 0011 1001 0100 #CRC result in bit stream order
1100 0000 0010 1001 #final CRC result in normal order
CRC final 0xC029
```

#### 7.3.2.1.1.2 Verifying Frame CRC

There are several methods for checking the CRC of a frame. One method is to simply calculate the CRC for the transmitted command except the last two bytes (CRC bytes) using the method described in the previous section, and then compare that result with the transmitted CRC bytes. A more simple option is to run the entire transmission through the CRC algorithm. If the CRC is correct, the result is 0000. In this case, the initial zero padding of the bit-stream with 16 zeroes is not necessary. Using the previous result and running through the algorithm produces the following results:

Example 1: CRC Verification Using Polynomial Division:

```
Command Frame = 0x80 00 02 0F 0B (0b1000 0000 0000 0000 0000 0010 0000 1111 0000 1011)
CRC to Check = 0xC029
Command Frame w/ CRC in bit stream order = 0x80 00 02 0F 0B C0 29 (0b1000 0000 0000 0000 0000 0010
```



BQ79600-Q1 SLUSDS1A – NOVEMBER 2019 – REVISED AUGUST 2020

0000 1111 0000 1011 0000 0011 1001 0100) After Initialization (XOR with 0xFFFF) = 0b0 1111 1110 1111 1111 0100 0000 1111 0000 1101 0000 0000 0011 1001 0100 1111 1110 1111 1111 0100 0000 1111 0000 1101 0000 0000 0011 1001 010 #delete leading zeros from previous result 0011 1110 1111 1101 1100 0000 1111 0000 1101 0000 0000 0011 1001 0100 11 1110 1111 1101 1100 0000 1111 0000 1101 0000 0000 0011 1001 0100 #delete leading zeros from previous result 11 0000 0000 0000 101 #XOR with polynomial 00 1110 1111 1101 0110 0000 1111 0000 1101 0000 0000 0011 1001 0100 ..... 1100 0110 0000 0010 1001 0100 1100 0000 0000 0010 1 #XOR with polynomial 0000 0110 0000 0000 0001 0100 1 1000 0000 0000 0101 00 1 1000 0000 0000 0101 #XOR with polynomial 0 0000 0000 0000 0000 00 0x0000 #verfiy that CRC checks out valid

#### Note

The result of '0b0000 0000 0000 0000' for the CRC indicates a successful check.

#### 7.3.2.1.2 Physical Layer

#### 7.3.2.1.2.1 UART

Communication between host and BQ79600-Q1 can be configured to UART mode, refer to Section 7.3.1.3. The UART interface baud rate is default to 1Mbps at power up or digital reset. The UART interface follows the standard serial protocol of 8-N-1 (see Figure 7-10), where it sends information as a START bit, followed by eight data bits, and then one STOP bit. The STOP bit indicates the end of the byte. The protocol also supports two STOP bits. When the device is configured as 2 stop bits ([TWO\_STOP\_EN] = 1, stack devices should also be set as two stop bits), the UART response frame from the device to MCU will always return with 2 stop bits.

The UART sends data on the TX pin and receives data on the RX pin. When idle, the TX and RX are high. TX is always pulled to VIO internally while in ACTIVE or SLEEP mode, whether enabled or disabled.

The UART interface is strictly a half-duplex interface. While transmitting, any attempted communication on RX is ignored. The only exception is Section 7.3.2.1.2.1.2.



Figure 7-10. UART Character Definition

Note: User can change baud rate using register bit [UART\_VIF\_BAUD] for debug purpose.

#### 7.3.2.1.2.1.1 TX HOLD OFF

UART transmitter is configurable to wait a specified number of bit periods after the last bit reception of Single Device read command frame from host before starting transmitting Response Frame using the TX\_HOLD\_OFF register, as showed in Figure 7-11. This provides time for the host to switch the bus direction at the end of its transmission.

Note

Host does not need to configure register TX\_HOLD\_OFF in BQ79600-Q1 if Stack Read command is used. Host shall not use Broadcast Read Command.





## Figure 7-11. TX HOLD OFF Timing Diagram

#### 7.3.2.1.2.1.2 UART COMM CLEAR

Note

Comm Clear concept only applies to bridge device not stack device.

Comm Clear command is used to clear the receiver and instruct it to look for a new start of frame. (Resync up with host) The next byte following the Comm Clear is considered a "start of frame" byte. The digital receiver continuously monitors the RX line for Comm Clear condition which is RX pin is held low for tUART (CLR) bit periods, showed in Figure 7-12.

When Comm Clear is detected, FAULT\_COMM1 [COMMCLR\_DET] and FAULT\_COMM1 [STOP\_DET] are set. [STOP\_DET] flag is set because the Comm Clear timing violates the typical byte timing and the STOP bit is seen as '0'. The only exception to this is when a COMM CLEAR is sent while BQ79600-Q1 is in sleep. If this is the case, there is no STOP error flag.



Figure 7-12. Comm Clear Timing

#### 7.3.2.1.2.2 SPI

Note

To facilitate the communication between daisy chain (asynchronous protocol) and SPI (synchronous protocol), BQ79600-Q1 requires the use of Section 7.3.2.1.2.2.1.

Communication between host and BQ79600-Q1 can be configured to SPI mode, refer to Section 7.3.1.3. The host is always a SPI master while BQ79600-Q1 is always a slave. At physical layer, SPI is a five pin interface including 4 common pins (nCS, SCLK, MOSI, MISO) plus SPI\_RDY. At SPI interface, each bit is captured on low to high clock transitions and propagated on high to low clock transition and byte includes 8 bits as shown in Figure 7-13. Please note, MISO is driven high in idle mode. If MCU talks to multiple slaves, please add a tri-state buffer between BQ79600 MISO and MCU.





#### Note

Although SPI interface is full duplex at physical layer, at frame layer, it is effectively half duplex because daisy chain only supports half duplex. It means, at the given time, only a command frame OR a response frame is transmitted between MCU and the device.

- When command is being sent from MCU to the device, BQ79600 TX FIFO (2 buffers) should be empty, 0xFF is sent to MCU (except in FIFO diagnostic mode)
- When response is being sent from device to MCU, MCU shall clock in 0xFF
- Host shall provide SPI clock in the range between 2MHz and 6MHz. This range is set by the predefined size
  of FIFO. Even SPI can run at 6MHz, it does not increase the throughput of total system as daisy chain speed
  still limit the throughput.
- To avoid collisions on the daisy chain interface, the MCU must wait until all expected response frames are received (or waiting timer expires) before sending another command frame to bq79600. Refer to flow chart in Figure 7-16.
- Master shall always drive MOSI to '1' when not sending command frame into device.
- Host Read mode: from host perspective, read mode is between first byte of a valid read command and last expected number of byte received.
- Device Read mode: start from first byte of a valid read command, device exists read mode when TX FIFO times out and FIFO is empty. Device read mode is subset of host read mode. (concept used for understanding of communication fault registers 0x2301, 0x2302)
- Other than Comm Clear, device rejects any data from MOSI before exiting Device Read mode.
- SPI module rejects any data from daisy chain (stack device) or from itself after TX FIFO timeout List item. until it enters Device Read mode again.



- For command frame, device uses falling edge of nCS as indication of start of frame, and rising edge as end of frame. MCU needs to toggle and keep nCS low for the entire frame (up to 14 characters), toggle nCS back high at the end of this frame. It is legitimate to freeze SCLK while nCS is low. Pulsing nCS in the middle of a command frame is not supported.
- For response frame, nCS is not required to remain low throughout, although it can just like sending command frame. Host can toggle nCS high, stop SPI reading in the middle of the frame (at byte boundary).



Figure 7-14. nCS Behavior when Sending Frames

## 7.3.2.1.2.2.1 SPI\_RDY and SPI FIFOs

SPI\_RDY is a output signal indicating to host that data is ready to communicate. SPI FIFOs Figure 7-15 are buffers in the device for temporary storage of incoming/outgoing data. They are required for the following reasons:

- Daisy chain baud rate is approximately 1Mbps by default, once host requests large amount of data, e.g. 400 bytes, device daisy chain receiver would try to send it back to host, but since device does not own the SCLK, it cannot control when the data would be read out. Thus when host is not reading, device need to store the incoming data in the TX FIFO. And even when host is reading, FIFOs are still needed to handle the baud rate difference between SPI and daisy chain.
- SPI\_RDY is required because there is limited depth of TX FIFOs. If host requests more than 256 bytes, and host does not service (read data out) device in time, data overflow would happen. SPI\_RDY indicates to host that certain amount of data is ready to be read or written, e.g. If host request 129 bytes, first time SPI\_RDY flags 128 bytes is ready, second time SPI\_RDY flags 1byte is ready. For details refer to Table 7-5





Figure 7-15. SPI FIFO Simplified Diagram

TX FIFO consists of two 128 bytes buffers (working together as Ping-Pong buffer).

- 1. When Ping buffer is filled up, Pong buffer should be empty, to store incoming data.
- 2. While Pong buffer is being filled, Ping buffer is being read. Each byte in buffer is reset to 0xFF once being read. Ping buffer shall be empty (read out) before Pong buffer is full.
- 3. After Pong buffer is filled up, Ping buffer catches up.
- 4. Device goes through this loop (step 1 to 3) till all response data are received.
- 5. Host has to read TX FIFO fast enough such that Ping (Pong) buffer is read out and ready to store data from daisy chain before Pong (Ping) buffer is full.

|                | Table 7-5. SPI_RDT Benavior Summary |                                                                  |                                              |  |  |  |
|----------------|-------------------------------------|------------------------------------------------------------------|----------------------------------------------|--|--|--|
|                | CASE<br>#                           | HI->LOW WHEN                                                     | LO->HI WHEN                                  |  |  |  |
|                |                                     | а                                                                | b                                            |  |  |  |
| Host<br>Writes | 1                                   | In 2µs when RX FIFO has >= 16 bytes.                             | After event a1, in $2\mu s$ when RX FIFO has |  |  |  |
|                | 2                                   | In 5µs after device receives 1st byte of read command frame.     | In 1us after ping (pong) buffer is full.     |  |  |  |
| Host           |                                     | TX buffer being read becomes empty (before transmitting out last | TX FIFO time out happened                    |  |  |  |

| Table 7-5. | SPI | RDY | <b>Behavior</b> | Summary |
|------------|-----|-----|-----------------|---------|
|            |     | -   |                 |         |

Notes:

Reads

3

what.

SPI RDY sets flag only, doesn't gate data flow into or out of device.

Note: once going low, SPI RDY remains low for 2µs no matter

- Once devices enters Device Read mode, device rejects any data from host other than COMM CLEAR. a1, b1 doesn't apply anymore.
- TX FIFO Timeout: after SPI module receives one byte of data from either daisy chain or BQ79600-Q1 local, a timer starts; this timer expires if there is no data received for 30µs.

## 7.3.2.1.2.2.2 Flow to Read/Write BQ79600-Q1

bit of last byte in the buffer)

User shall follow flow chart Figure 7-16 to do read from device and Figure 7-17 to do write to device activities.

Note: TX FIFO timeout could happen while SPY RDY

is high (while host is reading TX FIFO), in this case,

2µs, then come back high.

after event a3, SPI\_RDY goes how for approximately

< 8 bytes.





Figure 7-16. Flow Chart to Read from Device

#### Note

MCU shall check SPI\_RDY pin at least every t8 (max service interval). t8 = 1ms at SCLK = 6MHz / 890µs at SCLK = 4MHz /550µs at SCLK = 2MHz assuming host starts to read TX FIFO right after detecting SPI\_RDY = '1 and SPI bus has 30% idle time in the process of reading 128 bytes.

- For response frame, nCS has to be toggled high after reading the last byte of data in the current buffer.
- t<sub>WAIT\_READ\_MAX</sub>
  - stack read/single device read from stack devices, with n stack devices, request m bytes in total (payload + overheads, from all stack devices), wait time: (n-1)\*3µs\*2 + m\*10µs + 100µs.
  - single device read from BQ79600-Q1, request m bytes , wait time: 100µs + m\*10µs.



Figure 7-17. Flow Chart to Send Write Command Frame to Device

#### Notes:

- Since write command frame doesn't incur response frames, host shall discard data from MISO pin.
- If host sends partial data, the device would keep waiting the rest of command data till communication time out happens. Refer to Section 7.3.2.4 for details.

7.3.2.1.2.2.3 SPI COMM CLEAR

#### Note

SPI Comm Clear, applied only to bridge device, is used to clear the FIFOs and reset SPI module.

It stops BQ79600-Q1 sending response; it cannot stop stack devices sending response data back to BQ79600-Q1. If host still couldn't communicate to device, host can ultimately use SHUTDOWN ping followed by WAKE ping to reboot device. Device only responses to Comm Clear in ACTIVE. Use the SPI Comm Clear command when:

- SPI\_RDY being low exceeds expected time, either t<sub>SPI\_RD\_WAIT\_MAX</sub> in READ mode in Figure 7-16 or when 220µs while sending write command frame into device. Don't send Comm Clear before this wait time has elapsed.
- Data read back by host has CRC error.
- Host cannot communicate to the device.



Figure 7-18. SPI Comm Clear



SPI Comm Clear is strictly defined as nCS toggling low, 8 bits of '0', nCS toggling high like shown in Figure 7-18. nCS must remain low while sending the Comm Clear. If additional data is detected on MOSI pin before nCS going high, [COMCLR\_ERR] bit is set, device ignores malformed Comm Clear. A correctly formed Comm Clear will only trigger [COMMCLR\_DET]. If Comm Clear is used, it can trigger DEBUG\_SPI\_FRAME [TR\_SOF] (while transmitting local data), [RC\_SOF](receiving partial data) and [TS\_WAIT] (while transmitting daisy chain data).

#### 7.3.2.1.2.3 Daisy Chain

Daisy chain is the interface (COMH/COML) communicating to stack devices. It is bi-directional and half duplex, and, therefore, has a transmitter (TX) and receiver (RX) on both COMH and COML interfaces, Figure 7-1. Signal going in and out of daisy chain port is taken care by the device. To use the device, host does not need to know daisy chain physical layer protocol (bit definition, byte definition and byte transferring). Host just needs to control SPI or UART port properly. Still, for user's information, daisy chain physical layer protocol is described below.

Daisy chain bit is transmitted between COM\*P and COM\*N in fully differential fashion, see Figure 7-19.

Daisy chain byte uses an asynchronous 13-bit byte-transfer protocol. The definition of each bit in the byte is defined in Table 7-6. Byte to byte transmission is captured in Figure 7-20.



Figure 7-19. Daisy Chain Bit Definition



Figure 7-20. Daisy Chain Byte/ Byte Transfer Definition



| BIT NAME                | DESCRIPTION                                                                                                                                                                                        |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preamble (half-bit)     | Indicates a start of byte transaction, signaling the receiver to start sampling. This half-bit and the following 2 SYNC bits are used for extra timing information.                                |
| SYNC[1:0]               | Always 0b00. The SYNC bits are used for the digital to assess the timing and noise level on the byte, improving the detection of a '1' and '0' in a noisy environment.                             |
| Start-Of-Frame (1-bit)  | The Start-Of-Frame (SOF) bit defines the byte as the INIT byte (initialization byte) in the frame, refer to Figure 7-8. Stack device needs this information in order to process the communication. |
| Data[7:0]               | The actual 8-bit payload.                                                                                                                                                                          |
| Byte Error BERR (1-bit) | For BQ79600-Q1, BERR is always '0' in command frames sent to stack device. While in received response frames, if it is '1', it indicates last device DEBUG_COM*_PHY[PERR] = 1.                     |
| Postamble (half-bit)    | Indicates the end of byte transaction.                                                                                                                                                             |

#### Table 7-6. Daisy Chain Byte Definition

### 7.3.2.2 Tone Communication Protocol

Other than data, certain information is transmitted using tone: signals to change power state of stack device (SLP2ACT tone, WAKE tone, SHUTDOWN tone, HWRST tone), signals related to faults (FAULT tone and HEARTBEAT tone). The definition of each tone is defined in Figure 7-22 and Figure 7-21.

Device can transmit and receive tones in summary below:

| DIRECTION | NAME                                                               |
|-----------|--------------------------------------------------------------------|
| Receive   | FAULT tone and HEARTBEAT tone                                      |
| Transmit  | SLP2ACT tone, WAKE tone, SHUTDOWN tone, HWRST tone, HEARTBEAT tone |

Note:

- Device does not transmit Fault Tone as it uses Section 7.3.3.2.1 to signal fault if enabled.
- SLP2ACT/WAKE/SHUTDOWN/HWRST tone transmitting is on demand when corresponding bit in register CONTROL1 and CONTROL2 is set.
- When bridge device in SHUTDOWN, wakeup bridge device doesn't change power mode of stack devices.
- Receiving threshold value is defined as n<sub>HBDET</sub>, n<sub>FTONEDET</sub> in section 6.6.
- Transmitting number is predefined by device in Table 7-8.

#### Table 7-8. Transmitting Tones Summary Table

|                                           | SLP2ACT | WAKE | SHUTDOWN | HWRST | HEARTBEAT (SLEEP only) |
|-------------------------------------------|---------|------|----------|-------|------------------------|
| N of Couplets Transmitted in Single Burst | 30      | 90   | 270      | 810   | 30                     |
| Burst Period                              | NA      | NA   | NA       | NA    | 400ms                  |











#### 7.3.2.3 Device Auto Addressing / Ring Communication

Note

The host starts communication at least 100µs after changing the *[DIR\_SEL]* setting to ensure the device finishes the COMH/COML reconfiguration.

#### 7.3.2.3.1 Auto-Addressing

To properly communicate to every device in daisy chain, host has to assign a unique device address to every device. This process is called Auto-addressing. This step is required every time devices come out of SHUTDOWN or digital reset. Table 7-9 describes a procedure to bring up a system of 1 bridge device and 3 stack devices from SHUTDOWN to a state ready to do read/write communication.

All device addresses must be sequential

#### Table 7-9. Auto-Addressing with Figure 7-22(a), assume all devices are in SHUTDOWN

| STEP | WORK WITH BQ7961X-Q1                                                                                                |
|------|---------------------------------------------------------------------------------------------------------------------|
| 1    | send WAKE ping on RX (wakeup BQ79600-Q1)                                                                            |
| 2    | single device write to BQ79600-Q1 CONTROL1 [SEND_WAKE] = 1 (wake up stack devices)                                  |
| 3    | dummy stack write data 0x00 to register 0x343 to 0x34A (sync up internal DLL). These are 8 separate write commands. |
| 4    | brdcast write 0x01 to address 0x309 (enable auto addressing)                                                        |



## Table 7-9. Auto-Addressing with Figure 7-22(a), assume all devices are in SHUTDOWN (continued)

| STEP | WORK WITH BQ7961X-Q1                                                                                                            |
|------|---------------------------------------------------------------------------------------------------------------------------------|
| 5    | brdcast write consecutively to 0x306 = 0,1,2,3 (address 1-3 assigned to BQ7961X-Q1, 0 assigned to BQ79600-Q1)                   |
| 6    | brdcast write 0x02 to address 0x308 (set BQ7961X-Q1 as stack device )                                                           |
| 7    | single device write to device 3: data 0x03 to address 0x308 (set 3rd BQ7961X-Q1 as top of stack, BQ79600-Q1 is default to base) |
| 8    | dummy stack read registers 0x343 to 0x34A (sync up internal DLL). These are 8 separate read commands.                           |
| 9    | stack read address 0x306 (read back to verify address are correct for stack devices)                                            |
| 10   | single device read to BQ79600-Q1, verify 0x2001 = 0x14                                                                          |
| 11   | finish initialization                                                                                                           |

#### 7.3.2.3.2 Ring Communication (optional)

A ring communication (optional) allows the system to establish communication from either direction. This allows the system to continue communicating to all stack devices even if one piece of daisy chain cable is broken.

Table 7-10 describes a procedure auto address Figure 7-23(b): to bring up a system of 1 bridge device and 3 stack devices from SHUTDOWN to a state ready to do read/write communication in **reverse direction**.

To change communication direction from Figure 7-23(a) to Figure 7-23(b), follow the steps 2, 4-14. (Assuming all devices in (a) are already in ACTIVE and auto addressed as described in Table 7-9)



#### Figure 7-23. Example to Change Communication Direction in Daisy Chain

| Table 7-10. Auto-Addressing Figure 7-22(b), assume all devices are in SHUTDOWN |
|--------------------------------------------------------------------------------|
| WORK WITH BQ7961X-Q1                                                           |

| 1 | send WAKE ping on RX (wakeup BQ79600-Q1)                                                                              |
|---|-----------------------------------------------------------------------------------------------------------------------|
| 2 | single device write to BQ79600-Q1 control 1 [DIR_SEL] = 1 (change BQ79600-Q1 direction)                               |
| 3 | single device write to BQ79600-Q1 CONTROL1 [SEND_WAKE] = 1 (wake up stack devices)                                    |
| 4 | dummy stack write data 0x00 to registers 0x343 to 0x34A (sync up internal DLL). These are 8 separate write commands.  |
| 5 | brdcast write reverse 0x80 to address 0x309 (change stack devices direction DIR_SEL =1)                               |
| 6 | brdcast Write 0x02 to address 0x308 <sup>(1)</sup>                                                                    |
| 7 | brdcast Write 0x81 to address 0x309 (enable BQ7961X-Q1 auto addressing)                                               |
| 8 | brdcast Write consecutively to address 0x307 = 0,1,2,3 (address 1-3 assigned to BQ7961X-Q1, 0 assigned to BQ79600-Q1) |
| 9 | brdcast write 0x02 to address 0x308 (set BQ7961X-Q1 as stack device )                                                 |
|   |                                                                                                                       |

28 Submit Document Feedback

STEP

Copyright © 2020 Texas Instruments Incorporated



### Table 7-10. Auto-Addressing Figure 7-22(b), assume all devices are in SHUTDOWN (continued)

| STEP | WORK WITH BQ7961X-Q1                                                                                                            |
|------|---------------------------------------------------------------------------------------------------------------------------------|
| 10   | single device write to device 3: data 0x03 to address 0x308 (set 3rd BQ7961X-Q1 as top of stack, BQ79600-Q1 is default to base) |
| 11   | dummy stack read registers 0x343 to 0x34A (sync up internal DLL). These are 8 separate read commands.                           |
| 12   | stack read address 0x307 (read back to verify address are correct for stack device)                                             |
| 13   | single device read to BQ79600-Q1, verify 0x2001 = 0x14                                                                          |
| 14   | finish initialization                                                                                                           |

(1) Clear the previous TOP\_STACK flag after communication direction is changed because top of stack device cannot be reached if one cable is broken

#### 7.3.2.4 Communication Timeout

In ACTIVE, there are two programmable communication timeout timers, **comm timeout short** (once expires, flag fault) and **comm timeout long** (once expired, transition to SLEEP or SHUTDOWN). They monitor the absence of a valid frame from either UART/SPI or daisy chain communications. A valid frame is defined as any frame (response or command) that does NOT contain any errors that prevent the frame from being processed.

In SHUTDOWN, the timers are disabled and reset. In SLEEP, the last timer values are held frozen. The timer is reset every time a valid response or command frame is received.

How to set the timer, timer expiration action are described in COMM\_TIMEOUT. In order to avoid entering SHUTDOWN mode before a communications timeout fault, ensure the COMM\_TIMEOUT [CTS\_TIME] is shorter than the COMM\_TIMEOUT [CTL\_TIME].

#### 7.3.2.5 Communication Debug Mode

The device provides a communication debug mode to ease the initial development phase. Enter/exit debug is controlled by setting of register DEBUG\_CTRL\_UNLOCK. Once device is in debug mode, user is able to control the UART/daisy chain baud rate and on/off of COMH/COML RX/TX. Please refer to register DEBUG\_COMM\_CTRL. User can always read DEBUG\_COMM\_STAT register for comm status disregard the setting/mode of device.

In addition to that, device provides communication low level faults (physical and frame layer)to facilitate debug. Refer to registers from address 0x2301 - 0x2307.



## 7.3.3 Fault Handling

## 7.3.3.1 Fault Status Hierarchy/Reset/Mask

#### 7.3.3.1.1 Fault Status Hierarchy

BQ79600-Q1 reports faults in hierarchy, as shown in Figure 7-24:

- Level 1 is FAULT\_SUMMARY register in which each bit represents an OR function of all the bits in its own hierarchy captured in level 2.
- Level 2 bit is the OR function of level 3 bits in its own hierarchy.
- Level 3 contains debug register bits meant to inform host frame and physical layer fault. Level 3 fault is useful in firmware development.
- Any bit triggered in lower level would trigger higher level bit in its hierarchy, e.g. if [TXFIFO\_OV] is set, [SPI\_PHY], [FAULT\_COMM] would also be set.

Note

Host system can periodically poll the FAULT\_SUMMARY to check the fault status and only read the lower level fault registers if needed.

#### 7.3.3.1.2 Fault Reset and Mask

Once fault is detected, the fault status bit is latched until cleared using the reset bit.

When a specific fault reset bit is set, the same color coded bits in level 1 to level 3 are cleared if the fault condition is gone. If the fault condition persists and the reset bit is written, the fault status bit is not reset. For example, if [TXFIFO\_OV], [DVDD\_OV] bits are set, [SPI\_PHY], [FAULT\_COMM] and [FAULT\_PWR] are set, if fault conditions are eliminated and write '1' to [RST\_UART\_SPI] and [RST\_PWR], 5 faults bits would be '0'.

When a specific fault mask bit is set, the same color coded bits would be masked, meaning the fault bits will still be set, but the faults will not be reflected in level 1, FAULT\_SUMMARY register. For example, if [MSK\_UART\_SPI] = 1, any bits being set marked green in level 2 and 3 won't set [FAULT\_COMM] bit.

When fault is masked, it will also prevent the device from asserting the NFAULT pin when the masked faults occur. See Section 7.3.3.2 for details.

MASK/RST



Figure 7-24. Fault Status Hierarchy, Mask and Reset



## 7.3.3.2 Fault Interface

Host can acquire the fault status with the following two methods:

- Host ignores NFAULT pin, constantly polls the FAULT\_SUMMARY register of each device. If FAULT\_SUMMARY is non-zero, read the low level fault status registers to obtain more information.
- Host monitors NFAULT pin status. Enable fault status to pass down the daisy chain to bridge device. Enable bridge device's NFAULT pin to be asserted when the FAULT\_SUMMARY is non-zero. When NFAULT is triggered, host polls fault information to diagnose further.

### 7.3.3.2.1 NFAULT

Device integrates an NMOS open-drain output (NFAULT) to signal the MCU that a fault has occurred in the system (either fault from BQ79600-Q1 or from monitoring IC). The NFAULT driver is enabled when [NFAULT\_EN] = 1. When BQ79600-Q1 detects an unmasked fault, NFAULT asserts low. When NFAULT is disabled, the device will set the corresponding flag in *FAULT\_SUMMARY* register but will not assert NFAULT.

If the fault information of stack devices are not transmitted to bridge device through Section 7.3.3.2.2, NFAULT output only indicates faults in BQ79600-Q1.

#### 7.3.3.2.2 Daisy Chain (COMH and COML)

When using BQ79600-Q1 NFAULT pin to signal the host under a fault detection, the stack devices have to transfer their fault status information to the base device. The information is transmitted through COMH/L interface through the same communication cables:

- In ACTIVE, BQ79600-Q1 detects embedded fault info in response frame from stack device.
- In SLEEP, stack device sends Heartbeat and Fault tone to BQ79600-Q1.
- In SHUTDOWN, use Sniff Detector of BQ79600-Q1 monitors stack device Fault tone.

#### 7.3.3.2.2.1 Fault Transmitting when BQ79600-Q1 in ACTIVE

In ACTIVE mode, stack devices can embed their fault status in their response frames (refer to Figure 7-7) that are sent to BQ79600-Q1. The BQ79600-Q1 can detect their embedded fault info and sets [FTONE\_DET] bit once criteria in Figure 7-25 is met. Please refer to BQ7961X-Q1 on how to use embedded fault feature.

To pass on the fault status of the stack devices, the host sends a stack read which will result with response frame pass through every device in the daisy chain, giving each device an opportunity to embed their fault status to response frame.



Figure 7-25. Embed Fault Detection in Response Frame

#### 7.3.3.2.2.2 Fault Transmitting when BQ79600-Q1 in SLEEP

Because data communication is not available in SLEEP mode, the device provides following options to transmitting fault information:

• Transmit the Heartbeat tone (enabled by [HB\_TX\_EN], used to check integrity of cable between bridge and first stack device). Device does not transmitted fault tone as it has NFAULT.

• Detect Heartbeat and Fault tone, enabled, by [TONE\_RX\_EN].

These tones are transmitted in the same direction as a communication command frame, which is based on the CONTROL1[DIR\_SEL] setting. For the tone signal to return back to BQ79600-Q1 (so NFAULT can be triggered if needed), a Ring architecture must be used to support transmitting fault status in SLEEP mode.



Figure 7-26. Heartbeat and Fault Tone Examples

Both the Heartbeat and Fault Tone are a type of tone similar to the communication. One main difference is a communication tone only transmits with a single burst of couplets, while Heartbeat and Fault Tones are sent with a burst of couplets periodically. See Figure 7-21 for details.

#### 7.3.3.2.2.3 Fault Transmitting (Automatic Host Wakeup/Reverse Wakeup) when BQ79600-Q1 in SHUTDOWN

| Note                                                                                          |  |
|-----------------------------------------------------------------------------------------------|--|
| This feature (Auto Host Wakeup/Reverse Wakeup) is only available if Section 7.3.5 is enabled. |  |

The purpose of this user case is to keep BQ79600-Q1 in lowest power mode while still being able to detect fault information from stack devices. In this case, fault information transmittion is similar to that of SLEEP: top of stack device sends HB or Fault tone to BQ79600-Q1. The difference lies in the detection of those tones in BQ79600-Q1. In SHUTDOWN, TONE RX is off, only low power Section 7.3.5 is available. Once sniffer detects FAULT tone, it puts device into VALIDATE mode in which full power TONE RX is available, device would validate if true Fault tone exists or not. If yes, it triggers INH. See Figure 7-27 for different case.



Figure 7-27. Reverse Wakeup User Case



#### 7.3.4 INH/ Reverse Wakeup

#### Note

INH pin is used if Reverse Wakeup feature is used. If this feature is not used, connect this pin to BAT pin, refer to schematic in Figure 8-1.

Reverse wakeup feature is a mechanism where BQ79600-Q1 can wakeup the host, through INH pin, on faulty status from either BQ79600-Q1 or stack devices like BQ7961X-Q1. MCU and its supply (PMIC/SBC) are in SHUTDOWN for power saving on low voltage battery side.

The INH pin is a high voltage output pin that provides voltage from the BAT minus  $V_{DROP\_INH}$  to enable an external high voltage regulators (SBC, PMIC). These regulators are usually used to support the microprocessor and VIO pin. When INH PMOS pullup is not activated, INH pin goes to a high Z state, it relies on external circuit to define the pin voltage (in application circuit, 100kohm resistor to GND is used.)

INH PMOS pullup can be triggered:

- In SLEEP mode or VALIDATE mode if following faults are detected regardless of setting of register FAULT\_MSK: [FTONE\_DET], [HB\_FAIL], [HB\_FAST], [AVAO\_SW\_FAIL], [FACT\_CRC], [CONF\_MON\_ERR].
- In ACTIVE, INH can only be triggered by setting [INH\_SET\_GO] =1.

Once INH triggered, it remains latched in all modes as long as VBAT is not removed.

INH function described above can be disabled by configuring INH\_DIS[1:0] = 2'b11.

Every time INH PMOS is activated, fault bit [INH] is set. To clear the fault, set INH\_DIS[1:0] = 2'b11 (disarm INH driver), then write [RST\_SYS] = 1. After this, to use INH feature, set INH\_DIS[1:0] = 2'b00.

As part of safety diagnostic (SM202 in Safety Manual), host can trigger INH in ACTIVE and check if pin voltage is set properly: If INH pin voltage is higher than  $V_{INH DET}$ , [INH\_STAT] = 1.

#### Note

INH pin should be considered a "high voltage logic" terminal, thus should be used to drive the EN terminal of the system's power management device. It should be not used as a switch for power management supply itself. This terminal is not reverse battery protected and thus should not be connected outside of the system module.



#### 7.3.5 Sniff Detector

#### Note

Sniff detector is only used if reverse wakeup feature is used.

Sniff detector, powered by AVAOREF, is used to detect fault tone from stack device on COMH\* or COML\*. This detector would trigger if it detects/counts no less than nVALIDATE of continuous couplets (either "-" or "+") with amplitude larger than  $V_{VAL\_THR}$ . If any couplet timing interval is larger than  $t_{SNIFFIDLE}$ , detector/counter is reset.

This sniff detector rejects HB tone since nVALIDATE is more than 30, both HB/Fault tone are "-" tone; detector doesn't expect "+" tone.

#### Note

The usage assumption of this detector is when system is in idle mode, BQ79600-Q1 in SHUTDOWN.

Sniff detector is only effective in SHUTDOWN. Once detector is triggered, device transitions from SHUTDOWN to VALIDATE. The sniff detector is by default disabled when first transition from COMPLETE OFF to SHUTDOWN. To enable the feature, host has to keep [SNIFDET\_EN] = '1' & [SNIFDET\_DIS] = '0' before transitioning to SHUTDOWN. After enabling the detector, if device doesn't transition to COMPLETE OFF, the only way to disable the detector is to keep [SNIFDET\_DIS] = '1'. (Disable bit has higher priority so don't care about the setting of [SNIFDET\_EN]) before transitioning to SHUTDOWN.)



## 7.3.6 Device Diagnostic

The product is developed as a safety element out of context (SEooC), with a target safety goal of ASIL-D for communication. The following sub-sections describe the diagnostic control and fault status that can be used as part of the safety mechanisms.

The Safety Manual and FMEDA for BQ79600-Q1 are available separately from Texas Instruments. Contact TI Sales Associate or Applications Engineer for further information.

#### 7.3.6.1 Power Supplies Check

#### 7.3.6.1.1 Power Supply Diagnostic Check

The internal power supply circuits have overvoltage, undervoltage, and/or current limit checks. The table below summarizes the diagnostics that apply for each power supply and the corresponding action when failure is detected.

| SUPPLY  | OV CHECK                                                 | UV CHECK                                                     | CURRENT LIMIT                                         |  |  |  |  |  |  |  |  |
|---------|----------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|--|
| DVDD    | If fails, set [DVDD_OV]                                  | If fails, digital reset                                      | Limit current to EC table current limit specification |  |  |  |  |  |  |  |  |
| CVDD    | If fails, set [CVDD_OV]                                  | lf fails, digital reset, set<br>[CVDD_UV_DRST]               | Limit current to EC table current limit specification |  |  |  |  |  |  |  |  |
| AVAOREF | If fails, set [AVDDREF_OV]<br>(AVAOREF supplies AVDDREF) | If fails, device shuts down                                  |                                                       |  |  |  |  |  |  |  |  |
| AVDDREF | If fails, set [AVDDREF_OV]                               | If fails, set [AVAO_SW_FAIL] or digital reset                |                                                       |  |  |  |  |  |  |  |  |
| VIO     |                                                          | If fails, device losses data communication and Ping function |                                                       |  |  |  |  |  |  |  |  |

# Table 7-11. Power Supply Diagnostic Summary

## 7.3.6.1.2 Power Supply BIST

The device implemented a power supply BIST (Built-In Self-Test) function to test CVDD, DVDD, AVDDREF OV detection comparator integrity. It is a command base function initiated by host. Steps below explains how it works, and further details can be found in Safety Manual (SM017).

- 1. Host shall read the register FAULT\_PWR to verify [CVDD\_OV], [DVDD\_OV], [AVDDREF\_OV] are low.
- 2. Host shall write [PWR\_DIAG\_GO] = 1.
- 3. After 1.7ms, host shall read if [PWR\_DIAG\_RDY] = 1, else shall, keep waiting, reread.
- 4. If yes, host shall read FAULT\_PWR register, [CVDD\_OV], [DVDD\_OV], [AVDDREF\_OV] to verify the bits are asserted.
- 5. Host shall reset faults above.

## 7.3.6.2 Thermal Shutdown

Thermal shutdown (TSHUT) event occurs when the Thermal Shutdown sensor value exceeds the thermal shutdown temperature threshold. The sensor operates without interaction and is separated from the ADC measured die sensor. The thermal shutdown function has a register-status indicator flag (*FAULT\_SYS[TSHUT]*) that is saved during the shutdown event and can be read after the device is waken back up. When a TSHUT fault occurs, the device immediately enters the SHUTDOWN mode. Any pending transactions on UART or daisy chain are discarded. There is no fault signaling when a thermal shutdown event occurs, as the device immediately shuts down.

To awaken the device, host shall ensure the ambient temperature is below  $T_{SD\_FALL}$  and sends a WAKE ping to the base device. Host shall not attempt to wake the device if the ambient temperature is still above  $T_{SD\_FALL}$ .

Upon waking up, the *FAULT\_SYS[TSHUT]* bit is set. The *FAULT\_SYS[SHUTDOWN\_REC]* = 1 indicating the prior shutdown was caused by abnormal event. See Section 7.5.17 for more details. If the system faults are unmasked, *FAULT\_MSK1[MSK\_SYS]* = 0, the thermal shutdown will be reflected as FAULT and will be indicated in the *FAULT\_SUMMARY* register and the assertion of the NFAULT pin.



## 7.3.6.3 Oscillators Watchdog

The oscillators are monitored by watchdog circuits. There are two oscillators in the device, the HFO and the LFO. If these oscillators are not functioning, the device does not operate. If the HFO or LFO does not transition within the expected time, the watchdog circuits trigger Digital Reset.

When such unexpected reset occurs, it is recommended for the host to send a SHUTDOWN ping/tone to the problem device and follow up a WAKE ping to reset the daisy chain. If the oscillators are truly damaged, the device will not restart and must be replaced.

In addition to the watchdog, the LFO frequency is monitored to ensure it stays within acceptable limits. If the LFO frequency falls outside of the expected range, the FAULT\_SYS\_FAULT[LFO] bit is set.

#### 7.3.6.4 Register Bit Flip Monitor

This bit flip checker monitors 2 configuration registers: DEV\_CONF1, FAULT\_MSK. It is always running when device is out of SHUTDOWN. Whenever user changes those 2 register settings or any of the register bit flips, fault bit [CONF\_MON\_ERR] is set.

Once user changes the setting, user shall write [CONF\_MON\_GO]=1 (resample 2 register values), write [RST\_REG] =1 to clear the [CONF\_MON\_ERR] fault, after this point, if any bit flips among those 2 registers, [CONF\_MON\_ERR] is set. After device resets (receive WAKE ping or [SOFT\_RESET] = 1), [CONF\_MON\_ERR] = 0.

This device does not have customer register CRC check and the register bit flip monitor provides the protection for the above mentioned customer registers.

#### 7.3.6.5 SPI FIFO Diagnostic

The FIFO diagnostic mode provides a method for host to exercise the RX/TX FIFOs. Please refer to safety manual for detailed FIFO diagnostic safety mechanism implementation (SM132).

## 7.4 Device Functional Modes

See Section 7.3.1



# 7.5 Register Maps

|                  | Addr          | R/W Type | Reset Value | Data         |              |               |               |                  |               |               |               |
|------------------|---------------|----------|-------------|--------------|--------------|---------------|---------------|------------------|---------------|---------------|---------------|
|                  | Hex           |          |             | Bit7         | Bit6         | Bit5          | Bit4          | Bit3             | Bit2          | Bit1          | Bit0          |
| DIR0_ADDR        | 306           | R/W      | "0000 0000" | RSVD         | RSVD         | ADDRESS[5]    | ADDRESS[4]    | ADDRESS[3]       | ADDRESS[2]    | ADDRESS[1]    | ADDRESS[0]    |
| DIR1_ADDR        | 307           | R/W      | "0000 0000" | RSVD         | RSVD         | ADDRESS[5]    | ADDRESS[4]    | ADDRESS[3]       | ADDRESS[2]    | ADDRESS[1]    | ADDRESS[0]    |
| CONTROL1         | 309           | R/W-AC   | "0000 0000" | DIR_SEL      | SEND_SHUTDOW | N SEND_WAKE   | SEND_SLPTOACT | GOTO_SHUTDOWN    | GOTO_SLEEP    | SOFT_RESET    | ADDR_WR       |
| CONTROL2         | 30A           | R/W-AC   | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | RSVD             | RSVD          | SEND_HW_RESET | RSVD          |
| DIAG_CTRL        | 2000          | R/W-AC   | "0000 0000" | RSVD         | RSVD         | CONF_MON_GO   | PWR_DIAG_GO   | SPI_FIFO_DIAG_GO | FLIP_FACT_CRC | FLIP_TR_CRC   | INH_SET_GO    |
| DEV_CONF1        | 2001          | R/W      | "0001 0100" | SNIFDET_EN   | SNIFDET_DIS  | TONE_RX_EN    | FCOMM_EN      | TWO_STOP_EN      | NFAULT_EN     | RESERVED      | HB_TX_EN      |
| DEV_CONF2        | 2002          | R/W      | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | RSVD             | RSVD          | INH_DIS[1]    | INH_DIS[0]    |
| TX_HOLD_OFF      | 2003          | R/W      | "0000 0000" | DLY[7]       | DLY[6]       | DLY[5]        | DLY[4]        | DLY[3]           | DLY[2]        | DLY[1]        | DLY[0]        |
| SLP_TIMEOUT      | 2004          | R/W      | "0000 0011" | RSVD         | RSVD         | RSVD          | RSVD          | RSVD             | SLP_TIME[2]   | SLP_TIME[1]   | SLP_TIME[0]   |
| COMM_TIMEOUT     | 2005          | R/W      | "0011 0100" | RSVD         | CTS_TIME[2]  | CTS_TIME[1]   | CTS_TIME[0]   | CTL_ACT          | CTL_TIME[2]   | CTL_TIME[1]   | CTL_TIME[0]   |
| SPI_FIFO_UNLOCK  | 2010          | R/W      | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | CODE[3]          | CODE[2]       | CODE[1]       | CODE[0]       |
| FAULT_MSK        | 2020          | R/W      | "0000 0000" | MSK_COML_H   | MSK_UART_SPI | MSK_FCOMM_DET | MSK_FTONE_DET | MSK_HB           | MSK_REG       | MSK_SYS       | MSK_PWR       |
| FAULT_RST        | 2030          | R/W-AC   | "0000 0000" | RST_COML_H   | RST_UART_SPI | RST_FCOMM_DET | RST_FTONE_DET | RST_HB           | RST_REG       | RST_SYS       | RST_PWR       |
| FAULT_SUMMARY    | 2100          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | FAULT_COMM       | FAULT_REG     | FAULT_SYS     | FAULT_PWR     |
| FAULT_REG        | 2101          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | RSVD             | CONF_MON_ERR  | FACTLDERR     | FACT_CRC      |
| FAULT_SYS        | 2102          | R        | "0000 0000" | VALIDATE_DET | LFO          | SHUTDOWN_REC  | DRST          | CTL              | CTS           | TSHUT         | INH           |
| FAULT_PWR        | 2103          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | CVDD_UV_DRST  | CVDD_OV          | DVDD_OV       | AVDDREF_OV    | AVAO_SW_FAIL  |
| FAULT_COMM1      | 2104          | R        | "0000 0000" | RSVD         | FCOMM_DET    | FTONE_DET     | HB_FAIL       | HB_FAST          | UART_FRAME    | COMMCLR_DET   | STOP_DET      |
| FAULT_COMM2      | 2105          | R        | "0000 0000" | RSVD         | RSVD         | SPI_FRAME     | SPI_PHY       | COML_FRAME       | COML_PHY      | COMH_FRAME    | COMH_PHY      |
| DEV_DIAG_STAT    | 2110          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | RSVD          | RSVD             | RSVD          | PWR_DIAG_RDY  | INH_STAT      |
| PARTID           | 2120          | R        | "0000 0000" | REV[7]       | REV[6]       | REV[5]        | REV[4]        | REV[3]           | REV[2]        | REV[1]        | REV[0]        |
| DIE_ID1          | 2121          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID2          | 2122          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID3          | 2123          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID4          | 2124          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID5          | 2125          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID6          | 2126          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID7          | 2127          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID8          | 2128          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DIE_ID9          | 2129          | R        | "0000 0000" | ID[7]        | ID[6]        | ID[5]         | ID[4]         | ID[3]            | ID[2]         | ID[1]         | ID[0]         |
| DEBUG_CTRL_UNLOC | <b>K</b> 2200 | R/W      | "0000 0000" | CODE[7]      | CODE[6]      | CODE[5]       | CODE[4]       | CODE[3]          | CODE[2]       | CODE[1]       | CODE[0]       |
| DEBUG_COMM_CTRL  | 2201          | R/W      | "0111 1000" | RSVD         | COML_TX_EN   | COML_RX_EN    | COMH_TX_EN    | COMH_RX_EN       | UART_VIF_BAUD | USER_UART_EN  | USER_DAISY_EN |
| DEBUG_COMM_STAT  | 2300          | R        | "0001 0011  | RSVD         | RSVD         | RSVD          | HW_DAISY_DRV  | COML_TX_ON       | COML_RX_ON    | COMH_TX_ON    | COMH_RX_ON    |
| DEBUG_SPI_PHY    | 2301          | R        | "0000 0000" | RSVD         | FMT_ERR      | COMCLR_ERR    | TXDATA_UNEXP  | RXDATA_UNEXP     | TXFIFO_OF     | TXFIFO_UF     | RXFIFO_OF     |
| DEBUG_SPI_FRAME  | 2302          | R        | "0000 0000" | RSVD         | RSVD         | TR_SOF        | TR_WAIT       | RC_IERR          | RC_SOF        | RC_BYTE_ERR   | RC_CRC        |
| DEBUG_UART_FRAME | 2303          | R        | "0000 0000" | RSVD         | RSVD         | TR_SOF        | TR_WAIT       | RC_IERR          | RC_SOF        | RC_BYTE_ERR   | RC_CRC        |
| DEBUG_COMH_PHY   | 2304          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | PERR          | BERR_TAG         | SYNC2         | SYNC1         | BIT           |
| DEBUG_COMH_FRAM  | E 2305        | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | RR_IERR       | RR_SOF           | RR_BYTE_ERR   | RR_UNEXP      | RR_CRC        |
| DEBUG_COML_PHY   | 2306          | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | PERR          | BERR_TAG         | SYNC2         | SYNC1         | BIT           |
| DEBUG_COML_FRAM  | E 2307        | R        | "0000 0000" | RSVD         | RSVD         | RSVD          | RR_IERR       | RR_SOF           | RR_BYTE_ERR   | RR_UNEXP      | RR_CRC        |

Figure 7-28. Register Summary



# 7.5.1 Register Summary Table

| ADDRESS | REGISTER          | DESCRIPTION                    | R/W MODE | RESET VALUE | NVM<br>VALUES | INCLUDED IN NVM? |
|---------|-------------------|--------------------------------|----------|-------------|---------------|------------------|
| 0x306   | DIR0_ADDR         | Device Address North Direction | R/W      | 0x00        | n/a           | no               |
| 0x307   | DIR1_ADDR         | Device Address South Direction | R/W      | 0x00        | n/a           | no               |
| 0x309   | CONTROL1          | Control1                       | R/W      | 0x00        | n/a           | no               |
| 0x30A   | CONTROL2          | Control2                       | R/W      | 0x00        | n/a           | no               |
| 0x2000  | DIAG_CTRL         | Diagnostic Control             | R/W      | 0x00        | n/a           | no               |
| 0x2001  | DEV_CONF1         | Device Configure1              | R/W      | 0x14        | n/a           | no               |
| 0x2002  | DEV_CONF2         | Device Configure2              | R/W      | 0x00        | n/a           | no               |
| 0x2003  | TX_HOLD_OFF       | Transmitter Hold off Control   | R/W      | 0x00        | n/a           | no               |
| 0x2004  | SLP_TIMEOUT       | Sleep Timer                    | R/W      | 0x03        | n/a           | no               |
| 0x2005  | COMM_TIMEOUT      | Communication Timeout Control  | R/W      | 0x34        | n/a           | no               |
| 0x2010  | SPI_FIFO_UNLOCK   | FIFO Diagnostic Unlock         | R/W      | 0x00        | n/a           | no               |
| 0x2020  | FAULT_MSK         | Fault Mask                     | R/W      | 0x00        | n/a           | no               |
| 0x2030  | FAULT_RST         | Fault Reset                    | R/W      | 0x00        | n/a           | no               |
| 0x2100  | FAULT_SUMMARY     | Fault Summary                  | R        | 0x00        | n/a           | no               |
| 0x2101  | FAULT_REG         | Register Fault                 | R        | 0x00        | n/a           | no               |
| 0x2102  | FAULT_SYS         | System Fault                   | R        | 0x00        | n/a           | no               |
| 0x2103  | FAULT_PWR         | Power Fault                    | R        | 0x00        | n/a           | no               |
| 0x2104  | FAULT_COMM1       | Communication Fault1           | R        | 0x00        | n/a           | no               |
| 0x2105  | FAULT_COMM2       | Communication Fault2           | R        | 0x00        | n/a           | no               |
| 0x2110  | DEV_DIAG_STAT     | Diagnostic Status              | R        | 0x00        | n/a           | no               |
| 0x2120  | PARTID            | Part ID                        | R        | 0x00        | various       | yes              |
| 0x2121  | DIE_ID1           | Die ID1                        | R        | 0x00        | various       | yes              |
| 0x2122  | DIE_ID2           | Die ID2                        | R        | 0x00        | various       | yes              |
| 0x2123  | DIE_ID3           | Die ID3                        | R        | 0x00        | various       | yes              |
| 0x2124  | DIE_ID4           | Die ID4                        | R        | 0x00        | various       | yes              |
| 0x2125  | DIE_ID5           | Die ID5                        | R        | 0x00        | various       | yes              |
| 0x2126  | DIE_ID6           | Die ID6                        | R        | 0x00        | various       | yes              |
| 0x2127  | DIE_ID7           | Die ID7                        | R        | 0x00        | various       | yes              |
| 0x2128  | DIE_ID8           | Die ID8                        | R        | 0x00        | various       | yes              |
| 0x2129  | DIE_ID9           | Die ID9                        | R        | 0x00        | various       | yes              |
| 0x2200  | DEBUG_CTRL_UNLOCK | Debug Control Unlock           | R/W      | 0x00        | n/a           | no               |
| 0x2201  | DEBUG_COMM_CTRL   | Debug Communication Control    | R/W      | 0x78        | n/a           | no               |
| 0x2300  | DEBUG_COMM_STAT   | Debug Communication Status     | R        | 0x13        | n/a           | no               |
| 0x2301  | DEBUG_SPI_PHY     | SPI Physical Layer Error       | R        | 0x00        | n/a           | no               |
| 0x2302  | DEBUG_SPI_FRAME   | SPI Frame Layer Error          | R        | 0x00        | n/a           | no               |
| 0x2303  | DEBUG_UART_FRAME  | UART Frame Layer Error         | R        | 0x00        | n/a           | no               |
| 0x2304  | DEBUG_COMH_PHY    | COMH Physical Layer Error      | R        | 0x00        | n/a           | no               |
| 0x2305  | DEBUG_COMH_FRAME  | COMH Frame Layer Error         | R        | 0x00        | n/a           | no               |
| 0x2306  | DEBUG_COML_PHY    | COML Physical Layer Error      | R        | 0x00        | n/a           | no               |
| 0x2307  | DEBUG_COML_FRAME  | COML Frame Layer Error         | R        | 0x00        | n/a           | no               |



## 7.5.2 Register: DIR0\_ADDR

| Address: 0x306                                                                                                                                                                                                                                                                                                                                                              |     |              |    |    |    |    |    |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------|----|----|----|----|----|--|
| B7                                                                                                                                                                                                                                                                                                                                                                          | B6  | B5           | B4 | B3 | B2 | B1 | B0 |  |
| RS                                                                                                                                                                                                                                                                                                                                                                          | SVD | ADDRESS[5:0] |    |    |    |    |    |  |
| 0                                                                                                                                                                                                                                                                                                                                                                           | 0   | 0            | 0  | 0  | 0  | 0  | 0  |  |
| RW                                                                                                                                                                                                                                                                                                                                                                          | RW  | RW           | RW | RW | RW | RW | RW |  |
| ADDRESS [5:0] Follow steps in section "Device Addressing" to config this register. Always shows the current Device Address used by the device when [DIR_SEL] = 0.<br>Default to 0x00 when digital core out of digital reset. MCU can re-address the device by writing a different device address to this register, and the device will take on the new address immediately. |     |              |    |    |    |    |    |  |

# 7.5.3 Register: DIR1\_ADDR

| Address: 0x307                                                                                                                                                                                                                                                                                                                                                              |     |    |              |    |    |    |    |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|--------------|----|----|----|----|--|--|--|
| B7                                                                                                                                                                                                                                                                                                                                                                          | B6  | B5 | B4           | B3 | B2 | B1 | B0 |  |  |  |
| RS                                                                                                                                                                                                                                                                                                                                                                          | SVD |    | ADDRESS[5:0] |    |    |    |    |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                           | 0   | 0  | 0            | 0  | 0  | 0  | 0  |  |  |  |
| RW                                                                                                                                                                                                                                                                                                                                                                          | RW  | RW | RW           | RW | RW | RW | RW |  |  |  |
| ADDRESS [5:0] Follow steps in section "Device Addressing" to config this register. Always shows the current Device Address used by the device when [DIR_SEL] = 1.<br>Default to 0x00 when digital core out of digital reset. MCU can re-address the device by writing a different device address to this register, and the device will take on the new address immediately. |     |    |              |    |    |    |    |  |  |  |

# 7.5.4 Register: CONTROL1

| Address: 0x0309   |                                                                                                                                                                            |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------|------------|---------|--|--|
| B7                | B6                                                                                                                                                                         | B5                                                                 | B4                                                             | B3                                                                      | B2                                                | B1         | B0      |  |  |
| DIR_SEL           | SEND_SHUTDO<br>WN                                                                                                                                                          | SEND_WAKE                                                          | SEND_SLPTOAC<br>T                                              | GOTO_SHUTDO<br>WN                                                       | GOTO_SLEEP                                        | SOFT_RESET | ADDR_WR |  |  |
| 0                 | 0                                                                                                                                                                          | 0                                                                  | 0                                                              | 0                                                                       | 0                                                 | 0          | 0       |  |  |
| RW                | RW                                                                                                                                                                         | RW                                                                 | RW                                                             | RW                                                                      | RW                                                | RW         | RW      |  |  |
| DIR_SEL           | Select daisy chain comm direction. Not self-clear bit.<br>0: In a device, command frame travels from MCU to COMH<br>1: In a device, command frame travels from MCU to COML |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| SEND_SHUTDO<br>WN | Sends SHUTDOWN tone to next device up the stack. The device receiving this bit is unaffected. Self-clear bit.<br>0: Ready<br>1: Send SHUTDWON tone up the stack            |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| SEND_WAKE         | Send WAKE tone up the stack. Self-clear bit.<br>0: Ready<br>1: Send WAKE tone up the stack, then reset its own                                                             |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| SEND_SLPTOAC<br>T | Send SLEEPtoWAKE tone up the stack. Self-clear bit.<br>0: Ready<br>1: Send SLEEPtoWAKE tone up the stack                                                                   |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| GOTO_SHUTDO<br>WN | Transition device to<br>0: Ready<br>1: Enter SHUTDOV                                                                                                                       | SHUTDOWN mode                                                      | e. Self-clear bit.                                             |                                                                         |                                                   |            |         |  |  |
| GOTO_SLEEP        | Transition device to SLEEP mode. Self-clear bit.<br>0: Ready<br>1: Enter SLEEP mode                                                                                        |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| SOFT_RESET        | Reset the digital to OTP default. Self-clear bit.<br>0: Ready<br>1: Reset device                                                                                           |                                                                    |                                                                |                                                                         |                                                   |            |         |  |  |
| ADDR_WR           | Enable device to sta<br>0: Not performing a<br>1: Device is being a                                                                                                        | art auto-addressing.<br>uto-address. Device<br>uuto-addressed; the | See auto-addressin<br>forwards communic<br>1st communication t | g chapter for detail.<br>ation transaction as<br>ransaction it received | Self cleared.<br>normal<br>d will not be forwarde | ed.        |         |  |  |



# 7.5.5 Register: CONTROL2

| Address: 0x30A                                                                                                               |                   |       |    |    |    |    |    |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------|-------------------|-------|----|----|----|----|----|--|--|--|
| B7                                                                                                                           | B6                | B5    | B4 | B3 | B2 | B1 | B0 |  |  |  |
|                                                                                                                              | SEND_HW_RESE<br>T | SPARE |    |    |    |    |    |  |  |  |
| 0                                                                                                                            | 0                 | 0     | 0  | 0  | 0  | 0  | 0  |  |  |  |
| RW                                                                                                                           | RW                | RW    | RW | RW | RW | RW | RW |  |  |  |
| SEND_HW_RESE Send HW_RESET tone up the stack. Self-clear bit.<br>T 0: Ready<br>1: Send HW_RESET tone to next stack device up |                   |       |    |    |    |    |    |  |  |  |

# 7.5.6 Register: DIAG\_CTRL

| Address: 0x2000      |                                                                                                                                                                                                                        |                                                              |                                               |                                       |                         |                      |                     |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------|---------------------------------------|-------------------------|----------------------|---------------------|--|
| B7                   | B6                                                                                                                                                                                                                     | B5                                                           | B4                                            | B3                                    | B2                      | B1                   | B0                  |  |
| RS                   | VD                                                                                                                                                                                                                     | CONF_MON_GO                                                  | PWR_DIAG_GO                                   | SPI_FIFO_DIAG_<br>GO                  | FLIP_FACT_CRC           | FLIP_TR_CRC          | INH_SET_GO          |  |
| 0                    | 0                                                                                                                                                                                                                      | 0                                                            | 0                                             | 0                                     | 0                       | 0                    | 0                   |  |
| RW                   | RW                                                                                                                                                                                                                     | RW                                                           | RW                                            | RW                                    | RW                      | RW                   | RW                  |  |
| CONF_MON_GO          | GO Resample the 2 registers (DEV_CONF1, FAULT_MSK) setting that bit flip monitor checks against. self-clear bit. For usage, refer to paragraph: Register Bit Flip Monitor 0: No action 1: Resample 2 registers setting |                                                              |                                               |                                       |                         |                      |                     |  |
| PWR_DIAG_GO          | <ul> <li>Indicates a power supply BIST diagnostic is initiated, self-clear bit.</li> <li>0: No action</li> <li>1: Initiate power BIST diagnostic</li> </ul>                                                            |                                                              |                                               |                                       |                         |                      |                     |  |
| SPI_FIFO_DIAG_<br>GO | Write the unlock co<br>steps of FIFO diagr<br>0: No action<br>1: Initiate SPI FIFO                                                                                                                                     | de 0x0A to SPI_FIF0<br>nostic, refer to safety<br>diagnostic | D_UNLOCK and follor<br>manual. This bit is s  | owed by writing [SPI<br>self-cleared. | _FIFO_DIAG_GO] =        | : 1 to do FIFO diagn | ostic. For detailed |  |
| FLIP_FACT_CRC        | An enable bit to flip<br>0: No action<br>1: flip the CRC expe                                                                                                                                                          | the factory CRC exp<br>ected value. This wil                 | bected value. This is<br>I cause a factory CR | for factory CRC dia                   | gnostic.<br>6[FACT_CRC] |                      |                     |  |
| FLIP_TR_CRC          | Sends a purposely incorrect communication (during transmitting response) CRC by inverting all of the calculated CRC bits<br>0: Send CRC as calculated<br>1: Send inverted CRC                                          |                                                              |                                               |                                       |                         |                      |                     |  |
| INH_SET_GO           | This bits intentional<br>0: mission mode<br>1: Trigger INH PMC                                                                                                                                                         | lly activates INH PM<br>DS pull up                           | OS pull up, sets [IN⊦                         | i] and [INH_STAT] to                  | 0 1. (self-cleared)     |                      |                     |  |



## 7.5.7 Register: DEV\_CONF1

| Address: 0x2001 |                                                                                                                                                                                                                                                                                  |                                                |                       |                       |                 |          |          |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------|-----------------------|-----------------|----------|----------|--|
| B7              | B6                                                                                                                                                                                                                                                                               | B5                                             | B4                    | B3                    | B2              | B1       | B0       |  |
| SNIFDET_EN      | SNIFDET_DIS                                                                                                                                                                                                                                                                      | TONE_RX_EN                                     | FCOMM_EN              | TWO_STOP_EN           | NFAULT_EN       | RESERVED | HB_TX_EN |  |
| 0               | 0                                                                                                                                                                                                                                                                                | 0                                              | 1                     | 0                     | 1               | 0        | 0        |  |
| RW              | RW                                                                                                                                                                                                                                                                               | RW                                             | RW                    | RW                    | RW              | RW       | RW       |  |
| SNIFDET_EN      | VIFDET_EN Enable the Sniff detector on COM* port, this bit is latched into AVAOREF domain, once latched in, this bit is still effective in SHUTDOWN<br>0: no effect<br>1: SNIF DET is enabled in SHUTDOWN                                                                        |                                                |                       |                       |                 |          |          |  |
| SNIFDET_DIS     | ET_DIS Enable the Sniff detector on COM* port, this bit is latched into AVAOREF domain, once latched in, this bit is still effective in SHUTDOWN<br>0: no effect<br>1: SNIF DET is disabled in SHUTDOWN, if both SNIFDET EN and SNIFDET DIS are '1', SNIFDET DIS takes priority. |                                                |                       |                       |                 |          |          |  |
| TONE_RX_EN      | Enable the Tone receiver, depends on [DIR_SEL], one of the COML/COMH tone recover is enabled. COMH/COML tone receivers are enabled in VALIDATE disregarding setting of this bit.<br>0: Disable<br>1: Enable                                                                      |                                                |                       |                       |                 |          |          |  |
| FCOMM_EN        | Enable the fault sta<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                  | te detection through                           | communication in A    | CTIVE mode            |                 |          |          |  |
| TWO_STOP_EN     | Enables two stop b<br>0: One STOP bit<br>1: Two STOP bit                                                                                                                                                                                                                         | its for the UART in c                          | ase of severe oscilla | tor error in both the | host and device |          |          |  |
| NFAULT_EN       | Enables the NFAUL<br>0: NFAULT driver is<br>1: NFAULT pulls low                                                                                                                                                                                                                  | T function<br>disabled<br>v to indicate an unm | asked fault is detect | ed                    |                 |          |          |  |
| RESERVED        | Reserved. Default                                                                                                                                                                                                                                                                | value is 0. Please do                          | n't alter.            |                       |                 |          |          |  |
| HB_TX_EN        | Enable HEARTBEA<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                       | ∖T transmitter when o                          | device is in SLEEP r  | node                  |                 |          |          |  |

# 7.5.8 Register: DEV\_CONF2

| Address: 0x2002 |                                                                                                                               |         |    |    |    |    |    |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------|---------|----|----|----|----|----|--|--|
| B7              | B6                                                                                                                            | B5      | B4 | B3 | B2 | B1 | B0 |  |  |
|                 | INH_D                                                                                                                         | IS[1:0] |    |    |    |    |    |  |  |
| 0               | 0                                                                                                                             | 0       | 0  | 0  | 0  | 0  | 0  |  |  |
| RW              | RW                                                                                                                            | RW      | RW | RW | RW | RW | RW |  |  |
| INH_DIS[1:0]    | INH_DIS[1:0] Disable INH driver (PMOS pull up). In all modes, this bit overwrites [INH_SET_GO] and fault tone detection event |         |    |    |    |    |    |  |  |
|                 | 00: INH function is                                                                                                           | enabled |    |    |    |    |    |  |  |
|                 | 01: INH function is                                                                                                           | enabled |    |    |    |    |    |  |  |
|                 | 10: INH function is enabled                                                                                                   |         |    |    |    |    |    |  |  |
|                 | 11: INH function is DISABLED                                                                                                  |         |    |    |    |    |    |  |  |

# 7.5.9 Register: TX\_HOLD\_OFF

| Address: 0x2003                                                                                                                                                  |    |    |    |    |    |    |    |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|--|--|--|
| B7                                                                                                                                                               | B6 | B5 | B4 | B3 | B2 | B1 | B0 |  |  |  |
| DLY[7:0]                                                                                                                                                         |    |    |    |    |    |    |    |  |  |  |
| 0                                                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |  |  |
| RW                                                                                                                                                               | RW | RW | RW | RW | RW | RW | RW |  |  |  |
| DLY[7:0] Set the number of bit period delay from 0 to 255, after receiving the STOP bit of a command frame and before transmitting the 1st bit of response frame |    |    |    |    |    |    |    |  |  |  |



# 7.5.10 Register: SLP\_TIMEOUT

| Address: 0x2004 |                                                                                                                                                                    |                                                                |                    |                     |                       |                    |               |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------|---------------------|-----------------------|--------------------|---------------|
| B7              | B6                                                                                                                                                                 | B5                                                             | B4                 | B3                  | B2                    | B1                 | B0            |
|                 |                                                                                                                                                                    | RSVD                                                           | _                  |                     |                       | SLP_TME[2:0]       |               |
| 0               | 0 0 0 0 1                                                                                                                                                          |                                                                |                    |                     |                       |                    |               |
| RW              | RW                                                                                                                                                                 | RW                                                             | RW                 | RW                  | RW                    | RW                 | RW            |
| SLP_TME[2:0]    | This timer starts co<br>reset if device wake<br>000: no timeout. De<br>001: 5s<br>010: 10s<br>011: 1min<br>100: 10mins<br>101: 30mins<br>110: 1hour<br>111: 2hours | unting when device<br>es up to ACTIVE.<br>evice remains in SLE | enters SLEEP or VA | LIDATE. When the ti | imer expires, the dev | vice enters SHUTDC | WN. The timer |

# 7.5.11 Register: COMM\_TIMEOUT

| Address: 0x2005 |                                                                                                                                                                                                                                                                                                                                              |                                                                   |                                                                |                                                                   |                      |                    |      |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------|----------------------|--------------------|------|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                           | B5                                                                | B4                                                             | B3                                                                | B2                   | B1                 | B0   |  |
| RSVD            |                                                                                                                                                                                                                                                                                                                                              | CTS_TIME[2:0]                                                     |                                                                | CTL_ACT                                                           |                      | CTL_TIME[2:0]      |      |  |
| 0               | 0 1 1                                                                                                                                                                                                                                                                                                                                        |                                                                   |                                                                | 0                                                                 | 1                    | 0                  | 0    |  |
| RW              | RW                                                                                                                                                                                                                                                                                                                                           | RW                                                                | RW                                                             | RW                                                                | RW                   | RW                 | RW   |  |
| CTS_TIME[2:0]   | Set the short communication timeout. When this timer expires, the device set the FAULT_SYS [CTS] bit. This can be used as an alert to the system to prevent a long communication timeout.<br>000: disable short communication timeout<br>001: 100ms<br>010: 2s<br>011: 10s (default)<br>100: 1min<br>101: 10mins<br>110: 30min<br>111: 1hour |                                                                   |                                                                |                                                                   |                      |                    |      |  |
| CTL_ACT         | Configure the devic<br>0: set FAULT_SYS<br>1: Send the device                                                                                                                                                                                                                                                                                | ce action when long o<br>[CTL] and send device<br>to SHUTDOWN. FA | communication time<br>ce to SLEEP mode (<br>ULT_SYS[CTL] bit w | out timer expires<br>default at reset)<br><i>i</i> ill not be set |                      |                    |      |  |
| CTL_TIME[2:0]   | Set the long comm<br>000: disable long co<br>001: 100ms<br>010: 2s<br>011: 10s<br>100: 1min (default)<br>101: 10mins<br>110: 30min<br>111: 1hour                                                                                                                                                                                             | unication timeout. W                                              | hen this timer expire<br>ut                                    | s, the device takes t                                             | he action configurec | I by the [CTL_ACT] | oit. |  |

# 7.5.12 Register: SPI\_FIFO\_UNLOCK

| Address: 0x2010 |                                                                                                                                                                                                                                                                                                                                                                                                                            |     |    |           |    |    |    |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|-----------|----|----|----|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                         | B5  | B4 | B3        | B2 | B1 | B0 |  |  |
|                 | RS                                                                                                                                                                                                                                                                                                                                                                                                                         | SVD |    | CODE[3:0] |    |    |    |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                          | 0   | 0  | 0 0 0     |    |    |    |  |  |
| RW              | RW                                                                                                                                                                                                                                                                                                                                                                                                                         | RW  | RW | RW        | RW | RW | RW |  |  |
| CODE[3:0]       | DE[3:0] In UART mode - write has no impact and read always returns 0 In SPI mode - Write the unlock code 0x0A to SPI_FIFO_UNLOCK (MSB 4 bits are don't care, e.g. 0x2A would also unlock) and followed by writing [SPI_FIFO_DIAG_GO] = 1 to do FIFO diagnostic. For detailed steps of FIFO diagnostic, refer to safety manual. After these bits are written, read cmd doesn't affect them while any write cmd clears them. |     |    |           |    |    |    |  |  |



# 7.5.13 Register: FAULT\_MSK

| Address: 0x2020   |                                                                                                                                                                                                                                                                                                                                                                                              |                                                              |                                                                   |                                             |                     |                      |                  |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------|---------------------|----------------------|------------------|--|--|
| B7                | B6                                                                                                                                                                                                                                                                                                                                                                                           | B5                                                           | B4                                                                | B3                                          | B2                  | B1                   | B0               |  |  |
| MSK_COML_H        | MSK_UART_SPI                                                                                                                                                                                                                                                                                                                                                                                 | MSK_FCOMM_D<br>ET                                            | MSK_FTONE_DE<br>T                                                 | MSK_HB                                      | MSK_REG             | MSK_SYS              | MSK_PWR          |  |  |
| 0                 | 0                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                            | 0                                                                 | 0                                           | 0                   | 0                    | 0                |  |  |
| RW                | RW                                                                                                                                                                                                                                                                                                                                                                                           | RW                                                           | RW                                                                | RW                                          | RW                  | RW                   | RW               |  |  |
| MSK_COML_H        | If this bit is set, [FAULT_COMM] bit in FAULT_SUMMARY register is not set (NFAULT won't toggle) due to bits: [COML_FRAME],<br>[COMH_FRAME], [COML_PHY], [COMH_PHY] and registers: DEBUG_COMH_PHY, DEBUG_COMH_FRAME, DEBUG_COML_PHY,<br>DEBUG_COML_FRAME<br>0: Assert NFAULT and set [FAULT_COMM] if fault above is detected<br>1: No NFAULT action, [FAULT_COMM] not set due to faults above |                                                              |                                                                   |                                             |                     |                      |                  |  |  |
| MSK_UART_SPI      | If this bit is set, [FAULT_COMM] bit in FAULT_SUMMARY register is not set (NFAULT won't toggle) due to [STOP_DET],<br>[COMMCLR_DET], [UART_FRAME], [SPI_FRAME], [SPI_PHY] bits and DEBUG_UART_FRAME, DEBUG_SPI_PHY,<br>DEBUG_SPI_FRAME registers<br>0: Assert NFAULT and set [FAULT_COMM] if fault above is detected<br>1: No NFAULT action, [FAULT_COMM] not set due to faults above        |                                                              |                                                                   |                                             |                     |                      |                  |  |  |
| MSK_FCOMM_D<br>ET | If this bit is set, [FAULT_COMM] bit in FAULT_SUMMARY register is not set (NFAULT won't toggle) due to [FCOMM_DET]<br>0: Assert NFAULT and set [FAULT_COMM] if fault above is detected<br>1: No NFAULT action, [FAULT_COMM] not set due to faults above                                                                                                                                      |                                                              |                                                                   |                                             |                     |                      |                  |  |  |
| MSK_FTONE_DE<br>T | If this bit is set, [FA<br>0: Assert NFAULT a<br>1: No NFAULT action                                                                                                                                                                                                                                                                                                                         | ULT_COMM] bit in F<br>and set [FAULT_COI<br>on, [FAULT_COMM] | AULT_SUMMARY re<br>MM] if fault above is<br>not set due to faults | egister is not set (NF<br>detected<br>above | AULT won't toggle)  | due to [FTONE_DET    | []               |  |  |
| MSK_HB            | If this bit is set, [FA<br>0: Assert NFAULT a<br>1: No NFAULT action                                                                                                                                                                                                                                                                                                                         | ULT_COMM] bit in F<br>and set [FAULT_COI<br>on, [FAULT_COMM] | AULT_SUMMARY re<br>MM] if fault above is<br>not set due to faults | egister is not set (NF<br>detected<br>above | AULT won't toggle)  | due to [HB_FAIL] an  | d [HB_FAST]      |  |  |
| MSK_REG           | If this bit is set, [FA<br>FAULT_REG regist<br>0: Mask disabled<br>1: Mask enabled to                                                                                                                                                                                                                                                                                                        | ULT_REG] bit in FAl<br>er.<br>prevent fault signali          | JLT_SUMMARY reg                                                   | ister is not set and N                      | IFAULT won't toggle | due to OTP fault. It | doesn't affect   |  |  |
| MSK_SYS           | If this bit is set, [FAULT_SYS] bit in FAULT_SUMMARY register is not set and NFAULT won't toggle due to SYS fault. It doesn't affect<br>FAULT_SYS register.<br>0: Assert NFAULT if any bit from FAULT_SYS is set to '1'<br>1: No NFAULT action regardless of FAULT_SYS status                                                                                                                |                                                              |                                                                   |                                             |                     |                      |                  |  |  |
| MSK_PWR           | If this bit is set, [FA<br>FAULT_PWR regist<br>0: Mask disabled<br>1: Mask enabled to                                                                                                                                                                                                                                                                                                        | ULT_PWR] bit in FA<br>ier.<br>prevent fault signali          | ULT_SUMMARY reg                                                   | jister is not set and №                     | NFAULT won't toggle | due to PWR fault. I  | t doesn't affect |  |  |



# 7.5.14 Register: FAULT\_RST

| Address: 0x2030   |                                                                                                                                                                                                    |                                                                                                                                                                                              |                           |                    |               |         |         |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------------------|---------------|---------|---------|--|--|
| B7                | B6                                                                                                                                                                                                 | B5                                                                                                                                                                                           | B4                        | B3                 | B2            | B1      | B0      |  |  |
| RST_COML_H        | RST_UART_SPI                                                                                                                                                                                       | RST_FCOMM_DE<br>T                                                                                                                                                                            | RST_FTONE_DE<br>T         | RST_HB             | RST_REG       | RST_SYS | RST_PWR |  |  |
| 0                 | 0                                                                                                                                                                                                  | 0                                                                                                                                                                                            | 0                         | 0                  | 0             | 0       | 0       |  |  |
| RW                | RW                                                                                                                                                                                                 | RW                                                                                                                                                                                           | RW                        | RW                 | RW            | RW      | RW      |  |  |
| RST_COML_H        | Reset bits: COML_FRAME, COMH_FRAME, COML_PHY, COMH_PHY and registers: DEBUG_COMH_PHY, DEBUG_COMH_FRAME, DEBUG_COML_PHY, DEBUG_COML_FRAME. self-cleared bit.<br>0: Do not reset<br>1: Reset to 0x00 |                                                                                                                                                                                              |                           |                    |               |         |         |  |  |
| RST_UART_SPI      | Reset STOP_DET,<br>DEBUG_SPI_FRAI<br>0: Do not reset<br>1: Reset to 0x00                                                                                                                           | Reset STOP_DET, COMMCLR_DET, UART_FRAME, SPI_FRAME, SPI_PHY bits and DEBUG_UART_FRAME, DEBUG_SPI_PHY,<br>DEBUG_SPI_FRAME registers. self-cleared bit.<br>): Do not reset<br>1: Reset to 0x00 |                           |                    |               |         |         |  |  |
| RST_FCOMM_DE<br>T | E Reset FCOMM_DET bit, self-cleared bit.<br>0: Do not reset<br>1: Reset to '0'                                                                                                                     |                                                                                                                                                                                              |                           |                    |               |         |         |  |  |
| RST_FTONE_DE<br>T | Reset FTONE_DE<br>0: Do not reset<br>1: Reset to '0'                                                                                                                                               | T bit, self-cleared bit.                                                                                                                                                                     |                           |                    |               |         |         |  |  |
| RST_HB            | Reset HB_FAIL and<br>0: Do not reset<br>1: Reset to '0'                                                                                                                                            | d HB_FAST bit, self-                                                                                                                                                                         | cleared bit.              |                    |               |         |         |  |  |
| RST_REG           | Resets FAULT_SUMMARY [FAULT_REG] to '0', self-cleared bit.<br>0: Do not reset<br>1: Reset to '0'                                                                                                   |                                                                                                                                                                                              |                           |                    |               |         |         |  |  |
| RST_SYS           | This bit is self-clear<br>0: Do not reset<br>1: Reset register F/                                                                                                                                  | r to 0 after writing to<br>AULT_SYS and [FAL                                                                                                                                                 | 1.<br>JLT_SYS] to 0x00 ar | nd 'O'             |               |         |         |  |  |
| RST_PWR           | Resets FAULT_SU<br>0: Do not reset<br>1: Reset                                                                                                                                                     | MMARY [FAULT_PV                                                                                                                                                                              | VR] to '0' and registe    | r FAULT_PWR, self- | -cleared bit. |         |         |  |  |

# 7.5.15 Register: FAULT\_SUMMARY

| Address: 0x2100 |                                                                                                 |                                                                                                                             |                         |               |           |           |           |  |  |
|-----------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------|-----------|-----------|-----------|--|--|
| B7              | B6         B5         B4         B3         B2         B1         B0                            |                                                                                                                             |                         |               |           |           |           |  |  |
|                 | RS                                                                                              | VD                                                                                                                          |                         | FAULT_COMM    | FAULT_REG | FAULT_SYS | FAULT_PWR |  |  |
| 0               | 0                                                                                               | 0                                                                                                                           | 0                       | 0             | 0         | 0         | 0         |  |  |
| R               | R                                                                                               | R                                                                                                                           | R                       | R             | R         | R         | R         |  |  |
| FAULT_COMM      | Indicate communica<br>0: No fault<br>1: Fault                                                   | ndicate communication related fault is detected (any bits in register FAULT_COMM1, FAULT_COMM2 is set)<br>No fault<br>Fault |                         |               |           |           |           |  |  |
| FAULT_REG       | Indicate registers re<br>0: No fault<br>1: Fault                                                | elated fault is detecte                                                                                                     | ed                      |               |           |           |           |  |  |
| FAULT_SYS       | Indicates system fault is detected (any bits in register FAULT_SYS).<br>0: No fault<br>1: Fault |                                                                                                                             |                         |               |           |           |           |  |  |
| FAULT_PWR       | Indicates a power s<br>0: No fault<br>1: Fault                                                  | supply fault is detecte                                                                                                     | ed (any bits in registe | er FAULT_PWR) |           |           |           |  |  |



# 7.5.16 Register: FAULT\_REG

| Address: 0x2101  |                                                            |                                                                                                                                                                         |                       |       |              |           |          |  |  |  |
|------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------|--------------|-----------|----------|--|--|--|
| B7               | B6                                                         | B5                                                                                                                                                                      | B4                    | B3    | B2           | B1        | B0       |  |  |  |
| RSVD             |                                                            |                                                                                                                                                                         |                       |       | CONF_MON_ERR | FACTLDERR | FACT_CRC |  |  |  |
| 0                | 0                                                          | 0                                                                                                                                                                       | 0                     | 0     | 0            | 0         | 0        |  |  |  |
| R                | R                                                          | R                                                                                                                                                                       | R                     | R     | R            | R         | R        |  |  |  |
| CONF_MON_ER<br>R | Indicates monitored<br>Monitor.<br>0: No fault<br>1: Fault | ndicates monitored 2 registers (DEV_CONF1, FAULT_MSK) have at least one bit flip. For usage, refer to paragraph: Register Bit Flip<br>/onitor.<br>또 No fault<br>: Fault |                       |       |              |           |          |  |  |  |
| FACTLDERR        | Indicates the factor<br>0: No fault<br>1: Fault            | ndicates the factory NVM registers could not be loaded from OTP.<br>): No fault<br>I: Fault                                                                             |                       |       |              |           |          |  |  |  |
| FACT_CRC         | Indicates a CRC er<br>0: No fault<br>1: Fault              | ror has occurred in t                                                                                                                                                   | he factory register s | pace. |              |           |          |  |  |  |

# 7.5.17 Register: FAULT\_SYS

| Address: 0x2102  |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                          |                                      |                                                |                                |                        |                        |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------|--------------------------------|------------------------|------------------------|--|--|--|
| B7               | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                      | B5                                                                                                                       | B4                                   | B3                                             | B2                             | B1                     | B0                     |  |  |  |
| VALIDATE_DET     | LFO                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SHUTDOWN_REC                                                                                                             | DRST                                 | CTL                                            | CTS                            | TSHUT                  | INH                    |  |  |  |
| 0                | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                        | 0                                    | 0                                              | 0                              | 0                      | 0                      |  |  |  |
| R                | R                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R                                                                                                                        | R                                    | R                                              | R                              | R                      | R                      |  |  |  |
| VALIDATE_DET     | Indicates device tra<br>0: no transitioned to<br>1: transitioned to V/                                                                                                                                                                                                                                                                                                                                                                                  | ndicates device transitioned to VALIDATE mode<br>): no transitioned to VALIDATE MODE<br>1: transitioned to VALIDATE MODE |                                      |                                                |                                |                        |                        |  |  |  |
| LFO              | Indicated LFO frequ<br>0: no fault<br>1: fault                                                                                                                                                                                                                                                                                                                                                                                                          | ndicated LFO frequency is off by +/-25%<br>): no fault<br>1: fault                                                       |                                      |                                                |                                |                        |                        |  |  |  |
| SHUTDOWN_RE<br>C | <ul> <li>Indicates the device was shut down using SHUTDOWN ping. If this bit is set, the COML and COMH RX are both disabled at wake up as a way to isolate itself from the stack. Send another wake ping or [SOFT_RESET] to re-enable COMH/L RX.</li> <li>The previous SHUTDOWN was normal</li> <li>The previous SHUTDOWN was caused by ping, which is not a usual SHUTDOWN method, indicating potential communication issue with the device</li> </ul> |                                                                                                                          |                                      |                                                |                                |                        |                        |  |  |  |
| DRST             | Indicates a digital re<br>0: no digital reset<br>1: digital reset has o                                                                                                                                                                                                                                                                                                                                                                                 | eset has occurred.<br>occurred                                                                                           |                                      |                                                |                                |                        |                        |  |  |  |
| CTL              | Indicates a long con<br>device shutdown.<br>0: No fault<br>1: long communicat                                                                                                                                                                                                                                                                                                                                                                           | mmunication timeout oc<br>tion timeout occurs. Ob                                                                        | curred. Device a servable if long ti | ction is configured b<br>meout action is set t | y [CTL_ACT]. This b<br>o SLEEP | it is not observable i | f the action is set to |  |  |  |
| СТЅ              | Indicates a short communication timeout occurred. No action from the device. This can be served as an alert to system before reaching long communication timeout.<br>0: No fault<br>1: short communication timeout occurs                                                                                                                                                                                                                               |                                                                                                                          |                                      |                                                |                                |                        |                        |  |  |  |
| TSHUT            | Indicates the previous shutdown was due to thermal shutdown<br>0: die temp is < thermal shutdown threshold<br>1: the previous shutdown was to due thermal shutdown                                                                                                                                                                                                                                                                                      |                                                                                                                          |                                      |                                                |                                |                        |                        |  |  |  |
| INH              | Indicates INH PMO<br>0: INH driver is off<br>1: INH driver enable                                                                                                                                                                                                                                                                                                                                                                                       | S is enabled<br>ed, pulls pin up to BAT                                                                                  |                                      |                                                |                                |                        |                        |  |  |  |



# 7.5.18 Register: FAULT\_PWR

| Address: 0x2103 |                                                                                            |                                                                                                                  |               |         |         |            |              |  |  |
|-----------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------|---------|---------|------------|--------------|--|--|
| B7              | B6                                                                                         | B5                                                                                                               | B4            | B3      | B2      | B1         | B0           |  |  |
|                 | RSVD                                                                                       |                                                                                                                  | CVDD_UV_DRST  | CVDD_OV | DVDD_OV | AVDDREF_OV | AVAO_SW_FAIL |  |  |
| 0               | 0                                                                                          | 0                                                                                                                | 0             | 0       | 0       | 0          | 0            |  |  |
| R               | R                                                                                          | R                                                                                                                | R             | R       | R       | R          | R            |  |  |
| CVDD_UV_DRST    | Indicates CVDDUV<br>0: no fault<br>1: fault                                                | dicates CVDDUV fault caused DRST. Shutdown/power up event shall not trigger this fault.<br>: no fault<br>: fault |               |         |         |            |              |  |  |
| CVDD_OV         | Indicates an over v<br>0: no fault<br>1: fault                                             | Indicates an over voltage fault on the CVDD pin<br>0: no fault<br>1: fault                                       |               |         |         |            |              |  |  |
| DVDD_OV         | Indicates an over v<br>0: no fault<br>1: fault                                             | oltage fault on the D                                                                                            | VDD pin       |         |         |            |              |  |  |
| AVDDREF_OV      | Indicates an over voltage fault on the AVDD_REF internal supply<br>0: no fault<br>1: fault |                                                                                                                  |               |         |         |            |              |  |  |
| AVAO_SW_FAIL    | Indicates a fault is o<br>0: no fault<br>1: fault                                          | detected on the AVA                                                                                              | O_REF switch. |         |         |            |              |  |  |

# 7.5.19 Register: FAULT\_COMM1

| Address: 0x2104 |                                                                                                                                                                                                                                                     |                                                                                                                                                                                           |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|--------------------------------------------|----------------------------------------|-------------------------------------------------|---------------------------------------|--|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                  | B5                                                                                                                                                                                        | B4                                          | B3                                         | B2                                     | B1                                              | B0                                    |  |  |  |  |
| RSVD            | FCOMM_DET                                                                                                                                                                                                                                           | FTONE_DET                                                                                                                                                                                 | HB_FAIL                                     | HB_FAST                                    | UART_FRAME                             | COMMCLR_DET                                     | STOP_DET                              |  |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                         | 0                                           | 0                                          | 0                                      | 0                                               | 0                                     |  |  |  |  |
| R               | R                                                                                                                                                                                                                                                   | R                                                                                                                                                                                         | R                                           | R                                          | R                                      | R                                               | R                                     |  |  |  |  |
| FCOMM_DET       | Indicates the fault s<br>family<br>0: no fault<br>1: fault                                                                                                                                                                                          | ndicates the fault status bit in comm frame is set by stack devices. At least a fault in stack devices happened. Only apply to non-bq79606<br>family<br>D: no fault<br>1: fault           |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
| FTONE_DET       | Indicates the fault to<br>= 0 and vice versa.<br>0: no fault<br>1: fault                                                                                                                                                                            | Indicates the fault tone is detected, COM Port in sleep mode if work with non-bq79606 (Detection is monitoring the COML side if [DIR_SEL] = 0 and vice versa.)<br>0: no fault<br>1: fault |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
| HB_FAIL         | Indicates HB tone is NOT detected within tHB_PERIOD, not supported with BQ79606A-Q1 (Detection is monitoring the COML side if [DIR_SEL] = 0 and vice versa.)<br>0: no fault, HB tone detected as expected<br>1: fault                               |                                                                                                                                                                                           |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
| HB_FAST         | Indicates HB tone is<br>[DIR_SEL] = 0 and<br>previous Heartbeat<br>0: no fault<br>1: fault                                                                                                                                                          | s detected within tHI<br>vice versa.) This bit<br>tone.                                                                                                                                   | 3_FAST (too frequer<br>could also be set wh | nt), not supported wit<br>nen [FTONE_DET]= | th BQ79606A-Q1(E<br>1 depends on how s | Detection is monitorir<br>oon the Fault Tone is | g the COML side if<br>s detected from |  |  |  |  |
| UART_FRAME      | Indicates a UART FAULT detected when receiving command or transmitting response frames Further detail of the fault information is available in the DEBUG_UART_FRAME register<br>0: no fault<br>1: fault                                             |                                                                                                                                                                                           |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
| COMMCLR_DET     | A UART/SPI communication clear signal is detected. This bit is set when Sleep2active ping is sent in UART mode. While in SPI mode, it is<br>not set when sleep2active ping is sent.<br>0: no UART/SPI Comm Clear<br>1: UART/SPI Comm Clear detected |                                                                                                                                                                                           |                                             |                                            |                                        |                                                 |                                       |  |  |  |  |
| STOP_DET        | Indicates and unex<br>0: no fault<br>1: fault                                                                                                                                                                                                       | pected STOP condit                                                                                                                                                                        | ion is received. Appl                       | y to UART mode. Th                         | nis bit is set when Sle                | eep2active ping is se                           | ent in ACTIVE.                        |  |  |  |  |



# 7.5.20 Register: FAULT\_COMM2

| Address: 0x2105 |                                                                                                                                                                                |                                                                                                                                                                                                                   |                              |                         |                      |                         |                     |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------------------|----------------------|-------------------------|---------------------|--|--|--|--|
| B7              | B6                                                                                                                                                                             | B5                                                                                                                                                                                                                | B4                           | B3                      | B2                   | B1                      | B0                  |  |  |  |  |
| RS              | SVD                                                                                                                                                                            | SPI_FRAME                                                                                                                                                                                                         | SPI_PHY                      | COML_FRAME              | COML_PHY             | COMH_FRAME              | COMH_PHY            |  |  |  |  |
| 0               | 0                                                                                                                                                                              | 0                                                                                                                                                                                                                 | 0                            |                         |                      |                         |                     |  |  |  |  |
| R               | R                                                                                                                                                                              | R R R R R R R                                                                                                                                                                                                     |                              |                         |                      |                         |                     |  |  |  |  |
| SPI_FRAME       | Indicates a SPI frar<br>information is availa<br>0: no fault<br>1: fault                                                                                                       | indicates a SPI frame level FAULT detected when receiving command or transmitting response frames. Further detail of the fault information is available in the DEBUG_SPI_FRAME register 0: no fault 1: fault      |                              |                         |                      |                         |                     |  |  |  |  |
| SPI_PHY         | Indicates a SPI bit I<br>available in the DEI<br>0: no fault<br>1: fault                                                                                                       | Indicates a SPI bit level FAULT detected when receiving command or transmitting response frames. Further detail of the fault information is<br>available in the DEBUG_SPI_PHY register<br>0: no fault<br>1: fault |                              |                         |                      |                         |                     |  |  |  |  |
| COML_FRAME      | Indicate a COML by<br>DEBUG_COML_FF<br>0: no fault<br>1: fault                                                                                                                 | Indicate a COML byte level fault detected when receiving response frames. Further details of the fault information is available in DEBUG_COML_FRAME<br>0: no fault<br>1: fault                                    |                              |                         |                      |                         |                     |  |  |  |  |
| COML_PHY        | Indicate a COML bi<br>available in DEBUG<br>0: no fault<br>1: fault                                                                                                            | t level fault detected<br>S_COML_PHY regis                                                                                                                                                                        | , which would cause<br>ter.  | e at least a byte level | (RC_RR) fault. Furt  | her details of the fau  | It information are  |  |  |  |  |
| COMH_FRAME      | Indicate a COMH byte level fault detected when receiving response frames. Further details of the fault information is available in DEBUG_COMH_FRAME<br>0: no fault<br>1: fault |                                                                                                                                                                                                                   |                              |                         |                      |                         |                     |  |  |  |  |
| COMH_PHY        | Indicate a COMH b<br>available in DEBUG<br>0: no fault<br>1: fault                                                                                                             | it level fault detected<br>S_COMH_PHY regis                                                                                                                                                                       | l, which would cause<br>ter. | e at least a byte leve  | I (RC_RR) fault. Fur | ther details of the fai | ult information are |  |  |  |  |

# 7.5.21 Register: DEV\_DIAG\_STAT

| Address: 0x2110 |                                                                                                                                                 |                             |                        |                  |    |    |    |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------|------------------|----|----|----|--|--|--|
| B7              | B6                                                                                                                                              | B5                          | B4                     | B3               | B2 | B1 | B0 |  |  |  |
|                 |                                                                                                                                                 |                             | PWR_DIAG_RDY           | INH_STAT         |    |    |    |  |  |  |
| 0               | 0                                                                                                                                               | 0                           | 0                      | 0                | 0  | 0  | 0  |  |  |  |
| R               | R                                                                                                                                               | R R R R R R R               |                        |                  |    |    |    |  |  |  |
| PWR_DIAG_RDY    | PWR_DIAG_RDY Indicates a power supply BIST test is done. It is cleared when [PWR_DIAG_GO] bit is set.<br>0: BIST is not done<br>1: BIST is done |                             |                        |                  |    |    |    |  |  |  |
| INH_STAT        | Indicates INH Pin so<br>0: Voltage not detected<br>1: Voltage detected                                                                          | ee VINH_DET, this b<br>sted | bit reflects real time | value of pin INH |    |    |    |  |  |  |

# 7.5.22 Register: PARTID

| Address: 0x2120 |                     |                    |                 |        |    |    |    |
|-----------------|---------------------|--------------------|-----------------|--------|----|----|----|
| B7              | B6                  | B5                 | B4              | B3     | B2 | B1 | B0 |
|                 |                     |                    | REV             | /[7:0] |    |    |    |
| 0               | 0                   | 0                  | 0               | 0      | 0  | 0  | 0  |
| R               | R                   | R                  | R               | R      | R  | R  | R  |
| REV[7:0]        | Device revision 0x0 | 0 = A0, 0x01 = A1, | 0x02 = A2, etc. |        |    |    |    |



## 7.5.23 Register: DIE\_ID1

| Address: 0x2121 |                       |                                          |                     |                          |      |    |    |  |  |  |
|-----------------|-----------------------|------------------------------------------|---------------------|--------------------------|------|----|----|--|--|--|
| B7              | B6                    | B5                                       | B4                  | B3                       | B2   | B1 | B0 |  |  |  |
|                 | ID[7:0]               |                                          |                     |                          |      |    |    |  |  |  |
| 0               | 0                     | 0                                        | 0                   | 0                        | 0    | 0  | 0  |  |  |  |
| R               | R                     | R                                        | R                   | R                        | R    | R  | R  |  |  |  |
| ID[7:0]         | Digital reset value ( | אָל אָאָל אָאָאָאָאָאָאָאָאָאָאָאָאָאָאָ | VM loaded successfu | ully, it is value in the | NVM. |    |    |  |  |  |

## 7.5.24 Register: DIE\_ID2

| Address: 0x2122 |                       |                       |                     |                          |      |    |    |  |  |
|-----------------|-----------------------|-----------------------|---------------------|--------------------------|------|----|----|--|--|
| B7              | B6                    | B5                    | B4                  | B3                       | B2   | B1 | B0 |  |  |
| ID[7:0]         |                       |                       |                     |                          |      |    |    |  |  |
| 0               | 0                     | 0                     | 0                   | 0                        | 0    | 0  | 0  |  |  |
| R               | R                     | R                     | R                   | R                        | R    | R  | R  |  |  |
| ID[7:0]         | Digital reset value ( | 0x00, after factory N | /M loaded successfi | ully, it is value in the | NVM. |    |    |  |  |

# 7.5.25 Register: DIE\_ID3

| Address: 0x2123 |                       |                        |                    |                          |      |    |    |
|-----------------|-----------------------|------------------------|--------------------|--------------------------|------|----|----|
| B7              | B6                    | B5                     | B4                 | B3                       | B2   | B1 | B0 |
|                 |                       |                        | ID[                | 7:0]                     |      |    |    |
| 0               | 0                     | 0                      | 0                  | 0                        | 0    | 0  | 0  |
| R               | R                     | R                      | R                  | R                        | R    | R  | R  |
| ID[7:0]         | Digital reset value ( | )x00, after factory אי | VM loaded successf | ully, it is value in the | NVM. |    |    |

## 7.5.26 Register: DIE\_ID4

| Address: 0x2124 |                       |                       |                    |                          |      |    |    |  |  |  |
|-----------------|-----------------------|-----------------------|--------------------|--------------------------|------|----|----|--|--|--|
| B7              | B6                    | B5                    | B4                 | В3                       | B2   | B1 | В0 |  |  |  |
| 0               | 0                     | 0                     | 0                  | 0                        | 0    | 0  | 0  |  |  |  |
| R               | R                     | R                     | R                  | R                        | R    | R  | R  |  |  |  |
| ID[7:0]         | Digital reset value ( | )x00, after factory N | /M loaded successf | ully, it is value in the | NVM. |    |    |  |  |  |

# 7.5.27 Register: DIE\_ID5

| Address: 0x2125 |                       |                       |                     |                          |      |    |    |
|-----------------|-----------------------|-----------------------|---------------------|--------------------------|------|----|----|
| B7              | B6                    | B5                    | B4                  | B3                       | B2   | B1 | B0 |
|                 | •                     |                       | ID[7                | 7:0]                     |      |    |    |
| 0               | 0                     | 0                     | 0                   | 0                        | 0    | 0  | 0  |
| R               | R                     | R                     | R                   | R                        | R    | R  | R  |
| ID[7:0]         | Digital reset value ( | 0x00, after factory N | /M loaded successfu | ully, it is value in the | NVM. |    |    |

## 7.5.28 Register: DIE\_ID6

| Address: 0x2126 |                       |                      |                     |                          |      |    |    |  |  |  |  |
|-----------------|-----------------------|----------------------|---------------------|--------------------------|------|----|----|--|--|--|--|
| B7              | B6                    | B5                   | B4                  | B3                       | B2   | B1 | B0 |  |  |  |  |
|                 |                       |                      | ID[                 | 7:0]                     |      |    |    |  |  |  |  |
| 0               | 0                     | 0                    | 0                   | 0                        | 0    | 0  | 0  |  |  |  |  |
| R               | R                     | R                    | R                   | R                        | R    | R  | R  |  |  |  |  |
| ID[7:0]         | Digital reset value ( | x00, after factory N | VM loaded successfu | ully, it is value in the | NVM. |    | •  |  |  |  |  |



# 7.5.29 Register: DIE\_ID7

| Address: 0x2127 |                       |                       |                     |                          |      |    |    |
|-----------------|-----------------------|-----------------------|---------------------|--------------------------|------|----|----|
| B7              | B6                    | B5                    | B4                  | B3                       | B2   | B1 | B0 |
|                 |                       |                       | ID[                 | 7:0]                     |      |    |    |
| 0               | 0                     | 0                     | 0                   | 0                        | 0    | 0  | 0  |
| R               | R                     | R                     | R                   | R                        | R    | R  | R  |
| ID[7:0]         | Digital reset value ( | )x00, after factory N | VM loaded successfu | ully, it is value in the | NVM. |    |    |

## 7.5.30 Register: DIE\_ID8

| Address: 0x2128 |                       |                       |                     |                          |      |    |    |  |  |
|-----------------|-----------------------|-----------------------|---------------------|--------------------------|------|----|----|--|--|
| B7              | B6                    | B5                    | B4                  | B3                       | B2   | B1 | B0 |  |  |
| ID[7:0]         |                       |                       |                     |                          |      |    |    |  |  |
| 0               | 0                     | 0                     | 0                   | 0                        | 0    | 0  | 0  |  |  |
| R               | R                     | R                     | R                   | R                        | R    | R  | R  |  |  |
| ID[7:0]         | Digital reset value ( | 0x00, after factory N | VM loaded successfu | ully, it is value in the | NVM. |    |    |  |  |

# 7.5.31 Register: DIE\_ID9

| Address: 0x2129 |                       |                       |                    |                          |      |    |    |
|-----------------|-----------------------|-----------------------|--------------------|--------------------------|------|----|----|
| B7              | B6                    | B5                    | B4                 | B3                       | B2   | B1 | B0 |
|                 |                       |                       | ID[                | 7:0]                     |      |    |    |
| 0               | 0                     | 0                     | 0                  | 0                        | 0    | 0  | 0  |
| R               | R                     | R                     | R                  | R                        | R    | R  | R  |
| ID[7:0]         | Digital reset value ( | )x00, after factory N | VM loaded successf | ully, it is value in the | NVM. |    |    |

## 7.5.32 Register: DEBUG\_CTRL\_UNLOCK

| Address: 0x2200                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |    |    |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|--|--|
| B7                                                                                                                                                                                                                                                                                                                | B6 | B5 | B4 | B3 | B2 | B1 | B0 |  |  |
| CODE[7:0]                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |  |  |
| 0                                                                                                                                                                                                                                                                                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |  |
| RW                                                                                                                                                                                                                                                                                                                | RW | RW | RW | RW | RW | RW | RW |  |  |
| CODE[7:0] Write the unlock code (0xA5) to this register to activate the setting in the DEBUG_COMM_CTRL register. Any other value than the unlock code will deactivate any effect in the DEBUG_COMM_CTRL setting and return to the device's normal setting. This register doesn't affect DEBUG_COMM_STAT register. |    |    |    |    |    |    |    |  |  |



# 7.5.33 Register: DEBUG\_COMM\_CTRL

| Address: 0x2201   |                                                                                                                                                                                                                                                                                                                                                                            |                                                                       |                                                                 |                      |               |                  |               |  |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------|----------------------|---------------|------------------|---------------|--|--|--|
| B7                | B6                                                                                                                                                                                                                                                                                                                                                                         | B5                                                                    | B4                                                              | B3                   | B2            | B1               | В0            |  |  |  |
| RSVD              | COML_TX_EN                                                                                                                                                                                                                                                                                                                                                                 | COML_RX_EN                                                            | COMH_TX_EN                                                      | COMH_RX_EN           | UART_VIF_BAUD | USER_UART_E<br>N | USER_DAISY_EN |  |  |  |
| 0                 | 1                                                                                                                                                                                                                                                                                                                                                                          | 1                                                                     | 1                                                               | 1                    | 0             | 0                | 0             |  |  |  |
| RW                | RW                                                                                                                                                                                                                                                                                                                                                                         | RW                                                                    | RW                                                              | RW                   | RW            | RW               | RW            |  |  |  |
| COML_TX_EN        | Enable COML trans<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                               | smitter                                                               |                                                                 | ·                    |               |                  |               |  |  |  |
| COML_RX_EN        | Enable COML rece<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                | inable COML receiver<br>): disable<br>: enable                        |                                                                 |                      |               |                  |               |  |  |  |
| COMH_TX_EN        | Enable COMH tran<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                | Enable COMH transmitter<br>0: disable<br>1: enable                    |                                                                 |                      |               |                  |               |  |  |  |
| COMH_RX_EN        | Enable COMH rece<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                | eiver                                                                 |                                                                 |                      |               |                  |               |  |  |  |
| UART_VIF_BAUD     | <ul> <li>This bit changes the baud rate of UART and Daisy Chain (Also called VIF) to 250kb/s. Useful on Daisy Chain debug. When system set all the daisy chain devices to the 250kb/s baud rate, it slows down the response byte through the Daisy Chain to increase the robustness of the Daisy Chain for debug purpose.</li> <li>O: 1Mbps</li> <li>1: 250kbps</li> </ul> |                                                                       |                                                                 |                      |               |                  |               |  |  |  |
| USER_UART_EN      | This bit enables [UART_VIF_BAUD] setting<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                        |                                                                       |                                                                 |                      |               |                  |               |  |  |  |
| USER_DAISY_E<br>N | This bit enables the<br>0: the setting of bits<br>1: the device will co                                                                                                                                                                                                                                                                                                    | e setting of bits [6:3<br>s [6:3 ] of current re<br>onfigure the COML | ] in this register<br>gister has no effect<br>and COMH per curr | ent register setting |               |                  |               |  |  |  |

# 7.5.34 Register: DEBUG\_COMM\_STAT

| Address: 0x2300 |                                                                                                                                                                                                                                                             |                                                                    |              |            |            |            |            |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------|------------|------------|------------|------------|--|--|
| B7              | B6                                                                                                                                                                                                                                                          | B5                                                                 | B4           | B3         | B2         | B1         | B0         |  |  |
|                 | RSVD                                                                                                                                                                                                                                                        |                                                                    | HW_DAISY_DRV | COML_TX_ON | COML_RX_ON | COMH_TX_ON | COMH_RX_ON |  |  |
| 0               | 0                                                                                                                                                                                                                                                           | 0                                                                  | 1            | 0          | 0          | 1          | 1          |  |  |
| R               | R                                                                                                                                                                                                                                                           | R                                                                  | R            | R          | R          | R          | R          |  |  |
| HW_DAISY_DRV    | ndicates the COML and COMH are controlled by the device itself or by MCU control<br>): the DEBUG_COMM_CTRL [USER_DAISY_EN] = 1. COML and COMH are under manual control through DEBUG_COMM_CTRL<br>register<br>1: COML and COMH are controlled by the device |                                                                    |              |            |            |            |            |  |  |
| COML_TX_ON      | Show the current COML transmitter status<br>0: Disabled<br>1: Enabled                                                                                                                                                                                       |                                                                    |              |            |            |            |            |  |  |
| COML_RX_ON      | Show the current C<br>0: Disables<br>1: Enables                                                                                                                                                                                                             | Show the current COML receiver status<br>0: Disables<br>1: Enables |              |            |            |            |            |  |  |
| COMH_TX_ON      | Show the current COMH transmitter status<br>0: Disabled<br>1: Enabled                                                                                                                                                                                       |                                                                    |              |            |            |            |            |  |  |
| COMH_RX_ON      | Show the current C<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                             | OMH receiver status                                                | 3            |            |            |            |            |  |  |



# 7.5.35 Register: DEBUG\_SPI\_PHY

| Address: 0x2301 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------|--|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | B5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | B4                                                                  | B3                                                                 | B2                                                                    | B1                                                                  | B0                                                          |  |  |  |  |
| RSVD            | FMT_ERR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | COMCLR_ERR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TXDATA_UNEXP                                                        | RXDATA_UNEXP                                                       | TXFIFO_OF                                                             | TXFIFO_UF                                                           | RXFIFO_OF                                                   |  |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                   | 0                                                                  | 0                                                                     | 0                                                                   | 0                                                           |  |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R                                                                   | R                                                                  | R                                                                     | R                                                                   | R                                                           |  |  |  |  |
| FMT_ERR         | when not in Host Read mode (after sending a write cmd frame), indicates malformed cmd is received: 1. first byte of data after nCS falling<br>edge is 0xFF 2. devices receives not multiple of 8bit . 3. In ACTIVE, nCS pulses low without SCLK toggling (send SLP2ACT ping) Comm<br>clear doesn't trigger this fault. This fault doesn't lock down SPI interface.<br>0: No fault<br>1: Fault                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| COMCLR_ERR      | Nore than 8 SCLK pulses are received during a comm clear. Once this fault is detected, device ignores the malformed comm clear. This<br>fault doesn't affect SPI_RDY nor data storing into RX/TX FIFO.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| TXDATA_UNEXP    | This fault occurs when: 1. device receives unexpected data from itself or daisy chain after a Comm clr OR 2. device receives unexpected data from daisy chain(or from bq79600) after a TX FIFO timeout. Once this fault is detected, device doesn't store any new data into RX/TX FIFO. Device sends out 0xFF on MISO after current byte finished transmission(FIFO data mask happens at byte boundary). SPI_RDY held low till Comm Clear detected. Comm Clear needed for recovery.<br>0: No fault<br>1: Fault                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| RXDATA_UNEXP    | Host sends data other than 0xFF during Device Read mode OR initiates SPI communication when SPI_RDY = 0 (e.g. While FIFO2 is being filled up, host continues reading FIFO2 right after FIFO1 is read out. SPI_DRY is low at this point) Once this fault is detected, device doesn't store any new data into RX/TX FIFO. Device would sends out 0xFF on MISO after current byte finished transmission(FIFO data mask happens at byte boundary). SPI_RDY held low till Comm Clear detected. Comm Clear needed for recovery.<br>0: No fault<br>1: Fault |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| TXFIFO_OF       | If SPI module receir<br>the 2nd FIFO). One<br>current byte finisher<br>needed for recovery<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                | It Fault<br>If SPI module receives data (from itself or daisy chain) when current FIFO is full and 2nd FIFO is not empty (host hasn't complete reading<br>the 2nd FIFO). Once this fault is detected, device doesn't store any new data into RX/TX FIFO. Device sends out 0xFF on MISO after<br>current byte finished transmission(FIFO data mask happens at byte boundary). SPI_RDY held low till Comm Clear detected. Comm Clear<br>needed for recovery.<br>0: No fault                                                                                                                                                                                                                                                 |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| TXFIFO_UF       | In Host Read mode<br>Slave sets this fault<br>any new data into F<br>boundary). SPI_RD<br>reading happens, it<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                             | It: Fault<br>In Host Read mode, when both FIFOs are empty and the host continues to send clocks for more read data (send 0xFF through MOSI). SPI<br>Slave sets this fault flag and continues to send 0xFF on MISO when host requests data. Once this fault is detected, device doesn't store<br>any new data into RX/TX FIFO. Device sends out 0xFF on MISO after current byte finished transmission(FIFO data mask happens at byte<br>boundary). SPI_RDY held low till Comm Clear detected. Comm Clear needed for recovery. (FIFO 1 is read out, FIFO2 is still buffering, if<br>reading happens, it is RXDATA_UNEXP fault) Once FIFO is empty, device rejects any 0xFF until nCS going high.<br>0: No fault<br>1: Fault |                                                                     |                                                                    |                                                                       |                                                                     |                                                             |  |  |  |  |
| RXFIFO_OF       | While device is rece<br>doesn't store any m<br>happens at byte bo<br>frame into bq79600<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                   | eiving command frar<br>ew data into RX/TX<br>undary). SPI_RDY h<br>" to avoid this fault.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ne, more data is sen<br>FIFO. Device sends<br>leld low till Comm Cl | It than device can ac<br>out 0xFF on MISO a<br>lear detected. Comm | commodate in RX F<br>after current byte fini<br>a Clear needed for re | IFO. Once this fault<br>shed transmission(F<br>covery. Follow "Flow | is detected, device<br>IFO data mask<br>v to send write cmd |  |  |  |  |



# 7.5.36 Register: DEBUG\_SPI\_FRAME

| Address: 0x2302 |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                              |                                           |                                 |                      |                        |                   |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------------------------------|----------------------|------------------------|-------------------|--|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                           | B5                                                                                                                                                                                                                                                                                                                           | B4                                        | B3                              | B2                   | B1                     | B0                |  |  |  |  |
| RSVD            |                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TR_SOF                                                                                                                                                                                                                                                                                                                       | TR_WAIT                                   | RC_IERR                         | RC_SOF               | RC_BYTE_ERR            | RC_CRC            |  |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                            | 0                                         | 0                               | 0                    | 0                      | 0                 |  |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R                                                                                                                                                                                                                                                                                                                            | R                                         | R                               | R                    | R                      | R                 |  |  |  |  |
| TR_SOF          | Indicates that a SPI COMM CLEAR is received while there is data in output FIFO (SPI_RDY is 0 or SPI_RDY = 1 and receiving new data from VIF) If SPI_RDY = 1 and not receiving new data from VIF while receiving COMM CLEAR, it doesn't assert this bit.<br>0: No fault<br>1: Fault                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                           |                                 |                      |                        |                   |  |  |  |  |
| TR_WAIT         | Indicates that a SPI COMM CLEAR is received while there is no data in output FIFO regardless of SPI_RDY.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                              |                                           |                                 |                      |                        |                   |  |  |  |  |
| RC_IERR         | Detects initialization byte error in the received command frame. Example: • reserved command bits in the "INIT byte" is set, • expected to a cmd "INIT byte', but it is configured as response frame instead • extra data is sent other than one cmd frame during one nCS low<br>All bytes that follow are discarded until a Comm Clear is received or a SOF due to a properly formed new command is received (nCS falling, etc).<br>0: No fault<br>1: Fault |                                                                                                                                                                                                                                                                                                                              |                                           |                                 |                      |                        |                   |  |  |  |  |
| RC_SOF          | Detects a start-of-fr<br>partial cmd frame is<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                     | rame (SOF) error. Mo<br>s sent                                                                                                                                                                                                                                                                                               | ostly, this is SPI COI                    | MM CLEAR is receiv              | ed on the SPI before | e the current frame is | s finished, e.g.  |  |  |  |  |
| RC_BYTE_ERR     | Device receives dat<br>also be set) CRC is<br>communication CLE<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                   | Device receives data from the VIF that needs to go out on SPI, while host send data into device through SPI. (TXDATA_UNEXP should also be set) CRC is not calculated and doesn't forward communication in daisy chain. All bytes that follow are ignored until a communication CLEAR is received.<br>0: No fault<br>1: Fault |                                           |                                 |                      |                        |                   |  |  |  |  |
| RC_CRC          | Detects CRC error<br>only if no physical le<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                       | in the received comr<br>evel error, IERR, BE                                                                                                                                                                                                                                                                                 | nand frame from SP<br>RR, SOF error deteo | l. The frame will be o<br>cted. | considered as disca  | rded frame. Frame C    | CRC is calculated |  |  |  |  |

# 7.5.37 Register: DEBUG\_UART\_FRAME

| Address: 0x2303 |                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                   |                                           |                              |                      |                       |                   |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------|----------------------|-----------------------|-------------------|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                | B5                                                                                                                                                                                                                                                                                                | B4                                        | B3                           | B2                   | B1                    | B0                |  |  |  |
| RSVD            |                                                                                                                                                                                                                                                                                                                                                                                                                   | TR_SOF                                                                                                                                                                                                                                                                                            | TR_WAIT                                   | RC_IERR                      | RC_SOF               | RC_BYTE_ERR           | RC_CRC            |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                 | 0                                         | 0                            | 0                    | 0                     | 0                 |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                 | R                                                                                                                                                                                                                                                                                                 | R                                         | R                            | R                    | R                     | R                 |  |  |  |
| TR_SOF          | Indicates that a UART COMM CLEAR is received while the device is still transmitting data to host.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                   |                                           |                              |                      |                       |                   |  |  |  |
| TR_WAIT         | The device is waiting for its turn to transfer a response out but the action is terminated because: 1. the device receives a UART COMM CLEAR signal, or 2. the device receives a new command This bit is valid when broadcast or stack read command has been issued.<br>0: No fault<br>1: Fault                                                                                                                   |                                                                                                                                                                                                                                                                                                   |                                           |                              |                      |                       |                   |  |  |  |
| RC_IERR         | Detects initialization byte error in the received command frame. Example: • a STOP error is detected, • reserved command bits in the "INIT byte" is set, • expected a "INIT byte', but it is configured as response frame instead (e.g. 1st byte received after COMM CLEAR signal should but a "INIT byte") All bytes that follow are ignored until a communication CLEAR is received.<br>0: No fault<br>1: Fault |                                                                                                                                                                                                                                                                                                   |                                           |                              |                      |                       |                   |  |  |  |
| RC_SOF          | Detects a start-of-fr<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                  | ame (SOF) error. Mo                                                                                                                                                                                                                                                                               | ostly, this is UART C                     | OMM CLEAR is rece            | eived on the UART b  | efore the current fra | me is finished.   |  |  |  |
| RC_BYTE_ERR     | Other than INIT byt<br>doesn't forward con<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                             | Other than INIT byte, if STOP error is detected in rest of byte in the frame or TX receives data while RX is using. CRC is not calculated and doesn't forward communication in daisy chain. All bytes that follow are ignored until a communication CLEAR is received.<br>0: No fault<br>1: Fault |                                           |                              |                      |                       |                   |  |  |  |
| RC_CRC          | Detects CRC error<br>only if no physical le<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                            | in the received comr<br>evel error, IERR, BE                                                                                                                                                                                                                                                      | nand frame from UA<br>RR, SOF error detec | RT. The frame will b<br>sted | e considered as disc | carded frame. Frame   | CRC is calculated |  |  |  |



# 7.5.38 Register: DEBUG\_COMH\_PHY

| Address: 0x230 | 4                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                              |                              |                        |                        |                      |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------|------------------------|------------------------|----------------------|--|--|--|--|--|
| B7             | B6                                                                                                              | B5                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | B4                                           | B3                           | B2                     | B1                     | B0                   |  |  |  |  |  |
|                | RSVD                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PERR                                         | BERR_TAG                     | SYNC2                  | SYNC1                  | BIT                  |  |  |  |  |  |
| 0              | 0                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                            | 0                            | 0                      | 0                      | 0                    |  |  |  |  |  |
| R              | R                                                                                                               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R                                            | R                            | R                      | R                      | R                    |  |  |  |  |  |
| PERR           | Pertain to received<br>will also set the [PE<br>of data or wrong da<br>0: no comm error d<br>1: detected abnorm | Pertain to received response frame from stack device only. PERR is a lump bit of all physical errors. Any error bit that is set in this register will also set the [PERR] bit. However, abnormality that isn't classified in the register can also trigger the [PERR] bit (e.g. detecting missing of data or wrong data order.)<br>0: no comm error detected<br>1: detected abnormality of the received comm frame. BERR is asserted to the forwarded communication. |                                              |                              |                        |                        |                      |  |  |  |  |  |
| BERR_TAG       | Indicates BERR bit<br>0: received respons<br>1: received respons                                                | Indicates BERR bit is set in at least one byte in received response frame from stack device<br>0: received response frame doesn't have BERR<br>1: received response frame has BERR                                                                                                                                                                                                                                                                                   |                                              |                              |                        |                        |                      |  |  |  |  |  |
| SYNC2          | Timing information<br>expected window, t<br>0: No fault<br>1: Fault                                             | extracted from the d<br>his bit is set and the                                                                                                                                                                                                                                                                                                                                                                                                                       | emodulation of the p<br>byte is not processe | oreamble half-bit and<br>ed. | the two full bits of s | ynchronization is out  | side of the          |  |  |  |  |  |
| SYNC1          | If the demodulation<br>bit is set and the by<br>0: No fault<br>1: Fault                                         | of the preamble hal<br>te is not processed.                                                                                                                                                                                                                                                                                                                                                                                                                          | f-bit and the two full                       | bits of synchronizati        | on data have errors a  | and the timing is like | ly not correct, this |  |  |  |  |  |
| BIT            | The device has det<br>0: No fault<br>1: Fault                                                                   | ected a data bit, hov                                                                                                                                                                                                                                                                                                                                                                                                                                                | vever, the detection                         | samples is not enou          | gh to guarantee a str  | rong '1' or '0'.       |                      |  |  |  |  |  |

# 7.5.39 Register: DEBUG\_COMH\_FRAME

| Address: 0x2305 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                      |                     |                      |                        |          |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------|---------------------|----------------------|------------------------|----------|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | B5                    | B4                   | B3                  | B2                   | B1                     | B0       |  |  |  |
|                 | RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | RR_IERR              | RR_SOF              | RR_BYTE_ERR          | RR_UNEXP               | RR_CRC   |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                     | 0                    | 0                   | 0                    | 0                      | 0        |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R                     | R                    | R                   | R                    | R                      | R        |  |  |  |
| RR_IERR         | Detects initialization byte error in the received response frame. This may due to improper formatting of a byte such as a frame initialization byte is expected, but start-of-frame (SOF) bit is not set, or an invalid frame type is selected. All bytes from VIF that follows are ignored until a SOF bit is received (BQ79600 still forwards data from VIF to UART/SPI).<br>0: No fault<br>1: Fault                                                                           |                       |                      |                     |                      |                        |          |  |  |  |
| RR_SOF          | Valid when [DIR_SEL] = 0. Detects a start-of-frame (SOF) error on COMH. The SOF bit shall only be set in the initialization frame but the SOF bit is set in the current frame that is not expected.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                   |                       |                      |                     |                      |                        |          |  |  |  |
| RR_BYTE_ERR     | Valid when [DIR_SEL] = 0. Detected any byte errors, other than the error in the initialization byte, in the received response frame. If the byte err is on the last byte of the CRC, it would check CRC in addition to discarding the frame. This error can be triggered by one or more error bit set in the DEBUG_COMH_PHY register. All bytes from VIF that follows are ignored until a SOF bit is received (BQ79600 still forwards data from VIF to UART/SPI).<br>0: No fault |                       |                      |                     |                      |                        |          |  |  |  |
| RR_UNEXP        | lf [DIR_SEL] = 1, bu<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                  | ut device received re | esponse frame from ( | COMH which is an ir | nvalid condition and | device will set this e | ror bit. |  |  |  |
| RR_CRC          | Indicates one or mo<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                   | ore COMH response     | frames being discar  | ded due to CRC erro | or.                  |                        |          |  |  |  |



# 7.5.40 Register: DEBUG\_COML\_PHY

| Address: 0x2306 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |      |          |       |       |     |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|----------|-------|-------|-----|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | B5 | B4   | B3       | B2    | B1    | B0  |  |  |  |
|                 | RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    | PERR | BERR_TAG | SYNC2 | SYNC1 | BIT |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0  | 0    | 0        | 0     | 0     | 0   |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R  | R    | R        | R     | R     | R   |  |  |  |
| PERR            | Pertain to received response frame from stack device only. PERR is a lump bit of all physical errors. Any error bit that is set in this register will also set the [PERR] bit. However, abnormality that isn't classified in the register can also trigger the [PERR] bit (e.g. detecting missing of data or wrong data order.)<br>0: no comm error detected<br>1: detected abnormality of the received comm frame. BERR is asserted to the forwarded communication. |    |      |          |       |       |     |  |  |  |
| BERR_TAG        | Indicates BERR bit is set in at least one byte in received response frame from stack device<br>0: received response frame doesn't have BERR<br>1: received response frame has BERR                                                                                                                                                                                                                                                                                   |    |      |          |       |       |     |  |  |  |
| SYNC2           | Timing information extracted from the demodulation of the preamble half-bit and the two full bits of synchronization is outside of the expected window, this bit is set and the byte is not processed.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                    |    |      |          |       |       |     |  |  |  |
| SYNC1           | If the demodulation of the preamble half-bit and the two full bits of synchronization data have errors and the timing is likely not correct, this bit is set and the byte is not processed.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                               |    |      |          |       |       |     |  |  |  |
| ВІТ             | The device has detected a data bit, however, the detection samples is not enough to guarantee a strong '1' or '0'.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                        |    |      |          |       |       |     |  |  |  |

# 7.5.41 Register: DEBUG\_COML\_FRAME

| Address: 0x2307 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                      |                     |                       |                         |          |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------|---------------------|-----------------------|-------------------------|----------|--|--|--|
| B7              | B6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | B5                    | B4                   | B3                  | B2                    | B1                      | B0       |  |  |  |
|                 | RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | RR_IERR              | RR_SOF              | RR_BYTE_ERR           | RR_UNEXP                | RR_CRC   |  |  |  |
| 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                     | 0                    | 0                   | 0                     | 0                       | 0        |  |  |  |
| R               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R                     | R                    | R                   | R                     | R                       | R        |  |  |  |
| RR_IERR         | Detects initialization byte error in the received response frame. This may due to improper formatting of a byte such as a frame initialization<br>byte is expected, but start-of-frame (SOF) bit is not set, or an invalid frame type is selected. All bytes from VIF that follows are ignored until<br>a SOF bit is received (BQ79600 still forwards data from VIF to UART/SPI).<br>0: No fault<br>1: Fault                                                                                 |                       |                      |                     |                       |                         |          |  |  |  |
| RR_SOF          | Valid when [DIR_SEL] = 1. Detects a start-of-frame (SOF) error on COML. The SOF bit shall only be set in the initialization frame but the SOF bit is set in the current frame that is not expected.<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                               |                       |                      |                     |                       |                         |          |  |  |  |
| RR_BYTE_ERR     | Valid when [DIR_SEL] = 1. Detected any byte errors, other than the error in the initialization byte, in the received response frame. If the byte err is on the last byte of the CRC, it would check CRC in addition to discarding the frame. This error can be triggered by one or more error bit set in the DEBUG_COML_PHY register. All bytes from VIF that follows are ignored until a SOF bit is received (BQ79600 still forwards data from VIF to UART/SPI).<br>0: No fault<br>1: Fault |                       |                      |                     |                       |                         |          |  |  |  |
| RR_UNEXP        | If [DIR_SEL] = 0, bu<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                              | ut device received re | esponse frame from ( | COML which is an ir | valid condition and o | device will set this er | ror bit. |  |  |  |
| RR_CRC          | Indicates one or mo<br>0: No fault<br>1: Fault                                                                                                                                                                                                                                                                                                                                                                                                                                               | ore COML response     | frames being discard | ded due to CRC erro | or.                   |                         |          |  |  |  |



# 8 Application and Implementation

Note

Information in the following applications sections is not part of the TI component specification, and TI does not warrant its accuracy or completeness. TI's customers are responsible for determining suitability of components for their purposes. Customers should validate and test their design implementation to confirm system functionality.

## 8.1 Application Information

This section is concerned with the external operation, what external components are required to add to the device to make it usable in a particular design, and how to calculate the values for those external components.

## 8.2 Typical Applications

## 8.2.1 Bridge With Reverse Wakeup in UART

The following application circuit is used when user chooses to use UART interface and any of those features: reverse wakeup, ring architecture, fault/heartbeat tone.



## Figure 8-1. Typical Bridge with Reverse Wakeup in UART Applications Circuit

#### 8.2.1.1 Design Requirements

Table 8-1 describes the design parameters.

 Table 8-1. Recommended Design Requirement

| ······································ |       |  |  |  |  |  |  |  |
|----------------------------------------|-------|--|--|--|--|--|--|--|
| PARAMETER                              | VALUE |  |  |  |  |  |  |  |
| UART speed                             | 1Mbps |  |  |  |  |  |  |  |

## 8.2.1.2 Detailed Design Procedure

#### 8.2.1.2.1 MCU Interface (UART, NFAULT)

To select UART interface, connect nCS, nUART/SPI and SCLK pins to GND. UART interface includes RX/TX pins. They are pulled up through a 10-100k $\Omega$  resistor to VIO like figure above.

NFAULT pin, if not used, connect to GND. Otherwise, pull it up wtih  $100k\Omega$  to VIO.

#### 8.2.1.2.2 Daisy Chain Interface

Given that galvanic isolation is expected between BQ79600-Q1 and stack BQ devices, transformer isolation is recommended. Section 8.2.1 shows the interface components values.

Contact TI for transformer recommendations.

### 8.2.1.2.3 INH Connection

INH pin is connected to the power management IC (PMIC) enable pin such that when reverse wakeup is triggered, INH would be pulled towards BAT and enable PMIC. INH pin should always be lower than BAT pin. The  $100k\Omega$  connected to INH in Section 8.2.1 is to make sure INH pin potential is defined when INH driver is off.

## 8.2.1.3 Application Performance Plot



Figure 8-2. Command and Response Frame for Read from 2 Stack Devices



BQ79600-Q1 SLUSDS1A – NOVEMBER 2019 – REVISED AUGUST 2020



Figure 8-3. Zoomed View of Response Frame for 8 Registers Read from Stack Devices

## 8.2.2 Bridge Without Reverse Wakeup in SPI

The following application circuit is used when user chooses to use SPI interface and none of those features: reverse wakeup, ring architecture, fault/heartbeat tone.





## 8.2.2.1 Design Requirements

Table 8-2 describes the design parameters.

Table 8-2. Key Requirements

| PARAMETER | VALUE     |  |  |  |  |  |  |  |
|-----------|-----------|--|--|--|--|--|--|--|
| SPI speed | 2 - 6Mbps |  |  |  |  |  |  |  |



## 8.2.2.2 Detailed Design Procedure

#### 8.2.2.2.1 MCU Interface (SPI, SPI\_RDY, NFAULT)

To select SPI interface, connect MOSI, MISO, SCLK, nCS, nUART/SPI as figure above shows. Connect SPI\_RDY to MCU GPIO port for SPI flow control use, Section 7.3.2.1.2.2.1.

NFAULT pin, if not used, connect to GND. Otherwise, pull it up wtih 100K $\Omega$  to VIO.

#### 8.2.2.2.2 Daisy Chain Interface

Refer to Section 8.2.1.2.2.

#### 8.2.2.3 Application Performance Plot

See Application Performance Plot for application performanace curve.



# 9 Power Supply Recommendations

The BQ79600-Q1 can be powered by either directly from 12-V battery (nominal 9 - 16V) or regulated 5-V supply. The design consideration for both options are described in the table below.

|      | 12-V BATTERY (nominal 9 - 16 V)                                                                                                                          | REGULATED 5-V SUPPLY                               |  |  |  |  |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--|--|--|--|--|--|--|
| VIO  | 3.125 - 5.25V, decouple 0.1-µF capacitor to gnd                                                                                                          | 3.125 - 5.25V, decouple 0.1-µF capacitor to gnd    |  |  |  |  |  |  |  |
| BAT  | Put RC between supply battery and BAT pin, R = $10\Omega$ , C = $0.1$ -µF capacitor.<br>Make sure BAT pin sees no less than 5.5V and no larger than 40V. | 4.75 - 5.25V, decouple 0.22-μF<br>capacitor to gnd |  |  |  |  |  |  |  |
| CVDD | Decouple 0.22-µF capacitor to gnd                                                                                                                        | shorted to BAT                                     |  |  |  |  |  |  |  |
| DVDD | Decouple 0.22-µF capacitor to gnd                                                                                                                        | Decouple 0.22-µF capacitor to gnd                  |  |  |  |  |  |  |  |

# Table 9-1 Supply Design Considerations

59



# 10 Layout

The layout for this device must be designed carefully. Any design outside these guidelines can affect the communication robustness and EMI performance. Care must be taken in the layout of signals to and from the device to avoid coupling noise onto sensitive inputs. The layout of ground and power connections, as well as communication signals, should also be made carefully.

## **10.1 Layout Guidelines**

## 10.1.1 Ground Planes

It is very important to establish a clean grounding scheme to ensure best performance of the device. There is one ground pin (GND) on the device. It is a good practice to use top and bottom PCB layers for signal routing, and use middle layers as ground planes. Even on a PCB layer that is mainly for signal routing, it is good practice to have a small island of ground pour if possible to provide a low-impedance ground, rather than simply a via through the ground trace to an lower ground plane. Create a keep-out area (no other traces and no ground plane) around the daisy chain components in all PCB layers.

There is a strong recommendation to have a minimum of 4 layers in the PCB, with one fully dedicated layer as an unbroken VSS plane (except thermal reliefs). Avoid placing tracks on this layer to maintain the unbroken integrity of the plane structure.

## 10.1.2 Bypass Capacitors for Power Supplies

The bypass capacitors of the following pins must be placed as close to the device pins as possible to ensure proper performance.

• BAT, VIO, CVDD, DVDD

## 10.1.3 UART/SPI communication

The UART/SPI interface (MISO/TX, MOSI/RX, SCLK, nCS, nUART/SPI\_RDY) between MCU and BQ79600-Q1 shall be kept as short and straight as possible for optimized EMC performance.

## **10.1.4 Daisy Chain Communication**

It is important to have proper layout on the COMHP/N and COMLP/N circuits in order to have the best robust daisy chain communication.

- Keep differential traces as short as possible and as straight as possible. Minimize turns and avoid any looping on the traces.
- Keep the differential traces on the same layers. Run the trace in parallel with shielding and matching trace impedance.
- Place the isolation components close to the connectors.
- Create a keep-out area (no other traces and no ground plane) around the daisy chain components in all PCB layers.

## 10.2 Layout Example

This section presents the BQ79600-Q1 Evaluation Module (EVM) design as a layout example. Given the EVM doesn't have an MCU, the example of UART/SPI connection layout is not optimized.



BQ79600-Q1 SLUSDS1A – NOVEMBER 2019 – REVISED AUGUST 2020



Figure 10-1. Top Layer Layout



Figure 10-2. Signal 1 Layer Layout





Figure 10-3. Signal 2 Layer Layout



Figure 10-4. Bottom Layer Layout



# 11 Device and Documentation Support

### **11.1 Device Support**

## **11.2 Third-Party Products Disclaimer**

TI'S PUBLICATION OF INFORMATION REGARDING THIRD-PARTY PRODUCTS OR SERVICES DOES NOT CONSTITUTE AN ENDORSEMENT REGARDING THE SUITABILITY OF SUCH PRODUCTS OR SERVICES OR A WARRANTY, REPRESENTATION OR ENDORSEMENT OF SUCH PRODUCTS OR SERVICES, EITHER ALONE OR IN COMBINATION WITH ANY TI PRODUCT OR SERVICE.

## **11.3 Receiving Notification of Documentation Updates**

To receive notification of documentation updates, navigate to the device product folder on ti.com. Click on *Subscribe to updates* to register and receive a weekly digest of any product information that has changed. For change details, review the revision history included in any revised document.

#### **11.4 Support Resources**

TI E2E<sup>™</sup> support forums are an engineer's go-to source for fast, verified answers and design help — straight from the experts. Search existing answers or ask your own question to get the quick design help you need.

Linked content is provided "AS IS" by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI's views; see TI's Terms of Use.

#### 11.5 Trademarks

TI E2E<sup>™</sup> is a trademark of Texas Instruments.

All other trademarks are the property of their respective owners.

## **11.6 Electrostatic Discharge Caution**



This integrated circuit can be damaged by ESD. Texas Instruments recommends that all integrated circuits be handled with appropriate precautions. Failure to observe proper handling and installation procedures can cause damage.

ESD damage can range from subtle performance degradation to complete device failure. Precision integrated circuits may be more susceptible to damage because very small parametric changes could cause the device not to meet its published specifications.

## 11.7 Glossary

**TI Glossary** This glossary lists and explains terms, acronyms, and definitions.



# 12 Mechanical, Packaging, and Orderable Information

The following pages include mechanical, packaging, and orderable information. This information is the most current data available for the designated devices. This data is subject to change without notice and revision of this document. For browser-based versions of this data sheet, refer to the left-hand navigation.



10-Dec-2020

# PACKAGING INFORMATION

| Orderable Device | Status<br>(1) | Package Type | Package<br>Drawing | Pins | Package<br>Qty | Eco Plan<br>(2) | Lead finish/<br>Ball material<br>(6) | MSL Peak Temp<br>(3) | Op Temp (°C) | Device Marking<br>(4/5) | Samples |
|------------------|---------------|--------------|--------------------|------|----------------|-----------------|--------------------------------------|----------------------|--------------|-------------------------|---------|
| BQ79600PWRQ1     | ACTIVE        | TSSOP        | PW                 | 16   | 2000           | RoHS & Green    | NIPDAU                               | Level-2-260C-1 YEAR  | -40 to 125   | BQ79600                 | Samples |

<sup>(1)</sup> The marketing status values are defined as follows:

ACTIVE: Product device recommended for new designs.

LIFEBUY: TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.

NRND: Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.

PREVIEW: Device has been announced but is not in production. Samples may or may not be available.

**OBSOLETE:** TI has discontinued the production of the device.

<sup>(2)</sup> RoHS: TI defines "RoHS" to mean semiconductor products that are compliant with the current EU RoHS requirements for all 10 RoHS substances, including the requirement that RoHS substance do not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, "RoHS" products are suitable for use in specified lead-free processes. TI may reference these types of products as "Pb-Free".

**RoHS Exempt:** TI defines "RoHS Exempt" to mean products that contain lead but are compliant with EU RoHS pursuant to a specific EU RoHS exemption.

Green: TI defines "Green" to mean the content of Chlorine (CI) and Bromine (Br) based flame retardants meet JS709B low halogen requirements of <= 1000ppm threshold. Antimony trioxide based flame retardants must also meet the <= 1000ppm threshold requirement.

<sup>(3)</sup> MSL, Peak Temp. - The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.

<sup>(4)</sup> There may be additional marking, which relates to the logo, the lot trace code information, or the environmental category on the device.

<sup>(5)</sup> Multiple Device Markings will be inside parentheses. Only one Device Marking contained in parentheses and separated by a "~" will appear on a device. If a line is indented then it is a continuation of the previous line and the two combined represent the entire Device Marking for that device.

(<sup>6)</sup> Lead finish/Ball material - Orderable Devices may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead finish/Ball material values may wrap to two lines if the finish value exceeds the maximum column width.

Important Information and Disclaimer: The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.



www.ti.com

# TAPE AND REEL INFORMATION





#### QUADRANT ASSIGNMENTS FOR PIN 1 ORIENTATION IN TAPE



| *All dimensions are nominal |  |
|-----------------------------|--|
|                             |  |

| Device       | Package<br>Type | Package<br>Drawing | Pins | SPQ  | Reel<br>Diameter<br>(mm) | Reel<br>Width<br>W1 (mm) | A0<br>(mm) | B0<br>(mm) | K0<br>(mm) | P1<br>(mm) | W<br>(mm) | Pin1<br>Quadrant |
|--------------|-----------------|--------------------|------|------|--------------------------|--------------------------|------------|------------|------------|------------|-----------|------------------|
| BQ79600PWRQ1 | TSSOP           | PW                 | 16   | 2000 | 330.0                    | 12.4                     | 6.9        | 5.6        | 1.6        | 8.0        | 12.0      | Q1               |



www.ti.com

# PACKAGE MATERIALS INFORMATION

3-Jun-2022



\*All dimensions are nominal

| Device       | Package Type | Package Drawing | Pins | SPQ  | Length (mm) | Width (mm) | Height (mm) |
|--------------|--------------|-----------------|------|------|-------------|------------|-------------|
| BQ79600PWRQ1 | TSSOP        | PW              | 16   | 2000 | 356.0       | 356.0      | 35.0        |

# **PW0016A**



# **PACKAGE OUTLINE**

# TSSOP - 1.2 mm max height

SMALL OUTLINE PACKAGE



NOTES:

- 1. All linear dimensions are in millimeters. Any dimensions in parenthesis are for reference only. Dimensioning and tolerancing per ASME Y14.5M. 2. This drawing is subject to change without notice. 3. This dimension does not include mold flash, protrusions, or gate burrs. Mold flash, protrusions, or gate burrs shall not
- exceed 0.15 mm per side.
- 4. This dimension does not include interlead flash. Interlead flash shall not exceed 0.25 mm per side.
- 5. Reference JEDEC registration MO-153.



# PW0016A

# **EXAMPLE BOARD LAYOUT**

# TSSOP - 1.2 mm max height

SMALL OUTLINE PACKAGE



NOTES: (continued)

6. Publication IPC-7351 may have alternate designs.

7. Solder mask tolerances between and around signal pads can vary based on board fabrication site.



# PW0016A

# **EXAMPLE STENCIL DESIGN**

# TSSOP - 1.2 mm max height

SMALL OUTLINE PACKAGE



NOTES: (continued)

9. Board assembly site may have different recommendations for stencil design.



<sup>8.</sup> Laser cutting apertures with trapezoidal walls and rounded corners may offer better paste release. IPC-7525 may have alternate design recommendations.

# IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements.

These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

TI objects to and rejects any additional or different terms you may have proposed.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2022, Texas Instruments Incorporated