7-Cell to 16-Cell Battery Monitor and Protector ## DESCRIPTION The MP2796 is a robust battery management device, providing a complete analog front-end (AFE) monitoring and protection solution. It is designed for multiple-cell series battery management systems (BMS). The device can support I<sup>2</sup>C or SPI communication. It supports connections for 7-cell to 16-cell series battery packs, with an absolute voltage exceeding 80V on particular pins. The MP2796 integrates two separate analog-todigital converters (ADCs). The first ADC measures each channel's differential cell voltages (up to 16 channels), die temperature, and 4-channel temperatures via external NTC thermistors. The second ADC measures the charge/discharge current via an external currentsense resistor. When paired with an MPF4279x fuel gauge, the MP2796 can achieve a state-of-charge (SOC) error to within 2%. The MP2796 includes high-side MOSFET (HSFET) drivers for charge and discharge control. The discharge (DSG) MOSFET driver includes a configurable soft start (SS) that provides a controlled turn-on, eliminating the need for an external pre-charge circuit. The MOSFET drivers also incorporate over-current protection (OCP), short-circuit protection (SCP), battery undervoltage protection (UVP), battery over-voltage protection (OVP), and high-/low-temperature protection. All of these protections have configurable thresholds. Internal passive balancing MOSFETs can be used to equalize mismatched cells, supporting up to 58mA. There is also the option to drive external balancing transistors (MOSFET or BJT). The MP2796 is available in a TQFP-48 (7mmx7mm) package. 5/9/2023 ### **FEATURES** - Incorporates Dual Analog-to-Digital Converter (ADC) Architecture: - <±2% State-of-Charge (SOC) Error with MPF4279x Fuel Gauge - Cell Voltage Measurement Error <10mV</li> - Current Error <±0.5%</li> - Includes High-Side N-Channel MOSFET Drivers for Charge and Discharge Control: - Supports MOSFET Soft-Start Discharge Control to Eliminate Pre-Charge Circuit - Drives Up to 100A DC with Parallel N-Channel MOSFETs - Hardware Configurable Protections: - Charge/Discharge OCP and SCP - Cell UVP and OVP - Pack UVP and OVP - o Cell Low-/High-Temperature Protection - o Die High-Temperature Protection - Passive Cell Balancing up to 58mA per Cell: - Can Drive External Balancing Transistors - Automatic or Manual Control - Additional Features: - Integrated 3.3V and 5V LDOs - Reduced Current Standby Mode - High-Voltage and Low-Voltage GPIOs - Dedicated Thermistor Inputs - Open-Wire Detection - Persistent Dead Battery Flag - Lockable Multiple-Time Programmable (MTP) Memory for Key Thresholds - I<sup>2</sup>C or SPI Interface with 8-Bit CRC - Random Cell Connection Tolerant - Available in a TQFP-48 (7mmx7mm) Package #### **APPLICATIONS** - E-Bikes, E-Scooters - Battery Backup and UPSs - Power and Gardening Tools - Energy Storage Systems (ESSs) All MPS parts are lead-free, halogen-free, and adhere to the RoHS directive. For MPS green status, please visit the MPS website under Quality Assurance. "MPS", the MPS logo, and "Simple, Easy Solutions" are trademarks of Monolithic Power Systems, Inc. or its subsidiaries. # **TYPICAL APPLICATION** ## ORDERING INFORMATION | Part Number* | Package | rage Top Marking MSL Rating | | Communication | | |------------------|-------------------|-----------------------------|-----|--------------------------------|--| | MP2796DFP-xxxx** | TQFP-48 (7mmx7mm) | See Below | 3 | | | | MP2796DFP-0000 | TQFP-48 (7mmx7mm) | See Below | 3 | I <sup>2</sup> C, CRC disabled | | | MP2796DFP-0001 | TQFP-48 (7mmx7mm) | See Below | 3 | I <sup>2</sup> C, CRC enabled | | | MP2796DFP-0002 | TQFP-48 (7mmx7mm) | See Below | 3 | SPI, CRC disabled | | | EVKT-MP2796-0000 | Evaluation kit | N/A | N/A | N/A | | | EVKT-MP2796-0002 | Evaluation kit | N/A | N/A | N/A | | <sup>\*</sup> For Tray, add suffix -T (e.g. MP2796DFP-xxxx-T). # **TOP MARKING (MP2796)** # M<u>PSYYWW</u> MP2796 LLLLLLLLL MPS: MPS prefix YY: Year code WW: Week code MP: MPS prefix 2796: Part number LLLLLLLL: Lot number <sup>\*\* &</sup>quot;-xxxx" is the configuration code identifier for the register settings. Each "x" can be a hexadecimal value between 0 and F. The default codes are "0000", "0001", and "0002". Contact an MPS FAE to create this unique number. ### **EVALUATION KIT EVKT-MP2796-0000** EVKT-MP2796-0000 kit contents (items below can be ordered separately): | # | Part Number | Item | Quantity | |---|--------------------|---------------------------------------------------------------------------------------------------|----------| | 1 | EV2796-0000-FP-00A | MP2796DFP-0000 I <sup>2</sup> C evaluation board | 1 | | 2 | EVKT-USBI2C-02 | Includes one USB-to-I <sup>2</sup> C communication interface, one USB cable, and one ribbon cable | 1 | | 3 | Online resources | Include datasheet, user guide, product brief, and GUI | 1 | ## Order directly from MonolithicPower.com or our distributors. Figure 1: EV2796-0000-FP-00A Evaluation Kit Set-Up ### **EVALUATION KIT EVKT-MP2796-0002** EVKT-MP2796-0002 kit contents (items below can be ordered separately): | # | Part Number | Item | Quantity | |---|--------------------|--------------------------------------------------------------------------------------|----------| | 1 | EV2796-0002-FP-00A | MP2796DFP-0002 SPI evaluation board | 1 | | 2 | EVKT-USBSPI-00 | Includes one USB-to-SPI communication interface, one USB cable, and one ribbon cable | 1 | | 3 | Online resources | Include datasheet, user guide, product brief, and GUI | 1 | ## Order directly from MonolithicPower.com or our distributors. Figure 2: EV2796-0002-FP-00A Evaluation Kit Set-Up # **PACKAGE REFERENCE** # **PIN FUNCTIONS** | Pin# | Name | Type | Description | |------|---------|----------|------------------------------------------------------------------------------| | 00 | 2) /2 | Р | 3.3V voltage output to drive external peripherals. Bypass 3V3 with an | | 26 | 3V3 | Р | external 1µF capacitor. | | 22 | ACND | Р | Ground. Connect AGND near the positive connection (SRP) of the low-side | | 23 | AGND | Р | sense resistor. | | | | | Battery-side pack-sensing voltage and low-current positive supply pin. | | 45 | VTOP | Р | VTOP must be connected to the top of the battery stack, which is the highest | | | | | positive voltage in the battery pack. | | 46 | C16 | I | Connect to the positive pin of cell 16. | | 47 | C15 | I | Connect to the positive pin of cell 15. | | 48 | C14 | I | Connect to the positive pin of cell 14. | | 1 | C13 | I | Connect to the positive pin of cell 13. | | 2 | C12 | ı | Connect to the positive pin of cell 12. | | 3 | C11 | ı | Connect to the positive pin of cell 11. | | 4 | C10 | ı | Connect to the positive pin of cell 10. | | 5 | C9 | ı | Connect to the positive pin of cell 9. | | 6 | C8 | ı | Connect to the positive pin of cell 8. | | 7 | C7 | İ | Connect to the positive pin of cell 7. | | 8 | C6 | i | Connect to the positive pin of cell 6. | | 9 | C5 | i | Connect to the positive pin of cell 5. | | 10 | C4 | i | Connect to the positive pin of cell 4. | | 11 | C3 | i | Connect to the positive pin of cell 3. | | 12 | C2 | i | Connect to the positive pin of cell 2. | | 13 | C1 | i | Connect to the positive pin of cell 1. | | 14 | C0 | i | Connect to the negative pin of cell 1. | | 44 | CHG | 0 | Charge MOSFET driver. | | 39 | DSG | 0 | Discharge MOSFET driver. | | 36 | GPIO1 | I/O | General-purpose pin 1. | | 35 | GPIO2 | I/O | General-purpose pin 2. | | 37 | N/C | 1/0 | Not connected. | | 30 | NSHDN | 1 | Active-low shutdown input signal. | | 20 | NTC1 | l<br>I | Thermistor 1 terminal. | | 19 | NTC2 | ı | Thermistor 2 terminal. | | 18 | NTC3 | ı | Thermistor 2 terminal. | | 17 | NTC3 | l<br>I | Thermistor 3 terminal. | | 21 | NTCB | 0 | NTC bias. | | 40 | N/C | 0 | Not connected. | | 38 | PACKP | I/O | | | | | | Pack sensing voltage (load side). | | 24 | REGCTRL | Р | Turn-on control for the external BJT low-dropout (LDO) regulator. | | 25 | REGIN | Р | Internal regulator input. Connect an external 3.3µF bypass capacitor from | | 4.4 | CDVDCC | | REGIN to AGND. | | 41 | SBYDSG | 0 | Discharge bypass P-channel MOSFET driver. | | 29 | WDT | I/O | Watchdog timer pin. | | 28 | xALERT | 0 | Interrupt alert output. | | 16 | SRN | <u> </u> | Negative sense pin. | | 15 | SRP | l | Positive sense pin. | | 40 | 1/05 | _ | Charge pump regulated voltage. Connect a 47nF capacitor from VCP to | | 42 | VCP | Р | VMID, then adjust the value based on the number of parallel DSG and CHG | | | | | MOSFETs. | | 27 | VDD | Р | 1.8V rail for internal use. Connect a 1µF bypass capacitor from VDD to | | | | | AGND. | | 43 | VMID | Р | Protection MOSFET middle point. | # PIN FUNCTIONS (continued) | Pin # | Name | Type | Description | |-------|-----------|------|---------------------------------------------------------------------------------------------------------------------| | 22 | VREF | Р | Analog-to-digital converter (ADC) reference voltage. | | 34 | GPIO3/nCS | I/O | <b>Multi-function pin.</b> This pin can be set as GPIO3, or it can be set for SPI cable selection. | | 31 | SCL/SCK | I | <b>Multi-function pin.</b> This pin can be set as the I <sup>2</sup> C interface clock or the SPI interface clock. | | 32 | SDA/SDI | I/O | <b>Multi-function pin.</b> This pin can be set as the I <sup>2</sup> C interface data or the SPI serial data input. | | 33 | SDO | 0 | SPI serial data output. | # **ABSOLUTE MAXIMUM RATINGS** (1) | CHG, DSG, VCP to AGND SBYDSG to AGND VTOP to AGND PACKP to AGND VMID to AGND Cx - C(x - 1) (x: 1 to 16) C16 to AGND Cx to AGND (x: 1 to 15) | 0.3V to +86V<br>0.3V to +86V<br>0.5V to +86V<br>0.3V to +86V<br>0.3V to +10V<br>0.3V to +86V | |---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | C0 to AGND | -0.5V to +5.7V | | VCP to VMID | 0.3V to +20V | | REGCTRL to AGND | | | NSHDN to AGND | | | VDD to AGND | | | All other pins to AGND | | | Junction temperature | | | Lead temperature | | | Storage temperature | - 65°C to +150°C | ## ESD Ratings | Human body model (HE | 3M) <sup>(2)</sup> . | | 1.5kV | |------------------------|----------------------|------------------|-------| | Charged device model ( | (CDM) | ) <sup>(3)</sup> | 500V | # Recommended Operating Conditions (4) | VTOP voltage | 18V to 75.2V | |-----------------------------------------------|-----------------| | $Cx - C(x - 1) (x: 1 \text{ to } 16)^{(5)}$ . | | | C0 to AGND | | | REGIN voltage | 4.5V to 5.5V | | Operating temperature (T <sub>J</sub> ) | 40°C to +85°C | | SRP to SRN | 100mV to +100mV | ### Thermal Resistance (6) | Junction-to-ambient (R <sub>0JA</sub> ) | 46.6°C/W | |--------------------------------------------------|----------| | Junction-to-case (top) (R <sub>0JC(TOP)</sub> ) | 14.5°C/W | | Junction-to-board (top) (R <sub>0JB(TOP)</sub> ) | 27.1°C/W | #### Notes: - 1) Exceeding these ratings may damage the device. - 2) Tested per ANSI/ESDA/JEDEC JS-001. - 3) Tested per ANSI/ESDA/JEDEC JS-002. - The device is not guaranteed to function outside of its operating conditions. - 5) The stack voltage should exceed 18V. - Metrics provided using set-up conditions compliant with EIA/JESD51-2, 7, and 8. # **ELECTRICAL CHARACTERISTICS** Connected cells = 16, each cell voltage = 3.75V, $V_{TOP}$ = 60V, $T_A$ = 25°C, unless otherwise noted. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |-----------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------| | Supply Current and Leak | age | | | | | | | | | VTOP + REGIN current, NSHDN pin low, 3.3V off, T <sub>A</sub> = 25°C | | 1 | | μA | | Total shutdown current | IVTOP SHDN | VTOP + REGIN current, NSHDN pin<br>low, 3.3V off,<br>T <sub>A</sub> = -40°C to +85°C | | | 2.5 | μA | | Total Shutdown Current | IVTOP_SHDN | VTOP + REGIN current, 3.3V on, NSHDN pin low, T <sub>A</sub> = 25°C | | 13.5 | | μA | | | | VTOP + REGIN current, 3.3V on, NSHDN pin low, $T_A = -40$ °C to +85°C | | | 20 | μΑ | | | | VTOP + REGIN current, communication interface enabled, safe state (all MOSFETs off), hardware monitoring off, $T_A = 25$ °C | | 23 | | μA | | Total safe state current | Ivtop_safe | VTOP + REGIN current, communication interface enabled, safe state (all MOSFETs off), hardware monitoring off, T <sub>A</sub> = -40°C to +85°C | | | 30 | μА | | Call lookage | 1 | T <sub>A</sub> = 25°C | -200 | | +200 | nA | | Cell leakage | ICx_LEAK | $T_A = -40$ °C to +85°C | -600 | | +600 | nA | | Supported Series Cells | | | | | | | | Supported cell number (7) | Ncell | | 7 | | 16 | | | VTOP supply voltage range | VVTOP_SUPPLY | $T_A = -40$ °C to +85°C | 18 | | 75.2 | V | | VTOP under-voltage lockout (UVLO) threshold | Vvtop_uvlo | Falling edge, T <sub>A</sub> = -40°C to +85°C | 14.6 | 15.8 | 17 | V | | VTOP under-voltage | VVTOP_UVLO_ | T <sub>A</sub> = 25°C | | 1.15 | | V | | (UV) hysteresis | HYST | $T_A = -40$ °C to +85°C | 0.78 | | 1.5 | V | | Current Sense | T | | | | ı | ı | | Current analog-to-digital converter (ADC) conversion time | tiadc | 16 bits (15 bits + sign) | | 2 | | ms | | Current ADC measurement range | Vsrpn | $T_A = -40$ °C to +85°C | -100 | | +100 | mV | | | | 16-bit conversion, FSR = 100mV, SRP-N common mode: $+300$ mV to $-125$ mV from GND, $T_A = 25$ °C | -0.5 | | +0.5 | % | | Current ADC measurement gain error | I <sub>ADC_GAIN_ERR</sub> | 16-bit conversion, FSR = 100mV, SRP-N common mode: $+300$ mV to $-125$ mV from GND, $T_A = -40$ °C to $85$ °C | -1 | | +1 | % | #### Note: 7) Guaranteed by design. Connected cells = 16, each cell voltage = 3.75V, $V_{TOP}$ = 60V, $T_A$ = 25°C, unless otherwise noted. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |-------------------------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------|-----|-------|-------| | Current-sense offset (8) | VIADC_ACC_<br>OFFSET | SRP - SRN = 0V, SRP-N common mode: $+300$ mV to $-125$ mV from GND, $T_A = -40$ °C to $+85$ °C | -12 | - | +12 | μV | | SRP and SRN leakage | I <sub>SRPN_LEAK</sub> | IADC not running, T <sub>A</sub> = -40°C to +85°C | -500 | | +500 | nA | | SRP and SRN | I | IADC running, $ SPR - SRN = 100$ mV, absolute value, $T_A = -40$ °C to $+85$ °C | | 0.5 | | μA | | differential input<br>current | SRPN_DIFF | IADC running, SPR - SRN < 5mV,<br>T <sub>A</sub> = -40°C to +85°C | | 50 | | nA | | ADC Sigma Delta Volta | age | | | | | | | Voltage ADC conversion time | tvadc | 15 bits, T <sub>A</sub> = 25°C | | 2 | | ms | | Cell Voltage Measurer | nent | | | | | | | Cell ADC measurement range | $V_{CELL}$ | $T_A = -40$ °C to +85°C | 1 | | 5 | V | | | | V <sub>CELL</sub> = 2V to 4.5V, T <sub>A</sub> = 25°C | -10 | | +10 | mV | | Total cell | Vcell_err | $V_{CELL} = 2V \text{ to } 4.5V,$<br>$T_A = -20^{\circ}\text{C to } +65^{\circ}\text{C}$ | -12.5 | | +12.5 | mV | | measurement error | | $V_{CELL} = 2V \text{ to } 4.5V,$<br>$T_A = -40^{\circ}\text{C to } +85^{\circ}\text{C}$ | -17.5 | | +17.5 | mV | | | | V <sub>CELL</sub> = 1V to 5V, T <sub>A</sub> = -40°C to +85°C | -20 | | +20 | mV | | C0 to AGND voltage | Vco_to_agnd | C0 to AGND voltage drop resulting in less than 15mV error on cell 1, T <sub>A</sub> = -40°C to +85°C | -0.25 | | | V | | Cell ADC input current | In_cell_conv | Input current during ADC conversion when V <sub>CELL</sub> = 5V, T <sub>A</sub> = 25°C, cell 1 is measured by the C1 to C0 voltage | | 1.2 | | μA | | Die Temperature | | | | | | | | Die temperature operating range | T <sub>DIE</sub> | | -40 | | +85 | °C | | Over-temperature (OT) analog shutdown threshold | $T_{DIE\_OTSD}$ | | | 140 | 155 | °C | | Negative Temperature | Coefficient ( | NTC) Temperature Measurement | | | | | | NTC voltage measurement range | Vntc | Nominal NTC range within a percentage of NTCB, T <sub>A</sub> = 25°C | 0 | | 100 | % | | NTC total measurement error | V <sub>NTC_ERR</sub> | 15-bit conversion, NTCB = 3.3V,<br>T <sub>A</sub> = -40°C to 85°C | -55 | | +55 | LSB | #### Note: <sup>8)</sup> Guaranteed by design. Cell current measurement offset error is specified after calibration. Contact an MPS FAE for the related application note. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | | |---------------------------------------|------------------------|-------------------------------------------------------------------------------|-------|------|-------|-------|--| | NTCx input leakage | Intc_in_leak | ADC off, on each NTC pin,<br>T <sub>A</sub> = -40°C to +85°C | | | 250 | nA | | | NTCx input leakage<br>ADC on | INTC_LEAK_CONV | ADC converting NTCx, on each NTC pin, T <sub>A</sub> = 25°C | | | 250 | nA | | | VTOP Measurement | TOP Measurement | | | | | | | | VTOP measurement range | V <sub>VTOP</sub> | $T_A = -40$ °C to +85°C | 18 | | 75.2 | V | | | VTOP total measurement error | V <sub>V</sub> TOP_ERR | 15-bit conversion (positive range),<br>T <sub>A</sub> = -40°C to +85°C | -250 | | +250 | mV | | | PACKP Measurement | | | | | | | | | Pack measurement range | VPACKP | $T_A = -40$ °C to +85°C | 2.5 | | 75.2 | ٧ | | | Pack total measurement error | V <sub>PACKP_ERR</sub> | 15-bit conversion (positive range),<br>T <sub>A</sub> = -40°C to +85°C | -250 | | +250 | mV | | | <b>GPIO Measurement</b> | | | | | | | | | GPIO measurement range | $V_{\text{GPIO}}$ | T <sub>A</sub> = 25°C | 0 | | 3.3 | V | | | CDIO total | | 15-bit ADC reading, T <sub>A</sub> = 25°C | -15 | | +15 | mV | | | GPIO total measurement error | V <sub>GPIO_ERR</sub> | 15-bit ADC reading,<br>T <sub>A</sub> = -40°C to +85°C | -25 | | +25 | mV | | | GPIO input current during ADC reading | IGPIO_CONV_IN | GPIO pins input current during ADC conversion, T <sub>A</sub> = -40°C to 85°C | | 1 | | μA | | | Regulators Measureme | ents | | | | | | | | DECIN magazirament | | 15-bit ADC reading, T <sub>A</sub> = 25°C | -15 | | +15 | mV | | | REGIN measurement error | Vregin_err | 15-bit ADC reading,<br>T <sub>A</sub> = -40°C to +85°C | -25 | | +25 | mV | | | 3V3 total measurement | | 15-bit ADC reading, T <sub>A</sub> = 25°C | -15 | | +15 | mV | | | error | $V_{3V3\_ERR}$ | 15-bit ADC reading,<br>T <sub>A</sub> = -40°C to +85°C | -25 | | +25 | mV | | | VDD total | | 15-bit ADC reading, T <sub>A</sub> = 25°C | -15 | | +15 | mV | | | VDD total measurement error | $V_{VDD\_ERR}$ | 15-bit ADC reading,<br>T <sub>A</sub> = -40°C to +85°C | -25 | | +25 | mV | | | Hardware Protection | | | | | | | | | Cell over-voltage (OV) and UV steps | VCELL_TH_STEP | | | 19.5 | | mV | | | Call OV/LIV stan | | V <sub>CELL</sub> = 2V to 4.5V, T <sub>A</sub> = 0°C to 60°C | -19.5 | | +19.5 | mV | | | Cell OV/UV step accuracy | Vcell_th_acc | V <sub>CELL</sub> = 1V to 5V,<br>T <sub>A</sub> = -40°C to +85°C | -40 | | +40 | mV | | Connected cells = 16, each cell voltage = 3.75V, $V_{TOP}$ = 60V, $T_A$ = 25°C, unless otherwise noted. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |-----------------------------------|-----------------------------|----------------------------------------------------------------------------------------------|-------|------|-------|-------| | Pack OV/UV steps | VPACK_TH_STEP | | | 19.5 | | mV | | Deep discharge steps | V <sub>DEEPTH_STEP</sub> | | | 19.5 | | mV | | Deep discharge step | Vdeepth_step_acc | $V_{CELL} = 2V \text{ to } 4.5V,$<br>$T_A = 0^{\circ}\text{C to } 60^{\circ}\text{C}$ | -19.5 | | +19.5 | mV | | accuracy | V DEEPTH_STEP_ACC | $V_{CELL} = 1V \text{ to } 5V,$<br>$T_A = -40^{\circ}\text{C to } +85^{\circ}\text{C}$ | -40 | | +40 | mV | | SC fastest detection time | t <sub>SC_DGL_MIN</sub> | Fastest deglitch setting and latency, T <sub>A</sub> = -40°C to +85°C | | | 120 | μs | | OC1 discharge FSR value | Voc1_dsg_fsr_1x | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = 25°C | | 80 | | mV | | OC1 discharge full scale accuracy | Voc1_dsg_fsr_1x_acc | Range and LSB selector = 0 (1x),<br>FSR (max setting),<br>$T_A = -40$ °C to +85°C | -15 | | +15 | % | | OC1 discharge offset | Voc1_dsg_fsr_1x_off | Range and LSB selector = 0 (1x), offset on LSB, $T_A = -40$ °C to +85°C | -1.5 | | +1.5 | mV | | OC1 discharge FSR value | V <sub>OC1_DSG_FSR_3X</sub> | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = 25°C | | 240 | | mV | | OC1 discharge full scale accuracy | Voc1_dsg_fsr_3x_acc | Range and LSB selector = 1 (3x),<br>FSR (max setting),<br>T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | OC1 discharge offset | Voc1_dsg_fsr_3x_off | Range and LSB selector = 1 (3x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | OC2 discharge FSR value | Voc2_dsg_fsr_1x | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = 25°C | | 80 | | mV | | OC2 discharge full scale accuracy | Voc2_dsg_fsr_1x_acc | Range and LSB selector = 0 (1x),<br>FSR (max setting),<br>$T_A = -40$ °C to +85°C | -15 | | +15 | % | | OC2 discharge offset | Voc2_dsg_fsr_1x_off | Range and LSB selector = 0 (1x), offset on smallest setting, T <sub>A</sub> = -40°C to 85°C | -1.5 | | +1.5 | mV | | OC2 discharge FSR value | Voc2_dsg_fsr_3x | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = 25°C | | 240 | | mV | | OC2 discharge full scale accuracy | Voc2_dsg_fsr_3x_acc | Range and LSB selector = 1 (3x),<br>FSR (max setting),<br>T <sub>A</sub> = -40°C to 85°C | -15 | | +15 | % | | OC2 discharge offset | Voc2_dsg_fsr_3x_off | Range and LSB selector = 1 (3x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | OC charge FSR value | Voc_chg_fsr_1x | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = 25°C | | 51.2 | | mV | © 2023 MPS. All Rights Reserved. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |----------------------------------|--------------------|----------------------------------------------------------------------------------------------|------|-----|------|-------| | OC charge full scale accuracy | Voc_chg_fsr_1x_acc | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | OC charge offset | Voc_chg_fsr_1x_off | Range and LSB selector = 0 (1x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | OC charge FSR value | Voc_chg_fsr_3x | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = 25°C | | 153 | | mV | | OC charge full scale accuracy | Voc_chg_fsr_3x_acc | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | OC charge offset | Voc_chg_fsr_3x_off | Range and LSB selector = 1 (3x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | SC discharge FSR value | Vsc_dsg_fsr_1x | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = 25°C | | 176 | | mV | | SC discharge full scale accuracy | Vsc_dsg_fsr_1x_acc | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | SC discharge offset | Vsc_dsg_fsr_1x_off | Range and LSB selector = 0 (1x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | SC discharge FSR value | Vsc_dsg_fsr_3x | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = 25°C | | 528 | | mV | | SC discharge full scale accuracy | Vsc_dsg_fsr_3x_acc | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | SC discharge offset | Vsc_dsg_fsr_3x_off | Range and LSB selector = 1 (3x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -2 | | +2 | mV | | SC charge FSR value | Vsc_chg_fsr_1x | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = 25°C | | 80 | | mV | | SC charge full scale accuracy | Vsc_chg_fsr_1x_acc | Range and LSB selector = 0 (1x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | | SC charge offset | Vsc_chg_fsr_1x_off | Range and LSB selector = 0 (1x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | SC charge FSR value | Vsc_chg_fsr_3x | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = 25°C | | 240 | | mV | | SC charge full scale accuracy | Vsc_chg_fsr_3x_acc | Range and LSB selector = 1 (3x), FSR (max setting), T <sub>A</sub> = -40°C to +85°C | -15 | | +15 | % | Connected cells = 16, each cell voltage = 3.75V, $V_{TOP}$ = 60V, $T_A$ = 25°C, unless otherwise noted. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |--------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------|------|-------------------------|-------| | SC charge offset | Vsc_chg_fsr_3x_off | Range and LSB selector = 1 (3x), offset on smallest setting, T <sub>A</sub> = -40°C to +85°C | -1.5 | | +1.5 | mV | | Cell-Balancing | | | | | | | | On resistance (R <sub>DS(ON)</sub> ) | _ | T <sub>A</sub> = 25°C | | 28 | | Ω | | for the balancing MOSFET | R <sub>DS(ON)_BAL_FET</sub> | $T_A = -40$ °C to +85°C | 15 | | 50 | Ω | | Open Wire | <b>,</b> | | | | | | | Open-wire pull-up current | low_pup | T <sub>A</sub> = 25°C | | 100 | | μA | | Open-wire pull-down current | low_pd | T <sub>A</sub> = 25°C | | 100 | | μA | | Low-Dropout Regulator | (LDO) Supply and | References | | | | | | REGCTRL output voltage | Vregetrl | $V_{TOP} = 18V$ to 75.2V, with REGCTRL load current = 0mA and 1mA, $T_A = -40^{\circ}\text{C}$ to +85°C | 5.45 | 5.6 | 5.75 | V | | REGIN voltage (9) | Vregin | With external REGIN BJT_FZT853TA, $V_{TOP} = 18V$ to 75.2V, with load current = 1mA and 50mA, $T_A = -40$ °C to +85°C | 4.65 | 5.1 | 5.4 | V | | REGIN analog UV | Vregin_uv | External power to REGIN, falling edge, $V_{TOP} = 18V$ to 75.2V, $T_A = -40$ °C to $+85$ °C | 4.16 | 4.3 | 4.44 | V | | 3V3 nominal voltage | V <sub>3V3</sub> | T <sub>A</sub> = 25°C | | 3.3 | | V | | 3V3 output accuracy | V <sub>3</sub> V <sub>3</sub> _ACC | $T_A = -40$ °C to +85°C | -5 | | +5 | % | | 3V3 short-circuit current | I <sub>3V3_EFET</sub> | External power to REGIN,<br>T <sub>A</sub> = -40°C to +85°C | 55 | 68 | 80 | mA | | VDD output voltage | $V_{DD}$ | $T_A = 25$ °C | | 1.8 | | V | | Reference voltage | V <sub>REF</sub> | $T_A = 25$ °C | | 3.3 | | V | | NTCB pull-up voltage | V <sub>NTCB</sub> | NTCB enabled, no load,<br>T <sub>A</sub> = 25°C | | 3.3 | | V | | NTODIcad | | NTCB enabled, max load,<br>T <sub>A</sub> = 25°C | | 4 | | mA | | NTCB load | INTCB_MAXLOAD | NTCB enabled, max load,<br>T <sub>A</sub> = -40°C to +85°C | 3.2 | | 4.8 | mA | | 3V3 analog UV | V <sub>3</sub> V <sub>3</sub> _UV | Falling edge | | 2.85 | | V | | GPIO | | | | • | | | | GPIO input voltage (high) | VIH_GPIO | Voltage high ( $V_H$ ) = 3.3V or 5V,<br>$T_A$ = -40°C to +85°C | 0.8 x<br>V <sub>H</sub> | | Vн | V | | GPIO input voltage (low) | VIL_GPIO | V <sub>H</sub> = 3.3V or 5V,<br>T <sub>A</sub> = -40°C to +85°C | 0 | | 0.2 x<br>V <sub>H</sub> | V | | GPIO output voltage (high) | V <sub>OH_GPIO</sub> | V <sub>H</sub> = 3.3V or 5V,<br>I <sub>SOURCE</sub> = 1.5mA,<br>T <sub>A</sub> = -40°C to +85°C | V <sub>H</sub> -<br>0.5 | | V <sub>H</sub> | V | #### Note: 9) Guaranteed by design. The REGIN voltage is limited by the V<sub>REGCTRL</sub> and is equal to V<sub>REGCTRL</sub> - V<sub>BE\_ON</sub>. | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |-------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|------|-------| | GPIO output voltage (low) | Vol-gpio | V <sub>H</sub> = 3.3V or 5V, I <sub>SINK</sub> = 1.5mA,<br>T <sub>A</sub> = -40°C to +85°C | 0 | | 0.4 | V | | GPIO push-pull resistor (up) | R <sub>GPIO_PUP</sub> | GPIO high voltage = 3.3V, external power to REGIN | | 430 | | Ω | | GPIO push-pull resistor (down) | R <sub>GPIO_PDOWN</sub> | GPIO low voltage = 0V | | 110 | 200 | Ω | | GPIO pull-up mode | RGPIO_WEAK_PUP | | | 17 | | kΩ | | NSHDN Pin | | | | | | | | NSHDN internal pull down | R <sub>SHDN_PD</sub> | NSHDN 0V to 5V | | 5 | | МΩ | | NSHDN configuring voltage | Vnshdn_prog | | 7.5 | 7.6 | 7.7 | V | | NSHDN deglitch to enter shutdown | tnshdn_dgl_enter | T <sub>A</sub> = 25°C, IC stays in safe<br>mode for longer than<br>tnshdn_dgl_active | | 8 | | ms | | NSHDN deglitch active time | tnshdn_dgl_active | T <sub>A</sub> = 25°C | | 4 | | ms | | NSHDN falling threshold | V <sub>NSHDN_FALL</sub> | | | 1 | | V | | | | 3V3 enabled at shutdown mode | | 2.65 | | V | | NSHDN rising threshold | Vnshdn_rise | 3V3 disabled at shutdown mode | | 2 | | V | | WDT Pin | | | | | | | | Reset pulse length | twdt_rstpulse_len | | | 10 | | ms | | High-Side MOSFET (HS- | FET) Drive | | | | | | | CHG gate drive voltage | Vснg | C <sub>LOAD</sub> = 80nF, static value at transition completed, V <sub>TOP</sub> = 18V to 75.2V, V <sub>GS</sub> = 10V, T <sub>A</sub> = 25°C | | 10 | | V | | CHG gate drive voltage accuracy | V <sub>CHG_ACC</sub> | $C_{\text{LOAD}}$ = 80nF, static value at transition completed, $V_{\text{TOP}}$ = 18V to 75.2V, 10V selected, $T_{\text{A}}$ = -40°C to +85°C | 9.3 | | 10.7 | V | | CHG gate drive turn-on resistance | R <sub>CHG_ON</sub> | MOSFET drive turned on,<br>PACKP = V <sub>TOP</sub> , T <sub>A</sub> = 25°C | | 2600 | | Ω | | CHG gate driver turn-off resistance | Rchg_off | MOSFET driver turned off,<br>PACKP = V <sub>TOP</sub> , T <sub>A</sub> = 25°C | | 840 | | Ω | | DSG gate drive voltage | Vpsg | $C_{LOAD} = 80 nF$ , static value at transition completed, $V_{TOP} = 18 V$ to 75.2V, $V_{GS} = 10 V$ , $T_A = 25 ^{\circ}C$ | | 10 | | V | | DSG gate driver voltage accuracy | V <sub>DSG_ACC</sub> | $C_{\text{LOAD}}$ = 80nF, static value at transition completed, $V_{\text{TOP}}$ = 18V to 75.2V, 10V selected, $T_{\text{A}}$ = -40°C to +85°C | 9.3 | | 10.7 | V | | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |--------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|------|-------| | DSG gate driver turn-on resistance | R <sub>DSG_ON</sub> | MOSFET driver turned on,<br>PACKP = V <sub>TOP</sub> , T <sub>A</sub> = 25°C | | 2600 | | Ω | | DSG gate driver turn-off resistance | R <sub>DSG_OFF</sub> | MOSFET driver turned off,<br>PACKP = V <sub>TOP</sub> ,<br>DSG = PACKP + 5V, T <sub>A</sub> = 25°C | | 600 | | Ω | | SBYDSG gate driver voltage | V <sub>SBYDSG</sub> | $C_{LOAD}$ = 10nF, static value at completed transition, $V_{TOP}$ = 18V to 75.2V, $V_{GS}$ = -10V, $T_A$ = -40°C to +85°C | -12 | -10 | -9 | ٧ | | SBYDSG gate driver on resistance | R <sub>SBYDSG_ON</sub> | MOSFET driver turned on,<br>T <sub>A</sub> = -40°C to +85°C | | 14.3 | | kΩ | | SBYDSG gate driver off resistance | R <sub>SBYDSG_OFF</sub> | MOSFET driver turned off,<br>T <sub>A</sub> = -40°C to +85°C | | 2.7 | | kΩ | | Charge Pump | | | | | | | | Charge pump output voltage | V <sub>CP</sub> | Gate driver voltage = 10V, regular control mode, T <sub>A</sub> = 25°C | | 14.7 | | V | | Charge pump output voltage accuracy | V <sub>CP_ACC</sub> | Accuracy of select VCP average value, T <sub>A</sub> = -40°C to +85°C | -1 | | +1 | V | | Charge pump turn-on time | tcp_ton | VCP - AGND transition from $V_{TOP}$ to $V_{TOP}$ + VCP, 10nF capacitor on VCP, $V_{TOP}$ = 21V, for both low-power mode and regular control mode, $T_A$ = -40 to +85°C | | | 2 | ms | | Pull-Up Comparators | | | | | | | | PACKP charge | IPACKP_PUP | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | | 250 | | μΑ | | PACKP discharge | PACKP_PDOWN | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | | 250 | | μΑ | | PACKP exceeds V <sub>TOP</sub> | V <sub>PACKP_HGR_VTOP</sub> | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | | 280 | | mV | | PACKP is below V <sub>TOP</sub> | VPACKP_LWR_VTOP | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | | -1.77 | | V | | Standby comparator accuracy | Vsby_comp_accu | Offset on the smallest setting, $T_A = 25$ °C | -125 | | +125 | μV | | PACKP short recovery threshold | VPACKP_SCOC_REC_TH | T <sub>A</sub> = 25°C | | 110 | | mV | | Short recovery current-<br>source accuracy | Iscoc_pup | Offset on the smallest setting, T <sub>A</sub> = 25°C | -50 | | +50 | μΑ | | Internal Clock | | | | | | | | | | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | | 2 | | MHz | | Internal clock frequency | f <sub>2M_CLOCK</sub> | $V_{TOP} = 18V \text{ to } 75.2V,$<br>$T_A = -40^{\circ}\text{C to } +85^{\circ}\text{C}$ | 1.85 | 2 | 2.15 | MHz | | Low-fraguency internal | | $V_{TOP} = 18V \text{ to } 75.2V, T_A = 25^{\circ}C$ | 31.2 | 32 | 32.8 | kHz | | Low-frequency internal clock | f <sub>32</sub> к_сьоск | $V_{TOP} = 18V \text{ to } 75.2V,$<br>$T_A = -40^{\circ}\text{C to } +85^{\circ}\text{C}$ | 30.7 | | 33.3 | kHz | | Parameter Name | Symbol | Condition | Min | Тур | Max | Units | |-------------------------------------|--------------------------|---------------------------------------------------------------|--------------|--------------|---------------|-------| | I <sup>2</sup> C Communication Inte | rface | | | | | | | I <sup>2</sup> C clock frequency | f <sub>I2C</sub> | T <sub>A</sub> = 25°C | | | 400 | kHz | | SCL, SDA low input voltage | VILOW | T <sub>A</sub> = -40°C to +85°C | | | 0.25 x<br>3V3 | V | | SCL, SDA high input voltage | Vihigh | $T_A = -40$ °C to +85°C | 0.7 x<br>3V3 | | | V | | SCL, SDA input<br>hysteresis | VIHYST | $T_A = -40$ °C to +85°C | | 0.2 x<br>3V3 | | V | | SPI Communication Inte | erface | | | | | | | SPI clock frequency | f <sub>SPI</sub> | $T_A = 25$ °C | | | 1.0 | MHz | | SPI input low | V <sub>SPI_IN_LOW</sub> | SDI, CLK, T <sub>A</sub> = -40°C to +85°C | | | 0.25 x<br>3V3 | ٧ | | SPI input high | V <sub>SPI_IN_HIGH</sub> | SDI, CLK, T <sub>A</sub> = -40°C to +85°C | 0.7 x<br>3V3 | | | V | | SDO high-side (HS) on resistance | R <sub>SDO_DRV_HI</sub> | Isource = 1.5mA,<br>T <sub>A</sub> = -40°C to +85°C | 75 | 100 | 125 | Ω | | SDO low-side (LS) on resistance | R <sub>SDO_DRV_LOW</sub> | I <sub>SINK</sub> = 1.5mA,<br>T <sub>A</sub> = -40°C to +85°C | 38 | 52 | 66 | Ω | ## TYPICAL PERFORMANCE CHARACTERISTICS # Cell Voltage Error Measurement vs. Temperature # Cell Voltage Error Measurement vs. Temperature # Cell Voltage Error Measurement vs. Temperature # Cell Voltage Error Measurement vs. Temperature #### **Current Error Measurement vs.** # **TYPICAL PERFORMANCE CHARACTERISTICS** Performance curves and waveforms are tested on the evaluation board. $V_{TOP}$ = 60V, $T_A$ = 25°C, unless otherwise noted. CH1: V<sub>MID</sub> CH3: V<sub>PACK+</sub> CH2: V<sub>GS\_DSG</sub> CH4: I<sub>DSG</sub> ### **DSG Soft Start** PACK+ is connected to a 1mF capacitor, the DSG slope is 0.2V/ms #### **DSG Fast-Off in Short-Circuit** $R_{SRP-SRN} = 1 m \Omega$ , short-circuit threshold is 99mV, deglitch off, 4 paralleled AM90N08-04BA devices act as the DSG N-channel MOSFETs, which has a typical $C_{ISS}$ of 9924pF 18 ## TYPICAL PERFORMANCE WHEN PAIRED WITH MPF4279X FUEL GAUGE The MP2796 battery monitor includes strictly synchronized cell and pack voltage and current measurements, for the purpose of maximizing state-of-charge (SOC) determination. MPS' MPF4279x family of fuel gauges are designed to take advantage of this feature. This section illustrates the SOC accuracy of the MP2796 battery monitor when combined with MPS' MPF4279x fuel gauge family. ## Constant-Current/Constant-Voltage (CC/CV) Charge and Dynamic Discharge Cycle The next scenarios consist of charging a 10S1P (10) battery using the typical CC/CV method, followed by a highly dynamic discharge at different ambient temperatures. The charge constant current rate is 1C, while the charge termination current in this example is 0.1C. The highly dynamic discharge corresponds to a typical e-bike's current profile, with an average current of 1C and maximum peak currents up to 2.8C. Figure 3 shows the current profile of the complete cycle at 25°C. Figure 3: CC/CV Charge and Dynamic Discharge Current Profile Figure 4 shows the performance of the combined MP2796 and MPF42791 for the CC/CV charge and dynamic discharge cycle at an ambient temperature of 25°C. During charge, the root-mean-squared (RMS) (11) and maximum pack SOC error are 0.61% and 1.03%, respectively. During discharge, the rootmean-squared and pack SOC error are 0.78% and 1.94%, respectively. 10) 10S1P refers to the battery configuration. There are 10 groups of 1 parallel cell connected in series. 11) The RMS error is equal to where $\theta$ is the actual SOC, $\hat{\theta}$ is the estimated SOC, and N is the number of samples. Figure 4: Combined MP2796 + MPF42791 Performance for a CC/CV Charge and Dynamic Discharge (Ambient Temperature = 25°C) Figure 5 shows the performance of the combined MP2796 and MPF42791 for the CC/CV charge and dynamic discharge cycle at an ambient temperature of 0°C. During charge, the root-mean-squared and maximum pack SOC error are 0.68% and 1.22%, respectively. During discharge, the root-mean-squared and pack SOC error are 1.15% and 2.97%, respectively. Figure 5: Combined MP2796 + MPF42791 Performance for a CC/CV Charge and Dynamic Discharge (Ambient Temperature = 0°C) Figure 6 shows the performance of the combined MP2796 and MPF42791 for the CC/CV charge and dynamic discharge cycle at an ambient temperature of 40°C. During charge, the root-mean-squared and maximum pack SOC error are 0.40% and 0.60%, respectively. During discharge, the root-mean-squared and pack SOC error are 0.77% and 1.89%, respectively. Figure 6: Combined MP2796 + MPF42791 Performance for a CC/CV Charge and Dynamic Discharge (Ambient Temperature = 40°C) #### **Performance Summary** This section provides a summary the combined MP2796 and MPF42791 real-world performance. Table 1 shows a summary of the pack SOC performance metrics for a 10S1P battery. Table 1: MPF42791 SOC Root-Mean-Squared (and Maximum) Error | Test Case | 0°C | 25°C | 40°C | |-------------------|---------------|---------------|---------------| | CC/CV charge | 0.68% (1.22%) | 0.61% (1.03%) | 0.40% (0.60%) | | Dynamic discharge | 1.15% (2.97%) | 0.78% (1.94%) | 0.77% (1.89%) | # **FUNCTIONAL BLOCK DIAGRAM** Figure 7: Functional Block Diagram #### **OPERATION** #### **Main Modes** The MP2796's main operation modes are listed and described below (see Figure 8). #### Shutdown Mode It is vital to preserve a battery's capacity. Shutdown mode minimizes the amount of leakage from the battery pack, which extends the battery pack's shelf storage life. In shutdown mode, the communication interface is unavailable and REGIN is loosely regulated, which means its voltage is below the normal voltage without any load capacity. However, it is possible to keep 3.3V active in shutdown mode with a slight margin for current consumption. Pull the NSHDN pin to ground to enter shutdown mode. #### Safe Mode To enter safe mode from shutdown mode, pull up the NSHDN pin and wait at least 5ms before issuing an I<sup>2</sup>C or SPI command. If any functional commands are required in safe mode (e.g. high-resolution voltage scanning, Coulomb counting, MOSFETs turn-on, voltage protection monitoring, open wire, and cell-balancing), then the I<sup>2</sup>C or SPI bus must be idle for at least 200µs after the functional command in enabled. Safe mode is characterized by the following conditions: - The protection MOSFETs turn off. - The over-voltage (OV) and under-voltage (UV) hardware autonomous protection state machine is disabled, unless it is forcibly enabled. The communication interface is enabled. To leave safe mode, see the Protection MOSFET Enable Control section on page 23. In safe mode, it is possible enable protection monitoring (cell OV, cell UV, and current monitoring). #### **Active Mode** In active mode, the high-side drivers turn on, and the BMS can be powered or be charged by a downstream system through the CHG and DSG N-channel MOSFETs. ### Standby Mode Standby mode reduces current consumption by using a standby P-channel MOSFET to power the system (instead of DSG N-channel MOSFET), and conducts through the CHG N-channel MOSFET's body diode. To enter standby mode, standby mode must be enabled, and the current must be below the standby current threshold. In standby mode, the time between ADC voltage conversions used for protection monitoring can be independently lengthened via the STBY\_MONITOR\_CFG register. This reduces the average current consumption. #### Fault Mode In fault mode, both the CHG and DSG MOSFET drivers turn off in response to a fault event. Protection monitoring is still enabled during a fault. Fault mode can be cleared manually or through automatic fault recovery, depending on the configuration. Figure 8: Main States Diagram #### Registers (Default and Lock) Most of the configuration settings and options have a configurable default value. Certain registers can be configured independently, or they can be locked in read-only mode. This prevents critical safety features from being changed. #### **Protection MOSFET Enable Control** The MP2796 can leave safe mode and enter active mode via pin control or register control, though only one control method can be selected at a time. The FET\_SRC register can be set using either the register (ACTIVE\_CTRL register) or pin (GPIO1/2) to determine whether the device should remain in safe mode or active mode. There are two control strategies that can be selected via the FET\_CFG register: simple or direct. Table 2 lists the BMS behavior in simple mode, where a single control is offered for both the charge and the discharge driver. The system internally handles the MOSFETs' turn-on and turn-off sequences. Table 2: Protection MOSFETs (Simple Mode) | Configuration: FET_SRC = GPIO, Standby P-Channel MOSFET Disabled | | | | | | |------------------------------------------------------------------|-------------|--------------|--------------|--|--| | MOSFET | GPIO1 = Low | GPIO1 = High | GPIO1 = High | | | | WOSFET | GPIOT = LOW | Fault | No Fault | | | | CHG N-channel MOSFET | Off | Off | On | | | | DSG N-channel MOSFET | Off | Off | On | | | Table 3 describes how the BMS behaves in direct mode, in which each driver (charge MOSFET driver and discharge MOSFET driver) can be directly controlled. Table 3: Protection MOSFETs (Direct Mode) | Configuration: FET SRC = GPIO, Standby P-Channel MOSFET Disabled | | | | | | |------------------------------------------------------------------|----------------------------|-------|--------------|--------------|--------------| | | No Fault | | | | | | MOSFET | GPIO1 = Low<br>GPIO2 = Low | Fault | GPIO1 = High | GPIO1 = Low | GPIO1 = High | | | 0.102 - 2011 | | GPIO2 = Low | GPIO2 = High | GPIO2 = High | | CHG N-channel MOSFET | Off | Off | Off | On | On | | DSG N-channel MOSFET | Off | Off | On | Off | On | #### **MOSFET Driving Ability** The high-side MOSFET (HS-FET) driver can drive multiple DSG/CHG FETs in parallel. The VCP capacitor value must be increased, depending on the number of parallel MOSFETs in the application. #### DSG MOSFET Soft Start (SS) (12) One of the biggest challenges when designing a BMS with HS-FETs is limiting the inrush current and protecting the DSG MOSFET from exceeding its safe operating area (SOA) while it turns on when a large capacitive load is present. To address this issue, most system designers add what is commonly referred to as a precharge or pre-biased external circuit. This type of external circuit requires additional MOSFETs and physically large power resistors, which limit the discharge current while the load capacitance is charging. To reduce the significant size and cost of this circuit, the MP2796's DSG N-channel MOSFET driver includes an innovative soft start (SS) discharge MOSFET control circuit. SS controls the rising slope of the DSG voltage by setting the DSG\_SOFTON\_DV bits, and thereby reducing the discharging current. To ensure that the DSG MOSFET's SOA is not exceeded during SS, the MP2796 uses 3 separate over-current (OC) comparators. #### Note: 12) For detailed design guidelines on how to configure the DSG MOSFET SS settings, contact an MPS FAE for the related application note. ### **CHG MOSFET Soft Start (SS)** The CHG MOSFET driver supports a configurable SS via the CHG\_SOFTON\_PUP register to set the pull-up current values (ranging between 3 $\mu$ A and 10 $\mu$ A). When CHG\_SOFTON\_EN is enabled and V<sub>PACKP</sub> exceeds V<sub>TOP</sub>, the MOSFET drive circuit automatically uses CHG SS to control the CHG pin's output current, so that V<sub>GS</sub> rises slowly. #### **GPIO Pins** The GPIO pins can be directly controlled by the MCU through registers, or they can be assigned to special functions. The GPIO pins have the following functions: - <u>Push-pull output</u>: The pull-up voltage can be configured to REGIN or 3V3. - <u>Pull-up capability</u>: Connect a 20kΩ pull-up resistor to REGIN or 3V3. - Digital input. - Analog input: Can act as a buffered ADC input with a 0V to 3.3V range. In addition to the GPIO functions, the GPIO1 and GPIO2 pins can also enable certain protections (see the Protection MOSFET Enable Control section on page 23). In addition to the GPIO capability, the GPIO3 pin can be configured to initiate automatic cellbalancing (as an input), or indicate fault status (as an output). #### **WDT Pin** The WDT pin is controlled by the watchdog timer (WDT), and provides the following functions: - Toggles with a high pulse when a watchdog event occurs to reset an external IC (e.g. the host MCU). - Triggers a self-reset to the IC by bringing the device back to its default values. - Can be pulled high externally to reset the device. #### Alert (xALERT) The xALERT pin can be configured to be an active high (3.3V) or active low interrupt pin. When set to active low, xALERT goes low if there is a pending interrupt. When set to active high, this pin goes high if there is a pending interrupt. Protections and other events trigger this pin, but certain bits must be enabled to ensure that only the relevant sources generate an interrupt. #### Protections, Interrupts, and Faults Hardware protections can trigger both interrupt and faults independently (see Figure 9). Figure 9: General Faults and Interrupts Architecture #### **Current Protections** ## Over-Current Protection (OCP) All over-current protection (OCP) monitoring is performed with the same over-current (OC) analog comparator. Two possible range (RNG) levels are available for each threshold. The threshold limit and deglitch are available with the multiple-time programmable (MTP) memory so that the value can be customized during battery pack assembly for different projects. OC1\_DCHG\_EN\_CTRL, OC2\_DCHG\_EN\_CTRL, and OC\_CHG\_EN\_CTRL are the enable bits for discharge OC 1, discharge OC 2, and charge OC monitoring. Once enabled, the monitoring function starts during the transition from safe mode to active mode, and keeps running in active mode. Use SAFE\_SCOC\_EN to enable monitoring in safe mode. The enable bits for OC monitoring can be permanently locked in read-only mode, preventing the MCU from performing further changes. Once OC monitoring is enabled, the interrupt and fault polices can be set. When only the CHG or DSG MOSFET turns on, the OC limits are set to whichever value is smaller between the configured value and 17.5mV. Meanwhile, the deglitch filter is the smaller value between the configured value and 16ms. ## Discharge Over-Current Protection (OCP) Two different, independent thresholds are available for discharge OCP: OC1 and OC2. Table 4 on page 25 lists the resolution and ranges for discharge OC1 and OC2. Table 4: Discharge OC1 and OC2 | Threshold | RNG = 0 | RNG = 1 (3x) | |-----------|---------|--------------| | LSB (mV) | 2.5 | 7.5 | | FSR (mV) | 80 | 240 | Each limit has its own configurable deglitch time (OC1\_DSG\_DGL and OC2\_DSG\_DGL) with two configurable ranges (see Table 5). In standby mode, the discharge OC thresholds are set to 2.5mV, and the deglitch filter is the shorter value between the configured value and 1ms. Table 5: OC1 and OC2 Deglitch Times | Deglitch<br>Range | OCx_DSG_<br>DGL_RNG = 0 | OCx_DSG_<br>DGL_RNG = 1 | |-------------------|-------------------------|-------------------------| | LSB (ms) | 5 | 40 | | FSR (ms) | 315 | 2520 | ### Charge Over-Current Protection (OCP) Table 6 lists the resolution and range for charge OCP. **Table 6: Charge OCP** | Threshold | RNG = 0 | RNG = 1 (3x) | |-----------|---------|--------------| | LSB (mV) | 1.6 | 4.8 | | FSR (mV) | 51.2 | 153.6 | The charge OC limit has its own configurable deglitch time with two configurable ranges (see Table 7). **Table 7: Charge OC Deglitch Time** | Deglitch<br>Range | OC_CHG_<br>DGL_RNG = 0 | OC_CHG_<br>DGL_RNG = 1 | |-------------------|------------------------|------------------------| | LSB (ms) | 5 | 40 | | FSR (ms) | 315 | 2520 | #### **Short-Circuit Protections (SCP)** All short-circuit protection (SCP) monitoring is performed on a single short-circuit analog comparator. Each limit has a configurable deglitch time in the range of 100µs to 25.5ms. SC\_DCHG\_EN\_CTRL and SC\_CHG\_EN\_CTRL are the enable bits for discharge short-circuit and charge short-circuit monitoring, respectively. Once monitoring is enabled and the MP2796 goes from safe mode to active mode, the IC begins monitoring. The SAFE\_SCOC\_EN register can enable monitoring in safe mode. Once short-circuit current monitoring is enabled, the interrupt and fault polices can be set. ### Discharge Short-Circuit Table 8 shows the resolution and range for the discharge short-circuit current limit. **Table 8: Discharge Short-Circuit Current Limit** | | Li | Deglitch | | |-----|---------|----------|--------| | | RNG = 0 | RNG = 1 | Range | | LSB | 5.5mV | 16.5mV | 200µs | | FSR | 176mV | 528mV | 25.4ms | ## **Charge Short-Circuit** Table 9 shows the resolution and range for the charge short-circuit current limit. **Table 9: Charge Short-Circuit Current Limit** | | Li | Deglitch | | |-----|---------|----------|--------| | | RNG = 0 | RNG = 1 | Range | | LSB | 2.5mV | 7.5mV | 200µs | | FSR | 80mV | 240mV | 25.4ms | # **Voltage Protections** When enabled, all voltage protections are automatically monitored without needing an MCU to schedule ADC conversion. An autonomous hardware state machine periodically schedules the conversion for all relevant channels, and the results are internally checked and compared to the limits. The deglitch filters described refers to the number of consecutive readings during which the relevant channel exceeds its thresholds. The interval between readings is typically 254ms, though this value depends on the device's state (e.g. active mode or standby mode) and the configuration of the hardware monitoring (e.g. the ACTIVE\_MONITOR\_CFG register for active mode and STBY\_MONITOR\_CFG for standby mode). # Cell Under-Voltage (UV) and Over-Voltage (OV) Thresholds When fewer than 16 cells are used, only the cells enabled by the CELL\_S\_CTRL register monitored for under-voltage (UV) and over-voltage (OV) conditions. These thresholds are available in the MTP, which means they can be customized during battery pack assembly for different projects. Table 10 on page 26 lists the values for cell OV and UV thresholds. Table 10: Cell OV and UV Thresholds | Cell<br>OV/UV | Limit | Hysteresis | Deglitch | |---------------|--------|------------|-----------| | LSB | 19.5mV | 19.5mV | 1 reading | | FSR | 4.98V | 292.5mV | 16 | # Pack Under-Voltage (UV) and Over-Voltage (OV) Thresholds The pack OV and UV thresholds are monitored by the VTOP pin. These thresholds are available in the MTP, which means they can be customized during battery pack assembly for different projects (see Table 11). Table 11: Pack OV and UV Thresholds | Pack<br>OV/UV | Limit | Hysteresis | Deglitch | |---------------|--------|------------|-----------| | LSB | 19.5mV | 78mV | 1 reading | | FSR | 80V | 4.922V | 16 | # Negative Temperature Coefficient (NTC) Temperature The negative temperature coefficient (NTC) voltages are checked during the automatic hardware monitoring sequence. Figure 10 shows the block diagram of the NTC-sensing architecture. All NTC channels are monitored in a ratiometric conversion. This means that the ADC reference is switched to NTCB for the NTC channels. In this scenario, all effects related to NTCB drifts due to the temperature and operating conditions are removed from the reading. NTC1~4 have limits that can be set according to two modes: - <u>Cell monitor mode</u>: The NTC monitors the temperature of the lithium cell in the pack. The MP2796 provides independent cell temperature limits (hot and cold) for the charging and discharging currents. - These thresholds are available in the MTP, and can be customized during battery pack assembly for different projects. - PCB monitor mode: The NTC monitors the PCB or the protection MOSFET's temperature. A standard hot temperature limit is provided for both the charge and discharge current. Note that using NTCs results in a lower voltage threshold for OT (hot) conditions and a higher voltage threshold for under-temperature (cold) conditions. Figure 10: Architecture for NTC ADC Acquisition #### **Die Temperature** The die temperature alarm has two thresholds. The first is a digital threshold that can be configured between 70°C and 120°C. With this threshold, the comparator's output can put the IC in fault mode. The second is an analog threshold that forces the device to shut down at 140°C. The digital die temperature threshold is typically used as an early warning, since the analog threshold forces the IC to shut down. Until the analog OT condition is resolved, the IC remains in a forced shutdown state, and the communication interface is unavailable. #### **Dead Cells** The pack is monitored at a cell level for dead cells. A dead cell is defined as any cell whose voltage falls below the manufacturer's specified final discharge voltage, in which continued charging should be avoided. If dead cell detection is enabled, the MP2796 checks if any cell is below the configurable threshold (CELL\_DEAD\_LIMIT), which is typically much lower than the cell's UV threshold. Once a dead cell condition is detected, the persistent dead cell flag (CELL\_DEAD\_LOG\_STS) is set to 1. When the default values for CELL\_DEAD\_EN and CELL\_DEAD\_FAULT\_EN are enabled via the OTP, this flag remains at 1 even if the device enters and exits shutdown mode. This flag can be cleared by the CELL\_DEAD\_DET\_CLEAR command. #### **Mismatched Cells** Excessively mismatched or unbalanced cells can be detected by monitoring the maximum and minimum cell voltages. If the difference between the maximum cell voltage and the minimum cell voltage exceeds a defined threshold, then a cell mismatch status is triggered. The mismatched cell with the higher voltage is reported as an individual flag. The cell with the minimum voltage is reported in the CELL\_MSMT\_LOWER register. #### **Diagnostics and Integrity** ### LDO (REGIN, 3.3V and 1.8V) Rail Monitoring The LDO UV threshold is provided for the REGIN, 3.3V, and 1.8V rails. This UV threshold is compared to the ADC readings with the same refresh interval as the other voltage monitors, so it measures the nominal rail voltage rather than detecting deglitches. #### **ADC Self-Test Conversion** The ADC converts a known voltage value and ensures that the conversion result is within a predefined window that accounts for tolerance and temperature shifts. # One-Time Programmable (OTP) Cyclic Redundancy Check (CRC) A one-time programmable (OTP) cyclic redundancy check (CRC) is executed when the device exits shutdown mode. If the CRC fails, the device can be configured to enter fault mode, preventing the BMS from turning on the protection MOSFETs. ### **Communication CRC** Typically, the CRC detects errors in exchanged data. The MP2796 supports CRC for exchanged data. When this functionality is enabled, the following is possible: - Write a transaction to 1 register (2 bytes) to append a 1-byte CRC. A correct CRC is required for a successful write transaction. - Read a transaction for 1 register (2 bytes) to append a 1-byte CRC. - The read transaction length can be temporarily increased to 126 bytes using a dedicated register. The CRC is appended at the end of the transaction. The communication CRC is implemented by the CRC-8 algorithm. The CRC can detect 1 incorrect bit. However, all CRC techniques encounter limitations when there are more incorrect bits. If more than 1 bit is corrupted, the error detection depends on the specific pattern. Statistically, the detection can occur, but it is not guaranteed. In general, the ability to detect errors decreases when there is more data to check. For more details, see the I<sup>2</sup>C Read section and SPI Read section on page 36 to page 41. ## **Watchdog Timer** The watchdog timer monitors communication with the I<sup>2</sup>C or SPI interface. If there is no write to the WDT\_RST register within a certain interval, the timer is triggered. The watchdog has a barkbite style. The bark notifies the device when the MCU has failed to clear the watchdog timer. This results in a bark timeout, which can be configured to trigger the alert pin. The WDT bark counter setting is 25ms per LSB, with up to 3.2 seconds maximum. After a bite timeout, there is an optional feature to reset the device's registers to the default values. The WDT bite counter setting is 25ms per LSB, with up to 3.2 seconds maximum. Using the bidirectional, configurable WDT, it is possible to set up the IC to self-reset and/or to reset an external IC if its reset trigger is connected to the WDT pin. ## Interrupts Interrupt statuses are split between 2 register addresses (RD\_INT0 and RD\_INT1). Each interrupt source has a matching enable bit and a dedicated clear bit to clear the interrupt. Table 12 shows the main interrupts. Table 13 on page 29 shows additional interrupts. Table 12: Main Interrupts (RD\_INT0) | Condition | Flag | Description | Related Status Register(s) | |--------------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | Cell OV | CELL_OV_INT_STS | Unified flag for cell OV conditions. The related register reports each cell's OV flag, which is checked to determine which cell is generating the interrupt. | Flags in address,<br>RD_CELL_OV | | Cell UV | CELL_UV_INT_STS | Unified flag for cell UV conditions. The related register reports each cell's UV flag, which is checked to determine which cell is generating the interrupt. | Flags in address,<br>RD_CELL_UV | | VTOP pack OV | VTOP_OV_INT_<br>STS | Dedicated flag for battery pack OV conditions detected on the VTOP pin. | | | VTOP pack UV | VTOP_UV_INT_STS | Dedicated flag for battery pack UV conditions detected on the VTOP pin. This is unrelated to the VTOP UV analog threshold. | | | ОС | OVER_CURR_<br>INT_STS | OC interrupt for charge, discharge 1, and discharge 2. | OC1_DCHG_STS, OC2_DCHG_STS, OC_CHG_STS | | SCP | SHORT_CURR_<br>INT_STS | Short-circuit interrupt for both charge and discharge. | SC_CHG_STS,<br>SC_DCHG_STS | | NTC cold | NTC_COLD_<br>INT_STS | Unified flag for NTC cold conditions for all NTC channels configured in cell mode. To identify which NTC is the source of the interrupt, the additional individual flags should be checked. | NTC1_CELL_COLD_STS,<br>NTC2_CELL_COLD_STS,<br>NTC3_CELL_COLD_STS,<br>NTC4_CELL_COLD_STS | | NTC hot | NTC_HOT_INT_<br>STS | Unified flag for NTC hot conditions for all NTC channels configured in cell mode. To identify which NTC is the source of the interrupt, the additional individual flags should be checked. | NTC1_CELL_HOT_STS,<br>NTC2_CELL_HOT_STS,<br>NTC3_CELL_HOT_STS,<br>NTC4_CELL_HOT_STS | | Watchdog interrupt | WDT_INT_STS | Notification for either a bite or bark event from the communication watchdog timer. | WDT_BARKED,<br>WDT_BITE | | Fault recovered | RECOVERED_<br>INT_STS | Notification that the system recovers from a fault state, including both automatic fault recovery and a manual MCU clearing. | | | AFE mode change | AFE_MODE_<br>CHANGE_INT_STS | The AFE has changed states (e.g. safe mode, active mode, fault mode, standby mode). | PWR_STATE | | Scan complete | VSCAN_DONE_<br>INT_STS | Notification that the high-resolution voltage ADC scan has finished converting of all the channels on its list. | | | Pack current | PACK_CURRENT_<br>INT_STS | Interrupt indicating a change in the battery pack current range (discharge, standby, or charge). | PACK_CURRENT_STATUS | ## Table 13: Additional Interrupts (RD\_INT1) | Name | Flag | Description | Related Status Register(s) | |---------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | | | Reports a MOSFET driver issue such as the following: | | | FET driver | FET_DRIVER_INT_STS | <ul> <li>FET timeout: the DSG or CHG driver did not reach its final voltage within the timeout interval</li> <li>A lower level OC condition occurs during CHG or DSG soft start</li> <li>A short-circuit is issued before DSG turns on</li> </ul> | FET_TIMEOUT | | PACKP voltage | PACKP_V_INT_STS | The voltage on PACKP node has changed compared to VTOP. Note that the PACKP comparator is invalid when disabled or during short-circuit removal, but still reports to the interrupt. | PACKP_COMP_STS | | Balancing complete | BAL_DONE_INT_STS | Balancing has been completed. | Flags in address,<br>BAL_STS | | Self-test fail | SELF_TEST_INT_STS | The ADC is failing its self-diagnostic test and/or the conversion of this value is outside the specified boundaries. | SELF_TEST_STS_OV,<br>SELF_TEST_STS_UV | | Scheduler error | FSM_ERROR_INT_STS | The scheduler was busy when a new feature command was requested, and concurrent operation is not supported. For example, the device may report that an MCU conversion command is ignored since open-wire detection is running, or it may report that a cell-balancing command is ignored since open-wire detection is running. | | | PCB temperature hot | PCB_MNTR_HOT_<br>INT_STS | Unified flag for NTC hot conditions for all NTC channels configured in PCB mode. To identify which NTC is the source of the interrupt, the individual flags should be checked. | NTC1_PCB_MNTR_HOT_STS,<br>NTC2_PCB_MNTR_HOT_STS,<br>NTC3_PCB_MNTR_HOT_STS,<br>NTC4_PCB_MNTR_HOT_STS | | Die temperature | DIE_TEMP_INT_STS | The die temperature is too high, reported by the digital die temperature check. | | | Mismatched cells | CELL_MISMATCH_<br>INT_STS | The voltage difference between cells is too great. | Flags in address,<br>RD_CELL_MSMT | | Dead cell | CELL_DEAD_INT_STS | The dead cell threshold has been reached. | Flags in address,<br>RD_CELL_DEAD | | Open wire | OPEN_WIRE_INT_STS | Open-wire detection is complete. The open-wire interrupt status register must be checked to identify if there are any disconnected wires. | Flags in address,<br>RD_OPENH, RD_OPENL | | VDD | VDD_INT_STS | The VDD rail is below the defined UV threshold. | | | 3V3 | 3V3_INT_STS | The 3.3V rail is below the defined UV threshold. | | | REGIN | REGIN_INT_STS | The REGIN rail is below the defined UV threshold. | | | OTP CRC | OTP_CRC_EVENT_<br>INT_STS | The CRC stored in the OTP does not match the computed CRC value from OTP memory readback. The manual CRC check is completed. | | The interrupt source can be configured using a TYPE selector. Depending on the interrupt, the TYPE selector provides a few options: - Level (high) - Rising edge - Falling edge - Rising and falling edge Each interrupt that is related to a protection flag follows the processes described above. #### Fault In fault mode, both discharge (DSG N-channel MOSFETs and standby P-channel MOSFET) and charge (CHG N-channel MOSFETs) are turned off. Faults can be cleared either by an automatic recovery or manual MCU clearing. The fault enable control bit for each fault has a configurable default value, and the option to permanently lock the register in read-only mode. Table 14 lists certain faults and their recovery methods. Table 15 on page 31 lists additional faults and their recovery methods. Table 14: Fault and Recovery Management (Part I) | | Table 14: Fault and Recovery Management (Part I) | | | | |-------------------------------------|--------------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Fault | Enable Control | Can Be<br>Read-Only? | Recovery Method(s) | | | Cell OV | CELL_OV_<br>FAULT_EN | Yes | Configurable for manual or automatic recovery. Manual recovery: The host MCU writes to the fault clear command (CELL_OV_FAULT_CLR) Automatic recovery: This method is enabled with CELL_OV_REC. An additional recovery logic option is available via CELL_OV_LOGIC_SEL | | | Cell UV | CELL_UV_<br>FAULT_EN | Yes | Configurable for manual or automatic recovery. Note that if the battery pack's current status is charging, then the cell UV fault is blocked, but the status is still reported when V <sub>CELL</sub> < (cell UV threshold). • Manual recovery: The host MCU writes to the fault clear command (CELL_UV_FAULT_CLR) • Automatic recovery: This method is enabled with CELL_UV_REC. An additional recovery logic option is available via CELL_UV_LOGIC_SEL | | | Dead cell | CELL_DEAD_<br>FAULT_EN | Yes | The host MCU writes to the fault clear command (CELL_DEAD_FAULT_CLR). CELL_DEAD_LOG_STS prevents the IC from entering active mode, which can only be cleared by CELL_DEAD_DET_CLEAR. | | | Cell mismatch | CELL_MSMT_<br>FAULT_EN | Yes | The host MCU writes to CELL_MSMT_FAULT_CLR. | | | Open wire | OPEN_WIRE_<br>FAULT_EN | Yes | The host MCU writes to OPEN_WIRE_FAULT_CLR. | | | VTOP OV | VTOP_OV_<br>FAULT_EN_<br>CTRL | Yes | The host MCU writes to VTOP_OV_FAULT_CLR. | | | VTOP UV | VTOP_UV_<br>FAULT_EN_<br>CTRL | Yes | The host MCU writes to VTOP_UV_FAULT_CLR. | | | Cell NTC too<br>hot<br>(discharge) | NTC_CELL_<br>HOT_FAULT_<br>EN | Yes | Configurable for manual or automatic recovery. Manual recovery: The MCU writes to the clear bit (NTC_CELL_HOT_FAULT_CLR) Automatic mode: The device recovers when the NTC voltage (V <sub>NTC</sub> ) exceeds (hot discharge threshold + hysteresis)). This method is enabled with NTC_CELL_DCHG_REC | | | Cell NTC too<br>cold<br>(discharge) | NTC_CELL_<br>COLD_FAULT_<br>EN | Yes | Configurable for manual or automatic recovery. Manual recovery: The MCU writes to the clear bit (NTC_CELL_COLD_FAULT_CLR) Automatic mode: The device recovers when V <sub>NTC</sub> falls below (cold discharge threshold - hysteresis). This method is enabled with NTC_CELL_DCHG_REC | | | | | | Configurable for manual or automatic recovery. | |------------------------------|--------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Cell NTC too<br>hot (charge) | NTC_CELL_<br>HOT_FAULT_<br>EN | Yes | Manual recovery: The MCU writes to the clear bit (NTC_CELL_HOT_FAULT_CLR) Automatic recovery: The device recovers when V <sub>NTC</sub> exceeds (hot charge threshold + hysteresis). This method is enabled with NTC_CELL_CHG_REC. An additional recovery logic option is available via NTC_CHG_REC_MODE | | | | | Configurable for manual or automatic recovery. | | Cell NTC too cold (charge) | NTC_CELL_<br>COLD_FAULT_<br>EN | Yes | <ul> <li>Manual recovery: The MCU writes to the clear bit (NTC_CELL_COLD_FAULT_CLR)</li> <li>Automatic recovery: The device recovers when V<sub>NTC</sub> falls below (cold charge threshold - hysteresis). This method is enabled via NTC_CELL_CHG_REC. An additional recovery logic option is available via NTC_CHG_REC_MODE</li> </ul> | # Table 15: Fault and Recovery Management (Part II) | Fault | Enable Control | Can be<br>Read-Only? | Recovery Method(s) | |------------------------|-----------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Configurable for manual or automatic recovery. This can only be manually cleared when OC_DCHG_RECOVERY_FAILED has issued a report. • Manual recovery: The host MCU writes to the fault clear command | | Pack OC<br>discharge 1 | OC1_DCHG_<br>FAULT_EN | Yes | OC1_DCHG_FAULT_CLR) Automatic recovery: Enabled with OC1_DCHG_REC. This device tries to turn on the MOSFETs to check if the condition is removed. If removed, the device auto-clears the fault status and goes back to safe mode. If the condition is not removed within the time set by OC1_DCHG_RETRY, then the device reports to OC_DCHG_RECOVERY_FAILED. Once the pack drops below 110mV, the device reports to OC_DCHG_RECOVERY_FAILED directly. | | | | | Configurable for manual or automatic recovery. This can only be manually cleared when OC_DCHG_RECOVERY_FAILED has issued a report. | | Pack OC<br>discharge 2 | OC2_DCHG_<br>FAULT_EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (OC2_DCHG_FAULT_CLR)</li> <li>Automatic recovery: Enabled with OC2_DCHG_REC. This device tries to turn on the MOSFETs to check if the condition is removed. If removed, the device auto-clears the fault status and goes back to safe mode. If the condition is not removed within the time set by OC2_DCHG_RETRY, then the device reports to OC_DCHG_RECOVERY_FAILED. Once the pack drops below 110mV, the device reports to OC_DCHG_RECOVERY_FAILED directly.</li> </ul> | | | | | Configurable for manual or automatic recovery. This can only be manually cleared when OC_CHG_RECOVERY_FAILED has issued a report. | | Pack OC<br>charge | OC_CHG_<br>FAULT_EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (OC_CHG_FAULT_CLR)</li> <li>Automatic recovery: Enabled with OC_CHG_REC. This device tries to turn on the MOSFETs to check if the condition is removed. If removed, the device auto-clears the fault status and goes back to safe mode. If the condition is not removed within the time set by OC_CHG_RETRY, then the device reports to OC_CHG_RECOVERY_FAILED.</li> </ul> | | | | | Configurable for manual or automatic recovery. This can only be manually cleared when SC_DCHG_RECOVERY_FAILED has issued a report. | |------------------------------------------------|-------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pack short-<br>circuit<br>current<br>discharge | SC_DCHG_<br>FAULT_EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (SC_DCHG_FAULT_CLR)</li> <li>Automatic recovery: Enabled with SC_DCHG_REC. The device monitors the PACKP voltage to see if it rises to 110mV. If this condition is not removed by SC_PUP_RETRY_N, then the device reports to SC_DCHG_RECOVERY_FAILED.</li> </ul> | | | | | Configurable for manual or automatic recovery. This can only be manually cleared when SC_CHG_RECOVERY_FAILED has issued a report. | | Pack short-<br>circuit<br>current<br>charge | SC_CHG_<br>FAULT_EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (SC_CHG_FAULT_CLR)</li> <li>Automatic recovery: Enabled with SC_CHG_REC. The device monitors the PACKP voltage to see if it falls below (V<sub>TOP</sub> + 270mV). If this condition is not removed within the time set by SC_PUP_RETRY_N, then the device reports to SC_CHG_RECOVERY_FAILED.</li> </ul> | | 3.3V or<br>VDD UV | 3V3_VDD_<br>FAULT_EN | Yes | Manual recovery only. The host MCU writes to the fault clear command (3V3_VDD_FAULT_CLR). | | | | | Configurable for manual or automatic recovery. | | PCB monitor too hot | PCB_MNTR_<br>FAULT_EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (PCB_MNTR_FAULT_CLR)</li> <li>Automatic recovery: The device recovers when the NTC voltage exceeds (monitor hot threshold + hysteresis). This method is enabled with PCB_MNTR_REC.</li> </ul> | | | | | Configurable for manual or automatic recovery. | | Die too hot<br>digital | DIE_TEMP_<br>DIG_FAULT_<br>EN | Yes | <ul> <li>Manual recovery: The host MCU writes to the fault clear command (DIE_TEMP_FAULT_CLR)</li> <li>Automatic recovery: The device waits for the die temperature to drop below (digital temperature threshold - hysteresis). This method is enabled with DIE_TEMP_FAULT_REC.</li> </ul> | | Die too hot analog | N/A; hardcoded enable | N/A | The IC returns to safe mode from shutdown mode once the die temperature drops below (analog temperature threshold - hysteresis). | | Driver turn on fail | N/A; hardcoded enable | N/A | Manual recovery only. The host MCU writes to the fault clear command (DRIVER_FAULT_CLR). | #### **Regulators and Power Domains** There are three main power rails: - REGIN (5V): supplies power to the AFE analog circuitry - 3V3 (3.3V): powers an external MCU - VDD (1.8V): internal use only; powers the digital domain The 3.3V rail can be configured to be on or off in shutdown mode. #### **Open-Wire Detection** The open wire state machine automatically controls the pull-up and pull-down currents sources during open-wire detection, and detects the voltage changes on each cell. The cells that are detected can be set by the CELLS\_CTRL register. The open-wire detection current uses a pair of 100µA pull-up/-down currents. The interval can be configured to be between 1ms and 16ms, with a 1ms resolution. The default is 8ms. The threshold that determines how much change can be accepted for an open circuit is a configurable voltage threshold ranging between 39.06mV and 625mV, with 39.06mV steps. The default is 195mV. The host MCU can trigger open-wire detection with a dedicated command register. If multiple open wires are present simultaneously, then the detection logic reports at least one open wire, which tells the device to avoid using the overall battery pack (see Figure 11 on page 33). Figure 11: Open-Wire Detection Architecture #### **Cell-Balancing** The battery reaches its end of life (EOL) when the capacity of the weakest cell is too low to be usable. Unbalanced cells yield the same effect, with one cell at a higher SOC, and another at a lower SOC. To reduce the effects of the issue, it is critical to balance lithium cells. Unbalanced cells can be caused by cell temperature differences, different self-discharge rates, and general production tolerances that affect cell chemistry and alter aging rates among strings of parallel cells. Cell-balancing can extend the usable life of the battery pack by keeping the voltage of each cell within the defined safe operating area (SOA). #### Internal MOSFET Balancing The MP2796 supports direct cell balancing, without the use of external MOSFETs or BJTs, for currents up to about 58mA (with a 4V cell voltage). The balance current for each cell is dictated by the combined filter resistor and the on resistance of the internal balancing MOSFET ( $R_{(DS)ON}$ ). The MP2796 can simultaneously balance only even or odd cells. Internal logic handles the sequencing between even and odd cells. #### **External Balancing** A balancing current exceeding 58mA can be achieved by adding external balancing MOSFETs or BJTs. This balancing current is limited by board thermals and the wiring resistance. For external MOSFETs, it is also limited by the MOSFETs' $R_{(DS)ON}$ at the appropriate gate voltage ( $V_{GS}$ ). For external BJTs, it may be limited by the $h_{FE}$ . For external MOSFETs, a minimum gate threshold voltage of 1.8V is required (assuming a 4.2V lithium cell) to turn on the balancing MOSFETs. ### Manual Cell-Balancing The cells that need to be balanced are manually marked by writing to the appropriate register (BAL LIST). The balancing time for marked cells can be configured via BAL\_REPETITION, with 0 to 31 repetitions. When BAL\_REPETITION is set to 0, there is only one 30ms execution. The host MCU should periodically read the AFE die temperature to ensure it is within the operating range, as an excessive temperature can lead to over-temperature (OT) shutdown. #### **Automatic Cell-Balancing** Automatic cell-balancing offers the following configurations: - Enable automatic cell balancing by setting the register BALANCE\_MODE\_REG = 1. - Configure the method for initiating automatic cell-balancing via the register BALANCE\_ MODE\_CTRL. The MP2796 can be configured to use register control (BALANCE\_GO) or GPIO3 control to initiate automatic cell-balancing. - 3. Disable constant automatic balancing by setting register AUTO\_BAL\_ALWAYS = 0. The register BAL\_REPETITION sets the number of cell-balancing iterations. The cell-balancing repetition number is ignored if AUTO\_BAL\_ALWAYS = 1, and the device constantly balances the cells until the AUTO\_BAL\_ALWAYS is set to 0, or until the balancing list is empty. - 4. Set the balancing threshold via the register BAL\_MSM\_TH. This is the minimum voltage difference between the current cell voltage and the lowest cell voltage to be eligible for cell balancing. This value ranges between 19.5mV and 87.855mV, with 9.765mV steps. - Set the minimum balancing voltage via the register CELL\_BAL\_MIN. This is the minimum cell voltage for a cell to be eligible for balancing. This value ranges from 2500mV to 4961mV with 39mV steps. Set ABAL\_ON\_CHARGE = 1 to enable automatic cell-balancing when the state of the current is in charge mode. Set ABAL\_ON\_STBY = 1 to enable automatic cell-balancing when the state of the current is in standby mode. If the state of the current is in discharge mode, the automatic cell-balancing will be skipped. The die temperature threshold can be used to prevent or suspend balancing. The MP2796 can be configured to suspend constant automatic cell-balancing (AUTO\_BAL\_ALWAYS = 1), when the die temperature threshold has been exceeded (see STOP\_ON\_HOT). Once the OT condition is removed, the constant automatic cell-balancing will resume Figure 12 shows the cell-balancing list update for automatic cell-balancing. Figure 13 shows the cell-balancing sequence for the cell-balancing list. Figure 12: Automatic Cell-Balancing (Cell Voltage Evaluation) Figure 13: Executing Balancing for Cell in Balancing List ### **Supported Concurrency** Table 16 shows which features can be enabled once a feature is active. When multiple features are enabled simultaneously, some remaining features can still be activated. It is possible to use a high-resolution voltage scan during cell-balancing, but care should be taken, as voltage readings on the cell being balanced and adjacent cells are affected. **Table 16: Supported Concurrencies** | Active<br>Task | Triggered By | Concurrent Features | |----------------------------------------|------------------|------------------------------| | High-<br>resolution<br>voltage<br>scan | ADC_SCAN_<br>GO | Cell-balancing | | Cell-<br>balancing | BALANCE_GO | High-resolution voltage scan | | Open wire | OPEN_WIRE_<br>GO | N/A | The command sequence to the MP2796 should be controlled in the following manner: - During high-resolution voltage scanning, wait to set ADC\_SCAN\_GO = 0 until SCAN\_DONE\_STS or SCAN\_ERROR\_STS updates to 1. - During cell-balancing, wait to set BALANCE\_GO = 0 until BAL\_DONE\_STS or BAL\_ERROR\_STS updates to 1. To stop automatic cell-balancing, set AUTO\_BAL\_ALWAYS = 0, wait until BAL\_DONE\_STS or BAL\_ERROR\_STS updates to 1, and then set BALANCE\_GO = 0. - When conducting open-wire checks, wait to set OPEN\_WIRE\_GO = 0 until OPEN\_WIRE\_DONE\_STS or OPEN WIRE ERR STS updates to 1. For these command sequences, the status can be determined via polling or via interrupts (VSCAN\_DONE\_INT\_STS, BAL\_DONE\_INT\_STS, and OPEN\_WIRE\_INT\_STS). See to the Interrupts section on page 28 for more details. # High-Resolution Voltage ADC Scan for the MCII A voltage scan can convert the following classes of inputs: Die temperature voltage - NTC1, NTC2, NTC3, and NTC4 voltages - Cell voltages - VTOP pin voltage - PACKP pin voltage - GPIO voltages (GPIO1, GPIO2, and GPIO3) - Regulators (VDD [1.8V], 3V3, and REGIN) If a class of inputs is not enabled, the scan skips to the next class. Control bits are provided to enable individual channels in each class. The device is notified when the scan is complete, and the results are available for readback. ### **High-Resolution Current Reading** The current is measured via an external currentsense resistor between SRP and SRN. It is synchronized with the VTOP channel conversion, which can be enabled using VTOP SYNC EN. ### Non-Volatile Memory (NVM) Configuration The default values of most registers can be configured through the non-volatile memory (NVM). Some registers are one-time programmable (OTP), while others are multiple-time programmable (MTP). The MTP registers can be programmed up to three times. These values can be locked, so that the same version of the IC can be adjusted for similar projects with minor differences. To configure the MTP, apply 7.5V to the NSHDN pin and follow the steps below: - 1. Ensure that the NSHDN pin is set to 7.5V. - 2. Write the appropriate value to the register that allows MTP. - 3. Write prior to the store command with the following command access code: 0xA5B6 (REG0xB9 = 0xA5B6). - Send the command to store the register's current value to the NVM by writing 1 to STORE\_NVM\_CMD (0xB8, bit[3]). - 5. Wait for STORE\_IN\_PROGRESS to go back to 0. - Recover the NSHDN pin to 3.3V. MP2796 Rev. 1.0 5/9/2023 #### I<sup>2</sup>C INTERFACE The MP2796 can use an I<sup>2</sup>C interface to flexibly set parameters and report device statuses instantaneously. The I<sup>2</sup>C is a two-wire serial interface with two bus lines: a serial data line (SDA) and a serial clock line (SCL). Both SDA and SCL are open drains, and they must be connected to the positive supply voltage via a pull-up resistor. The IC operates as a slave device that receives control inputs from the master device, such as a microcontroller (MCU). The SCL is always driven by the master device. The I<sup>2</sup>C interface supports both standard mode (up to 100kbit/s) and fast mode (up to 400kbit/s). All transactions begin with a start (S) command and are terminated by a stop (P) command. Start and stop commands are always generated by the master. A start command is defined as a high-to-low transition on the SDA while the SCL is high. A stop command is defined as a low-to-high transition on the SDA while the SCL is high (see Figure 14). Figure 14: Start and Stop Commands For data validity, the data on the SDA must be stable during the high period of the clock. The high or low state of the SDA can only change when the clock signal on the SCL is low (see Figure 15). Every byte on the SDA must be 8 bits long. The number of bytes that can be transmitted per transfer is unrestricted. Data is transferred with the most significant bit (MSB) first. Figure 15: Bit Transfer on the I<sup>2</sup>C Bus Each byte must be followed by an acknowledge (ACK) bit, which is generated by the receiver to signal to the transmitter that the byte was successfully received. The ACK signal occurs when the transmitter releases the SDA line during the acknowledge clock pulse. This allows the receiver to pull the SDA line low. The SDA line stays low during the high period of the ninth clock. If the SDA line is high during the 9th clock pulse, this is defined as a not acknowledge (NACK) signal. The master can then generate either a stop command to abort the transfer, or a repeated start (Sr) command to start a new transfer. After the start command, a slave address is sent. This address is 7 bits long, followed by an 8th data direction bit (R/W). A 0 indicates a transmission (write), and a 1 indicates a request for data (read). Figure 16 shows the address bit arrangement. Figure 16: 7-Bit Address Figure 17 shows a data transfer on the I<sup>2</sup>C bus. Figure 17: Data Transfer on the I<sup>2</sup>C Bus #### I<sup>2</sup>C Read When CRC is enabled, the payload is limited to 2 bytes by default (see Figure 18 on page 38). This value can be increased to 63 words (126 bytes) using the XFR\_NUM\_RD\_WORDS register. XFR\_NUM\_RD\_WORDS retains the new value only for the next transaction, so ensure that the next transaction uses the increased payload count. ### CRC in an fC Read Transaction After completing the request for a read transaction, the host MCU must ensure that the CRC matches the value provided in the read transaction to confirm that no bits were corrupted during the transmission. The CRC-8 algorithm follows the polynomial $(1 + x^1 + x^2 + x^8)$ , and is applied byte-wise to the bytes, following the order in which the bytes are transmitted or received. If it were bit-wise, the MSB would be processed first in each byte. An example of this sequence is shown below: - 1. Slave address byte + write (0x02) - 2. Register address byte (0x00) - 3. Slave address byte + read (0x03) - 4. Register address byte (0x00) - 5. Word 1 byte 1 / bits[7:0] (0x7C) - 6. Word 1 byte 2 / bits[15:8] (0x00) This sequence results in CRC = 0x36 being appended as the last CRC byte. Although this byte of the fourth sequence does not exist in the actual read sequence, it must be added in the CRC calculation. ### I<sup>2</sup>C Write Figure 19 on page 38 shows how the byte is ordered in a write transaction. When CRC is enabled, the targeted register address is modified according to payload only if the CRC results match. ### CRC in an PC Write Transaction The CRC-8 algorithm follows the polynomial $(1 + x^1 + x^2 + x^8)$ , and is applied byte-wise to the bytes following the order in which they are transmitted or received. If it were bit-wise, the MSB would first be processed in each byte. An example of this sequence is shown below: - 1. Slave address byte + write (0x02) - 2. Register address byte (0x00) - 3. Word 1 byte 1 / bits[7:0] (0x7C) - 4. Word 1 byte 2 / bits[15:8] (0x00) This sequence results in CRC = 0x72, which the host MCU should append as the last CRC byte to ensure a successful transaction. Figure 18: I<sup>2</sup>C Single Address Read Figure 19: I<sup>2</sup>C Write Transaction ### Serial Peripheral Interface (SPI) The MP2796 has an interface that is compatible with serial peripheral interfaces (SPIs). This interface is configured to operate using clock phase (CPHA) = 1 and clock polarity (CPOL) = 1. Consequently, data on SDI must be stable during SCK's rising edge. Words are transferred with most significant bit (MSB) first. During a write transaction, the data value on SDI is latched to the device on SCK's rising edge. During a read transaction, the bit stream is presented on SDO with the MSB first, and is valid during SCK's rising edge, while the SDO transitions on SCK's falling edge. nCS must remain low for the entire command sequence duration, including the time between the command byte and subsequent data. During a write command, data is latched on nCS's rising edge (see Figure 20 on page 40). ### **SPI Data Protocol** For a successful SPI transaction, nCS must go low and there must be a successful match between the transaction slave address and the internally configured slave address (located in register DEVICE\_ADD). The MP2796's SPI requires a specific transaction structure. ### SPI Read Read transactions should have the fields arranged with a matching order for the slave address, read bit, register address, and data payload (see Figure 21 on page 40). When CRC is enabled, the payload is limited to two bytes by default. This value can be increased to 63 words (126 bytes) using the XFR\_NUM\_RD\_WORDS register. XFR\_NUM\_RD\_WORDS retains the new value only for the next transaction, so ensure that the next transaction uses the increased payload count. ### CRC in an SPI Read Transaction After completing the request for a read transaction, the host MCU must ensure that the CRC matches the value provided in the read transaction to confirm that no bits were corrupted during the transmission. The CRC-8 algorithm follows the polynomial $(1 + x^1 + x^2 + x^8)$ , and is applied byte-wise to the bytes, following the order in which bytes are transmitted or received. If it were bit-wise, the MSB would first be processed in each byte. An example of this sequence is shown below: - 1. Slave address byte + read (0x03) - 2. Register address byte (0x00) - 3. Word 1 byte 1 / bits[7:0] (0x7C) - 4. Word 1 byte 2 / bits[15:8] (0x00) This sequence results in CRC = 0x64 being appended as the last CRC byte. ### SPI Write Write transactions should have the fields arranged with a slave address, write bit, register address, and data payload (see Figure 22 on page 41). When CRC is enabled, the SPI write payload is limited to 2 bytes and targeted register addresses are modified according to the payload only if the CRC matches. #### CRC in an SPI Write Transaction The CRC-8 algorithm follows the polynomial $(1 + x^1 + x^2 + x^8)$ , and is applied byte-wise to the bytes following the order in which they are transmitted or received. If it were bit-wise, the MSB would first be processed in each byte. An example of this sequence is shown below: - 1. Slave address byte + write (0x02) - Register address byte (0x00) - 3. Word 1 byte 1 / bits[7:0] (0x7C) - 4. Word 1 byte 2 / bits[15:8] (0x00) This sequence results in CRC = 0x72, which the host MCU should append as the last CRC byte to ensure a successful transaction. Figure 20: SPI Signal Sequencing ## SPI Read without CRC: 1 Word (2 Bytes) ## SPI Read with CRC: 1 Word (2 Bytes) Payload ## SPI Read with CRC: 2 Words (4 Bytes) Payload Figure 21: SPI Read Transaction # SPI Write without CRC: 1 Word (2 Bytes) # SPI Write with CRC: 1 Word (2 Bytes) Figure 22: SPI Write Transaction ## **REGISTER MAP** The default slave address is 01h. The address can be configured by modifying DEVICE\_ADD (register 0xA3, bits[14:8]). Once the value has been changed, the next communication should use the new address. Note that the default address may be different for the chips with different "xxxx" suffixes. All the bits in an address that are not populated by a register should be treated as reserved bits. Their values should not be modified during write operations that are meant to change bits in the same address. This register map is organized by functions, which means registers that are located at the same address may be in different sections. However, the role of each bit in a given address can be used to learn more about other registers that are located in the same address. ## **Cell Configuration** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Reset Value<br>(OTP/MTP) | Encoding,<br>LSB, and<br>Range | |---------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------|--------------------------------| | CELLS_CTRL:<br>0x00 | Bits[3:0]:<br>CELL_S_CTRL | Sets the number of stacked cells in use. 0x0: Cells 7~1 enabled 0x1: Cells 7~1 enabled 0x2: Cells 7~1 enabled 0x3: Cells 7~1 enabled 0x3: Cells 7~1 enabled 0x4: Cells 7~1 enabled 0x5: Cells 7~1 enabled 0x6: Cells 7~1 enabled 0x6: Cells 7~1 enabled 0x7: Cells 8~1 enabled 0x8: Cells 9~1 enabled 0x9: Cells 10~1 enabled 0xA: Cells 11~1 enabled 0xB: Cells 12~1 enabled 0xC: Cells 13~1 enabled 0xC: Cells 13~1 enabled 0xC: Cells 15~1 enabled 0xE: Cells 15~1 enabled 0xF: Cells 15~1 enabled | R/W (can<br>lock to<br>read-only) | 0xF (MTP) | N/A | ### **IC State Control** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Reset Value<br>(OTP/MTP) | Encoding,<br>LSB, and<br>Range | |---------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|--------------------------------| | PWR_STATUS:<br>0x01 | Bits[4:0]:<br>PWR_STATE | Returns the power state status. 0x01: Safe mode 0x02: Standby mode 0x04: Active mode 0x08: Fault mode 0x10: Recovery mode | Read-only | 0x01 | N/A | | PWR_STATUS:<br>0x01 | Bits[9:7]:<br>PACK_<br>CURRENT_<br>STATUS | Returns the pack current status. 0x1: The battery pack current is discharging 0x2: The battery pack current is in standby range, meaning it is within ±STBY_CUR_TH 0x4: The battery pack current is charging | Read-only | 0x2 | N/A | | | | | | | • | |---------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-----------------| | STB_STATUS:<br>0x02 | Bit[0]:<br>STBY_STATE | Reports the on/off setting for standby mode. If off, the AFE does not transition to standby mode from active mode, regardless of whether the current level is in the standby mode range. | Read-only | 0x0 | 0: Off<br>1: On | | STB_STATUS: 0x02 | Bit[6]:<br>DSG_PFET_<br>SYNC | Reports whether the SBYDSG driver is on or off. | Read-only | 0x0 | 0: Off<br>1: On | | STB_STATUS: | Bits[10:8]: | Reports the voltage comparison result between PACKP and VTOP. The exact voltage level for the transition can be slightly different based on the direction of the transition and the applied hysteresis. | | | | | 0x02 | PACKP_COMP_<br>STS | 0x4: VPACKP > VVTOP + 270mV 0x3: The PACKP comparator is invalid 0x2: VVTOP + 160mV > VPACKP > VVTOP - 1V 0x1: VPACKP < VVTOP - 1.6V 0x0: The comparison result is not available | Read-only | 0x0 | N/A | | ACT_CFG:<br>0x05 | Bit[0]:<br>FET_SRC | Defines the source that enables the MOSFETs and switches to active mode. The CHG and DSG MOSFETs are controlled by the host MCU, via either register or pin. 0: Register control 1: GPIO (GPIO1 or GPIO1 and | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | ACT_CFG:<br>0x05 | Bit[1]:<br>FET_CFG | GPIO2 depending on FET_CFG) Selects the CHG and DSG MOSFET control logic. 0: Simple mode. The internal logic automatically determines the turnon/-off sequencing 1: Direct mode. In direct mode with pin control, GPIO1 controls the DSG MOSFET and GPIO2 controls the CHG MOSFET. When direct mode is selected and faults are enabled, the IC still uses the internal logic to turn off the MOSFETs | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | ACT_CFG:<br>0x05 | Bits[4:3]:<br>ACTIVE_<br>CTRL | When FET_SRC = 0 and FET_CFG = 0: 0x0: All MOSFETs are off 0x1: CHG and DSG turn on 0x2: All MOSFETs are off 0x3: CHG and DSG turn on When FET_SRC = 0 and FET_CFG = 1: 0x0: All MOSFETs are off 0x1: DSG turns on 0x2: CHG turns on 0x3: CHG and DSG turn on | R/W | 0x0 (OTP) | N/A | | ACT_CFG:<br>0x05 | Bit[9]:<br>FT_STATE_SEL | 0: Rising edge 1: Level When this bit is set to 0, the MOSFETs transition to start-up via a control source (depending on FET_SRC), which is disabled then enabled. When this bit is set to 1, the MOSFETs start up depending on the control source status. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | |-------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|------------------------------------------------------| | STB_CFG:<br>0x06 | Bit[0]:<br>STBY_STATE_<br>EN | Enables or disables standby mode.<br>When disabled, the device cannot<br>enter standby mode. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | STB_CFG:<br>0x06 | Bits[2:1]:<br>STBY_CUR_TH | Sets the standby comparator current threshold. | R/W | 0x0 (OTP) | 0x0: 250μV<br>0x1: 375μV<br>0x2: 500μV<br>0x3: 625μV | | STB_CFG:<br>0x06 | Bit[3]:<br>STBY_HYS | Enables the digital hysteresis on the standby current comparator. 1: Enabled 0: Disabled | R/W | 0x0 (OTP) | N/A | | STB_CFG:<br>0x06 | Bits[5:4]:<br>STBY_<br>MONITOR_CFG | Selects the interval used for voltage protection monitoring to refresh the ADC reading while in standby or safe mode: 0x0: Voltage protection readings are refreshed every 254ms 0x1: Voltage protection readings are refreshed every 492ms 0x2: Voltage protection readings are refreshed every 968ms 0x3: Not allowed | R/W (can<br>lock to<br>read-only) | 0x2 (OTP) | N/A | | STB_CFG:<br>0x06 | Bit[6]:<br>STBY_PFET_EN | Enables the P-channel MOSFET in standby mode when ENABLE_REG_CFG is set to simple mode. To control the standby MOSFET in direct mode, use P_FET_MANUAL setting together with P_FET_MAN_CTRL to turn the driver on and off. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | SAFE_CFG:<br>0x07 | Bit[0]:<br>PROTECT_IN_<br>SAFE_CFG | Enables voltage protection monitoring in safe mode Disables voltage protection monitoring in safe mode | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | SAFE_CFG:<br>0x07 | Bit[1]:<br>SAFE_SCOC_<br>EN | Enables short-circuit (SC) and over-<br>current (OC) monitoring, even in<br>safe mode. This function is disabled<br>by default, since the MOSFETs are<br>disabled in safe mode. If enabled,<br>current consumption increases. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | SAFE_CFG:<br>0x07 | Bit[3]:<br>ACTIVE_<br>MONITOR_CFG | Selects the interval used for voltage protection monitoring to refresh the ADC reading in active mode. 0x0: Voltage protection readings are refreshed every 254ms 0x1: Voltage protection readings are refreshed every 135ms | R/W | 0x0 | N/A | |-----------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | RGL_CFG:<br>0x08 | Bit[2]:<br>V3P3_SHDN_<br>EN | Enables the 3.3V regulator during shutdown mode. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | RGL_CFG:<br>0x08 | Bit[3]:<br>V3P3_SHOFF_<br>STS | Reports the internal enable/disable control for the 3.3V regulator during shutdown mode. When enabled, the 3.3V rails stay on even in shutdown mode. | Read-only | 0x1 | 0: Disabled<br>1: Enabled | | LOAD_<br>CHARGER_<br>CFG:<br>0x09 | Bit[15]:<br>PACKP_CMP_<br>EN | Enables the PACKP vs. VTOP comparator. When disabled, the comparator can still be internally enabled for other functions, such as short-circuit removal detection. | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | ## **Pins and GPIO** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------|-------------------------------| | GPIO_<br>STATUS:<br>0x0A | Bit[0]:<br>GPIO1 | Reports the GPIO1 pin status (high/low). | Read-only | 0x1 | 0: Low<br>1: High | | GPIO_<br>STATUS:<br>0x0A | Bit[1]:<br>GPIO2 | Reports the GPIO2 pin status (high/low). | Read-only | 0x1 | 0: Low<br>1: High | | GPIO_<br>STATUS:<br>0x0A | Bit[2]:<br>GPIO3 | Reports the GPIO3 pin status (high/low). | Read-only | 0x1 | 0: Low<br>1: High | | GPIO_OUT:<br>0x0B | Bit[0]:<br>GPIO1_O | Sets the target output level for GPIO1 (high or low). This bit is effective only when GPIO1 is used as a digital output (GPIO1_IO is set to output). | R/W | 0x0 (OTP) | 0: Low<br>1: High | | GPIO_OUT:<br>0x0B | Bit[1]:<br>GPIO2_O | Sets the target output level for GPIO2 (high or low). This bit is effective only when GPIO2 is used as a digital output (GPIO2_IO is set to output). | R/W | 0x0 (OTP) | 0: Low<br>1: High | | GPIO_OUT:<br>0x0B | Bit[2]:<br>GPIO3_O | Sets the target output level for GPIO3 (high or low). This bit is effective only when GPIO3 is used as a digital output (GPIO3_IO is set to output). | R/W | 0x0 (OTP) | 0: Low<br>1: High | | GPIO_CFG:<br>0x0C | Bit[0]:<br>GPIO1_IO | Defines the direction for GPIO1. 0: Output 1: Input | R/W (can lock to read-only) | 0x1 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[1]:<br>GPIO1_TYPE | Defines the type of input for GPIO1. 0: Digital input 1: Buffered ADC input, 3.3V range | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[2]:<br>GPIO1_PUP | Enables the GPIO1 pull-up capability. When enabled, a 20kΩ pull-up resistor is applied to GPIO1. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |-------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | GPIO_CFG:<br>0x0C | Bit[4]:<br>GPIO2_IO | Defines the direction for GPIO2. 0: Output 1: Input | R/W (can lock to read-only) | 0x1 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[5]:<br>GPIO2_TYPE | Defines the input type for GPIO2. 0: Digital input 1: Buffered ADC input, 3.3V range | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[6]:<br>GPIO2_PUP | Enables the GPIO2 pull-up capability. When enabled, a 20kΩ pull-up resistor is applied to GPIO2. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | GPIO_CFG:<br>0x0C | Bit[8]:<br>GPIO3_IO | Defines the direction for GPIO3. 0: Output 1: Input | R/W (can lock to read-only) | 0x1 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[9]:<br>GPIO3_TYPE | Defines the input type for GPIO3. 0: Digital input 1: Buffered ADC input, 3.3V range | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | GPIO_CFG:<br>0x0C | Bit[10]:<br>GPIO3_PUP | Enables the GPIO3 pull-up capability. When enabled, a 20kΩ pull-up resistor is applied to GPIO3. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | GPIO_CFG:<br>0x0C | Bit[11]:<br>GPIO3_FSEL | 0: GPIO 1: Fault indicator. Valid when GPIO3 is set to be an output | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | PINS_CFG:<br>0x0D | Bit[0]:<br>ALERT_POL | O: Active low. xAlert goes low when an interrupt is pending Active high. xAlert goes high when an interrupt is pending | R/W (can lock to read-only) | 0x1 (OTP) | N/A | | PINS_CFG:<br>0x0D | Bit[5]:<br>WDT_RPT | When enabled, a bite event triggers the WDT pin to toggle a high pulse. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | PINS_CFG:<br>0x0D | Bit[6]:<br>WDT_RST_EN | Enables the WDT pin to reset the MP2796 back to its factory settings. When disabled, a WDT pulse caused by a watchdog bite does not trigger a reset. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | PINS_CFG:<br>0x0D | Bit[8]:<br>GPIO_LV_CFG | Sets the GPIO1~3 pull-up voltage. 0: 3V3 1: REGIN | R/W (can lock to read-only) | 0x0 (OTP) | N/A | # **Watchdog Functions** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------| | WDT_STATUS:<br>0x0E | Bit[0]:<br>WDT_BARKED | Indicates whether the bark timer has expired and a bark event has occurred. | Read-only | 0x0 | 0: False<br>1: True | | WDT_STATUS:<br>0x0E | Bit[1]:<br>WDT_BITE | Indicates whether the bite timer has expired and a bite event has occurred. This event toggles the WDT pin, if WDT_RPT is set to enable. | Read-only | 0x0 | 0: False<br>1: True | | WDT_RST:<br>0x0F | Bit[0]:<br>WDT_RST | Writing 1 to this bit resets the watchdog timer counter, and clears WDT_BITE and WDT_BARKED. This is a self-clearing register. | Write-only | 0x0 | 1: Reset the counter and clear the bits | |------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|---------------------------------------------------| | WDT_CFG:<br>0x10 | Bit[0]:<br>WDT_COM_<br>CTRL | Enables watchdog communication. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | WDT_CFG:<br>0x10 | Bits[8:2]:<br>WDT_BARK_<br>CFG | Configures the watchdog bark timeout. The bark setting defines the delay from the last watchdog reset to the bark. | R/W (can lock to read-only) | 0x4F (OTP) | LSB: 25ms<br>RNG: 25ms to<br>3200ms<br>0x00: 25ms | | WDT_CFG:<br>0x10 | Bits[15:9]:<br>WDT_BITE_CFG | Configures the watchdog bite timeout. The bite setting defines the delay from the bark to the bite. | R/W (can lock to read-only) | 0x77 (OTP) | LSB: 25ms<br>RNG: 25ms to<br>3200ms<br>0x00: 25ms | ## **MOSFET Driver** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------|-------------------------------| | FET_STATUS:<br>0x11 | Bit[0]:<br>CHG_DRV | Reports whether the CHG driver is on or off. | Read-only | 0x0 | 0: Off<br>1: On | | FET_STATUS:<br>0x11 | Bit[1]:<br>DSG_DRV | Reports whether the DSG driver is on or off. | Read-only | 0x0 | 0: Off<br>1: On | | FET_STATUS:<br>0x11 | Bit[2]:<br>SBYDSG_DRV | Reports whether the SBYDSG driver is on or off. | Read-only | 0x0 | 0: Off<br>1: On | | FET_STATUS:<br>0x11 | Bit[3]:<br>FET_TIMEOUT | When true, an issue was detected during the latest turn-on attempt. | Read-only | 0x0 | 0: False<br>1: True | | FET_STATUS:<br>0x11 | Bit[8]:<br>CHG_DRV_<br>TRANS | The CHG driver is changing states The CHG driver is settled (off or at its target voltage) | Read-only | 0x0 | N/A | | FET_STATUS:<br>0x11 | Bit[9]:<br>DSG_DRV_<br>TRANS | The DSG driver is changing states The DSG driver is settled (off or at its target voltage) | Read-only | 0x0 | N/A | | FET_STATUS:<br>0x11 | Bit[10]:<br>SBYDSG_DRV_<br>TRANS | The SBYDSG driver is changing states The SBYDSG driver is settled (off or at its target voltage) | Read-only | 0x0 | N/A | | FET_STATUS:<br>0x11 | Bit[11]:<br>CP_STS | Indicates the charge pump's status (on or off). | Read-only | 0x0 | 0: Off<br>1: On | | FET_CTRL:<br>0x12 | Bit[0]:<br>P_FET_MAN_<br>CTRL | Turns the SBYDSG MOSFET driver on and off. To use this bit, P_FET_MANUAL must be enabled, and the IC must be in direct mode. | R/W | 0x0 (OTP) | 0: Off<br>1: On | | FET_MODE:<br>0x13 | Bit[0]:<br>DSG_SOFTON_<br>EN | Enables soft start for the DSG MOSFET driver. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | FET_MODE:<br>0x13 | Bit[3]: FET_ON_<br>RUN_SC_DET_<br>EN | Enables the short-circuit detection sequence prior to the MOSFET turning on. If detection is enabled and the device detects that PACKP is shorted to ground, then a MOSFET driver fault is generated. The associated MOSFET driver bit can be manually cleared with DRIVER_FAULT_CLR. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |-------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|------------------------------------------------------| | FET_MODE:<br>0x13 | Bit[4]:<br>CHG_SOFTON_<br>EN | 0: CHG soft start disabled 1: CHG soft start enabled | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | FET_MODE:<br>0x13 | Bits[7:5]:<br>TURNON_<br>TIMEOUT | Sets the MOSFET turn-on timeout delay. Applies to both the CHG and DSG MOSFETs. This function is paused during soft start (SS). | R/W | 0x0 (OTP) | LSB: 20ms<br>RNG: 40ms to<br>180ms<br>0: 40ms | | FET_MODE:<br>0x13 | Bit[8]:<br>CHG_TURNON_<br>TIMER | Changes the CHG SS timeout. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: 25ms<br>1: 50ms | | FET_MODE:<br>0x13 | Bit[9]:<br>TURNON_<br>TIMEOUT_<br>FAULT | O: A fault is not triggered after turn- on timeout 1: A fault is triggered after turn-on timeout | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FET_MODE:<br>0x13 | Bit[11]:<br>CHG_SOFTON_<br>OC_LIM | Sets the over-current (OC) threshold that is only applicable when the CHG undergoes SS. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: 3.6mV<br>1: 4.8mV | | FET_MODE:<br>0x13 | Bit[12]: P_FET_<br>MANUAL | Enables the manual control of the P-channel MOSFET, only effective when direct mode is enabled (FET_CFG = 1). When this bit is enabled, P_FET_MAN_CTRL can be used to control the SBYDSG driver. | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FET_CFG:<br>0x14 | Bits[2:0]:<br>DSG_SOFTON_<br>DV | Sets the discharge MOSFET turn-<br>on slope. 3'b000: 0.1V/ms 3'b001: 0.2V/ms 3'b010: 0.4V/ms 3'b011: 0.6V/ms 3'b100: 0.8V/ms 3'b101: 1.0V/ms 3'b110: 1.2V/ms 3'b111: 1.6V/ms | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | N/A | | FET_CFG:<br>0x14 | Bits[5:4]:<br>STBY_SC_<br>CUR_TH | Sets the standby comparator current threshold, which acts as a protection again excessive current while the DSG N-channel MOSFET ramps up during SS. | R/W | 0x3 (OTP) | 0x0: 250μV<br>0x1: 375μV<br>0x2: 500μV<br>0x3: 625μV | | FET_CFG:<br>0x14 | Bits[8:6]:<br>RAMP_UP_<br>SC_GF | Deglitch filter for the standby comparator current threshold when DSG N-channel MOSFET is ramping up during SS. 3'b000: 100µs 3'b001: 200µs 3'b010: 400µs 3'b100: 1200µs 3'b100: 2400µs 3'b111: 2400µs 3'b111: 2400µs | R/W | 0x3 (OTP) | N/A | |------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-------------------------------------------------------------------------------------------| | FET_CFG:<br>0x14 | Bits[11:9]:<br>CHG_SOFTON_<br>PUP | Sets the pull-up current values during CHG MOSFET SS. | R/W (can lock to read-only) | 0x4 (MTP) | LSB: 1µA,<br>RNG: 3µA to<br>10µA<br>0x0: 3µA | | FET_CFG:<br>0x14 | Bits[14:12]:<br>FET_DRV_LVL | Defines V <sub>GS</sub> for the CHG and DSG MOSFETs. | R/W (can<br>lock to<br>read-only) | 0x3 (OTP) | 0x0: 7V<br>0x1: 8V<br>0x2: 9V<br>0x3: 10V<br>0x4: 11V<br>0x5: 12V<br>0x6: 12V<br>0x7: 12V | ## Interrupt | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|--------------------------------| | RD_INT0:<br>0x15 | Bit[0]:<br>CELL_OV_INT_<br>STS | Reports whether an interrupt related to a cell over-voltage (OV) event has been detected. The flags located in RD_CELL_OV should be checked to identify which cell caused the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[1]:<br>CELL_UV_INT_<br>STS | Reports whether an interrupt related to a cell under-voltage (UV) event has been detected. The flags located in RD_CELL_UV should be checked to identify which cell caused the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[2]:<br>VTOP_UV_INT_<br>STS | Reports whether a UV interrupt related to the battery stack positive terminal (VTOP) has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[3]:<br>VTOP_OV_INT_<br>STS | Reports whether an OV interrupt related to the battery stack positive terminal (VTOP) has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[4]:<br>OVER_CURR_<br>INT_STS | Reports whether an interrupt related to an over-current (OC) event has been detected. This signal is generated by combining the interrupt detection for discharge OC and charge OC. OC1_DCHG_STS, OC2_DCHG_STS, and OC_CHG_STS should be checked to identify the source of the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | T | ı | | 1 | |------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_INT0:<br>0x15 | Bit[5]:<br>SHORT_CURR_<br>INT_STS | Reports whether an interrupt related to a short-circuit event has been detected. This signal is generated by combining the interrupt detection for discharge short-circuit and charge short-circuit. SC_CHG_STS and SC_DCHG_STS should be checked to identify the source of the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[6]:<br>NTC_COLD_<br>INT_STS | Reports whether an interrupt related to an NTC cold event has been detected. This signal is generated combining the interrupt detection for all 4 NTC channels. NTC1_CELL_COLD_STS, NTC2_CELL_COLD_STS, NTC3_CELL_COLD_STS, and NTC4_CELL_COLD_STS should be checked to identify the source of the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[7]:<br>NTC_HOT_INT_<br>STS | Reports whether an interrupt related to an NTC hot event has been detected. This signal is generated by combining the interrupt detection for all 4 NTC channels. NTC1_CELL_HOT_STS, NTC2_CELL_HOT_STS, NTC3_CELL_HOT_STS, and NTC4_CELL_HOT_STS should be checked to identify the source of the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[8]:<br>WDT_INT_STS | Reports whether an interrupt related to watchdog communication has been detected. A watchdog bark and a watchdog bite event can both trigger a watchdog event interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[9]:<br>RECOVERED_<br>INT_STS | Reports whether an interrupt related to fault recovery event has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[10]:<br>AFE_MODE_<br>CHANGE_<br>INT_STS | Reports whether an interrupt related to an AFE mode change has been detected. A mode change is a change between any of the operating modes (e.g. safe, fault, active, standby). | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[11]:<br>VSCAN_DONE_<br>INT_STS | Reports whether an interrupt related to a high-resolution voltage scan has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT0:<br>0x15 | Bit[14]:<br>PACK_<br>CURRENT_INT_<br>STS | Reports whether an interrupt related to a battery pack current change has been detected. The pack current changes when switching between discharge, standby, and charge mode, which is reported in PACK_CURRENT_STATUS. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[0]:<br>OTP_CRC_<br>EVENT_INT_<br>STS | Reports whether an interrupt related to a one-time-programmable (OTP) memory CRC fault has been detected. When enabled, this interrupt can be triggered by the following conditions: The OTP CRC calculation fails while restoring the OTP OTP CRC is manually triggered using OTP_CRC_DO. In this scenario, an interrupt event is generated when a CRC check is completed (for either passing or failing) | Read-only | 0x0 | 0: Not detected<br>1: Detected | |------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_INT1:<br>0x16 | Bit[1]:<br>REGIN_INT_<br>STS | Reports whether an interrupt related to a UV condition on REGIN has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[2]:<br>3V3_INT_STS | Reports whether an interrupt related to a UV condition on 3V3 has been detected. This is triggered by monitoring the 3V3 ADC or the 3.3V analog comparator. The 3.3V UV analog comparator is always enabled, so when 3V3_INT_EN is enabled, it can trigger an interrupt even if 3V3_EN is disabled. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[3]:<br>VDD_INT_STS | Reports whether an interrupt related to a UV condition on VDD has been detected. A VDD UV event can be triggered by either ADC voltage monitoring or the VDD UV comparator. The VDD analog comparator is always enabled, so when VDD_INT_EN is enabled, it can trigger an interrupt even if VDD_EN is disabled. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[4]:<br>OPEN_WIRE_<br>INT_STS | Reports whether an interrupt related to an open-wire event has been detected. The open wire status registers (located at the RD_OPENH and RD_OPENL addresses) must be checked to determine whether there are disconnected wires. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[5]:<br>CELL_DEAD_<br>INT_STS | Reports whether an interrupt related to a dead cell has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[6]:<br>CELL_<br>MISMATCH_<br>INT_STS | Reports whether an interrupt related to a cell mismatch has been detected. Flags in the RD_CELL_MSMT and CELL_MSMT_LOWER registers should be read to identify the cells triggering the event. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | D:4[7]. | Denomber whether on intermediated | | | | |-------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|--------------------------------| | RD_INT1:<br>0x16 | Bit[7]: DIE_TEMP_INT_ STS | Reports whether an interrupt related to a digital die temperature event has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[8]:<br>PCB_MNTR_<br>HOT_INT_STS | Reports whether an interrupt related to the NTC hot PCB monitor has been detected. NTC1_PCB_MNTR_HOT_STS, NTC2_PCB_MNTR_HOT_STS, NTC3_PCB_MNTR_HOT_STS, and NTC4_PCB_MNTR_HOT_STS should be checked to identify which NTC caused the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[9]:<br>FSM_ERROR_<br>INT_STS | Reports whether an interrupt related to a scheduler error event has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[10]:<br>SELF_TEST_<br>INT_STS | Reports whether an interrupt related to an ADC self-diagnostic event has been detected. The SELF_TEST_STS_OV and SELF_TEST_STS_UV flags should be checked to identify the cause of the interrupt. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[11]:<br>BAL_DONE_<br>INT_STS | Reports whether an interrupt related to a cell-balancing done event has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[12]:<br>PACKP_V_INT_<br>STS | Reports whether an interrupt related to a PACKP voltage change event has been detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_INT1:<br>0x16 | Bit[13]:<br>FET_DRIVER_<br>INT_STS | Reports whether an interrupt related to a MOSFET driver error has been detected. MOSFET driver errors cover the following conditions: MOSFET timeout An issue detected during a short-circuit or OC fault clearing sequence An issue during CHG or DSG SS, such as a short-circuit or an OC condition | Read-only | 0x0 | 0: Not detected<br>1: Detected | | INTO_CLR:<br>0x17 | Bit[0]:<br>CELL_OV_INT_<br>CLEAR | Write 1 to this bit to clear a cell OV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[1]:<br>CELL_UV_INT_<br>CLEAR | Write 1 to this bit to clear a cell UV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[2]:<br>VTOP_UV_INT_<br>CLEAR | Write 1 to this bit to clear a battery pack UV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[3]:<br>VTOP_OV_INT_<br>CLEAR | Write 1 to this bit to clear a battery pack OV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[4]:<br>OVER_CURR_<br>INT_CLEAR | Write 1 to this bit to clear an OC interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT0_CLR:<br>0x17 | Bit[5]:<br>SHORT_CURR_<br>INT_CLEAR | Write 1 to this bit to clear a short-circuit interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | |-------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------|-----|------------------------| | INTO_CLR:<br>0x17 | Bit[6]:<br>NTC_COLD_<br>INT_CLEAR | Write 1 to this bit to clear an NTC cold cell monitor interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[7]:<br>NTC_HOT_INT_<br>CLEAR | Write 1 to this bit to clear an NTC hot cell monitor interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[8]:<br>WDT_INT_<br>CLEAR | Write 1 to this bit to clear a watchdog event interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[9]:<br>RECOVERED_<br>INT_CLEAR | Write 1 to this bit to clear a fault recovery interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT0_CLR:<br>0x17 | Bit[10]:<br>AFE_MODE_<br>CHANGE_INT_<br>CLEAR | Write 1 to this bit to clear an AFE mode change interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT0_CLR:<br>0x17 | Bit[11]:<br>VSCAN_DONE_<br>INT_CLEAR | Write 1 to this bit to clear a completed high-resolution voltage scan interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INTO_CLR:<br>0x17 | Bit[14]:<br>PACK_<br>CURRENT_INT_<br>CLEAR | Write 1 to this bit to clear a battery pack current change interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[0]:<br>OTP_CRC_<br>EVENT_INT_<br>CLEAR | Write 1 to this bit to clear an OTP CRC interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[1]:<br>REGIN_INT_<br>CLEAR | Write 1 to this bit to clear a REGIN interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[2]: 3V3_INT_<br>CLEAR | Write 1 to this bit to clear a 3V3 UV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[3]: VDD_INT_<br>CLEAR | Write 1 to this bit to clear a VDD UV interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[4]:<br>OPEN_WIRE_<br>INT_CLEAR | Write 1 to this bit to clear an open wire interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[5]:<br>CELL_DEAD_<br>INT_CLEAR | Write 1 to this bit to clear a dead cell interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[6]:<br>CELL_<br>MISMATCH_<br>INT_CLEAR | Write 1 to this bit to clear a mismatched cell interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | INT1_CLR:<br>0x18 | Bit[8]:<br>PCB_MNTR_<br>TEMP_INT_<br>CLEAR | Write 1 to this bit to clear an NTC hot PCB monitor interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | Bit[9]:<br>FSM_ERROR_<br>INT_CLEAR | Write 1 to this bit to clear a schedule error interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | |--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------| | Bit[10]:<br>SELF_TEST_<br>INT_CLEAR | Write 1 to this bit to clear a self-diagnostic interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | Bit[11]:<br>BAL_DONE_<br>INT_CLEAR | Write 1 to this bit to clear a balancing complete interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | Bit[12]:<br>PACKP_V_INT_<br>CLEAR | Write 1 to this bit to clear a PACKP voltage change interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | Bit[13]:<br>FET_DRIVER_<br>INT_CLEAR | Write 1 to this bit to clear a MOSFET driver event interrupt. This is a self-clearing register. | Write-only | 0x0 | 1: Clear the interrupt | | Bit[0]:<br>CELL_OV_INT_<br>EN | Enables interrupt reporting for cell OV conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[1]:<br>CELL_UV_INT_<br>EN | Enables interrupt reporting for cell UV conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[2]:<br>VTOP_UV_INT_<br>EN | Enables interrupt reporting for battery pack UV conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[3]:<br>VTOP_OV_INT_<br>EN | Enables interrupt reporting for battery pack OV conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[4]:<br>OVER_CURR_<br>INT_EN | Enables interrupt reporting for OC conditions. Note that there are individual enable/disable control bits: OC_CHG_INT_EN, OC2_DCHG_INT_EN, and OC1_DCHG_INT_EN. OVER_CURR_INT_EN acts as a master enabler, so it must be enabled for the charger and discharge interrupt to work. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[5]:<br>SHORT_CURR_<br>INT_EN | Enables interrupt reporting for short-circuit conditions. Note that there are individual enable/disable control bits: SC_CHG_INT_EN and SC_DCHG_INT_EN. SHORT_CURR_INT_EN acts as a master enabler, so it must be enabled for the charger and discharge interrupt to work. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[6]:<br>NTC_COLD_<br>INT_EN | Enables interrupt reporting for NTC cold cell monitoring conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[7]:<br>NTC_HOT_INT_<br>EN | Enables interrupt reporting for NTC hot cell monitoring conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[8]:<br>WDT_INT_EN | Enables interrupt reporting for watchdog communication. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | Bit[9]:<br>RECOVERED_<br>INT_EN | Enables interrupt reporting for fault recovery. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | | FSM_ERROR_INT_CLEAR Bit[10]: SELF_TEST_INT_CLEAR Bit[11]: BAL_DONE_INT_CLEAR Bit[12]: PACKP_V_INT_CLEAR Bit[13]: FET_DRIVER_INT_CLEAR Bit[0]: CELL_OV_INT_EN Bit[1]: CELL_UV_INT_EN Bit[2]: VTOP_UV_INT_EN Bit[3]: VTOP_OV_INT_EN Bit[3]: VTOP_OV_INT_EN Bit[4]: OVER_CURR_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_COLD_INT_EN Bit[6]: NTC_HOT_INT_EN Bit[9]: RECOVERED_ | FSM_ERROR_INT_CLEAR Bit[10]: SELF_TEST_INT_CLEAR Bit[11]: BAL_DONE_INT_CLEAR Bit[12]: PACKP_V_INT_CLEAR Bit[13]: FET_DRIVER_INT_CLEAR Bit[0]: CELL_OV_INT_EN Bit[1]: CELL_UV_INT_EN Bit[1]: CFUR_UV_INT_EN Bit[1]: COVER_CURR_INT_EN COC_DCHG_INT_EN, COC | FSM_ERROR_INT_CLEAR Bit[10]: Bit[10]: SELF_TEST_INT_CLEAR Bit[11]: Bit[11]: Bit[11]: Bit[12]: PACKP_V_INT_CLEAR Bit[12]: PACKP_V_INT_CLEAR Bit[13]: Bit[13]: Bit[13]: Bit[13]: FFT_DRIVER_INT_CLEAR Bit[13]: FFT_DRIVER_INT_CLEAR Bit[13]: Bit[13]: Bit[13]: FFT_DRIVER_INT_CLEAR Bit[13]: Bit[13]: Bit[13]: FFT_DRIVER_INT_CLEAR Bit[13]: Bit[13]: Bit[13]: FFT_DRIVER_INT_CLEAR Bit[13]: Bit[13]: CELL_OV_INT_EN Bit[13]: CELL_UV_INT_EN Bit[13]: CELL_UV_INT_EN Bit[13]: COLDE_INT_EN DOVER_CURR_INT_EN, and OC1_DCHG_INT_EN, OC1_ | FSM_ERROR_INT_CLEAR ergister. write-only register. | | INT0_EN:<br>0x19 | Bit[10]:<br>AFE_MODE_<br>CHANGE_INT_<br>EN | Enables interrupt reporting an AFE mode change. | R/W | 0x0 | 0: Disabled<br>1: Enabled | |------------------|--------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------|-----------|---------------------------| | INT0_EN:<br>0x19 | Bit[11]:<br>VSCAN_DONE_<br>INT_EN | Enables interrupt reporting for high-<br>resolution voltage ADC scan<br>completion. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT0_EN:<br>0x19 | Bit[14]:<br>PACK_<br>CURRENT_INT_<br>EN | Enables interrupt reporting for battery pack current direction changes. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INTO_EN:<br>0x19 | Bit[15]:<br>INT_ALERT_<br>CTRL | Enables interrupt reporting to the xALERT pin. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[0]:<br>OTP_CRC_<br>EVENT_INT_EN | Enables interrupt reporting for an OTP CRC event. | R/W | 0x1 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[1]:<br>REGIN_INT_EN | Enables interrupt reporting for a REGIN UV event. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[2]:<br>3V3_INT_EN | Enables interrupt reporting for a 3V3 UV event. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[3]:<br>VDD_INT_EN | Enables interrupt reporting for a VDD UV event. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[4]:<br>OPEN_WIRE_<br>INT_EN | Enables interrupt reporting for completed open-wire detection. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[5]:<br>CELL_DEAD_<br>INT_EN | Enables interrupt reporting for a dead cell condition. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[6]: CELL_<br>MISMATCH_<br>INT_EN | Enables interrupt reporting for a cell mismatch condition. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[7]: DIE_TEMP_INT_ EN | Enables interrupt reporting for a die over-temperature (OT) event. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[8]:<br>PCB_MNTR_<br>TEMP_INT_EN | Enables interrupt reporting for an NTC hot PCB condition. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[9]:<br>FSM_ERROR_<br>INT_EN | Enables interrupt reporting for a scheduled error. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[10]:<br>SELF_TEST_<br>INT_EN | Enables interrupt reporting for an ADC self-diagnostics OV/UV conditions. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[11]:<br>BAL_DONE_<br>INT_EN | Enables interrupt reporting for completed cell-balancing. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[12]:<br>PACKP_V_INT_<br>EN | Enables interrupt reporting for PACKP voltage changes. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | INT1_EN:<br>0x1A | Bit[13]:<br>FET_DRIVER_<br>INT_EN | Enables interrupt reporting for MOSFET driver issues. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | | | <u> </u> | | | | |--------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----| | INT_TYPE0:<br>0x1B | Bits[1:0]:<br>VTOP_UV_INT_<br>TYPE | Controls the triggering logic for a battery pack UV interrupt. Ox0: Interrupt generated on input status signal high Ox1: Interrupt generated on the rising edge of the input status signal Ox2: Interrupt generated on the falling edge of the input status signal Ox3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | INT_TYPE0:<br>0x1B | Bits[3:2]:<br>VTOP_OV_INT_<br>TYPE | Controls the triggering logic for a battery pack OV interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | INT_TYPE0:<br>0x1B | Bits[5:4]:<br>NTC_COLD_<br>INT_TYPE | Controls the triggering logic for an NTC cold cell monitor interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | INT_TYPE0:<br>0x1B | Bits[7:6]:<br>NTC_HOT_INT_<br>TYPE | Controls the triggering logic for an NTC hot cell monitor interrupt. Ox0: Interrupt generated on input status signal high Ox1: Interrupt generated on the rising edge of the input status signal Ox2: Interrupt generated on the falling edge of the input status signal Ox3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | INT_TYPE1:<br>0x1C | Bits[9:8]:<br>REGIN_INT_TY<br>PE | Controls the triggering logic for a REGIN interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | Bits[11:10]:<br>3V3_INT_TYPE | Controls the triggering logic for a 3V3 interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | |----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bits[13:12]:<br>VDD_INT_TYPE | Controls the triggering logic for a VDD UV interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | Bits[1:0]:<br>CELL_DEAD_<br>INT_TYPE | Controls the triggering logic for a dead cell interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | Bits[3:2]:<br>CELL_<br>MISMATCH_<br>INT_TYPE | Controls the triggering logic for a mismatched cell interrupt. Ox0: Interrupt generated on input status signal high Ox1: Interrupt generated on the rising edge of the input status signal Ox2: Interrupt generated on the falling edge of the input status signal Ox3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | Bits[5:4]:<br>DIE_TEMP_INT_<br>TYPE | Controls the triggering logic for a die temperature interrupt. Ox0: Interrupt generated on input status signal high Ox1: Interrupt generated on the rising edge of the input status signal Ox2: Interrupt generated on the falling edge of the input status signal Ox3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | | Bits[1:0]: CELL_DEAD_INT_TYPE Bits[3:2]: CELL_MISMATCH_INT_TYPE Bits[5:4]: DIE_TEMP_INT_ | Bits[11:10]: 3V3_INT_TYPE Bits[13:12]: VDD_INT_TYPE Bits[1:0]: CELL_DEAD_INT_TYPE Bits[1:0]: CELL_DEAD_INT_TYPE Bits[3:2]: CELL_MISMATCH_INT_TYPE Bits[3:2]: CCILL_MISMATCH_INT_TYPE Bits[3:2]: COntrols the triggering logic for a dead cell interrupt generated on the rising adf alling edges of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising and falling edges of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox2: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on input status signal ox3: Interrupt generated on the rising edge of the input status signal ox2: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the rising edge of the input status signal ox3: Interrupt generated on the risi | Bits[11:10]: 3V3_INT_TYPE Bits[11:10]: 3V3_INT_TYPE Bits[13:12]: VDD_INT_TYPE Bits[1:0]: CCITCOIS the triggering logic for a VDD UV interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal 0x3: Interrupt generated on the rising edge of the input status signal | 3V3 interrupt 3V3 interrupt 3V3 3V | | INT_TYPE2:<br>0x1D | Bits[7:6]:<br>PCB_MNTR_<br>TEMP_INT_<br>TYPE | Controls the triggering logic for an NTC hot PCB monitor interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | |--------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------------------------| | INT_TYPE2:<br>0x1D | Bits[11:10]:<br>SELF_TEST_<br>INT_TYPE | Controls the triggering logic for a self-diagnostic interrupt. Ox0: Interrupt generated on input status signal high Ox1: Interrupt generated on the rising edge of the input status signal Ox2: Interrupt generated on the falling edge of the input status signal Ox3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | MASK_INT0:<br>0x1E | Bit[0]:<br>CELL_OV_<br>MASK | Enables clearing the cell OV interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[1]:<br>CELL_UV_<br>MASK | Enables clearing the cell UV interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[2]:<br>VTOP_UV_<br>MASK | Enables clearing the VTOP UV interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[3]:<br>VTOP_OV_<br>MASK | Enables clearing the VTOP OV interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[4]:<br>OVER_CURR_<br>MASK | Enables clearing the OC interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[5]:<br>SC_MASK | Enables clearing the short-circuit interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | |--------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------------------------| | MASK_INT0:<br>0x1E | Bit[6]:<br>NTCS_CELL_<br>COLD_MASK | Enables clearing the NTC cold cell interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT0:<br>0x1E | Bit[7]:<br>NTCS_CELL_<br>HOT_MASK | Enables clearing the NTC hot cell interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[0]:<br>SELF_TEST_<br>MASK | Enables clearing the self-test interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[1]:<br>REGIN_MASK | Enables clearing the REGIN interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[2]:<br>3V3_MASK | Enables clearing the 3V3 interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[3]:<br>VDD_MASK | Enables clearing the VDD interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[6]:<br>CELL_MSMT_<br>MASK | Enables clearing the mismatched cell interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[7]:<br>DIE_TEMP_<br>DIG_MASK | Enables clearing the die temperature interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | MASK_INT1:<br>0x1F | Bit[8]:<br>PCB_MNTR_<br>HOT_MASK | Enables clearing the NTC hot PCB monitor interrupt flag and pulls the interrupt pin low, unless there are other interrupts pending. When disabled, the interrupt process can set the interrupt flag again. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | |--------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------------------------|--| |--------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------------------------|--| ## **Over-Current** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|--------------------------------| | OC_STATUS:<br>0x20 | Bit[0]:<br>OC1_DCHG_<br>STS | Indicates the latched discharge over-current (OC) limit 1 interrupt status. 1: Interrupt detected 0: No interrupt detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge type, the bit is set to 1 if a rising edge is detected. For a falling edge type, the bit is set to 1 if a falling edge is detected. For a rising and falling edge type, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. The type is defined by OC_DCHG_INT_TYPE, with the type selection being common for both limit 1 and limit 2 interrupts. This status bit can be cleared with OVER_CURR_INT_CLEAR. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | OC_STATUS:<br>0x20 | Bit[1]:<br>OC2_DCHG_<br>STS | Indicates the latched discharge OC limit 2 interrupt status. 1: Interrupt detected 0: No interrupt detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge type, the bit is set to 1 if a rising edge is detected. For a falling edge type, the bit is set to 1 if a falling edge is detected. For a rising and falling edge type, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. The type is defined by OC_DCHG_INT_TYPE, with the type selection being common for both limit 1 and limit 2 interrupts. This status bit can be cleared with OVER_CURR_INT_CLEAR. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | Indicates the latched charge OC limit interrupt status. 1: Interrupt detected 0: No interrupt detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge type, the bit is set to 1 if | | | | |--------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|--------------------------------| | OC_STATUS:<br>0x20 | Bit[2]:<br>OC_CHG_STS | a rising edge is detected. For a falling edge type, the bit is set to 1 if a falling edge is detected. For a rising and falling edge type, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | The type is defined by OC_CHG_INT_TYPE. This status bit can be cleared with OVER_CURR_INT_CLEAR. | | | | | OC_STATUS:<br>0x20 | Bit[8]:<br>OC1_DCHG_<br>RT_STS | Reports in real time whether a discharge OC limit 1 is detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | OC_STATUS:<br>0x20 | Bit[9]:<br>OC2_DCHG_<br>RT_STS | Reports in real time whether a discharge OC limit 2 is detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | OC_STATUS:<br>0x20 | Bit[10]:<br>OC_CHG_RT_<br>STS | Reports in real time whether a charge OC limit is detected. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | OCFT_CTRL:<br>0x23 | Bit[0]:<br>OC1_DCHG_<br>EN_CTRL | Enables discharge OC limit 1 monitoring. When disabled, a discharge OC limit 1 event does not trigger a fault or interrupt, regardless of whether the fault and interrupt bits are enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[1]:<br>OC2_DCHG_<br>EN_CTRL | Enables discharge OC limit 2 monitoring. When disabled, a discharge OC limit 2 event does not trigger a fault or interrupt, regardless of whether the fault and interrupt bits are enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[2]:<br>OC_CHG_EN_<br>CTRL | Enables charge OC limit monitoring. When disabled, a charge OC limit event does not trigger a fault or interrupt, regardless of whether the fault and interrupt bits are enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[3]:<br>OC1_DCHG_<br>INT_EN | Enables bit-level control for a discharge OC 1 interrupt. OVER_CURR_INT_EN must be enabled for this bit to be effective. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[4]:<br>OC2_DCHG_<br>INT_EN | Enables bit-level control for a discharge OC 2 interrupt. OVER_CURR_INT_EN must be enabled for this bit to be effective. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[5]:<br>OC_CHG_INT_<br>EN | Enables bit-level control for a charge OC interrupt. OVER_CURR_INT_EN must be enabled for this bit to be effective. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[6]:<br>OC1_DCHG_<br>FAULT_EN | Enables a discharge OC 1 event to put the MP2796 in fault mode. When enabled, this OC event puts the AFE in a fault state. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |--------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------|---------------------------------------------------------| | OCFT_CTRL:<br>0x23 | Bit[7]:<br>OC2_DCHG_<br>FAULT_EN | Enables a discharge OC 2 event to put the MP2796 in fault mode. When enabled, this OC event puts the AFE in a fault state. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | OCFT_CTRL:<br>0x23 | Bit[8]:<br>OC_CHG_<br>FAULT_EN | Enables a charge OC event to put<br>the MP2796 in fault mode. When<br>enabled, this OC event puts the<br>AFE in a fault state. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | | | Controls the triggering logic for discharge OC interrupt. | | | | | OCFT_CTRL:<br>0x23 | Bits[13:12]:<br>OC_DCHG_INT_<br>TYPE | 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0 <b>x</b> 0 | N/A | | | | Controls the triggering logic for charge OC interrupt. | | | | | OCFT_CTRL:<br>0x23 | Bits[15:14]:<br>OC_CHG_INT_<br>TYPE | 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | | | Configures the discharge OC 1 threshold. | | | | | DSGOC_LIM:<br>0x24 | Bits[4:0]:<br>OC1_DCHG_LIM | With a 1x range (OC1_DCHG_RNG = 0), the smallest available code is 2.5mV. With a 3x range (OC1_DCHG_RNG = 1), the minimum code is 7.5mV. | R/W (can<br>lock to<br>read-only) | 0x10 (MTP) | N/A | | 0x24 | OCT_DOTIG_EIN | The limit has an offset equal to the LSB, so $0x00 = 2.5 \text{mV}$ with a 1x range and $0x00 = 7.5 \text{mV}$ with a 3x range. The full-scale range depends on OC1_DCHG_RNG (80mV for 1x, 240mV for 3x). | | | | | DSGOC_LIM:<br>0x24 | Bit[5]:<br>OC1_DCHG_<br>RNG | Selects the range and LSB for the discharge OC level 1 threshold. | R/W (can lock to read-only) | 0x0 (MTP) | 0: 2.5mV/LSB,<br>80mV FSR<br>1: 7.5mV/LSB,<br>240mV FSR | | DSGOC_LIM:<br>0x24 | Bits[12:8]:<br>OC2_DCHG_<br>LIM | Configures the discharge OC 2 threshold. With a 1x range (OC2_DCHG_RNG = 0), the smallest available code is 2.5mV. With a 3x range (OC2_DCHG_RNG = 1), the minimum code is 7.5mV. The limit has an offset equal to the LSB, so 0x00 = 2.5mV with a 1x range and 0x00 = 7.5mV with a 3x range. The full-scale range depends on OC2_DCHG_RNG (80mV for 1x, 240mV for 3x). | R/W (can<br>lock to<br>read-only) | 0x09 (MTP) | N/A | |--------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|---------------------------------------------------------| | DSGOC_LIM:<br>0x24 | Bit[13]:<br>OC2_DCHG_<br>RNG | Selects the range and LSB for the discharge OC level 2 threshold. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: 2.5mV/LSB,<br>80mV FSR<br>1: 7.5mV/LSB,<br>240mV FSR | | DSGOC_DEG:<br>0x25 | Bits[5:0]:<br>OC1_DCHG_<br>DGL | Sets the discharge OC 1 deglitch value. When OC1_DCHG_DGL_RNG = 0, the code LSB is 5ms. When OC1_DCHG_DGL_RNG = 1, the code LSB is 40ms. When OC1_DCHG_DGL = 0x00 there is no deglitch, regardless of the LSB. This means an OC event is flagged as soon as it is detected. The response time is about 100µs. The full-scale range depends on the OC1_DCHG_DGL_RNG setting (315ms or 2520ms). | R/W (can<br>lock to<br>read-only) | 0x14 (MTP) | N/A | | DSGOC_DEG:<br>0x25 | Bit[6]:<br>OC1_DCHG_<br>DGL_RNG | Sets the discharge OC 1 deglitch bit weight, and selects the range for OC1_DCHG_DGL. 0: 5ms LSB / 315ms FSR 1: 40ms LSB / 2520ms FSR | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | N/A | | DSGOC_DEG:<br>0x25 | Bits[13:8]:<br>OC2_DCHG_<br>DGL | Sets the discharge OC 2 deglitch value. When OC2_DCHG_DGL_RNG = 0, the code LSB is 5ms. When OC2_DCHG_DGL_RNG = 1, the code LSB is 40ms. When OC2_DCHG_DGL = 0x00 there is no deglitch, regardless of the LSB. This means an OC event is flagged as soon as it is detected. The response time is about 100µs. The full-scale range depends on the OC2_DCHG_DGL_RNG setting (315ms or 2520ms). | R/W (can<br>lock to<br>read-only) | 0x04 (MTP) | N/A | | DSGOC_DEG:<br>0x25 | Bit[14]:<br>OC2_DCHG_<br>DGL_RNG | Sets the discharge OC 2 deglitch bit weight, and selects the range for OC2_DCHG_DGL. 0x0: 5ms LSB / 315ms FSR 0x1: 40ms LSB / 2520ms FSR | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | N/A | |--------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------|-------------------------------------------------------------| | | | Sets the charge OC threshold. With a 1x range (OC_CHG_RNG = | | | | | CHGOC_DEG: | Bits[4:0]: | 0), the smallest available code is 1.6mV. With a 3x range (OC_CHG_RNG = 1), the minimum code is 4.8mV. | R/W (can | | | | 0x26 | OC_CHG_LIM | The limit has an offset equal to the LSB, so $0x00 = 1.6$ mV with a 1x range and $0x00 = 4.8$ mV with a 3x range. | lock to<br>read-only) | 0x10 (MTP) | N/A | | | | The full-scale range depends on OC_CHG_RNG as well (51.2mV for 1x and 153.6mV for 3x). | | | | | CHGOC_DEG:<br>0x26 | Bit[5]:<br>OC_CHG_RNG | Selects the range and LSB selector for the charge OC threshold (OC_CHG_LIM). | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | 0: 1.6mV/LSB,<br>51.2mV FSR<br>1: 4.8mV/LSB,<br>153.6mV FSR | | | | Sets the OC charge deglitch value. | | | | | | Bits[13:8]:<br>OC_CHG_DG | When OC_CHG_DGL_RNG = 0x0, the code LSB is 5ms. When OC_CHG_DGL_RNG = 0x1, the code LSB is 40ms. | | 0x04 (MTP) | | | CHGOC_DEG:<br>0x26 | | When OC_CHG_DG = 0x00, there is no deglitch, regardless of the LSB. This means an OC event is flagged as soon as it is detected. The response time is about 100µs. | R/W (can<br>lock to<br>read-only) | | N/A | | | | The full-scale range depends on the OC_CHG_DGL_RNG setting (315ms or 2520ms). | | | | | CHGOC_DEG: | Bit[14]:<br>OC_CHG_DGL_ | Sets the charge OC deglitch bit weight, and selects the range for OC_CHG_DG. | R/W (can lock to | 0x0 (MTP) | N/A | | 0x26 | RNG | 0x0: 5ms LSB / 315ms FSR<br>0x1: 40ms LSB / 2520ms FSR | read-only) | UXU (IVITE) | | # **Short-Circuit** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------|--------------------------------| | | | Reports whether a latched discharge short-circuit event has been detected. | | | | | SC_STATUS:<br>0x27 | Bit[0]:<br>SC_DCHG_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling) selected by SC_DCHG_INT_TYPE. For a rising edge type, the bit is set to 1 if a rising edge is detected. For a falling edge type, the bit is set to 1 if a falling edge is detected. For a rising and falling edge type, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | This status bit can be cleared with SHORT_CURR_INT_CLEAR. | | | | | | | Reports whether a latched charge short-circuit event has been detected. | | | | | SC_STATUS:<br>0x27 | Bit[1]:<br>SC_CHG_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling) selected by SC_CHG_INT_TYPE. For a rising edge type, the bit is set to 1 if a rising edge is detected. For a falling edge type, the bit is set to 1 if a falling edge is detected. For a rising and falling edge type, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | This status bit can be cleared with SHORT_CURR_INT_CLEAR. | | | | | SC_STATUS:<br>0x27 | Bit[8]:<br>SC_DCHG_RT_<br>STS | Reports whether a discharge short-circuit event has been detected in real time. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | SC_STATUS:<br>0x27 | Bit[9]:<br>SC_CHG_RT_<br>STS | Reports whether a charge short-circuit event has been detected in real time. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | SCFT_CTRL:<br>0x2A | Bit[0]:<br>SC_DCHG_EN_<br>CTRL | Enables discharge short-circuit monitoring. When disabled, this fault does not trigger an interrupt or a fault, regardless of whether those bits are enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: Disabled<br>1: Enabled | | SCFT_CTRL:<br>0x2A | Bit[1]:<br>SC_CHG_EN_<br>CTRL | Enables charge short-circuit monitoring. When disabled, this fault does not trigger an interrupt or a fault, regardless of whether those bits are enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (MTP) | 0: Disabled<br>1: Enabled | | | | Enables the interrupt for a discharge | | | | |--------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|---------------------------| | SCFT_CTRL:<br>0x2A | Bit[2]:<br>SC_DCHG_INT_<br>EN | short-circuit current. For this bit to be effective, SC_DCHG_EN_CTRL must be enabled. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | SCFT_CTRL:<br>0x2A | Bit[3]:<br>SC_CHG_INT_<br>EN | Enables the interrupt for a charge short-circuit current. For this bit to be effective, SC_CHG_EN_CTRL must be enabled. | R/W | 0x0 | 0: Disabled<br>1: Enabled | | SCFT_CTRL:<br>0x2A | Bit[4]:<br>SC_DCHG_<br>FAULT_EN | Enables a discharge short-circuit event to force the MP2796 into fault mode. For this bit to be effective, SC_DCHG_EN_CTRL must be enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SCFT_CTRL:<br>0x2A | Bit[5]:<br>SC_CHG_<br>FAULT_EN | Enables a charge short-circuit event to force the MP2796 into fault mode. For this bit to be effective, SC_CHG_EN_CTRL must be enabled. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SCFT_CTRL:<br>0x2A | Bits[13:12]:<br>SC_DCHG_INT_<br>TYPE | Controls the triggering logic for discharge short-circuit interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | SCFT_CTRL:<br>0x2A | Bits[15:14]:<br>SC_CHG_INT_<br>TYPE | Controls the triggering logic for charge short-circuit interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x0 | N/A | | DSGSC_CFG:<br>0x2B | Bits[4:0]:<br>SC_DCHG_LIM | Configures the short-circuit discharge threshold. With a 1x range (SC_DCHG_RNG = 0), the smallest available code is 5.5mV. With a 3x range (SC_DCHG_RNG = 1), the minimum code is 16.5mV. This threshold has an offset equal to the LSB, so 0x00 = 5.5mV with a 1x range and 0x00 = 16.5mV with a 3x range. The full-scale range depends on the SC_DCHG_RNG (176mV for 1x and 528mV for 3x). | R/W (can<br>lock to<br>read-only) | 0x11 (MTP) | N/A | | DSGSC_CFG:<br>0x2B | Bit[5]:<br>SC_DCHG_RNG | Selects the range and LSB for the discharge short-circuit threshold (SC_DCHG_LIM). | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | 0: 5.5mV/LSB,<br>176mV FSR<br>1:<br>16.5mV/LSB,<br>528mV FSR | |--------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|--------------------------------------------------------------| | DSGSC_CFG:<br>0x2B | Bits[14:8]:<br>SC_DCHG_DG | Configures the discharge short-circuit deglitch time. When SC_DCHG_DG = 0x00, there is no deglitch, so a short-circuit event is flagged as soon as it is detected. The response time is about 100µs. | R/W (can<br>lock to<br>read-only) | 0x01 (MTP) | LSB: 200µs,<br>RNG:100µs to<br>25500µs,<br>0x00: 100µs | | CHGSC_CFG:<br>0x2C | Bits[4:0]:<br>SC_CHG_LIM | Configures the charge short-circuit threshold. With a 1x range (SC_CHG_RNG = 0), the smallest available code is 2.5mV. With a 3x range (SC_CHG_RNG = 1), the minimum code is 7.5mV. The limit has an offset equal to the LSB, so 0x00 = 2.5mV with a 1x range and 0x00 = 7.5mV with a 3x range. The full-scale range depends on the SC_CHG_RNG (80mV for 1x and 240mV for 3x). | R/W (can<br>lock to<br>read-only) | 0x11 (MTP) | N/A | | CHGSC_CFG:<br>0x2C | Bit[5]:<br>SC_CHG_RNG | Selects the range and LSB for the charge short-circuit threshold (SC_CHG_LIM). | R/W (can<br>lock to<br>read-only) | 0x0 (MTP) | 0: 2.5mV/LSB,<br>80mV FSR<br>1: 7.5mV/LSB,<br>240mV FSR | | CHGSC_CFG:<br>0x2C | Bits[14:8]:<br>SC_CHG_DG | Configures the charge short-circuit deglitch time. When SC_CHG_DG = 0x00, there is no deglitch, so a short-circuit event is flagged as soon as it is detected. The response time is about 100µs. | R/W (can<br>lock to<br>read-only) | 0x08 (MTP) | LSB: 200µs,<br>RNG: 100µs to<br>25500µs,<br>0x00:100µs | # Over-Voltage (OV), Under-Voltage (UV), Dead Cell, and Mismatched Cell | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Type | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|--------------------------------| | RD_CELL_UV:<br>0x2D | Bit[0]:<br>CELL_1_UV_<br>STS | Reports whether an under-voltage (UV) condition has been detected on cell 1. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[1]:<br>CELL_2_UV_<br>STS | Reports whether a UV condition has been detected on cell 2. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[2]:<br>CELL_3_UV_<br>STS | Reports whether a UV condition has been detected on cell 3. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | |---------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_CELL_UV:<br>0x2D | Bit[3]:<br>CELL_4_UV_<br>STS | Reports whether a UV condition has been detected on cell 4. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[4]:<br>CELL_5_UV_<br>STS | Reports whether a UV condition has been detected on cell 5. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[5]:<br>CELL_6_UV_<br>STS | Reports whether a UV condition has been detected on cell 6. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[6]:<br>CELL_7_UV_<br>STS | Reports whether a UV condition has been detected on cell 7. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[7]:<br>CELL_8_UV_<br>STS | Reports whether a UV condition has been detected on cell 8. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[8]:<br>CELL_9_UV_<br>STS | Reports whether a UV condition has been detected on cell 9. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[9]:<br>CELL_10_UV_<br>STS | Reports whether a UV condition has been detected on cell 10. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[10]:<br>CELL_11_UV_<br>STS | Reports whether a UV condition has been detected on cell 11. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[11]:<br>CELL_12_UV_<br>STS | Reports whether a UV condition has been detected on cell 12. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[12]:<br>CELL_13_UV_<br>STS | Reports whether a UV condition has been detected on cell 13. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | |---------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_CELL_UV:<br>0x2D | Bit[13]:<br>CELL_14_UV_<br>STS | Reports whether a UV condition has been detected on cell 14. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[14]:<br>CELL_15_UV_<br>STS | Reports whether a UV condition has been detected on cell 15. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_UV:<br>0x2D | Bit[15]:<br>CELL_16_UV_<br>STS | Reports whether a UV condition has been detected on cell 16. Send an interrupt UV clear to clear this bit. 0: No UV event has been detected 1: A UV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[0]:<br>CELL_1_OV_<br>STS | Reports whether an over-voltage (OV) condition has been detected on cell 1. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[1]:<br>CELL_2_OV_<br>STS | 1: An OV event has been detected Reports whether an OV condition has been detected on cell 2. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[2]:<br>CELL_3_OV_<br>STS | Reports whether an OV condition has been detected on cell 3. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[3]:<br>CELL_4_OV_<br>STS | Reports whether an OV condition has been detected on cell 4. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[4]:<br>CELL_5_OV_<br>STS | Reports whether an OV condition has been detected on cell 5. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[5]:<br>CELL_6_OV_<br>STS | Reports whether an OV condition has been detected on cell 6. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[6]:<br>CELL_7_OV_<br>STS | Reports whether an OV condition has been detected on cell 7. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | |---------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_CELL_OV:<br>0x2E | Bit[7]:<br>CELL_8_OV_<br>STS | Reports whether an OV condition has been detected on cell 8. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[8]:<br>CELL_9_OV_<br>STS | Reports whether an OV condition has been detected on cell 9. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[9]:<br>CELL_10_OV_<br>STS | Reports whether an OV condition has been detected on cell 10. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[10]:<br>CELL_11_OV_<br>STS | Reports whether an OV condition has been detected on cell 11. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[11]:<br>CELL_12_OV_<br>STS | Reports whether an OV condition has been detected on cell 12. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[12]:<br>CELL_13_OV_<br>STS | Reports whether an OV condition has been detected on cell 13. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[13]:<br>CELL_14_OV_<br>STS | Reports whether an OV condition has been detected on cell 14. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[14]:<br>CELL_15_OV_<br>STS | Reports whether an OV condition has been detected on cell 15. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_OV:<br>0x2E | Bit[15]:<br>CELL_16_OV_<br>STS | Reports whether an OV condition has been detected on cell 16. Send an interrupt OV clear to clear this bit. 0: No OV event has been detected 1: An OV event has been detected | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_<br>MSMT:<br>0x2F | Bit[0]:<br>CELL_1_MSMT_<br>STS | Reports the cell 1 mismatch interrupt status. Clear a mismatch | | | | |---------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|---------------------| | | | with CELL_MISMATCH_INT_CLEAR. | Read-only | 0x0 | 0: False<br>1: True | | | | 0: No mismatch 1: A mismatch has been detected | | | | | RD_CELL_<br>MSMT:<br>0x2F | Bit[1]:<br>CELL_2_MSMT_<br>STS | Reports the cell 2 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. | Read-only | 0x0 | 0: False<br>1: True | | | | 0: No mismatch 1: A mismatch has been detected | | | | | RD_CELL_<br>MSMT:<br>0x2F | Bit[2]:<br>CELL_3_MSMT_<br>STS | Reports the cell 3 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. | Read-only | 0x0 | 0: False<br>1: True | | | | 0: No mismatch 1: A mismatch has been detected | | | | | RD_CELL_<br>MSMT:<br>0x2F | Bit[3]:<br>CELL_4_MSMT_<br>STS | Reports the cell 4 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. | Read-only | 0x0 | 0: False<br>1: True | | | | No mismatch A mismatch has been detected | | | | | RD_CELL_<br>MSMT:<br>0x2F | Bit[4]:<br>CELL_5_MSMT_<br>STS | Reports the cell 5 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. | Read-only | 0x0 | 0: False<br>1: True | | | | No mismatch A mismatch has been detected | | | | | RD_CELL_<br>MSMT:<br>0x2F | Bit[5]:<br>CELL_6_MSMT_<br>STS | Reports the cell 6 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[6]:<br>CELL_7_MSMT_<br>STS | Reports the cell 7 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[7]:<br>CELL_8_MSMT_<br>STS | Reports the cell 8 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[8]:<br>CELL_9_MSMT_<br>STS | Reports the cell 9 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | |---------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|---------------------| | RD_CELL_<br>MSMT:<br>0x2F | Bit[9]:<br>CELL_10_<br>MSMT_STS | Reports the cell 10 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[10]:<br>CELL_11_<br>MSMT_STS | Reports the cell 11 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[11]:<br>CELL_12_<br>MSMT_STS | Reports the cell 12 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[12]:<br>CELL_13_<br>MSMT_STS | Reports the cell 13 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[13]:<br>CELL_14_<br>MSMT_STS | Reports the cell 14 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[14]:<br>CELL_15_<br>MSMT_STS | Reports the cell 15 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected | Read-only | 0x0 | 0: False<br>1: True | | RD_CELL_<br>MSMT:<br>0x2F | Bit[15]:<br>CELL_16_<br>MSMT_STS | Reports the cell 16 mismatch interrupt status. Clear a mismatch with CELL_MISMATCH_INT_CLEAR. 0: No mismatch 1: A mismatch has been detected. | Read-only | 0x0 | 0: False<br>1: True | | | | Reports cell 1's dead interrupt | | | | |---------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_CELL_<br>DEAD:<br>0x30 | Bit[0]:<br>CELL_1_DEAD_<br>STS | status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[1]:<br>CELL_2_DEAD_<br>STS | Reports cell 2's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[2]:<br>CELL_3_DEAD_<br>STS | Reports cell 3's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[3]:<br>CELL_4_DEAD_<br>STS | Reports cell 4's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[4]:<br>CELL_5_DEAD_<br>STS | Reports cell 5's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[5]:<br>CELL_6_DEAD_<br>STS | Reports cell 6's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[6]:<br>CELL_7_DEAD_<br>STS | Reports cell 7's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead 1: This cell is dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | |---------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|--------------------------------| | RD_CELL_<br>DEAD:<br>0x30 | Bit[7]:<br>CELL_8_DEAD_<br>STS | Reports cell 8's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_<br>DEAD:<br>0x30 | Bit[8]:<br>CELL_9_DEAD_<br>STS | 1: This cell is dead Reports cell 9's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[9]: CELL_10_<br>DEAD_STS | Reports cell 10's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[10]:<br>CELL_11_<br>DEAD_STS | Reports cell 11's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | RD_CELL_<br>DEAD:<br>0x30 | Bit[11]:<br>CELL_12_<br>DEAD_STS | Reports cell 12's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 0: This cell is not dead<br>1: This cell is dead | | | | | | 1 | T | | | 1 | |----------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|---------------------------------------------------------| | RD_CELL_<br>DEAD:<br>0x30 | Bit[12]:<br>CELL_13_<br>DEAD_STS | Reports cell 13's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead 1: This cell is dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_<br>DEAD:<br>0x30 | Bit[13]:<br>CELL_14_<br>DEAD_STS | Reports cell 14's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead 1: This cell is dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_<br>DEAD:<br>0x30 | Bit[14]:<br>CELL_15_<br>DEAD_STS | Reports cell 15's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead 1: This cell is dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_CELL_<br>DEAD:<br>0x30 | Bit[15]:<br>CELL_16_<br>DEAD_STS | Reports cell 16's dead interrupt status. If CELL_DEAD_STS_SEL = 0, this bit indicates the interrupt status; if CELL_DEAD_STS_SEL = 1, this bit indicates the real-time status. 0: This cell is not dead 1: This cell is dead | Read-only | 0x0 | 0: Not detected<br>1: Detected | | CELL_MSMT_<br>STS:<br>0x33 | Bits[9:0]:<br>CELL_MSMT_<br>DELTA | Reports the voltage difference between the cell with the lowest voltage and the cell with the highest voltage. If the interrupt is disabled, this bit indicates the real-time status; otherwise, this bit is latched at the interrupt and returns to the real-time status after being cleared. | Read-only | 0x000 | LSB: 4.88mV,<br>RNG: 0mV to<br>4997.12mV,<br>0x000: 0mV | | CELL_MSMT_<br>STS:<br>0x33 | Bits[13:10]:<br>CELL_MSMT_<br>LOWER | Reports the cell with the lowest voltage. If the interrupt is disabled, this bit indicates the real-time status; otherwise, this bit is latched at the interrupt and returns to the real-time status after being cleared. 0x0: Cell 1 0xF: Cell 16 | Read-only | 0x0 | N/A | | CELL_MSMT_<br>STS:<br>0x33 | Bit[14]:<br>CELL_MSMT_<br>RT_STS | Reports the real-time cell mismatch status. 0: There is no mismatch 1: A mismatch has been detected | Read-only | 0x0 | N/A | | PACKFT_<br>CTRL:<br>0x34 | Bit[0]:<br>VTOP_UV_EN_<br>CTRL | Enables the monitoring for battery pack (VTOP) under-voltage protection (UVP). | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |--------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|--------------------------------| | PACKFT_<br>CTRL:<br>0x34 | Bit[1]:<br>VTOP_UV_<br>FAULT_EN_<br>CTRL | Enables battery pack UVP to put the device in fault mode. 0: The device does not enter fault mode 1: The device enters fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[4]:<br>VTOP_OV_EN_<br>CTRL | Enables the monitoring for battery pack (VTOP) over-voltage protection (OVP). | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[5]:<br>VTOP_OV_<br>FAULT_EN_<br>CTRL | Enables battery pack OVP to put the device in fault mode. 0: The device does not enter fault mode 1: The device enters fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[8]:<br>CELL_DEAD_EN | Enables dead cell protection. This bit must be enabled to trigged dead cell faults or interrupts (which both have their own enable controls as well). | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[9]:<br>CELL_DEAD_<br>FAULT_EN | <ul><li>0: A dead cell does not force the device into fault mode</li><li>1: A dead cell puts the device in fault mode</li></ul> | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[10]:<br>CELL_DEAD_<br>STS_SEL | Show the latched dead cell status going to the interrupt controller Show the real-time dead cell status | R/W | 0x0 | N/A | | PACKFT_<br>CTRL:<br>0x34 | Bit[11]:<br>CELL_MSMT_<br>EN | Disable cell mismatch logic Enable cell mismatch logic | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[12]:<br>CELL_MSMT_<br>FAULT_EN | O: A cell mismatch does not force the device into fault mode 1: A cell mismatch puts the device in fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | PACKFT_<br>CTRL:<br>0x34 | Bit[14]:<br>CELL_DEAD_<br>LOG_STS | Reports whether a dead cell event has been detected. This status is not cleared by shutting down. It must be cleared with CELL_DEAD_DET_CLEAR. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | PACKFT_<br>CTRL:<br>0x34 | Bit[15]:<br>CELL_DEAD_<br>DET_CLEAR | Set this bit to 1 to clear the dead cell status. This is a self-clearing bit. | Write-only | 0x0 | N/A | | CELLFT_CTRL:<br>0x35 | Bit[0]:<br>SYNC_RT_<br>STATUS | When this bit is set to "on", it synchronizes the status bit to allow the voltage ADC monitoring input status to be cleared after it has been disabled. | R/W | 0x0 | 0: Off<br>1: On | | CELLFT_CTRL:<br>0x35 | Bit[1]:<br>CELL_UV_EN_<br>CTRL | Enables cell UVP. This bit must be enabled for UV faults or interrupts to be triggered. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | CELLFT_CTRL:<br>0x35 | Bit[2]:<br>CELL_UV_<br>FAULT_EN | 0: Cell UVP does not force the device into fault mode 1: Cell UVP puts the device in fault mode | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | CELLFT_CTRL:<br>0x35 | Bit[4]:<br>CELL_OV_EN_<br>CTRL | Enables cell OVP. This bit must be enabled for OV faults or interrupts to be triggered. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |----------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-------------------------------------------------| | CELLFT_CTRL:<br>0x35 | Bit[5]:<br>CELL_OV_<br>FAULT_EN | O: Cell OVP does not force the device into fault mode 1: Cell OVP puts the device in fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | CELLFT_CTRL:<br>0x35 | Bits[8:7]:<br>CELL_UV_INT_<br>TYPE | Controls the triggering logic for cell UV interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x1 | N/A | | CELLFT_CTRL:<br>0x35 | Bits[10:9]:<br>CELL_OV_INT_<br>TYPE | Controls the triggering logic for cell OV interrupt. 0x0: Interrupt generated on input status signal high 0x1: Interrupt generated on the rising edge of the input status signal 0x2: Interrupt generated on the falling edge of the input status signal 0x3: Interrupt generated on the rising and falling edges of the input status signal | R/W | 0x1 | N/A | | CELLFT_CTRL:<br>0x35 | Bit[11]:<br>CELL_UV_STS_<br>SEL | Selects what each of the CELL_x_UV_STS bits report. 0: Report the latched cell x status going to the interrupt controller 01: Report the latest outcome of the cell x UV check | R/W | 0x0 | N/A | | CELLFT_CTRL:<br>0x35 | Bit[12]:<br>CELL_OV_STS_<br>SEL | Selects what each of the CELL_x_OV_STS bits report. 0: Report the latched cell x status going to the interrupt controller 1: Report the latest outcome of the cell x OV check | R/W | 0x0 | N/A | | CELL_HYST:<br>0x36 | Bits[7:4]:<br>CELL_UV_HYST | Sets the cell UV threshold hysteresis. | R/W | 0xA (OTP) | LSB: 19.5mV<br>RNG: 0mV to<br>292.5mV<br>0: 0mV | | CELL_HYST:<br>0x36 | Bits[11:8]:<br>CELL_OV_HYST | Sets the cell OV threshold hysteresis. | R/W | 0xA (OTP) | LSB: 19.5mV<br>RNG: 0mV to<br>292.5mV<br>0: 0mV | | | | | | | | | PACK_UV_OV:<br>0x37 | Bit[0]:<br>VTOP_UV_RT_<br>STS | Reports the real-time result of the VTOP vs. UV threshold comparison. Depending on the settings, a hysteresis may be applied to the threshold for comparison. 0: VTOP ≥ UV threshold 1: VTOP < UV threshold | Read-only | 0x0 | 0: Not detected<br>1: Detected | |---------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|------------------------------------------------------------| | PACK_UV_OV:<br>0x37 | Bits[7:2]:<br>VTOP_UV_<br>HYST | Sets the battery pack UV threshold hysteresis. | R/W | 0x20 (MTP) | LSB:<br>78.125mV<br>RNG: 0mV to<br>4921.875mV<br>0x00: 0mV | | PACK_UV_OV:<br>0x37 | Bit[8]:<br>VTOP_OV_RT_<br>STS | Reports the real-time result of the VTOP vs. OV threshold comparison. Depending on the settings, a hysteresis may be applied to the threshold for comparison. 0: VTOP ≤ OV threshold | Read-only | 0x0 | 0: Not detected<br>1: Detected | | | | 1: VTOP > OV threshold | | | | | PACK_UV_OV:<br>0x37 | Bits[15:10]:<br>VTOP_OV_<br>HYST | Sets the battery pack OV threshold hysteresis. | R/W | 0x20 (MTP) | LSB:<br>78.125mV<br>RNG: 0mV to<br>4921.875mV<br>0x00: 0mV | | CELL_UV:<br>0x38 | Bits[7:0]:<br>CELL_UV | Configures the cell UV threshold. | R/W (can<br>lock to<br>read-only) | 0x98 (MTP) | LSB: 19.53mV<br>RNG: 0mV to<br>4980.15mV<br>0x00: 0mV | | | | Sets the cell UV deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. | | | | | CELL_UV:<br>0x38 | Bits[11:8]:<br>CELL_UV_DG | 0x0: A UV condition is reported as soon as the UV threshold is reached 0x1: A UV condition is reported when the current and previous protection readings violate the cell UV threshold | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | | | | 0xF: A UV condition is reported when a total of 16 protection cycles violate the cell UV threshold | | | | | CELL_OV:<br>0x39 | Bits[7:0]:<br>CELL_OV | Configures the cell OV threshold. | R/W (can<br>lock to<br>read-only) | 0xD7 (MTP) | LSB: 19.53mV<br>RNG: 0mV to<br>4980.15mV<br>0x00: 0mV | | | | Sets the cell OV deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. | | | | | CELL_OV:<br>0x39 | Bits[11:8]:<br>CELL_OV_DG | 0x0: An OV condition is reported as soon as the OV threshold is reached 0x1: An OV condition is reported when the current and previous protection readings violate the cell OV threshold | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | | | | 0xF: An OV condition is reported when a total of 16 protection cycles violate the cell OV threshold | | | | | PACK_UV:<br>0x3A | Bits[11:0]:<br>VTOP_UV_LIMIT | Configures the battery pack UV threshold. | R/W | 0x948 (MTP) | LSB:<br>19.531mV<br>RNG: 0mV to<br>79979.5mV<br>0x000: 0mV | |----------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------|-------------------------------------------------------------| | | | Sets the VTOP UV deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. | | | | | PACK_UV:<br>0x3A | Bits[15:12]:<br>VTOP_UV_DG | 0x0: A UV condition is reported as soon as the UV threshold is reached 0x1: A UV condition is reported when the current and previous protection readings violate the VTOP UV threshold | R/W | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | | | | 0xF: A UV condition is reported when a total of 16 protection cycles violate the VTOP UV threshold | | | | | PACK_OV:<br>0x3B | Bits[11:0]:<br>VTOP_OV_<br>LIMIT | Configures the battery pack OV threshold. | R/W | 0xD71<br>(MTP) | LSB:<br>19.531mV<br>RNG: 0mV to<br>79979.5mV,<br>0x000: 0mV | | | | Sets the VTOP OV deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. | | | | | PACK_OV:<br>0x3B | Bits[15:12]:<br>VTOP_OV_DG | 0x0: An OV condition is reported as soon as the OV threshold is reached 0x1: An OV condition is reported when the current and previous protection readings violate the VTOP OV threshold | R/W | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | | | | 0xF: An OV condition is reported when a total of 16 protection cycles violate the VTOP OV threshold | | | | | CELL_DEAD_<br>THR:<br>0x3C | Bits[6:0]:<br>CELL_DEAD_<br>LIMIT | Configures the dead cell threshold. | R/W | 0x68 (MTP) | LSB: 19.53mV<br>RNG: 0mV to<br>2480.31mV<br>0x00: 0mV | | | | Sets the dead cell deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. | | | | | CELL_DEAD_<br>THR:<br>0x3C | Bits[10:7]:<br>CELL_DEAD_<br>DGL_N | 0x0: A dead cell condition is reported as soon as the dead cell threshold is reached 0x1: A dead cell condition is reported when the current and previous protection readings violate the dead cell threshold | R/W | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | | | | 0xF: A dead cell condition is reported when a total of 16 protection cycles violate the dead cell threshold | | | | | CELL_MSMT:<br>0x3D | Bits[4:0]:<br>MSMT_TH | Sets the mismatched cell threshold. The weight of each bit is below: Bit[4]: 625mV Bit[3]: 312.5mV Bit[2]: 156.25mV Bit[1]: 78.1mV Bit[0]: 39mV | R/W | 0x02 (OTP) | N/A | |--------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|-----------------------------------------------------------| | CELL_MSMT:<br>0x3D | Bits[8:5]:<br>CELL_MSMT_<br>DGL_N | Sets the mismatched cell deglitch delay, which can be set between 1 reading (no deglitch) and 16 readings. Ox0: A mismatched cell condition is reported as soon as the dead cell threshold is reached Ox1: A mismatched cell condition is reported when the current and previous protection readings violate the mismatched cell threshold OxF: A mismatched cell condition is reported when a total of 16 protection cycles violate the mismatched cell threshold | R/W | 0x0 (OTP) | LSB: 1 update<br>RNG: 1 to 16<br>update(s)<br>0: 1 update | # **NTC Die Temperature** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------| | | | Reports the NTC1 hot cell interrupt status. | | | | | | | 0: No interrupt detected 1: An interrupt was detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[0]:<br>NTC1_CELL_<br>HOT_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[1]:<br>NTC2_CELL_<br>HOT_STS | Reports the NTC2 hot cell interrupt status. 0: No interrupt detected 1: An interrupt was detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal | Read-only | 0x0 | N/A | |---------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----| | | | is high. Reports the NTC3 hot cell interrupt | | | | | | | status. 0: No interrupt detected 1: An interrupt was detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[2]:<br>NTC3_CELL_<br>HOT_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | | | Reports the NTC4 hot cell interrupt status. 0: No interrupt detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[3]:<br>NTC4_CELL_<br>HOT_STS | 1: An interrupt was detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | | | I | | | | |---------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----| | | | Reports the NTC1 cold cell interrupt status. 0: No interrupt detected 1: An interrupt was detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[4]:<br>NTC1_CELL_<br>COLD_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | | | Reports the NTC2 cold cell interrupt status. 0: No interrupt detected | | | | | | | 1: An interrupt was detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[5]:<br>NTC2_CELL_<br>COLD_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | | | Reports the NTC3 cold cell interrupt status. | | | | | | | 0: No interrupt detected 1: An interrupt was detected | | | | | RD_NTC_DIE:<br>0x3E | Bit[6]:<br>NTC3_CELL_<br>COLD_STS | The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[7]:<br>NTC4_CELL_<br>COLD_STS | Reports the NTC4 cold cell interrupt status. 0: No interrupt detected 1: An interrupt was detected The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. | Read-only | 0x0 | N/A | |---------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----| | RD_NTC_DIE:<br>0x3E | Bit[8]:<br>NTC1_PCB_<br>MNTR_HOT_<br>STS | Reports the NTC1 hot PCB interrupt status. Depending on PCB_MNTR_STS_SEL, this bit may report the latched status or the real-time status. The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. If PCB_MNTR_STS_SEL reports the real-time status: | Read-only | 0x0 | N/A | | | | O: The NTC1 PCB temperature is within its normal range 1: The NTC1 PCB temperature is too hot If PCB_MNTR_STS_SEL reports | | | | | | | the latched status: 0: No interrupt has been detected 1: An interrupt has been detected | | | | | | 1 | T | | | | |---------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----| | RD_NTC_DIE:<br>0x3E | Bit[9]:<br>NTC2_PCB_<br>MNTR_HOT_<br>STS | Reports the NTC2 hot PCB interrupt status. Depending on PCB_MNTR_STS_SEL, this bit may report the latched status or the real-time status. The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge is detected. For a rising and falling edge is detected. For a level, the bit is set to 1 if the source signal is high. If PCB_MNTR_STS_SEL reports the real-time status: 0: The NTC2 PCB temperature is within its normal range 1: The NTC2 PCB temperature is too hot If PCB_MNTR_STS_SEL reports the latched status: 0: No interrupt has been detected 1: An interrupt has been detected | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[10]:<br>NTC3_PCB_<br>MNTR_HOT_<br>STS | Reports the NTC3 hot PCB interrupt status. Depending on PCB_MNTR_STS_SEL, this bit may report the latched status or the real-time status. The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. If PCB_MNTR_STS_SEL reports the real-time status: 0: The NTC3 PCB temperature is within its normal range 1: The NTC3 PCB temperature is too hot If PCB_MNTR_STS_SEL reports the latched status: 0: No interrupt has been detected 1: An interrupt has been detected | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[11]:<br>NTC4_PCB_<br>MNTR_HOT_<br>STS | Reports the NTC4 hot PCB interrupt status. Depending on PCB_MNTR_STS_SEL, this bit may report the latched status or the real-time status. The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge, the bit is set to 1 if a falling edge is detected. For a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. If PCB_MNTR_STS_SEL reports the real-time status: 0: The NTC4 PCB temperature is within its normal range 1: The NTC4 PCB temperature is too hot If PCB_MNTR_STS_SEL reports the latched status: 0: No interrupt has been detected 1: An interrupt has been detected | Read-only | 0x0 | N/A | |---------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----| | RD_NTC_DIE:<br>0x3E | Bit[13]:<br>DIE_TEMP_<br>DIG_RT_STS | Reports the real-time digital die temperature status, based on the result of the latest comparison between the digital die temperature reading and the associated hot threshold. 0: The die temperature is within its normal range 1: The digital die temperature is too hot | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[14]:<br>DIE_TEMP_<br>DIG_STS | Reports the die temperature interrupt status. The latched value depends on the selected interrupt type (e.g. rising, falling, or rising and falling). For a rising edge, the bit is set to 1 if a rising edge is detected. For a falling edge, the bit is set to 1 if a falling edge is detected. For a rising and falling edge, the bit is set to 1 if either edge is detected. For a level, the bit is set to 1 if the source signal is high. This bit is cleared by DIE_TEMP_DIG_CLEAR. 0: No digital die temperature event has been detected 1: The digital die temperature event has been detected | Read-only | 0x0 | N/A | | RD_NTC_DIE:<br>0x3E | Bit[15]:<br>DIE_TEMP_<br>ANA_EVENT | Obtains the status from analog circuit recordings after a hot die temperature event. This bit cannot be read in real time, since digital logic is shut down when this event occurs. This bit is cleared by DIE_TEMP_ANA_CLEAR. 0: The die temperature is within its normal range 1: The analog die temperature is too hot | Read-only | 0x0 | N/A | |---------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|-----------------------------------------------------------------------------------------| | RD_V_NTC4_<br>LR:<br>0x3F | Bits[9:0]:<br>NTC4_VALUE | Reports the NTC4 protection ADC reading. NTC4 monitoring is controlled by NTC4_EN, so this register updates when protection monitoring is requested and NTC4_EN is enabled. | Read-only | 0x000 | LSB:<br>0.09766% of<br>NTCB<br>RNG: 0% to<br>99.906% of<br>NTCB<br>0x000: 0% of<br>NTCB | | RD_V_NTC4_<br>LR:<br>0x3F | Bit[12]:<br>NTC1_CELL_<br>COLD_RT_STS | Reports the NTC1 cold cell real-time status. 0: The NTC1 temperature is within its normal range 1: The NTC1 temperature is too cold | Read-only | 0x0 | N/A | | RD_V_NTC4_<br>LR:<br>0x3F | Bit[13]:<br>NTC2_CELL_<br>COLD_RT_STS | Reports the NTC2 cold cell real-time status. 0: The NTC2 temperature is within its normal range 1: The NTC2 temperature is too cold | Read-only | 0x0 | N/A | | RD_V_NTC4_<br>LR:<br>0x3F | Bit[14]:<br>NTC3_CELL_<br>COLD_RT_STS | Reports the NTC3 cold cell real-time status. 0: The NTC3 temperature is within its normal range 1: The NTC3 temperature is too cold | Read-only | 0x0 | N/A | | RD_V_NTC4_<br>LR:<br>0x3F | Bit[15]:<br>NTC4_CELL_<br>COLD_RT_STS | Reports the NTC4 cold cell real-time status. 0: The NTC4 temperature is within its normal range 1: The NTC4 temperature is too cold | Read-only | 0x0 | N/A | | RD_V_NTC3_<br>LR:<br>0x40 | Bits[9:0]:<br>NTC3_VALUE | Reports the NTC3 protection ADC reading. NTC3 monitoring is controlled by NTC3_EN, so this register updates when protection monitoring is requested and NTC3_EN is enabled. | Read-only | 0x000 | LSB:<br>0.09766% of<br>NTCB<br>RNG: 0% to<br>99.906% of<br>NTCB<br>0x000: 0% of<br>NTCB | | RD_V_NTC3_<br>LR:<br>0x40 | Bit[12]:<br>NTC1_CELL_<br>HOT_RT_STS | Reports the NTC1 hot cell real-time status. 0: The NTC1 temperature is within its normal range 1: The NTC1 temperature is too hot | Read-only | 0x0 | N/A | | RD_V_NTC3_<br>LR:<br>0x40 | Bit[13]:<br>NTC2_CELL_<br>HOT_RT_STS | Reports the NTC2 hot cell real-time status. 0: The NTC2 temperature is within its normal range 1: The NTC2 temperature is too hot | Read-only | 0x0 | N/A | |---------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-----------------------------------------------------------------------------------------| | RD_V_NTC3_<br>LR:<br>0x40 | Bit[14]:<br>NTC3_CELL_<br>HOT_RT_STS | Reports the NTC3 hot cell real-time status. 0: The NTC3 temperature is within its normal range 1: The NTC3 temperature is too hot | Read-only | 0x0 | N/A | | RD_V_NTC3_<br>LR:<br>0x40 | Bit[15]:<br>NTC4_CELL_<br>HOT_RT_STS | Reports the NTC4 hot cell real-time status. 0: The NTC4 temperature is within its normal range 1: The NTC4 temperature is too hot | Read-only | 0x0 | N/A | | RD_V_NTC2_<br>LR:<br>0x41 | Bits[9:0]:<br>NTC2_VALUE | Reports the NTC2 protection ADC reading. NTC2 monitoring is controlled by NTC2_EN, so this register updates when protection monitoring is requested and NTC2_EN is enabled. | Read-only | 0x000 | LSB:<br>0.09766% of<br>NTCB<br>RNG: 0% to<br>99.906% of<br>NTCB<br>0x000: 0% of<br>NTCB | | RD_V_NTC1_<br>LR:<br>0x42 | Bits[9:0]:<br>NTC1_VALUE | Reports the NTC1 protection ADC reading. NTC1 monitoring is controlled by NTC1_EN, so this register updates when protection monitoring is requested and NTC1_EN is enabled. | Read-only | 0x000 | LSB:<br>0.09766% of<br>NTCB<br>RNG: 0% to<br>99.906% of<br>NTCB<br>0x000: 0% of<br>NTCB | | RD_T_DIE:<br>0x43 | Bits[9:0]:<br>DIE_TEMP_V | Reports the die temperature, which can be calculated with the following equation: T = Reading x 0.474 - 269.12°C | Read-only | 0x000 | LSB: 0.474°C<br>RNG:<br>-269.12°C to<br>+215.78°C<br>0x2E3:<br>81.18°C | | NTC_CLR:<br>0x44 | Bit[2]:<br>PCB_MNTR_<br>STS_SEL | Controls the NTCx_PCB_MNTR _HOT_STS register. 0: Show the latched status going to the interrupt controller 1: Show the real-time status | R/W | 0x0 | N/A | | NTC_CLR:<br>0x44 | Bit[14]:<br>DIE_TEMP_<br>DIG_CLEAR | Write 1 to clear a digital die too hot event. This bit is a self-clearing register. | Write-only | 0x0 | N/A | | NTC_CLR:<br>0x44 | Bit[15]:<br>DIE_TEMP_<br>ANA_CLEAR | Write 1 to clear an analog die too hot event. This bit is a self-clearing register. | Write-only | 0x0 | N/A | | DIE_CFG:<br>0x46 | Bit[1]:<br>DIE_TEMP_<br>DIG_EN | O: Disabled 1: Enable digital die temperature sensor | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | DIE_CFG:<br>0x46 | Bit[3]:<br>DIE_TEMP_<br>DIG_FAULT_EN | O: A digital die temperature events does not trigger fault mode 1: A digital die temperature events triggers fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[0]:<br>NTC1_EN | Enables protection monitoring for NTC1 if monitoring is required. Monitoring is automatically required when the IC is not in safe mode, but this function can be enabled in safe mode with PROTECT_IN_SAFE_CFG. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | NTC_CFG:<br>0x47 | Bit[1]:<br>NTC1_TYPE_<br>SEL | Configures the NTC1 monitor type. 0: Cell monitor 1: PCB monitor | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | NTC_CFG:<br>0x47 | Bit[2]:<br>NTC2_EN | Enables protection monitoring for NTC2 if monitoring is required. Monitoring is automatically required when the IC is not in safe mode, but this function can be enabled in safe mode with PROTECT_IN_SAFE_CFG. | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[3]:<br>NTC2_TYPE_<br>SEL | Configures the NTC2 monitor type. 0: Cell monitor 1: PCB monitor | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | NTC_CFG:<br>0x47 | Bit[4]: NTC3_EN | Enables protection monitoring for NTC3 if monitoring is required. Monitoring is automatically required when the IC is not in safe mode, but this function can be enabled in safe mode with PROTECT_IN_SAFE_CFG. | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[5]:<br>NTC3_TYPE_<br>SEL | Configures the NTC3 monitor type. 0: Cell monitor 1: PCB monitor | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | N/A | | NTC_CFG:<br>0x47 | Bit[6]:<br>NTC4_EN | Enables protection monitoring for NTC4 if monitoring is required. Monitoring is automatically required when the IC is not in safe mode, but this function can be enabled in safe mode with PROTECT_IN_SAFE_CFG. | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[7]:<br>NTC4_TYPE_<br>SEL | Configures the NTC4 monitor type. 0: Cell monitor 1: PCB monitor | R/W (can lock to read-only) | 0x1 (OTP) | N/A | | NTC_CFG:<br>0x47 | Bit[8]:<br>NTC3_PD_EN | Enables the internal pull-down function on NTC3. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[9]:<br>NTC4_PD_EN | Enables the internal pull-down function on NTC4. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG:<br>0x47 | Bit[10]:<br>NTCB_<br>DYNAMIC_ON | Enables dynamic bias on NTCB during ADC conversions of NTC channels. When disabled, NTCB is always enabled, which increases current consumption. | R/W<br>(can lock to<br>read-only) | 0x1 (OTP) | N/A | | NTC_CFG: 0x47 | Bit[13]:<br>NTC_CELL_<br>HOT_FAULT_<br>EN | O: The system does not enter fault mode if the cell monitor hot limit is reached 1: The system enters fault mode if the cell monitor hot limit is reached | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |----------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------|------------------------------------------------------------------------------------| | NTC_CFG: 0x47 | Bit[14]:<br>NTC_CELL_<br>COLD_FAULT_<br>EN | O: The system does not enter fault mode if the cell monitor cold limit is reached 1: The system enters fault mode if the cell monitor cold limit is reached | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTC_CFG: 0x47 | Bit[15]:<br>PCB_MNTR_<br>FAULT_EN | 0: The system does not enter fault mode if the PCB monitor's hot limit is reached 1: The system enters fault mode if the PCB monitor's hot limit is reached | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | NTCC_OTHR_<br>DSG:<br>0x48 | Bits[9:0]:<br>NTC_CELL_<br>HOT_DISCH | Sets the discharge NTC hot cell monitor voltage threshold. The limit is triggered if the value is equal to or below the set threshold. | R/W (can<br>lock to<br>read-only) | 0x12E<br>(MTP) | LSB:<br>0.09756% of<br>NTCB<br>RNG: 0% to<br>99.9% of NTCB<br>0x000: 0% of<br>NTCB | | NTCC_UTHR_<br>DSG:<br>0x49 | Bits[9:0]:<br>NTC_CELL_<br>COLD_DISCH | Sets the discharge NTC cold cell monitor voltage threshold. The limit is triggered if the value exceeds the set threshold. | R/W (can<br>lock to<br>read-only) | 0x294 (MTP) | LSB:<br>0.09756% of<br>NTCB<br>RNG: 0% to<br>99.9% of NTCB<br>0x000: 0% of<br>NTCB | | NTCC_OTHR_<br>CHG:<br>0x4A | Bits[9:0]:<br>NTC_CELL_<br>HOT_CHG | Sets the charge NTC hot cell monitor voltage threshold. The limit is triggered if the value is equal to or below the set threshold. | R/W (can<br>lock to<br>read-only) | 0x12E<br>(MTP) | LSB:<br>0.0975% of<br>NTCB<br>RNG: 0% to<br>99.9% of NTCB<br>0x000: 0% of<br>NTCB | | NTCC_UTHR_<br>CHG:<br>0x4B | Bits[9:0]:<br>NTC_CELL_<br>COLD_CHG | Sets the charge NTC cold cell monitor voltage threshold. The limit is triggered if the value exceeds the set threshold. | R/W (can<br>lock to<br>read-only) | 0x294 (MTP) | LSB:<br>0.09756% of<br>NTCB<br>RNG: 0% to<br>99.9% of NTCB<br>0x000: 0% of<br>NTCB | | NTCC_UTHR_<br>CHG:<br>0x4B | Bits[15:11]:<br>NTC_CELL_<br>HYST | Sets the NTC cell monitor hysteresis. | R/W (can<br>lock to<br>read-only) | 0x11 (OTP) | LSB: 0.1953%<br>of NTCB<br>RNG: 0% to<br>6.055% of<br>NTCB,<br>0x00: 0% of<br>NTCB | | NTCM_OTHR:<br>0x4C | Bits[9:0]:<br>PCB_MNTR_<br>HOT | Sets the NTC hot PCB monitor voltage threshold. The limit is triggered if the NTC reading is equal to or below the set threshold. | R/W | 0x0EB<br>(OTP) | LSB:<br>0.09756% of<br>NTCB<br>RNG: 0% to<br>99.9% of NTCB<br>0x000: 0% of<br>NTCB | | | | | | | | | NTCM_OTHR:<br>0x4C | Bits[15:11]:<br>PCB_MNTR_<br>HYST | Sets the NTC hot PCB monitor hysteresis. | R/W | 0x10 (OTP) | LSB: 0.1953%<br>of NTCB<br>RNG: 0% to<br>6.055% of<br>NTCB,<br>0x00: 0% of<br>NTCB | |--------------------|-----------------------------------|----------------------------------------------|-----|----------------|------------------------------------------------------------------------------------| | DIE_OT:<br>0x4D | Bits[9:0]:<br>DIE_TEMP_HOT | Sets the digital die temperature threshold. | R/W | 0x2E3<br>(OTP) | LSB: 0.474°C<br>RNG:<br>-269.12°C to<br>+215.78°C<br>0x2E3:<br>81.18°C | | DIE_OT:<br>0x4D | Bits[15:11]:<br>DIE_TEMP_<br>HYST | Sets the digital die temperature hysteresis. | R/W | 0x15 (OTP) | LSB: 0.474°C<br>RNG: 0°C to<br>14.68°C,<br>0x15: 10°C | ### **Diagnosis** | Address Name and location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------------------------------------| | SELF_STS:<br>0x4E | Bit[0]:<br>SELF_TEST_<br>STS_UV | 0: No failure has been detected 1: A failure has been detected | Read-only | 0x0 | N/A | | SELF_STS:<br>0x4E | Bit[1]:<br>SELF_TEST_<br>STS_OV | 0: No failure has been detected 1: A failure has been detected | Read-only | 0x0 | N/A | | SELF_STS:<br>0x4E | Bit[2]:<br>REGIN_STS | 0: No failure has been detected<br>1: A failure has been detected | Read-only | 0x0 | N/A | | SELF_STS:<br>0x4E | Bit[3]:<br>3V3_STS | 0: No failure has been detected<br>1: A failure has been detected | Read-only | 0x0 | N/A | | SELF_STS:<br>0x4E | Bit[4]: VDD_STS | 0: No failure has been detected<br>1: A failure has been detected | Read-only | 0x0 | N/A | | SELF_STS:<br>0x4E | Bit[5]: OTPCHK_<br>DONE_STS | When true, OTP CRC check is complete. This bit can be cleared by setting OTP_CRC_DO = 0. | Read-only | 0x0 | 0: False<br>1: True | | SELF_STS:<br>0x4E | Bit[6]:<br>OTP_CRC_<br>OUTCOME | Reports the errors in the outcome CRC OTP check. 0: No errors detected 1: One or more error(s) detected The result of the previous check is retained until OTP_CRC_DO is set to 1 (from 0). Then OTP_CRC_OUTCOME remains at 0 until the check is completed and a new result is available. | Read-only | 0x0 | 0: False<br>1: True | | RD_VA1P8:<br>0x4F | Bits[9:0]:<br>VDD_VALUE | Reports the latest ADC reading for the VDD regulator. | Read-only | 0x000 | LSB:<br>3.2227mV<br>RNG: 0mV to<br>3296.82mV,<br>0x000: 0mV | | RD_VA3P3:<br>0x50 | Bits[9:0]:<br>3V3_VALUE | Reports the latest ADC reading for the 3V3 regulator. | Read-only | 0x000 | LSB:<br>6.4453mV<br>RNG: 0mV to<br>6593.55mV,<br>0x000: 0mV | | RD_VA5:<br>0x51 | Bits[9:0]:<br>REGIN_VALUE | Reports the latest ADC reading for REGIN. | Read-only | 0x000 | LSB:<br>6.4453mV<br>RNG: 0mV to<br>6593.55mV,<br>0x000: 0mV | |--------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|-------------------------------------------------------------| | RD_VASELF:<br>0x52 | Bits[9:0]:<br>SELF_TEST_<br>VALUE | Reports the latest 10-bit ADC reading for the internal fixed voltage reference, which acts as an ADC self-test. | Read-only | 0x000 | LSB:<br>3.2227mV<br>RNG: 0mV to<br>3296.82mV,<br>0x000: 0mV | | RD_OPENH:<br>0x53 | Bit[0]:<br>CELL_0_OPW_<br>STS | Reports whether C0 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[1]:<br>CELL_1_OPW_<br>STS | Reports whether C1 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[2]:<br>CELL_2_OPW_<br>STS | Reports whether C2 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[3]:<br>CELL_3_OPW_<br>STS | Reports whether C3 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[4]:<br>CELL_4_OPW_<br>STS | Reports whether C4 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[5]:<br>CELL_5_OPW_<br>STS | Reports whether C5 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[6]:<br>CELL_6_OPW_<br>STS | Reports whether C6 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[7]:<br>CELL_7_OPW_<br>STS | Reports whether C7 has as an open wire after a detection has been executed. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[8]:<br>CELL_8_OPW_<br>STS | Reports whether C8 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[9]:<br>CELL_9_OPW_<br>STS | Reports whether C9 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[10]:<br>CELL_10_OPW_<br>STS | Reports whether C10 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[11]:<br>CELL_11_OPW_<br>STS | Reports whether C11 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[12]:<br>CELL_12_OPW_<br>STS | Reports whether C12 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | |-------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|--------------------------------| | RD_OPENH:<br>0x53 | Bit[13]:<br>CELL_13_OPW_<br>STS | Reports whether C13 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[14]:<br>CELL_14_OPW_<br>STS | Reports whether C14 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENH:<br>0x53 | Bit[15]:<br>CELL_15_OPW_<br>STS | Reports whether C15 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | RD_OPENL:<br>0x54 | Bit[0]:<br>CELL_16_OPW_<br>STS | Reports whether C16 has as an open wire after a detection has been executed. The cell must be enabled from CELL_S_CTRL for this flag to function. | Read-only | 0x0 | 0: Not detected<br>1: Detected | | SFT_GO:<br>0x55 | Bit[0]:<br>OTP_CRC_DO | Write 0 to this bit to clear the results. Write 1 to this bit to schedule an OTP CRC. | R/W | 0x0 | N/A | | SFT_GO:<br>0x55 | Bit[8]:<br>OPEN_WIRE_<br>GO | Write 1 to this bit to schedule an open-wire check. Write 0 to this bit to clear the results of a completed open-wire detection. | R/W | 0x0 | 1: Execute this function | | SFT_GO:<br>0x55 | Bit[9]:<br>OPEN_WIRE_<br>DONE_STS | Reports whether open-wire detection is complete. When true, open-wire detection is complete. Write 0 to OPEN_WIRE_GO to clear this flag. | Read-only | 0x0 | 0: False<br>1: True | | SFT_GO:<br>0x55 | Bit[10]:<br>OPEN_WIRE_<br>ERR_STS | Reports whether an error has occurred during open-wire detection (e.g. cell-balancing is already operating). | Read-only | 0x0 | 0: False<br>1: True | | SELF_CFG:<br>0x56 | Bit[0]:<br>REGIN_EN | Enables ADC REGIN monitoring to ensure that the REGIN supply is above the defined UV level. 0: Disable REGIN check 1: Enable REGIN check | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[1]:<br>3V3_EN | Enables ADC 3V3 UV monitoring to ensure that the 3.3V supply is above the defined UV level. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[2]:<br>VDD_EN | Enables the ADC VDD monitoring check to ensure that the digital 1.8V supply is above the defined UV level. 0: Disable VDD check 1: Enable VDD check | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |-------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------|-----------------------------------------------------------| | SELF_CFG:<br>0x56 | Bit[3]:<br>ADC_SELF_<br>TEST_EN | Enables the ADC self-test check that indicates whether the applied voltage is within the allowed range. 0: Disabled 1: Enabled | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[6]:<br>OTP_CRC_EN | Enables the OTP CRC. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[9]:<br>OPEN_WIRE_<br>FAULT_EN | O: An open-wire condition does not trigger fault mode 1: An open-wire condition triggers fault mode | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[10]:<br>OPEN_WIRE_<br>PON | Enables open-wire detection when the device is powered on (leaving shutdown mode). | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[14]:<br>3V3_VDD_<br>FAULT_EN | Defines the reaction when a 3.3V UV or VDD UV condition is detected (analog comparator and ADC monitoring). 0: Disable fault mode 1: Enable fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | SELF_CFG:<br>0x56 | Bit[15]:<br>OTP_FAULT_EN | O: An OTP CRC error does not trigger fault mode 1: An OTP CRC error triggers fault mode | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | OPEN_CFG:<br>0x57 | Bits[3:0]:<br>OPW_CHECK_<br>LEN | Sets the length of each pull-up and pull-down phase. | R/W | 0x7 (OTP) | LSB: 1ms<br>RNG: 1ms to<br>16ms<br>0: 1ms | | OPEN_CFG:<br>0x57 | Bits[11:8]:<br>OPW_CHECK_<br>TH | Sets the open-wire threshold used during the detection sequence. | R/W | 0x4 (OTP) | LSB: 39.06mV<br>RNG: 39.06mV<br>to 624.96mV<br>0: 39.06mV | | REGIN_UV:<br>0x58 | Bits[8:0]:<br>REGIN_UV_<br>LIMIT | Sets the REGIN UV threshold, which is applied to ADC readings. | Read-only | 0x16D<br>(OTP) | LSB:<br>12.891mV<br>RNG: 0mV to<br>6587.1mV<br>0x000: 0mV | | V3P3_UV:<br>0x59 | Bits[7:0]:<br>3V3_UV_LIMIT | Sets the threshold for 3.3V UV conditions, which is applied to the ADC reading reported in 3V3_VALUE. | R/W | 0xF0 (OTP) | LSB: 12.89mV<br>RNG: 0mV to<br>3287.1mV<br>0x00: 0mV | | VDD_UV:<br>0x5A | Bits[7:0]:<br>VDD_UV_LIMIT | Sets the threshold for VDD 1.8V UV conditions, which is applied to the ADC reading reported in VDD_VALUE. | Read-only | 0x84 (OTP) | LSB: 12.89mV<br>RNG: 0mV to<br>3287.1mV<br>0x00: 0mV | | SELF_THR:<br>0x5B | Bits[7:0]:<br>SELF_TEST_<br>UV_LIMIT | Sets the threshold for self-test UV conditions, which is applied to the SELF_TEST_VALUE ADC readings. | Read-only | 0x55 (OTP) | LSB 12.89mV<br>RNG: 0mV to<br>3287.1mV,<br>0x00: 0mV | |-------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------|-----------|------------|------------------------------------------------------| | SELF_THR:<br>0x5B | Bits[15:8]:<br>SELF_TEST_<br>OV_LIMIT | Sets the threshold for self-test OV conditions, which is applied to SELF_TEST_VALUE ADC readings. | Read-only | 0x65 (OTP) | LSB: 12.89mV<br>RNG: 0mV to<br>3287.1mV<br>0x00: 0mV | # **Fault and Fault Recovery** | Address<br>Name and<br>Location | Field Bit Position and Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------| | FT_STS1:<br>0x5D | Bit[0]:<br>CELL_UV_<br>FAULT_STS | Reports whether a cell UV condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[1]:<br>CELL_OV_<br>FAULT_STS | Reports whether a cell OV condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[2]:<br>CELL_DEAD_<br>FAULT_STS | Reports whether a dead cell condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[3]:<br>CELL_MSMT_<br>FAULT_STS | Reports whether a cell mismatch condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[4]:<br>OPEN_WIRE_<br>FAULT_STS | Reports whether an open-wire condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[5]:<br>VTOP_UV_<br>FAULT_STS | Reports whether a VTOP UV condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[6]:<br>VTOP_OV_<br>FAULT_STS | Reports whether a VTOP OV condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[7]:<br>PCB_MNTR_<br>FAULT_STS | Reports whether an NTC PCB monitor condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[8]:<br>NTC_CELL_<br>HOT_FAULT_<br>STS | Reports whether an NTC hot cell monitoring condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[9]:<br>NTC_CELL_<br>COLD_FAULT_<br>STS | Reports whether an NTC cold cell monitoring condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[10]:<br>OC1_DCHG_<br>FAULT_STS | Reports whether a discharge over-<br>current (OC) 1 condition is<br>triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[11]:<br>OC2_DCHG_<br>FAULT_STS | Reports whether a discharge OC 2 condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[12]:<br>OC_CHG_<br>FAULT_STS | Reports whether a charge OC condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[13]:<br>SC_DCHG_<br>FAULT_STS | Reports whether a discharge short-circuit condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[14]:<br>SC_CHG_<br>FAULT_STS | Reports whether a charge short-circuit condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS1:<br>0x5D | Bit[15]:<br>DIE_TEMP_ | Reports whether a die temperature condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | |------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|--------------------------| | FT_STS2:<br>0x5E | Bit[0]: OTP_CRC_ FAULT_STS | Reports whether an OTP CRC condition is triggering a fault. This bit can be cleared with OTP_CRC_CLR. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[1]:<br>3V3_FAULT_STS | Reports whether a 3V3 UV is triggering a fault. A 3V3 fault can be triggered by ADC 3V3 UV monitoring or the 3.3V analog UV comparator. The 3.3V analog comparator is always enabled, so when 3V3_VDD_FAULT_EN is enabled, it can trigger a fault even when ADC 3V3 UV monitoring (3V3_EN) is disabled. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[2]:<br>VDD_FAULT_<br>STS | Reports whether a VDD UV is triggering a fault. A VDD fault can be triggered by ADC VDD UV monitoring or the VDD analog UV comparator. The VDD analog comparator is always enabled, so when 3V3_VDD_FAULT_EN is enabled, it can trigger a fault even when ADC VDD UV monitoring (VDD_EN) is disabled. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[3]:<br>DRIVER_<br>FAULT_STS | Reports whether a driver turn-on condition is triggering a fault. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[9]:<br>SC_CHG_<br>RECOVERY_<br>FAILED | When true, automatic recovery has failed. Use SC_CHG_FAULT_CLR to clear this bit. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[10]:<br>SC_DCHG_<br>RECOVERY_<br>FAILED | When true, automatic recovery has failed. SC_DCHG_FAULT_CLR to clear this bit. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[11]:<br>OC_CHG_<br>RECOVERY_<br>FAILED | When true, automatic recovery has failed. Use OC_CHG_FAULT_CLR to clear this bit. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[12]:<br>OC_DCHG_<br>RECOVERY_<br>FAILED | When true, automatic recovery has failed. Use OC1_DCHG_FAULT_CLR or OC2_DCHG_FAULT_CLR to clear this bit. | Read-only | 0x0 | 0: False<br>1: True | | FT_STS2:<br>0x5E | Bit[13]:<br>RMVL_BUSY | When true, short-circuit removal detection is busy after an OC or SC protection has occurred. | Read-only | 0x0 | 0: False<br>1: True | | FT_CLR:<br>0x5F | Bit[0]:<br>CELL_UV_<br>FAULT_CLR | Write 1 to this bit to manually clear a cell UV fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[1]:<br>CELL_OV_<br>FAULT_CLR | Write 1 to this bit to manually clear a cell OV fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[2]:<br>CELL_DEAD_<br>FAULT_CLR | Write 1 to this bit to manually clear a dead cell fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | |-----------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | FT_CLR:<br>0x5F | Bit[3]:<br>CELL_MSMT_<br>FAULT_CLR | Write 1 to this bit to manually clear a mismatched cell fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[4]:<br>OPEN_WIRE_<br>FAULT_CLR | Write 1 to this bit to manually clear a cell open wire fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[5]:<br>VTOP_UV_<br>FAULT_CLR | Write 1 to this bit to manually clear a battery pack UV fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[6]:<br>VTOP_OV_<br>FAULT_CLR | Write 1 to this bit to manually clear a battery pack OV fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[7]:<br>PCB_MNTR_<br>FAULT_CLR | Write 1 to this bit to manually clear an NTC PCB monitor fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[8]:<br>NTC_CELL_<br>HOT_FAULT_<br>CLR | Write 1 to this bit to manually clear a hot cell fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[9]:<br>NTC_CELL_<br>COLD_FAULT_<br>CLR | Write 1 to this bit to manually clear a cold cell fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[10]:<br>OC1_DCHG_<br>FAULT_CLR | Write 1 to this bit to manually clear a discharge OC 1 fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[11]:<br>OC2_DCHG_<br>FAULT_CLR | Write 1 to this bit to manually clear a discharge OC 2 fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[12]:<br>OC_CHG_FAULT<br>_CLR | Write 1 to this bit to manually clear a charge OC fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[13]:<br>SC_DCHG_<br>FAULT_CLR | Write 1 to this bit to manually clear a discharge short-circuit fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[14]:<br>SC_CHG_<br>FAULT_CLR | Write 1 to this bit to manually clear a charge short-circuit fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_CLR:<br>0x5F | Bit[15]:<br>DIE_TEMP_<br>FAULT_CLR | Write 1 to this bit to manually clear a die temperature fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_REC:<br>0x60 | Bit[1]:<br>NTC_CELL_<br>DCHG_REC | Enables auto-recovery from an NTC cell type fault (the temperature is back within the nominal range) in discharge mode or standby mode. Set this bit to 0 for manual recovery. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[2]:<br>NTC_CELL_<br>CHG_REC | Enables auto-recovery from an NTC cell type fault (the temperature is back within the nominal range) in charge mode. Set this bit to 0 for manual recovery. | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |-----------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | FT_REC:<br>0x60 | Bit[3]:<br>NTC_CHG_REC_<br>MODE | Defines the recovery logic from an NTC hot/cold condition in charge mode. 0: NTC voltage [>/<] NTC_CELL_XXXX_CHG ± NTC_CELL_HYST 1: (NTC voltage [>/<] NTC_CELL_HYST) 1: (NTC voltage [>/<] NTC_CELL_HYST) or if the charger is removed: (NTC voltage [>/<] NTC_CELL_HYST) In this logic, NTC_CELL_HOT_CHG or NTC_CELL_HOT_CHG or NTC_CELL_HOT_CHG with comparison. The signs within the brackets are determined by the fault. When the current is within the standby boundaries in fault mode, NTC_CELL_XXXX_THR_IN_USE depends | R/W | 0x0 (OTP) | N/A | | FT_REC:<br>0x60 | Bit[4]:<br>PCB_MNTR_REC | Enables automatic recovery from an NTC PCB monitor type fault. Set this bit to 0 for manual recovery. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[6]:<br>OC1_DCHG_REC | Enables an automatic recovery attempt for discharge OC 1 conditions. 0: Manual recovery 1: Automatic recovery attempt | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[7]:<br>OC2_DCHG_REC | Enables an automatic recovery attempt for discharge OC 2 conditions. 0: Manual recovery 1: Automatic recovery attempt | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[8]:<br>OC_CHG_REC | Enables an automatic recovery attempt for charge OC conditions. 0: Manual recovery 1: Automatic recovery attempt | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[9]:<br>SC_DCHG_REC | Enables an automatic recovery attempt for discharge short-circuit conditions. 0: Manual recovery 1: Automatic recovery attempt | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[10]:<br>SC_CHG_REC | Enables an automatic recovery attempt for charge short-circuit conditions. 0: Manual recovery 1: Automatic recovery attempt | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | |------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | FT_REC:<br>0x60 | Bit[12]:<br>DIE_TEMP_<br>FAULT_REC | Enables automatic recovery for die temperature conditions (when the temperature drops). 0: Manual recovery 1: Automatic recovery attempt | R/W (can lock to read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | FT_REC:<br>0x60 | Bit[13]:<br>DRIVER_FAULT_<br>CLR | Write 1 to this bit to manually clear a MOSFET driver fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_REC:<br>0x60 | Bit[14]:<br>OTP_CRC_CLR | Write 1 to this bit to manually clear an OTP CRC fault. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT_REC:<br>0x60 | Bit[15]:<br>3V3_VDD_<br>FAULT_CLR | Write 1 to this bit to manually clear 3.3V and 1.8V UV faults. This is a self-clearing register. | Write-only | 0x0 | 1: Execute this function | | FT0_CFG:<br>0x61 | Bit[2]:<br>CELL_HOT_<br>STBY_MODE | Defines the selection criteria for the NTC hot threshold when the battery pack current is within the STBY_CUR_TH range. 0: Available. The hotter threshold (and lower voltage) is selected between NTC_CELL_HOT_CHG and NTC_CELL_HOT_DISCH, and applied when the battery pack current is within the standby region 1: Conservative. The colder threshold (and higher voltage) is selected between NTC_CELL_HOT_CHG and NTC_CELL_HOT_DISCH, and applied when the battery pack current is within the standby region | R/W | 0x0 | N/A | | FT0_CFG:<br>0x61 | Bit[3]:<br>CELL_COLD_<br>STBY_MODE | Defines the selection criteria for the NTC cold threshold when the battery pack current is within the STBY_CUR_TH range. 0: Available. The colder threshold (and higher voltage) is selected between NTC_CELL_COLD_DISCH and NTC_CELL_COLD_CHG, and applied when the battery pack current is within the standby region 1: Conservative. The hotter threshold (and lower voltage) is selected between NTC_CELL_COLD_DISCH and NTC_CELL_COLD_DISCH and NTC_CELL_COLD_CHG, and applied when the battery pack current is within the standby region | R/W | 0x0 | N/A | | FT0_CFG:<br>0x61 | Bit[5]:<br>CELL_UV_<br>LOGIC_SEL | Selects which logic is used for status recovery from cell UV conditions. 0: The status recovers once the cell exceeds (UV threshold + hysteresis) 1: The status recovers by following either logic below: • The cell exceeds the UV threshold and the PACKP voltage exceeds (VTOP + 270mV) • The cell exceeds (UV threshold + hysteresis) | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | N/A | |------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|------------------------------------------------------------------------------------------| | FT0_CFG:<br>0x61 | Bit[7]:<br>CELL_UV_REC | O: Manual recovery from cell UV fault 1: Automatic recovery from cell UV fault | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | FT0_CFG:<br>0x61 | Bit[9]:<br>CELL_OV_<br>LOGIC_SEL | Selects which logic is used for status recovery from cell OV conditions. 0: The status recovers once the cell falls below (OV threshold - hysteresis) 1: The status recovers by following either logic below: • The cell falls below the OV threshold and the PACKP voltage falls below (VTOP – 1.6V) • The cell falls below (OV threshold – hysteresis) | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | N/A | | FT0_CFG:<br>0x61 | Bit[11]:<br>CELL_OV_REC | O: Manual recovery from cell OV fault 1: Automatic recovery from cell OV fault | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | FT1_CFG:<br>0x62 | Bits[1:0]:<br>SCOC_PUP | Sets the battery pack pull-up current during short-circuit removal detection. | R/W | 0x0 (MTP) | 0x0: 250μA<br>0x1: 500μA<br>0x2: 750μA<br>0x3: 250μA | | FT1_CFG:<br>0x62 | Bits[3:2]:<br>SCOC_DET_<br>TIME | Sets the time for SCOC_PUP. | R/W | 0x0 (MTP) | 0x0: 125ms<br>0x1: 250ms<br>0x2: 500ms<br>0x3: 1s | | FT1_CFG:<br>0x62 | Bits[6:4]:<br>SCOC_RETRY_<br>DELAY | Sets the delay between short-circuit removal detection and a retry. | R/W | 0x0 (MTP) | 0x0: 1s<br>0x1: 2s<br>0x2: 4s<br>0x3: 6s<br>0x4: 10s<br>0x5: 15s<br>0x6: 20s<br>0x7: 25s | | FT1_CFG:<br>0x62 | Bits[14:13]:<br>SC_PUP_<br>RETRY_N | Sets how many times short-circuit removal detection retries. 2'b00: Keep trying 2'b01: 1 try 2'b10: 2 tries 2'b11: 4 tries | R/W | 0x0 (MTP) | N/A | | FT2_CFG:<br>0x63 | Bits[1:0]:<br>OC1_DCHG_<br>COOL | Sets the discharge OC 1 cool-down time. 2'b00: 100ms 2'b01: 200ms 2'b10: 500ms 2'b11: 1s | R/W | 0x0 (MTP) | N/A | |------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----|-----------|----------------------------------| | FT2_CFG:<br>0x63 | Bits[3:2]:<br>OC1_DCHG_<br>RETRY | Sets the number of discharge OC 1 reconnection attempts. 2'b00: 1 time 2'b01: 2 times 2'b10: 3 times 2'b11: Keep trying | R/W | 0x0 (MTP) | LSB: 1 attempt<br>0x0: 1 attempt | | FT2_CFG:<br>0x63 | Bits[5:4]:<br>OC2_DCHG_<br>COOL | Sets the discharge OC 2 cool-down time. 2'b00: 100ms 2'b01: 200ms 2'b10: 500ms 2'b11: 1s | R/W | 0x0 (MTP) | N/A | | FT2_CFG:<br>0x63 | Bits[7:6]:<br>OC2_DCHG_<br>RETRY | Sets the number of discharge OC 2 reconnection attempts. 2'b00: 1 time 2'b01: 2 times 2'b10: 3 times 2'b11: Keep trying | R/W | 0x0 (MTP) | LSB: 1 attempt 0x0: 1 attempt | | FT2_CFG:<br>0x63 | Bits[9:8]:<br>OC_CHG_COOL | Sets the charge OC cool-down time. 2'b00: 100ms 2'b01: 200ms 2'b10: 500ms 2'b11: 1s | R/W | 0x0 (MTP) | N/A | | FT2_CFG:<br>0x63 | Bits[11:10]:<br>OC_CHG_RETRY | Sets the number of charge OC reconnection attempts. 2'b00: 1 time 2'b01: 2 times 2'b10: 3 times 2'b11: Keep trying | R/W | 0x0 (MTP) | N/A | ### **ADC** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------|----------------------------------------------------|-----------|--------------------------|-----------------------------------------------------------| | RD_VPACKP:<br>0x69 | Bits[14:0]:<br>VPACK_V | Returns the PACKP high-resolution voltage reading. | Read-only | 0x0000 | LSB:<br>0.002441V<br>RNG: 0V to<br>79.9976V<br>0x0000: 0V | | RD_VTOP:<br>0x6A | Bits[14:0]:<br>VTOP_V | Returns the VTOP high-resolution voltage reading. | Read-only | 0x0000 | LSB:<br>0.002441V<br>RNG: 0V to<br>79.9976V<br>0x0000: 0V | | RD_ITOP:<br>0x6B | Bits[15:0]:<br>VTOP_I | Returns the battery pack current reading (synchronous to VTOP_V). Signed short integer, and ranges from -32768 to +32767. | Read-only | 0x0000 | LSB:<br>0.00305176mV<br>RNG: -100mV<br>to +99.997mV<br>0x0000: 0mV | |---------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------|--------|--------------------------------------------------------------------| | RD_VCELL1:<br>0x6C | Bits[14:0]:<br>CELL_1_V | Returns the cell 1 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL2:<br>0x6E | Bits[14:0]:<br>CELL_2_V | Returns the cell 2 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL3:<br>0x70 | Bits[14:0]:<br>CELL_3_V | Returns the cell 3 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL4:<br>0x72 | Bits[14:0]:<br>CELL_4_V | Returns the cell 4 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL5:<br>0x74 | Bits[14:0]:<br>CELL_5_V | Returns the cell 5 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL6:<br>0x76 | Bits[14:0]:<br>CELL_6_V | Returns the cell 6 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL7:<br>0x78 | Bits[14:0]:<br>CELL_7_V | Returns the cell 7 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL8:<br>0x7A | Bits[14:0]:<br>CELL_8_V | Returns the cell 8 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL9:<br>0x7C | Bits[14:0]:<br>CELL_9_V | Returns the cell 9 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL10:<br>0x7E | Bits[14:0]:<br>CELL_10_V | Returns the cell 10 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL11:<br>0x80 | Bits[14:0]:<br>CELL_11_V | Returns the cell 11 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL12:<br>0x82 | Bits[14:0]:<br>CELL_12_V | Returns the cell 12 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | |---------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------|--------|-----------------------------------------------------------------------------------------------| | RD_VCELL13:<br>0x84 | Bits[14:0]:<br>CELL_13_V | Returns the cell 13 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL14:<br>0x86 | Bits[14:0]:<br>CELL_14_V | Returns the cell 14 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL15:<br>0x88 | Bits[14:0]:<br>CELL_15_V | Returns the cell 15 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VCELL16:<br>0x8A | Bits[14:0]:<br>CELL_16_V | Returns the cell 16 high-resolution reading. | Read-only | 0x0000 | LSB:<br>0.15259mV<br>RNG: 0mV to<br>4999.85mV<br>0x0000: 0mV | | RD_VNTC4:<br>0x8C | Bits[14:0]:<br>NTC4_HIRES_V | Returns the NTC4 high-resolution voltage ADC reading. This reading is ratiometric to NTCB, which has a 3.3V nominal value. | Read-only | 0x0000 | LSB: 0.00305176% of NTCB RNG: 0% to 99.99695% of NTCB 0x0000: 0% of NTCB | | RD_VNTC3:<br>0x8D | Bits[14:0]:<br>NTC3_HIRES_V | Returns the NTC3 high-resolution voltage ADC reading. This reading is ratiometric to NTCB, which has a 3.3V nominal value. | Read-only | 0x0000 | LSB: 0.00305176% of NTCB RNG: 0% to 99.99695% of NTCB 0x0000: 0% of NTCB | | RD_VNTC2:<br>0x8E | Bits[14:0]:<br>NTC2_HIRES_V | Returns the NTC2 high-resolution voltage ADC reading. This reading is ratiometric to NTCB, which has a 3.3V nominal value. | Read-only | 0x0000 | LSB: 0.00305176% of NTCB RNG: 0% to 99.99695% of NTCB 0x0000: 0% of NTCB | | RD_VNTC1:<br>0x8F | Bits[14:0]:<br>NTC1_HIRES_V | Returns the NTC1 high-resolution voltage ADC reading. This reading is ratiometric to NTCB, which has a 3.3V nominal value. | Read-only | 0x0000 | LSB:<br>0.00305176%<br>of NTCB<br>RNG: 0% to<br>99.99695% of<br>NTCB<br>0x0000: 0% of<br>NTCB | | RD_VGPIO3:<br>0x90 | Bits[14:0]:<br>GPIO3_<br>VOLTAGE | Returns the GPIO3 high-resolution voltage reading. | Read-only | 0x0000 | LSB:<br>0.1007mV<br>RNG: 0mV to<br>3299.9mV<br>0x0000: 0mV | | | | | | | LSB: | |---------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------|------------------------------------------------------------------------| | RD_VGPIO2:<br>0x91 | Bits[14:0]:<br>GPIO2_<br>VOLTAGE | Returns the GPIO2 high-resolution voltage reading. | Read-only | 0x0000 | 0.1007mV<br>RNG: 0mV to<br>3299.9mV<br>0x0000: 0mV | | RD_VGPIO1:<br>0x92 | Bits[14:0]:<br>GPIO1_<br>VOLTAGE | Returns the GPIO1 high-resolution voltage reading. | Read-only | 0x0000 | LSB:<br>0.1007mV<br>RNG: 0mV to<br>3299.9mV<br>0x0000: 0mV | | RD_TDIE:<br>0x93 | Bits[14:0]:<br>DIE_T_<br>VOLTAGE | Returns the die temperature high-<br>resolution reading, which is<br>proportional to the internal die<br>temperature. The temperature can<br>be calculated with the following<br>equation: | Read-only | 0x0000 | LSB:<br>0.01481°C<br>RNG:<br>-269.12°C to<br>+216.16°C<br>0x4D93: 25°C | | | | T = Reading x 0.01481 - 269.12°C | | | | | | | This field reports the status of the feature command scheduler. | | | | | ADC_STS:<br>0x98 | Bits[9:8]:<br>FSM_STS | 0x0: Free 0x1: Executing voltage ADC scan 0x2: Executing cell-balancing 0x3: Executing open-wire detection | Read-only | 0x0 | N/A | | | | This field reports the status of the internal scheduler. | | | | | ADC_STS:<br>0x98 | Bits[12:11]:<br>INT_<br>SCHEDULER | 0x0: Idle 0x1: Refreshing voltage protection reading 0x2: Ready for the feature command 0x3: Not allowed | Read-only | 0x0 | N/A | | ADC_CTRL:<br>0x99 | Bit[0]:<br>ADC_SCAN_GO | Write 1 to this bit to start a high-resolution scan for all the selected channels. | R/W | 0x0 | 1: Execute this function | | ADC_CTRL:<br>0x99 | Bit[1]:<br>SCAN_DONE_<br>STS | Reports whether the high-resolution voltage scan status is complete (true) or not (false). | Read-only | 0x0 | 0: False<br>1: True | | ADC_CTRL:<br>0x99 | Bit[2]:<br>SCAN_ERROR_<br>STS | Reports whether an error has occurred when starting the high-resolution voltage scan (e.g. if openwire detection is already running). | Read-only | 0x0 | 0: False<br>1: True | | TRIMG_IPCB:<br>0x9B | Bits[9:0]:<br>I_PCB_GAIN_<br>VALUE | Current-sense PCB gain correction can compensate for sense resistors and SMT variation. The correction is applied to current ADC readings. It is not applied to short-circuit or OC detection. The encoding is in binary complement format, where LSB = 0.0244% and ranges between ±12.5%. | R/W (can<br>lock to<br>read-only) | 0x000 (MTP) | LSB: 0.0244%<br>RNG: -12.5%<br>to +12.476%,<br>0x000: 0% | | HR_SCAN0:<br>0x9C | Bit[0]:<br>SCAN_VCELLS_<br>EN | Enables the cell readings to be updated during the high-resolution voltage ADC scan, according to the enable setting of each individual cell. When disabled, the cell readings are excluded from the high-resolution voltage ADC scan. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[1]:<br>SCAN_VTOP_<br>EN | Enables the VTOP reading to be updated during the high-resolution voltage ADC scan. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |-------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|---------------------------| | HR_SCAN0:<br>0x9C | Bit[2]:<br>SCAN_PACKP_<br>EN | Enables the PACKP reading to be updated during the high-resolution voltage ADC scan. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[3]:<br>SCAN_GPIO_EN | Enables GPIO readings to be updated during the high-resolution voltage ADC scan, according to each individual GPIO enable setting. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[4]:<br>SCAN_NTCS_<br>EN | Enables the NTCs scan to be updated during the high-resolution voltage ADC scan, according to the enable setting of each individual NTC channel. | R/W (can lock to read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[5]:<br>SCAN_DIE_T | Enables the die temperature to be updated during the high-resolution voltage ADC scan. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[9]:<br>VTOP_SYNC_<br>EN | Enables the battery pack current reading that is synchronous with the VTOP reading to be updated during the high-resolution voltage ADC scan. When disabled, the synchronous VTOP current reading cannot be updated. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN0:<br>0x9C | Bit[11]:<br>CELL_1K_<br>COMP | Enables ADC cell measurement compensation for the voltage drop caused by the cell input resistor, RCELL_FILTER. This configuration should be enabled when the input filter resistor exceeds $500\Omega$ . For RCELL_FILTER values below $500\Omega$ , this should be disabled. | R/W | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[0]:<br>CELL_1_V_<br>READ_EN | Enables the cell 1 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[1]:<br>CELL_2_V_<br>READ_EN | Enables the cell 2 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[2]:<br>CELL_3_V_<br>READ_EN | Enables the cell 3 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[3]:<br>CELL_4_V_<br>READ_EN | Enables the cell 4 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[4]:<br>CELL_5_V_<br>READ_EN | Enables the cell 5 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[5]:<br>CELL_6_V_<br>READ_EN | Enables the cell 6 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | HR_SCAN1:<br>0x9D | Bit[6]:<br>CELL_7_V_<br>READ_EN | Enables the cell 7 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[7]:<br>CELL_8_V_<br>READ_EN | Enables the cell 8 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | |-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit[8]:<br>CELL_9_V_<br>READ_EN | Enables the cell 9 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[9]:<br>CELL_10_V_<br>READ_EN | Enables the cell 10 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[10]:<br>CELL_11_V_<br>READ_EN | Enables the cell 11 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[11]:<br>CELL_12_V_<br>READ_EN | Enables the cell 12 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[12]:<br>CELL_13_V_<br>READ_EN | Enables the cell 13 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[13]:<br>CELL_14_V_<br>READ_EN | Enables the cell 14 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[14]:<br>CELL_15_V_<br>READ_EN | Enables the cell 15 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[15]:<br>CELL_16_V_<br>READ_EN | Enables the cell 16 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x1 (OTP) | 0: Disabled<br>1: Enabled | | Bit[0]:<br>GPIO1_READ_<br>EN | Enables the GPIO1 high-resolution voltage. Effective when SCAN_GPIO_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[1]:<br>GPIO2_READ_<br>EN | Enables the GPIO2 high-resolution voltage. Effective when SCAN_GPIO_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[2]:<br>GPIO3_READ_<br>EN | Enables the GPIO3 high-resolution voltage. Effective when SCAN_GPIO_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[5]:<br>NTC1_READ_<br>EN | Enables the NTC1 high-resolution voltage scan. Effective when SCAN_NTCS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[6]:<br>NTC2_READ_<br>EN | Enables the NTC2 high-resolution voltage scan. Effective when SCAN_NTCS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[7]:<br>NTC3_READ_<br>EN | Enables the NTC3 high-resolution voltage scan. Effective when SCAN_NTCS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | Bit[8]:<br>NTC4_READ_<br>EN | Enables the NTC4 high-resolution voltage scan. Effective when SCAN_NTCS_EN is enabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | | CELL_8_V_ READ_EN Bit[8]: CELL_9_V_ READ_EN Bit[9]: CELL_10_V_ READ_EN Bit[10]: CELL_11_V_ READ_EN Bit[11]: CELL_12_V_ READ_EN Bit[12]: CELL_13_V_ READ_EN Bit[13]: CELL_14_V_ READ_EN Bit[14]: CELL_15_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[1]: GPIO1_READ_EN Bit[1]: GPIO2_READ_EN Bit[1]: GPIO3_READ_EN | CELL_8_V_ READ_EN Bit[8]: CELL_9_V_ READ_EN Bit[9]: CELL_10_V_ READ_EN Bit[10]: CELL_11_V_ READ_EN Bit[11]: CELL_11_V_ READ_EN Bit[11]: CELL_12_V_ READ_EN Bit[11]: CELL_12_V_ READ_EN Bit[12]: CELL_13_V_ READ_EN Bit[13]: CELL_14_V_ READ_EN Bit[13]: CELL_15_EN Bit[15]: CELL_14_V_ READ_EN Bit[16]: CELL_15_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[16]: CELL_16_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[15]: CELL_16_V_ READ_EN Bit[16]: CELL_16_V_ READ_EN Bit[16]: CELL_16_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[16]: CELL_16_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[17]: CELL_16_V_ READ_EN Bit[18]: CELL_16_V_ READ_EN Bit[19]: CELL_16_V_ READ_EN Bit[10]: CELL_16_V_ READ_EN CELL_1 | CELL_8_V READ_EN SCAN_VCELLS_EN is enabled. Bit[8]: | CELL_8_V_READ_EN voltage. Effective when READ_EN R/W 0x1 (OTP) Bit(8): CELL_9_V_READ_EN Enables the cell 9 high-resolution voltage. Effective when READ_EN RCAD_EN RCAD_EN Dx1 (OTP) Bit(9): CELL_10_V_READ_EN Enables the cell 10 high-resolution voltage. Effective when READ_EN RCAD_EN RCAD_EN RCAD_EN RCAD_EN RCAD_EN RCAD_EN Dx1 (OTP) Bit(10): CELL_11_V_Valtage. Effective when READ_EN Enables the cell 11 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. RCAD_EN Dx1 (OTP) Bit(11): CELL_12_V_READ_EN Enables the cell 12 high-resolution voltage. Effective when READ_EN RCAD_EN Dx1 (OTP) Bit(12): CELL_13_V_CELL_14_V_READ_EN Enables the cell 14 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. RCAD_COLL_SEN is enabled. RCAD_COLL_SEN is enabled. RCAD_COLL_SEN is enabled. Dx1 (OTP) Bit(13): CELL_14_V_READ_EN Enables the cell 15 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. RCAD_COLL_SEN is enabled. RCAD_COLL_SEN is enabled. Dx1 (OTP) Bit(15): CELL_16_V_READ_EN Enables the cell 15 high-resolution voltage. Effective when SCAN_VCELLS_EN is enabled. RCAN_CCAN_COLL_SEN is enabled. Dx1 (OTP) Dx1 (OTP) Dx1 | #### Communication | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------|--------------------------------------------------------| | SILC_INFO1:<br>0xA0 | Bits[5:0]:<br>XFR_NUM_RD_<br>WORDS | When CRC is enabled, this register defines the size of the readback in words before appending a CRC. After each read transaction, this bit self-resets back to 2 bytes. 6'b000001: 1 word / 2 bytes 6'b111111: 63 words / 126 bytes | R/W | 0x01 | LSB: 1 word,<br>RNG: 1 to 63<br>words<br>0x00: 0 words | | COMM_CFG:<br>0xA3 | Bit[2]:<br>USE_COMM_<br>CRC | Enables the use of CRC over the communication protocol. | R/W (can<br>lock to<br>Read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | COMM_CFG:<br>0xA3 | Bits[14:8]:<br>DEVICE_ADD | Sets the configurable device address. | R/W (can<br>lock to<br>read-only) | 0x01 (MTP) | N/A | # **Cell-Balancing** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |---------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------| | BAL_STS:<br>0xA4 | Bit[0]:<br>BALANCING_<br>ACTIVE | Reports whether cell-balancing is currently ongoing. | Read-only | 0x0 | 0: False<br>1: True | | BAL_STS:<br>0xA4 | Bits[6:1]: AUTO_<br>BALANCING_<br>COUNT_STS | Shows the number of balancing cycles that are actually performed. To be valid, BAL_DONE must be set to true. If any balancing cycle is skipped, the reason can be verified by reading AUTO_BAL_SKIPPED_HOT, AUTO_BAL_SKIPPED_DISCHAR GE, AUTO_BAL_SKIPPED_STANDBY, or AUTO_BAL_SKIPPED_CHARGE. This register is not updated when AUTO_BAL_ALWAYS is enabled. | Read-only | 0x00 | N/A | | BAL_STS:<br>0xA4 | Bit[7]:<br>AUTO_BAL_<br>SKIPPED_<br>CHARGE | When true, balancing cycles were skipped due to a detected charge current. | Read-only | 0x0 | 0: False<br>1: True | | BAL_STS:<br>0xA4 | Bit[8]:<br>AUTO_BAL_<br>SKIPPED_<br>STANDBY | When true, balancing cycles were skipped due to a detected standby current. | Read-only | 0x0 | 0: False<br>1: True | | BAL_STS:<br>0xA4 | Bit[9]:<br>AUTO_BAL_<br>SKIPPED_<br>DISCHARGE | When true, balancing cycles were skipped due to a detected discharge current. | Read-only | 0x0 | 0: False<br>1: True | | BAL_STS:<br>0xA4 | Bit[10]:<br>AUTO_BAL_<br>SKIPPED_HOT | When true, balancing cycles were skipped due to the die temperature being too hot. | Read-only | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[0]:<br>CELL_1_TO_<br>BALANCE | When true, cell 1 will be balanced during the next balancing session. When false, cell 1 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[1]:<br>CELL_2_TO_<br>BALANCE | When true, cell 2 will be balanced during the next balancing session. When false, cell 2 is skipped. | R/W | 0x0 | 0: False<br>1: True | |-------------------|------------------------------------|--------------------------------------------------------------------------------------------------------|-----------|-----|---------------------| | BAL_LIST:<br>0xA5 | Bit[2]:<br>CELL_3_TO_<br>BALANCE | When true, cell 3 will be balanced during the next balancing session. When false, cell 3 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[3]:<br>CELL_4_TO_<br>BALANCE | When true, cell 4 will be balanced during the next balancing session. When false, cell 4 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[4]:<br>CELL_5_TO_<br>BALANCE | When true, cell 5 will be balanced during the next balancing session. When false, cell 5 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[5]:<br>CELL_6_TO_<br>BALANCE | When true, cell 6 will be balanced during the next balancing session. When false, cell 6 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[6]:<br>CELL_7_TO_<br>BALANCE | When true, cell 7 will be balanced during the next balancing session. When false, cell 7 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[7]:<br>CELL_8_TO_<br>BALANCE | When true, cell 8 will be balanced during the next balancing session. When false, cell 8 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[8]:<br>CELL_9_TO_<br>BALANCE | When true, cell 9 will be balanced during the next balancing session. When false, cell 9 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[9]:<br>CELL_10_TO_<br>BALANCE | When true, cell 10 will be balanced during the next balancing session. If false, cell 10 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[10]:<br>CELL_11_TO_<br>BALANCE | When true, cell 11 will be balanced during the next balancing session. When false, cell 11 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[11]:<br>CELL_12_TO_<br>BALANCE | When true, cell 12 will be balanced during the next balancing session. When false, cell 12 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[12]:<br>CELL_13_TO_<br>BALANCE | When true, cell 13 will be balanced during the next balancing session. When false, cell 13 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[13]:<br>CELL_14_TO_<br>BALANCE | When true, cell 14 will be balanced during the next balancing session. When false, cell 14 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[14]:<br>CELL_15_TO_<br>BALANCE | When true, cell 15 will be balanced during the next balancing session. When false, cell 15 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_LIST:<br>0xA5 | Bit[15]:<br>CELL_16_TO_<br>BALANCE | When true, cell 16 will be balanced during the next balancing session. When false, cell 16 is skipped. | R/W | 0x0 | 0: False<br>1: True | | BAL_CTRL:<br>0xA6 | Bit[0]:<br>BALANCE_GO | Controls the start for both manual and automatic cell-balancing. When set to on, balancing begins. | R/W | 0x0 | 0: Off<br>1: On | | BAL_CTRL:<br>0xA6 | Bit[1]:<br>BAL_DONE_<br>STS | Reports whether cell-balancing is completed. | Read-only | 0x0 | 0: False<br>1: True | | BAL_CTRL:<br>0xA6 | Bit[2]:<br>BAL_ERROR_<br>STS | Reports whether an error occurs when balancing starts (e.g. if openwire detection is already running). | Read-only | 0x0 | 0: False<br>1: True | | BAL_CFG:<br>0xA7 | Bit[0]:<br>BALANCE_<br>MODE_CTRL | This register is used only when automatic cell-balancing is enabled. This feature is only available on I <sup>2</sup> C versions. 0: Register control (BALANCE_GO) 1: GPIO3 control (the direction of GPIO3 is set as input, and the input type is set as digital input). When set to high, balancing begins | R/W | 0x0 (OTP) | N/A | |------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|--------------------------------------------------------------------------------| | BAL_CFG:<br>0xA7 | Bit[1]:<br>BALANCE_<br>MODE_REG | Controls the cell-balancing mode. 0: Manual cell-balancing 1: Automatic cell-balancing | R/W (can lock to read-only) | 0x0 (OTP) | N/A | | BAL_CFG:<br>0xA7 | Bit[2]:<br>AUTO_BAL_<br>ALWAYS | This register is used only when automatic cell-balancing is enabled. When disabled, automatic cell-balancing uses BAL_REPETITION to control how many iterations the device repeats. When enabled, balancing continues until the balancing list is empty. To stop constant automatic cell-balancing before the balancing list is empty, change this bit to disabled. | R/W (can<br>lock to<br>read-only) | 0x0 (OTP) | 0: Disabled<br>1: Enabled | | BAL_CFG:<br>0xA7 | Bits[7:3]:<br>BAL_<br>REPETITION | Sets the number of repetitions for each execution of the balancing list. When set to 31 repetitions, 32 balancing cycles are executed. | R/W | 0x1F (OTP) | LSB: 1<br>repetition<br>RNG: 0 to 31<br>repetitions,<br>0x00: 0<br>repetitions | | BAL_THR:<br>0xA8 | Bits[5:0]:<br>CELL_BAL_MIN | Sets the qualifying minimum cell voltage to run automatic cell-balancing. When a cell is below this level, it is excluded from the balancing list, while other qualifying cells could be balanced if they meet applicable criteria. | R/W | 0x21 (OTP) | LSB: 39mV<br>RNG: 2500mV<br>to 4961mV<br>0x00: 2500mV | | BAL_THR:<br>0xA8 | Bit[6]:<br>ABAL_ON_<br>CHARGE | This register is used only when automatic cell-balancing is enabled. 0: Automatic balancing does not run when there is a charge current that exceeds the charge standby threshold 1: Automatic balancing can run when there is a charge current that exceeds the charge standby threshold | R/W | 0x0 | 0: Disabled<br>1: Enabled | | BAL_THR:<br>0xA8 | Bit[7]:<br>ABAL_ON_STBY | This register is used only when automatic cell-balancing is enabled. 0: Automatic balancing does not run when the current is between 0 and the standby threshold 1: Automatic balancing can run when the current is between 0 and the standby threshold | R/W | 0x0 | N/A | | BAL_THR:<br>0xA8 | Bit[9]:<br>STOP_ON_HOT | O: Don't suspend automatic cell-balancing if the silicon digital die temperature is too hot Suspend automatic cell-balancing if the silicon digital die temperature is too hot | R/W | R/W 0x0 | | |------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------|-----------------------------------------------------------| | BAL_THR:<br>0xA8 | Bits[12:10]:<br>BAL_MSM_TH | The cell-balancing threshold used by the automatic cell-balancing algorithm. | R/W | 0x2 (OTP) | LSB:<br>9.765mV<br>RNG: 19.5mV<br>to 87.85mV<br>0: 19.5mV | ## **Memory Control** | Address Name and Location | Field Bit<br>Position and<br>Name | Description | Туре | Value Reset<br>(OTP/MTP) | Encoding,<br>LSB and<br>Range | |----------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-----------------------------------| | | | Returns the thermometer-coded confirmation status of the NVM: | | | | | MEM_STATUS:<br>0xB4 | Bits[5:3]:<br>NVM_STATUS | 3'bxx1: NVM Page 1 has been fully configured, and the NVM-backed registers can be loaded and use CRC if enabled 3'bx1x: NVM Page 2 has been fully configured, and the NVM-backed registers can be loaded and use CRC if enabled 3'b1xx: NVM Page 3 has been fully configured, and the NVM-backed registers can be loaded and use CRC if enabled | Read-only | 0x1 | N/A | | OTP_CRC_<br>STATUS:<br>0xB6 | Bit[15]:<br>OTP_CRC_<br>ERROR | Reports whether an OTP CRC error has been detected. It is set by a CRC error during OTP restoration, and is reset by the restore command. | Read-only | 0x0 | 0: Not<br>detected<br>1: Detected | | NVM_CRC_<br>STATUS:<br>0xB7 | Bit[15]:<br>NVM_CRC_ERR<br>OR | Reports whether an NVM CRC error has been detected. It is set by a CRC error during NVM restoration, and it is reset by the restore command. | Read-only | 0x0 | 0: Not<br>detected<br>1: Detected | | OTP_STORE_<br>CMD:<br>0xB8 | Bit[0]:<br>RESERVED | Reserved. Do not change this register value. | R/W | 0x0 | N/A | | OTP_STORE_<br>CMD:<br>0xB8 | Bit[1]:<br>RESERVED | Reserved. Do not change this register value. | R/W | 0x0 | N/A | | OTP_STORE_<br>CMD:<br>0xB8 | Bit[2]:<br>RESERVED | Reserved. Do not change this register value. | R/W | 0x0 | N/A | | OTP_STORE_ Bit[3]: CMD: STORE_NVM_ CMD | | Store all NVM registers and the NVM CRC code in the OTP if STORE_CMD_ACCESS_CODE has been configured with the correct code. | R/W | 0x0 | N/A | | | | 1: Store all NVM registers and the NVM CRC code in the OTP. This is a self-clearing register | | | | # MP2796 - 7-CELL TO 16-CELL BATTERY MONITOR AND PROTECTOR | OTP_STORE_<br>CMD:<br>0xB8 | Bit[4]:<br>RESERVED | Reserved. Do not change this register value. | R/W | 0x0 | N/A | |----------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------|-----| | OTP_STORE_<br>CMD:<br>0xB8 | Bit[15]:<br>STORE_IN_<br>PROGRESS | Reports whether the store function is in progress. 0: Storage of register data to the MTP memory is not in progress 1: Storage of register data to the MTP memory is in progress | Read-only | 0x0 | N/A | | STORE_CMD_<br>ACCESS_<br>CODE:<br>0xB9 | Bits[15:0]:<br>STORE_CMD_<br>ACCESS_CODE | Before enabling the STORE_NVM_CMD command, 0xA5B6 must be written to this register to allow for the store command. This bit should be cleared once storage is complete. | R/W | 0x0000 | N/A | ## LOCK REGISTER MAP The MP2796 supports the configuration register lock function. This prevents critical safety settings from changing due to unforeseen circumstances All of the bits in an address that are not populated by a register should be treated as reserved. The value of these reserved bits may be 0 or 1, and should be set to 0 when there are write operations changing other bits in the same address. Setting these reserved bits to 0 does not change the value of the reserved bits. Once the lock bit is set to 1, it cannot be set to 0 unless the MP2796 is reset. All of the locking bits support the MTP, and the default value is 0. If the lock bit in the MTP is set to 1, the corresponding setting register cannot be modified anymore. Before setting the MTP command, carefully consider whether to set the locking bit to 1. Table 17 shows the lock register map. **Table 17: Lock Register Map** | Register Location and Bit Position for Locking | Locked Address Name and Location | Locked Field Bit Position and Name | |------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ov A A : D:4F4.E1 | FET_MODE: 0x13 | Bit[11]: CHG_SOFTON_OC_LIM Bit[9]: TURNON_TIMEOUT_FAULT Bit[8]: CHG_TURNON_TIMER | | 0xAA: Bit[15] | FET_CFG: 0x14 | Bits[14:12]: FET_DRV_LVL Bits[11:9]: CHG_SOFTON_PUP Bits[2:0]: DSG_SOFTON_DV | | 0xAA: Bit[14] | FET_MODE: 0x13 | Bit[12]: P_FET_MANUAL Bit[3]: FET_ON_RUN_SC_DET_EN | | 0xAA: Bit[13] | WDT_CFG: 0x10 | Bits[15:9]: WDT_BITE_CFG Bits[8:2]: WDT_BARK_CFG Bit[0]: WDT_COM_CTRL | | 0xAA: Bit[12] | PINS_CFG: 0x0D | Bit[8]: GPIO_LV_CFG Bit[6]: WDT_RST_EN Bit[5]: WDT_RPT Bit[0]: ALERT_POL | | 0xAA: Bit[11] | GPIO_CFG: 0x0C | Bit[11]: GPIO3_FSEL Bit[10]: GPIO3_PUP Bit[9]: GPIO3_TYPE Bit[8]: GPIO3_IO Bit[6]: GPIO2_PUP Bit[5]: GPIO2_TYPE Bit[4]: GPIO2_IO Bit[2]: GPIO1_PUP Bit[1]: GPIO1_TYPE Bit[0]: GPIO1_IO | | 0xAA: Bit[8] | RGL_CFG: 0x08 | Bit[2]: V3P3_SHDN_EN | | 0xAA: Bit[6] | STB_CFG: 0x06 | Bits[5:4]: STBY_MONITOR_CFG | | | T | T | |---------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 0xAA: Bit[5] | STB_CFG: 0x06 | Bit[6]: STBY_PFET_EN | | 0xAA: Bit[3] | ACT_CFG: 0x05 | Bit[9]: FT_STATE_SEL | | 0xAA: Bit[2] | ACT_CFG: 0x05 | Bit[1]: FET_CFG | | 0xAA: Bit[1] | ACT_CFG: 0x05 | Bit[0]: FET_SRC | | 0xAB: Bit[14] | HR_SCAN2: 0x9E | Bit[8]: NTC4_READ_EN Bit[7]: NTC3_READ_EN Bit[6]: NTC2_READ_EN Bit[5]: NTC1_READ_EN | | 0xAB: Bit[13] | HR_SCAN2: 0x9E | Bit[2]: GPIO3_READ_EN Bit[1]: GPIO2_READ_EN Bit[0]: GPIO1_READ_EN | | 0xAB: Bit[12] | HR_SCAN1: 0x9D | Bit[15]: CELL_16_V_READ_EN Bit[14]: CELL_15_V_READ_EN Bit[13]: CELL_14_V_READ_EN Bit[12]: CELL_13_V_READ_EN | | 0xAB: Bit[11] | TRIMG_IPCB: 0x9B | Bits[9:0]: I_PCB_GAIN_VALUE | | 0xAB: Bit[7] | DIE_CFG: 0x46 | Bit[3]: DIE_TEMP_DIG_FAULT_EN | | 0xAB: Bit[6] | DIE_CFG: 0x46 | Bit[1]: DIE_TEMP_DIG_EN | | 0xAB: Bit[4] | CELLFT_CTRL: 0x35 | Bit[5]: CELL_OV_FAULT_EN Bit[2]: CELL_UV_FAULT_EN | | 0xAB: Bit[3] | PACKFT_CTRL: 0x34 | Bit[12]: CELL_MSMT_FAULT_EN Bit[9]: CELL_DEAD_FAULT_EN Bit[5]: VTOP_OV_FAULT_EN_CTRL Bit[1]: VTOP_UV_FAULT_EN_CTRL | | 0xAB: Bit[2] | SCFT_CTRL: 0x2A | Bit[5]: SC_CHG_FAULT_EN Bit[4]: SC_DCHG_FAULT_EN Bit[1]: SC_CHG_EN_CTRL Bit[0]: SC_DCHG_EN_CTRL | | 0xAB: Bit[1] | OCFT_CTRL: 0x23 | Bit[8]: OC_CHG_FAULT_EN Bit[7]: OC2_DCHG_FAULT_EN Bit[6]: OC1_DCHG_FAULT_EN Bit[2]: OC_CHG_EN_CTRL Bit[1]: OC2_DCHG_EN_CTRL Bit[0]: OC1_DCHG_EN_CTRL | | 0xAB: Bit[0] | INT0_EN: 0x19 | Bit[15]: INT_ALERT_CTRL | | 0xAC: Bit[15] | COMM_CFG: 0xA3 | Bits[14:8]: DEVICE_ADD | | 0xAC: Bit[14] | COMM_CFG: 0xA3 | Bit[2]: USE_COMM_CRC | | 0xAC: Bit[13] | HR_SCAN1: 0x9D | Bit[11]: CELL_12_V_READ_EN Bit[10]: CELL_11_V_READ_EN | | 0xAC: Bit[11] | FET_MODE: 0x13 | Bit[4]: CHG_SOFTON_EN Bit[0]: DSG_SOFTON_EN | | 0xAC: Bit[10] | NTC_CFG: 0x47 | Bit[15]: PCB_MNTR_FAULT_EN | |---------------|---------------------|-------------------------------------------------------------------| | 0xAC: Bit[9] | NTC_CFG: 0x47 | Bit[14]: NTC_CELL_COLD_FAULT_EN Bit[13]: NTC_CELL_HOT_FAULT_EN | | 0xAC: Bit[8] | NTC_CFG: 0x47 | Bit[10]: NTCB_DYNAMIC_ON | | 0xAC: Bit[7] | NTC_CFG: 0x47 | Bit[7]: NTC4_TYPE_SEL | | 0xAC: Bit[6] | NTC_CFG: 0x47 | Bit[6]: NTC4_EN | | 0xAC: Bit[5] | NTC_CFG: 0x47 | Bit[5]: NTC3_TYPE_SEL | | 0xAC: Bit[4] | NTC_CFG: 0x47 | Bit[4]: NTC3_EN | | 0xAC: Bit[3] | NTC_CFG: 0x47 | Bit[3]: NTC2_TYPE_SEL | | 0xAC: Bit[2] | NTC_CFG: 0x47 | Bit[2]: NTC2_EN | | 0xAC: Bit[1] | NTC_CFG: 0x47 | Bit[1]: NTC1_TYPE_SEL | | 0xAC: Bit[0] | NTC_CFG: 0x47 | Bit[0]: NTC1_EN | | 0xAD: Bit[15] | CELL_UV: 0x38 | Bits[11:8]: CELL_UV_DG<br>Bits[7:0]: CELL_UV | | 0xAD: Bit[14] | CELL_OV: 0x39 | Bits[11:8]: CELL_OV_DG<br>Bits[7:0]: CELL_OV | | | NTCC_OTHR_DSG: 0x48 | Bits[9:0]: NTC_CELL_HOT_DISCH | | | NTCC_UTHR_DSG: 0x49 | Bits[9:0]: NTC_CELL_COLD_DISCH | | 0xAD: Bit[13] | NTCC_OTHR_CHG: 0x4A | Bits[9:0]: NTC_CELL_HOT_CHG | | | NTCC_UTHR_CHG: 0x4B | Bits[15:11]: NTC_CELL_HYST Bits[9:0]: NTC_CELL_COLD_CHG | | 0xAD: Bit[10] | CELLS_CTRL: 0x00 | Bits[3:0]: CELL_S_CTRL | | 0xAD: Bit[9] | SELF_CFG: 0x56 | Bit[15]: OTP_FAULT_EN | | 0xAD: Bit[8] | SELF_CFG: 0x56 | Bit[14]: 3V3_VDD_FAULT_EN | | 0xAD: Bit[7] | SELF_CFG: 0x56 | Bit[10]: OPEN_WIRE_PON | | 0xAD: Bit[6] | SELF_CFG: 0x56 | Bit[9]: OPEN_WIRE_FAULT_EN | | 0xAD: Bit[4] | SELF_CFG: 0x56 | Bit[6]: OTP_CRC_EN | | 0xAD: Bit[3] | SELF_CFG: 0x56 | Bit[3]: ADC_SELF_TEST_EN | | 0xAD: Bit[2] | SELF_CFG: 0x56 | Bit[2]: VDD_EN | | 0xAD: Bit[1] | SELF_CFG: 0x56 | Bit[1]: 3V3_EN | | 0xAD: Bit[0] | SELF_CFG: 0x56 | Bit[0]: REGIN_EN | | 0xAE: Bit[15] | DSGSC_CFG: 0x2B | Bits[14:8]: SC_DCHG_DG Bit[5]: SC_DCHG_RNG Bits[4:0]: SC_DCHG_LIM | | 0xAE: Bit[14] | CHGSC_CFG: 0x2C | Bits[14:8]: SC_CHG_DG Bit[5]: SC_CHG_RNG Bits[4:0]: SC_CHG_LIM | | 0xAE: Bit[13] | DSGOC_LIM: 0x24 | Bit[13]: OC2_DCHG_RNG<br>Bits[12:8]: OC2_DCHG_LIM | | | DSGOC_DEG: 0x25 | Bit[14]: OC2_DCHG_DGL_RNG Bits[13:8]: OC2_DCHG_DGL | |------------------|-------------------|----------------------------------------------------------------------------------------| | Ov A E . D:#[42] | DSGOC_LIM: 0x24 | Bit[5]: OC1_DCHG_RNG Bits[4:0]: OC1_DCHG_LIM | | 0xAE: Bit[12] | DSGOC_DEG: 0x25 | Bit[6]: OC1_DCHG_DGL_RNG Bits[5:0]: OC1_DCHG_DGL | | 0xAE: Bit[11] | CHGOC_DEG: 0x26 | Bit[14]: OC_CHG_DGL_RNG Bits[13:8]: OC_CHG_DG Bit[5]: OC_CHG_RNG Bits[4:0]: OC_CHG_LIM | | 0xAE: Bit[9] | FT_REC: 0x60 | Bit[12]: DIE_TEMP_FAULT_REC | | 0xAE: Bit[8] | FT_REC: 0x60 | Bit[10]: SC_CHG_REC | | 0xAE: Bit[7] | FT_REC: 0x60 | Bit[9]: SC_DCHG_REC | | 0xAE: Bit[6] | FT_REC: 0x60 | Bit[8]: OC_CHG_REC | | 0xAE: Bit[5] | FT_REC: 0x60 | Bit[7]: OC2_DCHG_REC | | 0xAE: Bit[4] | FT_REC: 0x60 | Bit[6]: OC1_DCHG_REC | | 0xAE: Bit[2] | FT_REC: 0x60 | Bit[4]: PCB_MNTR_REC | | 0xAE: Bit[1] | FT0_CFG: 0x61 | Bit[11]: CELL_OV_REC Bit[7]: CELL_UV_REC | | 0xAE: Bit[0] | FT_REC: 0x60 | Bit[2]: NTC_CELL_CHG_REC Bit[1]: NTC_CELL_DCHG_REC | | 0xAF: Bit[6] | FT0_CFG: 0x61 | Bit[9]: CELL_OV_LOGIC_SEL | | 0xAF: Bit[3] | FT0_CFG: 0x61 | Bit[5]: CELL_UV_LOGIC_SEL | | 0xB0: Bit[15] | PACKFT_CTRL: 0x34 | Bit[8]: CELL_DEAD_EN | | 0xB0: Bit[13] | CELLFT_CTRL: 0x35 | Bit[4]: CELL_OV_EN_CTRL Bit[1]: CELL_UV_EN_CTRL | | 0xB0: Bit[11] | BAL_CFG: 0xA7 | Bit[2]: AUTO_BAL_ALWAYS | | 0xB0: Bit[10] | BAL_CFG: 0xA7 | Bit[1]: BALANCE_MODE_REG | | 0xB0: Bit[9] | BAL_CFG: 0xA7 | Bit[0]: BALANCE_MODE_CTRL (I <sup>2</sup> C versions only) | ### APPLICATION INFORMATION ### **PCB Layout Guidelines** Proper PCB layout is critical to reduce noise, and to optimize the device's accuracy and reliability. For the best results, refer to Figure 19, Figure 20, and Figure 21, and follow the guidelines below: Route the ground plane such that it reduces ground noise and prevents stray current (see Figure 19). Figure 19: Recommended Layout for AGND - 2. Connect the AGND pin to a dedicated ground plane. Then connect the AGND plane to the negative terminal of the battery stack via a $0\Omega$ resistor. - 3. Review the schematic and layout to ensure that each component is connected to the correct ground (power vs. signal). For example, the diodes protecting the different power terminals should be connected to PGND. - 4. Consider the expected maximum peak load current, then check the PGND length, width, and thickness to ensure that there is an appropriate low-resistance path that prevents voltage drops. - 5. The REGIN, VDD, VREF, 3V3, and NTCB pins require external decoupling capacitors, which should be placed as close as possible to each pin. Minimize the trace inductance from these pins to AGND (see Figure 20). Figure 20: Recommended Layout for Decoupling **Capacitors** - Consider Kelvin connections at the sense resistor. A sense resistor with a dedicated sensing pad is ideal. A simple two-terminal sense resistor can be used in a 4-wire sensing configuration (see Figure 21). - 7. Route the sensing signals to SRP and SRN in parallel to avoid coupling interfering signals. Figure 21: 2512 Sense Resistor using 4-Wire **Footprint** - 8. Connect the temperature sensors (NTCx) to AGND using the star connection technique to avoid contaminating the voltage reading with the resistive voltage drop caused by the load or charging ground current. - Route the two wires connecting the NTCx pins together in twisted pairs to avoid signals. interfering This recommended if NTCx is located off-board. # TYPICAL APPLICATION CIRCUIT Figure 22 shows the typical external components and connections required to interface the MP2796 to the battery pack and the system. Figure 22: Typical Application Circuit for the MP2796 ## **Recommended External Components** Figure 23 shows a detailed view of all of the typical recommended external components. Figure 23: Recommended External Component Diagram Table 18 on page 118 provides guidance regarding which parameters should be evaluated when selecting each BOM component (see the Configuration for External or Internal Cell-Balancing section on page 120 for more details on cell-balancing). Refer to the MP2796 evaluation board datasheet to see each BOM component. #### **Table 18: Recommended Components** | Parameter<br>Identifier | Parameter Description | e 18: Recommende Component Description | Parameter Comments | Min | Тур | Max | Unit | |-------------------------|----------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|------| | General | | Description | | | <u> </u> | | | | General | Recommended Zener | AGND-C0 Zener | <u> </u> | | | I | T | | D <sub>AGND_C0</sub> | diode voltage rating | diode voltage | | | 3.3 | | V | | 0 | | External pack | | | 47 | 000 | _ | | CPACK_E | Capacitance value | capacitor | | | 47 | 200 | μF | | Pin Filtering | | | | | | | | | C <sub>VTOP_FLT</sub> | Required capacitance | VTOP-filtering | | | 470 | | nF | | - 7.0 2. | | capacitor<br>VTOP-filtering | | | | | | | $R_{VTOP\_FLT}$ | Required resistance | resistor | | | 20 | | Ω | | | | PACKP-filtering | Do not use a capacitor | | | | | | C <sub>PACK_FLT</sub> | Required capacitance | capacitor | larger or smaller than | | 10 | | nF | | | | - | the recommended value | | | | | | R <sub>PACK_FLT</sub> | Required resistance | PACKP-filtering resistor | | | 100 | | Ω | | Б. | B | VMID-filtering | | | 400 | | | | RVMID | Required resistance | resistor | | | 100 | | Ω | | Cell Voltage S | ensing | | | | | | | | CCELL FLT | Required capacitance | Cell-filtering | | | 100 | | nF | | | · · | capacitor | | 00 | 400 | | | | RCELL_FLT | Required resistance | Cell-filtering resistor | | 20 | 100 | | Ω | | N-Channel MO | OSFEI Driver | T | For a CHG N-channel | | 1 | ı | | | Dcнg-vgs | Recommended Zener diode voltage rating | Diode CHG V <sub>GS</sub> protection | MOSFET with a ±20V maximum V <sub>GS</sub> . If the CHG N-channel MOSFET has a smaller V <sub>GS</sub> , decrease the Zener voltage value accordingly. | | 16 | | V | | Dosg-ves | Recommended Zener diode voltage rating | Diode DSG V <sub>GS</sub> protection | For a DSG N-channel MOSFET with a ±20V maximum V <sub>GS</sub> . If the DSG N-channel MOSFET has a smaller V <sub>GS</sub> , decrease the Zener voltage value accordingly. | | 16 | | V | | RCHG_PUP | Recommended resistance | Charge N-channel<br>MOSFET pull-up<br>resistor | , | | 10 | | МΩ | | R <sub>DSG_PUP</sub> | Recommended resistance | Discharge N-channel<br>MOSFET pull-up<br>resistor | | | 10 | | МΩ | | R <sub>CHG_DRVER</sub> | Required resistance | N-channel MOSFET charge driver protection resistor | | | 100 | | Ω | | Rdsg_drver | Required resistance | N-channel MOSFET discharge driver protection resistor | | | 100 | | Ω | | Rмg | Required resistance | N-channel MOSFET gate protection resistor | | | 100 | | Ω | | Current Sensii | ng | • | | | | • | | | R <sub>SRN_FLT</sub> | Recommended resistance | SRN filtering resistor | | | 100 | | Ω | | CSRN_GND | Recommended capacitance | SRN-GND filtering capacitor | | | 100 | | nF | # MP2796 - 7-CELL TO 16-CELL BATTERY MONITOR AND PROTECTOR | CSRN SRP | Recommended | SRN/P differential | | | 100 | | nF | |----------------------|-----------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|----|-----| | - 5.41_514 | capacitance | filtering capacitor | | | | | | | R <sub>SRP_FLT</sub> | Recommended resistance | SRP filtering resistor | | | 100 | | Ω | | CSRP_GND | Recommended | SRP-GND filtering | | | 100 | | nF | | OSRP_GND | capacitance | capacitor | | | 100 | | 111 | | R <sub>SENSE</sub> | Recommended resistance | Pack current-sense resistor | The min and max values are recommended, and are based on the current-sense range. | 0.2 | 2 | 5 | mΩ | | Regulators | | | | | | | | | C <sub>3V3</sub> | Required capacitance | 3.3V capacitor | | 0.47 | 1 | 10 | μF | | | Required capacitance | | | | 47 | | nF | | CVCP | Required voltage rating | VCP-VMID capacitor | The rating can be proportionally reduced if fewer than 16 stacked cells are used. | 80 | | | V | | C <sub>VDD</sub> | Required capacitance | VDD bypass capacitor | | | 1 | | μF | | $C_{VMID}$ | Required capacitance | VMID bypass capacitor | | | 100 | | nF | | CVREF | Required capacitance | VREF bypass capacitor | | | 1 | | μF | | CREGIN | Required capacitance | REGIN capacitor | | | 3.3 | | μF | | C <sub>REG</sub> | Required capacitance | Regulator capacitor | | | 1 | | μF | | R <sub>REG</sub> | Regulator-limiting resistor value | Regulator-limiting resistor value | | | 500 | | Ω | | Temperature S | Sensing | | | | • | • | | | R <sub>NTC_PUP</sub> | Typical resistance | NTC pull-up | This is a typical value. Generally, the NTC pull-<br>up value should match<br>the NTC thermistor<br>value at 25°C. | | 10 | | kΩ | | Rитс | Typical resistance | NTC thermistor | If a smaller resistance is used, the NTCB current limit should be evaluated and compared to the total resistance connected to the NTCB in the worst-case scenario (hot temperatures). | | 10 | | kΩ | | C <sub>NTCB</sub> | NTCB capacitance | NTCB capacitor | | | | 10 | nF | ## Configuration for External or Internal Cell-Balancing Cell-balancing can be implemented via the internal balancing MOSFETs for up to 58mA. Higher cell-balancing current is possible with external MOSFETs or BJTs (see Figure 28). Figure 28: Typical Schematics Internal vs. External Balancing Configurations The following section describes the recommended components for each of these 3 balancing configurations. Table 19 recommends specific components for internal MOSFET balancing. Table 19: Recommended Component Selection for Internal MOSFET Balancing | Parameter Identifier | Parameter Description | Component Description | Notes | Min | Тур | Max | Unit | |--------------------------|-----------------------|--------------------------|---------------------------------------------------------------------------------------------------------------|-----|-----|-----|------| | C <sub>CELL_FILTER</sub> | Required capacitance | Cell-filtering capacitor | Internal balancing configuration. If RCELL_FILTER increases, CCELL_FILTER should be proportionally decreased. | | 100 | | nF | | RCELL_FILTER | Required resistance | Cell-filtering resistor | Resistance for the internal balancing configuration. | 20 | 100 | | Ω | The amount of current provided in an internal balancing configuration is easily derived by following the $R_{CELL\_FILTER}$ resistor value and considering the integrated MOSFET balancing resistance ( $R_{DS(ON)\_BAL\_FET}$ ). For example, for a lithium cell at 4V where $R_{CELL\_FILTER} = 20\Omega$ , the resistive path allows for 58mA once the integrated balancing resistor MOSFET is enabled. For higher balancing current, Table 20 and Table 21 on page 121 provide guidance on selecting the MOSFET or BJT circuit components. Table 20 recommends specific components for external MOSFET balancing. Table 20: Recommended Component Selection for External MOSFET Balancing | Parameter<br>Identifier | Parameter<br>Description | Component<br>Description | Notes | Min | Тур | Max | Unit | |-------------------------|----------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----|------|-----|------| | Ccell_filter | Required capacitance | Cell-filtering capacitor | Capacitance for external balancing configuration. If RCELL_FILTER increases, CCELL_FILTER should be proportionally decreased. | | 10 | | nF | | Rcell_filter | Required resistance | Cell-filtering resistor | Resistance for external balancing configuration. If RCELL_FILTER increases, CCELL_FILTER should be proportionally decreased. | 800 | 1000 | | Ω | | R <sub>BAL</sub> | Required resistance | Cell-balancing current-limiting resistor | Adjust this value to set the balancing current, and verify the power dissipation compared to package limit. | | 43 | | Ω | | VTH_MBAL | MOSFET V <sub>GS</sub> threshold | External balancing MOSFET MBAL | A higher voltage threshold may prevent the MOSFET from turning on. | | 1.5 | 1.8 | V | The external balancing MOSFETs should be selected using Table 19 on page 120. Choose a MOSFET with a sufficiently low V<sub>GS</sub> threshold. For simplification, assume that the integrated MOSFET-balancing resistance can be ignored. The available V<sub>GS</sub> that turns on the MOSFET is generated across R<sub>CFU FILTER</sub>. meaning its voltage is half of the lithium cell voltage (e.g. 4.2V / 2 = 2.1V). In this scenario, the $V_{GS}$ threshold for M<sub>BAL</sub> should be below 2.1V with an appropriate safety margin. The safety margin should allow for voltage drops on the integrated MOSFET balancing resistor. This drop can be caused by the following: Changes in the operating conditions resistance current gain BJT DC h<sub>FE\_QBAL</sub> Shifts in the M<sub>BAL</sub> V<sub>GS</sub> threshold across operating conditions resistor External **Q**BAL balancing BJT Drops that develop across the sensing wires due to the balancing current Table 21 recommends specific components for external BJT balancing. Parameter Parameter Component **Notes** Typ Max Unit Identifier Description Description Capacitance for external balancing Required Cell-filtering configuration. If R<sub>CELL FILTER</sub> increases, 100 nF CCELL FILTER capacitance capacitor Ccell\_filter should be proportionally decreased. Resistance for external balancing configuration. If $R_{\text{CELL\_FILTER}}$ increases, Required Cell-filtering 1000 RCELL\_FILTER 20 100 Ω resistance resistor CCELL\_FILTER should be proportionally decreased. Cell-balancing Adjust this value to set the balancing Required current-limiting current, and verify the power dissipation 43 Ω $R_{BAL}$ Table 21: Recommended Component Selection for External BJT Balancing Because R<sub>BAL</sub> sets the balancing current and dissipates most of the power, ensure that an appropriate resistor and resistor package are selected, especially for resistors below $100\Omega$ . For example, if $R_{BAL}$ = $43\Omega$ , there is 410mW of power dissipation when the lithium cell voltage = 4.2V. This means that a package of at least 2512 (6432 Metric) should be used. balancing current. compared to package limit. A lower her may limit the external It is also important to consider the thermal design of the overall board and enclosure. The MP2796 can simultaneously balance only odd or even cells, meaning 8 cells in a 16-cell system. When balancing is run continuously on 8 cells, 3.28W is dissipated as heat with a $43\Omega$ R<sub>BAL</sub>. To keep the MP2796 in the allowed temperature range, consider how this additional heat can be dissipated, as it is added to the amount of heat generated by other components. The MP2796 includes compensation for the voltage drop across the R<sub>CELL FILTER</sub> resistor via the OTP register CELL\_1K\_COMP. When enabled, this register compensates for an R<sub>CELL FILTER</sub> value of 1kΩ. Generally, CELL\_1K\_COMP should be enabled if $R_{CELL\ FILTER}$ is 500 $\Omega$ or greater. ## Selecting the VCP Capacitor When multiple MOSFETs in parallel are used for DSG or CHG, the VCP capacitance should be selected to avoid causing an excessive voltage drop while the MOSFETs turn on. Table 22 on page 122 lists values for the VCP capacitor depending on the total C<sub>ISS</sub> that the DSG or CHG MOSFET driver must drive. The total C<sub>ISS</sub> was obtained from the MOSFET datasheets. Design the number of parallel DSG MOSFETs to match the number of parallel CHG MOSFETs. If 4 parallel DSG MOSFETs are used, then the individual MOSFET's C<sub>ISS</sub> should be multiplied by 4, and the resulting C<sub>ISS</sub> value should be used. **Table 22: VCP Capacitor Selection** | CVCP | Total Ciss | |-------|------------| | 47nF | 47nF | | 68nF | 68nF | | 100nF | 100nF | ## **Unused Pins** For a particular application, some pins may not be required. Table 23 shows how to connect these pins when they are not used. **Table 23: Unused Pins Connection** | Pin# | Name | Recommendation | | | | | |--------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 1, 2, 3,<br>4, 5, 6,<br>46,<br>47,48 | C8,C9, C10,<br>C11, C12,<br>C13, C14,<br>C15, C16 | If fewer than 16 series cells are used, directly connect all unused cell channels to the practical maximum cell channel. For example, if only 10 cells are used, C16~C10 should be connected together. | | | | | | 15, 16 | SRP, SRN | If the current-sense function is not required, connect these pins to AGND. | | | | | | 17, 18,<br>19, 20 | NTC1, NTC2,<br>NTC3, NTC4 | Float the unused NTC channels. | | | | | | 21 | NTCB | If NTC temperature monitoring is not used, float this pin. | | | | | | 28 | XALERT | Float this pin if it is not used. | | | | | | 29 | WDT | Float this pin if it is not used. | | | | | | 33 | SDO | Float this pin if it is not used. | | | | | | 34 | GPIO3/nCS | Float this pin if it is not used. Note that the GPIO3 should be set to $20k\Omega$ pull-up mode via the GPIO_CFG register; otherwise there may be additional power consumption. | | | | | | 35, 36 | GPIO1,<br>GPIO2 | Float this pin if it is not used. Note that the unused GPIO should be set to $20k\Omega$ pullup mode via the GPIO_CFG register; otherwise there may be additional power consumption. | | | | | | 38 | PACKP | If the DSG MOSFET driver is not used, and the PACKP vs. VTOP comparator is r needed, connect this pin to VTOP. | | | | | | 39 | DSG | If the HS-FET drivers are not used and active mode is required, connect this pin to PACKP via a $100\Omega$ resistor and a 1nF capacitor. If active mode is not required, float this pin. | | | | | | 41 | SBYDSG | Float this pin if it is not used. | | | | | | 42 | VCP | If the HS-FET drivers are not used and active mode is required, connect this pin VMID via a 47nF VCP capacitor. If active mode is not required, float this pin. | | | | | | 43 | VMID | If the HS-FET drivers are not used, connect this pin to VTOP. | | | | | | 44 | CHG | If the HS-FET drivers are not used and active mode is required, connect this pin to VTOP via a $100\Omega$ resistor and a 1nF capacitor. If active mode is not required, float this pin. | | | | | # **PACKAGE INFORMATION** # **TQFP-48 (7mmx7mm)** ### **TOP VIEW** ## RECOMMENDED LAND PATTERN **SIDE VIEW** #### **DETAIL "A"** #### NOTE: - 1) ALL DIMENSIONS ARE IN MILLIMETERS. - 2) PACKAGE LENGTH DOES NOT INCLUDE MOLD FLASH, PROTRUSION OR GATE BURR. - 3) PACKAGE WITDH DOES NOT INCLUDE INTERLEAD FLASH OR PROTRUSION. 4) LEAD COPLANARITY (BOTTOM OF LEADS AFTER FORMING) SHALL BE 0.10 MILLIMETERS MAX. - 5) JEDEC REFERENCE IS MO-143. - 6) DRAWING IS NOT TO SCALE. # **CARRIER INFORMATION** | Part Number | Package<br>Description | Quantity/<br>Reel | Quantity/<br>Tube | Quantity/<br>Tray | Reel<br>Diameter | Carrier<br>Tape<br>Width | Carrier<br>Tape<br>Pitch | |----------------------|------------------------|-------------------|-------------------|-------------------|------------------|--------------------------|--------------------------| | MP2796DFP-<br>xxxx-T | TQFP-48<br>(7mmx7mm) | N/A | N/A | 250pcs | N/A | N/A | N/A | # **REVISION HISTORY** | Revision # | Revision Date | Description | Pages Updated | |------------|---------------|-----------------|---------------| | 1.0 | 5/9/2023 | Initial Release | - | **Notice:** The information in this document is subject to change without notice. Please contact MPS for current specifications. Users should warrant and guarantee that third-party Intellectual Property rights are not infringed upon when integrating MPS products into any application. MPS will not assume any legal responsibility for any said applications.