19-5128; Rev 0; 1/10

EVALUATION KIT

AVAILABLE

# **OV to 16V, Dual Hot-Swap Controller with 10-Bit Current and Voltage Monitor and 4 LED Drivers**

## **General Description**

The MAX5970 dual hot-swap controller provides complete protection for systems with two supply voltages from 0V to +16V. The MAX5970 includes four programmable LED outputs. The two hot-swap channels can be configured to operate as independent hot-swap controllers, or as a pair operating together so that both channels shut down if either channel experiences a fault.

The MAX5970 provides two programmable levels of overcurrent circuit-breaker protection: a fast-trip threshold for a fast turn-off, and a lower slow-trip threshold for a delayed turn-off. The maximum overcurrent circuitbreaker threshold range is set independently for each channel with a trilevel logic input IRNG\_, or by programming though the I<sup>2</sup>C interface.

The MAX5970 is an advanced hot-swap controller that monitors voltage and current with an internal 10-bit ADC which is continuously multiplexed to convert the output voltage and current of both hot-swap channels at 10ksps. Each 10-bit sample is stored in an internal circular buffer so that 50 past samples of each signal can be read back through the I<sup>2</sup>C interface at any time or after a fault condition.

The device includes five user-programmable digital comparators per hot-swap channel to implement overcurrent warning and two levels of overvoltage/undervoltage detection. When any of the measured values violates the programmable limits, an external ALERT output is asserted. In addition to the ALERT signal, the MAX5970 can be programmed to deassert the power-good signal and/or turn off the external MOSFET.

The MAX5970 features four I/Os that can be independently configured as general-purpose inputs/outputs (GPIOs) or as open-drain LED drivers with programmable blinking. These four I/Os can be configured for any mix of LED driver or GPIO function.

The MAX5970 is available in a 36-pin thin QFN-EP package and operates over the -40°C to +85°C extended temperature range.

## Features

- Two Independent Hot-Swap Controllers Operate from 0V to +16V
- ♦ 10-Bit ADC Monitors Voltage and Current of Each Channel
- Circular Buffers Store 5ms of Current and Voltage **Measurements**
- Two Independent Internal Charge Pumps Generate n-Channel MOSFET Gate Drives
- Internal 500mA Gate Pulldown Current for Fast Shutdown
- ◆ VariableSpeed/BiLevel<sup>™</sup> Circuit-Breaker Protection
- Independent Precision-Voltage Enable Inputs
- Alert Output Indicates Fault and Warning Conditions
- Independent Power-Good Outputs
- Independent Fault Outputs
- Four Open-Drain Outputs Sink 25mA to Directly Drive LEDs
- Programmable LED Flashing Function
- Autoretry or Latched Fault Management
- 400kHz I<sup>2</sup>C Interface
- Small 6mm x 6mm, 36-Pin TQFN-EP Package

## Applications

Single PCI Express<sup>®</sup> Hot-Plug Slot

**Blade Servers** 

Disk Drives/DASD/Storage Systems

Soft-Switch for ASICs, FPGAs, and Microcontrollers with Independent Core and I/O Voltages

## **Ordering Information**

| PART        | TEMP RANGE     | PIN-PACKAGE |
|-------------|----------------|-------------|
| MAX5970ETX+ | -40°C to +85°C | 36 TQFN-EP* |

+Denotes a lead(Pb)-free/RoHS-compliant package. \*EP = Exposed pad.

VariableSpeed/BiLevel is a trademark of Maxim Integrated Products, Inc. PCI Express is a registered trademark of PCI-SIG Corp.

## M/X/M

Maxim Integrated Products 1

For pricing, delivery, and ordering information, please contact Maxim Direct at 1-888-629-4642, or visit Maxim's website at www.maxim-ic.com.

## **ABSOLUTE MAXIMUM RATINGS**

| IN, SENSE_, MON_, GATE_ to AGND<br>LED_ to AGND<br>ON_, SDA, SCL to AGND | 0.3V to +16V           |
|--------------------------------------------------------------------------|------------------------|
| REG, DREG, IRNG_, MODE, PROT, A_,                                        |                        |
| PG_, ALERT, FAULT_ to AGND                                               | 0.3V to +4V            |
| REG to DREG                                                              | 0.3V to +0.3V          |
| RETRY, HWEN, POL to AGND                                                 | -0.3V to (VREG + 0.3V) |
| GATE1 to MON1, GATE2 to MON2                                             | 0.3V to +6V            |
| GND_, DGND to AGND                                                       | 0.3V to +0.3V          |
| SDA, ALERT Current                                                       | 20mA to +50mA          |
| LED_ Current                                                             |                        |

| GATE_, MON_, GND_ Current750mA                               |
|--------------------------------------------------------------|
| All Other Pins Input/Output Current                          |
| Continuous Power Dissipation ( $T_A = +70^{\circ}C$ )        |
| 36-Pin, 6mm x 6mm TQFN                                       |
| (derate 35.7mW/°C above +70°C)                               |
| Junction-to-Ambient Thermal Resistance (0JA) (Note 1) 28°C/W |
| Operating Temperature Range40°C to +85°C                     |
| Junction Temperature+150°C                                   |
| Storage Temperature Range65°C to +150°C                      |
| Lead Temperature (soldering, 10s)+300°C                      |

Note 1: Package thermal resistances were obtained using the method described in JEDEC specification JESD51-7, using a fourlayer board. For detailed information on package thermal consideration, refer to www.maxim-ic.com/thermal-tutorial.

\*\*As per JEDEC51 Standard (Multilayer Board)

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## **ELECTRICAL CHARACTERISTICS**

 $(V_{IN} = 2.7V \text{ to } 16V, T_A = -40^{\circ}\text{C} \text{ to } +85^{\circ}\text{C}, \text{ unless otherwise noted}$ . Typical values are at  $V_{IN} = 3.3V$  and  $T_A = +25^{\circ}\text{C}$ .) (Note 2)

| PARAMETER                           | SYMBOL            |                           | CONDITIONS                    | MIN    | ТҮР   | MAX   | UNITS   |
|-------------------------------------|-------------------|---------------------------|-------------------------------|--------|-------|-------|---------|
| Supply Input-Voltage Range          | Vin               |                           |                               | 2.7    |       | 16    | V       |
| Hot-Swap Voltage Range              |                   |                           |                               | 0      |       | 16    | V       |
| Supply Current                      | lin               |                           |                               |        | 2.5   | 4     | mA      |
| Internal LDO Output Voltage         | REG               | IREG = 0 to 5m            | A, $V_{IN} = 2.7V$ to 16V     | 2.49   | 2.53  | 2.6   | V       |
| Undervoltage Lockout                | UVLO              | VIN rising                |                               |        |       | 2.7   | V       |
| Undervoltage Lockout<br>Hysteresis  | UVLOHYS           |                           |                               |        | 100   |       | mV      |
| CURRENT-MONITORING FUN              | ICTION            | 1                         |                               |        |       |       |         |
| MON_, SENSE_ Input-Voltage<br>Range |                   |                           |                               | 0      |       | 16    | V       |
| SENSE_ Input Current                |                   | VSENSE_, VMON             | ı_ = 16V                      |        | 32    | 75    | μA      |
| MON_ Input Current                  |                   | VSENSE_, VMON             | I_ = 16V                      |        | 180   | 280   | μΑ      |
|                                     |                   | 25mV range                |                               |        | 24.34 |       |         |
| Current Measurement LSB<br>Voltage  |                   | 50mV range                |                               |        | 48.39 |       | μV      |
| voltage                             |                   | 100mV range               |                               |        | 96.77 |       |         |
|                                     |                   | V <sub>MON</sub> = 0V     | VSENSE VMON_ = 5mV            | -6.57  |       | +6.22 | - % FS  |
| Current Measurement Error           |                   | VMON_ = 0V                | VSENSE VMON_ = 20mV           | -6.71  |       | +6.82 |         |
| (25mV Range)                        |                   | V <sub>MON</sub> _ = 2.5V | VSENSE VMON_ = 5mV            | -9.71  |       | +8.92 | _ ⁄₀ r3 |
|                                     |                   | to 16V                    | VSENSE VMON_ = 20mV           | -10.24 |       | +9.36 |         |
|                                     |                   | V <sub>MON</sub> = 0V     | VSENSE VMON_ = 10mV           | -4.24  |       | +3.78 |         |
| Current Measurement Error           | Measurement Error |                           | MON_ = 0V VSENSE VMON_ = 40mV |        |       | +5.36 | - % FS  |
| (50mV Range)                        |                   | $V_{MON} = 2.5V$          | VSENSE VMON_ = 10mV           | -4.50  |       | +4.00 |         |
|                                     |                   | to 16V                    | VSENSE VMON_ = 40mV           | -4.20  |       | +4.50 |         |

## **ELECTRICAL CHARACTERISTICS (continued)**

 $(V_{IN} = 2.7V \text{ to } 16V, T_A = -40^{\circ}C \text{ to } +85^{\circ}C, \text{ unless otherwise noted. Typical values are at } V_{IN} = 3.3V \text{ and } T_A = +25^{\circ}C.)$  (Note 2)

| PARAMETER                                          | SYMBOL              |                                    | CONDITIONS                     | MIN     | ТҮР | MAX     | UNITS  |  |
|----------------------------------------------------|---------------------|------------------------------------|--------------------------------|---------|-----|---------|--------|--|
|                                                    |                     |                                    | VSENSE VMON_ = 20mV            | -2.70   |     | +2.43   |        |  |
| Current Measurement Error                          |                     | $V_{MON} = 0V$                     | VSENSE VMON_ = 80mV            | -3.63   |     | +4.56   |        |  |
| (100mV Range)                                      |                     | V <sub>MON</sub> _ = 2.5V          | VSENSE VMON_ = 20mV            | -3.14   |     | +3.19   | - % FS |  |
|                                                    |                     | to 16V                             | VSENSE VMON_ = 80mV            | -3.80   |     | +3.93   |        |  |
|                                                    |                     | N/1-1-1-1-01/                      | Circuit breaker, DAC = 102     | -2.106  |     | +0.888  |        |  |
| Fast Current-Limit Threshold                       |                     | VMON_ = 0V                         | Circuit breaker, DAC = 255     | -2.986  |     | +0.641  |        |  |
| Error (25mV Range)                                 |                     | VMON_ = 2.5V                       | Circuit breaker, DAC = 102     | -3.000  |     | +1.000  | mV     |  |
|                                                    |                     | to 16V                             | Circuit breaker, DAC = 255     | -3.500  |     | +1.500  | 1      |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 102     | -3.1188 |     | +0.926  |        |  |
| Fast Current-Limit Threshold                       |                     | $V_{MON} = 0V$                     | Circuit breaker, DAC = 255     | -4.873  |     | +0.3421 | 1,     |  |
| Error (50mV Range)                                 |                     | V <sub>MON</sub> _ = 2.5V          | Circuit breaker, DAC = 102     | -3.2668 |     | +0.9228 | - mV   |  |
|                                                    |                     | to 16V                             | Circuit breaker, DAC = 255     | -4.7    |     | +1.0212 | 1      |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 102     | -4.7987 |     | +1.1812 |        |  |
| Fast Current-Limit Threshold                       |                     | $V_{MON} = 0V$                     | Circuit breaker, DAC = 255     | -8.9236 |     | +0.202  |        |  |
| Error (100mV Range)                                |                     | VMON_ = 2.5V<br>to 16V             | Circuit breaker, DAC = 102     | -4.9991 |     | +0.6374 | - mV   |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 255     | -8.262  |     | +1      |        |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 102     | -1.7965 |     | +1.5496 |        |  |
| Slow Current-Limit Threshold                       |                     | $V_{MON} = 0V$                     | Circuit breaker, DAC = 255     | -1.86   |     | +1.5916 | mV     |  |
| Error (25mV Range)                                 |                     | V <sub>MON</sub> _ = 2.5V          | Circuit breaker, DAC = 102     | -2.149  |     | +1.9868 |        |  |
|                                                    |                     | to 16V                             | Circuit breaker, DAC = 255     | -2.2285 |     | +1.9982 |        |  |
| Slow Current-Limit Threshold<br>Error (50mV Range) |                     |                                    | Circuit breaker, DAC = 102     | -2.3992 |     | +1.8723 |        |  |
|                                                    |                     | $V_{MON} = 0V$<br>$V_{MON} = 2.5V$ | Circuit breaker, DAC = 255     | -2.5146 |     | +2.1711 | - mV   |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 102     | -2.4716 |     | +2.181  |        |  |
|                                                    |                     | to 16V                             | Circuit breaker, DAC = 255     | -2.7421 |     | +2.1152 |        |  |
|                                                    |                     |                                    | Circuit breaker, DAC = 102     | -3.3412 |     | +2.989  | 1      |  |
| Slow Current-Limit Threshold                       |                     | $VMON_ = 0V$                       | Circuit breaker, DAC = 255     | -3.8762 |     | +3.6789 |        |  |
| Error (100mV Range)                                |                     | VMON_ = 2.5V                       | Circuit breaker, DAC = 102     | -3.2084 |     | +2.7798 | - mV   |  |
|                                                    |                     | to 16V                             | Circuit breaker, DAC = 255     | -3.8424 |     | +2.6483 | 1      |  |
| Fast Circuit-Breaker<br>Response Time              | tFCB                | Overdrive = 10                     | % of current-sense range       |         | 2   |         | μs     |  |
| Slow Current-Limit Response                        | tSCB                | Overdrive = 4%                     | of current-sense range         |         | 2.4 |         |        |  |
| Time                                               |                     | Overdrive = 8%                     | of current-sense range         |         | 1.2 |         | ms     |  |
|                                                    |                     | Overdrive = 16                     | % of current-sense range       |         | 0.6 |         | -      |  |
| THREE-STATE INPUTS                                 | 1                   | 1                                  |                                | I       |     |         |        |  |
| A_, IRNG_, MODE, PROT<br>Low Current               | I <sub>IN_LOW</sub> | Input voltage =                    | 0.4V                           | -40     |     |         | μA     |  |
| A_, IRNG_, MODE, PROT T<br>High Current            | lin_high            | Input voltage =                    | nput voltage = VREG - 0.2V     |         |     | 40      | μΑ     |  |
| A_, IRNG_, MODE, PROT<br>Open Current              | IFLOAT              | Maximum sourc                      | ce/sink current for open state | -4      |     | +4      | μA     |  |

**MAX5970** 

## **ELECTRICAL CHARACTERISTICS (continued)**

 $(V_{IN} = 2.7V \text{ to } 16V, T_A = -40^{\circ}\text{C} \text{ to } +85^{\circ}\text{C}, \text{ unless otherwise noted.}$  Typical values are at  $V_{IN} = 3.3V$  and  $T_A = +25^{\circ}\text{C}.)$  (Note 2)

| PARAMETER                                  | SYMBOL   | CONDITIONS                                   | MIN   | ТҮР   | MAX   | UNITS |
|--------------------------------------------|----------|----------------------------------------------|-------|-------|-------|-------|
| A_, IRNG_, MODE, PROT<br>Low Voltage       |          | Relative to AGND                             |       |       | 0.4   | V     |
| A_, IRNG_, MODE, PROT<br>High Voltage      |          | Relative to REG                              | -0.24 |       |       | V     |
| TWO-STATE INPUTS                           | I        |                                              |       |       |       |       |
| ON_ Input Voltage                          | Von_     |                                              | 0.582 | 0.592 | 0.602 | V     |
| ON_ Input Hysteresis                       | VON_HYS  |                                              |       | 4     |       | %     |
| ON_ Input Current                          |          |                                              | -100  |       | +100  | nA    |
| TIMING                                     |          | · · ·                                        |       |       |       |       |
|                                            |          |                                              |       | 50    |       |       |
|                                            |          | Register configurable                        |       | 100   |       |       |
| MON_ to PG_ Delay                          |          | (see Tables 31a and 31b)                     |       | 200   |       | ms    |
|                                            |          |                                              |       | 400   |       |       |
| CHARGE PUMP (GATE_)                        |          | · · ·                                        |       |       |       |       |
| Charge-Pump Output Voltage                 |          | Relative to MON_, IGATE = 0                  | 4.5   | 5.1   | 5.5   | V     |
| Charge-Pump Output Source<br>Current       | IG(UP)   |                                              | 4     | 5     | 6     | μA    |
| GATE_ Discharge Current                    | IG(DN)   | VGATE VMON_ = 2V                             |       | 500   |       | mA    |
| OUTPUT (FAULT_, PG_, ALE                   |          |                                              |       |       |       | 1     |
| Output-Voltage Low                         |          | ISINK = 3.2mA                                |       |       | 0.2   | V     |
| Output Leakage Current                     |          |                                              |       |       | 1     | μA    |
| LED INPUT/OUTPUT                           |          |                                              |       |       |       |       |
| LED_ Input Threshold Low Level             | VIL      |                                              |       |       | 0.4   | V     |
| LED_ Input Threshold High Level            | VIH      |                                              | 1.4   |       |       | V     |
| LED_ Output Low                            | Vol      | ILED_ = 25mA                                 |       |       | 0.7   | V     |
| LED_ Input Leakage Current<br>(Open Drain) | IGPIO_IX | V <sub>LED</sub> = 16V                       | -1    |       | +1    | μA    |
| LED_ Weak Pullup Current                   | IPU_WEAK | $V_{LED_{}} = V_{IN} - 0.65V$                | 2     |       |       | μA    |
| ADC PERFORMANCE                            |          |                                              |       |       |       |       |
| Resolution                                 |          |                                              |       | 10    |       | Bits  |
| Maximum Integral Nonlinearity              | INL      |                                              |       | 1     |       | LSB   |
| ADC Total Monitoring Cycle<br>Time         |          | Two voltage and two current-sense conversion | 95    | 100   | 110   | μs    |
|                                            |          | 16V range                                    | 15.23 | 15.49 | 15.69 | 1     |
|                                            |          | 8V range                                     | 7.655 | 7.743 | 7.811 | 1     |
| MON_LSB Voltage                            |          | 4V range                                     | 3.811 | 3.875 | 3.933 | mV    |
|                                            |          | 2V range                                     | 1.899 | 1.934 | 1.966 | 1     |
|                                            |          | 16V range                                    | 10    | 25    | 41    |       |
| MON_ Code 000H to 001H                     |          | 8V range                                     | 4.7   | 12    | 21    | 1     |
| Transition Voltage                         |          | 4V range                                     | 2     | 6     | 12    | mV    |
|                                            |          | 2V range                                     | 0.5   | 3     | 5.5   | 1     |

## **ELECTRICAL CHARACTERISTICS (continued)**

 $(V_{IN} = 2.7V \text{ to } 16V, T_A = -40^{\circ}\text{C to } +85^{\circ}\text{C}, \text{ unless otherwise noted}$ . Typical values are at  $V_{IN} = 3.3V$  and  $T_A = +25^{\circ}\text{C}$ .) (Note 2)

| PARAMETER                                         | SYMBOL              | CONDITIONS                       | MIN | ТҮР  | MAX | UNITS |
|---------------------------------------------------|---------------------|----------------------------------|-----|------|-----|-------|
| I <sup>2</sup> C INTERFACE                        |                     | · ·                              |     |      |     |       |
| Serial-Clock Frequency                            | fscl                |                                  |     |      | 400 | kHz   |
| Bus Free Time Between<br>STOP and START Condition | tBUF                |                                  | 1.3 |      |     | μs    |
| START Condition Setup Time                        | tsu:sta             |                                  | 0.6 |      |     | μs    |
| START Condition Hold Time                         | thd:sta             |                                  | 0.6 |      |     | μs    |
| STOP Condition Setup Time                         | tsu:sto             |                                  | 0.6 |      |     | μs    |
| Clock High Period                                 | thigh               |                                  | 0.6 |      |     | μs    |
| Clock Low Period                                  | tLOW                |                                  | 1.3 |      |     | μs    |
| Data Setup Time                                   | tsu:dat             |                                  | 100 |      |     | ns    |
|                                                   |                     | Transmit                         | 100 |      |     |       |
| Data Hold Time                                    | <sup>t</sup> hd:dat | Receive                          | 300 |      | 900 | – ns  |
| Output Fall Time                                  | tOF                 | C <sub>BUS</sub> = 10pF to 400pF |     |      | 250 | ns    |
| Pulse Width of Spike<br>Suppressed                | tSP                 |                                  |     | 50   |     | ns    |
| SDA, SCL Input High Voltage                       | Vih                 |                                  | 1.8 |      |     | V     |
| SDA, SCL Input Low Voltage                        | VIL                 |                                  |     |      | 0.8 | V     |
| SDA, SCL Input Hysteresis                         | VHYST               |                                  |     | 0.22 |     | V     |
| SDA, SCL Input Current                            |                     |                                  | -1  |      | +1  | μA    |
| SDA, SCL Input Capacitance                        |                     |                                  |     | 15   |     | pF    |
| SDA Output Voltage                                | Vol                 | ISINK = 4mA                      |     |      | 0.4 | V     |

Note 2: All devices are 100% production tested at T<sub>A</sub> = +25°C. Limits over the temperature range are guaranteed by design.

**Typical Operating Characteristics** 

( $V_{IN}$  = 3.3V,  $T_A$  = +25°C, unless otherwise noted.)



 $(V_{IN} = 3.3V, T_A = +25^{\circ}C, unless otherwise noted.)$ 



**Typical Operating Characteristics (continued)** 



## **Typical Operating Characteristics (continued)**

(V<sub>IN</sub> = 3.3V, T<sub>A</sub> =  $+25^{\circ}C$ , unless otherwise noted.)

## 



\*EP = EXPOSED PAD.

## \_Pin Description

| PIN | NAME   | FUNCTION                                                                                                                                              |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | IRNG2  | Channel 2 Three-State Current-Sense Range Selection Input. Set the circuit-breaker threshold range by connecting to DGND, DREG, or leave unconnected. |
| 2   | IRNG1  | Channel 1 Three-State Current-Sense Range Selection Input. Set the circuit-breaker threshold range by connecting to DGND, DREG, or leave unconnected. |
| 3   | IN     | Power-Supply Input. Connect to a voltage from 2.7V to 16V. Bypass to AGND with a 1µF capacitor.                                                       |
| 4   | AGND   | Analog Ground. Connect all GND_ and DGND to AGND externally using a star connection.                                                                  |
| 5   | REG    | Internal Regulator Output. Bypass to ground with a 1µF capacitor. Connect only to DREG. Do not use to power external circuitry.                       |
| 6   | BIAS   | For normal operation, connect BIAS to REG.                                                                                                            |
| 7   | A1     | Three-State I <sup>2</sup> C Address Input 1                                                                                                          |
| 8   | AO     | Three-State I <sup>2</sup> C Address Input 0                                                                                                          |
| 9   | PROT   | Protection Behavior Input. Three-state input sets one of three different response options for undervoltage and overvoltage events.                    |
| 10  | SENSE1 | Channel 1 Current-Sense Input. Connect SENSE1 to the source of an external MOSFET and to one end of RSENSE1.                                          |
| 11  | MON1   | Channel 1 Voltage Monitoring Input                                                                                                                    |
| 12  | GATE1  | Channel 1 Gate-Drive Output. Connect to the gate of an external n-channel MOSFET.                                                                     |
| 13  | GND1   | Channel 1 Gate Discharge Current Ground Return. Connect all GND_ and DGND to AGND externally using a star connection.                                 |

| PIN | NAME   | FUNCTION                                                                                                                                                                                                                                |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14  | LED1   | LED Driver 1                                                                                                                                                                                                                            |
| 15  | LED2   | LED Driver 2                                                                                                                                                                                                                            |
| 16  | POL    | Polarity Select Input. Connect to DREG for active-high power-good outputs (PG_). Connect to GND for active-low power-good outputs.                                                                                                      |
| 17  | DREG   | Logic Power-Supply Input. Connect to REG externally through a 10 $\Omega$ resistor and to DGND with a 1 $\mu\text{F}$ ceramic capacitor.                                                                                                |
| 18  | ON1    | Channel 1 Precision Turn-On Input                                                                                                                                                                                                       |
| 19  | FAULT1 | Channel 1 Active-Low Open-Drain Fault Output. FAULT1 goes low if an overcurrent occurs on channel 1.                                                                                                                                    |
| 20  | FAULT2 | Channel 2 Active-Low Open-Drain Fault Output. FAULT2 goes low if an overcurrent occurs on channel 2.                                                                                                                                    |
| 21  | SDA    | I <sup>2</sup> C Serial-Data Input/Output                                                                                                                                                                                               |
| 22  | SCL    | I <sup>2</sup> C Serial-Clock Input                                                                                                                                                                                                     |
| 23  | ALERT  | Open-Drain Alert Output. ALERT goes low during a fault to notify the system of an impending failure.                                                                                                                                    |
| 24  | PG1    | Channel 1 Open-Drain Power-Good Output                                                                                                                                                                                                  |
| 25  | PG2    | Channel 2 Open-Drain Power-Good Output                                                                                                                                                                                                  |
| 26  | HWEN   | Hardware Enable Input. Connect to DREG or DGND. State is read upon power-up as V <sub>IN</sub> crosses the UVLO threshold and sets enable register bits with this value. After UVLO, this input becomes inactive until power is cycled. |
| 27  | DGND   | Digital Ground. Connect all GND_ and DGND to AGND externally using a star connection.                                                                                                                                                   |
| 28  | ON2    | Channel 2 Precision Turn-On Input                                                                                                                                                                                                       |
| 29  | RETRY  | Autoretry Fault Management Input. Connect to DREG to enable autoretry operation. Connect to DGND to enable latched-off operation.                                                                                                       |
| 30  | MODE   | Hot-Swap Two-State Mode Select Input. Connect MODE to DGND, DREG or leave it unconnected to oper-<br>ate the hot-swap channels independently or as a pair.                                                                              |
| 31  | LED4   | LED Driver 4                                                                                                                                                                                                                            |
| 32  | LED3   | LED Driver 3                                                                                                                                                                                                                            |
| 33  | GND2   | Channel 2 Gate Discharge Current Ground Return. Connect all GND_ and DGND to AGND externally using a star connection.                                                                                                                   |
| 34  | GATE2  | Channel 2 Gate-Drive Output. Connect to gate of an external n-channel MOSFET.                                                                                                                                                           |
| 35  | MON2   | Channel 2 Voltage Monitoring Input                                                                                                                                                                                                      |
| 36  | SENSE2 | Channel 2 Current-Sense Input. Connect SENSE2 to the source of an external MOSFET and to one end of RSENSE2.                                                                                                                            |
|     | EP     | Exposed Pad. EP is internally grounded. Connect externally to ground plane using a star connection.                                                                                                                                     |

## Pin Description (continued)

**MAX5970** 



**Typical Application Circuit** 

**Block Diagram** 



## **Detailed Description**

The MAX5970 includes a set of registers that are accessed through the I<sup>2</sup>C interface. Some of the registers

are read only and some of the registers are read and write that are updated to configure the MAX5970 for a specific operation. See Tables 1a and 1b for the registers map.

| REGISTER         | DESCRIPTION                                                   | CHANNEL 1 | CHANNEL 2 | RESET<br>VALUE | READ/<br>WRITE |
|------------------|---------------------------------------------------------------|-----------|-----------|----------------|----------------|
| adc_chx_cs_msb   | High 8 bits ([9:2]) of latest current-signal ADC result       | 0x00      | 0x04      |                | R              |
| adc_chx_cs_lsb   | Low 2 bits ([1:0]) of latest current-signal ADC result        | 0x01      | 0x05      |                | R              |
| adc_chx_mon_msb  | High 8 bits ([9:2]) of latest voltage-signal ADC result       | 0x02      | 0x06      |                | R              |
| adc_chx_mon_ lsb | Low 2 bits ([1:0]) of latest voltage-signal ADC result        | 0x03      | 0x07      |                | R              |
| min_chx_cs_msb   | High 8 bits ([9:2]) of current-signal minimum value           | 0x08      | 0x10      | 0xFF           | R              |
| min_chx_cs_ lsb  | Low 2 bits ([1:0]) of current-signal minimum value            | 0x09      | 0x11      | 0x03           | R              |
| max_chx_cs_msb   | High 8 bits ([9:2]) of current-signal maximum value           | 0x0A      | 0x12      | 0x00           | R              |
| max_chx_cs_ lsb  | Low 2 bits ([1:0]) of current-signal maximum value            | 0x0B      | 0x13      | 0x00           | R              |
| min_chx_mon_msb  | High 8 bits ([9:2]) of voltage-signal minimum value           | 0x0C      | 0x14      | 0xFF           | R              |
| min_chx_mon_ lsb | Low 2 bits ([1:0]) of voltage-signal minimum value            | 0x0D      | 0x15      | 0x03           | R              |
| max_chx_mon_msb  | High 8 bits ([9:2]) of voltage-signal maximum value           | 0x0E      | 0x16      | 0x00           | R              |
| max_chx_mon_ lsb | Low 2 bits ([1:0]) of voltage-signal maximum value            | 0x0F      | 0x17      | 0x00           | R              |
| uv1thr _chx_msb  | High 8 bits ([9:2]) of undervoltage warning (UV1) threshold   | 0x1A      | 0x24      | 0x00           | R/W            |
| uv1thr_chx_ lsb  | Low 2 bits ([1:0]) of undervoltage warning (UV1) threshold    | 0x1B      | 0x25      | 0x00           | R/W            |
| uv2thr_chx_msb   | High 8 bits ([9:2]) of undervoltage critical (UV2) threshold  | 0x1C      | 0x26      | 0x00           | R/W            |
| uv2thr_chx_ lsb  | Low 2 bits ([1:0]) of undervoltage critical (UV2) threshold   | 0x1D      | 0x27      | 0x00           | R/W            |
| ov1thr_chx_msb   | High 8 bits ([9:2]) of overvoltage warning<br>(OV1) threshold | 0x1E      | 0x28      | 0xFF           | R/W            |
| ov1thr_chx_ lsb  | Low 2 bits ([1:0]) of overvoltage warning<br>(OV1) threshold  | 0x1F      | 0x29      | 0x03           | R/W            |

## Table 1a. Register Address Map (Channel Specific)

**MAX5970** 

| REGISTER        | DESCRIPTION                                                         | CHANNEL 1 | CHANNEL 2 | RESET<br>VALUE | READ/<br>WRITE |
|-----------------|---------------------------------------------------------------------|-----------|-----------|----------------|----------------|
| ov2thr_chx_msb  | High 8 bits ([9:2]) of overvoltage critical (OV2) threshold         | 0x20      | 0x2A      | 0xFF           | R/W            |
| ov2thr_chx_ lsb | Low 2 bits ([1:0]) of overvoltage critical (OV2) threshold          | 0x21      | 0x2B      | 0x03           | R/W            |
| oithr_chx_msb   | High 8 bits ([9:2]) of overcurrent warning threshold                | 0x22      | 0x2C      | 0xFF           | R/W            |
| oithr_chx_ lsb  | Low 2 bits ([1:0]) of overcurrent warning threshold                 | 0x23      | 0x2D      | 0x03           | R/W            |
| dac_chx-fast    | Fast-comparator threshold DAC setting                               | 0x2E      | 0x2F      | 0xBF           | R/W            |
| cubf_ba_chx_v   | Base address for block read of 50-sample voltage-signal data buffer | 0x46      | 0x48      |                | R              |
| cubf_ba_chx_i   | Base address for block read of 50-sample current-signal data buffer | 0x47      | 0x49      |                | R              |

## Table 1a. Register Address Map (Channel Specific) (continued)

## Table 1b. Register Address Map (General)

| REGISTER        | DESCRIPTION                                                                                           | ADDRESS<br>(HEX CODE) | RESET<br>VALUE | READ/<br>WRITE |
|-----------------|-------------------------------------------------------------------------------------------------------|-----------------------|----------------|----------------|
| mon_range       | MON input range setting                                                                               | 0x18                  | 0x00           | R/W            |
| cbuf_chx_store  | Selective enabling of circular buffer                                                                 | 0x19                  | 0x0F           | R/W            |
| ifast2slow      | Current threshold fast-to-slow ratio setting                                                          | 0x30                  | 0x0F           | R/W            |
| status0         | Slow-trip and fast-trip comparators status register                                                   | 0x31                  | 0x00           | R              |
| status1         | PROT, MODE, and ON_ inputs status register                                                            | 0x32                  | _              | R              |
| status2         | Fast-trip threshold maximum range setting bits, from IRNG_<br>three-state inputs                      | 0x33                  | _              | R/W            |
| status3         | LATCH, POL, ALERT, and PG_ status register                                                            | 0x34                  | _              | R              |
| fault0          | Status register for undervoltage detection (warning or critical)                                      | 0x35                  | 0x00           | R/C            |
| fault1          | Status register for overvoltage detection (warning or critical)                                       | 0x36                  | 0x00           | R/C            |
| fault2          | Status register for overcurrent detection (warning)                                                   | 0x37                  | 0x00           | R/C            |
| pgdly           | Delay setting between MON measurement and PG_ assertion                                               | 0x38                  | 0x00           | R/W            |
| fokey           | Load register with 0xA5 to enable force-on function                                                   | 0x39                  | 0x00           | R/W            |
| foset           | Register that enables force-on function for a channel                                                 | 0x3A                  | 0x00           | R/W            |
| chxen           | Channel enable bits                                                                                   | 0x3B                  | _              | R/W            |
| dgl_i           | OC deglitch enable bits                                                                               | 0x3C                  | 0x00           | R/W            |
| dgl_uv          | UV deglitch enable bits                                                                               | 0x3D                  | 0x00           | R/W            |
| dgl_ov          | OV deglitch enable bits                                                                               | 0x3E                  | 0x00           | R/W            |
| cbufrd_hibyonly | Circular buffers readout mode: 8 bit or 10 bit                                                        | 0x3F                  | 0x0F           | R/W            |
| cbuf_dly_stop   | Circular buffer stop-delay. Number of samples recorded to the circular buffer after channel shutdown. | 0x40                  | 0x19           | R/W            |
| peak_log_rst    | Reset control bits for peak-detection registers                                                       | 0x41                  | 0x00           | R/W            |
| peak_log_hold   | Hold control bits for peak-detection registers                                                        | 0x42                  | 0x00           | R/W            |



## Table 1b. Register Address Map (General) (continued)

| REGISTER  | DESCRIPTION                                         | ADDRESS<br>(HEX CODE) | RESET<br>VALUE | READ/<br>WRITE |
|-----------|-----------------------------------------------------|-----------------------|----------------|----------------|
| LED_Flash | LED flash/GPIO enable register                      | 0x43                  | 0x00           | R/W            |
| LED_ph_pu | LED phase/weak pullup enable register               | 0x44                  | 0x00           | R/W            |
| LED_state | LED pins voltage state register (LED pins set open) | 0x45                  | 0x00           | R              |

#### **Grouping Hot-Swap Channels**

The MAX5970 can operate as either two independent hot-swap controllers or as a pair. See Table 2 for the configuration option based on the MODE logic level.

Hot-Swap Channels On-Off Control

Depending on the configuration of the Chx\_EN1 and Chx\_EN2 bits, when V<sub>IN</sub> is above the V<sub>UVLO</sub> threshold and the ON\_ input reaches its internal threshold, the MAX5970 turns on the external n-channel MOSFET for the corresponding channel, allowing power to flow to the load. The channel is enabled depending on the output of a majority function. Chx\_EN1, Chx\_EN2, and ON\_ are the inputs to the majority function and the channel is enabled when two or more of these inputs are 1.

#### (Channel enabled) = (Chx\_EN1 x Chx\_EN2) + (Chx\_EN1 x ON\_) + (Chx\_EN2 x ON\_)

The inputs ON\_ and Chx\_EN2 can be set externally; the initial state of the Chx\_EN2 bits in register *chxen* is set by the state of the HWEN input when V<sub>IN</sub> rises above V<sub>UVLO</sub>. The ON\_ inputs connect to internal precision analog comparators with a 0.6V threshold. Whenever V<sub>ON</sub>\_ is above 0.6V, the corresponding ON\_ bit in register *status1[0:1]* is set to 1. The inputs Chx\_EN1 and Chx\_EN2 can be set using the I<sup>2</sup>C interface; the Chx\_EN1 bits have a default value of 0. This makes it possible to enable or disable each of the MAX5970 channels independently with or without using the I<sup>2</sup>C interface (see Tables 3, 4a, and 4b).

#### **Table 2. Grouping Hot-Swap Channels**

| MODE INPUT       | FUNCTION DESCRIPTION |                                                                                                                                                                                |  |  |
|------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Low              | Independent          | Each channel operates as an independent hot-swap controller. A fault shutdown in one channel does not affect operation of other channel.                                       |  |  |
| High/unconnected | Paired               | Channel 0 and channel 1 operate together as one pair. A fault shutdown in one channel shuts down both channels in the pair. Both channels share the ADC monitoring capability. |  |  |

#### Table 3. chxen Register Format

| Description: Channel enable bits, from HWEN input and Chx_EN1 bits |       |       |       |         |         |         |         |                |
|--------------------------------------------------------------------|-------|-------|-------|---------|---------|---------|---------|----------------|
| Register Title                                                     | :     | chxen |       |         |         |         |         |                |
| Register Add                                                       | ress: | 0x3B  |       |         |         |         |         |                |
| R/W                                                                | R/W   | R/W   | R/W   | R/W     | R/W     | R/W     | R/W     | RESET<br>VALUE |
|                                                                    |       |       |       | Ch2_EN2 | Ch2_EN1 | Ch1_EN2 | Ch1_EN1 | ] _            |
| bit 7                                                              | bit 6 | bit 5 | bit 4 | bit 3   | bit 2   | bit 1   | bit 0   |                |

## Table 4a. status1 Register Function

| REGISTER<br>ADDRESS | BIT<br>RANGE | DESCRIPTION                                                                                                                                                                                                                                                                       |
|---------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | [1:0]        | ON_ Inputs State<br>1 = ON_ above 600mV channel enable threshold<br>0 = ON_ below 600mV channel enable threshold<br>Bit 0: ON1<br>Bit 1: ON2                                                                                                                                      |
| 0x32                | [4]          | Channel Grouping Mode (MODE Input)<br>0 = Grouped (MODE high or open)<br>1 = Independent (MODE low)                                                                                                                                                                               |
|                     | [7:6]        | Voltage Critical Behavior (PROT Input)<br>00 = Assert ALERT upon UV/OV critical (same as UV/OV warning behavior)<br>01 = Assert ALERT and deassert PG_ upon UV/OV critical<br>10 = Assert ALERT, deassert PG_, and shutdown channel(s) upon UV/OV critical<br>11 = (Not possible) |

## Table 4b. status1 Register Format

| Description:         Channel grouping (three-state MODE input), fault-deter           ON_ inputs status register |         |         |         |       | , fault-detection | behavior (thre | e-state PR( | OT input), and |
|------------------------------------------------------------------------------------------------------------------|---------|---------|---------|-------|-------------------|----------------|-------------|----------------|
| Register Title                                                                                                   |         | status1 |         |       |                   |                |             |                |
| Register Add                                                                                                     | ress:   | 0x32    |         |       |                   |                |             |                |
| R                                                                                                                | R       | R       | R       | R     | R                 | R              | R           | RESET<br>VALUE |
| prot[1]                                                                                                          | prot[0] |         | mode[0] | _     | _                 | ON2            | ON1         | 0x00           |
| bit 7                                                                                                            | bit 6   | bit 5   | bit 4   | bit 3 | bit 2             | bit 1          | bit 0       |                |

Figure 1 shows the detailed logic operation of the hotswap enable signals Chx\_EN1, Chx\_EN2, and ON\_, as well as the effect of various fault conditions.

An input undervoltage threshold control for enabling the hot-swap channel can be implemented by placing a resistive divider between the drain of the hot-swap MOSFET and ground, with the midpoint connected to ON\_. The turn-on threshold voltage for the channel is then:

#### $V_{EN} = 0.6V \times (R1 + R2)/R2$

The maximum rating for the ON\_ is 6V; do not exceed this value.

## Startup

**MAX5970** 

When all conditions for channel turn-on are met, the external n-channel MOSFET switch is fully enhanced with a typical gate-to-source voltage of 5V to ensure a low drain-to-source resistance. The charge pump at each GATE\_ driver sources 5µA to control the output voltage turn-on voltage slew rate. An external capacitor can be added from GATE\_ to GND\_ to further reduce the voltage slew rate. Placing a 1k $\Omega$  resistor in series with this capacitance prevents the added capacitance from increasing the gate turn-off time. Total inrush current is the load current summed with the product of the gate voltage slew rate dV/dt and the load capacitance.





Figure 1. Channel On-Off Control Logic Functional Schematic

To determine the output dV/dt during startup, divide the GATE\_ pullup current  $I_{G(UP)}$  by the gate-to-ground capacitance. The voltage at the source of the external MOSFET follows the gate voltage, so the load dV/dt is the same as the gate dV/dt. Inrush current is the product of the dV/dt and the load capacitance. The time to start up tsU is the hot-swap voltage VS\_ divided by the output dV/dt.

Be sure to choose an external MOSFET that can handle the power dissipated during startup. The inrush current is roughly constant during startup, and the voltage drop across the MOSFET (drain to source) decreases linearly as the load capacitance charges. The resulting power dissipation is therefore roughly equivalent to a single pulse of magnitude (VS\_ x Inrush current)/2 and duration tsy. Refer to the thermal resistance charts in the MOSFET data sheet to determine the junction temperature rise during startup, and ensure that this does not exceed the maximum junction temperature for worstcase ambient conditions.

#### **Circuit-Breaker Protection**

As the channel is turned on and during normal operation, two analog comparators are used to detect an overcurrent condition by sensing the voltage across an external resistor connected between SENSE\_ and MON\_. If the voltage across the sense resistor is less than the slow-trip and fast-trip circuit-breaker thresholds, the GATE\_ output remains high. If either of the thresholds is exceeded due to an overcurrent condition, the gate of the MOSFET is pulled down to MON\_ by an internal 500mA current source.

The higher of the two comparator thresholds, the fasttrip, is set by an internal 8-bit DAC (see Table 8), within one of three configurable full-scale current-sense ranges: 25mV, 50mV, or 100mV (see Tables 7a and 7b). The 8-bit fast-trip threshold DAC can be programmed

| Description:Current threshRegister Title:ifast2slowRegister Address:0x30 |       |       | hold fast to slo | w setting bits |         |         |         |                |
|--------------------------------------------------------------------------|-------|-------|------------------|----------------|---------|---------|---------|----------------|
| R/W                                                                      | R/W   | R/W   | R/W              | R/W            | R/W     | R/W     | R/W     | RESET<br>VALUE |
|                                                                          | _     | _     | _                | Ch2_FS1        | Ch2_FS0 | Ch1_FS1 | Ch1_FS0 | 0x0F           |
| bit 7                                                                    | bit 6 | bit 5 | bit 4            | bit 3          | bit 2   | bit 1   | bit 0   |                |

#### Table 5a. ifast2slow Register Format

## Table 5b. Setting Fast-Trip to Slow-Trip Threshold Ratio

| Chx_FS1 | Chx_FS0 | FAST-TRIP TO SLOW-TRIP RATIO (%) |
|---------|---------|----------------------------------|
| 0       | 0       | 125                              |
| 0       | 1       | 150                              |
| 1       | 0       | 175                              |
| 1       | 1       | 200                              |

from 40% to 100% of the selected full-scale currentsense range. The slow-trip threshold follows the fast-trip threshold as one of four programmable ratios, set by the ifast2slow register (see Tables 5a and 5b).

The fast-trip threshold is always higher than the slow-trip threshold, and the fast-trip comparator responds very quickly to protect the system against sudden, severe overcurrent events. The slower response of the slowtrip comparator varies depending upon the amount of overdrive beyond the slow-trip threshold. If the overdrive is small and short-lived, the comparator does not shut down the affected channel. As the overcurrent event increases in magnitude, the response time of the slowtrip comparator decreases. This scheme provides good rejection of noise and spurious overcurrent transients near the slow-trip threshold while aggressively protecting the system against larger overcurrent events that occur as a result of a load fault.

#### Setting Circuit-Breaker Thresholds

To select and set the MAX5970 slow-trip and fast-trip comparator thresholds, use the following procedure:

1) Select one of four ratios between the fast-trip threshold and the slow-trip threshold: 200%, 175%, 150%, or 125%. A system that experiences brief, but large transient load currents should use a higher ratio, whereas a system that operates continuously at higher average load currents might benefit from a smaller ratio to ensure adequate protection. The ratio is set by writing to the ifast2slow register. The default setting on power-up is 200%.

2) Determine the slow-trip threshold VTH,ST based on the anticipated maximum continuous load current during normal operation, and the value of the current-sense resistor. The slow-trip threshold should include some margin (possibly 20%) above the maximum load current to prevent spurious circuit-breaker shutdown and to accommodate passive component tolerances:

VTH,ST = RSENSE × ILOAD,MAX × 120%

3) Calculate the necessary fast-trip threshold VTH FT based on the ratio set in step 1:

#### VTH,FT = VTH,ST x (ifast2slow ratio)

- 4) Select one of the four maximum current-sense ranges: 25mV, 50mV, or 100mV. The current-sense range is initially set upon power-up by the state of the associated IRNG\_ input, but can be altered at any time by writing to the status2 register. For maximum accuracy and best measurement resolution, select the lowest current-sense range that is larger than the VTH.FT value calculated in Step 3.
- 5) Program the fast-trip and slow-trip thresholds by writing an 8-bit value to the dac chx register. This 8-bit value is determined from the desired VTH ST value that was calculated in Step 2, the threshold ratio from Step 1, and the current-sense range from Step 4:

DAC = VTH.ST x 255 x (ifast2slow ratio)/ (IRNG\_ current-sense range)



**MAX597C** 

The MAX5970 provides a great deal of system flexibility because the current-sense range, DAC setting, and threshold ratio can be changed on the fly for systems that must protect a wide range of interchangeable load devices, or for systems that control the allocation of power to smart loads. Table 6 shows the specified ranges for the fast-trip and slow-trip thresholds for all combinations of current-sense range and threshold ratio.

When an overcurrent event causes the MAX5970 to shut down a channel, a corresponding open-drain FAULT\_ output alerts the system. Figure 2 shows the operation and fault-management flowchart for one channel of the MAX5970.

| IRNG_ INPUT | FAST-TRIP DAC<br>OUTPUT RANGE (mV) | GAIN (2-BIT) (VFAST/VSLOW)<br>ifast2slow<br>(DEFAULT = 11) | SLOW-TRIP THRESHOLD RANGE<br>(mV) |  |
|-------------|------------------------------------|------------------------------------------------------------|-----------------------------------|--|
|             |                                    | 00 (125%)                                                  | 8.00 to 20.00                     |  |
| Low         | 10 to 25                           | 01 (150%)                                                  | 6.67 to 16.67                     |  |
| LOW         | 10 10 25                           | 10 (175%)                                                  | 5.71 to 14.29                     |  |
|             |                                    | 11 (200%)                                                  | 5.00 to 12.50                     |  |
|             |                                    | 00 (125%)                                                  | 16.00 to 40.00                    |  |
| Llich       | 20 to 50                           | 01 (150%)                                                  | 13.33 to 33.33                    |  |
| High        |                                    | 10 (175%)                                                  | 11.48 to 28.57                    |  |
|             |                                    | 11 (200%)                                                  | 10.00 to 25.00                    |  |
|             |                                    | 00 (125%)                                                  | 32.00 to 80.00                    |  |
|             | 40 to 100                          | 01 (150%)                                                  | 26.67 to 66.67                    |  |
| Unconnected | 40 to 100                          | 10 (175%)                                                  | 22.86 to 57.14                    |  |
|             |                                    | 11 (200%)                                                  | 20.00 to 50.00                    |  |

## Table 7a. IRNG Inputs Status Register Format

| Description:<br>Register Title |       | Fast-trip three<br>Status 2 | shold maximun | n range setting | bits, from IRN | G_ three-state i | inputs        |                |
|--------------------------------|-------|-----------------------------|---------------|-----------------|----------------|------------------|---------------|----------------|
| 5                              |       |                             |               |                 |                |                  |               |                |
| Register Add                   | ress: | 0x33                        |               |                 |                |                  |               |                |
|                                |       |                             |               |                 |                |                  |               |                |
|                                |       |                             |               | R/W             | R/W            | R/W              | R/W           | RESET<br>VALUE |
| _                              | _     | _                           | _             | CH1_<br>IRNG1   | CH1_<br>IRNG0  | CH0_<br>IRNG1    | CH0_<br>IRNG0 | ] _            |
| bit 7                          | bit 6 | bit 5                       | bit 4         | bit 3           | bit 2          | bit 1            | bit 0         | _              |

## Table 7b. Setting Current-Sense Range

| IRNG_ PIN STATE | Chx_IRNG1 | Chx_IRNG0 | MAXIMUM CURRENT-SENSE<br>SIGNAL (mV) |
|-----------------|-----------|-----------|--------------------------------------|
| Low             | 1         | 0         | 25                                   |
| High            | 0         | 1         | 50                                   |
| Open            | 0         | 0         | 100                                  |



Figure 2. Operation and Fault-Management Flowchart for One Channel

| Description:    |         | Fast-comparator threshold DAC setting |        |        |        |        |        |                |
|-----------------|---------|---------------------------------------|--------|--------|--------|--------|--------|----------------|
| Register Title: |         | dac_ch0 dac_ch1                       |        |        |        |        |        |                |
| Register Addr   | resses: | 0x2E                                  | 0x2F   |        |        |        |        |                |
| R/W             | R/W     | R/W                                   | R/W    | R/W    | R/W    | R/W    | R/W    | RESET<br>VALUE |
| DAC[7]          | DAC[6]  | DAC[5]                                | DAC[4] | DAC[3] | DAC[2] | DAC[1] | DAC[0] | 0xBF           |
| bit 7           | bit 6   | bit 5                                 | bit 4  | bit 3  | bit 2  | bit 1  | bit 0  | _              |

## Table 8. dac\_chx Register Format

**MAX5970** 

#### **Digital Current Monitoring**

The two current-sense signals are sampled by the internal 10-bit 10ksps ADC, and the most recent results are stored in registers for retrieval through the I<sup>2</sup>C interface. The current conversion values are 10 bits wide, with the eight high-order bits written to one 8-bit register and the two low-order bits written to the next higher 8-bit register address (Tables 9 and 10). This allows use of just the high-order byte in applications where 10-bit precision is not required. This split 8-bit/2-bit storage scheme is used throughout the MAX5970 for all 10-bit ADC conversion results and 10-bit digital comparator thresholds.

## Table 9. ADC Current Conversion Results Register Format (High-Order Bits)

| Description:   |                          | Most recent c | urrent conversi              | on result, high- | order bits [9:2] |        |        |                |  |
|----------------|--------------------------|---------------|------------------------------|------------------|------------------|--------|--------|----------------|--|
| Register Title |                          | adc_ch0_cs_i  | dc_ch0_cs_msb adc_ch1_cs_msb |                  |                  |        |        |                |  |
| Register Add   | Register Addresses: 0x00 |               | 0x04                         |                  |                  |        |        |                |  |
| R              | R                        | R             | R                            | R                | R                | R      | R      | RESET<br>VALUE |  |
| inew_9         | inew_8                   | inew_7        | inew_6                       | inew_5           | inew_4           | inew_3 | inew_2 | 0x00           |  |
| bit 7          | bit 6                    | bit 5         | bit 4                        | bit 3            | bit 2            | bit 1  | bit 0  |                |  |

## Table 10. ADC Current Conversion Results Register Format (Low-Order Bits)

| Description:   |          | Most recent current conversion result, low-order bits [0:1] |        |           |       |        |        |                |  |  |  |
|----------------|----------|-------------------------------------------------------------|--------|-----------|-------|--------|--------|----------------|--|--|--|
| Register Title | 9:       | adc_ch0_cs_ lst                                             | adc_cl | h1_cs_lsb |       |        |        |                |  |  |  |
| Register Add   | dresses: | 0x01                                                        | 0x05   |           |       |        |        |                |  |  |  |
| R              | R        | R                                                           | R      | R         | R     | R      | R      | RESET<br>VALUE |  |  |  |
|                |          |                                                             |        |           |       | inew_1 | inew_0 | 0x00           |  |  |  |
| bit 7          | bit 6    | bit 5                                                       | bit 4  | bit 3     | bit 2 | bit 1  | bit 0  | -              |  |  |  |

Once the PG\_ output is asserted, the most recent current samples are continuously compared to the programmable overcurrent warning register values. If the measured current value exceeds the warning level, the ALERT output is asserted. The MAX5970 response to this digital comparator is not altered by the setting of the PROT input (Tables 11 and 12).

continuously compared with the contents of minimum-

Minimum and Maximum Value Detection for Current Measurement Values All current measurement values from the ADC are and maximum-value registers, and if the most recent measurement exceeds the stored maximum or is less than the stored minimum, the corresponding register is updated with the new value. These peak detection registers are read accessible through the I<sup>2</sup>C interface (Tables 13–16). The minimum-value registers are reset to 0x3FF, and the maximum-value registers are reset to 0x000. These reset values are loaded upon startup of a channel or at any time as commanded by register peak\_log\_rst (Table 36).

## Table 11. Overcurrent Warning Threshold Register Format (High-Order Bits)

| Description:   |                         | Overcurrent w | arning thresho | ld high-order b | its [9:2] |       |       |                |
|----------------|-------------------------|---------------|----------------|-----------------|-----------|-------|-------|----------------|
| Register Title | :                       | oi_ch0_msb    | oi_ch1_        | _msb            |           |       |       |                |
| Register Add   | egister Addresses: 0x22 |               | 0x2C           |                 |           |       |       |                |
| R/W            | R/W                     | R/W           | R/W            | R/W             | R/W       | R/W   | R/W   | RESET<br>VALUE |
| oi_9           | oi_8                    | oi_7          | oi_6           | oi_5            | oi_4      | oi_3  | oi_2  | 0xFF           |
| bit 7          | bit 6                   | bit 5         | bit 4          | bit 3           | bit 2     | bit 1 | bit 0 | -              |

## Table 12. Overcurrent Warning Threshold Register Format (Low-Order Bits)

|                 |         |               |                | •               | •        |       |       |                |
|-----------------|---------|---------------|----------------|-----------------|----------|-------|-------|----------------|
| Description:    |         | Overcurrent w | arning thresho | ld low-order bi | ts [1:0] |       |       |                |
| Register Title: | :       | oi_ch0_ lsb   | oi_ch1_        | lsb             |          |       |       |                |
| Register Add    | resses: | 0x23          | 0x2D           |                 |          |       |       |                |
| R               | R       | R             | R              | R               | R        | R/W   | R/W   | RESET<br>VALUE |
|                 |         |               |                |                 |          | oi_1  | oi_0  | 0x03           |
| bit 7           | bit 6   | bit 5         | bit 4          | bit 3           | bit 2    | bit 1 | bit 0 |                |

## Table 13. ADC Minimum Current Conversion Register Format (High-Order Bits)

| Description:    |                        | Minimum curr | Minimum current conversion result high-order bits [9:2] |          |        |        |        |                |  |  |
|-----------------|------------------------|--------------|---------------------------------------------------------|----------|--------|--------|--------|----------------|--|--|
| Register Title: | :                      | min_ch0_cs_r | nsb min_ch                                              | 1_cs_msb |        |        |        |                |  |  |
| Register Add    | Register Addresses: 02 |              | 0x10                                                    |          |        |        |        |                |  |  |
| R               | R                      | R            | R                                                       | R        | R      | R      | R      | RESET<br>VALUE |  |  |
| imin_9          | imin_8                 | imin_7       | imin_6                                                  | imin_5   | imin_4 | imin_3 | imin_2 | 0xFF           |  |  |
| bit 7           | bit 6                  | bit 5        | bit 4                                                   | bit 3    | bit 2  | bit 1  | bit 0  | _              |  |  |

M/X/M

| Description:             |       | Minimum curren  | t conversio | n result low-ord | er bits [1:0] |        |        |                            |
|--------------------------|-------|-----------------|-------------|------------------|---------------|--------|--------|----------------------------|
| Register Title           | e:    | min_ch0_cs_ lst | min_c       | h1_cs_ lsb       |               |        |        |                            |
| Register Addresses: 0x09 |       | 0x11            |             |                  |               |        |        |                            |
| R                        | R     | R               | R           | R                | R             | R      | R      | RESE <sup>-</sup><br>VALUI |
|                          |       |                 |             |                  |               | imin_1 | imin_0 | 0x03                       |
| bit 7                    | bit 6 | bit 5           | bit 4       | bit 3            | bit 2         | bit 1  | bit 0  | _                          |

## Table 15. ADC Maximum Current Conversion Register Format (High-Order Bits)

| Description:    |         | Maximum cur | rent conversior | n result high-ord | der bits [9:2] |        |        |                |
|-----------------|---------|-------------|-----------------|-------------------|----------------|--------|--------|----------------|
| Register Title: |         | max_ch0_cs_ | msb max_ch      | 1_cs_msb          |                |        |        |                |
| Register Add    | resses: | 0x0A        | 0x12            |                   |                |        |        |                |
| R               | R       | R           | R               | R                 | R              | R      | R      | RESET<br>VALUE |
| imax_9          | imax_8  | imax_7      | imax_6          | imax_5            | imax_4         | imax_3 | imax_2 | 0x00           |
| bit 7           | bit 6   | bit 5       | bit 4           | bit 3             | bit 2          | bit 1  | bit 0  | _              |

## Table 16. ADC Maximum Current Conversion Register Format (Low-Order Bits)

| Description:<br>Register Title |                          | max_ch0_cs_ | lsb max_cl | n result low-orde<br>h1_cs_ lsb | er bits [1:0] |        |        |                |
|--------------------------------|--------------------------|-------------|------------|---------------------------------|---------------|--------|--------|----------------|
| Register Add                   | Register Addresses: 0x0B |             | 0x13       |                                 |               |        |        |                |
| R                              | R                        | R           | R          | R                               | R             | R      | R      | RESET<br>VALUE |
|                                |                          |             |            |                                 |               | imax_1 | imax_0 | 0x00           |
| bit 7                          | bit 6                    | bit 5       | bit 4      | bit 3                           | bit 2         | bit 1  | bit 0  | _              |

22

#### Digital Voltage Monitoring and Power-Good Outputs

channel can be set to 16V, 8V, 4V, or 2V by writing to register mon\_range. The default range is 16V (Tables 17 and 18).

The voltage at the load (MON\_ inputs) is sampled by the internal ADC. The MON\_ full-scale voltage for each

## Table 17. ADC Voltage Monitor Settings Register Format

| Description:    |         | ADC voltage | monitor full-sca | lle range setting | gs (for MON_ in | puts)     |           |                |
|-----------------|---------|-------------|------------------|-------------------|-----------------|-----------|-----------|----------------|
| Register Title: |         | mon_range   |                  |                   |                 |           |           |                |
| Register Add    | resses: | 0x18        |                  |                   |                 |           |           |                |
|                 |         |             |                  |                   |                 |           |           |                |
| R/W             | R/W     | R/W         | R/W              | R/W               | R/W             | R/W       | R/W       | RESET<br>VALUE |
|                 |         |             |                  | MON2_rng1         | MON2_rng0       | MON1_rng1 | MON1_rng0 | 0x00           |
| bit 7           | bit 6   | bit 5       | bit 4            | bit 3             | bit 2           | bit 1     | bit 0     |                |

## Table 18. ADC Full-Scale Voltage Setting

| MONx_rng1 | MONx_rng0 | ADC FULL-SCALE VOLTAGE (V) |
|-----------|-----------|----------------------------|
| 0         | 0         | 16                         |
| 0         | 1         | 8                          |
| 1         | 0         | 4                          |
| 1         | 1         | 2                          |

The most recent voltage conversion results can be read from the adc\_chx\_mon\_msb and adc\_chx\_mon\_lsb registers (see Tables 19 and 20).

## Table 19. ADC Voltage Conversion Result Register Format (High-Order Bits)

| Description:   |                          |             | 0         | ion result, high-   |        |        |        |                |  |  |
|----------------|--------------------------|-------------|-----------|---------------------|--------|--------|--------|----------------|--|--|
| Register Title | :                        | adc_ch0_mor | n_msb adc | msb adc_ch1_mon_msb |        |        |        |                |  |  |
| Register Add   | Register Addresses: 0x02 |             | 0x0       | 6                   |        |        |        |                |  |  |
| R              | R                        | R           | R         | R                   | R      | R      | R      | RESET<br>VALUE |  |  |
| vnew_9         | vnew_8                   | vnew_7      | vnew_6    | vnew_5              | vnew_4 | vnew_3 | vnew_2 | 0x00           |  |  |
| bit 7          | bit 6                    | bit 5 bit 4 |           | bit 3               | bit 2  | bit 1  | bit 0  | _              |  |  |

## Table 20. ADC Voltage Conversion Result Register Format (Low-Order Bits)

| Description: Most recent voltage conversion result, low-order bits [1:0] |          |            |          |               |       |        |        |                |
|--------------------------------------------------------------------------|----------|------------|----------|---------------|-------|--------|--------|----------------|
| Register Title                                                           | 9:       | adc_ch0_mo | n_lsb ad | c_ch1_mon_lsb |       |        |        |                |
| Register Add                                                             | dresses: | 0x03       | Ox       | 07            |       |        |        |                |
| R                                                                        | R        | R          | R        | R             | R     | R      | R      | RESET<br>VALUE |
|                                                                          |          |            |          |               |       | vnew_1 | vnew_0 | 0x00           |
| bit 7                                                                    | bit 6    | bit 5      | bit 4    | bit 3         | bit 2 | bit 1  | bit 0  |                |

M/IXI/M

#### Digital Undervoltage and Overvoltage Detection Thresholds

The most recent voltage values are continuously compared to four programmable limits, comprising two undervoltage (UV) levels (see Tables 21–24) and two overvoltage (OV) levels (see Tables 25–28).

## Table 21. Undervoltage Warning Threshold Register Format (High-Order Bits)

| Description:   |         | Undervoltage | warning thresh | nold high-order | bits [9:2] |       |       |                |
|----------------|---------|--------------|----------------|-----------------|------------|-------|-------|----------------|
| Register Title | :       | uv1th_ch0_m  | sb uv1th_      | ch1_msb         |            |       |       |                |
| Register Add   | resses: | 0xA1         | 0x1E           |                 |            |       |       |                |
| R/W            | R/W     | R/W          | R/W            | R/W             | R/W        | R/W   | R/W   | RESET<br>VALUE |
| uv1_9          | uv1_8   | uv1_7        | uv1_6          | uv1_5           | uv1_4      | uv1_3 | uv1_2 | 0x00           |
| bit 7          | bit 6   | bit 5        | bit 4          | bit 3           | bit 2      | bit 1 | bit 0 | _              |

## Table 22. Undervoltage Warning Threshold Register Format (Low-Order Bits)

| Description:   |         | Undervoltage  | warning thresh | nold low-order k | oits [1:0] |       |       |                |
|----------------|---------|---------------|----------------|------------------|------------|-------|-------|----------------|
| Register Title | S:      | uv1th_ch0_lst | o uv1th_       | ch1_lsb          |            |       |       |                |
| Register Add   | resses: | 0x1B          | 0x1F           |                  |            |       |       |                |
| R              | R       | R             | R              | R                | R          | R/W   | R/W   | RESET<br>VALUE |
|                |         |               |                |                  |            | uv1_1 | uv1_0 | 0x00           |
| bit 7          | bit 6   | bit 5         | bit 4          | bit 3            | bit 2      | bit 1 | bit 0 |                |

## Table 23. Undervoltage Critical Threshold Register Format (High-Order Bits)

| Description:    |        | Undervoltage | critical thresho | ld high-order b | its [9:2] |       |       |                |
|-----------------|--------|--------------|------------------|-----------------|-----------|-------|-------|----------------|
| Register Title: |        | uv2th_ch0_m  | sb uv2th_c       | ch1_msb         |           |       |       |                |
| Register Addr   | esses: | 0x1C         | 0x26             |                 |           |       |       |                |
| R/W             | R/W    | R/W          | R/W              | R/W             | R/W       | R/W   | R/W   | RESET<br>VALUE |
| uv2_9           | uv2_8  | uv2_7        | uv2_6            | uv2_5           | uv2_4     | uv2_3 | uv2_2 | 0x00           |
| bit 7           | bit 6  | bit 5        | bit 4            | bit 3           | bit 2     | bit 1 | bit 0 |                |

## Table 24. Undervoltage Critical Threshold Register Format (Low-Order Bits)

| Description:   |          | Undervoltage  | critical thresh | old low-order b | its [1:0] |       |       |                |
|----------------|----------|---------------|-----------------|-----------------|-----------|-------|-------|----------------|
| Register Title | 9:       | uv2th_ch0_lst | o uv2th_        | ch1_lsb         |           |       |       |                |
| Register Add   | dresses: | 0x1D          | 0x27            |                 |           |       |       |                |
| R              | R        | R             | R               | R               | R         | R/W   | R/W   | RESET<br>VALUE |
|                |          |               |                 |                 |           | uv2_1 | uv2_0 | 0x00           |
| bit 7          | bit 6    | bit 5         | bit 4           | bit 3           | bit 2     | bit 1 | bit 0 |                |

## Table 25. Overvoltage Warning Threshold Register Format (High-Order Bits)

| Description:    |         | Overvoltage v | varning thresho | ld high-order b | its [9:2] |       |       |                |
|-----------------|---------|---------------|-----------------|-----------------|-----------|-------|-------|----------------|
| Register Title: |         | ov1thr_ch0_m  | isb ov1thr_     | .ch1_msb        |           |       |       |                |
| Register Addr   | resses: | 0x1E          | 0x28            |                 |           |       |       |                |
| R/W             | R/W     | R/W           | R/W             | R/W             | R/W       | R/W   | R/W   | RESET<br>VALUE |
| ov1_9           | ov1_8   | ov1_7         | ov1_6           | ov1_5           | ov1_4     | ov1_3 | ov1_2 | 0xFF           |
| bit 7           | bit 6   | bit 5         | bit 4           | bit 3           | bit 2     | bit 1 | bit 0 |                |

## Table 26. Overvoltage Warning Threshold Register Format (Low-Order Bits)

| Description:   |         | Overvoltage v | arning thresh | old low-order bit | s [1:0] |       |       |                |
|----------------|---------|---------------|---------------|-------------------|---------|-------|-------|----------------|
| Register Title | :       | ov1thr_ch0_ls | b ov1thr_     | ov1thr_ch1_lsb    |         |       |       |                |
| Register Add   | resses: | 0x1F          | 0x29          |                   |         |       |       |                |
| R              | R       | R             | R             | R                 | R       | R/W   | R/W   | RESET<br>VALUE |
|                |         |               |               |                   |         | ov1_1 | ov1_0 | 0x03           |
| bit 7          | bit 6   | bit 5         | bit 4         | bit 3             | bit 2   | bit 1 | bit 0 |                |

## Table 27. Overvoltage Critical Threshold Register Format (High-Order Bits)

| Description:    |         | Overvoltage o | ritical threshold | d high-order bit | s [9:2] |       |       |                |
|-----------------|---------|---------------|-------------------|------------------|---------|-------|-------|----------------|
| Register Title: |         | ov2thr_ch0_m  | isb ov2thr_       | _ch1_msb         |         |       |       |                |
| Register Add    | resses: | 0x20          | 0x2A              |                  |         |       |       |                |
| R/W             | R/W     | R/W           | R/W               | R/W              | R/W     | R/W   | R/W   | RESET<br>VALUE |
| ov2_9           | ov2_8   | ov2_7         | ov2_6             | ov2_5            | ov2_4   | ov2_3 | ov2_2 | 0xFF           |
| bit 7           | bit 6   | bit 5         | bit 4             | bit 3            | bit 2   | bit 1 | bit 0 | -              |

## Table 28. Overvoltage Critical Threshold Register Format (Low-Order Bits)

| Description:   |          | Overvoltage c  | ritical threshol | d low-order bits | [1:0] |       |       |                |
|----------------|----------|----------------|------------------|------------------|-------|-------|-------|----------------|
| Register Title | 1        | ov2thr_ch0_lsl | ov2thr_          | _ch1_lsb         |       |       |       |                |
| Register Add   | Iresses: | 0x21           | 0x2B             |                  |       |       |       |                |
| R              | R        | R              | R                | R                | R     | R/W   | R/W   | RESET<br>VALUE |
|                |          |                |                  |                  |       | ov2_1 | ov2_0 | 0x03           |
| bit 7          | bit 6    | bit 5          | bit 4            | bit 3            | bit 2 | bit 1 | bit 0 | -              |

If PG\_ is asserted and the voltage is outside the warning limits, the ALERT output is asserted low. Depending on the status of the prot[] bits in register status1[7:6], the MAX5970 can also deassert the PG\_ output or turn off the external MOSFET when the voltage is outside the critical limits (see Figure 3). Table 29 shows the behavior for the three possible states of the PROT input. Note that the PROT input does not affect the MAX5970 response to the UV or OV warning digital comparators; it only determines

the system response to the critical digital comparators (see Tables 4a, 4b, and 29).

In a typical application, the UV1 and OV1 thresholds would be set closer to the nominal output voltage, and the UV2 and OV2 thresholds would be set further from nominal. This provides a progressive response to a voltage excursion. However, the thresholds can be configured in any arrangement or combination as desired to suit a given application.

| PROT INPUT<br>STATE | prot[1] | prot[0] | UV/OV WARNING<br>ACTION | UV/OV CRITICAL ACTION                        |
|---------------------|---------|---------|-------------------------|----------------------------------------------|
| Low                 | 0       | 0       | Assert ALERT            | Assert ALERT, clear PG_, shutdown channel(s) |
| High                | 0       | 1       | Assert ALERT            | Assert ALERT ,clear PG_                      |
| Unconnected         | 1       | 0       | Assert ALERT            | Assert ALERT                                 |



Figure 3. Graphical Representation of Typical UV and OV Thresholds Configuration

Table 29. PROT Input and prot[] Bits

#### Power-Good Detection and PG\_ Outputs

The PG\_ output for a given channel is asserted when the voltage at MON\_ is between the undervoltage and overvoltage critical limits. The status of the power-good signals is maintained in register status3[3:0]. A value of 1 in any of the pg[] bits indicates a power-good condition, regardless of the POL setting, which only affects the PG\_ output polarity. The open-drain PG\_ output can be configured for active-high or active-low status indication by the state of the POL input (see Table 30).

## Table 30. status3 Register Format

| Description:   |        | Power-good | status register; | LATCH, POL, A | LERT and Pow | er Good bits |       |                |
|----------------|--------|------------|------------------|---------------|--------------|--------------|-------|----------------|
| Register Title | 9:     | status3    |                  |               |              |              |       |                |
| Register Add   | dress: | 0x34       |                  |               |              |              |       |                |
| R              | R      | R          | R/W              | R             | R            | R            | R     | RESET<br>VALUE |
|                | RETRY  | POL        | ALERT            |               |              | pg[1]        | pg[0] | 0x00           |
| bit 7          | bit 6  | bit 5      | bit 4            | bit 3         | bit 2        | bit 1        | bit 0 |                |

The POL input sets the value of *status3[5]*, which is a read-only bit; the state of the POL input can be changed at any time during operation and the polarity of the PG\_ outputs changes accordingly.

The assertion of the PG\_ output is delayed by a userselectable time delay of 50ms, 100ms, 200ms, or 400ms (see Tables 31a and 31b).

## Table 31a. Power-Good Assertion Delay-Time Register Format

| Description:   |        | Power-good a | assertion delay- | -time register  |                 |                 |                 |                |
|----------------|--------|--------------|------------------|-----------------|-----------------|-----------------|-----------------|----------------|
| Register Title | :      | pgdly        |                  |                 |                 |                 |                 |                |
| Register Add   | Iress: | 0x38         |                  |                 |                 |                 |                 |                |
| R              | R      | R            | R                | R/W             | R/W             | R/W             | R/W             | RESET<br>VALUE |
| _              | _      | _            | _                | pgdly1<br>(CH1) | pgdly0<br>(CH1) | pgdly1<br>(CH0) | pgdly0<br>(CH0) | 0x00           |
| bit 7          | bit 6  | bit 5        | bit 4            | bit 3           | bit 2           | bit 1           | bit 0           | _              |

## Table 31b. Power-Good Assertion Delay

| pgdly1 (CH_) | pgdly0 (CH_) | PG_ASSERTION DELAY (ms) |
|--------------|--------------|-------------------------|
| 0            | 0            | 50                      |
| 0            | 1            | 100                     |
| 1            | 0            | 200                     |
| 1            | 1            | 400                     |

#### Minimum and Maximum Value Detection for Voltage Measurement Values

All voltage measurement values are compared with the contents of minimum- and maximum-value registers, and if the most recent measurement exceeds the stored maximum or is less than the stored minimum, the corresponding register is updated with the new value. These

peak detection registers are read accessible through the I<sup>2</sup>C interface (see Tables 32–35). The minimum-value registers are reset to 0x3FF, and the maximum-value registers are reset to 0x000. These reset values are loaded upon startup of a channel or at any time as commanded by register peak\_log\_rst (see Table 36).

## Table 32. ADC Minimum Voltage Conversion Register Format (High-Order Bits)

| Description:                |        | Minimum volta | age conversion | result, high-ord | der bits [9:2] |        |        |                |
|-----------------------------|--------|---------------|----------------|------------------|----------------|--------|--------|----------------|
| Register Title:             |        | min_ch0_mor   | _msb min_      | _ch1_mon_msb     |                |        |        |                |
| Register Addr               | esses: | 0x0C          | 0x14           | ļ                |                |        |        |                |
| R/W R/W R/W                 |        | R/W           | R/W            | R/W              | R/W            | R/W    | R/W    | RESET<br>VALUE |
| vmin_9 vmin_8 vmin_7 vmin_6 |        |               | vmin_6         | vmin_5           | vmin_4         | vmin_3 | vmin_2 | 0xFF           |
| bit 7                       | bit 6  | bit 5         | bit 4          | bit 3            | bit 2          | bit 1  | bit 0  |                |

## Table 33. ADC Minimum Voltage Conversion Register Format (Low-Order Bits)

| Description:                                    |                     | Minimum voltage conversion result, low-order bits [1:0] |      |       |       |        |        |                |  |
|-------------------------------------------------|---------------------|---------------------------------------------------------|------|-------|-------|--------|--------|----------------|--|
| Register Title: min_ch0_mon_lsb min_ch1_mon_lsb |                     |                                                         |      |       |       |        |        |                |  |
| Register Add                                    | resses:             | 0x0D                                                    | 0x15 |       |       |        |        |                |  |
| R/W                                             | R/W R/W R/W         |                                                         | R/W  | R/W   | R/W   | R/W    | R/W    | RESET<br>VALUE |  |
|                                                 |                     |                                                         |      |       |       | vmin_1 | vmin_0 | 0x03           |  |
| bit 7                                           | 7 bit 6 bit 5 bit 4 |                                                         |      | bit 3 | bit 2 | bit 1  | bit 0  |                |  |

## Table 34. ADC Maximum Voltage Conversion Register Format (High-Order Bits)

| Description:                                    |        | Maximum volt | age conversior | n result, high-or | der bits [9:2] |        |       |                |  |
|-------------------------------------------------|--------|--------------|----------------|-------------------|----------------|--------|-------|----------------|--|
| Register Title: max_ch0_mon_msb max_ch1_mon_msb |        |              |                |                   |                |        |       |                |  |
| Register Addr                                   | esses: | 0x0E         | 0x0E 0x12      |                   |                |        |       |                |  |
| R R                                             |        | R            | R              | R                 | R              | R/W    | R/W   | RESET<br>VALUE |  |
| vmax_9 vmax_8 vmax_7 vma                        |        | vmax_6       | vmax_5         | vmax_4            | vmax_3         | vmax_2 | 0x00  |                |  |
| bit 7 bit 6 bit 5 bit                           |        |              | bit 4          | bit 3             | bit 2          | bit 1  | bit 0 | _              |  |

## Table 35. ADC Maximum Voltage Conversion Register Format (Low-Order Bits)

| Description:             |                       | Maximum volt | age conversion | n result, low-orc | ler bits [1:0] |        |       |                |
|--------------------------|-----------------------|--------------|----------------|-------------------|----------------|--------|-------|----------------|
| Register Title           | 9:                    | max_ch0_mor  | n_lsb max      | _ch1_mon_lsb      |                |        |       |                |
| Register Addresses: 0x0F |                       |              | 0x13           | 3                 |                |        |       |                |
| R                        | R                     | R            | R              | R                 | R              | R/W    | R/W   | RESET<br>VALUE |
|                          |                       |              |                |                   | vmax_1         | vmax_0 | 0x00  |                |
| bit 7                    | bit 7 bit 6 bit 5 bit |              | bit 4          | bit 3             | bit 2          | bit 1  | bit 0 | -              |

#### Using the Voltage and Current Peak-Detection Registers

The voltage and current minimum- and maximum-value records in register locations 0x08 through 0x17 can be reset by writing a 1 to the appropriate location in register peak\_log\_rst (see Table 36). The minimum-value registers are reset to 0x3FF, and the maximum-value registers are reset to 0x00.

As long as a bit in peak\_log\_rst is 1, the corresponding peak-detection registers are disabled and are cleared to their power-up reset values. The voltage and current

minimum- and maximum-detection register contents for each signal can be held by setting bits in register peak\_log\_hold (see Table 37). Writing a 1 to a location in peak\_log\_hold locks the register contents for the corresponding signal and stops the min/max detection and logging; writing a 0 enables the detection and logging. Note that the peak-detection registers cannot be cleared while they are held by register peak\_log\_hold.

The combination of these two control registers allows the user to monitor voltage and current peak-to-peak values during a particular time period.

## Table 36. Peak-Detection Reset-Control Register Format

| Description:<br>Register Title<br>Register Add |       | Reset control<br>peak_log_rst<br>0x41 | bits for peak-c | letection registe | rs        |           |           |                |
|------------------------------------------------|-------|---------------------------------------|-----------------|-------------------|-----------|-----------|-----------|----------------|
| R                                              | R     | R                                     | R               | R/W               | R/W       | R/W       | R/W       | RESET<br>VALUE |
| _                                              | _     | _                                     |                 | Ch1_v_rst         | Ch1_i_rst | Ch0_v_rst | Ch0_i_rst | 0x00           |
| bit 7                                          | bit 6 | bit 5                                 | bit 4           | bit 3             | bit 2     | bit 1     | bit 0     | _              |

#### Table 37. Peak-Detection Hold-Control Register Format

| Description:    |       | Hold control b | oits for peak-de                    | etection register | s; per signal |           |           |                |  |
|-----------------|-------|----------------|-------------------------------------|-------------------|---------------|-----------|-----------|----------------|--|
| Register Title: | :     | peak_log_hold  | b                                   |                   |               |           |           |                |  |
| Register Add    | ress: | 0x42           |                                     |                   |               |           |           |                |  |
| R               | R     | R              | R                                   | R/W               | R/W           | R/W       | R/W       | RESET<br>VALUE |  |
| _               | —     | _              |                                     | Ch1_v_hld         | Ch1_i_hld     | Ch0_v_hld | Ch0_i_hld | 0x00           |  |
| bit 7           | bit 6 | bit 5          | bit 5 bit 4 bit 3 bit 2 bit 1 bit 0 |                   |               |           |           |                |  |

M/IXI/M

# **MAX5970**

#### **Deglitching of Digital Comparators**

The five digital comparators per hot-swap channel (undervoltage/overvoltage warning and critical, overcurrent warning) all have a user-selectable deglitching feature that requires two consecutive positive compares before the MAX5970 takes action as determined by the particular compare and the setting of the PROT input. The deglitching function is enabled or disabled per comparator by registers dgl\_i, dgl\_uv, and dgl\_ov (Tables 38, 39, and 40). Writing a 1 to the appropriate bit location in these registers enables the deglitch function for the corresponding digital comparator.

## Table 38. OI Warning Comparators Deglitch Enable Register Format

| Description:   |               | Deglitch enab | ole register for | overcurrent war | ning digital co | mparators |           |                |  |
|----------------|---------------|---------------|------------------|-----------------|-----------------|-----------|-----------|----------------|--|
| Register Title | ):            | dgl_i         | dgl_i            |                 |                 |           |           |                |  |
| Register Add   | Address: 0x3C |               |                  |                 |                 |           |           |                |  |
| R              | R             | R             | R                | R               | R               | R/W       | R/W       | RESET<br>VALUE |  |
|                |               |               |                  | —               | _               | Ch1_dgl_i | Ch0_dgl_i | 0x00           |  |
| bit 7          | bit 6         | bit 5         | bit 4            | bit 3           | bit 2           | bit 1     | bit 0     |                |  |

## Table 39. UV Warning and Critical Comparators Deglitch Enable Register Format

| Description:    |       | Deglitch enab | ole register for u | undervoltage wa | arning and criti | cal digital com | carators        |                |
|-----------------|-------|---------------|--------------------|-----------------|------------------|-----------------|-----------------|----------------|
| Register Title: | :     | dgl_uv        |                    |                 |                  |                 |                 |                |
| Register Add    | ress: | 0x3D          |                    |                 |                  |                 |                 |                |
| R               | R     | R             | R                  | R/W             | R/W              | R/W             | R/W             | RESET<br>VALUE |
| _               | _     | _             |                    | Ch1_dgl_<br>uv2 | Ch1_dgl_<br>uv1  | Ch0_dgl_<br>uv2 | Ch0_dgl_<br>uv1 | 0x00           |
| bit 7           | bit 6 | bit 5         | bit 4              | bit 3           | bit 2            | bit 1           | bit 0           | -              |

## Table 40. OV Warning and Critical Comparators Deglitch Enable Register Format

| Description:    |       | Deglitch enab | ole register for a | overvoltage war | ning and critica | al digital compa | arators         |                |
|-----------------|-------|---------------|--------------------|-----------------|------------------|------------------|-----------------|----------------|
| Register Title: | :     | dgl_ov        |                    |                 |                  |                  |                 |                |
| Register Add    | ress: | 0x3E          |                    |                 |                  |                  |                 |                |
|                 |       |               |                    |                 |                  |                  |                 |                |
| R               | R     | R             | R                  | R/W             | R/W              | R/W              | R/W             | RESET<br>VALUE |
|                 | _     | _             | _                  | Ch1_dgl_<br>ov2 | Ch1_dgl_<br>ov1  | Ch0_dgl_<br>ov2  | Ch0_dgl_<br>ov1 | 0x00           |
| bit 7           | bit 6 | bit 5         | bit 4              | bit 3           | bit 2            | bit 1            | bit 0           | -              |

#### **Circular Buffer**

The MAX5970 features four 10-bit "circular buffers" (in volatile memory) that contain a history of the 50 most-recent voltage and current digital conversion results for each hot-swap channel. These circular buffers can be read back through the I<sup>2</sup>C interface. The recording of new data to the buffer for a given signal is stopped under any of the following conditions:

• The corresponding channel is shut down because of a fault condition.

Table 41. Circular Buffer Read Addresses

- Clearing appropriate bits in register cbuf\_chx\_store.
- A read of the circular buffer base address is performed through the I<sup>2</sup>C interface.
- The corresponding channel is turned off by a combination of the Chx\_EN1, Chx\_EN2, or ON\_ signals.

The buffers allow the user to recall the voltage and current waveforms for analysis and troubleshooting. The buffer contents are accessed through the I<sup>2</sup>C interface at **four** fixed addresses in the MAX5970 register address space (see Table 41).

| ADDRESS | NAME          | DESCRIPTION                                          |
|---------|---------------|------------------------------------------------------|
| 0x46    | cbuf_ba_ch0_v | Base address for channel 0 voltage buffer block read |
| 0x47    | cbuf_ba_ch0_i | Base address for channel 0 current buffer block read |
| 0x48    | cbuf_ba_ch1_v | Base address for channel 1 voltage buffer block read |
| 0x49    | cbuf_ba_ch_i  | Base address for channel 1 current buffer block read |

Each of the four buffers can also be stopped under user control by register cbuf\_chx\_store (see Table 42).

### Table 42. Circular Buffer Control Register Format

| Description:   |        | Circular buffe | r run-stop con                    | trol register (per | -buffer control: | $1 = run, 0 = sterned{0}$ | op)       |                |  |  |
|----------------|--------|----------------|-----------------------------------|--------------------|------------------|---------------------------|-----------|----------------|--|--|
| Register Title | d.     | cbuf_chx_stor  | re                                |                    |                  |                           |           |                |  |  |
| Register Add   | lress: | 0x19           |                                   |                    |                  |                           |           |                |  |  |
|                |        |                |                                   |                    |                  |                           |           |                |  |  |
| R              | R      | R              | R                                 | R/W                | R/W              | R/W                       | R/W       | RESET<br>VALUE |  |  |
|                | _      | _              | —                                 | Ch1_i_run          | Ch1_v_run        | Ch0_i_run                 | Ch0_v_run | 0x0F           |  |  |
| bit 7          | bit 6  | bit 5          | t 5 bit 4 bit 3 bit 2 bit 1 bit 0 |                    |                  |                           |           |                |  |  |

The contents of a buffer can be retrieved as a block read of either fifty 10-bit values (spanning 2 bytes each) or of

fifty high-order bytes, depending on the per-signal bit settings of register cbufrd\_hibyonly (see Table 43).

## Table 43. Circular Buffer Resolution Register Format

| Description:   |               |                 |                                              | olution: high-ord<br>-order byte outp | <b>,</b> |     |     |                |  |  |  |
|----------------|---------------|-----------------|----------------------------------------------|---------------------------------------|----------|-----|-----|----------------|--|--|--|
| Register Title | :             | cbufrd_hibyonly |                                              |                                       |          |     |     |                |  |  |  |
| Register Add   | Address: 0x3F |                 |                                              |                                       |          |     |     |                |  |  |  |
| R              | R             | R               | R                                            | R/W                                   | R/W      | R/W | R/W | RESET<br>VALUE |  |  |  |
|                | _             | _               | – Ch1_i_res Ch1_v_res Ch0_i_res Ch0_v_res 0; |                                       |          |     |     |                |  |  |  |
| bit 7          | bit 6         | bit 5           | it 5 bit 4 bit 3 bit 2 bit 1 bit 0           |                                       |          |     |     |                |  |  |  |

If the circular buffer contents are retrieved as 10-bit data, the first byte read out is the high-order 8 bits of the 10-bit sample, and the second byte read out contains the two least-significant bits (LSBs) of the sample. This is repeated for each of the 50 samples in the buffer. Thus, 2 bytes must be read for each 10-bit sample retrieved. Conversely, if the buffer contents are retrieved as 8-bit data, then each byte read out contains the 8 MSB of each successive sample. It is important to remember

that in 10-bit mode, 100 bytes must be read to extract the entire buffer contents, but in 8-bit mode, only 50 bytes must be read.

The circular buffer system has a user-programmable stop delay that specifies a certain number of sample cycles to continue recording to the buffer after a shutdown occurs. This delay value is stored in register cbuf\_dly\_stop[5:0] (see Table 44).

## Table 44. Circular Buffer Stop-Delay Register Format

| Description:   |        |               |       | ny integer numb<br>event, before th |       |       |       | e recorded     |
|----------------|--------|---------------|-------|-------------------------------------|-------|-------|-------|----------------|
| Register Title | :      | cbuf_dly_stop | )     |                                     |       |       |       |                |
| Register Add   | lress: | 0x40          |       |                                     |       |       |       |                |
|                |        |               |       |                                     |       |       |       |                |
| R              | R      | R             | R     | R                                   | R     | R     | R     | RESET<br>VALUE |
| 0              | 0      |               |       |                                     |       |       |       | 0x19           |
| bit 7          | bit 6  | bit 5         | bit 4 | bit 3                               | bit 2 | bit 1 | bit 0 |                |

The default (reset) value of the buffer stop-delay is 25 samples, which means that an equal number of samples are stored in the buffer preceding and following the moment of the shutdown event. The buffer stop delay is analogous to an oscilloscope trigger delay, because it allows the MAX5970 to record what happened both immediately before and after a shutdown. In other words, when the contents of a circular buffer are read out of the MAX5970, the shutdown event, by default, is located in the middle of the recorded data. The balance of data before and after an event can be altered by writing a different value (between 0 and 50) to the buffer stop-delay register.

#### **Autoretry or Latched-Off Fault Management**

In the event of an overcurrent, undervoltage, or overvoltage condition that results in the shutdown of one or both channels, the MAX5970 device can be configured to either latch off or automatically restart the affected channel. The MAX5970 stays off if the RETRY input is set low (latched-off), and automatically retries if the RETRY input is high. The RETRY input is read once during initialization and sets the value of status3[6] register (see Table 30).

The autoretry feature has a fixed 200ms timeout delay between fault shutdown and the autorestart attempt. Be aware that if the MAX5970 is configured for autoretry operation, the startup event occurs every 200ms if a short circuit occurs. A short circuit during startup causes the output current to increase rapidly as the MOSFET is enhanced, until the slow-trip threshold is reached and the gate is pulled low again. Be sure to evaluate MOSFET junction temperature rise for this repeatedstress condition if autoretry is used.

To restart a channel that has been shutdown in latchedoff operation (RETRY low), the user must either cycle power to the IN pin, or toggle one or more of the ON\_ pin, Chx\_EN1 bit, or the Chx\_EN2 bit for the affected channel.

#### **Force-On Function**

When the force-on bit for a channel is set to 1 in register foset[1:0] (see Table 45), the channel is enabled regardless of the ON\_ voltage or the Chx\_EN1 and Chx\_EN2 bits in register chxen. In forced-on operation, all functions operate normally with the notable exception that the channel does not shut down due to any fault conditions that may arise.

There is a Force-On Key register fokey that must be set to 0xA5 in order for the Force-On function to become active (see Table 46). If this register contains any value other than 0xA5, writing 1 to the Force-On bits in register foset has no effect. This provides protection against accidental force-on operation that might otherwise be caused by an erroneous  $I^2C$  write.

## Table 45. Force-On Control Register Format

| Description:    |       | Force-on cont | rol register |       |       |        |       |                |
|-----------------|-------|---------------|--------------|-------|-------|--------|-------|----------------|
| Register Title: |       | foset         |              |       |       |        |       |                |
| Register Add    | ess:  | 0x3A          |              |       |       |        |       |                |
|                 |       |               |              |       |       |        |       |                |
| R               | R     | R             | R            | R     | R     | R/W    | R/W   | RESET<br>VALUE |
| 0               | 0     | 0             | 0            | 0     | 0     | Ch1_fo | Ch_fo | 0x00           |
| bit 7           | bit 6 | bit 5         | bit 4        | bit 3 | bit 2 | bit 1  | bit 0 | -              |

## Table 46. Force-On Key Register Format

| Description:    |          | Force-on key | register (must o | contain 0xA5 to | unlock force-or | n feature) |          |                |
|-----------------|----------|--------------|------------------|-----------------|-----------------|------------|----------|----------------|
| Register Title: |          | fokey        |                  |                 |                 |            |          |                |
| Register Add    | ress:    | 0x39         |                  |                 |                 |            |          |                |
| R/W             | R/W      | R/W          | R/W              | R/W             | R/W             | R/W        | R/W      | RESET<br>VALUE |
| fokey[7]        | fokey[6] | fokey[5]     | fokey[4]         | fokey[3]        | fokey[2]        | fokey[1]   | fokey[0] | 0x00           |
| bit 7           | bit 6    | bit 5        | bit 4            | bit 3           | bit 2           | bit 1      | bit 0    |                |

#### **Fault Logging and Indications**

The MAX5970 provides detailed information about any fault conditions that have occurred. Independent FAULT\_ outputs specifically indicate circuit-breaker shutdown events, while an ALERT output is asserted whenever a problem has occurred that requires attention or interaction.

#### Fault Dependency

If a fault event occurs (digital UV warning/critical, digital OV warning/critical, or digital overcurrent warning), the fault is logged by setting a corresponding bit in registers fault1 or fault2 (see Tables 47, 48, and 49).

## Table 47. Undervoltage Status Register Format

| ×              |        | Undervoltage detection stat | 0       | re status registe | er (warning [1:0 | 0] and critical [5 | 5:4] undervolta | age event      |
|----------------|--------|-----------------------------|---------|-------------------|------------------|--------------------|-----------------|----------------|
| Register Title | 9:     | fault0                      |         |                   |                  |                    |                 |                |
| Register Add   | Iress: | 0x35                        |         |                   |                  |                    |                 |                |
| R              | R      | R/C                         | R/C     | R                 | R                | R/C                | R/C             | RESET<br>VALUE |
| _              | _      | ch1_uv2                     | Ch0_uv2 | _                 | _                | Ch1_uv1            | Ch0_uv1         | 0x00           |
| bit 7          | bit 6  | bit 5                       | bit 4   | bit 3             | bit 2            | bit 1              | bit 0           |                |

| Description:   |       | Overvoltage of detection stat | 0       | e status registe | r (warning [1:0 | )] and critical [5 | :4] overvoltage | event          |
|----------------|-------|-------------------------------|---------|------------------|-----------------|--------------------|-----------------|----------------|
| Register Title | :     | fault1                        |         |                  |                 |                    |                 |                |
| Register Add   | ress: | 0x36                          |         |                  |                 |                    |                 |                |
| R              | R     | R/C                           | R/C     | R                | R               | R/C                | R/C             | RESET<br>VALUE |
| _              |       | Ch1_ov2                       | Ch0_ov2 |                  | _               | Ch1_ov1            | Ch0_ov1         | 0x00           |
| bit 7          | bit 6 | bit 5                         | bit 4   | bit 3            | bit 2           | bit 1              | bit 0           |                |

## Table 48. Overvoltage Status Register Format

## Table 49. Overcurrent Warning Status Register Format

| Description:   |        | Overcurrent o | digital-compare | status register | (overcurrent w | arning event de | tection status | 3)             |
|----------------|--------|---------------|-----------------|-----------------|----------------|-----------------|----------------|----------------|
| Register Title | :      | fault2        |                 |                 |                |                 |                |                |
| Register Add   | Iress: | 0x37          |                 |                 |                |                 |                |                |
| R              | R      | R             | R               | R               | R              | R/C             | R/C            | RESET<br>VALUE |
|                |        |               |                 |                 |                | Ch1_oi          | Ch0_oi         | 0x00           |
| bit 7          | bit 6  | bit 5         | bit 4           | bit 3           | bit 2          | bit 1           | bit 0          |                |

Likewise, circuit-breaker shutdown events are logged in register status0[7:0] (see Table 50).

## Table 50. Circuit-Breaker Event Logging Register Format

| Description:    |       | Circuit-breake | er slow- and fas | t-trip event log | ging  |          |          |                |
|-----------------|-------|----------------|------------------|------------------|-------|----------|----------|----------------|
| Register Title: |       | status0        |                  |                  |       |          |          |                |
| Register Add    | ress: | 0x31           |                  |                  |       |          |          |                |
| R               | R     | R              | R                | R                | R     | R        | R        | RESET<br>VALUE |
|                 |       | IFAULTS1       | IFAULTS0         |                  | —     | IFAULTF1 | IFAULTF0 | _              |
| bit 7           | bit 6 | bit 5          | bit 4            | bit 3            | bit 2 | bit 1    | bit 0    |                |

IFAULTSx indicates the overcurrent status from slow comparator. IFAULTFx indicates overcurrent status from fast comparator. The status of FAULT\_ reflects the NOR operation of IFAULTSx and IFAULTFx.

These fault register bits latch upon fault condition and are reset by restarting the affected channel as described in the *Autoretry or Latched-Off Fault Management* section.

#### FAULT\_ Outputs

When an overcurrent event (fast-trip or slow-trip) causes the MAX5970 to shut down the affected channel(s), a corresponding open-drain FAULT\_ output is asserted low. Note that the FAULT\_ outputs are not asserted for shutdowns caused by critical undervoltage or overvoltage.

The FAULT\_ output is cleared when the channel is disabled by pulling ON\_ low or by clearing the bits in the chxen register.

#### ALERT Output

ALERT is an open-drain output that is asserted low any time that a fault or other condition requiring attention has occurred. The state of the ALERT output is also indicated by status3[4].

#### Table 51. LED\_Flash/GPIO Enable Register

 $\overline{\text{ALERT}}$  is the NOR of registers 0x31, 0x35, 0x36 and 0x37, so when the  $\overline{\text{ALERT}}$  output goes low, the system microcontroller should query these registers through the I<sup>2</sup>C interface to determine the cause of the  $\overline{\text{ALERT}}$  assertion.

#### **LED Set Registers**

The MAX5970 has four open-drain LED drivers/userprogrammable GPIOs. When programmed as LED drivers, each driver can sink up to 25mA of current. Table 51 shows the register that enables the drivers as either LED drivers or GPIOs.

When any of the LED\_Set bit in the register is set to 1, the corresponding open-drain LED driver is turned OFF. The LED\_Flash bits enable each corresponding LED driver to flash on and off at 1Hz frequency regardless of the condition of the corresponding LED\_Set bit.

Bits 7-4 in Table 52 show how to set the LED drivers to be either in phase or out of phase with the internal 1Hz clock. Bits 3-0 show how to enable the  $4\mu$ A pullup current to disable a corresponding LED driver.

| Description:    |            | LED_Flash/GI | PIO Enable regi | ster     |          |          |          |                |
|-----------------|------------|--------------|-----------------|----------|----------|----------|----------|----------------|
| Register Title: | :          | LED_flash    |                 |          |          |          |          |                |
| Register Add    | ress:      | 0x43         |                 |          |          |          |          |                |
| R/W             | R/W        | R/W          | R/W             | R/W      | R/W      | R/W      | R/W      | RESET<br>VALUE |
| LED4 Flash      | LED3 Flash | LED2 Flash   | LED1 Flash      | LED4 Set | LED3 Set | LED2 Set | LED1 Set | 0x0F           |
| bit 7           | bit 6      | bit 5        | bit 4           | bit 3    | bit 2    | bit 1    | bit 0    |                |

#### Table 52. LED Phase/Weak Pullup Enable Register

| Description:   |            | LED Phase/W | eak Pullup Ena | ble register    |                 |                 |                 |                |
|----------------|------------|-------------|----------------|-----------------|-----------------|-----------------|-----------------|----------------|
| Register Title | :          | LED_ph_pu   |                |                 |                 |                 |                 |                |
| Register Add   | ress:      | 0x44        |                |                 |                 |                 |                 |                |
| R/W            | R/W        | R/W         | R/W            | R/W             | R/W             | R/W             | R/W             | RESET<br>VALUE |
| LED4<br>Phase  | LED3 Phase | LED2 Phase  | LED1 Phase     | LED4 Weak<br>PU | LED3 Weak<br>PU | LED2<br>Weak PU | LED1<br>Weak PU | 0x00           |
| bit 7          | bit 6      | bit 5       | bit 4          | bit 3           | bit 2           | bit 1           | bit 0           |                |

Table 53 shows LED State register. The LED State register is a read-only register. When the LEDs are disabled, the pins are configured as GPIOs. Applying an external voltage below 0.4V sets the GPIOs low and, applying an external voltage above 1.4V, sets the GPIOs high.

#### **I<sup>2</sup>C Serial Interface**

The MAX5970 features an  ${\rm I}^2{\rm C}$  serial interface consisting of a serial-data line (SDA) and a serial-clock line

(SCL). SDA and SCL allow bidirectional communication between the MAX5970 and the master device at clock rates from up to 400kHz. The I<sup>2</sup>C bus can have several devices (e.g., more than one MAX5970, or other I<sup>2</sup>C devices in addition to the MAX5970) attached simultaneously. The A0 and A1 inputs set one of nine possible I<sup>2</sup>C addresses (see Table 54).

## Table 53. LED State Register

|                 |       | 5            |        |                 |                 |                 |                 |                |
|-----------------|-------|--------------|--------|-----------------|-----------------|-----------------|-----------------|----------------|
| Description:    |       | LED State re | gister |                 |                 |                 |                 |                |
| Register Title: |       | LED_State    |        |                 |                 |                 |                 |                |
| Register Addr   | ress: | 0x45         |        |                 |                 |                 |                 |                |
| R               | R     | R            | R      | R               | R               | R               | R               | RESET<br>VALUE |
| _               | _     | _            | _      | LED4<br>Voltage | LED3<br>Voltage | LED2<br>Voltage | LED1<br>Voltage | _              |
| bit 7           | bit 6 | bit 5        | bit 4  | bit 3           | bit 2           | bit 1           | bit 0           |                |

## Table 54. MAX5970 Slave Address Settings

| ADDRES<br>STA |      |        |        |        | I <sup>2</sup> C ADDR | ESS BITS |        |        |        |
|---------------|------|--------|--------|--------|-----------------------|----------|--------|--------|--------|
| A1            | A0   | ADDR 7 | ADDR 6 | ADDR 5 | ADDR 4                | ADDR 3   | ADDR 2 | ADDR 1 | ADDR 0 |
| Low           | Low  | 0      | 1      | 1      | 1                     | 0        | 1      | 0      | R/W    |
| Low           | High | 0      | 1      | 1      | 1                     | 0        | 0      | 1      | R/W    |
| Low           | Open | 0      | 1      | 1      | 1                     | 0        | 0      | 0      | R/W    |
| High          | Low  | 0      | 1      | 1      | 0                     | 1        | 1      | 0      | R/W    |
| High          | High | 0      | 1      | 1      | 0                     | 1        | 0      | 1      | R/W    |
| High          | Open | 0      | 1      | 1      | 0                     | 1        | 0      | 0      | R/W    |
| Open          | Low  | 0      | 1      | 1      | 0                     | 0        | 1      | 0      | R/W    |
| Open          | High | 0      | 1      | 1      | 0                     | 0        | 0      | 1      | R/W    |
| Open          | Open | 0      | 1      | 1      | 0                     | 0        | 0      | 0      | R/W    |

The 2-wire communication is fully compatible with existing 2-wire serial interface systems; Figure 4 shows the interface timing diagram. The MAX5970 is a transmit/ receive slave-only device, relying upon a master device to generate a clock signal. The master device (typically a microcontroller) initiates data transfer on the bus and generates SCL to permit that transfer.

A master device communicates to the MAX5970 by transmitting the proper address followed by command and/or data words. Each transmit sequence is framed by a START (S) or REPEATED START (Sr) condition and a STOP (P) condition. Each word transmitted over the bus

is 8 bits long and is always followed by an acknowledge pulse.

SCL is a logic input, while SDA is a logic input/opendrain output. SCL and SDA both require external pullup resistors to generate the logic-high voltage. Use  $4.7 \text{k}\Omega$ for most applications.

#### Bit Transfer

Each clock pulse transfers one data bit. The data on SDA must remain stable while SCL is high (see Figure 5), otherwise the MAX5970 registers a START or STOP condition (see Figure 6) from the master. SDA and SCL idle high when the bus is not busy.



Figure 4. Serial-Interface Timing Details



Figure 5. Bit Transfer



Figure 6. START and STOP Conditions

WRITE WORD FORMAT

#### START and STOP Conditions

Both SCL and SDA idle high when the bus is not busy. A master device signals the beginning of a transmission with a START condition (see Figure 3) by transitioning SDA from high to low while SCL is high. The master device issues a STOP condition (see Figure 6) by transitioning SDA from low to high while SCL is high. A STOP condition frees the bus for another transmission. The bus remains active if a REPEATED START condition is generated, such as in the block read protocol (see Figure 7).

#### SEND BYTE FORMAT

| S    | ADDRESS                                                                      | WR                                                                            | ACK                            | DATA                                                         | ACK                                              | Р                  |                               | S                                 | ADDRESS                                               | WR                            | ACK              | COMMAN                                                     | ACK                            | DATA                                              | ACK                             | DATA                                                                        | ACK                                           | Ρ                                  |                     |
|------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------|--------------------------------------------------|--------------------|-------------------------------|-----------------------------------|-------------------------------------------------------|-------------------------------|------------------|------------------------------------------------------------|--------------------------------|---------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------|------------------------------------|---------------------|
|      | 7 BITS                                                                       | 0                                                                             |                                | 8 BITS                                                       |                                                  |                    |                               |                                   | 7 BITS                                                | 0                             |                  | 8 BITS                                                     |                                | 8 BITS                                            |                                 | 8 BITS                                                                      |                                               |                                    |                     |
|      | SLAVE ADDRE<br>EQUIVALENT<br>SELECT LINE (<br>3-WIRE INTER                   | TO CHIP-<br>OF A                                                              |                                | A BYTE-PR<br>RNAL ADD                                        |                                                  |                    |                               |                                   | SLAVE ADDI<br>EQUIVALEN<br>SELECT LINI<br>3-WIRE INTE | TO CHIE<br>OF A               | P- M<br>EE<br>RE | OMMAND BY<br>SB OF THE<br>EPROM<br>EGISTER BEII<br>RITTEN. |                                | DATA BYTE<br>THE EEPRC<br>BYTE IS TH              | M ADDI                          | RESS. S                                                                     | ECOND                                         | 3 OF                               |                     |
| ECE  | IVE BYTE FO                                                                  | RMAT                                                                          |                                |                                                              |                                                  |                    |                               | WRITE                             | BYTE FORN                                             | IAT                           |                  |                                                            |                                |                                                   |                                 |                                                                             |                                               |                                    |                     |
| S    | ADDRESS                                                                      | WR                                                                            | ACK                            | DATA                                                         | ACK                                              | Р                  |                               | S                                 | ADDRESS                                               | WF                            | ī μ              | ACK CO                                                     | MMAND                          | ACK                                               | DAT                             | TA A                                                                        | СК                                            | Ρ                                  |                     |
|      | 7 BITS                                                                       | 1                                                                             |                                | 8 BITS                                                       |                                                  |                    |                               |                                   | 7 BITS                                                | 0                             |                  |                                                            | BITS                           |                                                   | 8 BI                            | TS                                                                          |                                               |                                    |                     |
| :    | SLAVE ADDRE<br>EQUIVALENT T<br>SELECT LINE (<br>3-WIRE INTER<br>K WRITE FOR  | TO CHIP<br>OF A<br>FACE.                                                      | - THE<br>THE<br>BYT            | A BYTE-RE<br>REGISTER<br>LAST REAE<br>E TRANSMI<br>ENDENT ON | COMMAI<br>BYTE O<br>SSION. A                     | NDED E<br>R WRIT   | 3Y                            |                                   | SLAVE ADD<br>EQUIVALEN<br>SELECT LIN<br>3-WIRE INT    | T TO CHI<br>E OF A            | P-               | SEL                                                        | MAND B'<br>CTS REG<br>G WRITTI | ISTER                                             | REGIS<br>BYTE<br>50h.<br>81h, c | BYTE-D<br>STER SET<br>IF THE C<br>IF THE C<br>or 82h, TI<br>ETS THE<br>ESS. | omman<br>By The<br>Comman<br>Omman<br>He Data | COMN<br>D IS BI<br>D IS 80<br>BYTE | IAND<br>ELOW<br>)h, |
|      |                                                                              |                                                                               |                                |                                                              |                                                  |                    |                               |                                   |                                                       |                               |                  |                                                            |                                |                                                   |                                 |                                                                             |                                               |                                    |                     |
| S    | ADDRESS                                                                      | 5 W                                                                           | /R A                           | CK CON                                                       | IMAND                                            | ACK                | BYTE<br>COUNT= N              | ACł                               | C DATA B                                              | YTE A                         | ск [             | DATA BYTE                                                  | ACK                            | DATA BY<br>N                                      | re ac                           | K F                                                                         | >                                             |                                    |                     |
| S    | ADDRESS<br>7 BITS                                                            |                                                                               | VR A                           |                                                              | IMAND<br>BITS                                    | ACK                |                               | ACP                               |                                                       | A                             | CK [             |                                                            | ACK                            |                                                   | re <sub>ac</sub>                | K F                                                                         |                                               |                                    |                     |
|      |                                                                              | RESS-<br>T TO CH<br>E OF A<br>ERFACE.                                         | 0                              | 8 E<br>COMI<br>PREP<br>FOR E                                 |                                                  | /TE-               | COUNT= N                      | ACF                               | * 1<br>8 BITS                                         | S TE-DATA                     | A GOES I         |                                                            |                                | N<br>8 BITS                                       | re ac                           | K F                                                                         |                                               |                                    |                     |
|      | 7 BITS<br>SLAVE ADD<br>EQUIVALEN<br>SELECT LIN<br>3-WIRE INTI                | RESS-<br>T TO CH<br>E OF A<br>ERFACE.<br>MAT                                  | 0<br>IP-                       | 8 E<br>COMI<br>PREP<br>FOR E                                 | MAND BY<br>ARES DE                               | /TE-               | COUNT= N                      | J ACH                             | 1<br>8 BIT:<br>DATA BY<br>COMMA                       | S TE-DATA                     | AGOES            | <br>8 BITS<br>INTO THE RE                                  | GISTER S                       | N<br>8 BITS                                       |                                 |                                                                             | TA BYTE<br>N                                  | ACK                                | Р                   |
| BLOC | 7 BITS<br>SLAVE ADD<br>EQUIVALEN<br>SELECT LIN<br>3-WIRE INTI                | RESS-<br>T TO CH<br>E OF A<br>ERFACE.<br>MAT                                  | 0<br>IP-                       | 8 E<br>COMI<br>PREP.<br>FOR E<br>OPER                        | MAND BY<br>MAND BY<br>ARES DE<br>SLOCK<br>ATION. | /TE<br>VICE        | COUNT= N<br>8 BITS            |                                   | 1<br>8 BIT:<br>DATA BY<br>COMMA                       | TE-DATA<br>ND BYTE            | AGOES            | <br>8 BITS<br>INTO THE RE                                  | GISTER S                       | N<br>8 BITS<br>ET BY THE<br>DATA BY               | 716                             | KDA                                                                         | TA BYTE                                       | ACK                                | P                   |
| BLOC | 7 BITS<br>SLAVE ADD<br>EQUIVALEN<br>SELECT LIN<br>3-WIRE INTI<br>K READ FORI | RESS-<br>T TO CH<br>E OF A<br>ERFACE.<br>WR A<br>0<br>ESS-<br>TO CHIF<br>OF A | 0 IP-<br>CK C<br>P- PRE<br>FOF | 8 E<br>COMI<br>PREP.<br>FOR E<br>OPER                        | ARES DE<br>BLOCK<br>ATION.                       | (TE-<br>VICE<br>SR | COUNT= N<br>8 BITS<br>ADDRESS | WR<br>1<br>SS–<br>O CHIP-<br>DF A | ACK CO                                                | TE-DATA<br>ND BYTE<br>UNT= 16 | A GOES           | <br>8 BITS<br>INTO THE RE<br>DATA BY<br>1                  | GISTER S                       | N<br>8 BITS<br>ET BY THE<br>DATA BY<br><br>8 BITS | TE AC                           | KDA                                                                         | TA BYTE<br>N                                  | ACK                                | P                   |

Figure 7. SMBUS/I<sup>2</sup>C Protocols

#### Early STOP Conditions

The MAX5970 recognizes a STOP condition at any point during transmission except if a STOP condition occurs in the same high pulse as a START condition. This condition is not a legal I<sup>2</sup>C format. At least one clock pulse must separate any START and STOP condition.

#### **REPEATED START Conditions**

A REPEATED START (Sr) condition may indicate a change of data direction on the bus. Such a change occurs when a command word is required to initiate a read operation (see Figure 4). Sr may also be used when the bus master is writing to several I<sup>2</sup>C devices and does not want to relinquish control of the bus. The MAX5970 serial interface supports continuous write operations with or without an Sr condition separating them. Continuous read operations require Sr conditions because of the change in direction of data flow.

#### Acknowledge

**MAX5970** 

The acknowledge bit (ACK) is the 9th bit attached to any 8-bit data word. The receiving device always generates an ACK. The MAX5970 generates an ACK when receiving an address or data by pulling SDA low during the 9th clock period (see Figure 8). When transmitting data, such as when the master device reads data back from the MAX5970, the MAX5970 waits for the master device to generate an ACK. Monitoring ACK allows for detection of unsuccessful data transfers. An unsuccessful data transfer occurs if the receiving device is busy or if a system fault has occurred. In the event of an unsuccessful data transfer, the bus master should reattempt communication at a later time. The MAX5970 generates a NACK after the slave address during a software reboot or when receiving an illegal memory address.



Figure 8. Acknowledge

#### Send Byte

The send byte protocol allows the master device to send one byte of data to the slave device (see Figure 9). The send byte presets a register pointer address for a subsequent read or write. The slave sends a NACK instead of an ACK if the master tries to send an address that is not allowed. If the master sends a STOP condition, the internal address pointer does not change. The send byte procedure follows:

- 1) The master sends a START condition.
- 2) The master sends the 7-bit slave address and a write bit (low).
- 3) The addressed slave asserts an ACK on SDA.
- 4) The master sends an 8-bit data byte.
- 5) The addressed slave asserts an ACK on SDA.
- 6) The master sends a STOP condition.

#### Write Byte

The write byte/word protocol allows the master device to write a single byte in the register bank or to write to a series of sequential register addresses. The write byte procedure follows:

- 1) The master sends a START condition.
- 2) The master sends the 7-bit slave address and a write bit (low).
- 3) The addressed slave asserts an ACK on SDA.
- 4) The master sends an 8-bit command code.
- 5) The addressed slave asserts an ACK on SDA.
- 6) The master sends an 8-bit data byte.
- 7) The addressed slave asserts an ACK on SDA.
- 8) The addressed slave increments its internal address pointer.
- 9) The master sends a STOP condition or repeats steps 6, 7, and 8.

To write a single byte to the register bank, only the 8-bit command code and a single 8-bit data byte are sent. The data byte is written to the register bank if the command code is valid.

The slave generates a NACK at step 5 if the command code is invalid. The command code must be in the range of 0x00 to **0x45**. The internal address pointer returns to 0x00 after incrementing from the highest register address.

#### **Receive Byte**

The receive byte protocol allows the master device to read the register content of the MAX5970 (see Figure 9). The EEPROM or register address must be preset with a send byte protocol first. Once the read is complete, the internal pointer increases by one. Repeating the receive byte protocol reads the contents of the next address. The receive byte procedure follows:

- 1) The master sends a START condition.
- 2) The master sends the 7-bit slave address and a read bit (high).
- 3) The addressed slave asserts an ACK on SDA.
- 4) The slave sends 8 data bits.
- 5) The slave increments its internal address pointer.
- The master asserts an ACK on SDA and repeats steps 4 and 5 or asserts a NACK and generates a STOP condition.

The internal address pointer returns to 0x00 after incrementing from the highest register address.

#### Address Pointers

Use the send byte protocol to set the register address pointers before read and write operations. For the configuration registers, valid address pointers range from 0x00 to 0x45, and the circular buffer addresses are 0x46 to 0x49. Register addresses outside of this range result in a NACK being issued from the MAX5970.

#### Circular Buffer Read

The circular buffer read operation is similar to the receive byte operation. The read operation is triggered after any one of the circular buffer base addresses is loaded. During a circular buffer read, although all is transparent from the external world, internally the auto increment function in the I<sup>2</sup>C controller is disabled. Thus, it is possible to read one of the circular buffer blocks with a burst read without changing the virtual internal address corresponding to the base address. Once the master issues a NACK, the circular reading stops, and the default functions of I<sup>2</sup>C slave bus controller are restored. In 8-bit read mode, every I<sup>2</sup>C read operation shifts out a single sample from the circular buffer. In 10-bit mode, two subsequent I<sup>2</sup>C read operations shift out a single 10-bit sample from the circular buffer, with the high-order byte read first, followed by a byte containing the right-shifted two least-significant bits. Once the master issues a NACK, the read circular buffer operation terminates and normal I<sup>2</sup>C operation returns.

The data in the circular buffers is read back with the next-to-oldest sample first, followed by progressively more recent samples until the most recent sample is retrieved, followed finally by the oldest sample (see Table 55).

#### Table 55. Circular Buffer Readout Sequence

| READ-OUT ORDER       | 1ST OUT | 2ND OUT | <br>48TH OUT | 49TH OUT | 50TH OUT |
|----------------------|---------|---------|--------------|----------|----------|
| Chronological Number | 1       | 2       | <br>48       | 49       | 0        |

#### Chip Information

PROCESS: BiCMOS

#### Package Information

For the latest package outline information and land patterns, go to **www.maxim-ic.com/packages**. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.

| PACKAGE TYPE | PACKAGE CODE | DOCUMENT NO.   |  |
|--------------|--------------|----------------|--|
| 36 TQFN-EP   | T3666-3      | <u>21-0114</u> |  |

Maxim cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim product. No circuit patent licenses are implied. Maxim reserves the right to change the circuitry and specifications without notice at any time.

Maxim Integrated Products, 120 San Gabriel Drive, Sunnyvale, CA 94086 408-737-7600

© 2010 Maxim Integrated Products

Maxim is a registered trademark of Maxim Integrated Products, Inc.