# 2 to 10 Stacked Cells Battery Pack Fuel Gauge ## DESCRIPTION The MPF42797 is a drop-in solution to provide comprehensive status information on lithium-ion battery strings up to 10 series cells. The MPF42797 estimates the internal state-of-charge (SOC) and state-of-health (SOH) for each cell, as well as the full pack. The MPF42797 also determines remaining runtime, charge time, and instantaneous available power. On-board memory enables the lifetime logging of key parameters. The MPF42797 is simple to use and supports a variety of lithium cell chemistries and cell sizes. A few basic configurations allow for quick set-up, and advanced configuration capabilities can fine-tune the device for specific applications. When paired with an MP279x battery monitor, the MPF42797 can achieve SOC accuracy within 3%. The MPF42797 can also be paired with other analog front-end (AFE) or battery stack monitors. The 400kHz I<sup>2</sup>C interface provides standard, robust communication. The MPF42797 is available in a TQFN-32 (4mmx4mm) package. #### MINIMUM SYSTEM REQUIREMENTS - Battery Monitor Providing Individual Cell Voltages for 2 to 10 Series Cells, Pack Current, and Temperature - M0 System MCU with I<sup>2</sup>C and Interrupt, 48kB of Flash, and 4kB of RAM ## **FEATURES** - Compatible with Commonly used Battery Monitors for up to 10 Series Cells - ±3% State-of-Charge (SOC) Accuracy when Paired with MP279x Battery Monitors - Provides Critical Battery Information: - Pack and Cell SOC - Pack and Cell State-of-Health (SOH) - Remaining Runtime and Charge Time - Instantaneous Available Power - Supports a Wide Variety of Lithium Cells - Adaptive Learning can be Enabled to: - Refine Initial Charge Settings - Refine Initial Discharge Settings - Update Individual Cells' SOH to Track Degradation - Provides Lifetime Logging - 2.5V Minimum Supply Voltage - Low Current Consumption: 6µA in Disabled Mode and 135µA (Average) in Operating Mode during Rest - Supports Up to 400kHz I<sup>2</sup>C with Cyclic Redundancy Check (CRC) for Robust Communication - Available in a Compact TQFN-32 (4mmx4mm) Package - Available in Turn-Key MPS BMS Module: - o MBM1xS-P50 and MBM1xS-P100 ## **APPLICATIONS** - Light EV: Scooters, Bikes, and Golf Carts - Energy Storage: UPS and Renewable Energy - Industrial Robots, Floor Cleaners, and Forklifts - Cordless Tools and Gardening Equipment 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** 2 ## ORDERING INFORMATION | Part Number* | Package | Top Marking | MSL Rating | |-----------------------|-------------------|-------------|------------| | MPF42797DRT-0B-yyyy** | TQFN-32 (4mmx4mm) | See Below | 3 | | EVKT-MPF42797 | Evaluation kit | - | - | | EVKT- MBM1xS-P50 | Evaluation kit | - | - | <sup>\*</sup> For Tape & Reel, add suffix -Z (e.g. MPF42797DRT-0B-yyyy-Z). ## **TOP MARKING** MPSYWW M4279X LLLLLL MPF4279x Family Generic Version MPS: MPS prefix Y: Year code WW: Week code M4279X: Family part number\* LLLLL: Lot number # **EVALUATION KIT EVKT-MBM1XS-P50 (MP2791 BMS)** EVKT- MBM1xS-P50 kit contents (items below can be ordered separately): | # | Part Number | Item | Quantity | |---|-----------------------|----------------------------------------------------------------------|----------| | 1 | MBM1xS-P50 | MPF42797DRT-0B-yyyy and MP279x AFE reference design evaluation board | 1 | | 2 | EVKT-USB_RS232/I2C-01 | USB to RS232/I <sup>2</sup> C adapter | 1 | | 3 | Online resources | Include datasheet, user guide, product brief, and GUI | 1 | #### Order directly from MonolithicPower.com or our distributors. Figure 1: MBM1xS-P50 Evaluation Kit Set-Up <sup>\*\* &</sup>quot;-yyyy" refers to the default configuration identifier ("-0000" by default), where each "y" is a hexadecimal value between 0 and F. Work with an MPS FAE to obtain a customized default configuration. <sup>\*</sup> The specific part number is in the IC\_VER register. # **PACKAGE REFERENCE** # **PIN FUNCTIONS** | Connected to ground. | Din # | Nome | 1/0 | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------| | N/C No connection. | | | 1/0 | · | | N/C No connection. | • | | - | | | 4 N/C - No connection. 5 N/C - No connection. 6 N/C - No connection. 7 N/C - No connection. 8 N/C - No connection. 9 LDO Power Internal LDO. Bypass the LDO pin with a 2.2μF + 100nF ceramic capacitor connected to ground. 10 VDD Power Ground pin. 11 GND Power Ground pin. 12 nRST I IC reset control. 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O PC interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O PC interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O PC interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | | | - | | | 5 N/C - No connection. 6 N/C - No connection. 7 N/C - No connection. 8 N/C - No connection. 9 LDO Power Internal LDO. Bypass the LDO pin with a 2.2µF ceramic capacitor connected to ground. 10 VDD Power Power supply input. Bypass the VDD pin with a 2.2µF ceramic capacitor connected to ground. 11 GND Power Ground pin. 12 nRST I IC reset control. 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. <td></td> <td></td> <td>-</td> <td></td> | | | - | | | 6 N/C - No connection. 7 N/C - No connection. 8 N/C - No connection. 9 LDO Power Internal LDO. Bypass the LDO pin with a 2.2µF + 100nF ceramic capacitor connected to ground. 10 VDD Power Power supply input. Bypass the VDD pin with a 2.2µF ceramic capacitor connected to ground. 11 GND Power Ground pin. 12 nRST I IC reset control. 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. <td< td=""><td>•</td><td></td><td>-</td><td></td></td<> | • | | - | | | 7 N/C - No connection. 8 N/C - No connection. 9 LDO Power Internal LDO. Bypass the LDO pin with a 2.2µF + 100nF ceramic capacitor connected to ground. 10 VDD Power supply input. Bypass the VDD pin with a 2.2µF ceramic capacitor connected to ground. 11 GND Power Supply input. Bypass the VDD pin with a 2.2µF ceramic capacitor connected to ground. 12 nRST I IC reset control. 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SDA pin to the logic rail through a 10kΩ resistor. <td></td> <td></td> <td>-</td> <td></td> | | | - | | | 8 N/C - No connection. | 6 | | - | No connection. | | Power Internal LDO. Bypass the LDO pin with a 2.2μF + 100nF ceramic capacitor connected to ground. | 7 | | - | No connection. | | Connected to ground. | 8 | N/C | - | No connection. | | connected to ground. 11 GND Power Ground pin. | 9 | LDO | Power | Internal LDO. Bypass the LDO pin with a 2.2µF + 100nF ceramic capacitor connected to ground. | | 12 nRST I IC reset control. 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | 10 | VDD | Power | <b>Power supply input.</b> Bypass the VDD pin with a 2.2µF ceramic capacitor connected to ground. | | 13 N/C - No connection. 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | 11 | GND | Power | Ground pin. | | 14 N/C - No connection. 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | 12 | nRST | I | IC reset control. | | 15 CE I Chip enable. Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. 16 N/C - No connection. 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power SV to 3.3V power supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. | 13 | N/C | - | No connection. | | Communication interface to minimize current consumption. | 14 | N/C | - | No connection. | | 17 N/C - No connection. 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 30 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | 15 | CE | I | <b>Chip enable</b> . Set the CE pin low to stop fuel gauge updates and disable the communication interface to minimize current consumption. | | 18 N/C - No connection. 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power 3V to 3.3V power supply input. Bypass the VCC pin with a 2.2µF ceramic capacitor connected to ground. 32 GND Power Ground pin. | 16 | N/C | - | No connection. | | 19 N/C - No connection. 20 N/C - No connection. 21 N/C - No connection. 22 N/C - No connection. 23 SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. 24 SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Ground pin. | 17 | N/C | - | No connection. | | <ul> <li>N/C</li> <li>N/C</li> <li>No connection.</li> <li>N/C</li> <li>No connection.</li> <li>SCL</li> <li>I/O</li> <li>I<sup>2</sup>C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor.</li> <li>SDA</li> <li>I/O</li> <li>I<sup>2</sup>C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor.</li> <li>IRQ</li> <li>IRQ</li> <li>Interrupt request pin. The IRQ pin is the interrupt going to the host system(s).</li> <li>N/C</li> <li>No connection.</li> connecti</li></ul> | 18 | N/C | - | No connection. | | <ul> <li>N/C</li> <li>N/C</li> <li>No connection.</li> <li>SCL</li> <li>I/O</li> <li>I<sup>2</sup>C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor.</li> <li>SDA</li> <li>I/O</li> <li>I<sup>2</sup>C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor.</li> <li>IRQ</li> <li>IRQ</li> <li>Interrupt request pin. The IRQ pin is the interrupt going to the host system(s).</li> <li>N/C</li> <li>No connection.</li> <li>Power</li> <li>GND</li> <li>Power</li> <li>Ground pin.</li> </ul> | 19 | N/C | - | No connection. | | <ul> <li>N/C</li> <li>No connection.</li> <li>SCL</li> <li>I/O</li> <li>I<sup>2</sup>C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor.</li> <li>SDA</li> <li>I/O</li> <li>I<sup>2</sup>C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor.</li> <li>IRQ</li> <li>IRQ</li> <li>Interrupt request pin. The IRQ pin is the interrupt going to the host system(s).</li> <li>N/C</li> <li>No connection.</li> <li>Power</li> <li>GND</li> <li>Power</li> <li>Ground pin.</li> </ul> | 20 | N/C | - | No connection. | | SCL I/O I²C interface clock. Connect the SCL pin to the logic rail through a 10kΩ resistor. I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). N/C - No connection. ON C - No connection. N/C - No connection. ON C | 21 | N/C | - | No connection. | | SDA I/O I²C interface data. Connect the SDA pin to the logic rail through a 10kΩ resistor. IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). No connection. Ro connection. No connection. Ro connection. O No connection. No connection. Ro connection. O No connection. No connection. O No connection. Ro connection. O No | 22 | N/C | - | No connection. | | 25 IRQ O Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power SV to 3.3V power supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. 32 GND Power Ground pin. | 23 | SCL | I/O | <b>I<sup>2</sup>C interface clock.</b> Connect the SCL pin to the logic rail through a 10kΩ resistor. | | 26 N/C - No connection. 27 N/C - No connection. 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power Sylvania | 24 | SDA | I/O | I <sup>2</sup> C interface data. Connect the SDA pin to the logic rail through a $10kΩ$ resistor. | | <ul> <li>N/C - No connection.</li> <li>N/C - No connection.</li> <li>N/C - No connection.</li> <li>N/C - No connection.</li> <li>N/C - No connection.</li> <li>VCC Power Supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground.</li> <li>GND Power Ground pin.</li> </ul> | 25 | IRQ | 0 | Interrupt request pin. The IRQ pin is the interrupt going to the host system(s). | | 28 N/C - No connection. 29 N/C - No connection. 30 N/C - No connection. 31 VCC Power 3V to 3.3V power supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. 32 GND Power Ground pin. | 26 | N/C | - | No connection. | | <ul> <li>N/C - No connection.</li> <li>N/C - No connection.</li> <li>VCC Power Supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground.</li> <li>GND Power Ground pin.</li> </ul> | 27 | N/C | - | No connection. | | 30 N/C - No connection. 31 VCC Power Power Supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. 32 GND Power Ground pin. | 28 | N/C | - | No connection. | | 31 VCC Power Supply input. Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. 32 GND Power Ground pin. | 29 | N/C | - | No connection. | | 31 VCC Power capacitor connected to ground. 32 GND Power Ground pin. | 30 | N/C | - | No connection. | | · | 31 | VCC | Power | <b>3V to 3.3V power supply input.</b> Bypass the VCC pin with a 2.2μF ceramic capacitor connected to ground. | | 33 GND Power <b>Ground pin.</b> | 32 | GND | Power | Ground pin. | | | 33 | GND | Power | · | # **ABSOLUTE MAXIMUM RATINGS (1)** nRST pin.....-0.3V to +3.6V All other pins .....-0.3V to $V_{CC}$ + 0.3V Total power dissipation ( $T_A = 25^{\circ}C$ ) (2)..... ..... 500mW Storage temperature.....-55°C to +150°C Junction temperature ......-55°C to +150°C ESD Ratings Human body model (HBM) ..... ±4000V **Recommended Operating Conditions (3)** Supply voltage (V<sub>DD</sub>) ......3.0V to 3.6V All other pins ......-0.3V to $V_{CC}$ + 0.3V Operating junction temp (T<sub>J</sub>)..... -40°C to +85°C Thermal Resistance (4) $\theta_{JA}$ $\theta_{JC}$ TQFN-32 (4mmx4mm) ......47......4.5...°C/W #### Notes: - 1) Exceeding these ratings may damage the device. - The maximum allowable power dissipation is a function of the maximum junction temperature, T<sub>J</sub> (MAX), the junction-toambient thermal resistance, $\theta_{\text{JA}},$ and the ambient temperature, T<sub>A</sub>. The maximum allowable continuous power dissipation at any ambient temperature is calculated by $P_D$ (MAX) = $(T_J)$ (MAX) - $T_A$ ) / $\theta_{JA}$ . Exceeding the maximum allowable power dissipation can produce an excessive die temperature, and the regulator may go into thermal shutdown. Internal thermal shutdown circuitry protects the device from permanent damage. - The device is not guaranteed to function outside of its operating conditions. - Measured on the JESD51-7, a 4-layer PCB. # **ELECTRICAL CHARACTERISTICS** $V_{CC}$ = 3.3V, $T_A$ = 25°C, unless otherwise noted. | Parameters | Symbol | Condition | Min | Тур | Max | Units | |---------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------|--------------------------|-------| | State-of-Charge (SOC) Pe | rformance | | | | | | | | | MPS MP279x AFE family,<br>$15^{\circ}\text{C} \leq \text{T}_{\text{A}} \leq 35^{\circ}\text{C}$ , $\text{I}_{\text{CHG}} \leq 0.5\text{C}$ ,<br>$\text{I}_{\text{DIS}} \leq 0.5\text{C}$ | -2 | 0 | +2 | % | | Pack SOC accuracy (5) | $ heta_{ERR}$ | MPS MP279x AFE family,<br>$10^{\circ}\text{C} \leq \text{T}_{\text{A}} \leq 50^{\circ}\text{C}$ , $\text{I}_{\text{CHG}} \leq 1\text{C}$ ,<br>$\text{I}_{\text{DIS}} \leq 1\text{C}$ | -3 | 0 | +3 | % | | | | MPS MP279x AFE family,<br>$10^{\circ}\text{C} \leq \text{T}_{\text{A}} \leq 50^{\circ}\text{C}$ , $\text{I}_{\text{CHG}} \leq 2\text{C}$ ,<br>$\text{I}_{\text{DIS}} \leq 2\text{C}$ | -4 | 0 | +4 | % | | Power Supply | | | _ | | | | | VDD operating voltage range | $V_{DD}$ | | | 3.3 | 3.6 | V | | VCC operating voltage range | V <sub>CC</sub> | | | 3.3 | 3.6 | V | | Total active current | IDD_ACTIVE | V <sub>DD</sub> = 3.3V, fuel gauge updating | | 7.5 | | mA | | Total standby current | IDD_STANDBY | V <sub>DD</sub> = 3.3V, fuel gauge idle | | 50 | | μA | | Average operating current during CHG or DSG | I <sub>DD_CHG/DSG</sub> | V <sub>DD</sub> = 3.3V, NCELLS_SER = 10,<br>EXE_TIME = 4s, with I <sup>2</sup> C traffic | | 270 | | μA | | Average operating current during rest | I <sub>DD_REST</sub> | V <sub>DD</sub> = 3.3V, NCELLS_SER = 10,<br>EXE_TIME = 4s,<br>WEXE_TIME_REST = 4, with I <sup>2</sup> C<br>traffic | | 135 | | μA | | Total disabled current | I <sub>DD_DIS</sub> | $V_{DD} = 3.3V$ | | 6 | | μA | | Power-On Reset (POR) | _ | | | | • | | | Release threshold of POR | V <sub>ROT</sub> | V <sub>DD</sub> rising | 1.66 | 1.79 | 1.9 | V | | nRST Pin | | | | | | | | nRST pin threshold voltage | $V_{RST}$ | | 0.2 x<br>V <sub>DD</sub> | | 0.9 x<br>V <sub>DD</sub> | V | | Minimum pulse width on nRST pin | <b>t</b> RST | V <sub>DD</sub> = 3.3V | | 700 | | ns | | Time-out after reset | tтоит | | | 64 | 128 | ms | | CE | | | | | | | | Low input voltage | V <sub>IL_CE</sub> | I <sub>OL</sub> = 5mA | -0.3 | | V <sub>DD</sub> x 0.35 | V | | High input voltage | V <sub>IH_CE</sub> | | V <sub>DD</sub> x 0.65V | | V <sub>DD</sub> + 0.3V | V | | Low leakage current | ICE_LKG_LOW | Vce = 3.3V | | | 3 | μA | | High leakage current | ICE_LKG_HIGH | Vce = 3.3V | | | 3 | μA | | IRQ | | | | | | | | Low output voltage | $V_{IRQL}$ | Sink = 4mA | | | 0.4 | V | | High output voltage | V <sub>IRQH</sub> | Source = 4mA | V <sub>DD</sub> - 0.4 | | | V | | I <sup>2</sup> C DC Characteristics | | | | | | 1 | | High input voltage | V <sub>IH</sub> | SCL, SDA | 0.7 x<br>V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 | V | | Low input voltage | VıL | SCL, SDA | -0.5 | | 0.3 x<br>V <sub>DD</sub> | V | | Low output voltage | Vol | SDA, sink current = 3mA | | | 0.4 | V | | Lon output voltago | Ų OL | 1007 I, OHIN GUITOIN OHIN | | l | ₩.¬ | v | # **ELECTRICAL CHARACTERISTICS** (continued) $V_{DD}$ = 3.3V, $T_A$ = 25°C, unless otherwise noted. | Parameters | Symbol | Condition | Min | Тур | Max | Units | |--------------------------------------------|---------------------|-----------|-------|-----|------|-------| | I <sup>2</sup> C Timing Characteristics | | | | | | | | Spikes suppressed by input filter | t <sub>SP</sub> | | 0 | | 50 | ns | | Operating frequency range | f <sub>SCL</sub> | | 10 | | 400 | kHz | | SCL clock low period | t <sub>LOW</sub> | | 1.125 | | | μs | | SCL clock high period | t <sub>HIGH</sub> | | 1.125 | | | μs | | SCL and SDA falling time | t <sub>FALL</sub> | | | | 0.34 | μs | | SCL and SDA rising time | t <sub>RISE</sub> | | | | 0.34 | μs | | Data hold time | thd_dat | | 0 | | | ns | | Data set-up time | tsu_dat | | 125 | | | ns | | Data valid time | t <sub>V_DAT</sub> | | 475 | | | ns | | Set-up time for a repeated start condition | t <sub>SU_STA</sub> | | 125 | | | ns | | Hold time for a repeated start condition | t <sub>HD_STA</sub> | | 0 | | | ns | | Set-up time for a stop condition | tsu_sto | | 125 | | | ns | #### Note: <sup>5)</sup> Validated on a 10S1P Samsung INR18650 25R pack (see the Typical Performance Characteristics section on page 9 for more details). Similar results can be achieved with other cell/pack types after characterization ## TYPICAL PERFORMANCE CHARACTERISTICS The fuel gauge performance depends on multiple factors, such as the accuracy of the measurements, the correctness of the configuration, and the fidelity of the cell mathematical model. This means that fuel gauge performance may vary depending on the battery operating conditions. This section shows examples of the MPS MPF42797 fuel gauge pack's SOC performance when paired with MPS's MP279x AFE family. ## Constant-Current/Constant-Voltage (CC/CV) Charge and Dynamic Discharge Cycle The next scenarios consist of charging a 10S1P <sup>(6)</sup> 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 on page 10 shows the MPF42797's performance for the CC/CV charge and dynamic discharge cycle at an ambient temperature of 25°C. During charge, the root-mean-squared <sup>(7)</sup> and maximum pack SOC error are 0.70% and 1.20%, respectively. During discharge, the root-mean-squared and pack SOC error are 1.18% and 2.93%, respectively. #### Notes: - 6) 10S1P refers to the battery configuration. There are 10 groups of 1 parallel cell connected in series - 7) The RMS error is equal to $\sqrt{\frac{\sum_{n=1}^{N}(\theta_{n}-\widehat{\theta}_{n})^{2}}{N}}$ , where $\theta$ is the actual SOC, $\widehat{\theta}$ is the estimated SOC, and N is the number of samples. Figure 4: MPF42797 Performance for a CC/CV Charge and Dynamic Discharge (Ambient Temperature = 25°C) Figure 5 shows the MPF42797's performance for the CC/CV charge and dynamic discharge cycle at 40°C ambient temperature. During charge, the root-mean-squared and maximum pack SOC error are 1.31% and 2.49%, respectively. During discharge, the root-mean-squared and pack SOC error are 1.36% and 2.96%, respectively. Figure 6: MPF42797 Performance for a CC/CV Charge and Dynamic Discharge (Ambient Temperature = 40°C) #### **Performance Summary** This section provides a summary of the MPF42797's real-world performance. Table 2 shows a summary of the pack SOC performance metrics for a 10S1P battery. Table 2: MPF42797 SOC Root-Mean-Squared (and Maximum) Error | Test Case | 25°C | 40°C | |-------------------|---------------|---------------| | CC/CV charge | 0.70% (1.20%) | 1.31% (2.49%) | | Dynamic discharge | 1.18% (2.93%) | 1.36% (2.96%) | #### **OPERATION** The MPF42797 relies on a host microcontroller (MCU) to periodically update the fuel gauge's required inputs. This includes the cell voltages (via the VRDG\_CELLxx registers), current (via the IRDG\_CELLxx registers), and temperature (via the TRDG\_TSx registers). The host MCU is responsible for synchronizing the input data to the fuel gauge's execution time (EXE\_TIME). The host MCU sends the EXE\_CMD command to trigger the fuel gauge execution and waits until the iteration is completed (FG\_EXE\_FLAG = 0). Then the host MCU can read back the fuel gauge's output registers, such as the pack state-of-charge (SOC). The interrupt request (IRQ) pin can be configured to notify several events, such as a completed iteration or other. ## **Operating Modes** #### Active In active mode, the fuel gauge is either updating the battery internal states or communicating via the I<sup>2</sup>C bus. ## Standby In standby mode, the fuel gauge is idle, which means that all triggered updates have been completed and the fuel gauge is waiting for activity on the SDA line to transition to active mode. See the I<sup>2</sup>C Communication Interface section on page 15 for more details. #### Disabled In disabled mode, the chip enable (CE) pin is low. I<sup>2</sup>C communication is not available, and the fuel gauge achieves minimal current consumption but still retains all internal state variables in its memory. # Configuration and Data Exchange Configuration Mode In the configuration mode, the MPF42797 is set to receive configuration parameters. However, the device will stop operating. This mode is enabled by sending the CONFIG\_MODE\_CMD and can be confirmed by reading the CONFIG\_MODE\_FLAG register. After the fuel gauge configurations are successfully updated, the host system must send the CONFIG\_EXIT\_CMD command to save the configuration into non-volatile memory (NVM). This ensures that the configuration remains after a hardware reset (cycling the device's power or cycling power on the nRST pin). ## **Editing Mode** As an alternative to the configuration mode, the edit mode allows for partial configuration changes. In this mode, the fuel gauge settings can be updated, but not changes to the fuel gauge cell model. Configuration mode is required to change the fuel gauge cell model. In this mode, the fuel gauge operation does not stop, which allows for on-the-fly configurations. This mode is enabled by sending EDIT\_CONFIG\_CMD command and can be confirmed reading the bν EDIT SETTINGS FLAG. The host system can mode by sending exit this the END\_EDIT\_CONFIG\_CMD or CONFIG\_EXIT\_CMD command, which store the updated configuration in the MPF42797's NVM. #### I<sup>2</sup>C Communication Interface The MPF42797 has an I<sup>2</sup>C channel that communicates with the host MCU which extracts the data from the AFE. The I<sup>2</sup>C is a bidirectional, two-wire serial interface. Only two bus lines are required: a serial data line (SDA) and a serial clock line (SCL). The device can be considered a master or a slave when performing data transfers. A device that initiates a data transfer on the bus and generates the clock signals to permit the transfer is considered a master. Any device that the master addresses is considered a slave. Both MPF42797 I<sup>2</sup>C interfaces operate as slave devices with a configurable address (0x08 by default). They receive control inputs from the master device and ignore general call addresses. The I<sup>2</sup>C interface supports both standard mode (up to 100kbits), and fast mode (up to 400kbits). The SDA and SCL lines are bidirectional with open drain outputs that should be connected to the positive supply voltage via a current source or pull-up resistor. When the bus is free, both lines are high. The data on the SDA line must be stable during the high period of the clock. the high or low state of the data line can only change when the clock signal on the SCL line is low. Note that a single clock pulse is generated for each data bit transferred (see Figure 7). Figure 7: Bit Transfer on the I<sup>2</sup>C Bus All transactions must begin with a start (S) command and can be terminated with a stop (P) command. Start and stop commands are always generated by the master. A start command is defined by a high-to-low transition on the SDA line while SCL is high (see Figure 8). A stop command is defined by a low-to-high transition on the SDA line while the SCL is high (see Figure 8). The bus is considered busy after a start command and free after a stop command. Figure 8: I<sup>2</sup>C Start and Stop Commands Every byte on the SDA line must be 8 bits long and must be followed by an acknowledge (ACK) bit. Note that data is transferred with the most significant bit (MSB) first. A slave cannot receive or transmit a complete byte of data while performing other tasks, but it can hold the SCL line low to force the master into a wait state (clock stretching). Then, when the slave is ready, data transfer continues, and the clock line (SCL) is released. The acknowledgement takes place after every byte and allows the receiver to signal to the transmitter that the byte was successfully received. All clock pulses are generated by the master, including the 9th clock pulse (ACK). The transmitter releases the SDA line during the ACK clock pulse so that the receiver pulls the SDA line low. If the SDA line remains high during the acknowledge clock pulse, it is not acknowledged (NACK). Then the master can generate a stop command to abort the transfer, or it can generate a repeated start (Sr) command to start a new transfer. After the start command, a 7-bit slave address is sent, followed by the read/write (R/W) bit. A 0 represents a write transmission (W), while a 1 indicates a read request (R). Figure 9 shows a complete data transfer. Figure 9: Complete Data Transfer #### Active Mode The MPF42797 must be in active mode to communicate (see Operating Modes for additional detail). To transition to active mode, the SDA line must be pulled low. There is a 20ms timeout before starting operation, or the device transitions back to standby mode. After the operations are completed (e.g. I<sup>2</sup>C communication or fuel gauge updates) there is a 5ms timeout. A low 5ms pulse on the SDA line is recommended to transition to active mode. To verify that the MPF42797 is ready for communication, an I<sup>2</sup>C header with the start command, the device address, and the R/W bit can be sent. The device responds with an ACK signal if it is ready for communication. ## **Protocol Layer** The MPF42797 uses a protocol where 2 bytes are used for the register and command addresses. A length field is also provided to declare the number of bytes in each read or write transaction. The maximum allowed transaction length is 82 bytes of data (not including the register address, length byte, or CRC bytes). A cyclic redundancy check (CRC) can be used to ensure the transaction's integrity. When enabled, the last 4 bytes of the transaction correspond to the CRC. Figure 10 and Figure 11 show an example of read and write transactions with CRC, respectively. Figure 10: I2C Read Transaction with CRC Figure 11: I<sup>2</sup>C Write Transaction with CRC If CRC is disabled, a write transaction can optionally include the correct CRC bytes to be accepted. During a read, the MPF42797 does not include the CRC, so the NACK signal and stop command from the master come after DATA[x]. I<sup>2</sup>C operations using any address outside of the register map are invalid, even if they are partially valid addresses. An invalid read operation returns a 0 as the data and correct CRC (if enabled), and an invalid write operation is ignored. ## Cyclic Redundancy Check (CRC) The CRC spans the register address, length, and data payload. It is generated in blocks of 4 bytes. If the number of bytes is not a multiple of 4, the block is padded with 0x00. The algorithm to generate the CRC is listed below. ``` unsigned long crc32 (unsigned short Reg_Address, unsigned char len, unsigned char *data){ short i; unsigned long crc = 0xffffffff; unsigned char dataTemp[4]; for (i=-1; i<len; i++) { if(i==-1) { dataTemp[0]=len; dataTemp[1]=Reg_Address&0x00FF; dataTemp[2]=(Reg_Address&0xFF00)>>8; dataTemp[3]=0; else dataTemp[i%4]=data[i]; if((i\%4)==3 \mid \mid i == len-1 \mid \mid i == -1) { for (char j=0; j<4; j++) { crc ^= dataTemp[3-j] << 24; for (char k = 0; k < 8; ++k) { if ((crc & 0x8000000) != 0) crc = (crc << 1) ^ 0x04C11DB7;</pre> crc <<= 1; }} dataTemp[0]=0; dataTemp[1]=0: dataTemp[2]=0; dataTemp[3]=0; }} return crc; ``` To disable CRC and configure the slave address as 0x08, send the following message: {0x00, 0x41, 0x01, 0x08, 0x94, 0xA0, 0xDE, 0xDD} (Address = 0x4100, Length = 0x01, Data = 0x08, CRC = 0xDDDE A094). # I<sup>2</sup>C REGISTER MAP ## **Fuel Gauge Input** | Name,<br>Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |------------------------|---------------------------------------------------------------|-------------------------|------|------------------------------------------|--------------------------|------------------------------| | VRDG_CELL1,<br>0x0000 | Inputs cell 1's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL2,<br>0x0002 | Inputs cell 2's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL3,<br>0x0004 | Inputs cell 3's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL4,<br>0x0006 | Inputs cell 4's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL5,<br>0x0008 | Inputs cell 5's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL6,<br>0x000A | Inputs cell 6's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL7,<br>0x000C | Inputs cell 7's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL8,<br>0x000E | Inputs cell 8's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL9,<br>0x0010 | Inputs cell 9's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_CELL10,<br>0x0012 | Inputs cell 10's voltage reading. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_PACK,<br>0x0020 | Inputs the pack's voltage reading if VRDG_PACK_EN is enabled. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mV | 0mV | 0mV to<br>131070mV | | IRDG_CELL1,<br>0x0022 | Inputs cell 1's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL2,<br>0x0026 | Inputs cell 2's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL3,<br>0x002A | Inputs cell 3's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL4,<br>0x002E | Inputs cell 4's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL5,<br>0x0032 | Inputs cell 5's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL6,<br>0x0036 | Inputs cell 6's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL7,<br>0x003A | Inputs cell 7s current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | |------------------------|---------------------------------------------------------------|------------|-----|---------------------------------------------------|-----|-------------------------------------------------| | IRDG_CELL8,<br>0x003E | Inputs cell 8's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL9,<br>0x0042 | Inputs cell 9's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_CELL10,<br>0x0046 | Inputs cell 10's current reading if IRDG_CELLS_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | IRDG_PACK,<br>0x0062 | Inputs the pack's current reading if IRDG_PACK_EN is enabled. | 32, [31:0] | R/W | 32-bit signed, 2-comp integer LSB = 1mA | 0mA | -524288mA<br>to<br>+524287mA | | CCRDG,<br>0x0066 | Inputs the Coulomb count reading if CCRDG_EN is enabled. | 32, [31:0] | R/W | 32-bitsigned, 2-comp<br>integer<br>LSB = 0.0005mA | 0mA | -<br>1073741.83<br>2mA to<br>+1073741.8<br>32mA | | TRDG_TS1,<br>0x006A | Inputs temperature sensor 1's reading. | 16, [15:0] | R/W | 16-bit signed, 2-comp integer LSB = 0.01°C | 0°C | -273.15°C<br>to<br>+327.67°C | | TRDG_TS2,<br>0x006C | Inputs temperature sensor 2's reading. | 16, [15:0] | R/W | 16-bit signed, 2-comp integer LSB = 0.01°C | 0°C | -273.15°C<br>to<br>+327.67°C | | TRDG_TS3,<br>0x006E | Inputs temperature sensor 3's reading. | 16, [15:0] | R/W | 16-bit signed, 2-comp integer LSB = 0.01°C | 0°C | -273.15°C<br>to<br>+327.67°C | | TRDG_TS4,<br>0x0070 | Inputs temperature sensor 4's reading. | 16, [15:0] | R/W | 16-bit signed, 2-comp integer LSB = 0.01°C | 0°C | -273.15°C<br>to<br>+327.67°C | | TRDG_DIE,<br>0x0072 | Inputs the die temperature reading. | 16, [15:0] | R/W | 16-bit signed, 2-comp integer LSB = 0.01°C | 0°C | -273.15°C<br>to<br>+327.67°C | | BAL_CELL1,<br>0x0074 | Indicates cell 1's balancing status. 1: Active 0: Inactive | 1, [0] | R/W | Boolean true/false | 0 | 0 to 1 | | BAL_CELL2,<br>0x0074 | Indicates cell 2's balancing status. 1: Active 0: Inactive | 1, [1] | R/W | Boolean true/false | 0 | 0 to 1 | | BAL_CELL3,<br>0x0074 | Indicates cell 3's balancing status. 1: Active 0: Inactive | 1, [2] | R/W | Boolean true/false | 0 | 0 to 1 | | BAL_CELL4,<br>0x0074 | Indicates cell 4's balancing status. 1: Active 0: Inactive | 1, [3] | R/W | Boolean true/false | 0 | 0 to 1 | | BAL_CELL5,<br>0x0074 | Indicates cell 5's balancing status. 1: Active 0: Inactive | 1, [4] | R/W | Boolean true/false | 0 | 0 to 1 | | | | | | <u> </u> | | | | |-----------------------|-------------------------------------------------------------------------|--------|-----|----------------------|---|--------|--| | BAL_CELL6, | Indicates cell 6's balancing status. | 4 [5] | DAA | Dealess two /fales | | 0 to 4 | | | 0x0074 | 1: Active 0: Inactive | 1, [5] | R/W | Boolean true/false | 0 | 0 to 1 | | | | Indicates cell 7's balancing status. | | | | | | | | BAL_CELL7,<br>0x0074 | 1: Active | 1, [6] | R/W | Boolean true/false | 0 | 0 to 1 | | | 0,0074 | 0: Inactive | | | | | | | | BAL_CELL8, | Indicates cell 8's balancing status. | | | | | | | | 0x0074 | 1: Active | 1, [7] | R/W | Boolean true/false | 0 | 0 to 1 | | | | 0: Inactive | | | | | | | | BAL_CELL9, | Indicates cell 9's balancing status. | 1, [8] | R/W | Boolean true/false | 0 | 0 to 1 | | | 0x0074 | 1: Active 0: Inactive | ری ا | | Boologii ii do/ialoo | Ü | 0 10 1 | | | 5 05 | Indicates cell 10's balancing status. | | | | | | | | BAL_CELL10,<br>0x0074 | 1: Active | 1, [9] | R/W | Boolean true/false | 0 | 0 to 1 | | | | 0: Inactive | | | | | | | | | Resets the fuel gauge and lifetime log if set to 1 (i.e. FG_RST = | | | | | | | | HARD_RST,<br>0x0076 | LOG_RST = 1). This is a self- | 1, [0] | R/W | Boolean true/false | 0 | 0 to 1 | | | | clearing register that returns to 0 automatically. | | | | | | | | | Resets the fuel gauge if set to 1 | | | | | | | | | (i.e., STATUS_RST = SOH_RST = SOC_RST = FULL_RST = | | | | | | | | FC DET | EMTY_RST = IR_RST = | | | | | | | | FG_RST,<br>0x0076 | ETAC_RST = IDIS_AVG_RST = IDIS_END_RST = | 1, [1] | R/W | Boolean true/false | 0 | 0 to 1 | | | | ICHG_END_RST = ICHG_CC_RST = VCHG_CV_RST | | | | | | | | | = 1). This is a self-clearing register that returns to 0 automatically. | | | | | | | | | Resets the lifetime log. | | | | | | | | LOG_RST,<br>0x0076 | 1: Reset (self-clearing) | 1, [2] | R/W | Boolean true/false | 0 | 0 to 1 | | | 0x0076 | 0: No action | | | | | | | | WKUP, | Wakes up the fuel gauge. | | | | | | | | 0x0078 | 1: Wake up (self-clearing) 0: No action | 1, [3] | R/W | Boolean true/false | 0 | 0 to 1 | | | | Resets the pack status. | | | | | | | | STATUS_RST,<br>0x0076 | 1: Reset (self-clearing) | 1, [4] | R/W | Boolean true/false | 0 | 0 to 1 | | | 0x0076 | 0: No action | | | | | | | | SOH_RST, | Resets the SOH. | | | | | | | | 0x0076 | 1: Reset (self-clearing) 0: No action | 1, [5] | R/W | Boolean true/false | 0 | 0 to 1 | | | | Resets the SOC. | | | | | | | | SOC_RST,<br>0x0076 | 1: Reset (self-clearing) | 1, [7] | R/W | Boolean true/false | 0 | 0 to 1 | | | 0,0070 | 0: No action | | | | | | | | FULL_RST, | Resets the pack full. | | | | | _ | | | 0x0076 | 1: Reset (self-clearing)<br>0: No action | 1, [8] | R/W | Boolean true/false | 0 | 0 to 1 | | | EMTV DOT | Resets the pack empty. | | | | | | | | EMTY_RST,<br>0x0076 | 1: Reset (self-clearing) 0: No action | 1, [9] | R/W | Boolean true/false | 0 | 0 to 1 | | | | 1 | | 1 | 1 | I | l | | | IDIS_AVG_RST,<br>0x0076 | Resets the average discharge current. 1: Reset (self-clearing) 0: No action | 1, [10] | R/W | Boolean true/false | 0 | 0 to 1 | |-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|--------------------------------|-----------------|--------| | IDIS_END_RST,<br>0x0076 | Resets the discharge termination current. 1: Reset (self-clearing) 0: No action | 1, [11] | R/W | Boolean true/false | 0 | 0 to 1 | | ICHG_END_<br>RST,<br>0x0076 | Resets the charge termination current. 1: Reset (self-clearing) 0: No action | 1, [12] | R/W | Boolean true/false | 0 | 0 to 1 | | ICHG_CC_RST,<br>0x0076 | Resets the charge CC. 1: Reset (self-clearing) 0: No action | 1, [13] | R/W | Boolean true/false | 0 | 0 to 1 | | VCHG_CV_RST,<br>0x0076 | Resets the charge CV. 1: Reset (self-clearing) 0: No action | 1, [14] | R/W | Boolean true/false | 0 | 0 to 1 | | PCHG_SHW,<br>0x0078 | Shows the maximum charge power in PCHG, the limiting cell ID in PCHG_ID, and the limiting factor in PCHG_LIM (PCHG_SHW_EN by default). 1: Show 0: Do not show | 1, [0] | R/W | Control Enable = 1 Disable = 0 | PCHG_SHW_<br>EN | 0 to 1 | | PDIS_SHW,<br>0x0078 | Shows the maximum discharge power (PDIS_SHW_EN by default). 1: Show 0: Do not show | 1, [1] | R/W | Control Enable = 1 Disable = 0 | PDIS_SHW_<br>EN | 0 to 1 | ## **Fuel Gauge Backup** | Name, Address | Description | Bit<br>Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------|--------------------------|---------------| | | These bits are the backup register for cell 1's SOH. This address is a R/W alias for the SOH_CELL1 register. | | | | | | | SOH_CELL1_<br>BKUP,<br>0x0200 | The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | | Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | any other of the cell SOH backup es the fuel gauge to use the these registers as a starting point hing. | | | | | | | These bits are the backup register for cell 2's SOH. This address is a R/W alias for the SOH_CELL2 register. | | | | | | | SOH_CELL2_<br>BKUP,<br>0x0204 | The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. | 32, [31:0] | 32, [31:0] R/W integ | LSB = | 0% | 0% to<br>255% | | | Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | | | | 0.0000001% | | | SOH_CELL3_<br>BKUP,<br>0x0208 | These bits are the backup register for cell 3's SOH. This address is a R/W alias for the SOH_CELL3 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|------------------------------------------|----|---------------| | SOH_CELL4_<br>BKUP,<br>0x020C | These bits are the backup register for cell 4's SOH. This address is a R/W alias for the SOH_CELL4 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | SOH_CELL5_<br>BKUP,<br>0x0210 | These bits are the backup register for cell 5's SOH. This address is a R/W alias for the SOH_CELL5 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | SOH_CELL6_<br>BKUP,<br>0x0214 | These bits are the backup register for cell 6's SOH. This address is a R/W alias for the SOH_CELL6 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | SOH_CELL7_<br>BKUP,<br>0x0218 | These bits are the backup register for cell 7's SOH. This address is a R/W alias for the SOH_CELL7 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | # MPF42797 - 2 TO 10 STACKED CELLS BATTERY PACK FUEL GAUGE | SOH_CELL8_<br>BKUP,<br>0x021C | These bits are the backup register for cell 8's SOH. This address is a R/W alias for the SOH_CELL8 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|-------------------------------------------|----|--------------------| | SOH_CELL9_<br>BKUP,<br>0x0220 | These bits are the backup register for cell 9's SOH. This address is a R/W alias for the SOH_CELL9 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | SOH_CELL10_<br>BKUP,<br>0x0224 | These bits are the backup register for cell 10's SOH. This address is a R/W alias for the SOH_CELL10 register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this or any other of the cell SOH backup registers prepares the fuel gauge to use the values written in these registers as a starting point for the SOH learning. | 32, [31:0] | R/W | 32-bit unsigned integer LSB = 0.0000001% | 0% | 0% to<br>255% | | IDIS_AVG_<br>BKUP,<br>0x0280 | These bits are the backup register for the average discharge current. This address is a R/W alias for the IDIS_AVG register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this backup register prepares the fuel gauge to use the values written in this register as a starting point for this learning. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 2mA | - | 0mA to<br>131070mA | | IDIS_END_<br>BKUP,<br>0x0290 | These bits are the backup register for the discharge end current. This address is a R/W alias for the IDIS_END register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this backup register prepares the fuel gauge to use the values written in this register as a starting point for this learning. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 2mA | - | 0mA to<br>131070mA | | ICHG_CC_<br>BKUP,<br>0x02A0 | These bits are the backup register for the charge CC current. This address is a R/W alias for the ICHG_CC register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this backup register prepares the fuel gauge to use the values written in this register as a starting point for this learning. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 2mA | - | 0mA to<br>131070mA | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------|-----------------------------------|-----|--------------------| | ICHG_END_<br>BKUP,<br>0x02B0 | These bits are the backup register for the charge termination current. This address is a R/W alias for the ICHG_END register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this backup register prepares the fuel gauge to use the values written in this register as a starting point for this learning. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 2mA | - | 0mA to<br>131070mA | | VCHG_CV_<br>BKUP,<br>0x02C0 | These bits are the backup register for the charge CV voltage. This address is a R/W alias for the VCHG_CV register. The fuel gauge must be in learning backup mode for this register to be written. For more details, see the FG_BKUP_ENABLE register on page 20 and the FG_BKUP_FLAG register on page 28. Writing to this backup register prepares the fuel gauge to use the values written in this register as a starting point for this learning. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 2mV | 0mV | 0mV to<br>131070mV | | FG_BKUP_<br>ENABLE,<br>0x0300 | Enables learning backup mode. See the FG_BKUP_FLAG register on page 28 for more details. Learning backup mode must be enabled to enable any write operations to the learning backup registers. | 1, [0] | Write-<br>only | Control Enable = 1 Disable = 0 | 0 | 0 to 1 | # **Fuel Gauge Output** | Name, Address | Description | Bit<br>Length,<br>Position | Туре | Encoding | Decoded<br>Default<br>Value | Range | |-------------------------------|-----------------------------|----------------------------|-----------|--------------------------------------|-----------------------------|------------| | EMTY_SOC_<br>CELL1,<br>0x0564 | Returns cell 1's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL2,<br>0x0565 | Returns cell 2's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL3,<br>0x0566 | Returns cell 3's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL4,<br>0x0567 | Returns cell 4's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL5,<br>0x0568 | Returns cell 5's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL6,<br>0x0569 | Returns cell 6's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL7,<br>0x056A | Returns cell 7's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL8,<br>0x056B | Returns cell 8's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | |--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|---------------------------------------------|-------------|-------------------| | EMTY_SOC_<br>CELL9,<br>0x056C | Returns cell 9's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_SOC_<br>CELL10,<br>0x056D | Returns cell 10's empty SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 0% | 0% to 100% | | EMTY_ID,<br>0x0574 | Returns the cell ID for the cell that is empty limiting the pack. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 1 (cell ID) | 0 (cell ID) | 1 to 10 (cell ID) | | EMTY_RTIME,<br>0x0575 | Returns the remaining time for the pack to become empty. Smoother changes for the remaining time estimate can be achieved by increasing EMTY_RTIME_FILTER with the tradeoff of an increased phase delay. | 16, [15:0] | Read-only | 16-bit unsigned integer LSB = 1s | 0s | 0s to<br>65535s | | EMTY_LIM,<br>0x0577 | Outputs the pack's empty limiting factor. 0: Cell 1: Pack | 8, [7:0] | Read-only | Non-standard<br>LSB = 1 | 0 | 0 to 1 | | FULL_SOC_<br>CELL1,<br>0x057C | Returns cell's 1 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL2,<br>0x057D | Returns cell's 2 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL3,<br>0x057E | Returns cell's 3 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL4,<br>0x057F | Returns cell's 4 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL5,<br>0x0580 | Returns cell's 5 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL6,<br>0x0581 | Returns cell's 6 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL7,<br>0x0582 | Returns cell's 7 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL8,<br>0x0583 | Returns cell's 8 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4 % | 100% | 0% to 100% | | FULL_SOC_<br>CELL9,<br>0x0584 | Returns cell's 9 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_SOC_<br>CELL10,<br>0x0585 | Returns cell's 10 full SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.4% | 100% | 0% to 100% | | FULL_ID,<br>0x058C | Returns the cell ID for the cell that is full limiting the pack. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 1 (cell ID) | 0 (cell ID) | 1 to 10 (cell ID) | | FULL_RTIME,<br>0x058D | Returns the remaining time to reach a full pack. | 16, [15:0] | Read-only | 16-bit unsigned integer LSB = 1s | 0s | 0s to<br>65535s | | | Returns the pack's full limiting factor. | | | | | | |------------------------------|---------------------------------------------------------------------------------------------------------------|---------------|-------------|-----------------------------------|-----|--------------------| | FULL_LIM,<br>0x058F | 0: Cell<br>1: Pack | 1, [0] | Read-only | Non-standard | 0 | 0 to 1 | | IDIS_AVG,<br>0x0590 | Returns the learned value for the typical load current, which is drained from the battery during its use (the | 16, [15:0] | Read-only | 16-bit unsigned integer | - | 0mA to<br>131070mA | | | average discharge current). | | | LSB = 2mA | | | | IDIS_END,<br>0x0593 | Returns the learned value for the typical discharge termination current. | 16, [15:0] | Read-only | 16-bit unsigned integer | - | 0mA to<br>131070mA | | | 3, | | | LSB = 2mA | | | | ICHG_CC,<br>0x0597 | Returns the learned charge current of the charger in the CC region, as | 16, [15:0] | Read-only | 16-bit unsigned integer | - | 0mA to<br>131070mA | | | performed by the algorithm. | | | LSB = 2mA | | | | ICHG_END,<br>0x059B | Returns the learned value for the typical end of the discharge current | 16, [15:0] | Read-only | 16-bit unsigned integer | - | 0mA to<br>131070mA | | | | | | LSB = 2mA | | | | VCHG_CV,<br>0x059F | Returns the learned value for the typical charge CV voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer | 0mV | 0mV to<br>131070mV | | | | | | LSB = 2mV | | | | SOC_PACK_<br>UNAVBL, | Indicates whether the pack has an unavailable SOC due to empty or full conditions, or a mismatch between | 16, [15:0] | Read-only | 16-bit unsigned integer | 0% | 0% to 100% | | 0x05A3 | cells. Reflects the quantity of pack's unusable capacity. | LSB = 0.002 % | | | | | | | unusuble supusity. | | | 16-bit unsigned | | | | SOC_PACK,<br>0x05A5 | Returns the pack's SOC. | 16, [15:0] | Read-only | integer | 0% | 0% to 100% | | 0.000,00 | | | - | LSB = 0.002 % | | | | SOC_ABS_<br>CELL1,<br>0x05A8 | Returns cell 1's absolute SOC. Shows as reserved. | 8, [7:0] | Read-only | 8-bit unsigned integer LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 2's absolute SOC. | | | 8-bit unsigned integer | | | | CELL2,<br>0x05A9 | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 3's absolute SOC. | | | 8-bit unsigned integer | | | | CELL3,<br>0x05AA | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 4's absolute SOC. | | | 8-bit unsigned integer | | | | CELL4,<br>0x05AB | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 5's absolute SOC. | | | 8-bit unsigned integer | | | | CELL5,<br>0x05AC | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 6's absolute SOC. | | | 8-bit unsigned integer | | | | CELL6,<br>0x05AD | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 7's absolute SOC. | | | 8-bit unsigned integer | _ | | | CELL7,<br>0x05AE | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 8's absolute SOC. | 0 [7.0] | Dead | 8-bit unsigned integer | _ | 00/ +- 4000/ | | CELL8,<br>0x05AF | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_ | Returns cell 9's absolute SOC. | Q [7·∩] | Read only | 8-bit unsigned integer | 0 | 0% to 100% | | CELL9,<br>0x05B0 | Shows as reserved. | 8, [7:0] | Read-only | LSB = 0.4% | 0 | 0% to 100% | | SOC_ABS_<br>CELL10, | Returns cell 10's absolute SOC. | 8, [7:0] | Read-only | 8-bit unsigned integer | 0 | 0% to 100% | | 0x05B1 | Shows as reserved. | 0, [7.0] | i Neau-Only | LSB = 0.4% | | 0 /0 10 100 /0 | | SOH_PACK,<br>0x0608 | Returns the pack's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer LSB = 0.0000001% | 0 | 0% to 255% | |-----------------------|-------------------------------------------------------------------------------------------------------------------------|------------|-----------|---------------------------------------------|----------------|-----------------------------| | SOH_CELL1,<br>0x060C | Returns cell 1's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL2,<br>0x0610 | Returns cell 2's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL3,<br>0x0614 | Returns cell 3's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL4,<br>0x0618 | Returns cell 4's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL5,<br>0x061C | Returns cell 5's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL6,<br>0x0620 | Returns cell 6's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL7,<br>0x0624 | Returns cell 7's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL8,<br>0x0628 | Returns cell 8's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL9,<br>0x062C | Returns cell 9's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | SOH_CELL10,<br>0x0630 | Returns cell 10's SOH. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.0000001% | 0 | 0% to 255% | | PRDG,<br>0x070C | Returns the power state of the battery pack, which is equal to the pack current multiplied by the battery pack voltage. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.1mW | 0mW | 0mW to<br>429496729.<br>5mW | | PDIS,<br>0x0710 | Returns the maximum possible applicable discharge power. | 32, [31:0] | Read-only | 32-bit unsigned integer LSB = 0.1mW | 0mW | 0mW to<br>429496729.<br>5mW | | PDIS_ID,<br>0x0714 | Returns the cell ID that is most significantly limiting the maximum discharge power estimate. | 5, [4:0] | Read-only | 8-bit unsigned integer<br>LSB = 1 (cell ID) | 1 (cell<br>ID) | 1 to 10 (cell ID) | | PDIS_LIM,<br>0x0715 | Returns the limiting factor in the maximum discharge power estimate. 0: Cell 1: Pack | 1, [0] | Read-only | Non-standard | 0 | 0 to 1 | | PCHG,<br>0x0716 | Returns the maximum possible applicable charge power. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 0.1mW | 0mW | 0mW to<br>429496729.<br>5mW | | PCHG_ID,<br>0x071A | Returns the cell ID that is most significantly limiting the maximum charge power estimate. | 5, [4:0] | Read-only | 8-bit unsigned integer<br>LSB = 1 (cell ID) | 1 (cell<br>ID) | 1 to 10 (cell ID) | | PCHG_LIM,<br>0x071B | Returns the limiting factor in the maximum charge power estimate. 0: Cell 1: Pack | 1, [0] | Read-only | 8-bit unsigned integer | 0 | 0 to 1 | | STATUS,<br>0x071C | Returns the pack's current status. 0: Charge 1: Discharge 2: Rest | 2, [1:0] | Read-only | 8-bit unsigned integer<br>LSB = 1 | 0 | 0 to 2 | | FG_ITER,<br>0x071D | Counts the number of iterations executed by the fuel gauge. | 32, [31:0] | Read-only | 32-bit unsigned integer<br>LSB = 1 | 0 | 0 to<br>429496729<br>5 | | |--------------------|-------------------------------------------------------------|------------|-----------|------------------------------------|---|------------------------|--| |--------------------|-------------------------------------------------------------|------------|-----------|------------------------------------|---|------------------------|--| ## **Fuel Gauge Lifetime Log** | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |--------------------------------|---------------------------------------------|-------------------------|-----------|----------------------------------------|--------------------------|--------------------| | VRDG_MIN_<br>CELL1,<br>0x0C00 | Returns cell 1's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL2,<br>0x0C02 | Returns cell 2's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL3,<br>0x0C04 | Returns cell 3's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL4,<br>0x0C06 | Returns cell 4's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL5,<br>0x0C08 | Returns cell 5's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL6,<br>0x0C0A | Returns cell 6's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL7,<br>0x0C0C | Returns cell 7's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL8,<br>0x0C0E | Returns cell 8's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL9,<br>0x0C10 | Returns cell 9's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MIN_<br>CELL10,<br>0x0C12 | Returns cell 10's minimum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 5000mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL1,<br>0x0C20 | Returns cell 1's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL2,<br>0x0C22 | Returns cell 2's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL3,<br>0x0C24 | Returns cell 3's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL4,<br>0x0C26 | Returns cell 4's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL5,<br>0x0C28 | Returns cell 5's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL6,<br>0x0C2A | Returns cell 6's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL7,<br>0x0C2C | Returns cell 7's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL8,<br>0x0C2E | Returns cell 8's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_MAX_<br>CELL9,<br>0x0C30 | Returns cell 9's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | |---------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------|-----------|-----------------------------------------------------|----------------|----------------------| | VRDG_MAX_<br>CELL10,<br>0x0C32 | Returns cell 10's maximum measured voltage. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 0.1mV | 0mV | 0mV to<br>6553.5mV | | VRDG_DMAX,<br>0x0C40 | Returns the maximum measured voltage difference between the cells. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 2mV | 0mV | 0mV to<br>512mV | | VRDG_DMAX_<br>IDMAX,<br>0x0C41 | Identifies the cell with the highest voltage. This cell is used to calculate the maximum voltage difference between the cells. | 4, [3:0] | Read-only | Non-standard LSB = 1 (cell ID) Offset = 1 (cell ID) | 1 (cell<br>ID) | 1 to 10<br>(cell ID) | | VRDG_DMAX_<br>IDMIN,<br>0x0C41 | Identifies the cell with the lowest voltage. This cell is used to calculate the maximum voltage difference between the cells. | 4, [7:4] | Read-only | Non-standard LSB = 1 (cell ID) Offset = 1 (cell ID) | 1 (cell<br>ID) | 1 to 10<br>(cell ID) | | BAL_ETIME_<br>CELL1,<br>0x0C42 | Returns the total time that cell 1 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL2,<br>0x0C44 | Returns the total time that cell 2 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL3,<br>0x0C46 | Returns the total time that cell 3 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL4,<br>0x0C48 | Returns the total time that cell 4 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL5,<br>0x0C4A | Returns the total time that cell 5 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL6,<br>0x0C4C | Returns the total time that cell 6 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL7,<br>0x0C4E | Returns the total time that cell 7 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL8,<br>0x0C50 | Returns the total time that cell 8 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL9,<br>0x0C52 | Returns the total time that cell 9 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | BAL_ETIME_<br>CELL10,<br>0x0C54 | Returns the total time that cell 10 has been balanced. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1min | 0min | 0min to<br>65535min | | TRDG_MIN_<br>TS1,<br>0x0C62 | Returns the minimum temperature measured with temperature sensor 1. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MIN_<br>TS2,<br>0x0C63 | Returns the minimum temperature measured with temperature sensor 2. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MIN_<br>TS3,<br>0x0C64 | Returns the minimum temperature measured with temperature sensor 2. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MIN_<br>TS4,<br>0x0C65 | Returns the minimum temperature measured with temperature sensor 2. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MAX_<br>TS1,<br>0x0C66 | Returns the maximum temperature measured with temperature sensor 1. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MAX_<br>TS2,<br>0x0C67 | Returns the maximum temperature measured with temperature sensor 2. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | |----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|-----------------------------------------------------|----------------|---------------------| | TRDG_MAX_<br>TS3,<br>0x0C68 | Returns the maximum temperature measured with temperature sensor 3. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_MAX_<br>TS4,<br>0x0C69 | Returns the maximum temperature measured with temperature sensor 4. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 97.5°C | -30°C to<br>+97.5°C | | TRDG_DMAX,<br>0x0C6A | Returns the maximum measured temperature difference between temperature the sensors. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 0°C | 0°C to<br>127.5°C | | TRDG_DMAX_<br>IDMAX,<br>0x0C6B | Identifies the cell with the highest temperature. This cell is used to calculate the maximum temperature difference between the cells. | 4, [3:0] | Read-only | Non-standard LSB = 1 (cell ID) Offset = 1 (cell ID) | 1 (cell<br>ID) | 1 to 4 (cell ID) | | TRDG_DMAX_<br>IDMIN,<br>0x0C6B | Identifies the cell with the lowest temperature. This cell is used to calculate the maximum temperature difference between the cells. | 4, [7:4] | Read-only | Non-standard LSB = 1 (cell ID) Offset = 1 (cell ID) | 1 (cell<br>ID) | 1 to 4 (cell<br>ID) | | TRDG_ETIME_<br>UND0,<br>0x0C6C | Returns the amount of time that the battery's average temperature has been below 0°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>0TO5,<br>0x0C6E | Returns the amount of time that the battery's average temperature has been between 0°C and 5°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>5TO10,<br>0x0C70 | Returns the amount of time that the battery's average temperature has been between 5°C and 10°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>10TO15,<br>0x0C72 | Returns the amount of time that the battery's average temperature has been between 10°C and 15°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>15TO20,<br>0x0C74 | Returns the amount of time that the battery's average temperature has been between 15°C and 20°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>20TO25,<br>0x0C76 | Returns the amount of time that the battery's average temperature has been between 20°C and 25°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>25TO30,<br>0x0C78 | Returns the amount of time that the battery's average temperature has been between 25°C and 30°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>30TO35,<br>0x0C7A | Returns the amount of time that the battery's average temperature has been between 30°C and 35°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>35TO40,<br>0x0C7C | Returns the amount of time that the battery's average temperature has been between 35°C and 40°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>40TO45,<br>0x0C7E | Returns the amount of time that the battery's average temperature has been between 40°C and 45°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>45TO50,<br>0x0C80 | Returns the amount of time that the battery's average temperature has been between 45°C and 50°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>50TO55,<br>0x0C82 | Returns the amount of time that the battery's average temperature has been between 50°C and 55°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | Ohr | 0hr to<br>65535hr | | TRDG_ETIME_<br>55TO60,<br>0x0C84 | Returns the amount of time that the battery's average temperature has been between 55°C and 60°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | 0hr | 0hr to<br>65535hr | | TRDG_ETIME_<br>ABV60,<br>0x0C86 | Returns the amount of time that the battery's average temperature exceeds 60°C. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1hr | 0hr | 0hr to<br>65535hr | |---------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------|-----------|---------------------------------------------|--------------------|-----------------------------------------| | TRDG_MIN_<br>DIE,<br>0x0C88 | Returns the minimum temperature measured on the die. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | 0°C | -30°C to<br>+97.5°C | | TRDG_MAX_<br>DIE,<br>0x0C89 | Returns the maximum temperature measured on the die. | 8, [7:0] | Read-only | 8-bit unsigned integer<br>LSB = 0.5°C | -30°C | -30°C to<br>+97.5°C | | IRDG_MAX_<br>CHG,<br>0x0C8A | Returns the maximum measured charge current. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 2mA | 0mA | 0mA to<br>131070<br>mA | | IRDG_MAX_<br>DIS,<br>0x0C8C | Returns the maximum measured discharge current. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 2mA | 0mA | 0mA to<br>131070mA | | NCHG_CYC,<br>0x0C8E | Returns the number of completed charge cycles, which is when the battery pack's SOC has charged from below 15% to above 85%. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1 Event(s) | 0<br>events<br>(s) | 0<br>events(s)<br>to 65535<br>events(s) | | NCHG_10SOC,<br>0x0C90 | Returns the number of times the pack has been charged by 10%. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1 event | 0<br>events<br>(s) | 0<br>events(s)<br>to 65535<br>events(s) | | NSHDN,<br>0x0C92 | Returns the number of times the fuel gauge has woken up after sleep mode, a hard reset, or a shutdown. | 16, [15:0] | Read-only | 16-bit unsigned integer<br>LSB = 1 event | 0<br>events<br>(s) | 0<br>events(s)<br>to 65535<br>events(s) | ## **Fuel Gauge Flags** | ruei Gauge riags | | | | | | | | | |---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------|--------------|--------------------------|--------|--|--| | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | | | | FG_EXE_FLAG,<br>0x0F00 | Fuel gauge calculations are ongoing Fuel gauge calculations are complete | 1, [0] | Read-only | Non-standard | 0 | 0 to 1 | | | | EDIT_<br>SETTINGS_<br>FLAG,<br>0x0F00 | 1: Fuel gauge settings can be edited on the fly 0: Fuel gauge settings cannot be edited on the fly | 1, [1] | Read-only | Non-standard | 0 | 0 to 1 | | | | CONFIG_<br>MODE_FLAG,<br>0x0F00 | The fuel gauge is in configuration mode The fuel gauge is in running mode | 1, [2] | Read-only | Non-standard | 0 | 0 to 1 | | | | CONFIG_<br>EXIT_FLAG,<br>0x0F00 | There is a pending exit from configuration mode There is no pending exit from configuration mode | 1, [3] | Read-only | Non-standard | 0 | 0 to 1 | | | | CONFIG_RST_<br>FLAG,<br>0x0F00 | There is a pending reset to set the configurations to their default values There is no pending reset to set the configurations to their default values | 1, [4] | Read-only | Non-standard | 0 | 0 to 1 | | | | FG_RST_FLAG,<br>0x0F00 | There is no pending reset for the fuel gauge algorithm There is a pending reset for the fuel gauge algorithm | 1, [5] | Read-only | Non-standard | 0 | 0 to 1 | | | | LOG_RST_<br>FLAG,<br>0x0F00 | The lifetime log registers are being reset in the current fuel gauge iteration No lifetime log registers are being reset | 1, [6] | Read-only | Non-standard | 0 | 0 to 1 | | | | LOG_RST_<br>PNDG_FLAG,<br>0x0F00 | There is a pending reset to the lifetime log registers There is no pending reset to the lifetime log registers | 1, [7] | Read-only | Non-standard | 0 | 0 to 1 | | | | backup registers. Use FG_BKUP_ENABLE to exit/enter this mode. | FG_BKUP_<br>FLAG,<br>0x0F00 | | 1, [11] | Read-only | Non-standard | 0 | 0 to 1 | |---------------------------------------------------------------|-----------------------------|--|---------|-----------|--------------|---|--------| |---------------------------------------------------------------|-----------------------------|--|---------|-----------|--------------|---|--------| ## **Fuel Gauge Settings** | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------|-------------------------------------------|--------------------------|-----------------------| | EXE_TIME,<br>0x1000 | Sets the fuel gauge execution time interval. | 8, [7:0] | R/W | 8-bit unsigned integer LSB = 0.1s | 4s | 0.5s to 16s | | WEXE_TIME_<br>REST,<br>0x1001 | Updates the most time-consuming functions when the fuel gauge is resting each (WEXE_TIME_REST x EXE_TIME), instead of each EXE_TIME. The maximum allowed value for the execution period of this functions is 32s, so if the fuel gauge is set such that (WEXE_TIME_REST x EXE_TIME) is longer than 32s, then the period used is the multiple of EXE_TIME, that is closest to but shorter than 32s. | 5, [4:0] | R/W | 8-bit unsigned integer LSB = 1 | 4 | 1 to 16 | | DIS_ITH,<br>0x1002 | Sets the discharge status current threshold. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 1mA | 25mA | 0mA to<br>65535mA | | CHG_ITH,<br>0x1004 | Sets the charge status current threshold. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 1mA | 25mA | 0mA to<br>65535mA | | SOC_DMAX,<br>0x1006 | Sets the maximum SOC for the charge and discharge statuses. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 0.00005%/s | 0.07%/s | 0.00005%/s<br>to 2%/s | | SOC_DMAX_<br>REST,<br>0x1008 | Sets the maximum SOC slope for the resting status. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = 0.00005%/s | 0.001%/s | 0%/s to<br>2%/s | | VRDG_PACK_<br>EN,<br>0x1100 | Enables the VRDG_PACK input (pack voltage reading). | 1, [0] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | IRDG_PACK_<br>EN,<br>0x1100 | Enables the IRDG_PACK input (pack current reading). | 1, [1] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | IRDG_CELLS_<br>EN,<br>0x1100 | Enables the IRDG_CELLx inputs (cells current reading). | 1, [2] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | CCRDG_EN,<br>0x1100 | Enables the CCRDG input (coulomb countring). | 1, [3] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | SOH_LRN_EN,<br>0x1100 | Enables SOH learning. | 1, [7] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | | T | | 1 | 1 | T | 1 | |--------------------------------|------------------------------------------------------------|----------|-------|---------------------------------|---|--------| | ICHG_CC_LRN_<br>EN,<br>0x1100 | Enables charge CC learning. | 1, [10] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | | IOLIO END | | | | Control | | | | ICHG_END_<br>LRN_EN,<br>0x1100 | Enables charge termination current learning. | 1, [11] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | VCHG_CV_ | | | | Control | | | | LRN_EN,<br>0x1100 | Enables charge CV learning. | 1, [12] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | IDIS_AVG_ | | | | Control | | | | LRN_EN,<br>0x1100 | Enables discharge average current learning. | 1, [13] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | IDIS_END_ | | | | Control | | | | LRN_EN,<br>0x1100 | Enables discharge termination current learning. | 1, [14] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | IDIS_END_ | Footbase and footbase described | | | Control | | | | LRN_CONT_EN,<br>0x1100 | Enables continuous discharge termination current learning. | 1, [15] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | PCHG_SHW_ | | | | Control | | | | EN,<br>0x1100 | Sets the PCHG_SHW default value. | 1, [18] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | 5510 01111 511 | | | | Control | | | | PDIS_SHW_EN,<br>0x1100 | Sets the PDIS_SHW default value. | 1, [19] | R/W | Enable = 1<br>Disable = 0 | 1 | 0 to 1 | | | | | | Non-standard | | | | TSS_CELL1,<br>0x1200 | Sets cell 1's temperature sensor source. | 2, [1:0] | R/W | LSB = 1 | 1 | 1 to 4 | | 0.71200 | | | | Offset = 1 | | | | _ | | | | Non-standard | | | | TSS_CELL2, | Sets cell 2's temperature sensor source. | 2, [3:2] | R/W | LSB = 1 | 1 | 1 to 4 | | 0x1200 | · | 2, [0.2] | | Offset = 1 | | | | | | | | Non-standard | | | | TSS_CELL3, | Sets cell 3's temperature sensor source. | 2, [5:4] | R/W | LSB = 1 | 1 | 1 to 4 | | 0x1200 | | , [- ] | | Offset = 1 | | | | | | | | Non-standard | | | | TSS_CELL4, | Sets cell 4's temperature sensor source. | 2, [7:6] | R/W | LSB = 1 | 1 | 1 to 4 | | 0x1200 | Cote con 10 temperature concer course. | 2, [7.0] | '' | Offset = 1 | | 1.01 | | | | | | Non-standard | | | | TSS_CELL5, | Sets cell 5's temperature sensor source. | 2, [1:0] | R/W | LSB = 1 | 1 | 1 to 4 | | 0x1201 | Gets cell 3's telliperature sellsor source. | ۷, [۱.۵] | FX/VV | | ' | 1 10 4 | | | | | | Offset = 1 | | | | TSS_CELL6, | Cata call Cla tages and tree | 0.10.01 | D 444 | Non-standard | _ | 41.4 | | 0x1201 | Sets cell 6's temperature sensor source. | 2, [3:2] | R/W | LSB = 1 | 1 | 1 to 4 | | | | | | Offset = 1 | | | | TSS_CELL7, | | | | Non-standard | | | | 0x1201 | Sets cell 7's temperature sensor source. | 2, [5:4] | R/W | LSB = 1 | 1 | 1 to 4 | | | | | | Offset = 1 | | | | | T | | | | 1 | | |-----------------------|---------------------------------------------------------------------------------|--------------|---------|----------------------------|----------|---------------------------------------| | TSS CELL8, | | | | Non-standard | | | | 0x1201 | Sets cell 8's temperature sensor source. | 2, [7:6] | R/W | LSB = 1 | 1 | 1 to 4 | | | | | | Offset = 1 | | | | | | | | Non-standard | | | | TSS_CELL9,<br>0x1202 | Sets cell 9's temperature sensor source. | 2, [1:0] | R/W | LSB = 1 | 1 | 1 to 4 | | 0.71202 | | | | Offset = 1 | | | | | | | | Non-standard | | | | TSS_CELL10, | Sets cell 10's temperature sensor source. | 2, [3:2] | R/W | LSB = 1 | 1 | 1 to 4 | | 0x1202 | · | , <b>.</b> . | | Offset = 1 | | | | | | | | 8-bit unsigned integer | | | | NCELLS_SER,<br>0x1204 | Sets the number of series-connected cells in the battery pack. | 5, [4:0] | R/W | LSB = 1 | 16 | 2 to 10 | | | , , , , , , , , , , , , , , , , , , , , | | | _ | | | | NCELLS_PAR,<br>0x1205 | Sets the number of parallel-connected cells | 8, [7:0] | R/W | 8-bit unsigned integer | 1 | 1 to 255 | | UX 1205 | in the battery pack. | | | LSB = 1 | | | | NTSS, | Sets the number of temperature sensors in | 3, [2:0] | R/W | 8-bit unsigned integer | 1 | 1 to 4 | | 0x1206 | the battery pack. | J, [2.0] | 10,00 | LSB = 1 | ' | 1 10 4 | | RCXN_PACK, | Sets the connection resistance between | | 5 4 4 7 | 16-bit unsigned integer | | 0mΩ to | | 0x1207 | the battery and the battery management system (BMS) terminals. | 16, [15:0] | R/W | LSB = $0.1m\Omega$ | 10mΩ | 6553.5mΩ | | RBMS_HSIDE, | , | | | 16-bit unsigned integer | | 0mΩ to | | 0x1209 | Sets the BMS's high-side resistance. | 16, [15:0] | R/W | LSB = $0.1m\Omega$ | 4mΩ | 6553.5mΩ | | | | | | | | _ | | RBMS_LSIDE,<br>0x120B | Sets the BMS's low-side resistance. | 16, [15:0] | R/W | 16-bit unsigned integer | 2mΩ | 0mΩ to<br>6553.5mΩ | | 0.7.202 | | | | LSB = $0.1 \text{m}\Omega$ | | 00001011122 | | RCXN_CELL1, | Sets the connection resistance between cell 1's terminals and its corresponding | 16, [15:0] | R/W | 16-bit unsigned integer | 1mΩ | 0mΩ to | | 0x120D | voltage-sensing probes. | -,[] | · | LSB = $0.1m\Omega$ | | 6553.5mΩ | | RCXN_CELL2, | Sets the connection resistance between | | | 16-bit unsigned integer | | 0mΩ to | | 0x120F | cell 2's terminals and its corresponding voltage-sensing probes. | 16, [15:0] | R/W | LSB = $0.1m\Omega$ | 1mΩ | 6553.5mΩ | | | Sets the connection resistance between | | | 16-bit unsigned integer | | _ | | RCXN_CELL3,<br>0x1211 | cell 3's terminals and its corresponding | 16, [15:0] | R/W | | 1mΩ | 0mΩ to<br>6553.5mΩ | | | voltage-sensing probes. | | | LSB = $0.1 \text{m}\Omega$ | | 0000.02 | | RCXN_CELL4, | Sets the connection resistance between cell 4's terminals and its corresponding | 16, [15:0] | R/W | 16-bit unsigned integer | 1mΩ | 0mΩ to | | 0x1213 | voltage-sensing probes. | 10, [10.0] | | LSB = $0.1m\Omega$ | 111122 | 6553.5mΩ | | RCXN_CELL5, | Sets the connection resistance between | | | 16-bit unsigned integer | | 0mΩ to | | 0x1215 | cell 5's terminals and its corresponding voltage-sensing probes. | 16, [15:0] | R/W | LSB = $0.1m\Omega$ | 1mΩ | 6553.5mΩ | | | Sets the connection resistance between | | | 40 hit wasing adjust and | | | | RCXN_CELL6,<br>0x1217 | cell 6's terminals and its corresponding | 16, [15:0] | R/W | 16-bit unsigned integer | 1mΩ | 0mΩ to<br>6553.5mΩ | | VA1211 | voltage-sensing probes. | | | LSB = $0.1$ m $\Omega$ | <u> </u> | 221110.0000 | | RCXN_CELL7, | Sets the connection resistance between cell 7's terminals and its corresponding | 16, [15:0] | R/W | 16-bit unsigned integer | 1mΩ | 0mΩ to | | 0x1219 | voltage-sensing probes. | 10, [10.0] | 13/ 7 7 | LSB = $0.1m\Omega$ | 111132 | 6553.5mΩ | | RCXN_CELL8, | Sets the connection resistance between | | | 16-bit unsigned integer | | 0mΩ to | | 0x121B | cell 8's terminals and its corresponding voltage-sensing probes. | 16, [15:0] | R/W | LSB = $0.1m\Omega$ | 1mΩ | 6553.5mΩ | | | 0 01 | | | | 1 | | | RCXN_CELL9,<br>0x121D | Sets the connection resistance between cell 9's terminals and its corresponding | 16, [15:0] | R/W | 16-bit unsigned integer | 1mΩ | $0$ m $\Omega$ to $6553.5$ m $\Omega$ | | UNIZID | voltage-sensing probes. | | | LSB = $0.1m\Omega$ | | 0000.011122 | | RCXN_CELL10,<br>0x121F | Sets the connection resistance between cell 10's terminals and its corresponding voltage-sensing probes. | 16, [15:0] | R/W | 16-bit unsigned integer LSB = $0.1 \text{m}\Omega$ | 1mΩ | 0mΩ to<br>6553.5mΩ | |----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|----------------------------------------------------|-------------|--------------------| | ICHG_MAX,<br>0x122D | Sets the maximum charge current that the pack can accept. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2 mA | 4000 | 0mA to<br>131070mA | | ICHG_MAX_<br>MRGN,<br>0x122F | Sets the maximum charge current margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 4 mA | 120 | 0mA to<br>1020mA | | IDIS_MAX,<br>0x1230 | Sets the maximum discharge current that the pack can accept. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2 mA | 20000 | 0mA to<br>131070mA | | IDIS_MAX_<br>MRGN,<br>0x1232 | Sets the maximum discharge current margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 4 mA | 500 | 0mA to<br>1020mA | | VCELL_MAX,<br>0x1233 | Sets the maximum voltage accepted at the cell level. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 4200mV | 0mV to<br>6553.5mV | | VCELL_MAX_<br>MRGN,<br>0x1235 | Sets the maximum cell voltage margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.5mV | 5mV | 0mV to<br>127.5mV | | VCELL_MIN,<br>0x1236 | Sets the minimum voltage accepted at the cell level. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 0.1mV | 3000mV | 0mV to<br>6553.5mV | | VCELL_MIN_<br>MRGN,<br>0x1238 | Sets the minimum cell voltage margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.5mV | 5mV | 0mV to<br>127.5mV | | VPACK_MAX,<br>0x1239 | Sets the maximum voltage that the pack can accept. This value is used for charge power estimate. The pack float voltage represents the maximum voltage that the battery pack can reach in a charging scenario. It should be set the be equal to or exceed the charging system's CV. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mV | 41750m<br>V | 0mV to<br>131070mV | | VPACK_MAX_<br>MRGN,<br>0x123B | Sets the pack's maximum pack voltage margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 4mV | 48mV | 0mV to<br>1020mV | | VPACK_EMTY,<br>0x123C | Sets the pack empty voltage, which is the lowest usable pack voltage. This is the voltage at which the application considers a battery pack to be completely discharged, and stops operation. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mV | 30500m<br>V | 0mV to<br>131070mV | | VPACK_EMTY_<br>MRGN,<br>0x123E | Sets the margin the power learning algorithm applies to the pack empty voltage. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 4mV | 48mV | 0mV to<br>1020mV | | IDIS_AVG_SET,<br>0x1400 | Sets the nominal average discharge current (i.e. IDIS_AVG). | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 2500 | 2mA to<br>131070mA | | IDIS_END_SET,<br>0x1402 | Sets the nominal discharge termination current (i.e. IDIS_END). | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 2500 | 2mA to<br>131070mA | | EMTY_RTIME_<br>FILTER,<br>0x1406 | Sets the filter time constant for the remaining time-to-empty (i.e. EMTY_RTIME). Increasing EMTY_RTIME_FILTER results in a smoother estimate at the tradeoff of an increased phase delay. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 1s | 60s | 0s to 255s | | ICHG_CC_SET,<br>0x1500 | Sets the nominal charge constant current (i.e. ICHG_CC). It should be set to the nominal current that applied by the external charger to the battery pack while in the charge CC region. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 2500 | 2mA to<br>131070mA | |------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|---------------------------------------------|-----------------|----------------------------| | ICHG_END_<br>SET,<br>0x1502 | Sets the nominal charge termination current (i.e. ICHG_END). It should be set to the nominal current, which is used to detect the end of charge while in the charge CV region. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 250 | 2mA to<br>131070mA | | VCHG_CV_SET,<br>0x1504 | Sets the nominal charge constant voltage (i.e. VCHG_CV). This value should be set to the nominal voltage, which is applied to the battery pack by the external charger during CV charge. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mV | 41500mV | 0mV to<br>131070mV | | VCHG_CV_<br>MRGN,<br>0x1506 | Sets the charge constant voltage (i.e. VCHG_CV) margin. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 2mV | 50mV | 0 to 510mV | | FULL_RTIME_<br>FILTER,<br>0x150A | Sets the filter time constant for the remaining time-to-full (i.e. FULL_RTIME). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 1s | 10s | 0s to 255s | | ICHG_CC_<br>LRN_RNG,<br>0x1600 | If ICHG_CC_LRN_EN is enabled, these bits set the charge CC (i.e. ICHG_CC) learning range. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 10% | 0% to 100% | | ICHG_END_<br>LRN_RNG,<br>0x1601 | If ICHG_END_LRN_EN enabled, these bits set the charge termination current (i.e. ICHG_END) learning range. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 10% | 0% to 100% | | VCHG_CV_<br>LRN_RNG,<br>0x1602 | If VCHG_CV_LRN_EN is enabled, these bits set the charge CV (i.e. VCHG_CV) learning range. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 3% | 0% to 100% | | ICHG_LRN_ITH,<br>0x1603 | Sets the charge current threshold for current learnings (i.e. ICHG_END and VCHG_CV). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.01 C-rate | 0.01 C-<br>rate | 0 C-rate to<br>2.55 C-rate | | ICHG_CC_<br>LRN_DITH,<br>0x1604 | Sets the charge current derivative threshold for charge CC learning (i.e. ICHG_CC). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.01mA/s | 0.1mA/s | 0mA/s to<br>2.55mA/s | | VCHG_LRN_<br>DVTH,<br>0x1605 | Sets the charge voltage derivative threshold for charge CV learning (i.e. VCHG_CV and ICHG_END). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.01mV/s | 0.1mV/s | 0mV/s to<br>2.55mV/s | | IDIS_END_<br>LRN_RNG,<br>0x1700 | If IDIS_END_LRN_EN is enabled, these bits set the discharge termination current (i.e. IDIS_END) learning range. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 10% | 0% to 100% | | IDIS_END_<br>LRN_SOCTH,<br>0x1701 | If IDIS_END_LRN_EN is enabled, these bits set the SOC discharge termination current (i.e. IDIS_END) learning threshold. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 50% | 0% to 100% | | IDIS_END_<br>LRN_KPEAK,<br>0x1702 | If IDIS_END_LRN_EN is enabled, these bits set the discharge termination current (i.e. IDIS_END) learning peak current gain. | 7, [6:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 70% | 0% to 100% | | IDIS_<br>LRN_ITH,<br>0x1703 | Sets the discharge termination current threshold for learnings (i.e. IDIS_AVG, IDIS_END). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.01 C-rate | 0.05<br>C-rate | 0 C-rate to<br>2.55 C-rate | | IDIS_END_<br>LRN_FILTER,<br>0x1704 | Sets the filter time constant for discharge current learnings (i.e. IDIS_AVG and IDIS_END). | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 1s | 10s | 0s to 255s | | SOH_LRN_K,<br>0x1800 | If SOH_LRN_EN is enabled, these bits set the SOH learning gain. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.001 | 0.1s | 0s to<br>0.255s | |-----------------------------|-----------------------------------------------------------------------------------|----------|-----|----------------------------------------------|------|---------------------| | SOH_LRN_<br>DMAX,<br>0x1801 | If SOH_LRN_EN is enabled, these bits set the maximum increase for SOH learning. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.1% | 1% | 0% to<br>25.5% | | SOH_LRN_<br>DMIN,<br>0x1802 | If SOH_LRN_EN is enabled, these bits set the maximum decrease for SOH learning. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.1% | 1% | 0% to<br>25.5% | | SOH_LRN_<br>MAX,<br>0x1803 | If SOH_LRN_EN is enabled, these bits set the maximum value for SOH learning. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 110% | 100% to 200% | | SOH_LRN_MIN,<br>0x1804 | If SOH_LRN_EN is enabled, these bits set the minimum value for SOH learning. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 1% | 80% | 0% to 100% | | SOH_LRN_<br>TMAX,<br>0x1805 | If SOH_LRN_EN is enabled, these bits set the maximum temperature for SOH learning | 8, [7:0] | R/W | 8-bit signed, 2-comp<br>integer<br>LSB = 1°C | 30°C | -128°C to<br>+127°C | | SOH_LRN_<br>TMIN,<br>0x1806 | If SOH_LRN_EN is enabled, these bits set the minimum temperature for SOH learning | 8, [7:0] | R/W | 8-bit signed, 2-comp<br>integer<br>LSB = 1°C | 10°C | -128°C to<br>+127°C | ## **Fuel Gauge Model** | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |------------------------------|---------------------------------------------------------------------------------------------|-------------------------|------|---------------------------------------|--------------------------|---------------------| | CELL_MFR,<br>0x2000 | Sets the cell manufacturer. | 128, [127:0] | R/W | ASCII character(s) | Default | - | | CELL_<br>TYPE,<br>0x2010 | Sets the cell type model. | 128, [127:0] | R/W | ASCII character(s) | Default | - | | MDL_<br>QNOM,<br>0x2036 | Sets the nominal capacity of the cell, which is reported by the manufacturer. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 5mAh | 2500mAh | 1mAh to<br>65535mAh | | MDL_QMEAS,<br>0x2038 | Sets the capacity measured in the cell characterization test. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 1mAh | 2437mAh | 1mAh to<br>65535mAh | | CELL_ICHG_<br>MAX,<br>0x203E | Sets the maximum charge current that the cell can handle, according to the manufacturer. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 4000 | 0mA to<br>131070mA | | CELL_IDIS_<br>MAX,<br>0x2040 | Sets the maximum discharge current that the cell can handle, according to the manufacturer. | 16, [15:0] | R/W | 16-bit unsigned integer<br>LSB = 2mA | 20000 | 0mA to<br>131070mA | | CELL_<br>TMIN,<br>0x2042 | Sets the minimum temperature that the cell can handle, according to the manufacturer. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.5°C | 0°C | -128°C to<br>+127°C | | CELL_<br>TMAX,<br>0x2043 | Sets the maximum temperature that the cell can handle, according to the manufacturer. | 8, [7:0] | R/W | 8-bit unsigned integer<br>LSB = 0.5°C | 50°C | -128°C to<br>+127°C | # I<sup>2</sup>C Settings | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------|--------------------------------|--------------------------|----------| | I2C_ADDRESS,<br>0x4100 | Selects the slave I <sup>2</sup> C address of the device. | 7, [6:0] | R/W | 8-bit unsigned integer LSB = 1 | 8 | 0 to 127 | | I2C_CRC_EN,<br>0x4100 | 1: Enable CRC for I <sup>2</sup> C communication. Only write commands with the correct CRC are accepted. The response after a read command includes the 4 CRC bytes at the end 0: Disable CRC for I <sup>2</sup> C communication. Write commands with no CRC bytes (or with the correct CRC) are accepted. The response after a read command does not include the 4 CRC bytes | 1, [7] | R/W | Control Enable = 1 Disable = 0 | 1 | 0 to 1 | ## **Firmware Version** | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------|-----------------------|--------------------------|-------| | IC_VER,<br>0x6100 | Returns the IC version. 42790: 2 to 16 cells in series with LED support 42792: 2 to 16 cells in series cells 42795: 2 to 10 cells with LED support 42797: 2S to 10 in series cells 42791: 2 to 16 cells in series with resistance detection and a thermal model | 40, [39:0] | Read-only | ASCII<br>character(s) | 42797 | - | ## **Commands** | Name, Address | Description | Bit Length,<br>Position | Туре | Encoding | Decoded<br>Default Value | Range | |------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------|-------------------------------------------|--------------------------|----------| | RST_CMD,<br>0x7FFF | Resets the fuel gauge calculations. 0x01: Reset the fuel gauge. This is a self-clearing function | 8, [7:0] | Write-only | Active high command 1 = execute LSB = 1 | 0 | 0 to 255 | | EXE_CMD,<br>0x7FFE | Triggers the fuel gauge calculations. The system MCU is responsible for periodically writing this register to trigger an SOC update. This function should be triggered after providing all the updated voltage and current readings that are used to produce the updated SOC estimate. Ox01: Trigger a fuel gauge update refresh | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | | EDIT_CONFIG_<br>CMD,<br>0x7FFD | 0x01: The fuel gauge settings can be edited | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | | END_EDIT_<br>CONFIG_CMD,<br>0x7FFC | 0x01: The fuel gauge settings cannot be edited | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | # MPF42797 - 2 TO 10 STACKED CELLS BATTERY PACK FUEL GAUGE | CONFIG_<br>MODE_CMD,<br>0x7FFB | Directs the fuel gauge to enter configuration mode (cell profile, battery pack, and algorithm tuning). 0x01: Enter configuration mode | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|-------------------------------------------|---|----------| | CONFIG_EXIT_<br>CMD,<br>0x7FFA | Directs the fuel gauge to exit configuration mode (saves configuration values to flash) and reset. If not in configuration mode, the device stores the fuel gauge settings from the volatile memory to the NVM. Ox01: Exit configuration mode. The new configuration is stored in the NVM | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | | CONFIG_<br>RST_CMD,<br>0x7FF9 | The configuration values are re-initialized to the default values and the fuel gauge calculations are reset. 0x01: Reset the configuration. This is a self-clearing function | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | | LOG_RST_<br>CMD,<br>0x7FF8 | Re-initializes lifetime logging. 0x01: Re-initialize the lifetime log registers. This is a self-clearing function | 8, [7:0] | Write-only | Active high command 1 = Execute LSB = 1 | 0 | 0 to 255 | ## APPLICATION INFORMATION ## **Core Algorithm** The fuel gauge core algorithm accurately estimates core cell-level and pack-level parameters. These core parameters can be found in the Fuel Gauge Output register map. #### Cell Mathematical Model Cell dynamics are influenced by multiple factors, such as chemistry, SOC, current, and temperature. A mathematical model that captures the cell's most important dynamics is required to accurately measure internal variables. Cell mathematical models are provided by MPS. These models are either from a database or they are a result of the cell characterization routine. ## Cell State-of-Charge (SOC) Cell SOC refers to the cell capacity that is currently available, as a function of the rated capacity. SOC is an unknown, internal variable that cannot be directly measured, meaning it estimated be using available must measurements. The MPF42797 uses voltage, current, and temperature measurements observed over time to produce accurate SOC estimates across a wide range of operating conditions. ## Empty State-of-Charge (SOC) Empty SOC refers to the SOC level at which the battery pack is unable to discharge further without reaching the voltage cutoff limits. The empty SOC prediction relies on the operating conditions of the different cells, as well as the discharge current supplied to the load, which is specific to each application. In addition, the MPF42797 can predict whether the battery pack discharge is limited by the pack or one of the cells (the cell ID is provided). This is extremely important for accurate empty SOC estimation in unbalanced packs, since the fuel gauge must track the condition that limits the battery pack discharge. #### Full State-of-Charge (SOC) Full SOC refers to the SOC level at which the battery pack is unable to charge further without leaving the safe operating area (SOA). The full SOC prediction relies on the operating conditions of the different cells, as well as the constant-current/constant-voltage (CC/CV) charging sequence, which is specific to each application. The MPF42797 can predict whether the battery pack charge is limited by the pack or one of the cells (the cell ID is provided). This is extremely important for accurate full SOC estimation in unbalanced packs, since the fuel gauge must track the condition that limits the battery pack charge. ## Pack State-of-Charge (SOC) Pack SOC provides the capacity, which is a function of the available capacity given the actual pack operating conditions. Pack SOC relies on cell-level quantities and tracks the remaining capacity that the battery can charge or discharge without reaching the cutoff limits. Pack SOC can be considered the most vital estimate since it is typically the value shown to the application end user. ## Pack Unavailable State-of-Charge (SOC) Pack unavailable SOC refers to the capacity that is not available due to the actual pack operating conditions (e.g. mismatched cells and battery pack configurations). Pack unavailable SOC provides the capacity that the battery cannot use without violating the defined SOA. #### **Indicators** In addition to the core parameters, an extensive set of fuel gauge indicators are provided, based on the internal battery estimates. These indicators can be found in the Fuel Gauge Output register map. ## Remaining Time-to-Empty Remaining time-to-empty (EMTY\_RTIME) refers to how much time is left until the battery pack reaches the empty state while assuming the application-specific discharge current. This estimate informs the user of the remaining runtime until the pack reaches 0% SOC. ## Remaining Time-to-Full Remaining time-to-full (FULL\_RTIME) refers to how much time is left until the battery pack reaches the cutoff limits using the applicationspecific charge parameters (i.e. the CC and CV levels). This estimate informs the user of the remaining charge time until the pack reaches 100% SOC. ## Maximum Discharge Power The maximum discharge power (PDIS) refers to how much power the pack can deliver to the load without reaching the pack empty levels and leaving the SOA. The MPF42797 can predict whether the limiting factor under the maximum discharge power is caused by the pack or one of the cells (the cell ID is provided). ## Maximum Charge Power The maximum charge power (PCHG) refers to how much power the pack can accept for charging without breaching the cutoff limits. The MPF42797 can predict whether the limiting factor under the maximum charge power is caused by the pack or one of the cells (the cell ID is provided). #### Learnings Fuel gauge learnings are responsible for automatically fine-tuning the algorithm and tracking aging to keep estimates accurate across the device's lifetime. #### Charge Constant Current (CC) The charge CC learning (ICHG\_CC\_LRN) feature refines the initial charge CC value defined by the user. This smart adjustment compensates for when the charge CC deviates from its nominal settings, such as when there are production tolerances to the charging system. This feature minimizes the need for tuning while maintaining optimal SOC accuracy. The learning can be completed and leveraged within the same charge cycle. #### **Charge Termination Current** The charge termination current learning (ICHG\_END\_LRN) feature refines the initial charge termination current value defined by the user. This smart adjustment compensates for when the charge termination current deviates from its nominal settings, such as when there are production tolerances to the charging system. Charge termination current smart adjustments are applied in subsequent charge cycles following the cycle in which the learning occurred. #### Charge Constant Voltage (CV) The charge CV learning (VCHG\_CV\_LRN) feature refines the initial charge CV value defined by the user. This smart adjustment compensates for when the charge CV deviates from its nominal settings, such as production tolerances to the charging system. Charge CV smart adjustments are applied in subsequent charge cycles following the cycle in which the learning occurred. ## Discharge Average Current The discharge average current learning (IDIS\_AVG\_LRN) feature calculates the load average discharge current to accurately provide the time-to-empty estimate. ## **Discharge Termination Current** The discharge termination current learning (IDIS\_END\_LRN) feature refines the initial discharge termination current value defined by the user. This value adapts to load dynamics and keeps the SOC accurate with minimal user tuning. In addition, this feature includes two different operation modes depending on the application continuous requirements: and past-cycle learning. In continuous learning mode, the discharge termination current updates continuously while the pack discharges to accurately determine the empty SOC. Past-cycle learning uses the previous discharge cycle data to learn. Continuous learning is recommended for unpredictable discharge termination currents, whereas past-cycle learning is recommended for consistent discharge termination currents. #### State-of-Health (SOH) As battery cells age, their total capacity decreases due to unwanted side reactions and structural deterioration (often referred to as capacity fading). Up-to-date state-of-health (SOH) information is important since it has a major impact on the battery pack's available energy. The MPF42797 incorporates an SOH learning (SOH\_LRN) feature that can track individual cells' capacities (SOH\_CELLx) with respect to their nominal capacity. This feature can identify cells that are negatively impacting the overall pack performance. #### **Lifetime Log** Important events and certain conditions are reported in the lifetime log to gain insight on how the battery pack has been operating. The MPF42797 backs the relevant registers up to its non-volatile memory (NVM) every time the part enters disabled mode (or for each elapsed hour). ## **Count Log** The count log is the number of times the pack has been charged from below 15% to above 85%. The number of times the pack has been charged by 10% and the number of shutdowns are also reported in the lifetime log. Full shutdowns and entering disabled mode are considered shutdowns, and increase the counter. #### **Current Log** The current log is the maximum charge and discharge current that has been applied to the pack. It is reported in the lifetime log. #### Voltage Log The voltage log tracks the maximum and minimum voltage for each cell. This is reported in the lifetime log. In addition, the maximum cell voltage difference between two cells is also reported, as well as their corresponding cell IDs. #### Temperature Log The temperature log tracks the maximum and minimum temperature sensed on the pack. It also reports the maximum temperature difference between two sensors, and their corresponding temperature sensor IDs. The lifetime log details how much time the pack has operated under different temperature ranges. ## **Balancing Log** The balancing log tracks the number of times each cell has been balanced. ## **PCB Layout Guidelines** Place the bypass capacitor between each pair of VDD and GND pins, and as close as possible to the pin. # **TYPICAL APPLICATION CIRCUIT** **Figure 12: Typical Application Circuit** # **PACKAGE INFORMATION** # TQFN-32 (4mmx4mm) **TOP VIEW** **BOTTOM VIEW** #### SIDE VIEW #### **RECOMMENDED LAND PATTERN** ## NOTE: - 1) ALL DIMENSIONS ARE IN MILLIMETERS. - 2) EXPOSED PADDLE SIZE DOES NOT INCLUDE MOLD FLASH. - 3) LEAD COPLANARITY SHALL BE 0.08 MILLIMETERS MAX. - 4) JEDEC REFERENCE IS MO-220. - 5) 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 | |---------------------------|------------------------|-------------------|-------------------|-------------------|------------------|--------------------------|--------------------------| | MPF42797DRT-<br>0B-yyyy-Z | TQFN-32<br>(4mmx4mm) | 5000 | N/A | N/A | 13in | 12mm | 8mm | # **REVISION HISTORY** | Revision # | Revision Date | Description | Pages Updated | |------------|---------------|-----------------|---------------| | 1.0 | 9/7/2022 | 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.