<span id="page-0-0"></span>

### Current, Voltage, and Charge Monitor for High Voltage Battery Packs

- Measures Battery Stack Voltage, Current and Power
- $\blacksquare$  Indicates Accumulated Battery Charge and Energy
- 20-Bit Current Measurement with <1µV Offset
- Built-In Isolated isoSPI<sup>™</sup> or SPI Interface
- <sup>n</sup> **LTC68xx/ADBMS68xx Compatible, Supports Synchronous Measurements with Cell Monitors**
- Up to 12 Buffered Voltage Measurement Inputs
- Up to 5 GPIOs, Configurable to Drive Ground, Supply or Toggling at 400kHz
- High or Low Side Current Sense
- 0.3% Current and Voltage Accuracy
- 1% Energy and Charge Accuracy
- True Average ADCs
- <sup>n</sup> I 2C EEPROM Interface to Store Board Calibration Factors
- Threshold Registers for all Measured Quantities
- Engineered for ISO26262 Compliant Systems
- Open Wire Detection on Input Pins
- Available in 48-Lead LQFP Package
- AEC-Q100 Qualified for Automotive Applications

# **APPLICATIONS**

- $\blacksquare$  Electric and Hybrid Vehicles
- Isolated Current Sensing
- Backup Battery Systems
- High Power Portable Equipment

All registered trademarks and trademarks are the property of their respective owners.

# FEATURES DESCRIPTION

The [LTC®2949](https://www.analog.com/LTC2949?doc=LTC2949.pdf) is a high precision current, voltage, temperature, charge and energy meter for electrical and hybrid vehicles and other isolated current sense applications. It infers charge and energy flowing in and out of the battery pack by monitoring simultaneously the voltage drop over up to two sense resistors and the battery pack voltage.

Low offset ΔΣ ADCs ensure accurate measurement of voltage and current with insignificant power loss. Continuous integration of current and power ensures lossless tracking of charge and energy delivered or received by the battery pack.

The built-in serial interface can be configured to support isolated isoSPI communication to the host or as SPI interface.

The LTC2949 features 12 internally buffered high impedance inputs (V1 to V12) for measuring voltages from external sensors or resistor dividers allowing to measure temperatures, HV-Link voltages, chassis isolation and supervise contactor states. LTC2949 has up to five programmable digital outputs which can be set to ground, supply or toggling at 400kHz.

Programmable threshold and tracking registers reduce digital traffic to the host.



# TYPICAL APPLICATION

1

# **TABLE OF CONTENTS**



# <span id="page-2-0"></span>ABSOLUTE MAXIMUM RATINGS PIN CONFIGURATION

#### **(Notes 1, 2)**





# ORDER INFORMATION

#### **AUTOMOTIVE PRODUCTS\*\***



Contact the factory for parts specified with wider operating temperature ranges. \*The temperature grade is identified by a label on the shipping container. [Tape and reel specifications](https://www.analog.com/media/en/package-pcb-resources/package/tape-reel-rev-n.pdf). Some packages are available in 500 unit reels through designated sales channels with #TRMPBF suffix.

\*\*Versions of this part are available with controlled manufacturing to support the quality and reliability requirements of automotive applications. These models are designated with a #3ZZ suffix. Only the automotive grade products shown are available for use in automotive applications. Contact your local Analog Devices account representative for specific product ordering information and to obtain the specific Automotive Reliability reports for these models.

<span id="page-3-1"></span><span id="page-3-0"></span>**temperature range, otherwise specifications are at TA = 25°C.**



Rev A

**temperature range, otherwise specifications are at TA = 25°C.**



5

**temperature range, otherwise specifications are at TA = 25°C.**



Rev A

**temperature range, otherwise specifications are at TA = 25°C.**



7

**temperature range, otherwise specifications are at TA = 25°C.**



Rev A

**temperature range, otherwise specifications are at TA = 25°C.**





**Note 1:** Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. Exposure to any Absolute Maximum Rating condition for extended periods may affect the device reliability and lifetime.

**Note 2:** Positive currents flow into pins, negative currents flow out of pins. Minimum and maximum values refer to absolute values.

**Note 3:** Do not apply a voltage or current source to these pins. They must be unconnected, connected to capacitive loads or connected to a crystal according to their pin description. Otherwise permanent damage may occur.

**Note 4:** Do not apply a voltage source to these pins. Overloading these pins might disrupt operation.

**Note 5:** Active supply current (I<sub>CC</sub>) is dependent on the amount of time that the output drivers are active on IP and IM. During those times  $I_{CC}$  will increase by the 20 $\cdot$  I<sub>B</sub> drive current. For the maximum data rate 1MHz, the drivers are active approximately 5% of the time.

**Note 6:** These timing specifications are dependent on the delay through the cable, and include allowances for 50ns of delay each direction. 50ns corresponds to 10m of CAT-5 cable (which has a velocity of propagation of 66% the speed of light). Use of longer cables would require derating these specs by the amount of additional delay.

**Note 7:** Guaranteed by design and characterization, not subject to production test.

**Note 8:**  $C_B$  = capacitance of one bus line in pf (10pF <  $C_B$  < 400pF) **Note 9:** These specifications do not include rise time of SDO due to pull up resistance and load capacitance on SDO pin.

**Note 10:** Cycle time at which STATUS/FAULTS and V<sub>REF</sub> registers are updated.

**Note 11:** Cycle time at which STATUS/ALERT/FAULTS registers and all slow channel measurement results are updated after the first update. The first update after enabling any measurement is typically 50ms delayed.

# <span id="page-9-0"></span>TYPICAL PERFORMANCE CHARACTERISTICS



# <span id="page-10-0"></span>TYPICAL PERFORMANCE CHARACTERISTICS



# PIN FUNCTIONS

**AVCC (Pin 19):** Analog Supply Voltage. Bypass this pin to AGND with a 0.1μF (or greater) capacitor. AVCC operating range is 4.5V to 14V.

**AGND (Pin 18):** Analog Ground. Bypass this pin to AVCC with a 0.1μF (or greater) capacitor.

**BYP1 (Pin 16):** Internal Supply Voltage. Bypass BYP1 to DGND with a 1μF capacitor. BYP1 is regulated to 2.5V. Can supply external circuitry (example EEPROM) with up to 10mA. Overloading might disrupt LTC2949 functionality. **BYP2 (Pin 25):** Internal 3.25V Supply Voltage. Bypass BYP2 to DGND with a 1µF capacitor. Can supply external circuitry (example SPI isolator ADuM141E or ADuM4154) with up to 10mA. Overloading might disrupt LTC2949 functionality.

**CF1P, CF1M (Pins 44, 43):** Filter Capacitor Inputs for the first current channel. Connect a 1µF capacitor between CF1P and CF1M for filtering differential noise and fast current variations. Connect 0.1µF capacitors between AGND and the filter pins for damping high frequency common mode variations.

# <span id="page-11-0"></span>PIN FUNCTIONS

**CF2P, CF2M (Pins 39, 40):** Filter Capacitor Inputs for the second current channel. Connect a 1µF capacitor between CFI2P and CFI2M for filtering differential noise and fast current variations. Connect 0.1µF capacitors between AGND and the filter pins for damping high frequency common mode variations.

**CLKI (Pin 33):** Clock Input. Connect to ground if internal clock is used. For improved measurement accuracy, connect a 4MHz crystal between CLKI and CLKO and matching capacitors to ground, or drive with an external clock. See the [Timebase Control](#page-19-1) section.

**CLKO (Pin 34):** Clock Output. Connect a 4MHz crystal between CLKO and CLKI if used; leave pin unconnected otherwise.

**CSB/IM (Pin 30):** Active Low Chip Select in SPI mode or Isolated Interface Negative Input/Output in isoSPI mode.

**DGND (Pin 17):** Digital Ground. Connect to AGND.

**DNC (Pins 6, 21, 22, 23, 24, 31, 32, 36, 37, 46):** Do not connect.

**DVCC (Pin 20):** Supply Voltage. Bypass this pin to DGND with a 1μF capacitor. Operating range is 4.5V to 14V.

**I1P, I1M (Pins 45, 42):** Differential Input of I1ADC and overcurrent comparator 1. Tie to AGND if unused.

**I2P, I2M (Pins 38, 41):** Differential Input of I2ADC and overcurrent comparator 2. Tie to AGND if unused.

**IOVCC (Pin 26):** Serial Interface Configuration and Supply Pin. Tie pin to DGND for isoSPI communication. Tie pin to a voltage  $\geq 1.8V$  and  $\leq 4.5V$  and bypass with 1uF to DGND for standard SPI communication. In SPI mode IOVCC supplies the digital input and output circuits of the serial interface.

**SCK/IP (Pin 29):** Serial Clock Input in SPI mode or Isolated Interface Positive Input/Output in isoSPI mode.

**SCL (Pin 14):** I<sup>2</sup>C Master Clock Open Drain Output. Connect to clock input of EEPROM.

**SDA (Pin 15):** I<sup>2</sup>C Data Input And Open Drain Output. Connect to data line of EEPROM. SDA driven low at power up prevents LTC2949 to go automatically into SLEEP state and to execute HW memory BIST. Connect a 4.7k-10k pull-up resistor from SDA to BYP1 to ensure correct operation of auto-sleep and memory BIST.

**SDI/ICMP (Pin 27):** Serial Data Input in SPI mode or Isolated Interface Comparator Voltage Threshold in isoSPI mode. Tie ICMP to the resistor divider between IBIAS and DGND to set the voltage threshold of the isoSPI receiver comparators. The comparator thresholds are set to 1/2 the voltage on the ICMP pin.

**SDO/IBIAS (Pin 28):** Open Drain Serial Data Output in SPI mode or Isolated Interface Current Bias in isoSPI mode. In SPI mode tie with a pullup resistor to IOVCC. In isoSPI mode tie IBIAS to DGND through a resistor divider to set the interface output current level. When the isoSPI interface is enabled, the IBIAS pin voltage is regulated to 2V. The IP/IM output current drive is set to 20 times the current IB, sourced from the IBIAS pin.

**V1, V2, V3, V4, V5, V6, V7 (Pins 1, 2, 3, 4, 5, 7, 8):** Voltage Measurement Inputs. Pins are internally buffered before being applied to the AUXADC for ensuring high input impedance (50MΩ) and low leakage. Can be left floating if unused.

**V8-V12/GPIO1-GPIO5 (Pins 9, 10, 11, 12, 13):** General Purpose Voltage In– and Digital Outputs. Pins are internally buffered before being applied to the AUXADC for ensuring high input impedance (50M $\Omega$ ) and low leakage (<10nA). Each pin can be switched to DVCC, switched to DGND or to toggle at 400kHz (typ.) between DVCC and DGND. Pins are tri-state in sleep mode. Can be left floating if unused.

**VBATP VBATM (Pins 48, 47):** Battery Voltage Measurement. The differential voltage between VBATP and VBATM is internally buffered for ensuring high input impedance (50M $\Omega$ ) and low leakage (<10nA).

**VREF (Pin 35):** Reference Voltage Output. VREF provides a buffered 3V reference voltage for temperature measurements with NTCs. Current load is limited to 0.5mA. Bypass this pin to AGND with a 1μF capacitor.

**EXPOSED PAD (Pin 49):** Connect to AGND.

# <span id="page-12-0"></span>BLOCK DIAGRAM



\* Measured value not accessible by user. Only used for internal diagnostics.

\*\* VREF measurement value is only accessible by user from the AUX slow channel.

See also section 'Unused Input Pins V1-V12' for recommendation to allow VREF measurement from AUX fast channel.

See also 'Table 57. MUX Settings' for more details on AUX MUX configuration.

Rev A

### <span id="page-13-0"></span>**OVERVIEW**

The LTC2949 is a high precision current, voltage, charge and energy meter for electrical and hybrid vehicles or other applications requiring isolated data acquisition. Operating from supply voltages from 4.5 to 14V, it infers charge and energy flowing in and out of the battery pack by monitoring simultaneously the current through up to two sense resistors and the battery pack voltage. Five railto-rail low-offset ΔΣ ADCs ensure accurate measurement of currents, voltage and power with insignificant power loss. The LTC2949 uses instantaneous multiplication of voltage and current at a high sampling rate to infer accurately power even in presence of fast load variations. Additionally to the inputs for measuring currents and battery voltage, the LTC2949 features 12 analog input pins (V1 to V12) for measuring external voltages. Using its built-in multiplexer, the LTC2949 performs differential high input impedance rail-to-rail voltage measurements between any pair of input pins. Pins V8 to V12 can be configured as high voltage digital outputs, swinging from ground to digital supply voltage (DVCC) for controlling external components such as high voltage transistors. One automatic measurement cycle of current, voltage, power, temperature, supply voltage and two programmable multiplexer settings takes 100ms in slow mode. The LTC2949 repeatedly performs such measurements and recalculates energy, charge, time and updates the minimum/maximum tracking and threshold registers, resulting in continuous integration of current and power with lossless tracking of charge and energy delivered or received by the battery pack. An on-chip oscillator provides a 1% precise time base for calculating total charge, energy and time. If higher accuracy is required, a 4MHz crystal connected between pin CLKI and CLKO or an external clock can be used.

For time critical applications, a fast mode is available which reduces conversion times to 782µs. Data acquired during fast operation is stored in four FIFOs which contain each up to 1000 fast ADC readings from 4 synchronously measured parameters. Reading data from the FIFO yields simultaneously converted conversion results, enabling battery impedance tracking, current profiling or monitoring of other fast events, such as the pre-charging voltage before closing contactors. Thresholds can be set for parameters

measured in slow mode, and the LTC2949 will set the corresponding bit in the Alert Register if a threshold is exceeded. Programmable heartbeat functions on up to two GPIOs allow to signal any enabled alert over an isolation barrier, independent of the serial interface. Those pins toggle at 400kHz and stop toggling in case of an alert.

The LTC2949 features a programmable analog overcurrent comparator for each current channel for applications which require fast detection of overcurrent conditions. A programmable deglitch filter allows to discard overcurrent conditions shorter than a predefined time duration\*.

A 3V reference voltage output (VREF) is provided for connecting external NTCs or voltage dividers allowing to measure signals below ground. In slow mode, the LTC2949 provides means for linearizing temperature readings of up to two external NTCs by solving Steinhart-Hart equations with programmable coefficients. The LTC2949 can be configured to automatically compensate user-programmed temperature coefficients of low-cost shunt resistors by using linearized NTC temperature readings.

The LTC2949 features programmable gain correction factors to compensate for tolerances of external shunt resistors and resistor dividers. A master I2C interface and dedicated commands allow to read from and write to an external EEPROM which can be used for storing calibration factors and the entire register content of the LTC2949 to guarantee data retention without supply. Storing correction factors in an EEPROM enables a modular approach to factory-calibration of application boards.

A thermal shutdown circuit trips at die temperatures above 150°C and resets the IC to default state, only the thermal shutdown bit itself is not reset.

Measured quantities are stored in internal registers accessible via the onboard SPI or LTC-proprietary isoSPI interface which allows fully isolated operation of the LTC2949. The LTC2949 was developed for compatibility with Linear's Multicell Battery Monitors (LTC68XX). Various bus structures in either SPI or isoSPI, multi-drop and/or daisy chaining are possible. The LTC2949 supports a limited set of Linear's Battery Cell Monitor compatible commands for triggering synchronous ADC conversions and reading back data.

\*An overcurrent condition is signaled by a dedicated heartbeat pin for fastest response times.

<span id="page-14-0"></span>Digital data acquired in isolated operation is transferred over external capacitors or transformers across an isolation barrier. Bridging potential differences of several kV is achieved by choosing appropriate external components.

All those features enable a wide variety of applications beyond current and charge measurement, like measuring isolation resistance, controlling pre-charge switches, signaling alarm conditions, monitoring state of contactors, etc. The LTC2949 offers various diagnosis functions to support functional safety critical systems, see the Safety Manual for more information.

#### **MODES OF OPERATION**

#### **Core State Description**

When all power supply voltages have risen above their UVLO thresholds, the LTC2949 boots up, sets all registers to their default state and enters after 1s its default SLEEP state with a current consumption of 9µA (typ), preventing rapid discharge after insertion when being supplied by a battery.

In SLEEP state, all GPIOs are tri-state and the LTC2949 monitors the serial interface and initiates the boot sequence on a falling edge of CSB in SPI mode. In isoSPI mode the isoSPI interface must first be woken up by a wake-up pulse before a pulse generating a negative edge on the internal CSB can be sent. During the boot sequence, the host can poll the SLEEP bit in the Operation Control Register to check that the LTC2949 is awake and in STANDBY mode (see also [Figure 20](#page-43-1) about Wake-Up and Boot procedure). LTC2949 enters STANDBY state maximum 100ms ( $t_{\text{BODT}}$ ) after the first falling edge of CSB. In STANDBY state all reference voltages are powered up and a clock is provided to digital circuits. The LTC2949 automatically returns to SLEEP state if no wake up confirmation command is received within 1 second  $(t_{ACKN})$  after entering STANDBY state. Wake up is confirmed by writing 0x00 to register WKUPACK.

The LTC2949 enters SLEEP state  $\sim$ 200ms (t<sub>SLEEP</sub>) after receiving a sleep command. A negative edge on CSB during



**Figure 1. LTC2949 Operation State Diagram**

 $t_{\rm SI}$   $_{\rm FFP}$  will prevent the LTC2949 from entering SLEEP state. In SLEEP, internal analog supplies and BYP1 are switched off, causing the UVLOA and UVLOD bits to be set when the LTC2949 resumes from SLEEP. An internal always-on regulated voltage supplies the memory and guarantees data retention during SLEEP. If AVCC or DVCC drop below the UVLO threshold, the UVLO bit of the internal always-on supply UVLOSTBY is set and a power-on-reset occurs, resetting all registers to their default value. In STANDBY state, all internal circuitry is active but no measurements except the reference voltage (VREF) are being made. From STANDBY, the LTC2949 can be instructed to go into MEASURE state by setting the single shot (SSHOT) or continuous (CONT) bit in the Operations Control Register OPCTRL.

#### <span id="page-14-1"></span>**isoSPI State Description**

If the IOVCC pin is tied to a supply voltage  $\geq 1.8$ V, the LTC2949 operates in normal SPI mode and IOVCC supplies the receiving circuit and output driving circuit for all SPI signals.

Tying IOVCC to DGND enables the isoSPI port. The isoSPI port has three different states: IDLE, READY and ACTIVE. In IDLE state, the isoSPI port is powered down. Only

<span id="page-15-0"></span>differential activity on IP-IM generates a wake-up signal and the isoSPI port will enter READY state after  $t_{\text{REAPV}}$ (10µs) and be ready to send or receive data. The current consumption increases by several mA in READY. When communication takes place the isoSPI port is in ACTIVE state and supply current rises further depending on clock frequency. In order to save power the isoSPI port enters IDLE state when there has been no differential activity on IP-IM for more than  $t_{\text{IDIF}}$  (6.4ms typ.). Communication to the LTC2949 core is only possible if the isoSPI port is not in IDLE state. This means that even when the LTC2949 core is in STANDBY or MEASURE state and the isoSPI port is in IDLE state, communication can only take place 10µs  $(t_{\text{RFADV}})$  after differential activity on IP-IM.

[Figure 2](#page-15-2) displays the sequence of states which the isoSPI interface and the LTC2949 core go through from waking up the interface until effectuating ADC measurements. See also [Figure 20](#page-43-1) for recommended wake-up sequence implementations.

### **DATA ACQUISITION CHANNELS**

The LT2949 has two current ADCs (I1ADC, I2ADC), two power ADCs (P1ADC, P2ADC) and one Auxiliary ADC (AUXADC). I1ADC and P1ADC are grouped together and form data acquisition channel 1 (CH1), I2ADC and P2ADC form channel 2 (CH2) and the AUXADC together with auxiliary multiplexer (AUXMUX), die-temperature sensor and supply voltage sensor form channel AUX (CHAUX).



<span id="page-15-2"></span>**Figure 2. isoSPI State Diagram**

CH1 and CH2 can be individually set to an 18-bit high precision mode (slow mode, default) or a 15-bit fast mode. Activating fast mode reduces conversion times from 100ms to 782µs on the selected channel. The power ADCs can be individually configured as voltage ADCs by disabling the power multiplication after the input buffers by setting the corresponding Power as Voltage (PasV) bit in ADC Configuration Register (ADCCONF).

#### **Slow, High Precision Mode**

By default, LTC2949's acquisition channels are in slow high precision mode where conversions of CH1 or CH2 take 100ms and yield 18-bit conversion results of current and power or current and voltage, if PasV set. During these 100ms the auxiliary channel (CHAUX) measures



<span id="page-15-1"></span>**Figure 3. Timing of IsoSPI and Core States**

sequentially six different quantities using its Round Robin (RR) mode starting with VBATP – VBATM (BAT) then dietemperature (TEMP), AVCC supply voltage (VCC), two AUXMUX inputs (SLOT1 and SLOT2), selectable by the Multiplexer Setting Registers and finally the Reference Voltage (VREF). Furthermore, a moving average of the last four measurements of IADC1 and IADC2 in slow mode is provided, yielding a 20-bit result. In slow, high precision mode a single conversion or continuous conversions can be triggered. The continuous slow mode (CONT) is the most typical operation and also the prerequisite to make fast conversions.

### **Single Shot Measurement Mode (SSHOT)**

When bit SSHOT in the Operation Control Register is set, the LTC2949 takes measurements of CH1 and CH2 as well as the six auxiliary channel measurements described above, updates the corresponding minimum, maximum and threshold registers, resets bit SSHOT, sets the bit UPDATE in Status Register and returns to the STANDBY state. No time measurements are made and the charge and energy registers are not updated and therefore not compared against minimum/maximum thresholds. The host can poll the UPDATE bit in the STATUS Register to detect the completion of the measurement cycle. A measurement starts within 20ms ( $t_{\text{IDIF-CORF}}$ ) after setting bit SSHOT.

### **Continuous Measurement Mode (CONT)**

When the bit CONT in the Operation Control is set, the LTC2949 repeatedly takes measurements of CH1 and CH2 as well as the six auxiliary channel measurements, recalculates energy, charge, time and updates the minimum/maximum tracking and status registers every 100ms. The start of continuous high precision measurements can take up to 20ms ( $t_{\text{IDLE-CORF}}$ ) after setting bit CONT. The current and power ADCs run continuously in this mode, ensuring that no charge or energy is missed. If a power ADC is configured to measure voltage (PasV), the energy of the corresponding channel is not accumulated. The LTC2949 remains in continuous mode until bit CONT of the Operation Control Register is reset by the user. If the SSHOT bit is set while in continuous mode, the LTC2949 completes the current measurement cycle and then enters single shot mode, clearing the CONT bit in the Operation Control Register.

In continuous measurement mode, the host can poll for the end of a measurement cycle by periodically checking the corresponding time registers (TB1, TB2, TB3 or TB4) for incrementation.

### **Accessing High Precision Results**

At the end of each measurement cycle of 100ms, all result register for the measured quantities are updated; in continuous mode, accumulated quantities are updated also. Furthermore, the four preceding measurements of each current channel are stored in Current History Registers and their average in Current Average Registers, see the Register Map section for more details. The completion of register updates of the measurement results can be detected by reading one of the time registers (TB1-TB4) and looking for a changed value.

### **Fast Mode**

The LTC2949 provides a fast mode with a reduced conversion time of 782µs and a resolution of 15-bit. Fast mode allows to start measurements at a precise point in time and thereby perform measurements synchronized with the voltage measurements of LTC's Battery Stack Monitors, for example to deduce cell impedance of individual cells.

### **Fast Mode Configurations**

The LTC2949 allows to set data acquisition channel 2 in fast mode while data acquisition channel 1 stays in slow high precision mode or to set both data acquisition channels 1 and 2 in fast mode by setting the corresponding bit FACH1 or FACH2 in the Fast Control Register (FACTRL). The auxiliary channel can be set to fast mode independently of CH1 and CH2, converting only a single quantity (selected by the Fast MUX Control Registers) instead of Round-Robin (RR).

To enable short startup delays, the LTC2949 must be in continuous mode (CONT=1) before triggering fast conversions. Fast measurements are triggered either by an ADCV command (fast single shot) or by setting bit FACONV in the Fast Control Register (FACTRL). The ADCV command triggers a single fast conversion of the selected channels right after the correct PEC is received, synchronous to

LTC's Battery Stack Monitors. If fast measurements are triggered by setting FACONV=1, LTC2949 executes a sequence of fast conversions until FACONV or CONT is reset. Samples acquired during fast continuous mode are stored in individual FIFOs for up to four fast input channels (I1, I2, BAT via P1 or P2 and AUX).

CH1 and CH2 automatically restart in slow high precision mode after completion of joint fast mode conversions. If CH2 was in fast mode while CH1 continued in slow high precision mode, CH2 will stop converting after completion of fast mode acquisitions ready to perform further fast mode conversions when requested either by an ADCV command or by setting FACONV again. The auxiliary channel slow mode Round-Robin (BAT, TEMP, VCC, SLOT1, SLOT2, VREF) is automatically restarted after all fast measurements were stopped for 300 ms. In applications were continuous high AUX measurement rates (faster than every 100ms) are required, it is recommended to measure also VREF and optionally VCC via external connections to V1-V12 and implement a manual Round-Robin by fast single shot measurements in software.

### **Accessing Fast Mode Results**

The last results of fast conversions can be read out by the RDCV command providing sequentially the results of I1, I2, BAT via P1 or P2 and AUX followed by an indicator if the data is new (0xF) or old (0x0). BAT is the result of the power ADC, if the ADC is set in voltage mode (bit PasV=1), otherwise, the power ADC result is 0. If both channels are in fast mode with their power ADCs in voltage mode, BAT is obtained from PADC1. Please note that to be compliant with LTCs Battery Stack Monitors, RDCV reports LSByte first.

Furthermore, the last 1000 fast conversion results of I1, I2, BAT via P1 or P2 and AUX are stored in First-In-First-Out Registers accessible by FIFOI1, FIFOI2, FIFOBAT and FIFOAUX. Reading continuously from FIFOI1 provides successively 3 bytes for each sample of the first current ADC: I1 MSB, I1 LSB and a qualifier (TAG) whether the corresponding FIFO data is fine (0x00), has been already read because no new data has been added to the FIFO since the whole FIFO was read (0x55, default), or has been overwritten because the FIFO was filled without being read (0xAA). The other FIFOs present the respective quantities accordingly. All tags are initialized to their default value (0x55), if fast conversions are triggered by an ADCV command (while FACONV  $= 0$ ) or by setting FACONV. Also leaving the continuous mode by resetting CONT will clear the FIFOs.

The LSB sizes of the fast conversion results are the same for the RDCV and FIFO readings and are listed in [Table 28](#page-46-0).

When CH1 and CH2 are both in fast mode, 128 conversion results of IADC1 and IADC2 are averaged and stored in their respective non-accumulated results registers Current1 and Current2 and are added to the Charge1 and Charge2 registers ensuring that battery charge and discharge is monitored also in fast mode.

Similarly 128 conversion results of PADC1 and PADC2 with 11 bit resolution are averaged and stored in their respective non-accumulated results registers Power1 at and Power2 and are added to the Energy1 and Energy2 registers if the PADCs are in Power Mode (PasV=0). If CH1 is in slow mode and CH2 in fast mode, only CH1 results are reported in the Current and Power results registers, CH2 results can be accessed via RDCV or the respective FIFOs.

#### **Recommended Configurations of Data Acquisition Channels**

In a typical application case, both data acquisition channels offered by LTC2949 could monitor the current over a single shunt resistor, where CH1 is used to do high precision current and power measurements and charge and energy integration, while channel two takes fast snapshots of current and voltage for example for impedance measurement.

Alternatively, the two data acquisition channels offered by LTC2949 might be used to monitor currents over two different shunt resistors. In this application case, both channels might be used in either fast or slow mode. CHAUX can be configured fully independently from CH1 and CH2. The default mode of AUXADC is RR, which is deactivated by enabling fast mode on CHAUX.



#### <span id="page-18-0"></span>**Table 1. Acquisition Channels Configurations**

#### **Single Shunt Configuration**

If only one external shunt is used, CH1 can be used to perform continuous high precision integrated charge and energy measurements, while CH2 is used to perform fast measurements synchronized with LTC's Battery Stack Monitors. By setting bit CONT in the Operation Control Register (OPCTRL) and bit FACH2 in the Fast Control Register (FACTRL), CH1 will effectuate consecutive slow measurements, while CH2 is available for fast measurements triggered by an ADCV command. Measurements of CH1 and its integrated quantities are updated every 100ms while CH2 results can be read out with an RDCV command or obtained from the FIFO registers, in case of fast continuous (FACONV) operation.

#### **Dual Shunt High Precision Configuration**

For dual shunt applications that require continuous uninterrupted high precision coulomb counting and energy measurement CH1 and CH2 should be both configured to slow high precision mode by setting bit CONT in OPCTRL. Conversions on CH1 and CH2 take 100ms and a new RR cycle of CHAUX is started at every start of conversion of CH1.

If fast voltage data is required, the AUXADC can be configured for fast mode without interrupting charge and energy accumulation on CH1 and CH2. After setting bits FACONV and FACHA the AUXADC immediately stops RR mode and continuously measures a single quantity selected by the Fast MUX Control Registers. Data is written to the FIFOAUX. After clearing bit FACHA the AUXADC automatically returns to RR operation (after 300ms). Measurements of VREF, internal die temperature and VCC are only available if RR is enabled. Alternatively, external connections to V1-V12 can be applied to measure VREF and VCC (via an external resistive divider) also in fast mode.

#### **Dual Shunt Fast Measurement Configuration**

CH1 and CH2 are both set to fast mode by setting bits FACONV, FACH1 and FACH2. Charge is accumulated by summing up 15-bit current results, energy by summing up 11 bit power results.

One conversion takes 782µs and a new RR cycle is started after every 100ms. This configuration fits to an application where two shunt resistors are used and fast current, voltage and power is required. E.g.: Fast impedance tracking or measuring pre-charge voltage and current.

#### **POWER MEASUREMENT**

The LTC2949 measures power with additional ADCs that multiply voltage (VBATP – VBATM) and current at the full 5.24MHz sampling frequency, prior to any averaging due to the analog-to-digital conversion. This maintains accuracy even if current and voltage change in phase during the 100ms conversion time, which can happen if the power is drawn from a battery with significant impedance. [Figure](#page-18-1)  [4](#page-18-1) shows an example of the BAT voltage dropping from 4V to 3V due to battery impedance when an AC current is drawn by the load. In this example, the multiplication of average current with average voltage would lead to a +8% error in the calculated power as the voltage is significantly lower than the average voltage at the moments where the peak current is drawn. The scheme used by the LTC2949 avoids this error, maintaining specified accuracy with signals up to 50kHz.



<span id="page-18-1"></span>**Figure 4. Power Measurement of Transient Signals**

### <span id="page-19-0"></span>**CHARGE, ENERGY AND TIME**

The LTC2949 integrates the current and power measurements over time to calculate charge and energy flowing to the load. It also keeps track of total accumulated time used for the integration.

For the quantities charge and energy the LTC2949 provides three sets of registers each, for the quantity "time" four register sets.

Charge1, Energy1 and Time1 contain accumulated quantities of Channel1. Charge2, Energy2 and Time2 contain accumulated quantities of Channel2. Charge3 and Time3 contain the sum of charges monitored by Channel1 and Channel2 and the corresponding time. Similarly Energy4 and Time4 contain the sum of energies monitored by Channel1 and Channel2 and the corresponding time. See the [Accumulated Result Registers](#page-45-0) section in the Register Map description for more details.

Each register set can be separately configured to accumulate current and power based on the sign of the measured current. A minimum current threshold can also be set below which integration is stopped. See the [Control Registers](#page-55-0) section in the Register Map description for more details.

### **Time Base**

Accurately measuring charge and energy by integrating current and power requires a precise integration period. The LTC2949 uses either a trimmed internal oscillator or an external clock as the time base for determining the integration period. It can use either an external square wave clock in a frequency range between 100kHz and 25MHz or a 4MHz crystal as external clock input. If an external square wave is used, it should be connected to the CLKI pin and the CLKO pin should be left unconnected.

[Figure 5](#page-19-2) shows the recommended circuit if a crystal is used to generate the reference clock. In case the internal clock is used, tie CLKI to ground and leave CLKO unconnected.

### <span id="page-19-1"></span>**Timebase Control**

The LTC2949 uses the internal oscillator by default. If an external clock or a crystal is used, the PRE and DIV parameters in the Timebase Control Register need to be set appropriately. The LTC2949 then compares its inter-



<span id="page-19-2"></span>**Figure 5. Reference Clock with a 4MHz Crystal**

nal clock to the external frequency and represents Time, Charge, and Energy as multiples of the external clock period. To accommodate the large range of allowed external frequencies, an internal prescaler must be configured via the Timebase Control Register.

The prescaler consists of 2 stages, with the first dividing the external frequency f<sub>RFF</sub> by a factor  $2^{PRE}$ , and the second by a factor DIV. PRE is set between 0 and 5 with bits [2:0] of the Timebase Control Register. PRE should be configured such that the external frequency divided by 2PRE is less than 1MHz as shown in [Table 2](#page-19-3):

<span id="page-19-3"></span>**Table 2. Parameter PRE with External Clock**

| <sup>f</sup> ref                              | <b>PRE</b> | <b>2PRE</b> | <b>PRE[2:0]</b> |
|-----------------------------------------------|------------|-------------|-----------------|
| $0.1$ MHz $\leq$ f <sub>RFF</sub> $\leq$ 1MHz |            |             | 000             |
| 1MHz $\leq$ f <sub>RFF</sub> $\leq$ 2MHz      |            | 2           | 001             |
| $2MHz \le f_{RFF} \le 4MHz$                   | 2          | 4           | 010             |
| $4MHz \le f_{REF} \le 8MHz$                   | 3          | 8           | 011             |
| 8MHz $\leq$ f <sub>REF</sub> $\leq$ 16MHz     |            | 16          | 100             |
| 16MHz $\leq$ f <sub>RFF</sub> $\leq$ 25MHz    | 5          | 32          | 101             |
| Internal                                      |            |             | 111             |

The second stage of the prescaler then divides the result by a factor DIV. DIV is set between 0 and 31 by bits [7:3] of the Time Base Control Register. DIV should be set to the next lower integer value of the ratio between the output of the first stage of the prescaler ( $f_{RFF-1}$  =  $f_{RFF}/2^{PRE}$ ) and 32768Hz or, in other terms:

$$
DIV = floor\left(\frac{f_{REF}}{2^{PRE} \cdot 32768Hz}\right)
$$

If a crystal is used, the values are:  $PRE = 2$ ,  $DIV = 30$ . The Quick Eval™ Software for the LTC2949 contains an easy to use calculator for these parameters. [Table 3](#page-20-1) gives a few examples for common frequencies.



<span id="page-20-1"></span><span id="page-20-0"></span>**Table 3. Timebase Settings for Common Frequencies**

#### **OVERCURRENT COMPARATORS**

The LTC2949 features two fast differential over-current comparators with rail to rail input common mode and programmable threshold followed by configurable filters to suppress input glitches. Overcurrent comparator 1 (OCC1) is connected to pins I1P and I1M while overcurrent comparator 2 (OCC2) supervises the differential voltage between I2P and I2M. Both overcurrent comparators can individually be configured to detect either only positive or only negative overcurrents or overcurrents independent of their polarity. When at least one of the overcurrent comparators is enabled, GPIO5 turns into a heartbeat signal toggling at 400kHz while currents are within the desired range and staying low if any current exceeds its programmed limit.

The overcurrent comparator 1 (OCC1) between I1P and I1M is controlled by the control register OCC1CTRL while overcurrent comparator 2 (OCC2) is controlled by its control register at OCC2CTRL, both on page 0 of the register map. Both OCC Control Registers are organized as shown in [Table 4](#page-20-2).

<span id="page-20-2"></span>



The overcurrent comparators are enabled by setting the respective OCCxEN to 1.

Bits OCCxPOLx control the polarity sensitivity of the comparator as in [Table 5.](#page-20-3)

<span id="page-20-3"></span>**Table 5. OCC Polarity Configuration**

| OCCxPOL1 | <b>OCCxPOLO</b> | <b>POLARITY</b>          |
|----------|-----------------|--------------------------|
|          |                 | <b>Both Polarities</b>   |
|          |                 | <b>Positive Currents</b> |
|          |                 | <b>Negative Currents</b> |

The thresholds of the overcurrent comparators can be programmed individually by means of the OCCxDACx bits between 0 and 310mV.

#### **Table 6. OCC Thresholds**



Similarly, the duration of a threshold exceeding not reported by the comparator (Deglitch Time) can be programmed by the bits OCCxDGLTx between 20µs to 1.28ms.

#### **Table 7. OCC Deglitch Time**



Overcurrents are reported by setting OCC1 and OCC2 of VCC and OCC Status Register (STATVCC) and by stopping the heartbeat signal on GPIO5. While the update of the output register can take up to 100ms, the heartbeat is stopped within 15µs after an overcurrent exceeded the programmed deglitch time. Once an overcurrent occurred, the result bits in the register remain set until they are read by the host and subsequently cleared.

For diagnostic purposes, the overcurrent comparators have a self-test built in using test input signals IPT and IMT, see the Safety Manual for more information.

Rev A

### <span id="page-21-0"></span>**SERIAL INTERFACES OVERVIEW**

LTC2949 has two serial interfaces, one for communication with the host and a second to address an external EEPROM. The interface for host communication is composed by pins 27 through 30 and can be configured to be either a standard 4-wire serial peripheral interface (SPI) or a 2-wire isolated interface (isoSPI) based on the voltage of the IOVCC pin. Regardless of which configuration is selected, the LTC2949 acts as an SPI slave. The LTC2949 can be operated in addressable mode (SPI & isoSPI) or as last element of a daisy chain of LTC68xx Cell Monitors (isoSPI only).



**Figure 6. 4-Wire SPI External Connections**

A second interface composed by pins 14 and 15 is a master I2C interface, allowing to save and restore LTC2949's register content to and from an external EEPROM see the [External EEPROM Control Register](#page-66-0) section for more information.

### **4-WIRE SERIAL PERIPHERAL INTERFACE (SPI) PHYSICAL LAYER**

Connecting pin IOVCC to a supply voltage ≥1.8V configures the serial port for 4-wire SPI. Logic input thresholds and output swings are set by the voltage at the IOVCC pin, which should be connected to the same supply as the SPI master device. A 1µF bypass capacitor is recommended from IOVCC to DGND. The pin SDI is often referred to as MOSI, the pin SDO as MISO. The 4-wire serial port is configured to operate in a SPI system using CPHA = 1 and CPOL = 1. Consequently, data on SDI must be stable during the rising edge of SCK and data on SDO will be updated on the falling edge of SCK. The timing is depicted in [Figure 7](#page-21-1). The maximum data rate is 1Mbps. See [Electrical Charac](#page-3-1)[teristics](#page-3-1). SDO is open drain and requires a pull-up.



<span id="page-21-1"></span>**Figure 7. Timing Diagram of 4-Wire Serial Peripheral Interface**

#### <span id="page-22-0"></span>**2-WIRE ISOLATED INTERFACE (ISOSPI) PHYSICAL LAYER**

Tying IOVCC to local chip ground enables the isoSPI 2-wire interface which allows fully isolated operation of the LTC2949. The 2-wire interface provides means to communicate to LTC2949 using simple twisted pair cabling. An LTC6820 should be used for translating standard SPI signals from the SPI master into pulses that are sent over an isolation barrier to the LTC2949.

The interface is designed for low packet error rates when the cabling is subjected to high RF fields. Isolation is achieved through an external transformer. Capacitive coupling with 10nF capacitors could also be used, but has a very limited common mode noise rejection (only for low frequencies) and is only recommended for short single PCB interconnections with limited voltage transients at the isolation barrier. Additional clamping Schottky diodes might be necessary from IP and IM to VCC and GND. Standard SPI signals are encoded into differential pulses. The strength of the transmission pulse and the threshold level of the receiver are set by two external resistors. The values of the resistors allow the user to trade off power dissipation for noise immunity. [Figure 9](#page-22-1) illustrates how the isoSPI



**Figure 8. isoSPI Physical Layer**



<span id="page-22-1"></span>**Figure 9. isoSPI Interface**

circuit operates. A 2V reference drives the IBIAS pin. External resistors  $R_{B1}$  and  $R_{B2}$  create the reference current  $I<sub>B</sub>$ . This current sets the drive strength of the transmitter.  $R_{B1}$  and  $R_{B2}$  also form a voltage divider of the 2V reference at the ICMP pin. This sets the threshold voltage of the receiver circuit.

### **Waking Up the isoSPI Port**

The isoSPI port has 3 modes of operation, IDLE, READY and ACTIVE as described in the section [isoSPI State De](#page-14-1)[scription](#page-14-1). In IDLE, the WAKEUP circuit monitors activity on pins IP and IM. Differential activity on IP-IM wakes up the isoSPI interface. The isoSPI port will return to the low power IDLE state if there is no activity on IP/IM for a time of  $t_{\text{IDLE}}$ . The LTC2949 will be ready to communicate when the core is not in SLEEP and the isoSPI state changes to READY (within  $t_{RFADY}$  after wakeup) as illustrated in [Figure 3](#page-15-1). Common mode signals will not wake up the serial interface. The interface is designed to wake up after receiving a large signal single-ended pulse, or a low-amplitude symmetric pulse. The differential signal  $|IP - IM|$ , must be at least  $V_{WAKE} = 200$ mV for a minimum duration of t<sub>DWELL</sub> = 240ns to qualify as a wake up signal that powers up the serial interface.

"Long -1" or "Long +1" pulses (= drive CSB low, high) generated by LTC6820 and compatible isoSPI devices (e.g. LTC68xx Cell Monitors) will always meet this requirement. See following chapters for isoSPI pulse details.

### **Selecting Bias Resistors**

The adjustable signal amplitude allows the system to trade power consumption for communication robustness, and the adjustable comparator threshold allows the system to account for signal losses. The isoSPI transmitter drive current and comparator voltage threshold are set by a resistor divider ( $R_{BIAS} = R_{B1} + R_{B2}$ ) between the IBIAS and DGND. The divided voltage ( $V_{ICMP}$ ) is connected to the ICMP pin which sets the comparator threshold ( $V_{ICMP}$ ) to 1/2 of this voltage. When the isoSPI interface is enabled (not IDLE) IBIAS is held at 2V, causing a current  $I<sub>B</sub>$  to flow out of the IBIAS pin. The IP and IM pin drive currents are  $20 \cdot I_B$ .

As an example, if divider resistor  $R_{B1}$  is 2.8k and resistor  $R_{B2}$  is 1.21k (so that  $R_{BIAS} = 4k$ ), then:

$$
I_B = \frac{2V}{R_{B1} + R_{B2}} = 0.5mA
$$
  
\n
$$
I_{DRV} = I_{IP} = I_{IM} = 20 \cdot I_B = 10mA
$$
  
\n
$$
V_{ICMP} = 2V \cdot \frac{R_{B2}}{R_{B1} + R_{B2}} = I_B \cdot R_{B2} = 603mV
$$
  
\n
$$
V_{TCMP} = 0.5 \cdot V_{ICMP} = 302mV
$$

In this example, the pulse drive current IDRV will be 10mA, and the receiver comparators will detect pulses with IP-IM amplitudes greater than  $\pm 302$  mV. If the isolation barrier uses 1:1 transformers connected by a twisted pair and terminated with 100 $\Omega$  resistors on each end, then the transmitted differential signal amplitude  $(\pm)$  will be:

$$
V_A = I_{DRV} \cdot \frac{R_M}{2} = 0.5V
$$

(This result ignores transformer and cable losses, which may reduce the amplitude).

### **isoSPI Pulse Detail**

The transmitter can output three voltage levels:  $+V_A$ , OV, and  $-V_A$ . A positive output results from IP sourcing current and IM sinking current across load resistor  $R_M$ . A negative voltage is developed by IP sinking and IM sourcing. When both outputs are off, the load resistance forces the differential output to 0V. To eliminate the DC signal component and enhance reliability, the isoSPI uses bipolar pulses of two different pulse length. This allows for four types of pulses to be transmitted, as shown in [Table 8](#page-24-1). A +1 pulse will be transmitted as a positive pulse followed by a negative pulse.  $A - 1$  pulse will be transmitted as a negative pulse followed by a positive pulse. The duration of each pulse is defined as  $t_{1/2PW}$ , since each is half of the required symmetric pair. (The total isoSPI pulse duration is  $2 • t_{1/2PW}$ ).

#### <span id="page-24-1"></span>**Table 8. isoSPI Pulse Types**



An LTC6820 should be used to translate the SPI signals of a micro controller into isoSPI pulses. On the other side of the isolation barrier (i.e. at the other end of the cable), the LTC2949 will have IOVCC tied to its local GND. It receives transmitted pulses and reconstructs the SPI signals internally, as shown in [Table 9.](#page-24-2) In addition, during a READ command this port may transmit return data pulses which are transmitted  $t_{\text{RTN}}$  after the received pulse. The LTC2949 isoSPI port is a slave port and only transmits short –1 pulses, never long CSB pulses nor short +1 pulses. The master port recognizes a null response as a logic 1 (for this reason a no reply to a read command is equivalent to read only 0xFF... on the MISO line, which will also cause a PEC error, see chapters DATA LINK LAYER and following).

This allows for multiple slave devices on a single cable without risk of collisions (Multidrop). [Figure 11](#page-25-0) shows the isoSPI timing diagram for a READ command.

<span id="page-24-2"></span>



#### **Supported Bus Structures**

The addressing feature of the LTC2949 and LTC68xx-2 Cell Monitors allows multiple devices with different addresses to be connected on a single bus by multi-dropping them. Multi-dropping can be used in either SPI or isoSPI (See [Figure 12](#page-26-0) (A)). The LTC2949 also operates in parallel to or as last element of a daisy chain of LTC68xx Cell Monitors (See [Figure 12](#page-26-0) (B&C)).



<span id="page-24-0"></span>**Figure 10. isoSPI Pulse Detail**



**Figure 11. isoSPI Timing Diagram**

### **LTC2949 in Addressable/Multidrop Bus Configuration**

An LTC2949 can be directly connected to the master in SPI or through an LTC6820 in isoSPI mode. When operating together with LTC68xx Cell Monitors it is recommended to use the LTC2949 in a multidrop bus configuration to take advantage of the full feature set and minimize communication overhead. The LTC2949 can operate on the same SPI/ isoSPI with other LTC68xx Cell Monitors [\(Figure 12](#page-26-0) (A, B)). The LTC2949 responds to address 0xF. This address is hardwired and cannot be changed. Consequently, other LTC68xx Cell Monitors on the same bus must be pinconfigured to different addresses. Simultaneous writing to all devices on one bus is done by issuing a broadcast command. This feature proves useful for synchronous ADC conversions of LTC2949 and LTC68xx Cell Monitors. The common SDO pin is open drain and requires a pull-up.

### <span id="page-25-0"></span>**LTC2949 Connected to Reversible isoSPI Ring**

LTC2949 can be connected to one end of a reversible isoSPI ring. In this scenario the default communication to LTC2949 is done with direct commands, equivalent to the scenario where LTC2949 is connected in parallel to a daisychain. In case the direct link between the left side LTC6820 and LTC2949 fails, the communication to LTC2949 can be routed through the daisychain via the right side LTC6820, equivalent to the scenario where LTC2949 is connected on top of a daisychain.

### **LTC2949 on Top of a Daisy Chain**

It is recommended to operate LTC2949 in parallel to a daisy chain of LTC68xx Cell Monitors in either isoSPI or normal SPI by using its addressing feature. This is the mode with the minimum communication overhead. However, also operation as last element of a daisy chain is supported.

<span id="page-26-0"></span>

<span id="page-27-0"></span>As the LTC2949 has only one isoSPI port it must be placed as the last ( $M<sup>th</sup>$ ) element in a daisy chain. The  $0<sup>th</sup>$ element communicates to the master via port A which can be configured as isoSPI or normal SPI mode, depending on the connection of the ISOMOD pin. The 0th element connects via port B to the 1st element of the daisy chain using isoSPI, and so on. When the LTC68xx Cell Monitor is operating with port A as SPI (ISOMD =  $V^-$ ), the SPI detects one of four communication events: CSB falling, CSB rising, SCK rising with  $SDI = 0$ , and SCK rising with  $SDI =$ 1. Each event is converted into one of the four pulse types for transmission through the daisy chain. Long pulses are used to transmit CSB changes and short pulses are used to transmit data, as explained in [Table 8.](#page-24-1) When both ports are operated in isoSPI mode, isoSPI pulses on port A are passed to port B within a short delay.

### **DATA LINK LAYER**

All data transfers on LTC2949 occur in byte groups. Every byte consists of 8-bits. Bytes are transferred with the most significant bit (MSB) first. CSB must remain low for the entire duration of a command sequence, including between a command byte and subsequent data. A write command takes effect after a correct PEC is processed.

### **NETWORK LAYER**

The LTC2949 registers can be accessed by a direct read/ write command (DCMD) containing the registers to be

written or read from followed by the register data – see following section [Direct Read/Write Command \(DCMD\)](#page-32-0). Beside the DCMD, the LTC2949 supports the LTC68xx Cell Monitor compatible commands ADCV and RDCV.

When LTC2949 is the last element in an isoSPI daisy chain, the DCMD can be used to write to LTC2949 but not to read data from the device, because the DCMD is not supported by other LTC68xx Cell Monitors and thus they do not pass data from their port B to port A. Therefore, the RDCV command must be used to read from LTC2949 as element of a daisy chain. LTC2949 registers read by the RDCV command can be configured by a preceding DCMD.

[Table 10](#page-27-1) summarizes the possibilities to communicate to LTC2949.

#### <span id="page-27-1"></span>**Table 10. Communication with LTC2949**





**Figure 13. LTC2949 Connected to a Reversible isoSPI Ring**

#### **Fast Measurement Timings**

The following timing diagrams shows LTC2949 fast single shot timing in relation to LTC6810's timing of the ADCV command for measuring all six cells. Other LTC681x Cell Monitors have similar timing diagram, just with different number of ADCs and cells. The LTC681x devices have several ADC modes with different filter bandwidth and accuracy. Typically, in the 7kHz normal mode, all cells are converted within a time window very close to LTC2949's fast conversion time which is nominal 782µs. For example, the LTC6810 converts all cells within 815µs in the normal mode.

As an example, only three (I2, BAT, AUX) of maximum four ADCs of LTC2949 are configured for fast conversions. The displayed timings are valid for any allowed combinations of fast channels.











Note: If the first HS byte of the RDCV data is 0x0F, the conversion results of the very same data set are already valid. If the first HS byte of the RDCV data is 0x00, the conversion results of the very same data set are not valid. A new RDCV must be issued to check for updated conversion results. If the first HS byte of the RDCV data is 0x00 the host can continue to read HS bytes until it changes to 0x0F. The following RDCV command for sure will have valid conversion results, still, the HS byte of the very same data set will be 0x00, because it was already internally cleared after it was read 0x0F in the previous RDCV.

The following diagram shows details on LTC2949's fast continuous conversion timing. Fast continuous operation is started by a direct write command that sets bit FACONV and at least one of the channel bits (CH1, CH2, AUX) in register FACTRL.



**Figure 16. Timing for LTC2949's Fast Continuous Current and Voltage Measurements.**



#### **Fast AUX Measurements**

It is not possible to change the AUX MUX configuration during fast continuous mode (FCM) measurements. FAMUXP, FAMUXN can be written and the same value read back at any time, but the internal MUX will only be set to the requested configuration when receiving a new fast conversion request. This is either the ADCV command for fast single shot (FSSHT) or the transition from 0 to 1 of the FACONV bit for FCM measurements.

When leaving the FCM (FACONV  $= 0$ ), the host must wait for the last conversion being completed before any new fast conversion is triggered. This can be achieved by waiting at least 1.26 ms.

If both channels are configured fast, it must be ensured that either the FCM stays active for at least 128 samples or FSSHT measurements are inhibited for at least 100ms. Only after every 128 samples / 100 ms, the slow channel registers (including STATUS, FAULTS, EXTFAULTS) are updated. In applications in which it is required to enable and disable FACONV periodically or to perform repetitive FSSHT measurements it is recommended to configure CH1 for slow and CH2 for fast mode, which ensures the slow channel being updated periodically.

#### **Fast AUX Round-Robin Measurements**

FSSHT measurements shall be used in applications that require different inputs via the AUX MUX at high update rates (faster than 100 ms). Optionally, the FSSHT measurements can be surrounded by FCM periods, during which a single MUX input is converted continuously. The conversion results of the FCM periods can be read via the FIFO registers or via RDCV. Reading of conversion results from FIFOs is possible at any time. Still, the FSSHT trigger command (ADCV while CONT= 1 and FACTRL unequal zero) will clear all FIFOs.

Following table shows an example sequence of 4 FSSHT measurements that interrupt a FCM period. If only FSSHT measurements are required, the rows CONT0, CONT1 can be omitted.





**Note 1:** MISO data is only shown as an example and the actual data may change. 'X' indicates don't care data.

**Note 2:** A delay of ≥ 1.26 ms is mandatory between any ADCV and RDCV to ensure valid conversion result readings.

**Note 3:** Above MUX settings convert one external pin voltage V1 vs. GND and the internal VREF2 in three different ways. This example and can be adjusted and extended to any MUX configurations required.

**Note 4:** CONT0 and MUX0 can be merged to a single 3-write command to FAMUXN, FAMUXP, FACTRL (MOSI: 0xFEF3C7984600010E9516)

**Note 5:** When LTC2949 is in STANDBY state it can be moved to MEASURE state at any time by writing CONT=1. From the write command it takes t<sub>IDLE\_CORE</sub> until the MEASURE state is active and then worst case 140ms until the first slow channel conversion results can be read form LTC2949's registers. First fast measurements can be performed, if FACTRL was configured appropriately, already when MEASURE state is active.

**Note 6:** The following sequence allows a fast and efficient initialization of LTC2949 before any fast conversions can be performed:

1. Wakeup, configure ADCCONF and perform ADJUPD as required.

2. Write 0x08 (CONT) to OPCTRL

3. 3-Byte-Write to FAMUXN (e.g. 0x00 = GND), FAMUXP (e.g. 0x16 = VREF2), FACTRL (e.g. 0x02 = FACHA or another allowed combination to perform any fast conversion)

4. Send any ADxx (e.g. ADCV, see table 17)

5. Wait at least 1.2 ms

6. Send any RDxx (e.g. RDCVA, see table 18). If HS byte is unequal 0x0F go back to 3.

7. Initialization is done. LTC2949 is now in MEASURE mode and any fast conversions can be performed subsequently (e.g. the sequence from above table)

#### <span id="page-32-0"></span>**Direct Read/Write Command (DCMD)**

To access the full register map of the LTC2949, a special direct command (DCMD) is provided which is not used by other LTC68xx Cell Monitors. DCMD allows to read/write arbitrary number of bytes from/to LTC2949's register map. The LTC2949 auto-increments its address pointer after each data byte, so multiple registers can be written/read as part of a single transaction. Data packets from one to up to 16 bytes are interleaved by a two-byte data PEC. Data packets written without PEC are discarded. Read commands may stop at any byte.

#### **Table 11. Direct Read/Write Command Format**



ID byte is used to distinguish between read and write commands and it defines the number of data bytes per PEC (parameter N in above table). The ID byte is not part of any PEC, instead it has intrinsic error detection via redundancy and error check bits. See following tables for details.

#### **Table 12. Bit Definitions of Byte ID[7:0]**



#### **Table 13. ID[7:0] Byte Format Description**



#### **Table 14. Direct Read/Write Command Format Details**



#### **Commands Compatible with LTC68xx Cell Monitors (RDCV, ADCV)**

The LTC2949 supports several RDCV and ADCV style commands compatible with LTC68xx Cell Monitors. RDCVA-RDCVF, RDAUXA-RDAUXD, RDCFGA, RDCFGB (all referred as RDCV commands in this document), ADCV, ADOW, ADOL, ADAX, ADAXD, ADCVAX and ADCVSC (all referred as ADCV commands in this document) are supported as broadcast and addressed commands. Addressed commands are used to address LTC2949 exclusively. To trigger actions on LTC2949 and LTC68xx Cell Monitors simultaneously, broadcast commands are used. This is for example useful to initiating ADC conversions of several devices at the same time. No matter if LTC2949 is connected parallel to or on top of a daisy chain, addressed ADCV commands can trigger measurements on LTC2949 only and broadcast ADCV commands can perform synchronous ADC conversions on all devices connected to the SPI / isoSPI bus. The conversion starts at the end of the PEC for all devices.

In cases where LTC2949 is connected parallel to a daisy chain, direct read commands (DCMD) must be used to read register data and addressed RDCV commands (with RDCVCONF=1) must be used to read the last fast conversion results. If LTC2949 is connected on top of a daisy chain, broadcast RDCV commands must be used to read register data (RDCVCONF=0) or to read the last fast conversion results (RDCVCONF=1) depending on setting of REGSCTRL.RDCVCONF. Write to LTC2949's register map is always done with direct write commands (DCMD) independent of the bus topology. See [Table 10](#page-27-1) (Communication with LTC2949) for a summary of all possible communication scenarios.

Before LTC2949 can react on ADCV commands it must be running in slow continuous measurement mode (bit CONT in OPCTRL), at least one fast measurement channel must be selected via the Fast Control Register (FACTRL) and optionally, to make also fast BAT conversions via one of the power ADCs (P1 or P2 in voltage mode), P1ASV and/ or P2ASV in the ADC configuration register (ADCCONF) must be set. If LTC2949 is running in fast continuous mode (FACONV=1) any ADCV command is ignored and acquired samples can be read from the FIFO registers (FI-FOI1, FIFOI2, FIFOBAT, FIFOAUX). Still, also in this mode, it is possible to read the last fast conversion results via RDCV (RDCVCONF=1). If fast continuous mode is disabled (FACONV=0), any ADCV command will clear all FIFOs. If needed, samples within FIFOs should be read before sending an ADCV command while FACONV is cleared.

In the configuration where LTC2949 is on top of a daisy chain, after a broadcast RDCV command, the stacked LTC68xx Cell Monitors turn into a cascaded shift register, in which data is shifted through each device to the next device in the stack. In this scenario, LTC2949 responds to RDCV commands only if the Broadcast Read Enable bit (BCREN) in the Register Control Register (REGSCTRL) is set.

In the scenario where LTC2949 is placed in parallel to a daisy chain of LTC68xx Cell Monitors, the bit BCREN must be cleared (default) to avoid bus collisions. Still, any broadcast RDCV may clear LTC2949's internal HS byte (see below) if the bit RDCVCONF is set, no matter if BCREN is set or not. For this reason, it is recommended to read LTC2949's fast conversion results before reading from the LTC68xx Cell Monitors. Or, if for software timing reasons it is necessary to read from the LTC68xx Cell Monitors first, the bit RDCVCONF must be cleared before (it must be set again afterwards to read fast conversion data from LTC2949).

The last results of any fast conversion can be read out by the RDCV command, providing sequentially the results of I1, I2, BAT and AUX (least significant bytes first to be compatible with LTC68xx Cell Monitors) followed by one or more hand shake (HS) bytes, indicating if the data is new (0x0F) or old (0x00). Once LTC2949 sends the HS byte, it will continue sending it as long as the master is reading bytes. Still, a PEC will always be send for every 6 data bytes. Per transaction, the HS byte may only change from 0x00 to 0x0F, once it is 0x0F it won't change. This allows the master to poll for conversion results being ready by checking for a transition of the HS byte from 0x00 to 0x0F. If the first HS byte is 0x0F the conversion data received with that command is already new and valid. If the first HS byte is 0x00 the data received in the same transaction was not yet updated. A subsequent RDCV

command is necessary to read the updated conversion results, still, the HS byte will be reported as 0x00 for this RDCV command, as it was internally already cleared after it was read 0x0F with the previous RDCV.

LTC2949's fast conversion time is typically 0.8ms. Additional processing time is necessary for the results being ready to be read by the master. Worst case, 1.26 ms after a conversion was triggered, the results can be read via a FIFO register (in case of fast continuous mode) or via the RDCV command. For fast single shot measurements, this limits the maximum guaranteed sample rate to ~0.8ksps. For fast continuous measurement, the sample rate is fixed to 1.25ksps and the mentioned delay is just a latency between the actual measurements and the time the samples are available to be read. The master shall wait at least 1.26ms between the time fast continuous mode is enabled and the first time any FIFO register is read, to allow the first sample to be read from the FIFO. Alternatively, it is also possible to use a RDCV command to check when the first sample is ready (see HS byte above) and then read all samples from the FIFO registers periodically.

**Table 15. Format of ADCV/RDCV Style Commands. Only for RDCV Commands the Slave Sends Data to the Master on the MISO Line**

| <b>BYTE</b> |                   |                        |                  |                  |       | $\cdots$               |       | 10               | . .<br>. .             | 40<br> | $\cdots$<br>$\ddotsc$ |        | 18               | 19                     | $\cdots$              |
|-------------|-------------------|------------------------|------------------|------------------|-------|------------------------|-------|------------------|------------------------|--------|-----------------------|--------|------------------|------------------------|-----------------------|
| R/W         |                   | Master to slave (MOSI) |                  |                  |       | Slave to master (MISO) |       |                  |                        |        |                       |        |                  |                        |                       |
| Name        | CM <sub>D</sub> 0 | CM <sub>D</sub> 1      | PEC <sub>0</sub> | PEC <sub>1</sub> | DATA0 | .                      | DATA6 | PEC <sub>0</sub> | DE <sub>01</sub><br>∟ບ | DATA7  | $\cdots$              | DATA11 | PEC <sub>0</sub> | DEC <sub>1</sub><br>∟∪ | $\cdots$<br>$\cdot$ . |

CMD0 and CMD1 are the command bytes. The format for the commands is shown in [Table 16](#page-34-0). CC[10:0] is the 11-bit command code. A list of supported command codes is shown in [Table 17](#page-35-0) and [Table 18](#page-35-1). Broadcast commands have a value 0, addressed commands have a value 1 for CMD0[7] through CMD0[3]. The PEC must be computed on the entire 16-bit command (CMD0 and CMD1).

<span id="page-34-0"></span>**Table 16. CMD0, CMD1 Command Bytes Format. Data is Send from Master to Slave (MOSI). A/B is 0 for Broadcast and 1 for Addressed Commands.**

| <b>NAME</b>      | <b>BIT 7</b> | BIT <sub>6</sub> | BIT <sub>5</sub> | BIT<br>4 | <b>BIT 3</b> | BIT <sub>2</sub> | BIT . | <b>BIT 0</b> |
|------------------|--------------|------------------|------------------|----------|--------------|------------------|-------|--------------|
| CMD <sub>0</sub> | A/B          | A/B              | A/B              | A/B      | A/B          | CC[10]           | CC[9] | CC[8]        |
| CMD1             | CC[7]        | CC[6]            | CC[5]            | CG[4]    | CC[3]        | CC[2]            | CCI1  | CC[0]        |

<span id="page-35-0"></span>**Table 17. ADCV Style Commands. LTC2949 Performs a Fast Conversion Depending on FACTRL/ADCCONF Registers Upon Those Commands**



#### <span id="page-35-1"></span>**Table 18. RDCV Style Commands. Used to Read Fast Conversion Results or for Indirect Memory Map Reads from LTC2949**


The RDCV command allows reading data packets much longer than the daisy chain shift register. The length of the shift register is 64 • M bits, whereas M is the number of elements in the chain excluding LTC2949. Data from the LTC2949 is received by the master after 64 • M data bits starting with bit I1[7] according to the figure below. A PEC is calculated after every 6 data bytes. After the transmission of the conversions results, the LTC2949 continuously sends the hand shake byte (HS) indicating if the data is new (0x0F) or old (0x00). A transition of the hand shake byte from 0x00 to 0x0F indicates the arrival of new data, which can be read out by a subsequent RDCV command.

| CMD <sub>0</sub> | CMD <sub>1</sub> | <b>PECO</b>      | PEC1     | 11[7:0]   | 11[15:8] | 12[7:0] | 2[15:8] | BAT[7:0]         |
|------------------|------------------|------------------|----------|-----------|----------|---------|---------|------------------|
| BAT[15:8]        | PEC <sub>0</sub> | PEC <sub>1</sub> | AUX[7:0] | AUX[15:8] | НS       | НS      | НS      | HS               |
| PEC <sub>0</sub> | PEC <sub>1</sub> | НS               | НS       | <b>HS</b> | НS       | HS      | НS      | PEC <sub>0</sub> |
| PEC1             | HS               | НS               | НS       | НS        | НS       | HS      |         | .                |

**Table 19. RDCV Command Format. CMD0, CMD1 According to Table 18 (RDCV Style Commands). Requires RDCVCONF=1.**

Note: The conversion results 11, 12, BAT, AUX are converted to volts by multiplication with the LSB size 7.60371 µV for the current and 375.183 µV for the BAT and AUX channel.

### **Indirect Memory Access RDCV Command**

DCMD is the recommended way of reading data from the LTC2949 in addressable mode. When LTC2949 is the last element in a daisy chain, an RDCV has to be used to read data from the LTC2949, as DCMD is not supported by LTC68xx Cell Monitors and therefore does not configure them as shift registers, In default, the LTC2949 will respond to RDCV with the fast mode conversion results as described above (RDCVCONF = 1).

In order to gain access to the entire register map of LTC2949 an address pointer can be set causing the LTC2949 to provide data starting at that register address on subsequent RDCV commands. To use this indirect memory access RDCV command, the RDCV Configuration Bit (RDCVCONF) has to be reset and Broadcast Read Enable bit (BCREN) has to be set in REGSCTRL and the starting pointer must be written to the RDCV Indirect Address Register (RDCVIADDR). In this way any register can be read by subsequent RDCV commands. The address pointer is auto-incremented after every data byte for reading data bursts of any length. A PEC is transmitted after every six data bytes. Once the REGSC-TRL is written accordingly, only the Indirect Address Register must be updated to read from other memory locations.

Please note that the RDCVIADDR can also be written before the REGSCTRL if a single DCMD spanning from RDCVIADDR to REGSCTRL is used. For this single write burst, the two bytes between RDCVIADDR and REGSCTRL are don't care and can be written 0x00.



**Figure 17. Indirect Memory Access Read Procedure Using RDCV Command**





DATA<sub>0</sub> is the content of the register at the starting address that was written to RDCVIADDR. DATA<sub>1</sub> is the content of the register at the following address and so on.

## **Packet Error Code**

The packet error code (PEC) is a 15-bit cyclic redundancy check (CRC) value calculated for all of the bits in a register group in the order they are passed, using the initial PEC seed value of 000000000010000 and the following characteristic polynomial:  $x15 + x14 + x10 + x8 + x7 +$  $x4 + x3 + 1$ . To calculate the 15-bit PEC value, a simple procedure can be established:

- 1. Initialize the PEC to 000000000010000 (PEC is a 15 bit register group)
- 2. For each bit DIN coming into the PEC register group, set

 $INO = DIN XOR PEC [14]$  $IN3 = IN0$  XOR PEC  $[2]$  $IN4 = IN0 XOR PEC [3]$  $IN7 = IN0 XOR PEC [6]$  $IN8 = IN0 XOR PEC [7]$ IN10 = IN0 XOR PEC [9] IN14 = IN0 XOR PEC [13]

- 3. Update the 15-bit PEC as follows PEC  $[14] = IN14$ , PEC [13] = PEC [12], PEC [12] = PEC [11], PEC [11] = PEC [10], PEC [10] = IN10, PEC  $[9] = PEC [8]$ , PEC  $[8] = IN8$ , PEC  $[7] = IN7$ , PEC  $[6] = PEC [5]$ ,
	- PEC  $[5]$  = PEC  $[4]$ , PEC  $[4] = IN4$ , PEC  $[3] = IN3$ , PEC [2] = PEC [1],
	- PEC  $[1] = PEC [0],$
	- PEC [0] = IN0

4. Go back to step 2 until all the data is shifted. The final PEC (16-bits) is the 15-bit value in the PEC register right padded with 0. An example to calculate the PEC for a 16-bit word (0x0001) is listed in [Table 21](#page-38-0). The PEC for 0x0001 is computed as 0x3D6E after stuffing a 0-bit at the LSB. For longer data streams, the PEC is valid at the end of the last bit of data sent to the PEC register. LTC2949 calculates PEC for any command or data received and compares it with the PEC following the command or data. The command or data is regarded as valid only if the PEC matches. LTC2949 also attaches the calculated PEC at the end of the data it shifts out. [Table 22](#page-38-1) shows the format of PEC while writing to or reading from LTC2949.

#### <span id="page-38-0"></span>**Table 21. PEC Calculation for 0x0001**



#### <span id="page-38-1"></span>**Table 22. Write/Read PEC Format**



### **Improved PEC Calculation**

The PEC allows the user to have confidence that the serial data read from the LTC2949 is valid and has not been corrupted by any external noise source. This is a critical feature for reliable communication and the LTC2949 requires that a PEC be calculated for all data being read from and written to the LTC2949. For this reason it is important to have an efficient method for calculating the PEC. The code below demonstrates a simple implementation of a lookup table

derived PEC calculation method. There are two functions, the first function init\_PEC15\_Table() should only be called once when the microcontroller starts and will initialize a PEC15 table array called pec15Table[]. This table will be used in all future PEC calculations. The pec15 table can also be hard coded into the microcontroller rather than running the init\_PEC15\_Table() function at startup. The pec15() function calculates the PEC and will return the correct 15-bit PEC for byte arrays of any given length.

```
/************************************
```
remainder =  $16$ ; //PEC seed

Copyright 2012 Linear Technology Corp. (LTC) Permission to freely use, copy, modify, and distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies:

THIS SOFTWARE IS PROVIDED "AS IS" AND LTC DISCLAIMS ALL WARRANTIES INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL LTC BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM ANY USE OF SAME, INCLUDING ANY LOSS OF USE OR DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTUOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

```
***********************************************************/
int16 pec15Table[256];
int16 CRC15 POLY = 0x4599;
void init_PEC15_Table()
{
    for (int i = 0; i < 256; i++)
        remainder = i \ll 7;for (int bit = 8; bit > 0; --bit)
\left\{ \begin{array}{cc} 1 & 1 \\ 1 & 1 \end{array} \right\} if (remainder & 0x4000)
 {
                 remainder = ((remainder << 1));
             remainder = (remainder ^ CRC15poly)
 }
              else
{
             remainder = ((remainder << 1));
 }
        pec15Table[i] = remainder60xFFF;}
}
unsigned int16 pec15 (char *data , int len)
{
    int16 remainder,address;
```
for (int  $i = 0$ ;  $i < len$ ;  $i++)$ { address = ((remainder >> 7) ^ data[i]) &  $0xff$ ;//calculate PEC table address remainder = (remainder  $\langle\langle 8 \rangle$ )  $\land$  pec15Table[address];

```
}
return (remainder*2);//The CRC15 has a 0 in the LSB so the final value must be multiplied by 2
```
}



**Figure 18. Register Map** 

Figure 18. Register Map

See chapter "External EEPROM Control Register" for more details on using the optional external EEPROM See chapter "External EEPROM Control Register" for more details on using the optional external EEPROM

= reserved registers can be used to store custom data to external EEPROM<br>= registers can be used to store custom data to external EEPROM, if they are initialized by the host controller after EEPROM restore. = registers can be used to store custom data to external EEPROM, if they are initialized by the host controller after EEPROM restore.

NTC2A NTC2C RS2TCC RS2TCC RS2TCC RS2TCC RS2TCC RS2TCC 0x0 0x0 0x0 0x0 NTC1A NTC1C NTC1C RS1TC1C RS1TC1C RS1TC1C RS1TC1C RS1TC1C RS1TC1C RS1TC1C RS1TC1C 0x0 0x0 0x0 0x0

0x3F0000 0x3F0000 0x3F0000 0x3F0000  $\mathrm{MSE}$  MUX2GC  $\mathrm{MSE}$  music musi 0x35F0x3F0000 0x3F0000 0x3F00 RS2GC RS

RS2GC<br>
MUX2GC<br>
MUX2GC<br>
MTC1B<br>
MTC1B<br>
MTC2B<br>
MTC2B<br>
MTC2B

RS1GC<br>0x3F0000<br>0x3F0000<br>0x3F0000<br>NTC1A<br>NTC2A<br>NTC2A

RSRATIO<br>
MUX3GC<br>
MUX3GC<br>
MITC1C<br>
MITC2C<br>
MITC2C<br>
MITC2C

RSTUNLCK 0x0

RREF1 8

EL<br>
M<sub>O</sub>X8000<br>
0x8000

 $\frac{12\pi}{2}$ VOCTH<br>0x7FFF

0x7FFF 0x8000 0x7FFF 0x8000 0x7FFF IIITEN III DE LEGEN <br>DE LEGEN DE LEGEN DE

0x7FFF 0x8000 0x7FFF 0x8000 0x7FFF BATTLE SATTLE SATTLE

PTTH<br> **STEMPTH**<br>

STORE<br>
STOREF

 $\begin{array}{r} \n \hline \n 1TL \\
 \hline \n 0.8900 \\
 \hline \n 0.8000 \\
 \hline \n 0.01TL \\
 \hline \n 0.8900 \\
 \hline \n 0.0000 \\
 \hline \n 0.89000 \\
 \hline \n 0.89000\n \end{array}$ 

PITL<br>0x8000<br>TEMPTL<br>0x8000<br>0x8000

**0x90**

E **E REPLACE**<br>
STREET

**0xB0 0xC0 0xD0 0xE0**

0x900 0x900 0x800 0x800 0x800 0x800 0x800 0x800 0x800 0x80 0 SLOTING SLOTING

MUXNSET1 MUXPSET1 MUXNSET2 MUXPSET2 0x0 0x0 0x0 0x0 MUXNSET3 MUXPSET3 MUXNSET4 MUXPSET4 0x0 0x0 0x0 0x0 0x0 0x0

MUXNSET

**MUXPSET2 MUXPSET4** 

RREF2 8

 $\overline{271}$ **Dx8000** 

P<sub>2</sub>TH<sub>3</sub>

RS2TC2 8

0xFFFFFFFF

**TB4TH** 

FEHREN FEHREN EN EN DER EINEN EINER EI

ADCCONF 0x0 DIGINFO ANAINFO

**AINFO** 

 $\frac{8}{180}$ 

RS1T0

 $\begin{array}{r} \text{BATGC} \\ \text{0x3F000} \\ \text{0x3F000} \\ \text{0x3F000} \\ \text{RSTIC} \\ \text{RSTIC} \\ \text{RSTC} \\ \text{0x0} \end{array}$ 

= reserved registers can be used to store custom data to external EEPROM



E<br>Elele 0x7FFFFFFFFFFF

0x7FFFFFFFFFFF

0x800000000000

 $\frac{2}{3}$ 

0x800000000000

0x7FFFFFFFFFFFFFFF E4TL 0x8000000000000000

0x80000000000000000

0x7FFFFFFFFFFFFFFF  $\overline{\overline{\overline{\overline{\overline{C}}}}}$ 

C3TH

TB3TH 0xFFFFFFFF RS1TC2 8

TB2TH 0xFFFFFFFF



0x0 0x0 0x0 0x0 0x0 0x0 0x0 0x0 0x7 0x0 0x0 0x0 0x0 0x0

IFIFORCTRL FCURCOPCORD FCURCOPCORTRL FIFONTRL FIFOL FIFOL FIFOL FIFOL FIFOL FIFOL FIFOLD FIFOAUX RDCVIADDR FIFOAUX RDCVIADDR FIFOAUX RDCVIADDR FIFOAUX RDCVIADDR FIFOAUX RDCVIADDR FIFOAUX FIFOAUX RDCVIADDR FIFOAUX RDCVIADDR 0x0 0x80

FAMUXP<br>0x0

NNUXN

**IOCTRL** 

OXU<br>FOURGPIOCTRL<br>OXU

REGSCTRL<br>0x80

 $\begin{array}{|c|c|}\n\hline\n\text{NOVADOR} \\
\hline\n\text{NOV} \\
\hline\n\text{OXO}\n\end{array}$ 

Is

**PAGE 1**

C1TH C1TL TB1TH 0x7FFFFFFFFFFF 0x800000000000 0xFFFFFFFF

E1TH E1TL 0x7FFFFFFFFFFF 0x800000000000

WKUPACK 8

**SATMAX**<br>0x8000 OR880<br>OKRZIOTS

**X800** 

**0x70**

**0x30 0x40 0x50** **0xC0**

 $\frac{0}{24}$ VG

**0xA0**

BAT 0x0

**0x90**

 $\overline{\phantom{a}}$ 0x0

**0xF0**

# REGISTER MAP

2949 F18

41

### **Register Naming Conventions**



- RO Read Only SI Signed Integer
- SO Set Only (Note) UI Unsigned Integer

Note: Write 1 to SO bits to request the associated action. Successful write can be checked by a read command directly following the write command. After the action was performed the SO bit will be cleared automatically by LTC2949. Do not write to registers with SO bits, before all SO bits were read as 0. The typical processing time per action is t<sub>IDLE</sub> cone or t<sub>CONT</sub> depending on operation mode, see related bit description for details.

### **MEMORY MAP AND PAGING MECHANISM**

The memory map of the LTC2949 is organized in two pages, PAGE0 and PAGE1. PAGE0 contains all slow channel result quantities, control and status registers while PAGE1 contains all threshold and configuration registers. Each page has a register address space ranging from 0x00 to 0xEF, with each register consisting of one 8-bit byte of data. Registers 0xF0 to 0xFF are common to both register pages. Register REGSCTRL at 0xFF is part of this range and is used to switch between pages, see below. For clarity, all register addresses on PAGE1 are expressed as p1.0xYY in the following while addresses on PAGE0 are simply referred to as 0xYY.

Multiple-byte data is stored with most significant byte at the lowest address (little-endian). For instance, the MSB C1[47:40] of the quantity C1 is stored at address 0x00 in PAGE0.

Note that reading data from LTC2949's memory map (no matter if using direct command or indirect memory access RDCV command with RDCVCONF=0) reports MSBytes first, while reading fast conversion results via RDCV (RDCVCONF=1) reports LSBytes first.

Some addresses in the register map are not used and are reserved. Bits in non-reserved registers that are not explicitly described are also reserved. Writing to unused reserved registers or reserved bits in non-reserved registers may result in unwanted behavior of the LTC2949, reserved bits in non-reserved registers should be written as 0; reading of unused registers is generally harmless but will return random data. If software detection of device revision is necessary, then contact the factory for details.

### **Register Control Register**

The Register Control Register (0xFF) selects the active memory page, allows to configure the LTC2949 to respond to broadcast read commands, configures the RDCV command to indirect memory access mode and provides a memory locking mechanism.

| <b>BIT</b> | <b>SYMBOL</b>   | <b>TYPE</b> | <b>DEFAULT</b> | <b>OPERATION</b>                                                                                                                                                                                                  |
|------------|-----------------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | PAGE            | <b>RW</b>   | 0              | Memory Map Page Select<br>0: PAGEO of the memory map is selected.<br>1: PAGE1 of the memory map is selected.                                                                                                      |
|            | <b>BCREN</b>    | <b>RW</b>   | 0              | <b>Broadcast Read Enable</b><br>0: LTC2949 does not respond to broadcast read commands<br>1: LTC2949 responds to broadcast read commands                                                                          |
| [5:4]      | MLK[1:0]        | <b>RW</b>   | 00             | <b>Memory Lock</b><br>00: Memory not locked<br>01: Memory lock requested by master<br>10: Memory locked                                                                                                           |
|            | <b>RDCVCONF</b> | <b>RW</b>   |                | <b>RDCV Configuration Bit</b><br>0: Indirect memory access mode. RDCV will report data starting at address written to<br>RDCVIADDR (0xFC).<br>1: RDCV command will report latest fast channel conversion results. |

**Table 23. Control Register REGSCTRL (0xFF)**

LTC2949 provides a mechanism to lock the memory to keep coherency between registers when accessing the memory. A memory locking can be requested by the master by setting bits MLK[1:0] to 01. Now the LTC2949 updates its registers, e.g. with measurement results. During this time, read and write access to the LTC2949 memory apart from registers REGSCTR and RDCVIADDR is blocked. After all registers are updated by the LTC2949, it sets MLK[1:0] to 10 to indicate to the Master that memory is locked. The LTC2949 does not update the memory map any more until the master unlocks the memory by writing MLK[1:0] to 00.

The LTC2949's internal memory is still updated while the memory is locked and thus accumulation of values and updating of alerts is not interrupted. Once the memory is locked the master can read consistent data even by single byte access. Data does not change between those single read transactions. It is also possible to manipulate result parameter values e. g. to set a certain start value for Charge



**Figure 19. Memory Locking**

or Energy etc. Coherency within a single row of 16 bytes (register ranges 0x00 to 0x0F, 0x10 to 0x1F, ... and 0xE0 to 0xEF) is always guaranteed for multiple byte read and write bursts and does not require memory locking.



## **Table 24. Operation Control OPCTRL (0xF0)**

Note 9: ADJUPD shall be issued when in STANDBY mode only. The recommended implementation is to set ADJUPD as the last action of the initialization routine, before entering continuous mode. Once ADJUPD is set it takes a maximum of 100ms until LTC2949 has finished the internal update process and the bit ADJUPD is cleared automatically. Thus it is also possible to poll the bit ADJUPD for being cleared to indicate when the operation is done. In cases where it is necessary to assert ADJUPD after CONT was enabled, it is necessary to clear the bit CONT before, wait 100ms to ensure that all measurement cycles have completed and then assert ADJUPD. After ADJUPD was cleared automatically, the Continuous Mode may be entered again. To avoid the 100ms wait time when going to STANDBY mode, it is also possible to clear CONT and set CLR at the same time and poll for the bit CLR being cleared by LTC2949. This indicates also the end of any previously ongoing measurement cycle.

43

Reading of status (0x80), faults (0xDC-0xDD) and alert (0x81-0x87) registers may always be done without memory locking. Still, once it is necessary to clear those registers, memory locking is mandatory to avoid missing any alert and faults reporting. If an alert condition occurs while the memory is locked, LTC2949 will set the corresponding bit after the memory is unlocked by the host. This rule must be followed independent of the core state, as certain faults may also be raised in STANDBY mode.

Any fast conversions are not affected by the memory locking mechanism, thus it is still possible to change FAMUX settings, trigger fast single shots, read results via RDCV. Also reading conversion results from the FIFOs during fast continuous measurements is still possible.

### **Operation Control Register**

The Operation Control Register OPCTRL (0xF0) controls LTC2949's transitions between its CORE States: SLEEP, STANDBY, and MEASURE. Furthermore, it allows to clear accumulation and tracking registers, to validate changes of the configuration registers and to reset the LTC2949.

### **REGISTER MAP PAGE0**

### **Wake Up Acknowledge**

The LTC2949 automatically returns to SLEEP state if no wake up confirmation command is received within 1 second after entering STANDBY state. Wake up confirmation can be either writing 0x00 to register 0x70 or starting of a measurement. Before wake up confirmation, WKUPACK will report a countdown from 0xFF to 0x00 within approximately 1 second. Countdown will stop and WKUPACK will statically report 0x00 after wake up confirmation.



**Note:** When operating on top of a daisy chain, more than one dummy byte has to be send every time the isoSPI chain has to be woken up. See also 'Waking a Daisy Chain' chapters in latest cell monitor datasheets (e.g. LTC6812) for recommended procedures.

Rev A **Figure 20a. Flow Chart of Recommended Wake-Up Procedure and Example SPI Transactions for Direct and Indirect Read Scenarios**



**Figure 20b. Flow Chart of Recommended Wake-Up Procedure Implemented in a Sequence Without Polling**

### **Table 25. Wake Up Acknowledge Register (0x70)**



In applications where LTC2949 is connected on top of a daisychain, the bit BCREN in REGSCTRL must be set before being able to read from LTC2949. This is only possible after the boot sequence has finished. Polling of the SLEEP bit being cleared can still be implemented by interleaving the read of OPCTRL with a write to REGSCTRL with BCREN=1 (all other bits 0). As this scenario also implies indirect register reads via RDCV commands (for this reason RDCVCONF=0), the write to REGSCTRL can be done in a single four byte burst together with RDCVIADDR (set to 0xF0); the two bytes between RDCVIADDR and REGSCTRL set to 0x00. Thus the four bytes to be written are 0xF0,0x00,0x00,0x04 and the following RDCV command will report the content of OPCTRL. Still, if the boot sequence is not completed, LTC2949 will ignore the broadcast RDCV command and thus the master will read always 0xFF (which is also compatible with SLEEP=1), including PEC=0xFFFF if 8 bytes are read (its not necessary to read till the PEC in this case). After the boot OPCTRL will be read as 0x00.

### **Accumulated Result Registers**

The registers in [Table 26](#page-45-0) and [Table 27](#page-46-0) contain the accumulated quantities Charge, Energy and Time. The Time registers are unsigned integer values while the Charge and Energy registers are two's complement signed integer values. The value of each accumulated quantity can be determined by multiplying the respective register value with the corresponding LSB value from [Table 26](#page-45-0) (if the internal clock or crystal is used as a reference clock) or [Table 27](#page-46-0) (if an external reference clock is used).



#### <span id="page-45-0"></span>**Table 26. Accumulated Results Register Parameters for Use with Crystal or Internal Clock**

Charge1, Energy1 and Time1 contain accumulated quantities of Channel1. Charge2, Energy2 and Time2 contain accumulated quantities of Channel2. Charge3 and Time3 contain the weighted sum of charges monitored by Channel1 and Channel2 and the corresponding time. Similarly Energy4 and Time4 contain the weighted sum of energies monitored by Channel1 and Channel2 and the corresponding time.

If different sense resistors are used on CH1 and CH2, the LTC2949 uses the ratio of the sense resistors (RSRATIO) set in the Gain Configuration Registers to compute the correct weighted sums Charge3 and Energy4.

When the internal clock is used, PRE and DIV should be set to their default values which is done by writing 0x07 to register (0xE9), otherwise the values of PRE(0xE9)[2:0] and DIV(0xE9)[7:3] should be set according to section [Timebase Control.](#page-19-0)

| <b>ADDRESS</b> | <b>NAME</b> | <b>TYPE</b> | <b>DEFAULT</b> | <b>PARAMETER</b>            | LSB                                                              | <b>UNIT</b> | SI/UI     |
|----------------|-------------|-------------|----------------|-----------------------------|------------------------------------------------------------------|-------------|-----------|
| 0x00           | C1[47:0]    | <b>RW</b>   | 0x00           | Charge $1 = C1 \cdot LSBC1$ | $\vert$ LSBC1 = 1.21899e-5 • 1/fext • 2 <sup>PRE</sup> • (DIV+1) | Vs          | <b>SI</b> |
| 0x06           | E1[47:0]    | <b>RW</b>   | 0x00           | Energy1 = $E1 \cdot LSBE1$  | LSBE1 = 7.4895e-5 • 1/fext • $2^{PRE}$ • $(DIV+1)$               | $V^2S$      | SI        |
| 0x0C           | TB1[31:0]   | <b>RW</b>   | 0x00           | $Time1 = TB1 \cdot LSBTB1$  | LSBTB1 = 12.8315 • 1/fext • $2^{PRE}$ • (DIV+1)                  | s           | UI        |
| 0x10           | C2[47:0]    | <b>RW</b>   | 0x00           | Charge $2 = C2 \cdot LSBC2$ | LSBC2 = 1.21899e-5 • 1/fext • $2^{PRE}$ • (DIV+1)                | Vs          | <b>SI</b> |
| 0x16           | E2[47:0]    | <b>RW</b>   | 0x00           | Energy $2 = E2 \cdot LSBE2$ | LSBE2 = 7.4895e-5 • 1/fext • $2^{PRE}$ • (DIV+1)                 | $V^2S$      | SI        |
| 0x1C           | TB2[31:0]   | <b>RW</b>   | 0x00           | $Time2 = TB2 \cdot LSBTB2$  | LSBTB2 = 12.8315 • 1/fext • $2^{PRE}$ • (DIV+1)                  | S           | UI        |
| 0x24           | C3[63:0]    | <b>RW</b>   | 0x00           | Charge $3 = C3 \cdot LSBC3$ | LSBC3 = 1.21899e-5 • 1/fext • $2^{PRE}$ • (DIV+1)                | Vs          | <b>SI</b> |
| 0x2C           | TB3[31:0]   | <b>RW</b>   | 0x00           | $Time3 = TB3 \cdot LSBTB3$  | LSBTB3 = 12.8315 • 1/fext • $2^{PRE}$ • (DIV+1)                  | S           | UI        |
| 0x34           | E4[63:0]    | <b>RW</b>   | 0x00           | Energy $4 = E4 \cdot LSBE4$ | LSBE4 = 7.4895e-5 • 1/fext • $2^{PRE}$ • $(DIV+1)$               | $V^2$ s     | <b>SI</b> |
| 0x3C           | TB4[31:0]   | <b>RW</b>   | 0x00           | $Time4 = TB4 \cdot LSBTB4$  | LSBTB4 = 12.8315 • 1/fext • $2^{PRE}$ • (DIV+1)                  | S.          | UI        |

<span id="page-46-0"></span>**Table 27. Accumulated Results Register Parameters for Use with External Clock**

Note: Values of PRE and DIV should be calculated according to [Timebase Control](#page-19-0) section.

For instance, an external clock frequency of 10MHz would require values PRE to be set to 4 and DIV to be set to 19. With  $f_{\text{EXT}}=10$ MHz, LSBC1 is calculated as 390.078e-12 VS. To get the Charge1 value, the register content of C1 is multiplied with LSBC1. In this case, a C1 register value of 0x 75 5A 10 or 7690768 and the resulting Charge1 is 0.003 VS. For a sense resistor of 300µΩ this corresponds to 10As.

LSB values may be calculated easily using the Quick Eval software for the LTC2949 or by using the C/C<sup>++</sup> header files provided in the code section of the LTC2949 (see LTC2949 evaluation board DC2732A manual for details). The registers for Charge, Energy and Time can be preset to a non-zero initial value. In Continuous Mode all bytes of the respective quantity must be written in the same multi-byte transaction or while the memory is locked.

### **Non-Accumulated Result Registers**

Registers in [Table 28](#page-46-1) contain measured values of Currents, Powers, Voltages, Temperatures, VCC and VREF. All quantities are represented as two's complement signed integer values.

Current 1 represents the differential voltage sensed between CF1P and CF1M. Current 2 represents the differential voltage sensed between CF2P and CF2M. Battery voltage (BAT) is the differential voltage across pins VBATP and VBATM. Power 1 is the instantaneous multiplication of BAT and current 1. Power 2 is the instantaneous multiplication of BAT and current 2. Temperature is the temperature of the on-silicon temperature sensor. VCC is the voltage across pins A/DVCC and AGND. Registers SLOT1 and SLOT2 contain the results of the two multiplexer inputs choosen according to [Table 58](#page-58-0) and can be configured to give out voltage or temperature by means of the NTC Configuration Registers [\(Table 70\)](#page-63-0). VREF is the voltage across pins VREF and AGND. The moving average of the four preceding current measurements are stored in I1AVG and I2AVG. The values of these four current measurements are retained in the Current History registers; Current 1 History 1 is the result prior to Current 1, Current 1 History 2 is the current result prior to Current 1 History 1, and so on. All measured values are scaled with the LSB values from  [.](#page-47-0) To calculate the physical value of the measured parameter, multiply the register value by the appropriate LSB value.

| <b>ADDRESS</b> | <b>NAME</b> | <b>TYPE</b>    | <b>DEFAULT</b> | <b>PARAMETER</b>           | LSB    | <b>UNIT</b> | SI/UI |
|----------------|-------------|----------------|----------------|----------------------------|--------|-------------|-------|
| 0x90           | 11[23:0]    | R <sub>0</sub> | 0x00           | Current 1                  | 950    | nV          | SI    |
| 0x93           | P1[23:0]    | R <sub>0</sub> | 0x00           | Power 1 (Power, P1ASV = 0) | 5.8368 | $\mu[V^2]$  | SI    |
|                |             |                |                | Power 1 (Voltage, P1ASV=1) | 46.875 | uV          | SI    |
| 0x96           | 12123:01    | R <sub>0</sub> | 0x00           | <b>Current 2</b>           | 950    | nV          | SI    |

<span id="page-46-1"></span>**Table 28. Non-Accumulated Results Register Parameters**

<span id="page-47-0"></span>

The FIFO registers 0xF7 to 0xFA allow to read conversion results in fast continuous mode. When reading from those registers, the internal address auto-increment stops, allowing to read any number of bytes the fixed addresses. For each sample, three bytes have to be read which are MSB, LSB and TAG, see also fast mode section and below description for more details.

In Fast Mode, ADC conversion results turn negative when exceeding positive and clip when exceeding negative full-scale values. In Slow Modes, ADC conversion results clip when exceeding positive and negative full-scale values. Full-scale values are always beyond the specified input range.

Registers I1AVG (0x9C) and I2AVG (0xAC) are copied to registers 0xB0 and 0xC0, respectively. Thus, 0x9C-0x9E will report the same values as 0xB0-0xB2 and 0xAC-0xAE will report the same values as 0xC0-0xC2.



#### **Table 29. FIFO Register Read Format.**

The column Data Byte does not count the PEC bytes, which depend on the setting of data bytes per PEC (ID-byte for DCMD or fixed to six for RDCV). For maximum data throughput it is recommended to read the FIFOs with DCMDs with 16 bytes per PEC and multiples of 16 samples  $(= 48$  data bytes  $+ 3 \cdot 2$  PEC bytes).

#### **Table 30. FIFO TAG Definitions.**



It is recommended to connect LTC2949 always in parallel to a daisy chain. Also, in the scenario where LTC2949 is connected at one end of a reversible isoSPI chain, the default communication should be done with direct read commands. Only in case the direct isoSPI link to LTC2949 fails, the communication would be routed through the daisy chain.

In this configuration where LTC2949 is on top of a daisy chain, after the broadcast RDCV command, the stacked LTC68xx Cell Monitors turn into a cascaded shift register, in which data is shifted through each device to the next device in the stack. In this scenario, at the end of the read transaction, there is always a fixed number of samples stuck in the shift register, that is never transmitted to the master.

Several approaches are possible to avoid or minimize the loss of samples. Either fast continuous mode is stopped (FACONV=0), the FIFO is read until empty and then fast continuous measurement is repeated (FACONV=1). This results in a time window without measurements, equal to the time it takes to read the samples. For example, at 1Mbit/s serial clock rate, it takes 0.8 ms (approximately one fast conversion time) to read 24 samples (four byte command and PEC, 72 data bytes, 24 data PEC bytes equals in total 100 bytes or 800 bits). For lower clock speeds or longer cycle times, where more samples are read per cycle, the following approach is more efficient.

Alternatively, the FIFO read burst must be long enough to always empty the FIFO and read at least one sample with TAG RDOVR. Still, also here, one sample with TAG OK can arrive after the RDOVR and would then be stuck in the daisy chain's shift register. If the latency of the shift register (number of devices in the daisy chain times eight bytes times eight bit per byte divided by SPI clock speed) is longer than one fast conversion time, even more than one sample can get stuck in the daisy chain.

## **Tracking Registers**

The tracking registers keep track of the maximum and minimum values of previous conversions since the last reset. Value scaling is done in the same manner as the non-accumulated register values, using LSB values from [Table 31](#page-49-0). Negative values are treated as smaller (more minimum) than positive values as the minimum registers are updated.

For example: A register value  $11MAX(0x40.0x41)$  of 0000 0001 1111 0100b = 01 F4h = 500d indicates a resulting maximum sense resistor signal of 500 • 3.8µV = 1.9mV. A register value I1MIN(0x42,0x43) of 1111 1010 0010 0100b = FA 24h = –1500d indicates a minimum sense resistor signal of –1500 • 3.8µV = –5.7mV. The calculation of the other tracked parameter values is done the same way with their corresponding LSB values.



<span id="page-49-0"></span>**Table 31. Tracking Registers**

Note that the tracking registers for current and power report only the 16MSBs of the respective 18-bit result registers, leading to a four times larger LSB value.

## **STATUS, (EXT)FAULTS, Threshold and Overflow Alert Registers**

The registers described in the following chapters are used to signal certain events, like a voltage threshold violation, charger or energy overflow, supply undervoltage events and others. After power-up it is recommended to lock the memory, read STATUS, FAULTS and EXTFAULTS registers, check for the default values, clear them and finally unlock the memory. During normal operation those registers shall be checked periodically to be all zero, except for the UPDATE bit. Any other value indicates a failure.

Any bits in the STATUS, alerts (0x81-0x87), FAULTS and EXTFAULTS registers are only set to 1 by LTC2949 in case of an event, but never cleared automatically. After the master reads some bits being set, actions should be taken (e.g. to clear the charge register in case of a charge overflow), the memory must be locked (see REGSCTRL), the registers should be read again as other events may have occurred in the meantime, registers that or not 0x00 must be written to 0x00 and finally the memory must be unlocked to proceed with normal operation.

It is not recommended to write those registers without usage of the memory lock, as this may lead to loss of failure and alert reports.

### **Status and Fault Registers**

The STATUS register reports the status of register updates, undervoltage lockout, and reference clock errors. On power up, all undervoltage lockouts and the power-on reset are set to 1. After exit from shutdown, bits UVLOA and UVLOD are set. UPDATE is set to 1 when the LTC2949 has finished a measurement cycle and updated the result registers, the accumulation registers, and the tracking registers.

ADCERR is set to 1 if the supply voltage at AVCC is too low for a proper operation of the ADCs. The values in the result registers are not valid and should be discarded if ADCERR is set. TBERR is set to 1 if the internal time base overflows. This indicates an incorrect setting of the values PRE and DIV with respect to the external clock at CLKI. The values of accumulated results registers should be discarded if TBERR is set.





LTC2949 has several types of internal memory that are checked during boot-up via built-in self-test (BIST) routines. Errors in individual blocks are reported by the EXTFAULTS and FAULTS registers. The FAULTS register additionally reports error in the internal (on-chip) and external (from master to slave on the SPI/isoSPI interface) communication and indicates thermal shutdown and fast channel error events.

#### **Table 33. EXTFAULTS (0xDC)**



**Table 34. FAULTS (0xDD)**



### **Threshold and Overflow Alert Registers**

Threshold and overflow alert registers are set when the respective threshold values are exceeded or when registers overflow. Thresholds are set in the [Threshold Registers](#page-61-0) section.

The accumulated quantities are continuously checked against guard values to warn that a register is nearing overflow, nominally set to 90% of each register's maximum value. When any quantity crosses its guard threshold, the LTC2949 sets the corresponding overflow bit in the status register, generates an alert (if enabled) and continues accumulation. At the maximum voltage inputs, rollover typically happens several hours after an overflow alert is signaled, allowing the host time to take action to avoid data loss, by reading and clearing the concerned accumulators using the memory locking procedure. The overflow thresholds for 32-bit quantities (time) are 3865470565 LSB; for 48-bit quantities (charge and energy) is ±126663739519794 LSB.

The threshold and overflow comparators for accumulated quantities charge, energy and time use a floating point format internally. This can appear to cause slight bit-level comparison discrepancies, but the comparisons between accumulated result registers and their respective threshold registers will always have an accuracy of better than 0.001%.

An alert condition needs to be present for at least for 200ms to be reported by the alert registers (0x81-0x87). Only overcurrent conditions detected by either OCC1 or OCC2 can be signaled to the host within some µs by stopping heart beat on GPIO5.

To acknowledge and release an overcurrent alert the following steps can be performed:

- 1. Stop the overcurrent event
- 2. Lock the memory
- 3. Read STATUS-STATVCC, (EXT)FAULTS for any newly arrived error flags (including the asserted OCCx bits)
- 4. Clear STATUS-STATVCC, (EXT)FAULTS
- 5. Unlock the memory
- 6. Heartbeat on GPIO5 will start again

### **Table 35. Voltage, Temperature Threshold Alerts STATVT (0x81)**



### **Table 36. Current, Power Threshold Alerts STATIP (0x82)**



### **Table 37. Charge Threshold Alerts STATC (0x83)**



#### **Table 38. Energy Threshold Alerts STATE (0x84)**



#### **Table 39. Charge, Energy Overflow Alerts STATCEOF (0x85)**



#### **Table 40. Time Base Alerts STATTB (0x86)**



#### **Table 41. VCCOCC Threshold Alerts STATVCC (0x87)**



Note: The memory must be locked to clear status (0x80), faults (0xDC-0xDD) and alert (0x81-0x87) registers to avoid missing of any failure and alert reports. See REGSCTRL description for details.

### **Mask Registers**

The mask registers control which alerts stop heartbeat. If a mask register bit is reset to 0, exceeding of the respective threshold causes the heartbeat on GPIO4 pin to stop, if the latter is configured accordingly in the GPIO4HBCTRL register.

When a bit of the Status Mask Register (STATUSM) is set to 0, the corresponding bits of register STATUS (0x80) will stop heartbeat. When a bit of the status mask register is set to 1, heartbeat is unaffected by the corresponding bits of register STATUS (0x80).



### **Table 42. Status Mask STATUSM (0x88)**

When bits of STATVTM are set to 0, corresponding bits of register STATVT (0x81) will stop heartbeat. When a bit of STATVTM is set to 1, heartbeat is unaffected by the corresponding bits of register STATVT (0x81).

**Table 43. Voltage, Temperature Threshold Alert Mask STATVTM (0x89)**

| <b>BIT</b> | <b>SYMBOL</b> | <b>TYPE</b> | <b>DEFAULT</b> | <b>OPERATION</b>            |
|------------|---------------|-------------|----------------|-----------------------------|
|            | BATHM         | <b>RW</b>   |                | Mask BATH of STATVT(0x81)   |
|            | BATLM         | <b>RW</b>   |                | Mask BATL of STATVT(0x81)   |
| 2          | TEMPHM        | <b>RW</b>   |                | Mask TEMPH of STATVT(0x81)  |
| 3          | <b>TEMPLM</b> | <b>RW</b>   |                | Mask TEMPL of STATVT(0x81)  |
| 4          | SLOT1HM       | <b>RW</b>   |                | Mask SLOT1H of STATVT(0x81) |
| 5          | SLOT1LM       | <b>RW</b>   |                | Mask SLOT1L of STATVT(0x81) |
| 6          | SLOT2HM       | <b>RW</b>   |                | Mask SLOT2H of STATVT(0x81) |
|            | SLOT2LM       | <b>RW</b>   |                | Mask SLOT2L of STATVT(0x81) |

When bits from STATIPM are set to 0, bits from register STATIP(0x82) will stop heartbeat. When a bit of STATIPM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATIP(0x82).

| <b>BIT</b>     | <b>SYMBOL</b>     | <b>TYPE</b> | <b>DEFAULT</b> | <b>OPERATION</b>          |
|----------------|-------------------|-------------|----------------|---------------------------|
| 0              | <b>I1HM</b>       | <b>RW</b>   |                | Mask I1H of STATIP (0x82) |
|                | <b>I1LM</b>       | <b>RW</b>   |                | Mask I1L of STATIP (0x82) |
| ŋ              | P1HM              | <b>RW</b>   |                | Mask P1H of STATIP (0x82) |
| 3              | P <sub>1</sub> LM | <b>RW</b>   |                | Mask P1L of STATIP (0x82) |
| $\overline{4}$ | I2HM              | <b>RW</b>   |                | Mask I2H of STATIP (0x82) |
| 5              | I2LM              | <b>RW</b>   |                | Mask I2L of STATIP (0x82) |
| 6              | P2HM              | <b>RW</b>   |                | Mask P2H of STATIP (0x82) |
|                | P2LM              | <b>RW</b>   |                | Mask P2L of STATIP (0x82) |

**Table 44. Current, Power Threshold Alert Mask STATIPM (0x8A)**

When bits from STATCM are set to 0, bits from register STATC(0x83) will stop heartbeat. When a bit of STATCM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATC(0x83).

| BIT | <b>SYMBOL</b>     | <b>TYPE</b> | <b>DEFAULT</b> | <b>OPERATION</b>         |
|-----|-------------------|-------------|----------------|--------------------------|
|     | C1HM              | <b>RW</b>   |                | Mask C1H of STATC (0x83) |
|     | C <sub>1</sub> LM | <b>RW</b>   |                | Mask C1L of STATC (0x83) |
|     | C2HM              | <b>RW</b>   |                | Mask C2H of STATC (0x83) |
|     | C <sub>2</sub> LM | <b>RW</b>   |                | Mask C2L of STATC (0x83) |
| 4   | C3HM              | <b>RW</b>   |                | Mask C3H of STATC (0x83) |
|     | C3LM              | <b>RW</b>   |                | Mask C3L of STATC (0x83) |

**Table 45. Charge Threshold Alerts Mask STATCM (0x8B)**

When bits from STATEM are set to 0, bits from register STATE(0x84) will stop heartbeat. When a bit of STATEM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATE(0x84).

#### **Table 46. Energy Threshold Alerts Mask STATEM (0x8C)**



When bits from STATCEOFM are set to 0, bits from register STATCEOF(0x85) will stop heartbeat. When a bit of STAT-CEOFM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATCEOF(0x85).

**Table 47. Charge, Energy Overflow Alerts Mask STATCEOFM (0x8D)**

| <b>BIT</b> | SYMBOL | <b>TYPE</b> | <b>DEFAULT</b> | <b>OPERATION</b>             |
|------------|--------|-------------|----------------|------------------------------|
|            | C10FM  | <b>RW</b>   |                | Mask C10VF of STATCEOF(0x85) |
|            | C20FM  | <b>RW</b>   |                | Mask C20VF of STATCEOF(0x85) |
|            | C30FM  | <b>RW</b>   |                | Mask C30VF of STATCEOF(0x85) |
| 4          | E10FM  | <b>RW</b>   |                | Mask E10VF of STATCEOF(0x85) |
|            | E20FM  | <b>RW</b>   |                | Mask E20VF of STATCEOF(0x85) |
|            | E40FM  | <b>RW</b>   |                | Mask E40VF of STATCEOF(0x85) |

When bits from STATTBM are set to 0, bits from register STATTB (0x86) will stop heartbeat. When a bit of STATTBM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATTB (0x86).



### **Table 48. Time Base Alerts STATTBM (0x8E)**

When bits from STATVCCM are set to 0, bits from register STATVCC (0x87) will stop heartbeat. When a bit of STATVCCM register is set to 1, heartbeat is unaffected by the corresponding bits of register STATVCC (0x87).

#### Table 49. V<sub>CC</sub> Threshold Alerts STATVCCM (0x8F)



Note that the bits reporting the result of the overcurrent comparators OCC1 and OCC2 in STATVCC (0x87) do not have a corresponding mask bit in STATVCCM. Therefore the impact of OCC1 and OCC2 on heartbeat either on GPIO4 or GPIO5 cannot be masked. If overcurrent comparison is not desired the enable bit in OCCxCTRL has to be cleared (default).

### **Control Registers**

The control registers select the multiplexer input, control the accumulation of charge, energy and time, configure the GPIO pins, set the overcurrent comparator thresholds, and setup the timebase if an external clock is used.

The Overcurrent Control Registers allow to set the overcurrent comparator thresholds and deglitch filters, see also the [Overcurrent Comparators](#page-20-0) section.

#### **Table 50. OCC1CTRL (0xDE)**



#### **Table 51. OCC2CTRL (0xDF)**



The Accumulator Control and Deadband Registers allow to control the accumulation of Charge1, Energy1, Charge2, Energy2, Charge3 and Energy4 (C1, E1, C2, E2, C3, E4). Accumulation can be enabled, disabled or conditionally enabled based on the sign and absolute value of a measured current. C1 contains accumulated I1, C2 contains accumulated I2, E1 contains accumulated P1 and E2 contains accumulated P2. C3 contains the accumulated sum of I1 and I2 weighted by the gain setting parameters (see [Gain Configuration Registers](#page-64-0) section) and E4 the accumulated weighted sum of P1 and P2.

For example, by setting bit 0 of the ACCCTRL1 and bit 1 of ACCCTRL2, C1 contains the accumulation of positive currents I1 and C3 contains the accumulation of negative currents.



### **Table 52. Accumulator Control ACCCTRL1(0xE1)**

### **Table 53. Accumulator Control ACCCTRL2(0xE2)**



Small offset voltages in the current measurement path lead to large charge errors after a long integration time. The accumulator dead band registers allow to set a minimum absolute value of I1 and I2 before being accumulated.

#### **Table 54. Accumulation Dead Band ACCIDB1(0xE4)**



#### **Table 55. Accumulation Dead Band ACCIDB2(0xE5)**



The Time Base Control Register selects between the internal and an external reference clock, and sets the time base parameters when an external reference clock is used. Set PRE[2:0] = 111b or 7d (default) to enable the internal reference clock. To use an external reference clock, set the values of PRE[2:0] and DIV[4:0] according to the external clock frequency; see the [Timebase Control](#page-19-0) section for more information.



### **Table 56. Timebase Control TBCTRL (0xE9), DEFAULT VALUE: 0x07**

The multiplexer inputs are selected by the Multiplexer Control Registers. For each of the multiplexer outputs MUXP and MUXN, a 5-bit word selects the connected input.

#### <span id="page-57-0"></span>**Table 57. MUX Settings**



In slow, high precision mode the auxiliary channel (CHAUX) converts in Round Robin mode two differential inputs signals. For each of the two slots, the inputs multiplexed to MUXP and MUXN can be chosen by programming the corresponding 5-bit setting in the following four registers.

In fast mode, the auxiliary channel (CHAUX) converts only one differential input signal, which can be chosen by choosing the corresponding 5-bit setting in the Fast MUXP and MUXN Control registers.

During fast continuous measurements it is not possible to change the AUX MUX configuration. See note in chapter 'Fast Measurement Timings'.



#### <span id="page-58-0"></span>**Table 58. Multiplexer Control Registers in Slow Mode**

#### **Table 59. Multiplexer Control Registers for Fast Mode**



The Fast Control Register allows to configure and trigger fast conversions.

There is a timing constraint when writing to FGPIOCTRL and FACTRL, see description for FGPIOCTRL.

#### **Table 60. Fast Control Register FACTRL (0xF5)**



The GPIO control registers allow to configure the GPIO pins to be either tristate, low, high or toggling at 400kHz by setting the corresponding GPIO CTRL bits in 0xF1 and 0xF2.

GPIO4 and GPIO5 can be used as heartbeat pins toggling with a frequency of 400kHz and become static low upon an alert. While GPIO5 is activated by enabling any of the overcurrent comparators and is dedicated to alerts issued by these comparators, GPIO4 can be configured by the GPIO4 heartbeat control register (0xE8) to respond on any alert not masked by the mask registers. The setting in the GPIO4 heartbeat control register overrules the GPIO4CTRL setting in 0xF2. Similarly GPIO5CTRL setting in 0xF1 is overruled by enabling the overcurrent comparators.



### **Table 61. GPIO4 Heartbeat Control GPIO4HBCTRL (0xE8)**

#### **Table 62. Current Source and GPIO5 Control FCURGPIOCTRL (0xF1)**



The 250μA current sources at MUXP and MUXN allow open wire detection at all multiplexer inputs. If enabled, the current sources connect to the inputs during the time the ADC is connected and performs the conversion, no matter if it is the fast or slow channel. Typically, open wire detection is performed using the fast channel by first writing current source, GPIO and MUX control (4-byte write to 0xF1-0xF4), triggering the fast conversion by sending the ADCV, reading the results with RDCV and finally by writing again 4 bytes to 0xF1-0xF4 to set the next MUX input and current source configuration. This way, the time when current sources are enabled on a dedicated pin, is precisely timed. See the safety manual for more information.

Enabled current source on MUXP will alter the internal measurement of VREF (~4V/~0.7V when MUXPCURPOL = 1 / 0) and this change won't be visible on the external VREF pin. If enabled, also the NTC temperature measurement and the compensation of a shunt resistor's temperature drift will be altered, as they depend on the internal VREF measurement. The correct VREF voltage can always be measured via an external connection to one Vx pin, see also section Unused Input Pins V1-V12.

#### **Table 63. GPIO Control FGPIOCTRL (0xF2)**



If set to tristate, the GPIO pins can be used as analog inputs (V8-V12) to the auxiliary channel by choosing the corresponding multiplexer settings according to [Table 57.](#page-57-0)

Write to register FCURGPIOCTRL does not take effect immediately. Instead any changes will only become active once FGPIOCTRL is written. Thus it is recommended to always write both registers in a single burst.

Additionally there is a timing constraint when writing to FGPIOCTRL and FACTRL. Writing to those registers must always be delayed by a minimum of 1ms. Thus, its not allowed to write FGPIOCTRL and FACTRL in a single burst. Usually this can be easily achieved by partitioning code sections properly that control those registers.

#### **Table 64. RDCV Indirect Address (0xFC)**



The following register is provided for software debug purposes only. It allows synchronization of the host controller to the CORE system tick. DBGCNT is reset by the CORE after the last register of memory page 0 was updated. This happens typically 23ms after the end of a slow mode current/power conversion (EOC of I1, I2, P1, P2).

#### **Table 65. DBGCNT (0xD5)**



## **REGISTER MAP PAGE1**

PAGE1 of the LTC2949 register map contains threshold and configuration registers. The threshold registers allow to set threshold values for each measured quantity. The configuration registers allow to store application and board specific parameters and settings, which usually do not need to be modified during operation.

### **Software Reset**

The LTC2949 has a software reset feature, described in following table.





### <span id="page-61-0"></span>**Threshold Registers**

The threshold registers set threshold values for each measured quantity. When a measured value exceeds its threshold, an alert is triggered and the corresponding bits in the threshold and overflow alert registers (0x81 to 0x87) are set. When GPIO4 heartbeat is enabled in register GPIO4HBCTRL (0xE8), unmasked alerts in registers (0x88 to 0x8F) stop heartbeat on GPIO4. Value scaling is done in the same manner as in the corresponding result register values, using LSB values from [Table 26](#page-45-0), [Table 27](#page-46-0) and [Table 28. Non-Accumulated Results Register Parameters](#page-46-1).

#### **Table 67. Threshold Registers**





### **FLOAT24 Format**

The NTC configuration parameters and the gain correction factors described in the following paragraphs are stored as floating point numbers represented by the FLOAT24 format according to IEEE 754 standard. The LTC2949 implementation uses 1-bit for sign, a 7-bit exponent in two's complement format with 63 as bias and 16-bits for the mantissa, with an implicit leading bit of value 1 unless the exponent is stored with all zeros. As an example the value of 0.95 is represented by the 3 bytes number 0x3EE666 as shown below:

#### **Table 68. FLOAT24 Example**



 $= 0.5 \cdot 1.899994 = 0.94999$ 

The GUI controlling the LTC2949 demo board supports converting numbers to FLOAT24. The code section of the LTC2949 (https://www.analog.com/en/products/ltc2949.html#product-tools) also provides conversion functions written in C/C<sup>++</sup> for this purpose.

LTC2949.cpp contains following conversion functions:

```
void LTC2949_FloatToF24Bytes(float f32, byte* bytes)
```

```
void LTC2949_F24BytesToFloat(byte* bytes, float* f32)
```
### **Configuration Registers**

The following registers allow to configure LTC2949 application specific. Please note that LTC2949 must be in STANDBY and an update of these registers must be requested by setting the ADJUPD bit in the Operation Control Register (OPC-TRL) to make changes effective.

### **ADC Configuration Register**

The ADC Configuration Register allows to disable power multiplication on P1ADC and P2ADC, and to turn on NTC linearization of Slot1/2 measurements.



#### **Table 69. ADC Configuration ADCCONF (p1.0xDF)**

See [NTC Configuration Registers](#page-64-1) and section [Temperature Measurement](#page-67-0) for more information regarding NTC temperature measurement.

See [Table 28](#page-46-1) and [Table 31](#page-49-0) for effect of P1ASV/P2ASV on LSB sizes or Power-ADC related measurements/settings.



#### <span id="page-63-0"></span>**Table 70. Allowed Combinations of FACTRL and ADCVCONF (PxASV) Configurations.**

a) Any fast single shot measurement will interrupt the slow channel measurements. Slow channel will only resume to be updated if there was no fast single shot measurement for at least 160ms.

b) 15-bit Fast BAT (VBATP-VBATM) voltage measurement via one power ADC. It is always possible to measure VBATP-VBATM via AUX ADC in fast (FACHA=1) or slow mode.

Rev A c) Power ADCs (PxASV=0) of channels configured to fast mode will provide 11-bit conversions at an update rate of 100ms via P1/P2 registers. The LSB size stays the same, but the resolution in this case is only guaranteed to be 11-bit.

### <span id="page-64-1"></span>**NTC Configuration Registers**

When bits NTC1 and NTC2 in the ADC Configuration Register are set, LTC2949 reports the result of the corresponding CHAUX slot in temperature by comparing NTC resistance to reference resistors and solving Steinhart-Hart equations. The NTC Configuration Registers allow to set values of Steinhart-Hart coefficients (A,B,C) and reference resistors.

Furthermore, linear temperature coefficients of up to two external sense resistors can be compensated by thermally closely coupled NTC thermistors. Temperature compensation is enabled by writing the respective temperature coefficient and its reference temperature  $(T_0)$  in the NTC Configuration Register. See section [Temperature Measurement](#page-67-0) and [Sense Resistor Temperature Compensation](#page-68-0) for more details.



#### <span id="page-64-2"></span>**Table 71. NTC Configuration Registers**

Note that for the two 16-bit registers storing reference temperature RS1T0 and RS2T0 the least significant byte (LSB) of the mantissa is implicitly 0

### <span id="page-64-0"></span>**Gain Configuration Registers**

The LTC2949 can store gain correction factors for two current sense resistor, the battery voltage divider and four multiplexer inputs to compensate tolerances of external components in its Gain Setting Registers located between 0xB0 and 0xCF on measured page 1 of the register map. When these factors are set different than their default value of 1.0, the LTC2949 corrects the computed values of current, voltage, power, charge and energy accordingly. As the LTC2949 accumulators can be configured to compute the sums of charge and energy flown through two sense resistors, also the nominal ratio between the two sense resistors RSRATIO =  $R_{S1}/R_{S2}$  can be stored. The LTC2949 then multiplies the measurements of CH2 (I2, P2) by RSRATIO before adding them to the sum of charge (C3) or energy (E4). All these factors are stored in the Float24 format according to IEEE 754 standard described earlier.



### **Table 72. Gain Configuration Registers**



**Table 72. Gain Configuration Registers (continued)**

As an example, if a sense resistor of nominal 100 $\mu\Omega$  is used for CH1, but a board calibration reveals the sense resistor value to be 102μΩ, a factor of 100/102 = 0.9804 should be written to RS1GC [23:0] = float24(0.9804) = 0x3EF5F5.

Assuming a sense resistor of nominal value 10mΩ but real value of 9.8mΩ is used for CH2 the factor 1.024 should be programmed in RS2GC [23:0] = float24(1.024) = 0x3F0624 and a factor 0.01 should be programmed in RSRATIO[23:0]  $=$  float24(0.01) = 0x3847AE.

In many applications the LTC2949 measures high voltages using external resistor dividers which suffer from gain errors due to resistor tolerances. The LTC2949 allows to store gain correction factors for the measurement of battery voltage and four programmable MUX settings. E.g.: The LTC2949 will apply gain correction of 0.9 to differential measurements between V1 and V2 if registers MUX1GC[23:0] = 0x3ECCCC, MUXPSET1[7:0] = 0x01 and MUXNSET1[7:0]  $= 0x02$ , see also [Table 57](#page-57-0).

The assignment between MUX[1-4]GC and MUX[P,N]SET[1-4] is independent of the polarity of the MUX settings. Related to the example above the same gain correction is applied for measurements V1-V2 and V2-V1. Also swapping the register values of MUXPSET1 and MUXNSET1 leads to the same behaviour. The link between gain correction parameters and measurements is summarized in [Table 73](#page-65-0).

All Gain Configuration Registers can be copied to an external EEPROM, enabling a modular approach to factory calibration of application boards.

<span id="page-65-0"></span>

| <b>NAME</b> | AFFECTED MEASUREMENTS                                                                                                                                         |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BATGC       | BAT for slow and fast measurements                                                                                                                            |
|             | P1, P2, E1, E2, E4                                                                                                                                            |
|             | SLOT[1,2] AUX measurements if SLOT[1,2]MUX[P,N] is set to VBATP, VBATM of any polarity                                                                        |
|             | Fast AUX conversions if FAMUX[P,N] is set to VBATP, VBATM of any polarity                                                                                     |
| MUX[1-4]GC  | Slow and fast AUX measurements if SLOT[1,2]MUX[P,N] or FAMUX[P,N] matches MUX[P,N]SET[1-4] of any polarity                                                    |
| RS[1,2]GC   | 11, 12, P1, P2, C1, C2, C3, E1, E2, E4                                                                                                                        |
| RSRATIO     | C3, E4 (Note: The charge that is accumulated to C3 is (I1 + RSRATIO • I2) • dT, the energy that is accumulated to E4 is<br>$(P1 + RSRATIO \cdot P2) \cdot dT$ |

**Table 73. Relation Between Gain Correction Parameters and Measurements**

### **External EEPROM Control Register**

To prevent data loss when the LTC2949 is not powered, it can store its entire register content in an external EEPROM via its dedicated I2C interface. The communication to an EEPROM is controlled by the EEPROM Control Register (EEPROMCTRL).

| <b>BIT</b> | <b>SYMBOL</b>     | <b>TYPE</b>   | <b>DEFAULT</b> | <b>OPERATION</b>                        | <b>DURATION</b>  |
|------------|-------------------|---------------|----------------|-----------------------------------------|------------------|
| υ          | INIT              | <sub>SO</sub> |                | Write signature to EEPROM               | 40 <sub>ms</sub> |
|            | CHECK             | <sub>SO</sub> |                | Check the signature in EEPROM           | 25ms             |
|            | SAVE              | <sub>SO</sub> |                | Save MEM (but special row) to EEPROM    | 1100ms           |
|            | <b>RESTORE</b>    | <sub>SO</sub> |                | Restore EEPROM to MEM (but special row) | 1250ms           |
|            | <b>INITRSL</b>    | <b>RW</b>     |                | <b>Result of INIT</b>                   |                  |
|            | <b>CHECKRSL</b>   | <b>RW</b>     |                | <b>Result of CHECK</b>                  |                  |
|            | <b>SAVERSL</b>    | <b>RW</b>     |                | <b>Result of SAVE</b>                   |                  |
|            | <b>RESTORERSL</b> | <b>RW</b>     |                | <b>Result of RESTORE</b>                |                  |

**Table 74. EEPROM Control Register EEPROMCTRL (p1.0x50)**

The lower 4-bits of the EEPROMCTRL are SET ONLY and trigger dedicated communications with the EEPROM, while the higher 4-bits are read/write and are set by the LTC2949 after the typical time given in the column Duration upon a successful termination of a communication and must be reset by a write command from the host before the next communication is requested.

Before any other interaction, the EEPROM must be initialized by setting the INIT bit, which causes LTC2949 to write a defined signature to the EEPROM. Once the signature is written, LTC2949 will reset the INIT bit and set the INITRSL bit if the EEPROM has acknowledged according to the I<sup>2</sup>C protocol. Any other interaction with the EEPROM will be preceded by reading and checking this signature – additionally the signature can be checked by setting bit CHECK and verifying that bit CHECKRSL is set after bit CHECK was reset by LTC2949.

Setting bit SAVE causes the LTC2949 to save its entire memory except the last common row of both register pages to the EEPROM together with a CRC calculated from the entire register content. LTC2949 signals a successful save operation by setting bit SAVERSL, based on the check of the signature and the acknowledge of the EEPROM.

Setting bit RESTORE causes the LTC2949 to copy the content of the EEPROM to its internal RAM, calculate the CRC and set bit RESTORERSL if the CRC was found correct.

Any communication with the external EEPROM requires the LTC2949 to be in STANDBY mode to prevent data loss or data corruption.

Many applications require to store additional custom data, e.g. serial number. The reserved registers p1.0x1C - p1.0x1F (4 bytes) and p1.0x3C - p1.0x3F (4 bytes) can be used for that purpose. Additionally, registers of LTC2949 that do not require a board specific initialization and thus are initialized by the host controller, can be used to store custom data. For example, all accumulators are either just initialized with zero or via some state-of-charge algorithm. All threshold values are typically hard coded or initialized by some higher instance in the system. Mux setting registers are adjusted programmatically. Min/max tracking registers can be initialized by the host controller. The register map shown in Figure 18 gives an overview of those registers. Using all of them allows to increase the number of custom data bytes to 240 bytes.

To access this data the host commands an EEPROM RESTORE, reads all registers with custom data and initializes the registers afterwards to their desired value.



**Figure 21. EEPROM Connection. Recommended 4k Bit Automotive Qualified EEPROM with Internal EEC: M24C04-A125 from STMicroelectronics or without Internal EEC: AT24C04C or 24AA04 from Microchip.**

# APPLICATION INFORMATION

### <span id="page-67-0"></span>**TEMPERATURE MEASUREMENT**

The LTC2949s high impedance inputs V1-V12 can be used to measure temperature by means of thermistors and a reference resistor as shown below.

When bits NTC1 or NTC2 in the ADC Configuration Register are set, LTC2949 reports the result of the corresponding CHAUX slot in slow high precision mode in temperature by comparing the resistance of a thermistor (NTC)  $R_{NTC}$  to a reference resistor and solving the Steinhart-Hart equation.

$$
\frac{1}{T} = A + B \cdot \ln R_{NTC} + C \cdot (\ln R_{NTC})^3
$$

The value of the reference resistor  $R_{REF}$  and the Steinhart-Hart coefficients (A, B, C) need to be stored in the NTC Configuration Registers. Steinhart-Hart coefficients are commonly specified parameters provided by thermistor manufacturers or can be deduced from provided resistance tables.

The following table shows the relevant registers from the NTC configuration register for the application shown in [Figure 22](#page-67-1).

As VREF is measured with the same ADC as V1-V12, imperfections of VREF and gain error of the ADC do not impact the temperature measurement accuracy.



<span id="page-67-1"></span>**Figure 22. Connecting Thermistors**



### **Table 75. NTC1 Values in NTC Configuration Register**

### <span id="page-68-0"></span>**SENSE RESISTOR TEMPERATURE COMPENSATION**

The LTC2949 can be configured to compensate the temperature dependency of the used current sense resistors up to 2nd order based on temperature measurements with external NTCs. The compensation is enabled by writing the temperature coefficients (TC,TC2) of the sense resistor and the reference temperature  $(T_0)$  in the NTC configuration register. The LTC2949 will then compensate for the temperature induced deviation of the sense resistor from its nominal value  $R_0$  according to:

$$
R_{\text{SENSE}} = R_0 \cdot [1 + TC \cdot (T - T_0) + TC2 \cdot (T - T_0)^2]
$$

The temperature coefficient and reference temperature can be set for each sense resistor individually in the NTC configuration register. [Table 76](#page-69-0) shows the programmed coefficients for a copper sense resistor with a temperature coefficient of 3900ppm/K whose nominal value  $R_0$  was measured at 20°C.

If temperature compensation is enabled for one or both channels, the sense resistor connected to CH1 is compensated with the temperature of NTC1 measured during the first slot of CHAUX, while the sense resistor connected to CH2 is compensated with the temperature of NTC2 measured during the second slot of CHAUX. The multiplexer settings must be set such that the input pin connected to the corresponding NTC is selected during the respective slot. If CHAUX is changed to fast mode, the last NTC temperature measurements taken in Round Robin mode are used for temperature compensation.

The following linear equation system has to be solved to calculate A,B,C using three values, R1(T1), R2(T2), R3(T3) from a R versus T (in K) resistor table:



After solving the linear equation system, A, B, C can be expressed as:

$$
I_1 = \ln R_1
$$
  
\n
$$
I_2 = \ln R_2
$$
  
\n
$$
I_3 = \ln R_3
$$
  
\n
$$
m_2 = \frac{T_2^{-1} - T_1^{-1}}{I_2 - I_1}
$$
  
\n
$$
m_3 = \frac{T_3^{-1} - T_1^{-1}}{I_3 - I_1}
$$
  
\n
$$
\frac{m_3 - m_2}{I_3 + I_2 + I_1}
$$
  
\n
$$
B = m_2 - C \cdot (I_1^2 + I_1 \cdot I_2 + I_2^2)
$$
  
\n
$$
A = T_1^{-1} - (B + I_1^2 \cdot C) \cdot I_1
$$

For single shunt scenarios the temperature measured by one NTC with SLOT1 can be used to compensate both channels. See ADCCONF, bit NTCSLOT1.

### **isoSPI Setup**

The LTC2949 allows the isoSPI link in each application to be optimized for power consumption or for noise immunity. The power and noise immunity of an isoSPI system is determined by the programmed  $I_B$  current. The  $I_B$  current can range from 100 $\mu$ A to 1mA. A low  $I_B$ reduces the isoSPI power consumption in the READY and ACTIVE states, while a high  $I_B$  increases the amplitude of the differential signal voltage  $V_A$  across the matching termination resistor,  $R_M$ . I<sub>B</sub> is programmed by the sum of the  $R_{B1}$  and  $R_{B2}$  resistors connected between the  $I_{BIAS}$ pin and GND as shown in [Figure 23.](#page-69-1) For most applications

setting  $I_B$  to 0.5mA is a good compromise between power consumption and noise immunity. Using this  $I_B$  setting with a 1:1 transformer and  $R_M = 100\Omega$ ,  $R_{B1}$  should be set to 2.8k and  $R_{B2}$  set to 1.2k. In a typical CAT5 twisted pair these settings will allow for communication up to 50m. For applications that require cables longer than 50m it is recommended to increase the  $I_B$  to 1mA. This compensates for the increased insertion loss in the cable and maintains high noise immunity. So when using cables over 50m and, again, using a transformer with a 1:1 turns ratio and R<sub>M</sub> = 100 $\Omega$ , R<sub>B1</sub> would be 1.4k and R<sub>B2</sub> would be 600 $\Omega$ . Other I<sub>B</sub> settings can be used to reduce power consumption or increase the noise immunity as required by the application. In these cases when setting threshold voltage  $V_{ICMP}$  and choosing  $R_{B1}$  and  $R_{B2}$  resistor values the following rules should be used:

#### <span id="page-69-0"></span>**Table 76. Sense Resistor Temperature Coefficients**



Note: For copper only the first order temperature coefficient is relevant and thus TC2=0.0 (default).

#### **Table 77. Procedure to Enable Temperature Compensation of Sense Resistor**





<span id="page-69-1"></span>**Figure 23. isoSPI Circuit**

For cables under 50m:

 $I_B = 0.5mA$  $V_A = (20 \cdot I_B) \cdot (R_M/2)$  $V_{\text{TCMP}} = \frac{1}{2} \cdot V_A$  $V_{ICMP} = 2 \cdot V_{TCMP}$  $R_{B2} = V_{ICMP}/I_B$  $R_{B1} = (2/I_B) - R_{B2}$ For cables over 50m:  $I_B = 1mA$  $V_A = (20 \cdot I_B) \cdot (R_M/2)$  $V_{\text{TCMP}} = 1/4 \cdot V_A$  $V_{ICMP} = 2 \cdot V_{TCMP}$  $R_{B2} = V_{ICMP}/I_B$  $R_{B1} = (2/I_B) - R_{B2}$ 

The maximum data rate of an isoSPI link is determined by the length of the cable used. For cables 10 meters or less the maximum 1MHz SPI clock frequency is possible. As the length of the cable increases the maximum possible SPI clock rate decreases. This is a result of the increased propagation delays through the cable creating possible timing violations. [Figure 24](#page-70-0) shows how the maximum data rate is reduced as the cable length increases when using a CAT 5 twisted pair. Cable delay affects three timing specifications,  $t_{ClK}$ ,  $t_6$  and  $t_7$ . In the Electrical Characteristics table, each is derated by 100ns to allow for 50ns of cable delay. For longer cables, the minimum timing parameters may be calculated as shown below:

 $t_{\text{CI K}}$ , t6 and t7 > 0.9µs + 2  $\bullet$  t<sub>CABLE</sub>

### **Transformer Selection Guide**

As shown in Figure 23, a transformer or pair of transformers isolates the isoSPI signals between two isoSPI ports. The isoSPI signals have programmable pulse amplitudes up to  $1.6V_{P-P}$  and pulse widths of 50ns and 150ns. To be able to transmit these pulses with the necessary fidelity the system requires that the transformers have primary inductances above 60µH and a 1:1 turns ratio. It is also necessary to use a transformer with less than 2.5µH of leakage inductance. In terms of pulse shape the primary inductance will mostly effect the pulse droop of the 50ns and 150ns pulses. If the primary inductance is too low, the pulse amplitude will begin to droop and decay over the pulse period. When the pulse droop is severe enough, the effective pulse width seen by the receiver will drop substantially, reducing noise margin. Some droop is acceptable as long as it is a relatively small percentage of the total pulse amplitude. The leakage inductance primarily affects the rise and fall times of the pulses. Slower rise and fall times will effectively reduce the pulse width. Pulse width is determined by the receiver as the time the signal is above the threshold set at the ICMP pin. Slow rise and fall times cut into the timing margins. Generally it is best to keep pulse edges as fast as possible. When evaluating transformers, it is also worth noting the parallel winding capacitance. While transformers have very good CMRR at low frequency, this rejection will degrade at higher frequencies, largely due to the winding to winding capacitance. When choosing a transformer, it is best to pick one with less parallel winding capacitance when possible.



<span id="page-70-0"></span>**Figure 24. Data Rate vs Cable Length**

When choosing a transformer, it is equally important to pick a part that has an adequate isolation rating for the application. The working voltage rating of a transformer is a key spec when selecting a part for an application. Interconnecting daisy-chain links, devices see <60V stress in typical applications and ordinary pulse and LAN type transformers will suffice. Multi-drop connections and connections to the LTC6820, in general, may need much higher working voltage ratings for good long-term reliability. Usually, matching the working voltage to the voltage of the entire battery stack is conservative. Unfortunately, transformer vendors will often only specify one-second HV testing, and this is not equal to the long-term (permanent) rating of the part. For example, according to most safety standards a 1.5kV rated transformer is expected to handle 230V continuously, and a 3kV device is capable of 1100V long-term, though manufacturers may not always certify to those levels (refer to actual vendor data for specifics). Usually, the higher voltage transformers are called high isolation or reinforced insulation types by the suppliers. [Table 78](#page-72-0) shows a list of transformers that have been evaluated in isoSPI links.

## **EMC**

For the best electromagnetic compatibility (EMC) performance, it is recommended to use one of the circuits in [Figure 25](#page-72-1) and [Figure 26.](#page-72-2) The center tap of the transformer should be bypassed with a 10nF capacitor. The center tap capacitor will help attenuate common mode signals. Large center tap capacitors greater than 10nF should be avoided as they will prevent the isoSPI transmitters common mode voltage from settling. If a transformer without a center tap is used, the termination resistor should be split into two equal halves and connected in series across the IP and IM lines. The center of the two resistors should be bypassed with a capacitor as shown. To improve common mode current rejection a common mode choke should also be placed in series with the IP and IM lines of the LTC2949. The common mode choke will both increase EMI immunity and reduce EMI emission. When choosing a common mode choke, the differential mode impedance should be  $20\Omega$  or less for signals 50MHz and below. Common mode chokes similar to what is used in Ethernet applications are recommended.

Layout of the isoSPI signal lines also plays a significant role in maximizing the immunity of a circuit. The following layout quidelines should be followed:

- 1. The transformer should be placed as close to the isoSPI cable connector as possible. The distance should be kept less than 2cm. The LTC2949 should be placed at least 1cm to 2cm away from the transformer to help isolate the IC from magnetic field coupling.
- 2. On the top component layer, no ground plane should be placed under the transformer, the isoSPI connector, or in between the transformer and the connector.
- 3. The isoSPI signal traces should be isolated from surrounding circuits and traces by ground metal or space. No traces should cross the isoSPI signal lines, unless separated by a ground plane on an inner layer.

The isoSPI drive currents are programmable and allow for a trade-off between power consumption and noise immunity. The noise immunity of the LTC2949 has been evaluated using a bulk current injection (BCI) test. The BCI test injects current into the twisted-pair lines at set levels over a frequency range of 1MHz to 400MHz. With the minimum  $I_B$  current, 100 $\mu$ A, the isoSPI serial link was capable of passing a 40mA BCI test with no bit errors. A 40mA BCI test level is sufficient for industrial applications. Automotive applications have a much higher BCI requirement so the LTC2949  $I_B$  is set to 1 mA, the maximum power level. The isoSPI system is capable of passing a 200mA BCI test with no transmitted bit errors. The 200mA test level is typical for automotive requirements.
#### **Table 78. Recommended Transformers**





**Figure 25. Recommended isoSPI Circuit for EMC**



**Figure 26. Recommended isoSPI Circuit for Best EMC Performance when Using a Transformer without Center Tap**

#### **Table 79. Recommended Common Mode Chokes**







### **CURRENT AND VOLTAGE INPUT FILTERING**

To ensure the full electrical performance of the ADCs for current, power and voltage, apply the input filtering circuitry as depicted in [Figure 27](#page-73-0) to pins CFP, CFM, VBATP and VBATM. These components ensure an optimized input filtering for noise reduction. Equal time constants at current and voltage inputs minimize errors in power measurement of transient signals due to different delays in both paths.

#### **Unused Input Pins V1-V12**

Input pins V1-V12 can be left floating or connected to GND if not used. Still, it is not recommended to connect V8-V12 to GND as those pins can be driven high optionally when used as digital outputs.

Depending on the application and the configuration of LTC2949, it might be beneficial or sometimes even necessary to apply following external connections to inputs, which were unused.

- 1. Connect pin VREF to one of V1-V12
	- a. See last paragraph of section [Fast Mode Configura](#page-16-0)[tions](#page-16-0) for effect of fast AUX measurement on internal slow AUX Round-Robin. Register VREF is not updated while performing fast AUX conversions.
	- b. The internal VREF measurement is altered while the current sources (see register FCURGPIOCTRL) are enabled. Connecting VREF to one Vx pin always measurement of the correct VREF pin voltage at any time.
- c. VREF can be used to bias resistive dividers to allow measurement of voltages below GND. In those scenarios the differential voltage between Vx and VREF must be measured which is only possible if VREF is connected to one of V1-V12 pins.
- 2. Connect divided supply voltage AVCC/DVCC (e.g. 10k between GND/Vx and 20k between Vx and AVCC/DVCC) to one of V1-V12
	- a. Same as 1.a. Register VCC is not updated while performing fast AUX conversions.
- 3. Connect NTC to one of V1-V12
	- a. See section [Temperature Measurement](#page-67-0)
- <span id="page-73-0"></span>4. Connect pin VREF via an external 4k resistor to one of V1-V12
	- a. Allows to diagnose the internal current sources.
- 5. Connect pins BYP1 and BYP2 to separate unused pins of V1-V12.
	- a. Allows to diagnose internal generated supply voltages additionally to built-in self-tests.

### **High-Ohmic Resistive Dividers**

Any high voltage to be measured by LTC2949 must be divided down and optionally biased via VREF to move it into the LTC2949's supply voltage rails ±100mV and into the ADC's differential input voltage range (±4.8V). Typically, several resistors are connected in series, to minimize the voltage drop and power dissipation of individual resistors ([Figure 28](#page-74-0)). LTC2949 Operation State Diagram shows a typical schematic, as an example the signal is measured via V1 by the AUX ADC. The measurement is performed similarly via the BAT inputs (VBATP, VBATM) by the AUX or the Power ADCs (P1/P2 as voltage).

All voltage inputs of LTC2949 are buffered. The differential input impedance during measurements is guaranteed to be >50Meg. For typical resistive dividers, like those shown in the typical application, the effect of this equivalent >50Meg resistor is negligible. The error can be calculated as following:

Nominal gain factor:  $g = R_{low}/(R_{low}+R_{high})$ 

Effective low side resistor:  $R_{\text{lowd}} = R_{\text{low}} \cdot R_{\text{d}}/R$  $(R_{low}+R_d)$ ,  $R_d = 50e5$ 

Effective gain factor:  $g_d = R_{\text{lowd}}/(R_{\text{lowd}}+R_{\text{high}})$ 

Example values:  $R_{\text{low}}$ =30<sup>3</sup>,  $R_{\text{hich}}$ =5 • 1.3e6

Gain factor error:  $err = g_d/q - 1 = -0.06\%$ 

The differential input impedance during measurements is nonlinear, it increases with decreasing input signal and it may also change over temperature. For this reason, it can be calibrated only partially during a post-production board test procedure. Still, its guaranteed to be >50Meg over the full-scale input range and the whole operating temperature range and thus the error calculated above gives the worst-case error.

The high voltage is calculated from the ADC measurement the following way:

Divider connected to GND:  $V_{HVA} = V_{ADC}/g$ 

Divider connected to VREF:  $V_{HVP} = V_{ADC}/g+VREF$ 

As any resistive divider is affected by static tolerances, it can be calibrated by applying a known input signal and calculating greal from the ADC measurement. LTC2949 can compensate for this error by writing the gain correction factor GC=gnominal/greal to one of the related gain correction registers (BATGC, MUX1GC-MUX4GC). The optional external EEPROM can be used as a nonvolatile storage for those calibration factors.

LTC2949's gain correction registers are not limited to values around 1.0, for example it is possible to write a value of 10.0 and this factor would be applied just as any other. Still, there is a limitation by the size of the result registers which is 16-bit (including sign) for any AUX-ADC measurement like BAT, SLOT1/2 and the fast AUX measurement results. This leads to an absolute maximum register value of roughly 12.3V (375µV • [2<sup>15</sup>-1]). To avoid clipping or overflowing of the results, it is always recommended to use gain correction factors that correct the deviation from nominal factors (e.g. deviation from nominal resistor divider ratio) like in the example above. The host controller software then holds the hard-coded nominal factor (e.g. 6.53Meg/30k) and LTC2949 is applying the fine-trim based on the values that were stored into the external EEPROM during board calibration.

#### **POWERING THE LTC2949**

The LTC2949 requires a single supply voltage of 4.5 to 14V. The maximum supply current is 20mA when active and 120µA when sleeping. If isoSPI is selected up to 7mA are required additionally during communication. Any current that is necessary to drive circuits connected to the GPIO pins must also be considered when selecting and designing a suitable power supply.



<span id="page-74-0"></span>**Figure 28. Left: High-Ohmic Resistive Divider for Measuring 1000V Battery Voltage Via the AUX ADC Input V1. Right: Resistive Divider Connected to VREF Allows to Measure ±1000V.**

#### **Non-Isolated Supply**

LTC provides a broad spectrum of non-isolated power supply solutions including LDOs, switched mode power supplies and μModuleregulators. As the LTC2949 is mainly targeting high voltage battery applications the LT8315 can be considered. Using the LT8315 it is possible to supply the LTC2949 directly out of a high voltage battery of up to 560V as shown in [Figure 29.](#page-75-0)

#### **Isolated supply**

Most high voltage battery applications where the LTC2949 cannot be supplied directly out of the battery require an isolated power supply. A simple DC/DC converter is shown in [Figure 30](#page-76-0) using Linear Technology's LT3999 DC/DC converter and a high isolation-rated transformer.

The LT830X family of flyback converters with a suitable transformer is also a possible choice.



Minimum load requirement of the flyback converters must be considered which is typically much higher than the sleep current of the LTC2949. To prevent the output voltage from rising above LTC2949's operating ratings a 12V Zener diode (e.g. NXP: BZX384-B12,115) should be placed.

Transformer specification and design is possibly the most critical part of successfully applying the above mentioned DC/DC converters. Data sheets of the suggested parts give detailed information about critical parameters like saturation current, inductance, isolation voltage rating and creepage distance.



<span id="page-75-0"></span>**Figure 29. Nonisolated Supply Generation** 







<span id="page-76-0"></span>**Figure 30. Isolated Supply Generation with Push-Pull Transformer** 



**Figure 32. Battery Monitoring with High Side Current Sensing Over Two Sense Resistors, Battery Voltage Measurement, Temperature Measurement and Pre-Charge Voltage Measurement Using Isolated Supply and Isolated NMOS Gate Drive as Well as PhotoMos Relay.**

Rev A

# PACKAGE DESCRIPTION



**LXE Package 48-Lead Plastic Exposed Pad LQFP (7mm** × **7mm)** (Reference LTC DWG #05-08-1927 Rev B)

RECOMMENDED SOLDER PAD LAYOUT APPLY SOLDER MASK TO AREAS THAT ARE NOT SOLDERED

78

1.30 MIN

TRAY PIN 1 BEVEL

PIN "A1"

PACKAGE IN TRAY LOADING ORIENTATION

inr

### REVISION HISTORY



79