

### Click here to ask an associate for production status of specific part numbers. Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **General Description**

The MAX22216/MAX22217 integrate four programmable 36V half-bridges. It is primarily intended to drive inductive loads such as on-off solenoid valves, DC motors, proportional valves, bi-stable valves, relays, etc. The MAX22216 is capable of up to  $3.2A_{FS}$  per half-bridge, whereas the MAX22217 is capable of up to  $1A_{FS}$  per half-bridge. The MAX22216/MAX22217 operate from -40°C to +125°C ambient temperature.

The MAX22216/MAX22217 half-bridges support two different use cases. In the first case, configuration settings can be entered through a serial peripheral interface (SPI) and can be changed at any time. Alternatively, settings can be stored in one-time programmable (OTP) registers, which are loaded at power-up. This enables stand-alone operations. Registers are user-programmable. The OTP writing procedure must be executed in a factory under well-controlled temperature and voltage conditions.

High-side/low-side single-ended drive operations and bridge-tied load (BTL) configurations are supported. Channel parallelization is also supported.

Voltage control, current control, and mixed schemes are supported.

In voltage drive regulation mode (VDR mode), the halfbridge output voltage is controlled. Supply variations are internally compensated.

In current drive regulation mode (CDR mode), the halfbridge output current is controlled. The current is internally sensed and fed back to the controller for accurate closedloop regulation. Proportional and integral gains can be configured to optimize steady-state errors and dynamic performance.

The MAX22216/MAX22217 integrate functions aimed to optimize solenoid and DC motor drive control. These include a two-level sequencer for power saving, drive signal ramp control (RAMP) for noise reduction, a dither function (DITH) to counteract the effects of static friction and hysteresis, a fast demagnetization feature (DC\_H2L) to shorten on-off cycles, and a DC-Motor current limiter for limiting inrush and stall currents.

Advanced diagnostic functions are available to improve system reliability and enable predictive maintenance. These include the detection of plunger movement (DPM), inductance measurement, travel time measurement, open-load detection (OL), and real-time current monitoring through a serial Interface.

The MAX22216/MAX22217 feature a full set of protection

#### circuits, including overcurrent protection (OCP), overtemperature protection (OVT), and undervoltage lockout (UVM). A fault indicator pin is asserted whenever faults are detected.

The MAX22216/MAX22217 are offered in TQFN32 5mm x 5mm packages.

### **Applications**

- Solenoid On-Off Valves and Relays
- DC Motors
- Proportional Valves
- Bi-Stable Latching Solenoid Valves
- Switching Driver with Real-Time Current Measurement
- Digital Output Interface
- Electromechanical Motor Brake

### **Benefits and Features**

- Four Serial Controlled 36V Half Bridges
  - 1.7A DC (T<sub>A</sub> = 25°C) and 3.2A Full-Scale Current Capability (MAX22216)
  - 0.55A DC (T<sub>A</sub> = 25°C) and 1A Full-Scale Current Capability (MAX22217)
- Low RON for High Efficiency
- High Flexibility:
  - Independent Channel Setting
  - High-Side/Low-Side/Bridge-Tied Load Configuration/Parallel Mode Supported
- Advanced Control Methods
  - · Voltage/Current Drive Regulation
  - Two Levels Sequencer for Power Saving
  - DC-Motor Drive with Current Limiter
  - Dithering Function
  - Ramp up/down Control
  - Demagnetization Voltage Control
  - Integrated Current Sense
- Diagnostic Functions:
  - · Reaction and Travel Time Measurement
  - · Detection of Plunger Movements
  - Open-Load Detection
  - Inductance Measurement
  - Digital Current Sense Monitor
- Full Set of Protections
  - Overcurrent Protection
  - Thermal Protections
  - Undervoltage Lockout

#### Ordering Information appears at end of data sheet.

19-101721; Rev 1; 4/24

© 2024 Analog Devices, Inc. All rights reserved. Trademarks and registered trademarks are the property of their respective owners.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## Simplified Block Diagram



# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **TABLE OF CONTENTS**

| General Description                                | . 1 |
|----------------------------------------------------|-----|
| Applications                                       | . 1 |
| Benefits and Features                              | . 1 |
| Simplified Block Diagram                           | . 2 |
| Absolute Maximum Ratings                           | . 8 |
| Package Information                                | . 8 |
| TQFN 32 - 5mm x 5mm                                | . 8 |
| Electrical Characteristics                         | . 8 |
| Pin Configuration                                  | 13  |
| MAX22216/MAX22217                                  | 13  |
| Pin Description                                    | 13  |
| Functional Diagrams                                | 15  |
| Functional Diagram                                 | 15  |
| Detailed Description                               | 16  |
| OPERATING MODES OVERVIEW                           | 17  |
| Single-Ended Operation                             | 17  |
| Bridge-Tied Load Operation (Full Bridge)           | 19  |
| DC Motor Drive                                     | 21  |
| FUNCTIONAL DESCRIPTION                             | 22  |
| MAX22216/MAX22217 SPI or OTP Configuration         | 22  |
| Enable Logic Input (ENABLE)                        | 22  |
| Nap Mode and ACTIVE Bit                            | 22  |
| V <sub>IO</sub> Pin Description (V <sub>IO</sub> ) | 23  |
| CNTL Pin and CNTL Bits                             | 23  |
| Hardware Configuration                             | 23  |
| HS or LS Single-Ended Configuration                | 25  |
| Chopping Frequency and Timebase Configuration      | 25  |
| Slew Rate and Blanking Configuration (SRC)         | 25  |
| SEQUENCER SETTINGS                                 | 26  |
| Setting the Sequencer Control Mode                 | 26  |
| SEQUENCER LEVEL SETTINGS                           | 27  |
| Voltage Drive Regulation (VDR)                     | 27  |
| CURRENT DRIVE REGULATION (CDR)                     | 27  |
| Current Drive Regulation (CDR)                     | 27  |
| PI Controller                                      | 28  |
| Minimum TON Limitations                            | 29  |
| Current Reference                                  | 30  |
| Setting the Excitation Time (TIME_L2H)             | 30  |
| Setting the Ramp Slopes                            | 31  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| TABLE OF CONTENTS (CONTINUED)                                            |      |
|--------------------------------------------------------------------------|------|
| Enabling the Sine Wave Generator for Dithering or Inductance Measurement | . 31 |
| Setting the Sine Wave Generator                                          |      |
| Brake Current Limiter Function                                           | . 32 |
| DIAGNOSTIC FUNCTIONS AND STATUS MONITOR                                  | . 33 |
| Digital Current Monitor Function                                         | . 33 |
| PWM Duty Cycle Monitor Function                                          | . 34 |
| Digital V <sub>M</sub> Supply Voltage Monitor                            | . 34 |
|                                                                          | . 34 |
| Setting the Inductance Measurement                                       | . 35 |
| Detection of Plunger Movement (DPM) - Overview                           | . 35 |
| Setting the Detection of Plunger Movement                                |      |
| Resistance Measurement                                                   | . 38 |
| Setting the Status Monitor                                               | . 38 |
| STAT Monitor - Single-Ended Diagrams                                     | . 41 |
| STAT Monitor - Differential Diagrams                                     | . 42 |
| PROTECTIONS AND FAULT INDICATOR                                          | . 42 |
| Protections and Fault Indicator Pin (FAULT).                             | . 42 |
| Undervoltage Lockout (UVM)                                               | . 43 |
| Overcurrent Protection (OCP)                                             | . 44 |
| Open-Load Detection During Channel OFF (OL)                              | . 44 |
| Overtemperature Protection (OVT)                                         | . 44 |
| "HIT Current not Reached" Flag (HHF)                                     | . 45 |
| HOW TO CONFIGURE THE MAX22216/MAX22217                                   | . 45 |
| SPI Description                                                          | . 45 |
| SPI Data                                                                 | . 45 |
| CRC Error Detection on the Serial Interface                              | . 46 |
| One-Time Programmable (OTP)                                              | . 47 |
| OTP Programming                                                          | . 47 |
| Wake-Up Time for OTP Download at Power-Up                                | . 48 |
| Register Map                                                             | . 49 |
| FUNCTIONAL REGISTERS                                                     | . 49 |
| Register Details                                                         | . 54 |
| OTP_CONTROLLER                                                           | . 72 |
| Register Details                                                         | . 73 |
| Applications Information                                                 | . 75 |
| Examples of Use                                                          | . 75 |
| V <sub>M</sub> Switching Stand-Alone                                     | . 76 |
| Typical Application Circuits                                             | . 79 |
| Typical Application Circuit                                              | . 79 |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **TABLE OF CONTENTS (CONTINUED)**

| Ordering Information | 79 |
|----------------------|----|
| Revision History     | 80 |

Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **LIST OF FIGURES**

| Figure 1. Single-Ended Configuration               | 18 |
|----------------------------------------------------|----|
| Figure 2. Bridge-Tied Load Configuration           | 19 |
| Figure 3. DC Motor                                 | 21 |
| Figure 4. Block Diagram of Current Control Loop    | 29 |
| Figure 5. HS Configuration Maximal Voltage Graph   | 29 |
| Figure 6. LS Configuration Minimal Voltage Graph   | 30 |
| Figure 7. Detection of Plunger Movement            | 36 |
| Figure 8. STATUS Output Monitor Pin - Single Ended | 41 |
| Figure 9. STATUS Output Monitor Pin - Differential | 42 |
| Figure 10. Fault Output Schematic                  | 44 |
| Figure 11. SPI Datagram without CRC                | 45 |
| Figure 12. SPI Datagram with CRC                   | 45 |
| Figure 13. CRC byte                                | 46 |
| Figure 14. Examples of Use                         | 76 |
| Figure 15. Stand-Alone - VM Switching              | 78 |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### LIST OF TABLES

| Table 1. Hardware Configuration                          | 23 |
|----------------------------------------------------------|----|
| Table 2. Control Table                                   | 24 |
| Table 3. Full-Bridge Control                             | 24 |
| Table 4. PWM Master Frequency Setting                    | 25 |
| Table 5. Individual PWM Frequency                        | 25 |
| Table 6. Slew-Rate Control                               | 25 |
| Table 7. Blanking Time                                   | 26 |
| Table 8. Control Mode Setting                            | 26 |
| Table 9. Full Scale and Sense Scale                      | 28 |
| Table 10. Dither and Inductance Measurement Table        | 32 |
| Table 11. I_MONITOR ADC Max Value - Dec                  | 33 |
| Table 12. Inductance Measurement Fault Detection         | 35 |
| Table 13. STATUS Monitor Based on Inductance Measurement | 35 |
| Table 14. STAT Logic Output Pin Selection                | 39 |
| Table 15. Multifunction Status Pin                       | 40 |
| Table 16. Mask Bits                                      | 43 |
| Table 17. Stretch Enable                                 | 43 |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Absolute Maximum Ratings**

| V <sub>M</sub> to GND  | -0.3V to +42V                                            | SCK to GND0.3V to min (6V, V <sub>IO</sub> + 0.3V)V                       |
|------------------------|----------------------------------------------------------|---------------------------------------------------------------------------|
| V <sub>CP</sub> to GND | V <sub>M</sub> - 0.3V to min (+42V, V <sub>M</sub> + 6V) | SDO to GND                                                                |
| C <sub>FP</sub> to GND |                                                          | $V_{DD}$ to GND                                                           |
| C <sub>FN</sub> to GND | 0.3V to min (+42V, V <sub>M</sub> + 0.3V)                | V <sub>IO</sub> to GND0.3V to +6V                                         |
| CNTL_ to GND           | 0.3V to main (6V, V <sub>IO</sub> + 0.3V)V               | FAULT to GND0.3V to +6V                                                   |
| OUT_to GND             | 0.3V to V <sub>M</sub> + 0.3V                            | I <sub>REF</sub> to GND0.3V to min (+2.2, V <sub>DD</sub> + 0.3)V         |
| PGND to GND            | 0.3V to +0.3V                                            | Continuous Power Dissipation (2s2p Board) ( $T_A = +70^{\circ}C$ , derate |
| CRC_EN to GND          | 0.3V to min (6V, V <sub>IO</sub> + 0.3V)V                | 34.5mW/°C above +70°C.)                                                   |
| STAT_ to GND           | 0.3V to V <sub>IO</sub> + 0.3V                           | Operating Temperature Range40°C to +125°C                                 |
| ENABLE to GND          | 0.3V to V <sub>M</sub> + 0.3V                            | Junction Temperature+150°C                                                |
|                        | 0.3V to min (6V, V <sub>IO</sub> + 0.3V)V                | Storage Temperature Range65°C to 150°C                                    |
| SDI to GND             | 0.3V to min (6V, V <sub>IO</sub> + 0.3V)V                | Lead Temperature (soldering, 10s)+300°C                                   |

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.

## **Package Information**

### TQFN 32 - 5mm x 5mm

| Package Code                                 | T3255Y+4C        |  |  |  |  |
|----------------------------------------------|------------------|--|--|--|--|
| Outline Number                               | <u>21-100214</u> |  |  |  |  |
| Land Pattern Number                          | <u>90-100082</u> |  |  |  |  |
| Thermal Resistance, Single-Layer Board:      |                  |  |  |  |  |
| Junction to Ambient ( $\theta_{JA}$ )        | -                |  |  |  |  |
| Junction to Case $(\theta_{JC})$             | -                |  |  |  |  |
| Thermal Resistance, Four-Layer Board:        |                  |  |  |  |  |
| Junction to Ambient ( $\theta_{JA}$ ) 29°C/W |                  |  |  |  |  |
| Junction to Case $(\theta_{JC})$             | 1.7°C/W          |  |  |  |  |

For the latest package outline information and land patterns (footprints), go to <u>www.maximintegrated.com/packages</u>. 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 thermal resistances were obtained using the method described in JEDEC specification JESD51-7, using a four-layer board. For detailed information on package thermal considerations, refer to <u>www.maximintegrated.com/</u> <u>thermal-tutorial</u>.

### **Electrical Characteristics**

| PARAMETER                      | SYMBOL             | CONDITIONS       | MIN | TYP | MAX  | UNITS |
|--------------------------------|--------------------|------------------|-----|-----|------|-------|
| POWER SUPPLY                   |                    |                  |     |     |      |       |
| Supply Voltage Range           | VM                 |                  | 4.5 |     | 36   | V     |
| Logic Input Supply<br>Voltage  | V <sub>IO</sub>    |                  | 2.2 |     | 5.25 | V     |
| Sleep Mode Current consumption | I <sub>SLEEP</sub> | Enable logic low |     | 4   | 18   | μA    |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Electrical Characteristics (continued)**

| PARAMETER                              | SYMBOL              | CONE                          | DITIONS          | MIN                   | TYP                       | MAX                   | UNITS       |
|----------------------------------------|---------------------|-------------------------------|------------------|-----------------------|---------------------------|-----------------------|-------------|
| Nap Mode Current<br>Consumption        | I <sub>NAP</sub>    | Enable logic high, A          | active = 0       |                       | 210                       | 450                   | μA          |
| Quiescent Current<br>Consumption       | $I_{VM}$            | Enable logic high, A          | ctive = 1        |                       | 7                         | 9                     | mA          |
| LOGIC LEVEL INPUTS-O                   | UTPUTS              |                               |                  | ·                     |                           |                       |             |
| Input Voltage Level -<br>High          | VIH                 |                               |                  | 0.7 x V <sub>IO</sub> |                           |                       | V           |
| Input Voltage Level -<br>Low           | V <sub>IL</sub>     |                               |                  |                       |                           | 0.3 x V <sub>IO</sub> | V           |
| Input Hysteresis                       | V <sub>HYS</sub>    |                               |                  |                       | 0.15 x<br>V <sub>IO</sub> |                       | mV          |
| Logic Input Pin Pulldown<br>Resistance | R <sub>PD</sub>     | To GND. Pins CNTI<br>CRC_EN.  | , SCK, SDI,      | 70                    | 100                       | 130                   | kΩ          |
| CS Pin Pullup<br>Resistance            | R <sub>PU</sub>     | To V <sub>IO</sub>            |                  | 70                    | 100                       | 130                   | kΩ          |
| Logic-Low Output<br>Voltage            | V <sub>OL</sub>     | I <sub>LOAD</sub> = 5mA, STAT | and FAULT pin    |                       |                           | 0.4                   | V           |
| Logic-High Output<br>Voltage           | V <sub>OH</sub>     | I <sub>LOAD</sub> = -5mA      |                  | V <sub>IO</sub> - 0.4 |                           |                       | V           |
| Enable Voltage Level<br>High           | V <sub>IH(EN)</sub> |                               |                  | 0.9                   |                           |                       | V           |
| Enable Voltage Level<br>Low            | V <sub>IL(EN)</sub> |                               |                  |                       |                           | 0.6                   | V           |
| Enable Pulldown Input<br>Resistance    | R <sub>PD(EN)</sub> |                               |                  | 0.8                   | 1.5                       |                       | mΩ          |
| OUTPUT SPECIFICATION                   | NS                  | -                             | -                |                       |                           |                       |             |
|                                        |                     |                               | SNSF[1:0] = "00" |                       | 0.17                      | 0.330                 |             |
| Output On-Resistance                   | Potence             | MAX22216                      | SNSF[1:0] = "01" |                       | 0.23                      | 0.45                  | 0           |
| Low Side                               | R <sub>ON(LS)</sub> |                               | SNSF[1:0] = "10" |                       | 0.43                      | 0.83                  | Ω           |
|                                        |                     | MAX22217                      |                  |                       | 0.43                      | 0.83                  |             |
| Output On-Resistance<br>High Side      | R <sub>ON(HS)</sub> |                               |                  |                       | 0.17                      | 0.33                  | Ω           |
| Output Leakage                         | I <sub>LEAK</sub>   | Driver OFF                    |                  | -5                    |                           | 5                     | μA          |
| Dead Time                              | t <sub>DEAD</sub>   |                               |                  |                       | 0.1                       |                       | μs          |
|                                        |                     | SRC[1:0] = "00"               |                  |                       | 800                       |                       |             |
| Claur Data Ocatral                     | 000                 | SRC[1:0] = "01"               |                  |                       | 400                       |                       | <b>\</b> // |
| Slew-Rate Control                      | SRC                 | SRC[1:0] = "10"               |                  |                       | 200                       |                       | V/µs        |
|                                        |                     | SRC[1:0] = "11"               |                  | 100                   |                           |                       |             |
| PROTECTION CIRCUITS                    |                     |                               |                  |                       |                           |                       |             |
|                                        | OCP                 | SNSF[1:0] = "00"              |                  | 4                     |                           |                       |             |
| Overcurrent Protection<br>Threshold    | t <sub>OCP</sub>    | SNSF[1:0] = "01"              |                  | 2.5                   |                           |                       | А           |
|                                        | OCP                 | SNSF[1:0] ="10"               |                  | 1.2                   |                           |                       |             |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Electrical Characteristics (continued)**

| PARAMETER                                    | SYMBOL                                       | COND                                                              | ITIONS                         | MIN                  | TYP                      | MAX        | UNITS |
|----------------------------------------------|----------------------------------------------|-------------------------------------------------------------------|--------------------------------|----------------------|--------------------------|------------|-------|
| Overcurrent Protection<br>Blanking Time      | TOCP                                         |                                                                   | 1.45                           | 2.1                  | 2.85                     | μs         |       |
|                                              | 104.0                                        | Rising                                                            | 3.75                           | 4                    | 4.25                     |            |       |
| UVLO Threshold on $V_{M}$                    | UVLO                                         | Falling                                                           | Falling                        |                      |                          | 4.12       | V     |
| Thermal Protection<br>Threshold Temperature  | T <sub>SD</sub>                              |                                                                   |                                |                      | 165                      |            | °C    |
| Thermal Protection<br>Temperature Hysteresis | T <sub>SD_HYST</sub>                         |                                                                   |                                |                      | 20                       |            | °C    |
| Open-Load Detection                          | I <sub>OL_LS</sub>                           | OL EN = 1                                                         | HSnLS = 0,<br>Pulldown current |                      | 75                       | 135        | - μA  |
| Current                                      | I <sub>OL_HS</sub>                           |                                                                   | HSnLS = 1, Pullup<br>current   | -50                  | -22                      |            | μΑ    |
| Open-Load Detection                          | V <sub>OL_LS</sub>                           |                                                                   | HSnLS = 0                      |                      | 1.7                      | 2.4        |       |
| Voltage                                      | V <sub>OL_HS</sub>                           | OL_EN_ = 1                                                        | HSnLS = 1                      | V <sub>M</sub> - 2.4 | V <sub>M</sub> -<br>1.75 |            | V     |
| Open-Load Detect<br>Deglitch Time            | t <sub>OL</sub>                              |                                                                   |                                | 189                  | 200                      | 211        | μs    |
| LINEAR REGULATORS                            | VDD REGULATO                                 | R                                                                 |                                |                      |                          |            |       |
| V <sub>DD</sub> Regulator Output<br>Voltage  | V <sub>VDD</sub>                             | I <sub>LOAD</sub> = 20mA                                          |                                |                      | 1.868                    |            | V     |
| V <sub>DD</sub> Current Limit                | IVDD <sub>LIM</sub>                          |                                                                   |                                | 20                   |                          |            | mA    |
| LINEAR REGULATORS                            | VIO REGULAT                                  | OR - (for Stand-Alone                                             | USE CASE)                      |                      |                          |            |       |
| V <sub>IO</sub> Regulator Output<br>Voltage  | V <sub>VIO</sub>                             | EN_LDO = 1,<br>I <sub>LOAD</sub> = 10mA                           | V5nV3 = 1<br>V5nV3 = 0         | 4.8<br>3.15          | 5<br>3.3                 | 5.2<br>3.4 | v     |
| V <sub>IO</sub> Current Limit                | IVIO <sub>LIM</sub>                          | Total current. Interna<br>maximum 10mA                            |                                | 10                   |                          |            | mA    |
| CONTROL                                      |                                              |                                                                   |                                |                      |                          |            |       |
| Internal Oscillator<br>Frequency             | FCLK                                         |                                                                   |                                | 23.7                 | 25                       | 26.3       | MHz   |
|                                              |                                              | MAX22216                                                          | SNSF[1:0] = "00"               |                      | 3.2                      |            |       |
| CDR Maximum Full<br>Scale - LS or FB         | IFSMAX                                       | GAIN[1:0] = "00" -<br>LS or FB config.                            | SNSF[1:0] = "01"               |                      | 2.1                      |            | A     |
|                                              |                                              | ( <u>Note 1</u> )                                                 | SNSF[1:0] = "10"               |                      | 1                        |            | 1     |
| CDR Maximum Full                             | MAX22216<br>GAIN[1:0] = "0<br>HS config. (No |                                                                   | SNSF[1:0] = "00"               |                      | 1.5                      |            |       |
| Scale - HS                                   | IFSMAX                                       | MAX22216                                                          | SNSF[1:0] = "01"               |                      | 1                        |            | - A   |
|                                              |                                              | GAIN[1:0] = "00" -<br>HS config. ( <u>Note 1</u> )                | SNSF[1:0] = "10"               |                      | 0.5                      |            |       |
| CDR Maximum Full<br>Scale - LS or FB         | IFSMAX                                       | MAX22217 GAIN[1:0] = "00" - LS or FB<br>config. ( <u>Note 1</u> ) |                                |                      | 1                        |            | A     |
| CDR Maximum Full<br>Scale - HS               | IFSMAX                                       | MAX22217 GAIN[1:0<br>( <u>Note 1</u> )                            | )] = "00" - HS config.         |                      | 0.5                      |            | A     |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Electrical Characteristics (continued)**

| PARAMETER                                               | SYMBOL            | COND                                         | ITIONS                                                                      | MIN | TYP          | MAX | UNITS |
|---------------------------------------------------------|-------------------|----------------------------------------------|-----------------------------------------------------------------------------|-----|--------------|-----|-------|
| CDD Constant                                            | K                 | MAX22216                                     | MAX22216                                                                    |     | 1.017        |     |       |
| CDR Constant                                            | K <sub>CDR</sub>  | MAX22217                                     |                                                                             |     | 0.339        |     | – mA  |
| VDR Constant                                            | K <sub>VDR</sub>  |                                              |                                                                             |     | 30.518       |     | μV    |
| Resistance<br>Measurement Constant                      | K <sub>R</sub>    |                                              |                                                                             |     | 8.437        |     | mΩ    |
| REF Pin Resistor Range                                  | R <sub>REF</sub>  | See <u>Note 2</u>                            |                                                                             |     | 12kΩ ±<br>5% |     | kΩ    |
| Supply Voltage (V <sub>M</sub> )<br>Monitoring Constant | K <sub>VM</sub>   |                                              |                                                                             |     | 9.73         |     | mV    |
| CONTROL / ACCURACY                                      | ( <u>Note 3</u> ) |                                              |                                                                             |     |              |     |       |
|                                                         |                   |                                              | I <sub>OUT</sub> ≥ 250mA,<br>SNSF[1:0] = "00"                               | -5  |              | 5   |       |
| Current Control and                                     |                   | MAX22216,<br>GAIN[1:0] = "00"                | I <sub>OUT</sub> ≥ 140mA,<br>SNSF[1:0] = "01"                               | -5  |              | 5   | 0/    |
| Monitor - Accuracy DCD                                  |                   |                                              | I <sub>OUT</sub> ≥ 70mA,<br>SNSF = "10"                                     | -5  |              | 5   | - %   |
|                                                         |                   | MAX22217, GAIN[<br>1:0] = "00"               | I <sub>OUT</sub> ≥ 70mA                                                     | -5  |              | 5   |       |
| FUNCTIONAL TIMINGS                                      |                   |                                              | · · · · · ·                                                                 |     |              |     |       |
| Disable Time                                            | t <sub>DIS</sub>  | Enable falling edge t                        | o OUT_ tristated                                                            |     |              | 20  | μs    |
| Enable Time                                             | t <sub>EN</sub>   |                                              | From enable logic high to normal operation (see <i>Note 4</i> for details)  |     |              | 0.8 | ms    |
| Fixed Wake-Up Time                                      | <sup>t</sup> FWU  | From active = 1 to no<br>(excluding user OTP | ormal operation<br>download) - ( <u>Note 5</u> )                            |     |              | 1.1 | ms    |
| Variable Wake-Up Time                                   | t∨wu              |                                              | Time required to download one user-<br>configurable OTP register (2 bytes). |     | 2.56         |     | μs    |
| SPI SPECIFICATIONS                                      |                   | ·                                            | · · · ·                                                                     |     |              |     |       |
| SCK Clock Period                                        | tour              | V <sub>IO</sub> > 3V                         |                                                                             | 100 |              |     | ns    |
| SON CIOCK I EIIOG                                       | <sup>t</sup> CLK  | V <sub>IO</sub> < 3V                         |                                                                             | 140 |              |     | 113   |
| SCK High Time                                           | t <sub>CH</sub>   |                                              |                                                                             | 20  |              |     | ns    |
| SCK Low Time                                            | t <sub>CL</sub>   |                                              |                                                                             | 20  |              |     | ns    |
| CS SCK Valid before or after change of CS               | t <sub>CC</sub>   |                                              |                                                                             | 20  |              |     | ns    |
| CS Pulse-Width High                                     | t <sub>CSH</sub>  | See also <u>Note 6</u>                       |                                                                             | 20  |              |     | ns    |
| SDI Setup Time before<br>SCK Rising Edge                | t <sub>DS</sub>   |                                              |                                                                             | 10  |              |     | ns    |
| SDI Hold Time after<br>SCK Rising Edge                  | t <sub>DH</sub>   |                                              |                                                                             | 10  |              |     | ns    |
| SDO Propagation Delay                                   | te e              | $C_{1,0,1,0} = 15$ $nE_{1,0,1,0}$            | V <sub>IO</sub> > 3V                                                        |     |              | 40  |       |
| SDO Propagation Delay                                   | t <sub>DO</sub>   | C <sub>LOAD</sub> = 15pF                     | VIO < 3V                                                                    | 75  |              |     | ns ns |

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

- Note 1: Recommended "CDR Max full scale" specifies the maximum current at which the device has been characterized and tested. The device can possibly deliver currents higher than IFSMAX, provided that the overcurrent protection and thermal limitations are not exceeded.
- Note 2: Current control and monitor accuracy is directly proportional to the accuracy of the resistor connected to the  $I_{REF}$  pin. Use ±1% tolerance or better resistors whenever accuracy is required. Accuracy data in this data sheet assumes an ideal REF = 12k $\Omega$  resistor.
- **Note 3:** Guaranteed by Bench characterization. Not production tested.  $R_{REF} = 12k\Omega$
- **Note 4:** The enable command must be held logic high for longer than 0.8ms to ensure the MAX22216/MAX22217 complete its powerup sequence. Commands shorter than 0.8ms can cause the device to enter in unpredictable status.
- **Note 5:** The total wake-up time (t<sub>WU</sub>) is given by the sum of a fixed (T<sub>SWU</sub>) and a variable contribute N x T<sub>VWU</sub> in which N is the total number of user-programmable OTP registers (2 bytes each) written into the OTP bank. (See the <u>Wake Up time for OTP</u> <u>download at power up</u> section.)
- Note 6: A longer T<sub>CSH</sub> is required whenever a fault condition needs to be cleared. We recommend longer than 1µs T<sub>CSH</sub> whenever a fault condition needs to be cleared.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **Pin Configuration**

### MAX22216/MAX22217



## **Pin Description**

| PIN            | NAME            | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | REF<br>SUPPLY | TYPE  |
|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|
| 15, 20, 21, 26 | V <sub>M</sub>  | Supply Voltage Input. All V <sub>M</sub> pins must be shorted on the board.<br>Bypass V <sub>M</sub> to GND with 0.1µF local ceramic capacitors close to<br>pins 21, 20 and pins 26, 15. Add electrolytic reservoir tank<br>capacitors as required by the application (typically values >10µF).                                                                                                                                                                                                                                                                                                                                                                                                                 |               | Power |
| 32             | V <sub>IO</sub> | I/O Supply Input Voltage Pin if the Internal Linear Regulator is<br>Disabled (EN_LDO = 0 default condition). For SPI-based<br>applications, connect $V_{IO}$ to the external MCU supply voltage for<br>proper communication between the controller and the MAX22216/<br>MAX22217. Bypass $V_{IO}$ to GND with a 100nF or greater<br>capacitor.Voltage regulator output if the internal linear regulator is enabled<br>(EN_LDO = 1). This configuration is used for stand-alone OTP-<br>based applications. The linear regulator output can be configured<br>either at 3.3V or 5V. Connect at least a 0.47µF bypass capacitor<br>to GND to ensure the regulator stability. The maximum external<br>load is 10mA. |               |       |
| 6              | V <sub>DD</sub> | 1.8V LDO Regulator Output. Bypass GND with a 2.2 $\mu$ F ceramic capacitor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               | Power |
| 12             | C <sub>FN</sub> | Charge Pump Capacitor–N Side. Connect a 22nF, $V_M\mbox{-}rated$ ceramic capacitor from $C_{FN}$ to $C_{FP}.$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               | Power |
| 13             | C <sub>FP</sub> | Charge Pump Capacitor–P Side. Connect a 22nF, $V_M$ -rated ceramic capacitor from $C_{FN}$ to $C_{FP}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               | Power |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

# **Pin Description (continued)**

| PIN            | NAME             | FUNCTION                                                                                                                                                                                                        | REF<br>SUPPLY   | TYPE                 |
|----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------|
| 14             | V <sub>CP</sub>  | Charge Pump Output. Connect a 1 $\mu$ F, 5V, or greater ceramic capacitor to V <sub>M</sub> .                                                                                                                   |                 | Power                |
| 17, 18, 23, 24 | PGND             | Power Ground. All PGND pins must be shorted on the board.                                                                                                                                                       |                 | GND                  |
| 5              | GND              | Signal Ground                                                                                                                                                                                                   |                 | GND                  |
| 25             | OUT0             | Driver Output Channel 0                                                                                                                                                                                         |                 | Output               |
| 22             | OUT1             | Driver Output Channel 1                                                                                                                                                                                         |                 | Output               |
| 19             | OUT2             | Driver Output Channel 2                                                                                                                                                                                         |                 | Output               |
| 16             | OUT3             | Driver Output Channel 3                                                                                                                                                                                         |                 | Output               |
| 1              | I <sub>REF</sub> | Current Regulation Reference. Connect a 1% accurate $12k\Omega$ resistor from $I_{REF}$ to GND to set the full-scale current for all the channels in CDR Mode.                                                  |                 | Analog Input         |
| 29             | CS               | SPI Chip Select–Active Low. Internal pullup current.                                                                                                                                                            | V <sub>IO</sub> | Logic Input          |
| 28             | SCK              | SPI Clock Input. Rising edge clocks data into the part for write operations. Falling edge clocks data out of part for read operations. Internal pulldown to GND.                                                | V <sub>IO</sub> | Logic Input          |
| 30             | SDI              | SPI Data In from Controller. Internal pulldown to GND.                                                                                                                                                          | V <sub>IO</sub> | Logic Input          |
| 31             | SDO              | SPI Data Output.                                                                                                                                                                                                | V <sub>IO</sub> | Logic Output         |
| 7              | CNTL0            | Control Logic Input. Internal pulldown to GND. To avoid spurious triggering by large noise, it is recommended to connect the pin to GND if not used.                                                            | V <sub>IO</sub> | Logic Input          |
| 8              | CNTL1            | Control Logic Input. Internal pulldown to GND. To avoid spurious triggering by large noise, it is recommended to connect the pin to GND if not used.                                                            | V <sub>IO</sub> | Logic Input          |
| 9              | CNTL2            | Control Logic Input. Internal pulldown to GND. To avoid spurious triggering by large noise, it is recommended to connect the pin to GND if not used.                                                            | V <sub>IO</sub> | Logic Input          |
| 10             | CNTL3            | Control Logic Input. Internal pulldown to GND. To avoid spurious triggering by large noise, it is recommended to connect the pin to GND if not used.                                                            | V <sub>IO</sub> | Logic Input          |
| 3              | STAT0            | Status Logic Output.                                                                                                                                                                                            | V <sub>IO</sub> | Logic Output         |
| 4              | STAT1            | Status Logic Output.                                                                                                                                                                                            | V <sub>IO</sub> | Logic Output         |
| 11             | CRC_EN           | Logic Input. Drive CRC_EN logic high to enable cyclic redundancy check on SPI communication. Internal pulldown to GND.                                                                                          | V <sub>IO</sub> | Logic Input          |
| 2              | FAULT            | Pulled Logic Low with a Fault Condition. Open-drain output requires an external pullup resistor.                                                                                                                |                 | Open Drain<br>Output |
| 27             | ENABLE           | Enable Pin. HV logic input pin compatible up to $V_M$ . Drive ENABLE logic high to enable device; drive ENABLE logic low to enter low-power sleep mode; Internal pulldown resistor.                             |                 | Logic Input          |
| _              | EP               | Exposed Pad. The exposed pad (thermal pad) must be electrically connected to the board GND. For good thermal dissipation, use large ground planes on multiple layers and multiple vias connecting those planes. |                 | GND                  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **Functional Diagrams**

### **Functional Diagram**



# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Detailed Description**

The MAX22216/MAX22217 integrate four programmable 36V Half-Bridges. It is primarily intended to drive inductive loads such as on-off solenoid valves, DC motors, proportional valves, bi-stable valves, relays, etc. The MAX22216 is capable of up to  $3.2A_{FS}$  per half-bridge, whereas the MAX22217 is capable of up to  $1A_{FS}$  per half-bridge. The MAX22216/MAX22217 operate from -40°C to +125°C ambient temperature.

The MAX22216/MAX22217 half-bridges support two different use cases. In the first case, configuration settings can be entered through a serial peripheral interface (SPI) and can be changed any time. Alternatively, settings can be stored into one-time programmable (OTP) registers, which are loaded at power-up. This enables stand-alone operations. Registers are user-programmable. The OTP writing procedure must be executed in a factory under well-controlled temperature and voltage conditions.

Both high-side and low-side single-ended drive operations are supported to accommodate multiple load requirements.

Pairs of half-bridges can also be configured to drive loads in a bridge-tied load (BTL) configuration. Typical examples are proportional solenoid valves, bi-stable valves, or DC motors.

Since settings are completely independent, different types of loads can be driven simultaneously from the same MAX22216/MAX22217 devices. For instance, two single-ended controlled valves and one bi-stable valve in full-bridge configuration can be driven from the same MAX22216/MAX22217.

Channel parallelization is also supported to increase the current capability. For maximum flexibility, two, three, or all four half-bridges can be connected in parallel, resulting in 2X, 3X, and 4X current capability.

Both voltage and current control schemes are supported together with mixed modes.

In voltage mode, two regulation methods are supported and can be configured independently for each drive channel.

- In VDR\_DUTY, the user sets the target duty cycle. In this mode, the actual voltage applied to the load directly depends on the V<sub>M</sub> voltage supply.
- In VDR Mode (VDRnVDRDUTY), the user sets the target voltage to the load. An internal circuitry senses the supply
  voltage and compensates the output duty cycle to get the desired voltage.

In current mode (CDR mode), the output current is controlled. The current is internally sensed and fed back to the controller for accurate closed-loop regulation. Proportional and Integral gains can be configured to optimize steady-state error and dynamic performances. The reference current in CDR mode is determined by the resistor connected to the  $I_{REF}$  pin. For this reason, an accurate  $12k\Omega$  resistor must be connected between pin  $I_{REF}$  and GND.

The MAX22216/MAX22217 integrate functions aimed at optimizing solenoid and DC motor drive control, such as:

- Multi-level drive control method (excitation and hold drive with programmable excitation time), resulting in power savings and optimal drive of solenoid valves.
- Programmable voltage/current ramps (RAMP) smooth the activation/deactivation of the valves and hence reduce acoustic noise.
- Programmable dither (DITH) to counteract the effects of stiction and hysteresis by superimposing a small ripple over the DC level.
- A DC motor controller in which the motor is driven in voltage drive mode, the inrush and stall current being limited by an internal limiter circuit.
- A programmable demagnetization voltage (DC\_H2L) to ensure accurate and safe control of the demagnetization current (BTL configuration only).

Advanced diagnostic functions are also available to improve system reliability and enable predictive maintenance. In particular, the device features:

- Detection of plunger movement (DPM) aims to detect the movement of the plunger during the excitation phase and report a fault if the plunger gets stuck.
- An inductance measurement circuitry that can be used to detect the status of ON/OFF solenoid valves.
- Reaction time and travel time measurements for diagnostic and predictive maintenance.
- Open-load detection (OL).
- Real-time current monitoring through serial interface (SPI).

Finally, the MAX22216/MAX22217 feature a full set of protections, including overcurrent protection (OCP),

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

overtemperature protection (OVT), and undervoltage lockout (UVM). Whenever the fault is detected and if it is not masked, the fault indicator pin is asserted, and fault information is logged into a dedicated register.

The main differences between MAX22216 and MAX22217 are the output current rating and resistance, and channel current measurement. These differences are explained in the <u>*Electrical Characteristics*</u>, but as a general overview of the current measurement, they have different K<sub>CDR</sub> and only the MAX22216 has a sense scaling factor (SNSF) (for MAX22217 you can assume an SNSF of 1 in all formulas related to current measurements).

### **OPERATING MODES OVERVIEW**

#### Single-Ended Operation

In this configuration, the load is driven in single-ended mode, with the other terminal connected to the positive rail (lowside drive configuration) or to GND (high-side configuration).

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



Figure 1. Single-Ended Configuration

<u>Figure 1</u> shows a typical multilevel drive sequence in single-ended mode. The CNTL signal (namely either the logic input or the corresponding bit in the control register) activates/deactivates the solenoid as shown in <u>Figure 1</u>.

The following parameters are user configurable either with SPI (SPI-based use case) or with OTPs (Stand-alone use case) (see the Register Map section).

### Low-Side/High-Side Drive Settings

- Excitation High Level: **DC\_L2H[15:0]**
- Hold Level: DC\_H[15:0]
- Low Level: DC\_L[15:0] Low-level voltage setting is mainly intended for inductance measurement (AC scan)

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

- Excitation Time: TIME\_L2H[15:0]
- Energizing/de-energizing Ramp slope: RAMP[7:0]
- AC Scan/Dither Amplitude and Frequency (U\_AC\_SCAN[14:0] and F\_AC\_SCAN[11:0] global for all the channels)

DC levels settings may refer to voltages, duty cycles, or currents, depending on the desired control strategy. Mixed modes (for instance, DC\_L2H in voltage mode and DC\_H in current mode) are supported too.

#### **Bridge-Tied Load Operation (Full Bridge)**



Figure 2. Bridge-Tied Load Configuration

Figure 2 shows a typical multilevel drive sequence for a bridge-tied load solenoid (Bi-stable valves, proportional valves,

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

etc.). The CNTL signal (namely the logic input or the corresponding bit in the control register) activates/deactivates the solenoid as shown in Figure 2.

The following parameters are user configurable either with SPI (a SPI-based use case) or with OTPs (a stand-alone use case) (see the Register Map section).

Bridge-Tied Load Drive Settings

- Excitation High Level: DC\_L2H[15:0]
- Hold Level: DC\_H[15:0]
- Demagnetization Voltage: **DC\_H2L[15:0]**. It allows to demagnetize the coil by reverting the drive voltage. To avoid inverting the current, DC\_H2L is automatically de-asserted once the coil current approaches zero. DC\_H2L is global for all the channels.
- Low Level: **DC\_L[15:0]** Low-level voltage (normally set to zero)
- Excitation Time: TIME\_L2H[15:0]
- Energizing/de-energizing Ramp Slope: RAMP[7:0]
- AC Scan/Dither Amplitude and Frequency: (U\_AC\_SCAN[14:0] and F\_AC\_SCAN[11:0]) global for all the channels.

With the exception of the demagnetization level (DC\_H2L)I, which is programmable in voltage mode only, all the DC level settings may refer to voltages, duty cycles, or currents depending on the desired control strategy. Mixed modes (for instance, DC\_L2H in voltage mode and DC\_H in current mode) are supported too.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **DC Motor Drive**



Figure 3. DC Motor

Figure 3 shows the MAX22216/MAX22217 drive signals with reference to a bidirectional DC motor use case (similar drive methods can be implemented for a unidirectional DC motor drive). When the CNTL signal is applied (either from the logic input or via SPI), the controller applies the nominal voltage levels (DC\_H) first. If the inrush current during startup exceeds the programmable current limiter threshold (DC\_L2H), the current limiter takes over by reducing the PWM output voltage and effectively limiting the inrush current to a safe level. At the nominal speed of the motor, the BEMF limits the current so that the nominal voltage (DC\_H) is automatically applied.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

Note that the current limiter is always enabled. In particular, whenever a stall occurs, the limiter limits the stall current to a safe value for the motor and the driver. Once the current exceeds the current limit defined by the DC\_L2H register, the loop reduces the voltage applied to the motor, effectively limiting the current to the desired safe value.

The following parameters are user configurable:

#### **Brushed DC Motor Settings**

- DC Motor Drive Mode: CTRL\_MODE[1:0] = 10
- Current Limiter Threshold: DC\_L2H[15:0]
- Drive Voltage Level: DC\_H[15:0]
- Brake Current Level: TIME\_L2H[15:0]

The MAX22216/MAX22217 feature a current limiter for the motor brake current. This function enables the fastest deceleration of the motor given the overcurrent protection limitations of the device. See the <u>Brake Current Limiter</u> <u>Function</u> section for further details. Due to the way the output PWM is created, the actual output frequency is double the set F PWM. Also, the sine wave generator affects this operating mode only by adding noise at the HiZ state.

DC motor drive can also be used in single-ended mode, but the output will be affected by the CDRs MIN\_T\_ON (LS will have a minimum voltage and HS will have a maximum voltage), and the BRAKE is not functional.

### FUNCTIONAL DESCRIPTION

#### MAX22216/MAX22217 SPI or OTP Configuration

As shown in the <u>OPERATING MODES</u> section, the MAX22216/MAX22217 is a highly configurable device that supports different applications and use cases.

The configuration settings can be input into the MAX22216/MAX22217 in two different ways: through SPI-configuration (Mode 0 or Mode 3) or through OTP-configuration.

In SPI-configuration, volatile registers must be written through a serial peripheral interface (SPI) after power up.

In OTP-configuration, the user writes one-time programmable (OTP) registers whose content is used as the default configuration setting at power-up. OTP writing must be done in a controlled test setup in the factory. When OTP-configuration is used, the MAX22216/MAX22217 can operate in stand-alone mode with minimal control signals from outside.

Further details are available in the HOW TO CONFIGURE THE MAX22216/MAX22217 section.

#### Enable Logic Input (ENABLE)

The enable pin is a V<sub>M</sub>-rated logic input pin.

Drive the ENABLE logic low to disable the device. This corresponds status to the lowest power consumption for the device.

Drive the ENABLE logic high to enable the device. When enabled, the ENABLE pin must be held high for at least TEN to complete the power-up sequence and prevent the MAX22216/MAX22217 from entering unpredictable statuses.

A pulldown resistor ensures the MAX22216/MAX22217 is disabled if the Enable pin is not actively driven.

In stand-alone operating mode, the ENABLE pin can possibly be externally connected to the positive rail (V<sub>M</sub>). This way, the solenoid valve can be activated/deactivated by simply powering up/down the device (see the  $V_M$  Switching Stand-Alone section).

#### Nap Mode and ACTIVE Bit

The ACTIVE bit in the GLOBAL\_CFG register activates/deactivates the MAX22216/MAX22217. When ACTIVE = "0" and ENABLE is logic high, the device is in Nap Mode. Power consumption is minimized (see the *Electrical Characteristics* table), the sequencer is disabled, and driver outputs are tri-stated. In SPI-based applications, this corresponds to the default condition at power-up. To enter in normal operation, the ACTIVE bit must be set after the device configuration.

In an OTP-based application, this bit must be programmed high to enable stand-alone operations.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### V<sub>IO</sub> Pin Description (V<sub>IO</sub>)

The  $V_{IO}$  voltage is the reference for logic Inputs and output signals. The  $V_{IO}$  pin can be configured by writing two bits in the STATUS\_CFG[15:0] register.

EN\_LDO is the enable bit of the internal regulator.

If EN\_LDO = "0" (default), the V<sub>IO</sub> must be provided from the outside, and V<sub>IO</sub> is a supply voltage input pin.

If EN\_LDO = "1", then an internal linear regulator is turned on and the  $V_{IO}$  pin becomes an output (settable at 3.3V or 5V).

In SPI-based applications, the  $V_{IO}$  pin is normally configured as an input and connected to the voltage supply of the external controller to enable communication between the MAX22216/MAX22217 and the controller.

In OTP-based applications (stand-alone mode) in which the SPI is not used and wiring must be minimized, the internal linear regulator can be enabled to supply the internal I/O circuitry. The regulator output voltage can be set either at 3.3V or 5V, depending on the selection of the V5\_nV3 bit. The regulator can only be activated via the OTP programming functionality and is available after a reboot of the part.

#### **CNTL Pin and CNTL Bits**

As shown in <u>OPERATING MODES OVERVIEW</u>, a change of the status of the CNTL pin or of the CNTL bit in the STATUS register initiates and ends the sequence (with the exception of the V<sub>M</sub> switching stand-alone control, in which the supply voltage itself is used as a command signal; see the <u>V<sub>M</sub> Switching Stand-Alone</u> section).

The polarity of the CNTL pin can be changed with the CNTL\_POL bit in the GLOBAL\_CFG configuration register, this does not affect the polarity of the CNTL bits. Set CNTL\_POL = "0" for positive polarity (CNTL is active high). Set CNT\_POL = "1" for negative polarity (CNTL is active low). In the special case of using CNT\_POL = "1" together with a full-bridge configuration, the CNTL pins will not change polarity, but they will change the control channel. For example, the CNTL0 pin will control CH1 output, and the CNTL1 pin will control CH0. The same applies for CH2 and CH3 pairs. As this setting affects only the CNTL pins, all the other settings are the same.

CNTL bit in the STATUS register and CNTL pins are in or-ing configuration. If either the bit or the input signal is active, then the sequencer is enabled. This also means that once the channel is active using one method, it cannot be turned off using the other control method. If the MAX22216/MAX22217 are controlled via SPI, then the CNTL pins must be set as inactive (it is recommended to connect CNTL logic pins to GND to prevent spurious triggering by noise).

Vice versa, if the MAX22216/MAX22217 are controlled only via logic inputs CNTL, then the CNTL bits must be set as inactive (default state).

#### Hardware Configuration

The MAX22216/MAX22217 provide flexibility. The channel hardware configuration bits CHS[3:0] in the GLOBAL\_CFG register must be set to match the hardware configuration of the half bridge of the MAX22216/MAX22217.

Maximum current can be increased by using a parallel half- or full-bridge configuration. As there is no connection between the channels inside the IC, it has to be done on the PCB. A pair of channels can also be configured in full-bridge mode to drive the load differentially (bridge-tied load). <u>Table 1</u> summarizes all possible hardware configurations. (HB = Half Bridge, FB = Full Bridge).

| CHS | SUPPORTED CONFIGURATIONS               | HARDWARE SETTINGS          |
|-----|----------------------------------------|----------------------------|
| 0x0 | 4x Independent half-bridges (HB)       | OUT0, OUT1, OUT2, OUT3     |
| 0x1 | 3x Parallel HBs + 1x Independent HB    | OUT0 = OUT1 = OUT2, OUT3   |
| 0x2 | 2x Parallel HBs + 2x Independent HBs   | OUT0 = OUT1, OUT2, OUT3    |
| 0x3 | 2x Parallel HBs + 2x Parallel HBs      | OUT0 = OUT1, OUT2 = OUT3   |
| 0x4 | 4x Parallel HBs                        | OUT0 = OUT1 = OUT2 = OUT3  |
| 0x5 | 2x Independent Full Bridges (FB)       | OUT0 vs OUT1, OUT2 vs OUT3 |
| 0x6 | 1x Independent FB + 2x Independent HBs | OUT0 vs OUT1, OUT2, OUT3   |
| 0x7 | 1x Independent FB + 2x Parallel HB     | OUT0 vs OUT1, OUT2 = OUT3  |

### Table 1. Hardware Configuration

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### Table 1. Hardware Configuration (continued)

| 0x8 1x Parallel FB | OUT0 = OUT1 vs OUT2 = OUT3 |
|--------------------|----------------------------|
|--------------------|----------------------------|

When channels are parallelized, the MAX22216/MAX22217 uses the configuration settings of the channel with a lower channel index. For instance, for the configuration 0x3 in <u>Table 1</u>, the configuration settings of channel "0" and channel "2" control the parallelized half bridges, whereas the configuration settings of channel "1" and channel "3" are ignored.

<u>Table 2</u> and <u>Table 3</u> summarize the active control registers (CFG\_) and the active command signal (CNTL\_) for each Hardware Configuration. The configuration registers store all the parameters that are used by the sequencer (see the <u>OPERATING MODES</u> section), plus other configuration parameters explained in the following paragraphs. Each CFG is controlled by the specific CNTL channel (CFG\_0 is controlled by CNTL0), and it controls the output based on channel configuration.

The CNTL signals enable (CNTL = 1) or disable (CNTL = 0) the corresponding channels, as shown in <u>Table 2</u>.

The enable/disable signals can be either hardware-based (logic I/Os) or software-based (CNTL bits in the GLOBAL\_CTRL register). HW and SW controls are in OR configuration: if either the logic CNTL input or the corresponding bit in the GLOBAL\_CTRL register are logic high, then the channel is enabled. It follows that in SW-based control, the logic input pins must be grounded (logic low). Vice versa, for HW-based control, the control bits must be set to zero (default at power up).

In full-bridge operation, a center-aligned PWM chopping method is used so that the effective PWM frequency is doubled and ripple is minimized. With this technique, a zero voltage across the load corresponds to a 50% duty cycle applied on each side of the bridge-tied load. Moreover, the control signals (CNTLx, CNTLy) determine the configuration registers, as shown in <u>Table 3</u>.

|                    | OUTPUT SETTI         | NGS                            | ACTIVE CON         | IFIGURATION RE | GISTER/CONTRO | L CHANNEL   |
|--------------------|----------------------|--------------------------------|--------------------|----------------|---------------|-------------|
| CHS[3:0]           | OUTPUT CONFIGURATION |                                | CH0 OUTPUT         | CH1 OUTPUT     | CH2 OUTPUT    | CH3 OUTPUT  |
| 0x0                | 4x Independent HB    |                                | CFG_0/CNTL0        | CFG_1/CNTL1    | CFG_2/CNTL2   | CFG_3/CNTL3 |
| 0x1                | 3x Parallel HBs      | Parallel HBs 1x Independent HB |                    | CFG_0/CNTL0    |               | CFG_3/CNTL3 |
| 0x2                | 2x Parallel HBs      | 2x Independent HBs             | CFG_0/CNTL0        |                | CFG_2/CNTL2   | CFG_3/CNTL3 |
| 0x3                | 2x Parallel HBs      | 2x Parallel HBs                | CFG_0/CNTL0        |                | CFG_2/CNTL2   |             |
| 0x4                | 4x Para              | allel HBs                      | CFG_0/CNTL0        |                |               |             |
| 0x5                | 1x Independent FB    | 1x Independent FB              | see <u>T</u>       | able 3         | see T         | able 3      |
| 0x6                | 1x Independent FB    | 2x Independent HBs             | see <u>Table 3</u> |                | CFG_2/CNTL2   | CFG_3/CNTL3 |
| 0x7                | 1x Independent FB    | 2x Parallel HB                 | see <u>Table 3</u> |                | CFG_2         | / CNTL2     |
| 0x8 1x Parallel FB |                      |                                | see <u>T</u>       | able 3         |               |             |

### Table 2. Control Table

### Table 3. Full-Bridge Control

| CHS[3:0]  | BRIDGE CFG               | CNTLx | CNTLy | OUTx        | OUTy        | FB Status      |
|-----------|--------------------------|-------|-------|-------------|-------------|----------------|
| 0 x 05    | OUTx vs OUTy             | 0     | 0     | HiZ         | HiZ         | HiZ            |
|           | (x, y) = (0,1) or (2, 3) | 1     | 0     | CF          | G_x         | DRIVEN by CH X |
|           |                          | 0     | 1     | CF          | G_y         | DRIVEN by CH Y |
|           |                          | 1     | 1     | 50% PWM     | 50% PWM     | BRAKE          |
| CHS[3:0]  | BRIDGE CFG               | CNTL0 | CNTL1 | OUT0        | OUT1        | FB Status      |
| 0 x 06 or | OUT0 vs OUT1             | 0     | 0     | HiZ         | HiZ         | HiZ            |
| 0 x 07    |                          | 1     | 0     | CF          | G_0         | DRIVEN by CH 0 |
|           |                          | 0     | 1     | CF          | G_1         | DRIVEN by CH 1 |
|           |                          | 1     | 1     | 50% PWM     | 50% PWM     | BRAKE          |
| CHS[3:0]  | BRIDGE CFG               | CNTL0 | CNTL1 | OUT0 = OUT1 | OUT2 = OUT3 | FB Status      |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Table 3. Full-Bridge Control (continued)**

| 0 x 08 | OUT0 = OUT1 vs OUT2 = OUT3 | 0 | 0 | HiZ HiZ   |         | HiZ            |
|--------|----------------------------|---|---|-----------|---------|----------------|
|        |                            | 1 | 0 | CF        | G_0     | DRIVEN by CH 0 |
|        |                            | 0 | 1 | CFG_1 DRI |         | DRIVEN by CH 1 |
|        |                            | 1 | 1 | 50% PWM   | 50% PWM | BRAKE          |

#### HS or LS Single-Ended Configuration

In single-ended mode, the MAX22216/MAX22217 can be configured as an HS driver (load is connected between OUT and GND) or as an LS driver (load is connected between OUT and  $V_M$ ). The selection bit HSnLS can be written in the CFG\_CTRL[15:0] register. Set HSnLS = "1" for the HS operation. Set HSnLS = "0" for the LS operation.

#### **Chopping Frequency and Timebase Configuration**

The MAX22216/MAX22217 feature an integrated oscillator that sets the time base of the device and determines the chopping frequency, F<sub>PWM</sub>.

F\_PWM\_M[3:0] bits in the GLOBAL\_CTRL register set the master PWM frequency, as shown in Table 4.

### Table 4. PWM Master Frequency Setting

| HEX     | 0x0 | 0x1 | 0x2 | 0x3 | 0x4 | 0x5 | 0x6 | 0x7 |
|---------|-----|-----|-----|-----|-----|-----|-----|-----|
| F_PWM_M | 100 | 80  | 60  | 50  | 40  | 30  | 25  | 20  |
| HEX     | 0x8 | 0x9 | 0xA | 0xB | 0xC |     |     |     |
| F_PWM_M | 15  | 10  | 7.5 | 5   | 2.5 |     |     |     |

Note: 0xD, 0xE, and 0XF are same as 0x0 (100kHz)

The master chopping frequency can be further divided down individually for each half bridge by setting bits F\_PWM[1:0] in the configuration register for that specific channel, as shown in <u>Table 5</u>.

### Table 5. Individual PWM Frequency

| F_PW | M[1:0] | CHOPPING FREQUENCY OF INDIVIDUAL CHANNEL |
|------|--------|------------------------------------------|
| 0    | 0      | F_PWM_M                                  |
| 0    | 1      | F_PWM_M/2                                |
| 1    | 0      | F_PWM_M/4                                |
| 1    | 1      | F_PWM_M/8                                |

The resulting chopping frequency (F\_PWM) is also used as a time base for configuring the timings of the sequencer and/ or other functions. Generally, if the PWM frequency is not a requirement of the design, it is recommended to use smaller frequencies, such as 25kHz or 10kHz for increased accuracy. If the channels do not have different PWM frequency requirements, the main frequency can be set in F\_PWM\_M (PWM master frequency) and the individual channel F\_PWM can be left to the default setting of 0x00. Frequencies in the audio range (like 10kHz) might create noise in the solenoid coil.

#### Slew Rate and Blanking Configuration (SRC)

The slew rate of the rising and falling edges can be controlled by means of two configuration bits in the configuration register (SRC[1:0]). <u>Table 6</u> shows the possible settings.

Slower edges reduce over/undershooting and ringing and are therefore effective in mitigating electro magnetic emission (EME). On the other hand, slow edges result in higher power consumption and worse VDR control accuracy.

Current measurements taken just after the falling edges can be inaccurate as they may be affected by electrical noise and ringing occurring after the commutation.

### Table 6. Slew-Rate Control

| SRC[1:0] SLEW-RATE CONTROL |
|----------------------------|
|----------------------------|

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### Table 6. Slew-Rate Control (continued)

| 00 | Fast     |
|----|----------|
| 01 | 400 V/µs |
| 10 | 200 V/µs |
| 11 | 100 V/µs |

The T\_BLANKING bits are stored in the CFG\_CTRL register. T\_BLANKING and SRC Slew Rate affect the output only in single-ended CDR modes, as it adds a delay to the MIN\_T\_ON and hence adds restrictions to the duty cycle at a given PWM frequency (see the <u>Minimum TON Limitations</u> section).

### Table 7. Blanking Time

| T_BLANKING_[1:0] | T_BLANKING VALUE |
|------------------|------------------|
| 00               | 0                |
| 01               | 24               |
| 10               | 48               |
| 11               | 96               |

### SEQUENCER SETTINGS

#### Setting the Sequencer Control Mode

As shown in the <u>Operating Modes</u>, the sequencer can be configured to address different use cases.

The DC\_L2H and DC\_H levels can be controlled either in voltage mode or current mode. In addition, there are 2 mixed control modes, from which the Motor Control Mode is used to better address DC motor drive applications, as the DC\_L2H can be configured to set the threshold of the current limiter to suppress inrush current and DC\_H sets the motor driving voltage (see the <u>Bi-directional DC Motor Drive</u> section).

Two bits in the configuration register of each individual channel allow selecting the desired control mode, as shown in <u>Table 8</u>.

### **Table 8. Control Mode Setting**

| CTRL_MODE[1] | CTRL_MODE[0] | DC_L2H          | DC_H | TYPICAL USE CASES                  |
|--------------|--------------|-----------------|------|------------------------------------|
| 0            | 0            | VDR             | VDR  | Solenoid drive                     |
| 0            | 1            | CDR             | CDR  | Solenoid drive, Proportional valve |
| 1            | 0            | Current limiter | VDR  | Brushed DC motor                   |
| 1            | 1            | VDR             | CDR  | Solenoid drive, Proportional valve |

A third low level (DC\_L) can also be programmed individually for each channel, as explained in <u>Operating Modes</u>. DC\_L can be controlled only in voltage mode (VDR) together with the sine wave generator. This is mostly intended to be used in single mode operations to allow inductance measurement (see the <u>Inductance Measurement</u> section).

For full-bridge configuration, it is possible to demagnetize the coil by applying a reverse demagnetization voltage at the end of the excitation phase (see the <u>Bridge Tied Load Operation (Full Bridge)</u> section). The demagnetization voltage can be set by writing the global register DC\_H2L[15:0] with a negative value and setting H2L\_EN for each individual channel. To avoid current inversion, the demagnetization voltage is automatically de-asserted as soon as the current approaches zero.

It is also possible to set the device so that the reverse demagnetization voltage is applied when the coil is energized and the supply drops below a threshold stored into the VM\_THLD\_DOWN[3:0] bits of the VM\_THRESHOLD register (see the Register Map and  $V_M$  Switching Stand-Alone section for further details). If this function is enabled, as soon as the supply drops below VM\_THLD\_DOWN, a reverse voltage equal to DC\_H2L is applied so that the coil is quickly demagnetized. The reverse voltage is maintained until the current is zeroed. During the demagnetization transitory, the coil current recirculates back to the supply, causing the V<sub>M</sub> voltage to be pumped up. Therefore, the bypass capacitor on V<sub>M</sub> must be large enough to absorb the coil energy without exceeding the maximum operating voltage.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### SEQUENCER LEVEL SETTINGS

### Voltage Drive Regulation (VDR)

DC\_L2H, DC\_H, and DC\_L levels can be configured for VDR mode operation by programming the corresponding configuration registers for each individual channel. VDR is supported for high-side drive, low-side drive, and differential drive bridge-tied load (BTL) configurations.

Two alternative voltage control modes can be selected by means of the VDRnVDRDUTY selection bit in the GLOBAL\_CFG register:

When VDRDUTY is selected (VDRnVDRDUTY = "0"), the DC\_ levels correspond to the target duty cycle. The average output is proportional to the supply ( $V_M$ ). The average output voltage is therefore given by

 $V_{OUT}$  (V) =  $K_{VDR} \times V_M$  (V)  $\times DC_{[15:0]DEC}$ 

Where  $K_{VDR}$  is a constant equal to 30.518µ (see the <u>Electrical Characteristic</u> table). In this formula, it should be used as 30.518 x 10<sup>-6</sup> V.

When VDR is selected (VDRnVDRDUTY = "1"), the DC\_ levels correspond to the target output voltage. Variations of the supply voltage are internally compensated. The average output voltage is given by:

### V<sub>OUT</sub> (V) = K<sub>VDR</sub> x 36 x DC\_ [15:0]<sub>DEC</sub>

The voltage control accuracy is affected by several non-idealities that are not internally compensated. In particular, rise and fall edge mismatch and voltage drop on power FETs can have an impact on the VDR accuracy. In general, better performance can be achieved when fast edges and low PWM chopping frequencies are selected.

The internal PWM generator runs at 25MHz, so the actual resolution of the control depends on the programmed PWM chopping frequency. For instance, if channels run at 30kHz, the PWM resolution is 2 x 30kHz/25MHz = 0.24%.

The duty cycle control range is limited depending on the programmed chopping frequency, and in single ended CDR mode by the MIN\_T\_ON. However, the 100% and 0% (always ON and always OFF) statuses are always supported and mapped as  $DC_{15:0} = 0x7FFF$  and  $DC_{15:0} = 0x0000$ , respectively.

When in full-bridge configuration, the PWM modulator adopts a center-aligned modulation scheme. Both sides of the coil are PWM-modulated.

$$D_{OUTX} = (1 + D)/2, D_{OUTY} = (1-D)/2$$

Duty Cycle = 
$$D = D_{OUTX} - D_{OUTY}$$

Where X and Y are the two generic channels driving the load in full-bridge configuration.

This approach results in doubling the ripple frequency and halving the amplitude of the ripple. When VDR or VDRDUTY equals zero, the two channels output a 50% duty cycle.

#### **CURRENT DRIVE REGULATION (CDR)**

#### Current Drive Regulation (CDR)

DC\_L2H, DC\_H, and DC\_L levels can be configured for CDR Mode operation by programming the corresponding 16 bits configuration registers. CDR is supported for single-ended LS and HS drive and differential BTL configurations.

In DC motor drive mode (CTRL\_MODE\_[1:0] = "10" in the channel configuration register), the DC\_L2H stores the threshold at which the current limiter starts limiting the current either during motor start up or under stall conditions.

When the current drive regulation method is used, a proportional Integral controller controls the current at the desired set point. Current is internally sensed onto the low-side power FET without the need of external shunt resistors. The sensing is bidirectional, so that the MAX22216/MAX22217 can measure both sinking currents (LS drive and Full Bridge modes) and sourcing currents (HS drive Configuration Mode). However, in HS mode, the maximum current that can be accurately measured is less than for the LS and full-bridge modes since excessive currents can turn on the FET body drain diode and affect the accuracy of the measurement.

Under steady conditions, the controlled current can be calculated from the following formulas:

| MAX22216 | I <sub>OUT(mA)</sub> = K <sub>CDR</sub> x GAIN x SNSF x DC_[15:0] <sub>DEC</sub> |
|----------|----------------------------------------------------------------------------------|
|----------|----------------------------------------------------------------------------------|

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| Ν | /IAX22217 | $I_{OUT(mA)} = K_{CDR} \times GAIN \times DC_[15:0]_{DEC}$ |
|---|-----------|------------------------------------------------------------|
|---|-----------|------------------------------------------------------------|

Where

- DC\_[15:0]<sub>DEC</sub> is the target DC current value (in decimal notation) stored in the corresponding register. To avoid saturation, we recommend not exceeding DC\_[15:0]<sub>DEC</sub> = 3145 for LS and full-bridge configurations and 1475 for HS configurations (Assuming GAIN = SNSF = 1). In other terms, the maximum full-scale current is 3.2A in LS or full-bridge mode, and 1.5A in HS mode. The maximum bit value for the current is based on the channel control configuration and I\_MONITOR scaling of each channel. For more detail, see the *Digital Current Monitor Function* section. If the real current value is set too high, the OCP will trigger (as it is independent of the I\_MONITOR), or the IC will heat up too much and trigger the OVT. Always set the I\_MONITOR range, taking into consideration the maximum current in the configuration.
- K<sub>CDR</sub> is a constant typically equal to 1.017mA and 0.34mA, respectively, for the MAX22216 and MAX22217. K<sub>CDR</sub> directly depends on the external 12kΩ reference resistor connected between the I<sub>REF</sub> pin (see the <u>Current Reference</u> section). For accurate current control, a precise resistor must be used.
- GAIN (see <u>Table 9</u>) is a two bits programmable gain factor (GAIN[1:0] bits into the configuration register).
- SNSF (see <u>Table 9</u> is a two bits programmable Sense Scaling Factor (SNSF[1:0] bits into the Configuration Register). As shown in <u>Table 9</u>, the SNSF value determines the resistance of the low-side power FET (R<sub>ON</sub>), which is used as a sense element. A higher resistance of the sensing element results in better accuracy of the control at low currents. This function is only available for the MAX22216, so for MAX22217 you can assume SNSF = 1 in all current measurement related formulas.

When multiple half- or full-bridges are used in parallel, the maximum digital reading value multiplies independently of the individual channels GAIN or SNSF settings (as the I\_MEASUREMENT will become the sum of the individual channel currents); however, the GAIN/SNSF settings apply to all connected channels based on the main configuration channel; see the <u>Digital Current Monitor Function</u> section. For a quality reading of the current, it is recommended to set the GAIN and SNSF based on the worst-case maximum current for the application (including temperature increase in current consumption and MOSFET resistances), while using the smallest range possible for better resolution. If the I\_MONITOR value overflows, then the Inductance and Resistance measurements become unreliable. <u>Table 9</u> shows the scaling factors for the current measurement of one channel (maximum digital current value of 4095) and their effects.

| GAIN [1:0] | GAIN | SNSF [1:0] | SNSF   | TYP. LS R <sub>ON</sub> (Ω) | TOTAL FACTOR | MULTIPLIER | MAX CURRENT (A) |
|------------|------|------------|--------|-----------------------------|--------------|------------|-----------------|
| 00         | 1    |            |        |                             | 1            | 1.00       | 4.165           |
| 01         | 1/2  | 00         | 1      | 0.17                        | 1/2          | 0.5        | 2.082           |
| 10         | 1/3  | 00         |        | 0.17                        | 1/3          | 0.333      | 1.388           |
| 11         | 1/4  |            |        |                             | 1/4          | 0.25       | 1.041           |
| 00         | 1    |            |        |                             | 2/3          | 0.667      | 2.776           |
| 01         | 1/2  | 01         | 2/3    | 2/3 0.23                    | 2/6          | 0.333      | 1.388           |
| 10         | 1/3  |            |        |                             | 2/9          | 0.222      | 0.925           |
| 11         | 1/4  |            |        |                             | 2/12         | 0.167      | 0.694           |
| 00         | 1    |            |        |                             | 1/3          | 0.333      | 1.388           |
| 01         | 1/2  | 10         | 10 1/3 | 0.43                        | 1/6          | 0.167      | 0.694           |
| 10         | 1/3  |            |        |                             | 0.43         | 1/9        | 0.111           |
| 11         | 1/4  |            |        |                             | 1/12         | 0.083      | 0.347           |

### Table 9. Full Scale and Sense Scale

#### **PI Controller**

The current loop is based on Proportional Integral (PI) control. Proportional and Integral coefficients can be set individually for each channel. PI control results in optimal current control and tunable time response characteristics.

16 bits Register CFG\_P[15:0] and CFG\_I[15:0] define the control parameters for each channel. The registers define the Proportional Gain (Kp) and Integral Gain (Ki) characteristics in Q8.8 format.

Figure 4 shows the block diagram of the current control loop.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



Figure 4. Block Diagram of Current Control Loop

As the output of the IC is affected and limited by the load, it is recommended that a tuning method that takes this into consideration.

Both P and I are 16-bit variables, accepting values from 0 to 65535, which gives a great level of control. It is also recommended to use the opening current and opening time given by the load manufacturer; in this case, they represent DC\_L2H and TIME\_L2H.

### **Minimum TON Limitations**

For single-ended (HS or LS configurations) CDR operation, a minimum duty cycle of the low-side transistor has to be applied. This is needed to grant a correct measurement of the current. If the PI controller applies a duty cycle below the possible duty cycle, the output value of the PI controller will be overwritten. In this case, the integrator of the PI controller will be frozen unless the calculated values lead to a higher duty cycle on the low-side transistor. This behavior results in a minimal voltage above zero that can be applied in CDR mode in a LS driver configuration and a maximal voltage that is below the V<sub>M</sub> supply voltage in a HS driver configuration. The below diagrams indicate the behavior of the LS driver and HS driver configurations.



Figure 5. HS Configuration Maximal Voltage Graph

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



Figure 6. LS Configuration Minimal Voltage Graph

The minimal on-time on the low-side transistor is described by the formula:

MIN\_T\_ON (s) = (MIN\_TON\_SINGLE\_ENDED + 2<sup>SLEW\_RATE[1:0]+1</sup> +T\_BLANKING) x (2 / CLK\_FREQ (Hz)) where MIN\_TON\_SINGLE\_ENDED = 15 and CLK\_FREQ = 25 MHz

The below formulas define the minimal/maximal voltages resulting from the minimal ON time on the low-side transistor for both the HS and LS driver configurations.

Single-ended LS configuration:

$$V_{MIN}$$
 (V) = V<sub>M</sub> (V) x MIN\_T\_ON (s) x F\_PWM (Hz)

Single-ended HS configuration:

$$V_{MAX}(V) = V_M(V) \times (1 - MIN_T_ON(s) \times F_PWM(Hz))$$

To regulate a current in the single-ended configuration, the applied voltage in a steady state should not be too close to the resulting voltage constraint ( $V_{MIN}$  in the LS driver configuration,  $V_{MAX}$  in the HS driver configuration).

#### **Current Reference**

The user must connect a precise  $12k\Omega$  resistor between the I<sub>REF</sub> pin and GND to set the reference current of the internal ADC. The MAX22216/MAX22217 reads the current flowing through the resistor by enforcing a constant voltage of about 0.9V on the I<sub>REF</sub> pin. Therefore, the I<sub>REF</sub> current is about

$$I_{\text{REF}}(A) = 0.9V/12k\Omega = 75\mu A$$

The current control accuracy directly depends on the I<sub>REF</sub> current accuracy. Therefore, it is recommended to use 1% or more accurate resistors.

#### Setting the Excitation Time (TIME\_L2H)

For solenoid drive operation, one 16-bit register allows the configuration of the excitation time (TIME\_L2H) for each individual channel according to the following formula:

 $TIME_L2H (ms) = TIME_L2H[15:0]_{DEC} / F_PWM (KHz)$ 

in which F\_PWM is the chopping frequency of the individual channel (see the <u>Setting the Chopping Frequency (FPWM)</u> section).

The TIME\_L2H determines the per-programmed excitation time. The actual excitation time can be shortened and the power dissipation can be further reduced by using the automatic HIT to HOLD commutation function, which is based on the Detection of Plunger Movement (DPM) function (see the <u>Detection of Plunger Movement (DPM)</u> section).

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

If TIME\_L2H[15:0] = 0xFFFF, the excitation level DC\_L2H is applied continuously.

For Brushed DC Motor drive operation (CTRL\_MODE[1:0] = 10), the content of this register assumes a different meaning and determines the limiter current threshold during braking operation. This function is explained in detail in the <u>Brake</u> <u>Current Limiter Function</u> section.

#### Setting the Ramp Slopes

Slowing down the rising/falling edges of the current in an ON/OFF solenoid valve smooths the mechanical movement of the plunger into an ON/OFF solenoid valve and reduces the acoustic clicking noise during activation/deactivation of the valve. Moreover, it also helps reducing over-/under-shoots of the current when the PI-based current drive regulation (CDR mode) is used. The RAMP function generates controlled ramps among the excitation, hold, and off levels. Eight bits in the channel configuration register (RAMP[7:0]) set the desired slew rates. Bits RDWE, RMDE, and RUPE enable/ disable the function, respectively, for RAMP DW, RAMP MD, and RAMP UP (see the <u>Operating Modes</u> section). The ramp control is supported both in voltage and current drive modes. In VDR mode, the RAMP function ramps up/down the voltage applied to the load until the setpoint is reached. The voltage slew rate is approximatively given by the following formula:

RAMP SLEW RATE [V/ms] = K<sub>VDR</sub> x 36V x (RAMP[7:0]<sub>DEC</sub> + 1) \*F\_PWM(kHz)

For instance, if the chopping frequency is 25kHz, the ramp-up slew rate can be configured from 0.4V/ms to 102V/ms. In VDRDUTY mode, the RAMP function ramps up/down the output duty cycle until the setpoint is reached. The voltage slew rate is approximatively given by the following formula:

RAMP SLEW RATE [V/ms] = K<sub>VDR</sub> x V<sub>M</sub> x (RAMP[7:0]<sub>DEC</sub> + 1) \*F\_PWM(kHz)

In CDR mode, the RAMP function ramps up/down the load current until the setpoint is reached. The current slew rate is approximatively given by the following formula: MAX22216 RAMP\_SLEW\_RATE (mA/ms) =  $K_{CDR} \times GAIN \times SNSF \times (RAMP[7:0]_{DEC} + 1) \times F_PWM(kHz) MAX22217 RAMP_SLEW_RATE (mA/ms) = K_{CDR} \times GAIN \times (RAMP[7:0]_{DEC} + 1) \times F_PWM(kHz)$  For instance, if F\_PWM = 25kHz and GAIN = SNSF = 1, the Slew Rate of MAX22216 can be configured from 25.425mA/ms to 6508.8mA/ms. It must be noted that the maximum slew rate achievable in CDR mode can be limited by system parameters. In particular, for inductive loads, the maximum slew rate cannot exceed the theoretical maximum equal to  $V_M/I_{LOAD}$ .

#### Enabling the Sine Wave Generator for Dithering or Inductance Measurement

The MAX22216/MAX22217 integrate a sine wave generator, which creates a sine wave signal with programmable frequency and amplitude.

The purpose of the sine wave generator is twofold:

- 1. It can be used to add dithering to the DC voltage or current in order to overcome static friction and hysteresis problems, which in particular affect proportional valves.
- 2. It can be used as an AC scan signal to measure the coil inductance and detect the on/off status of the solenoid valve for diagnostic purposes.

The DITH\_EN and LMEAS\_EN bits in the configuration register of each individual channel activate/deactivate either the dithering or the inductance measurement function. For the dithering function, the sine wave is superimposed onto the DC\_H level with added noise at the DC\_L level. For the inductance measurement function, it can be set to superimpose the sine wave onto DC\_L2H and/or DC\_H levels, while it is always superimposed on the DC\_L level.

The sine wave generator starts after the first use of the channel. <u>Table 10</u> summarizes how the function is activated and onto which DC levels the sine wave signal is applied.

- In case the sine wave is used for dithering (DITH\_EN = "1", LMEAS\_EN = "0"), the AC signal is superimposed onto the DC\_H (hold) level and added noise at the DC\_L (low) level. Both voltage and current control modes are supported. The main use of this function is to get rid of friction in proportional valves.
- In case the sine wave is aimed to measure the inductance for diagnostic purposes (LMEAS\_EN = "1", DITH\_EN = X), then the AC voltage sine wave is superimposed only if the DC level is controlled in voltage mode (VDR). The inductance measurement can possibly be done in every sequencer phase (DC\_L2H, DC\_H, and DC\_L). Selection bits are available to enable/disable the measurement for the corresponding phase, as discussed in detail in the <u>Inductance Measurement</u> section. The primary use of the inductance measurement function is to detect the status of ON/OFF solenoid valves.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### Table 10. Dither and Inductance Measurement Table

| FUNCTION                                                                                         | ACTIVATION<br>BITS                                             | DESCRIPTION                                                                                                                                                         | CONTROL MODES                                                                                                        | DRIVER<br>PHASES                                                               | MAIN<br>TARGET<br>APPLICATION |
|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------|
| Sine Off                                                                                         | DITH_EN = 0<br>LMEAS_EN<br>= 0 Sine wave generator<br>disabled |                                                                                                                                                                     |                                                                                                                      |                                                                                |                               |
| DITH_EN = 1 AC current/voltage<br>LMEAS_EN superimposed onto the<br>= 0 DC current/voltage level |                                                                | <ul> <li>Supported both in CDR and<br/>VDR modes.</li> <li>AC SCAN amplitude can be<br/>either a current or a voltage,<br/>depending on the DC_H setting</li> </ul> | DC_H and noise<br>at the DC_L<br>level                                                                               | Proportional valves                                                            |                               |
| Inductance<br>Measurement                                                                        | Inductance = 1 + AC current is                                 |                                                                                                                                                                     | <ul> <li>VDR mode only.</li> <li>If CDR control is set, the sine wave generator is automatically disabled</li> </ul> | DC_L always,<br>DC_L2H, and<br>DC_H<br>selectable<br>(L_MEAS_L2H,<br>L_MEAS_H) | On/Off valves                 |

Dithering enables a small level of noise at the DC\_L level that can be used (together with the RAMP\_SLEW\_RATE control) to lower the impact of the valve armature onto the valve seal and prevent a sticky plunger in some applications. It is recommended to disable the function once the valve is closed. (right after turning off the channel), otherwise some valves may not close properly or heat up while not in use.

During the inductance or resistance measurements, the IND flag can be triggered when the channel turns off (depending on line noise and valve) due to the functionality of IAC\_THLD when measuring the DC\_L phase. In the case where the IND Flag is triggered continuously on the DC\_L level (if it reappears after clearing, this usually happens when IAC\_THLD is not 0), it is recommended to disable LMEAS\_EN while the channel is off (if LMEAS is turned off before the channel, the IND flag should not appear when turning off the channel) or to limit the readings using L\_NBR\_CALC and clear the flag. The IND flag triggers when the channel is turned on due to the coil transient response; to counter this, use the L\_MEAS\_WCYCLES to create a delay in the inductance measurement readings. Similarly, if it does not set RES\_THLD before turning on the channel (while LEAS\_EN is in use), the RES Flag will trigger, as the standard value for RES\_THLD is 0. Resistance measurements might also be affected by the transient response in some cases.

#### Setting the Sine Wave Generator

The sine wave amplitude and frequency can be configured as global parameters.

The sine wave frequency can be set by programming the global F\_AC\_SCAN register as shown in the formula below.

Sine Wave Frequency (Hz) = F\_PWM\_M (Hz) x (F\_AC\_SCAN[11:0]<sub>DEC</sub>/65535)

The sine wave generator amplitude can be set by programming the global U\_AC\_SCAN register. Depending on the control mode, the amplitude is set as described below.

| VDRDUTY      | $VOUT\_AC (V) = K_{VDR} \times V_M (V) \times U\_AC\_SCAN[14:0]_{DEC}$         |
|--------------|--------------------------------------------------------------------------------|
| VDR          | VOUT_AC (V) = K <sub>VDR</sub> x 36 x U_AC_SCAN [14:0] <sub>DEC</sub>          |
| CDR MAX22216 | IOUT_AC (mA) = K <sub>CDR</sub> x GAIN x SNSF x U_AC_SCAN[14:0] <sub>DEC</sub> |
| CDR MAX22217 | IOUT_AC (mA) = K <sub>CDR</sub> x GAIN x U_AC_SCAN[14:0] <sub>DEC</sub>        |

See the <u>CURRENT DRIVE REGULATION (CDR)</u> and <u>VOLTAGE DRIVE REGULATION (VDR)</u> sections for details about CDR and VDR parameters.

### Brake Current Limiter Function

As shown in <u>OPERATING MODES OVERVIEW</u>, the MAX22216/MAX22217 can be used to drive a bidirectional DC motor in full-bridge configuration (CTRL\_MODE[1:0] = 10).

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

To stop a running motor, the BRAKE condition has to be enforced (CNTL0 = CNTL1 = "1") (see <u>Table 3</u> in the <u>Hardware</u> <u>Configuration</u> section). During brake, both sides of the load are driven with a 50% duty cycle, causing the load to be virtually shorted so that the deceleration begins.

Because the BEMF voltage gets virtually shorted, the brake current can be very high and limited only by the motor resistance. This causes the MAX22216/MAX22217 overcurrent protection to be triggered and the device to outputs to be tri-stated. To overcome the problem, the MAX22216/MAX22217 feature a brake current limiter function that allows the fastest deceleration given the current limit constraint.

If this function is triggered, the content of the CFG\_L2H\_TIME register (namely bits TIME\_L2H[15:0]) sets the upper limit of the brake current (IBRAKE\_LIM). Whenever the current amplitude exceeds the IBRAKE\_LIM (see the formulas below), a current control loop is triggered, and the brake current is limited to the desired value, which is given by:

| MAX22216 | I_BRAKE_LIM(mA) = K <sub>CDR</sub> x GAIN x SNSF x TIME_L2H[15:0] <sub>DEC</sub> |
|----------|----------------------------------------------------------------------------------|
| MAX22217 | I_BRAKE_LIM(mA) = K <sub>CDR</sub> x GAIN x TIME_L2H[15:0] <sub>DEC</sub>        |

In particular, when TIME\_L2H[15:0] = "0", the driver enforces HiZ (coast).

The CFG\_L2H\_TIME register of the channel with the lower channel count is used for this function, so only the first half of the register creates the BRAKE: 0x0001 to 0x7FFF.

### DIAGNOSTIC FUNCTIONS AND STATUS MONITOR

### **Digital Current Monitor Function**

The internally sensed current is sampled at the PWM frequency and stored into Read Only registers (I\_MONITOR[15:0]). The user can read real time the I\_MONITOR value via SPI for diagnostic and/or control purposes. During SPI read/write operations, the content of these registers is held. The digital current monitor function is available even in voltage drive modes (VDR or VDRDUTY). Similarly to what is described in the <u>CURRENT DRIVE REGULATION</u> section, the actual value of the current can be decoded using the following formulas:

| MAX22216 | I <sub>MONITOR</sub> (mA) = K <sub>CDR</sub> x GAIN x SNSF x I_MONITOR[15:0] <sub>DEC</sub> |
|----------|---------------------------------------------------------------------------------------------|
| MAX22217 | I <sub>MONITOR</sub> (mA) = K <sub>CDR</sub> x GAIN x I_MONITOR[15:0] <sub>DEC</sub>        |

The maximum digital value of the ADC for each individual channel is  $\pm 4095$  (13 bits signed). For each parallel configuration, this maximum digital value is multiplied by the number of parallel systems (full- or half-bridge), but if one of the channels overflows (the current exceeds the maximum measurable current), the I\_MONITOR shows the maximum possible measured value for that configuration.

I\_MONITOR has to store the sum of up to 4 signed channel measurements (so it needs at least 15 bits); for this reason, it is stored in a 16-bit register. In the case of parallel channel configurations, the I\_MONITOR will appear only in the Diagnostics of the main control channel. All the other diagnostics are channel-dependent, even in parallel channel configurations. Table 11 shows the maximum I\_MONITOR digital value for each channel configuration.

### Table 11. I\_MONITOR ADC Max Value - Dec

| CHS[3:0] | CONFIGURATION | CH0       | CH1   | CH2  | CH3  |  |
|----------|---------------|-----------|-------|------|------|--|
| 0x0      | 4xIHB         | 4095      | 4095  | 4095 | 4095 |  |
| 0x1      | 3xPHB, 1xIHB  |           | 12287 | •    | 4095 |  |
| 0x2      | 2xPHB, 2xIHB  | 8         | 191   | 4095 | 4095 |  |
| 0x3      | 2xPHB, 2xPHB  | 8         | 8191  |      | 8191 |  |
| 0x4      | 4xPHB         |           | 16383 |      |      |  |
| 0x5      | 1xIFB, 1xIFB  | 4095 4095 |       | )95  |      |  |
| 0x6      | 1xIFB, 2xIHB  | 4         | 4095  |      | 4095 |  |
| 0x7      | 1xIFB, 2xPHB  | 4095 819  |       | 91   |      |  |
| 0x8      | 1xPFB         | 8191      |       |      |      |  |

In the case of a full-bridge configuration, the secondary channel I\_MONITOR shows the negative current flowing through it.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

In the case of parallel half-bridges, the summed current will appear on the I\_MONITOR of each channel, but for ease of use, it is recommended to use the I\_MONITOR on CH0 (0x45). In full-bridge configurations, the main I\_MONITOR channel is CH0 (0x45) or CH2 (0x57), and in parallel full-bridge the main I\_MONITOR is on CH0 (0x45).

### **PWM Duty Cycle Monitor Function**

16 bits register PWM\_DUTY reports a real-time digital representation of the duty cycle applied to the load. This information is particularly useful in current drive regulation (CDR) to monitor the actual duty cycle applied to the load and detect possible anomalies.

### Digital V<sub>M</sub> Supply Voltage Monitor

The supply voltage ( $V_M$ ) is internally measured and digitized. The user can monitor the real-time supply voltage by reading the VM\_MONITOR[15:0] register via SPI. This information can be decoded using the following formula:

 $VM(mV) = K_{VM} \times VM_MONITOR[15:0]_{DEC}$ 

Where  $K_{VM}$  = 9.73mV typical.

#### Inductance Measurement Overview

The sine wave voltage generator (see the <u>Enabling the Sine Wave Generator</u> and <u>Setting the Sine Wave Generator</u> sections) can be used to indirectly estimate the solenoid inductance by measuring the AC current induced by the AC scan voltage. The value of the inductance is, at first order, inversely proportional to the air gap. Therefore, the measurement of the inductance provides a sensor-less estimate of the spool displacement inside the valve. When driving ON/OFF valves, this technique can be used as a diagnostic tool to assess whether the valve is open or closed (see the <u>Status Monitor</u> (<u>STAT</u>) section).

This function is supported in both VDR and VDR\_DUTY modes, although VDR is normally recommended as it is less sensitive to supply variations. The function is not supported in CDR Mode.

The inductance measurement activated the I\_AC readings, which measure the current AC wave amplitude and the current median level of the output. For the I\_AC measurement, it is important to consider that the IC filters the read signal around the Sine Wave Generator frequency. This means that it does not see a lot of higher-frequency noise at the output, which can create a measurement bias. Both the I\_AC measurement and the average bias are usually very stable.

The MAX22216/MAX22217 measure the AC current generated by the scan AC sine wave voltage and store the result in the read-only register I\_AC[15:0].

The AC current value in Amperes is given by:

| MAX22216 | $I_AC (mA) = K_{CDR} \times GAIN \times SNSF \times I_AC[15:0]_{DEC}$ |
|----------|-----------------------------------------------------------------------|
| MAX22217 | $I_AC (mA) = K_{CDR} \times GAIN \times I_AC[15:0]_{DEC}$             |

A rough calculation of the solenoid inductance in Henry is then given by:

$$L[H] = \frac{U\_AC\_SCAN}{2\pi \times F\_AC\_SCAN \times I\_AC}$$

in which U\_AC\_SCAN and F\_AC\_SCAN are, respectively, the amplitude and frequency of the AC voltage scan signal. The actual inductance of the valve can significantly differ from what is predicted by this formula. First, the simple L+R model assumed for the calculation is really a rough approximation of the electrical model of a solenoid, in which many parameters play a role (coil saturation, eddy currents, magnetic hysteresis, load effects, etc.). Secondarily, similarly to what was discussed regarding the VDR mode generating the DC levels (see the <u>VOLTAGE DRIVE REGULATION (VDR</u>) section), the generation of the AC scan voltage is affected by errors, especially when high chopping frequencies and slow PWM edges are used. Nevertheless, the measurement of the absolute value of the I\_AC current has been found to be a good indicator to determine whether the plunger is in the ON or OFF position, making the method reliable for valves in which the I\_AC in the two statuses are well separated.

For HS or LS drives (single-ended operation), the superimposed AC signal amplitude must be less than the applied DC level. To measure the inductance when the coil is de-energized, the user must enforce a DC level (DC\_L) small enough to ensure the solenoid does not change its status but large enough to superimpose enough AC signal for the measurement.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

#### **Setting the Inductance Measurement**

Two 16 bits registers (CFG\_IND\_0 [15:0] and CFG\_IND\_1[15:0]) store the configuration parameters for the inductance measurement (or, better said, the I\_AC measurement) function for each individual channel.

As mentioned in the <u>Enabling the Sine Wave Generator for Dithering or Inductance Measurement</u> section, the bit L\_MEAS\_EN enables the function.

It is required that the I\_AC measurement starts only after the drive voltage has settled down to the pre-programmed DC level. By writing L\_MEAS\_WCYCLES, the user can set a delay from the change of the DC level to the actual start of the I\_AC measurement. This delay is expressed in the number of AC scan periods.

The I\_AC measurement is the average of multiple measurements on consecutive scan periods. By writing the L\_NBR\_CALC bits, the user can set the duration of the measurement. Such a duration is expressed in the number of AC scan periods.

In some applications, the solenoid is intentionally overdriven during the excitation time (TIME\_L2H), causing the coil to saturate. When this occurs, the inductance measurement becomes unreliable and misleading. The L\_MEAS\_L2H bit allows to inhibit the AC signal and any inductance measurement during the excitation time. Similarly, the L\_MEAS\_H bit allows to disable the inductance measurement during the hold phase (level H) if the coil saturates during said phase. Measurements performed during the OFF phase (or DC\_L phase) are generally more reliable.

The IAC\_THLD[11:0] bits set the threshold, which can be used for diagnostic purposes or to detect the status of the valve.

| MAX22216                                                                        | IAC_THLD(mA) = K <sub>CDR</sub> x GAIN x SNSF x IAC_THLD[11:0] <sub>DEC</sub> |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| MAX22217 IAC_THLD(mA) = K <sub>CDR</sub> x GAIN x IAC_THLD[11:0] <sub>DEC</sub> |                                                                               |

After the completion of the measurement, the content of the I\_AC[11:0] register is compared with the content of the IAC\_THLD[11:0] register.

If, as a result of the comparison, a fault is detected, the flag bit IND in the FAULT register is set.

While in DC\_L2H or DC\_H phase, the Fault is signaled out if the measured I\_AC amplitude is found larger than the threshold. Vice versa, while in DC\_L phase, a Fault is signaled out if the measured I\_AC is found smaller than the threshold. Table 12 summarizes the fault conditions.

### Table 12. Inductance Measurement Fault Detection

| PHASE          | CONDITION          | IND<br>FAULT | DESCRIPTION                                                                                                  |
|----------------|--------------------|--------------|--------------------------------------------------------------------------------------------------------------|
| DC_L2H<br>DC_H | I_AC ><br>IAC_THLD | 1            | A fault gets signaled out if the measured amplitude of the AC signal is larger than the configured IAC_THLD  |
| DC_L           | I_AC <<br>IAC_THLD | 1            | A fault gets signaled out if the measured amplitude of the AC signal is smaller than the configured IAC_THLD |

The comparison between I AC and IAC THLD can also be used to monitor the status of the valve.

The MAX22216/MAX22217 can be configured in such a way that the STT[3:0] bits in the STATUS register and/or the STAT0, STAT1 output pins of the MAX22216/MAX22217 directly reflect the result of the comparison, as shown in <u>Table</u> <u>13</u>. This is discussed in more detail in the next paragraphs.

### Table 13. STATUS Monitor Based on Inductance Measurement

| OUTPUT STATUS<br>BITS/PINS                   | STT[3:0] BITS<br>STAT0, STAT1 PINS |
|----------------------------------------------|------------------------------------|
| I_AC > IAC_THLD                              | 0                                  |
| I_AC <iac_thld< td=""><td>1</td></iac_thld<> | 1                                  |

#### **Detection of Plunger Movement (DPM) - Overview**

The detection of plunger movement (DPM) function senses the local dip of the current caused by the BEMF, which is generated by the plunger movement when the valve is activated. This detection is active during the entire TIME\_L2H excitation time.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

This function is available both in voltage mode (VDR) and in current mode (CDR).

In VDR mode, the plunger movement can be reliably detected in the entire TIME\_L2H excitation time.

In CDR mode, once the excitation level (DC\_L2H) has been reached, the internal control loop counteracts the BEMF perturbation in an attempt to stabilize the current, which makes the plunger movement detection problematic. For this reason, the DPM function in CDR is more reliable when the BEMF dip occurs during the excitation current ramp-up.



Figure 7. Detection of Plunger Movement

<u>Figure 7</u> shows the typical current signature of a properly working solenoid valve. The algorithm works on the rising edge of the current only (valve activation). DPM\_START and DPM\_THLD are current thresholds used to reduce noise and lower false triggers and errors.

When a current depth larger than DPM\_THLD occurs, a valid plunger movement is detected and DPM\_STATUS is triggered. After the end of the dip, the DPM calculates the TRAVEL\_TIME and the REACTION\_TIME.

If the END\_HIT\_AUTO bit is set logic low, then the sequencer increases the current/voltage up to DC\_L2H level and switches to DC\_H only when TIME\_L2H has elapsed.

If the END\_HIT\_AUTO bit is set logic high, then as soon as the DPM confirms a valid plunger movement, the sequencer automatically enforces the DC\_H setpoint, resulting in significant power savings.

The amplitude of the dip and its relative position along the current rising edge are useful indications of the status and aging of the valve.

When activated, the DPM function implemented in the MAX22216/MAX22217 outputs the four parameters

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

(I\_DPM\_PEAK, I\_DPM\_VALLEY, REACTION\_TIME, and TRAVEL\_TIME) that are stored in the corresponding Diagnostic Read Only registers of each individual channel and can be used to analyze the status of the solenoid.

With reference to Figure 7,

- 1. I\_DPM\_PEAK[15:0] represents the local maximum of the current (local peak) during the excitation phase.
- 2. I DPM VALLEY[15:0] represents the local minimum of the current (local valley) during the excitation phase.
- 3. REACTION\_TIME[15:0] represents the time interval expressed in the number of PWM periods from the ON command to the local minimum of the current.
- 4. TRAVEL\_TIME[15:0] represents the time interval expressed in the number of PWM periods from the local maximum to the local minimum of the current.

A drift of these parameters is a symptom of the aging of the valve and indicates the need for preventive maintenance of the valve during its operating life. The REACTION\_TIME and TRAVEL\_TIME can be calculated using the following formula:

REACTION\_TIME (ms) = REACTION\_TIME[15:0]/F\_PWM (KHz) TRAVEL\_TIME (ms) = TRAVEL\_TIME[15:0]/F\_PWM (KHz)

I\_DPM\_PEAK and I\_DPM\_VALLEY are numeric representations of the currents. The actual values can be calculated using the formulas below.

| MAX22216 | I_DPM_(mA) = 8 x K <sub>CDR</sub> x GAIN x SNSF x I_DPM_[11:0] <sub>DEC</sub> |
|----------|-------------------------------------------------------------------------------|
| MAX22217 | I_DPM_(mA) = 8 x K <sub>CDR</sub> x GAIN x I_DPM_[11:0] <sub>DEC</sub>        |

When the sequencer starts and if the DPM function is enabled, the algorithm first searches for I\_DPM\_PEAK and updates the resister once the peak is found.

Afterwards, the I\_DPM\_VALLEY, the REACTION\_TIME, and the TRAVEL\_TIME registers get written when either the current has risen back to the local maximum level or the TIME\_L2H has elapsed. This ends DPM detection.

#### **Setting the Detection of Plunger Movement**

Several parameters can be configured independently for each individual channel to configure and tune the DPM algorithm. They are stored in two 16 bits registers named CFG\_DPM0[15:0] and CFG\_DPM1[15:0]. (See the Register Map section.)

The DPM\_EN bit into CFG\_DPM1[15:0] is the enable bit. Set this bit high to enable the DPM function for that specific channel.

As shown in Figure 7, the algorithm starts searching for the BEMF dip above a programmable current level given by,

| MAX22216 | DPM_START(mA) = 64 x K <sub>CDR</sub> x GAIN x SNSF x DPM_START[7:0] <sub>DEC</sub> |
|----------|-------------------------------------------------------------------------------------|
| MAX22217 | DPM_START(mA) = 64 x K <sub>CDR</sub> x GAIN x DPM_START[7:0] <sub>DEC</sub>        |

in which DPM\_START[7:0] is an 8 bitfield into the CFG\_DPM1 register.

As soon as the local maximum of the current I\_DPM\_PEAK is detected, it is stored in the corresponding R/O register. The algorithm then compares the subsequent dip caused by the plunger movement with a programmable threshold, which can be set by writing the DPM\_THLD[11:0] bit field in the CFG\_DPM0 register. Current thresholds are given by,

| MAX22216 | DPM_THLD(mA) = 8 x K <sub>CDR</sub> x GAIN x SNSF x DPM_THLD[11:0] <sub>DEC</sub> |
|----------|-----------------------------------------------------------------------------------|
| MAX22217 | DPM_THLD(mA) = 8 x K <sub>CDR</sub> x GAIN x DPM_THLD[11:0] <sub>DEC</sub>        |

The user can set a deglitch time to avoid a false BEMF dip being detected. The deglitch time is set in the number of PWM cycles and is equal to:

DPM\_DEGLITCH = 2 x DPM\_MIN\_NBR[3:0]<sub>DEC</sub> x 1/FPWM

in which DPM\_MIN\_NBR[3:0] is a 4 bits bitfield into into the CFG\_DPM1 register.

If the current drops from the peak more than the DPM\_THLD for longer than the DPM\_DEGLITCH, then a valid BEMF dip is detected, meaning that the valve is working properly.

As soon as a valid BEMF dip has been recognized, the algorithm starts searching the local valley (the local minimum in the current profile). When the local valley is found, its value is stored into the I\_DPM\_VALLEY register. Moreover, the

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

DPM\_STATUS bit in the STATUS register is set. Since the STATUS bit is cleared every time the valve is deactivated (CNTL goes low), the DPM\_STATUS bit is informative on whether the valve has been properly activated (see the <u>STATUS</u> section).

Vice versa, in case if no valid BEMF dip has been recognized during the whole DC\_L2H time interval (Hit or Excitation time), then the DPM\_STATUS bit remains low and the DPM\_FAULT bit is set and can possibly be signaled out (see the <u>FAULT</u> section).

Finally, it is also possible to configure the MAX22216/MAX22217 so that the sequencer ends the excitation phase (HIT) as soon as a valid BEMF dip is detected. Two bits in CFG\_DPM1 control this function: END\_HIT\_AUTO and END\_HIT\_HIZ\_AUTO.

- Set END\_HIT\_AUTO = "1" to enable the automatic DC\_L2H to DC\_H switchover once a valid BEMF dip is detected and the current has risen back to the local maximum level (I\_DPM\_PEAK). This is shown with the red curve into the <u>Detection of Plunger Movement (DPM)</u>.
- Set END\_HIT\_HIZ\_AUTO = "1" to enable the automatic DC\_L2H to HiZ (High Impedance) switchover once a valid BEMF dip is detected and the current has risen back to the local maximum level. If no BEMF dip is detected, the drive phase will switch to HiZ when the TIME\_L2H elapses.

The END\_HIT\_AUTO or the END\_HIT\_HIZ\_AUTO dramatically improves the drive efficiency in latched valve applications.

#### **Resistance Measurement**

The MAX22216/MAX22217 can be configured to calculate the equivalent resistance of the coil. As the resistance is expected to increase when the coil temperature increases, this function enables an indirect measurement of the solenoid or motor temperature.

To enable the function, the inductance measurement must be enabled (see the <u>Setting the Inductance Measurement</u> section). If the inductance measurement is not required and only the resistance measurement is needed, the user can simply set the AC\_SCAN amplitude to zero so that only a DC level is applied to the load.

The resistance measurement is performed by dividing the average voltage and average current applied to the load during the inductance measurement (see the <u>Setting the Inductance Measurement</u> section). The measured resistance for each individual channel can be read by accessing the RES[15:0] bits via SPI.

The resistance measurement formula is:

$$R(m\Omega) = R[15:0] \times (K_R/(SNSF * GAIN))$$

Where  $K_R = 8.437 \text{ m}\Omega$ .

The user can set a resistance threshold by writing the RES\_THLD[15:0] bits into the configuration registers.

RES\_THLD(m
$$\Omega$$
) = RES\_THLD[15:0] x ( K<sub>R</sub>/(SNSF \* GAIN))

Where  $K_R = 8.437 \text{ m}\Omega$ .

If the calculated resistance exceeds the RES\_THLD value, then the MAX22216/MAX22217 set the RES status bit into the STATUS register. Moreover, the RES\_bit in the FAULT register can be set, and a fault can possibly be signaled out (see the <u>PROTECTIONS AND FAULT INDICATOR</u> section).

#### Setting the Status Monitor

The MAX22216/MAX22217 allow monitoring the channel status either by reading the STT[3:0] bits into the STATUS register via SPI or by observing the STAT0 and STAT1 logic output pins. The status monitor function can be configured by writing the Global Register STATUS\_CFG[15:0].

Status information is mapped onto the STAT0 and STAT1 output pins according to <u>Table 14</u>, in which CHS determines the Hardware configuration (see the <u>Setting the Hardware Configuration</u> section), and STAT\_SEL0 and STAT\_SEL1 are two selection bits in the STATUS\_CFG register.

Note that if a channel is configured in a full-bridge configuration (FB), the status pins output the logical OR of the STT\_ bits of the corresponding channels in all modes except for PWM monitoring. When PWM monitoring is selected, the STAT\_ pin outputs the PWM signal of the half bridge with the lower channel count. The polarity of the STAT pins can be changed with the STAT\_POL bit in the GLOBAL\_CFG register.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

The MAX22216/MAX22217 can be configured to output different types of information. <u>Table 15</u> summarizes all the possible settings. Three STAT\_FUN[2:0] bits into the STATUS\_CFG register permit the selection of the desired function.

**STAT\_FUN 0x0:** ON/OFF Status is detected based on the inductance measurement. This is achieved by comparing the internally measured I\_AC with a user-configurable threshold, IAC\_THLD. This threshold can be programmed individually for each channel. (See the *Inductance Measurement* section).

STAT\_FUN **0x1:** The STAT pins act as PWM Monitor outputs. In this configuration, a low-voltage replica of the PWM signal applied to the load is output on the status pin (STAT) for monitoring purposes. In particular, if MAX22216/ MAX22217 are configured in CDR mode, the STAT signal can be processed by an external processor to detect stall conditions, load or supply disconnections, or any abrupt changes in the load conditions causing an abnormal duty cycle variation.

STAT\_FUN **0x2:** STT bits are set (and hence the STAT pin outputs a logic high value) every time the Coil resistance exceeds a pre-programmed threshold (RES\_THLD). (See the <u>Resistance Measurement</u> section).

STAT\_FUN **0x3**: ON/OFF Status is detected based on the detection of plunger movement. When this configuration is used, the STT bit is cleared (and hence the STAT pins are de-asserted) every time the channel is OFF (i.e., CNTL = 0). When a valid BEMF dip is detected during the excitation phase, the STT bit is set (and hence the STAT pin is asserted).

STAT\_FUN **0x4:** In this configuration, the STT bits are set and the STAT pins are asserted when the part is supplied ( $V_M$  greater than UVLO) and cleared when the  $V_M$  drops ( $V_M$  less than UVLO). This stat is mainly used to show that the IC is within a functional voltage range, so it can also be controlled using VM\_THLD\_DOWN or a combination of VM\_THLD\_DOWN and VM\_THLD\_UP, presented in more detail in the <u>V\_M Switching Stand-Alone</u> section.

STAT\_FUN **0x5:** the STT bits are set and the STAT pins asserted when the coil current from the I\_MONITOR is higher than a programmable DC current threshold (IDC\_THLD). The IDC\_THLD can be programmed individually for each channel by writing the 16 bits CFG\_IDC\_THLD[15:0] register. In full-bridge configuration, the IDC\_THLD must be set on both channels. In comparison, in parallel full bridge, it must be set only on CH0 and CH1, while triggering both STAT pins independent of STAT\_SEL. In parallel configurations, the IDC\_THLD must be set based on the sum of currents on all channels, but only on the main control channel, and it will trigger the STAT on all connected channels. The threshold is given by

| MAX22216 | IDC_THLD (mA) = K <sub>CDR</sub> x GAIN x SNSF x IDC_THLD[15:0] <sub>DEC</sub> |
|----------|--------------------------------------------------------------------------------|
| MAX22217 | IDC_THLD (mA) = K <sub>CDR</sub> x GAIN x IDC_THLD[15:0] <sub>DEC</sub>        |

See also <u>STAT Monitor - Single-Ended Diagrams</u> and <u>STAT Monitor - Differential Diagrams</u> for a visual representation of the status monitor function.

### Table 14. STAT Logic Output Pin Selection

| СНЅ | CONFIGURATION<br>SETTING               | STAT0                                                    | STAT1                                                    |  |  |
|-----|----------------------------------------|----------------------------------------------------------|----------------------------------------------------------|--|--|
| 0x0 | 4x Independent HB                      | STT0 if STAT_SEL(0) = 0<br>STT1 if STAT_SEL(0) = 1       | STT2 if STAT_SEL(1) = 0<br>STT3 if STAT_SEL(1) = 1       |  |  |
| 0x1 | 3x Parallel HB<br>1x Independent HB    | STT0=STT1 = STT2                                         | STT3                                                     |  |  |
| 0x2 | 2x Parallel HB<br>2x Independent HB    | STT0 = STT1                                              | STT2 if STAT_SEL(1) = 0<br>STT3 if STAT_SEL(1) = 1       |  |  |
| 0x3 | 2x Parallel HB<br>2x Parallel HB       | STT0 = STT1                                              | STT2 = STT3                                              |  |  |
| 0x4 | 4x Parallel HB                         | STT0 = STT1 = STT2 = STT3                                | -                                                        |  |  |
| 0x5 | 1x Independent FB<br>1x Independent FB | STT0 in PWM monitoring<br>(STT0 OR STT1) all other modes | STT2 in PWM monitoring<br>(STT2 OR STT3) all other modes |  |  |
| 0x6 | 1x Independent FB<br>2x Independent HB | STT0 in PWM monitoring<br>(STT0 OR STT1) all other modes | STT2 if STAT_SEL(1) = 0<br>STT3 if STAT_SEL(1) = 1       |  |  |
| 0x7 | 1x Independent FB<br>2x Parallel HB    | STT0 in PWM monitoring<br>(STT0 OR STT1) all other modes | STT2 = STT3                                              |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

# Table 14. STAT Logic Output Pin Selection (continued)

| CHS | CONFIGURATION<br>SETTING | STAT0                                              | STAT1                                              |  |  |
|-----|--------------------------|----------------------------------------------------|----------------------------------------------------|--|--|
| 0x8 | 1x Parallel FB           | STT0 if STAT_SEL(0) = 0<br>STT1 if STAT_SEL(0) = 1 | STT0 if STAT_SEL(0) = 0<br>STT1 if STAT_SEL(0) = 1 |  |  |

## Table 15. Multifunction Status Pin

| STAT_FUN | FUNCTION                                     | CONDITION                                               | STAT<br>STAT_POL<br>= "0" | STAT<br>STAT_POL =<br>"1" | STT<br>BITS |
|----------|----------------------------------------------|---------------------------------------------------------|---------------------------|---------------------------|-------------|
| 0x0      | Status detection based on the inductance     | if IAC > IAC_THLD                                       | Low                       | High                      | "0"         |
| 0.00     | measurement                                  | if IAC < IAC_THLD                                       | High                      | Low                       | "1"         |
| 0x1      | PWM monitor                                  | -                                                       | PWM                       | PWM                       | n/a         |
| 0x2      | Status detection based on resistance         | if RES < RES_THLD                                       | Low                       | High                      | "0"         |
| 0.12     | measurement                                  | if RES > RES_THLD                                       | High                      | Low                       | "1"         |
| 0x3      | Status detection based on successful plunger | if CNTL = Low or<br>CNTL = HIGH but DPM<br>not detected | Low                       | High                      | "0"         |
|          | movement (DPM)                               | if CNTL = HIGH and DPM<br>is detected                   | High                      | Low                       | "1"         |
| 0x4      | Statue datastian based on V., datastian      | if V <sub>M</sub> < UVLO                                | Low                       | High                      | "0"         |
| 0.004    | Status detection based on $V_M$ detection    | if V <sub>M</sub> > UVLO                                | High                      | Low                       | "1"         |
| 0x5      | Status detection based on I_MONITOR          | if I_MONITOR <<br>IDC_THLD                              | Low                       | High                      | "0"         |
|          | measurement                                  | if I_MONITOR><br>IDC_THLD                               | High                      | Low                       | "1"         |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### STAT Monitor - Single-Ended Diagrams





# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



### **STAT Monitor - Differential Diagrams**

Figure 9. STATUS Output Monitor Pin - Differential

### PROTECTIONS AND FAULT INDICATOR

#### Protections and Fault Indicator Pin (FAULT)

The MAX22216/MAX22217 feature a full set of protections and diagnostic functions. These include:

- 1. Undervoltage lockout (UVM)
- 2. Overcurrent protection (OCP)
- 3. Overtemperature protection (OVT)
- 4. Open-load detection (OL)
- 5. "Hit current not reached" detection (HHF)
- 6. Communication error detection (COMER)
- 7. Detection of plunger movement fault (DPM)
- 8. Inductance measurement (IND)
- 9. Load resistance fault (RES)

Every time a fault occurs, the corresponding global bit in the R/O STATUS register is set.

Fault events are also logged into two R/O 16 bits fault registers named FAULT0[15:0] and FAULT1[15:0] for diagnostic purposes. Dedicated flag bits for each channel are available for OCP, OL, HHF, DPM, IND, and RES faults so that the user can determine which of the channels failed. The fault registers are "Write one to clear registers". The user can read back the registers via SPI and decide to clear each individual fault flag by writing "1" to the corresponding bit. Alternatively, the fault registers can be cleared by driving the ENABLE pin logic low or by powering off the device (power

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

cycling).

An active low open-drain fault indicator pin (FAULT) is available to signal out the fault condition for each of the above mentioned faults, with the exception of the IND and RES faults.

Faults can be masked by setting high the corresponding mask bit in the 16 bits global register GLOBAL\_CFG[15:0] register. When masked, the fault event does not activate the FAULT pin, so the external controller does not receive any interrupts. The mask bits are listed in the <u>Table 16</u>. The default value is zero.

### Table 16. Mask Bits

| FAULT | MASK BIT |
|-------|----------|
| UVM   | M_UVM    |
| OCP   | M_OCP    |
| OVT   | M_OVT    |
| OL    | M_OLF    |
| HHF   | M_HHF    |
| DPM   | M_DPM    |
| COMER | M_COM    |

Two bits in the STATUS\_CFG register (STRETCH\_EN[1:0]) can be used to stretch the duration of the fault signal following an <u>undervoltage</u> (UVM) or an overtemperature (OVT) fault detection, as shown in <u>Table 17</u>. This function ensures the <u>FAULT</u> pin is kept active (logic low) for a minimum time interval (stretch time) after the fault occurrence. Whenever the FAULT pin is used to drive an external LED (for instance, in stand-alone use cases), setting a long stretch time allows visual observation of the fault event.

#### **Table 17. Stretch Enable**

| STRETCH_EN | STRETCH TIME |
|------------|--------------|
| 00b        | No stretch   |
| 01b        | 1s           |
| 10b        | 2s           |
| 11b        | 3s           |

#### Undervoltage Lockout (UVM)

If at any time the voltage on the  $V_M$  pin falls below the undervoltage lockout threshold (about +4V typ), all channels are tri-stated, the internal charge pump is disabled, and the UVM bits in the fault register and in the STATUS register are set. The content of the logic registers is preserved until  $V_{DD}$  falls below the digital power-on reset (POR) threshold. When this happens (typically at  $V_{DD}$  = 1.0V), all registers are reset to their default values.

The output of the UVLO comparator activates the FAULT indicator pin if it is not masked.

On the FAULT pin, the user can choose to output either the non-latched information of the UVLO comparator or the latched UVM bit information from the register map (see Figure 10).

Moreover, in the former case, the user can set a minimum FAULT assertion time (Stretch Time; see the <u>Protections and</u> <u>Fault Indicator Pin (FAULT)</u> section).

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



Figure 10. Fault Output Schematic

#### **Overcurrent Protection (OCP)**

The overcurrent protection protects the device from short-circuits of the driver outputs to the rails (V<sub>M</sub> and GND) or across the load. When the output current exceeds OCP thresholds (see the <u>Electrical Characteristic</u> table), then the corresponding channel is automatically tri-stated, the global OCP bit in the STATUS register as well as the individual OCP\_ bit in the FAULT register are set, and the FAULT output is asserted (if not masked). Writing one to the fault register clears the flag and de-asserts the FAULT output but does not turn on the failed channel. Once the flag is cleared, normal operations are resumed by turning the failed channel off in the status register. In bridge-tied load or parallel configurations, all the channels that form the full bridge or the parallel configuration must be turned off to resume normal operation.

#### **Open-Load Detection During Channel OFF (OL)**

The OL\_EN bit in the CFG\_CTRL register enables or disables the open-load detection (OL) function. When this function is enabled, whenever the channel is tri-stated, a small source/sink current pulls the output node ( $I_{OL}$  LS,  $I_{OL}$  HS).

In single-ended configuration, if the voltage on the output pin is found to be less than  $V_{OL\ LS}$  for low-side configuration or greater than  $V_{OL\ HS}$  for high-side configuration, then an open-load condition is detected.

In full-bridge configuration, for the open-load detection to work properly, both channels must have open-load enabled, and the bridge must have one output configured as low-side ( $HSnLS_x = 0$ ) and the other output as high-side ( $HSnLS_y = 1$ ). The open-load condition is detected if both sides detect an open-load condition, and it will appear as OLF for both channels at the same time. In the case of parallel full-bridges, open-load detection has to be set on all channels, and two channels on the same side of the full-bridge have to be set to HSnLS (CH0 and CH1 or Ch2 and CH3). The OLF will appear for all channels at the same time.

If multiple channels are configured in parallel, even if the channels are connected via the PCB, the open-load detection will work independently for each of the channels connected in parallel. Generally, it is recommended use open-load detection only on the main control channel. In the case of using parallel half-bridges together with the HSnLS, if there is a need of open-load detection on all channels, each channel has to be individually set to HSnLS.

In all the cases, a relatively long deglitch time ( $t_{OL}$  = 200µs typ) starting from the enabling of the function ensures the output has settled down before the open-load condition is checked.

When an open-load condition is detected, the corresponding bit in the fault register as well as the OLF bit in the STATUS register are set. The FAULT output pin is also asserted if it is not masked.

#### **Overtemperature Protection (OVT)**

If the die temperature exceeds safe limits, all outputs are disabled. The OVT flag bit in the FAULT and STATUS registers is set, and the FAULT pin is driven low if not masked.

Once the die temperature has fallen to a safe level, operation automatically resumes. The FAULT pin is released after the stretch time (see the *Protection and Fault Indicator* section), but the flag bit remains set to '1' until the fault register is write to one.

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

#### "HIT Current not Reached" Flag (HHF)

In CDR mode, the user can monitor whether the preprogrammed HIT current level is reached. This diagnostic tool can be enabled by setting the bit HHF\_EN\_ to "1" in the CFG\_CTRL register. If the target current is not reached at the end of TIME\_L2H, then the individual HHF flag bit in the Fault register as well as the global HHF bit in the STATUS register are set. The FAULT indication pin is asserted if not masked. Note that this fault does not tri-state the driver. The flag bit is cleaned up when the fault register is write to one.

#### HOW TO CONFIGURE THE MAX22216/MAX22217

#### **SPI Description**

The MAX22216/MAX22217 feature a 10MHz capable serial peripheral interface (SPI) Mode 0, but is also compatible with Mode 3. The cyclic redundancy check control (CRC) is optional and can be activated by driving logic high the pin CRC EN.

The SPI supports daisy-chain connections so that multiple devices can be controlled from a single SPI. SDI input is clocked in on the rising edge of the SCK signal. Data output on SDO is clocked out on the falling edge of the SCK signal.

#### The SPI transfers are byte-oriented.

SPI transactions without CRC error detection.



Figure 11. SPI Datagram without CRC

The SPI input data transfer consists of a 24 bit word: 8 bits for the address and a W/R bit plus 16 bits of data. SPI transactions with CRC error detection.

| SDI //////////////////////////////////// | )15 \ D14 \ D13 \ D12 \ D11 \ D10 \ D9 \ D8 \ D7 \ D6 \ D5 \ D4 \ D3 \ D3 \ D2 \ | D1 \ D0 \ 0 \ 0 \ 0 \ Cl4 \ Cl3 \ Cl2 \ Cl1 \ Cl0 \                                         |
|------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| SDO                                      | DATA_OUT                                                                         | <u>0</u> 0 <u>0</u> <u>0</u> <u>0</u> <u>0</u> <u>0</u> <u>0</u> <u>0</u> <u>0</u> <u>0</u> |

Figure 12. SPI Datagram with CRC

The SPI input data transfer consists of 32 bits: 8 bits for the address and W/R bit, 16 bits of data, and 8 bits of FCS. The CRC error detection is just enabled if the CRC\_EN pin is high.

For more information about CRC error detection, see the <u>CRC Error Detection on the Serial Interface</u> section.

#### **SPI** Data

The SPI bitfields are the following:

- W/nR: Is 1 for a Write command, and it is 0 for a Read command.
- A[6:0]: Address
- D[15:0]: Input data (can be X for a read)
- S[7:0]: Status data
  - S[7] OVT
  - S[6] OCP
  - S[5] OLF
  - S[4] COMER
  - S[3] UVM

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

- S[2] DPM
- S[1] STAT1
- S[0] STAT0
- DATA\_OUT: Output data (it depends on the previous command).

• If the previous command was a write, DATA\_OUT will contain the D[15:0] data sent in the previous command.

If the previous command was a read, DATA\_OUT will contain the register map data at the A[6:0] address sent in the previous command.

A read access request uses dummy write data. Read data is transferred back to the master with subsequent read or write access. Hence, reading multiple registers can be done in a pipelined fashion.

Example:

| ACTION                            | DATA SENT ON SDI | DATA RECEIVED ON SDO   |
|-----------------------------------|------------------|------------------------|
| Read register 0x21 (send command) | 0x21XXXX         | 0xSS, unused_data      |
| Read register 0x21 (receive data) | 0x21XXXX         | 0xSS, data_register_21 |
| Write 0x1234 to register 0x10     | 0x901234         | 0xSS, data_register_21 |
| Write 0x5678 to register 0x10     | 0x905678         | 0xSS1234               |

SS - Status data

#### **CRC Error Detection on the Serial Interface**

CRC error detection on the serial interface CRC error detection of the serial data can be enabled to minimize incorrect operation/misinformation due to data corruption of the SDI/SDO signals.

The CRC Error Detection can be enabled by setting the CRC\_EN input logic high.

If error detection is enabled, then the MAX22216/MAX22217:

- 1. Performs error detection on the SDI data that it receives from the controller, and
- 2. Calculates a CRC on the SDO data and appends a check byte to the SDO diagnostics/status data that it sends to the controller.

This ensures that both the data that it receives from the controller (setting/configuration) and the data that it sends to the controller (diagnostics/status) have a low likelihood of undetected errors. Setting the CRCEN input high enables CRC error detection. A CRC Frame Check Sequence (FCS) is then sent along with each serial transaction. The 5-bit FCS is based on the generator polynomial X5 + X4 + X2 + 1 with a CRC starting value = 11111. When CRC is enabled, the MAX22216/MAX22217 expect a check byte appended to the SDI program/configure data that it receives. The check byte has the following format:



Figure 13. CRC byte

The five FCS bits (Clx / COx) are calculated on all the data sent in one SPI command, including the three "0" in the MSBs of the check byte. Therefore, the CRC is calculated from 19 bits. Cl0 is the LSB of the FCS. The MAX22216/MAX22217 verify the received FCS. If no error is detected, the MAX22216/MAX22217 changes configuration per the SDI data. If a CRC error is detected, then the MAX22216/MAX22217 do not change the configuration. Instead, the MAX22216/MAX22217 MAX22217 set the COMER bit of the status byte of the next SPI transmission high.

If multiple MAX22216/MAX22217 are connected in a daisy chain, the FCS bits for a specific MAX22216/MAX22217 in

## Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

a chain are calculated just on the data that has been sent to this specific MAX22216/MAX22217. Each MAX22216/ MAX22217 in a daisy chain is sent an FCS byte calculated independently from the data that has been sent to the other MAX22216/MAX22217. CRC error detection has to be consistently enabled or disabled within a daisy chain of the MAX22216/MAX22217.

#### One-Time Programmable (OTP)

The configuration settings can be programmed as power-on default by writing one-time programming registers (OTPs). The user can write OTPs registers in production according to his specific needs and verify their content by reading them back through SPI. Once the configuration settings are written into OTP registers, the MAX22216/MAX22217 can be operated by means of logic input signals (CNTL) without the need of SPI control. This operating mode is referred as "stand-alone mode".

The default values of every functional register in the RegMap can possibly be written in the OTP Memory bank. Typically, for stand-alone applications, only a subset of RegMap registers needs to be OTP programmed.

To enter OTP programming mode, the specific SPI command 0xF12A7 needs to be issued (see the <u>OTP Programming</u> section). This command gives access to the OTP Controller registers: OTP\_CONTROL(0x68), OTP\_STATUS (0x69), OTP\_DATA0 (0x7A), OTP\_DATA1 (0x7B), and OTP\_ADDR (0x7C). Similarly to the functional register case, the SPI transfer to the OTP controller register consists of a 24-bit word: 8 bits for the address and the W/R bit plus 16 bits of data.

#### **OTP Programming**

The OTP writing procedure must be executed in a controlled environment. It is normally operated in a factory under wellcontrolled temperature and voltage conditions.

For safe OTP writing, the following conditions must be fulfilled:

Programming Temp: 25°C ± 10°C

Programming Voltage ( $V_M$ ): 8.7 ± 0.13V (1.5%)

The OTP writing procedure is as follows:

- 1. Power up the MAX22216/MAX22217 with  $V_M$  at the programming voltage (8.7V).
- 2. Drive CRC\_EN = 0.
- 3. Activate the device by setting high the bit ACTIVE in the GLOBAL\_CFG register (0x01). All the remaining bits can be set at zero.
- 4. To enter the OTP programming mode, send an SPI command equal to 0xFD12A7.
- 5. To send a second SPI command 0xF8001B to prepare the OTP controller.
- 6. Write the address of the functional register that you want to program into the OTP\_ADDR register (0x7C).
- 7. Write the Least Significant Data Byte into the OTP\_DATA0 register (0x7A). This will become the Least Significant Data Byte Default value at power-up for that specific register.
- 8. Write the Most Significant Data Byte into the OTP\_DATA1 register (0x7B). This will become the Most Significant Data Byte Default value at power-up for that specific register.
- 9. To start programming, write the Start Programming bit (SRT\_PROG) of the register OTP\_CONTROL (0x68) with the remaining bits set at zero.
- 10. Poll the register OTP\_STATUS (0x69) until you see the DONE bit equal to one. If you find other bits equal to one, it means that something failed during programming, and hence the OTP content is corrupted.
- 11. If everything is ok, repeat steps 6–10 for the next Functional Register that you want to program. If a problem occurs at step 8, you can retry the procedure (steps 6–10) for the same Functional Register (see Note 1).
- To verify if the whole process was successful, do a power cycle and read back the default values of the Functional Registers that you have programmed. In case of errors, you can re-program the failed register by repeating steps 6–10 (see Note 1).

Note 1: When a writing cycle (steps 6-10) does not succeed and failures are found at step 10 or step 12, one register of the OTP memory bank becomes unusable. Since the size of the OTP memory bank is limited, you have a limited number of extra OTP write cycle attempts, including successful and unsuccessful attempts.

It is also possible to "lock" the OTP memory bank and avoid further attempts to write OTPs. Once all records' data have been written, the user can write a record with MTP\_ADDR = 0x41 and MTP\_DATA = 0xA5A5 and reboot the device. Doing that, no further programming session of the part will be possible. This prevents the final user from modifying the

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

factory-programmed settings.

#### Wake-Up Time for OTP Download at Power-Up

At power-up, the content of the OTP memory bank must be downloaded into the volatile register bank.

The total wake-up time  $(T_{WU})$  is the sum of a fixed contribution and a variable contribution. The variable contribution is due to the download of the OTP memory and depends on the total number of OTP registers that have been preprogrammed. In formula:

#### $T_{WU} = T_{FW} + T_{VWU} \times N_{OTP}$

Where  $T_{FW}$  denotes the fixed wake-up time and  $T_{VWU}$  denotes the variable wake-up time (see the <u>*Electrical Characteristic*</u> table), and N<sub>OTP</sub> is the number of RegMap registers whose default value has been pre-programmed into OTP registers.

# **Register Map**

### **FUNCTIONAL REGISTERS**

Functional registers can be addressed directly via SPI.

The default values from the factory of all registers is 0. All startup default register values can be re-written and locked in non-volatile memory (OTP) (see the OTP Programming section).

| ADDRESS  | NAME                 | MSB          |              |                     |               |               |              |               | LSB      |
|----------|----------------------|--------------|--------------|---------------------|---------------|---------------|--------------|---------------|----------|
| GLOBAL R | EGISTERS             |              |              |                     |               |               |              |               |          |
| 000      | GLOBAL_CTRL[15:8]    | _            | _            | _                   | _             | _             | _            | _             | _        |
| 0x00     | GLOBAL_CTRL[7:0]     | F_PWM_M[3:0] |              |                     | CNTL3         | CNTL2         | CNTL1        | CNTL0         |          |
|          | GLOBAL_CFG[15:8]     | ACTIVE       | M_OVT        | M_OCP               | M_OLF         | M_HHF         | M_DPM        | M_COM<br>F    | M_UVM    |
| 0x01     | GLOBAL_CFG[7:0]      | CNTL_P<br>OL | STAT_P<br>OL | P – VDRnVD CHS[3:0] |               |               |              |               |          |
| 0x02     | STATUS[15:8]         | -            | STT3         | STT2                | STT1          | STT0          | MIN_T_<br>ON | RES           | IND      |
|          | STATUS[7:0]          | OVT          | OCP          | OLF                 | HHF           | DPM           | COMER        | UVM           | RFU      |
| 0.402    | STATUS_CFG[15:8]     | -            | -            | -                   | _             | -             | -            | M_UVM_<br>CMP | V5_nV3   |
| 0x03     | STATUS_CFG[7:0]      | EN_LDO       | STRETCH      | H_EN[1:0]           | STAT_S<br>EL1 | STAT_S<br>EL0 | S            | TAT_FUN[2     | :0]      |
| 0.404    | DC_H2L[15:8]         |              |              |                     | DC_H2         | 2L[15:8]      |              |               |          |
| 0x04     | DC_H2L[7:0]          |              |              |                     | DC_H          | 2L[7:0]       |              |               |          |
| 0.405    | VM_MONITOR[15:8]     | -            | -            | _                   |               | VM            | MONITOR[     | 12:8]         |          |
| 0x05     | VM_MONITOR[7:0]      |              |              |                     | VM_MON        | ITOR[7:0]     |              |               |          |
| 000      | VM_THRESHOLD[15:8]   | -            | -            | _                   | -             | _             | -            | _             | _        |
| 0x06     | VM_THRESHOLD[7:0]    |              | VM_THL       | D_UP[3:0]           |               |               | VM_THLD_     | DOWN[3:0]     |          |
| 0x07     | F_AC[15:8]           | -            | -            | -                   | -             |               | F_AC_SC      | CAN[11:8]     |          |
| 0.07     | F_AC[7:0]            |              |              |                     | F_AC_S        | CAN[7:0]      |              |               |          |
| 0x08     | U_AC_SCAN[15:8]      | -            |              |                     | U_4           | AC_SCAN[1     | 4:8]         |               |          |
| 0,00     | U_AC_SCAN[7:0]       |              |              |                     | U_AC_S        | CAN[7:0]      |              |               |          |
| CONFIGUR | ATION REGISTERS CH 0 |              |              |                     |               |               |              |               |          |
| 0x09     | CFG_DC_L2H[15:8]     |              |              |                     | DC_L2F        | I_0[15:8]     |              |               |          |
| 0,09     | CFG_DC_L2H[7:0]      |              |              |                     | DC_L2H        | H_0[7:0]      |              |               |          |
| 0x0A     | CFG_DC_H[15:8]       |              |              |                     | DC_H_         | 0[15:8]       |              |               |          |
| 0,0,7    | <u>CFG_DC_H[7:0]</u> |              |              |                     | DC_H          | _0[7:0]       |              |               |          |
| 0x0B     | CFG_DC_L[15:8]       |              |              |                     | DC_L_         | 0[15:8]       |              |               |          |
| UXUD     | CFG_DC_L[7:0]        |              |              |                     | DC_L          | _0[7:0]       |              |               |          |
| 0x0C     | CFG_L2H_TIME[15:8]   |              |              |                     | TIME_L2       | H_0[15:8]     |              |               |          |
| 0,000    | CFG_L2H_TIME[7:0]    |              |              |                     | TIME_L2       | 2H_0[7:0]     |              |               |          |
| 0x0D     | CFG_CTRL0[15:8]      | CTRL_MC      | DE_0[1:0]    | HHF_EN<br>_0        | OL_EN_<br>0   | H2L_EN<br>_0  | RDWE_0       | RMDE_0        | RUPE_0   |
|          | CFG_CTRL0[7:0]       |              |              |                     |               |               |              |               |          |
| 0x0E     | CFG_CTRL1[15:8]      | _            | _            | _                   | _             | _             | HSnLS_<br>0  | F_PWN         | 1_0[1:0] |

| ADDRESS  | NAME                 | MSB     |              |                                   |                        |               |                 |                  | LSB            |  |  |
|----------|----------------------|---------|--------------|-----------------------------------|------------------------|---------------|-----------------|------------------|----------------|--|--|
|          | CFG_CTRL1[7:0]       | T_BLANK | ING_0[1:0]   | SLEW_RA                           | TE_0[1:0]              | GAIN          | v[1:0]          | SNS              | F[1:0]         |  |  |
|          | CFG_DPM0[15:8]       |         |              | _                                 | _                      |               | DPM THL         | _D_0[11:8]       |                |  |  |
| 0x0F     | CFG DPM0[7:0]        |         |              |                                   | DPM TH                 | LD_0[7:0]     |                 |                  |                |  |  |
| 0x10     | CFG_DPM1[15:8]       | _       | DPM_EN<br>_0 | END_HI<br>T_TO_HI<br>Z_AUTO<br>_0 | END_HI<br>T_AUTO<br>_0 |               | DPM_MIN_        | NBR_0[3:0]       |                |  |  |
|          | CFG_DPM1[7:0]        |         | 1            | 1                                 | DPM_ST                 | ART[7:0]      |                 |                  |                |  |  |
|          | CFG_IDC_THLD[15:8]   |         |              |                                   | IDC_THL                | D_0[15:8]     |                 |                  |                |  |  |
| 0x11     | CFG_IDC_THLD[7:0]    |         |              |                                   | IDC_TH                 | _D_0[7:0]     |                 |                  |                |  |  |
| a (a     | CFG_R_THLD[15:8]     |         |              |                                   | RES_THL                | .D_0[15:8]    |                 |                  |                |  |  |
| 0x12     | CFG_R_THLD[7:0]      |         |              |                                   | RES_TH                 | LD_0[7:0]     |                 |                  |                |  |  |
| 0x13     | CFG_IND_0[15:8]      | _       | _            | _                                 | _                      | DITH_E<br>N_0 | L_MEAS<br>_EN_0 | L_MEAS<br>_L2H_0 | L_MEAS<br>_H_0 |  |  |
|          | CFG_IND_0[7:0]       | L_      | MEAS_WC      | YCLES_0[3                         | :0]                    |               | L_NBR_C/        | ALC_0[3:0]       |                |  |  |
| 0x14     | CFG_IND_1[15:8]      | -       | _            | -                                 | _                      |               | IAC_THL         | D_0[11:8]        |                |  |  |
| UX 14    | CFG_IND_1[7:0]       |         |              |                                   | IAC_THL                | D_0[7:0]      |                 |                  |                |  |  |
| 0x15     | <u>CFG_P[15:8]</u>   |         |              |                                   | CFG_P                  | _0[15:8]      |                 |                  |                |  |  |
| UXIS     | <u>CFG_P[7:0]</u>    |         |              |                                   | CFG_F                  | P_0[7:0]      |                 |                  |                |  |  |
| 0.46     | <u>CFG_I[15:8]</u>   |         |              |                                   | CFG_I                  | _0[15:8]      |                 |                  |                |  |  |
| 0x16     | <u>CFG_I[7:0]</u>    |         |              |                                   | CFG_I                  | _0[7:0]       |                 |                  |                |  |  |
| CONFIGUR | ATION REGISTERS CH 1 | •       |              |                                   |                        |               |                 |                  |                |  |  |
| 0x17     | CFG_DC_L2H[15:8]     |         |              |                                   | DC_L2H                 | I_1[15:8]     | [15:8]          |                  |                |  |  |
| UX17     | CFG_DC_L2H[7:0]      |         |              |                                   | DC_L2H                 | H_1[7:0]      |                 |                  |                |  |  |
| 0x18     | CFG_DC_H[15:8]       |         |              |                                   | DC_H_                  | 1[15:8]       |                 |                  |                |  |  |
| 0210     | <u>CFG_DC_H[7:0]</u> |         |              |                                   | DC_H                   | _1[7:0]       |                 |                  |                |  |  |
| 0x19     | CFG_DC_L[15:8]       |         |              |                                   | DC_L_                  | 1[15:8]       |                 |                  |                |  |  |
| 0,19     | CFG_DC_L[7:0]        |         |              |                                   | DC_L                   | _1[7:0]       |                 |                  |                |  |  |
| 0x1A     | CFG_L2H_TIME[15:8]   |         |              |                                   | TIME_L2                | H_1[15:8]     |                 |                  |                |  |  |
| UXIA     | CFG_L2H_TIME[7:0]    |         |              |                                   | TIME_L2                | 2H_1[7:0]     |                 |                  |                |  |  |
| 0x1B     | CFG_CTRL0[15:8]      | CTRL_MC | DE_1[1:0]    | HHF_EN<br>_1                      | OL_EN_<br>1            | H2L_EN<br>_1  | RDWE_1          | RMDE_1           | RUPE_1         |  |  |
|          | CFG_CTRL0[7:0]       |         |              |                                   | RAMP                   | _1[7:0]       |                 |                  |                |  |  |
| 0x1C     | CFG_CTRL1[15:8]      | -       | -            | -                                 | -                      | -             | HSnLS_<br>1     | F_PWN            | /I_1[1:0]      |  |  |
|          | CFG_CTRL1[7:0]       | T_BLANK | ING_1[1:0]   | SLEW_RA                           | ATE_1[1:0]             | GAIN          | <b>V</b> [1:0]  | SNS              | F[1:0]         |  |  |
| 0x1D     | CFG_DPM0[15:8]       | -       | -            | -                                 | -                      |               | DPM_THL         | _D_1[11:8]       |                |  |  |
| UXID     | CFG_DPM0[7:0]        |         |              |                                   | DPM_TH                 | LD_1[7:0]     |                 |                  |                |  |  |
| 0x1E     | CFG_DPM1[15:8]       | _       | DPM_EN<br>_1 | END_HI<br>T_TO_HI<br>Z_AUTO<br>_1 | END_HI<br>T_AUTO<br>_1 |               | DPM_MIN_        | NBR_1[3:0]       |                |  |  |
|          | CFG_DPM1[7:0]        |         |              |                                   | DPM_ST                 | ART[7:0]      |                 |                  |                |  |  |
| 0.45     | CFG_IDC_THLD[15:8]   |         |              |                                   | IDC_THL                | D_1[15:8]     |                 |                  |                |  |  |
| 0x1F     | CFG_IDC_THLD[7:0]    |         |              |                                   | IDC_TH                 | _D_1[7:0]     |                 |                  |                |  |  |

| ADDRESS  | NAME                 | MSB     |              |                                   |                        |                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  | LSB            |  |  |  |
|----------|----------------------|---------|--------------|-----------------------------------|------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------|--|--|--|
| 0.00     | CFG_R_THLD[15:8]     |         |              |                                   | RES_THL                | LD_1[15:8]                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x20     | CFG_R_THLD[7:0]      |         |              |                                   | RES_TH                 | LD_1[7:0]<br>DITH_E L_MEAS L_MEAS L_MEAS |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x21     | CFG_IND_0[15:8]      | _       | -            | -                                 | _                      |                                          | L_MEAS<br>_EN_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | L_MEAS<br>_L2H_1 | L_MEAS<br>_H_1 |  |  |  |
|          | CFG_IND_0[7:0]       | L_      | MEAS_WC      | YCLES_1[3                         | :0]                    |                                          | 15:8]       Image: constraint of the second constrated constraned constraint of the second constraint of | 1                |                |  |  |  |
| 000      | CFG_IND_1[15:8]      | -       | _            | -                                 | _                      |                                          | IAC_THL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | D_1[11:8]        |                |  |  |  |
| 0x22     | CFG_IND_1[7:0]       |         |              |                                   | IAC_THL                | _D_1[7:0]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x23     | <u>CFG_P[15:8]</u>   |         |              |                                   | CFG_P                  | _1[15:8]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0823     | <u>CFG_P[7:0]</u>    |         |              |                                   | CFG_F                  | P_1[7:0]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x24     | <u>CFG_I[15:8]</u>   |         |              |                                   | CFG_I                  | _1[15:8]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0824     | <u>CFG_I[7:0]</u>    |         |              |                                   | CFG_I                  | _1[7:0]                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| CONFIGUR | ATION REGISTERS CH 2 |         |              |                                   |                        |                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x25     | CFG_DC_L2H[15:8]     |         |              |                                   | DC_L2F                 | l_2[15:8]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0,25     | CFG_DC_L2H[7:0]      |         |              |                                   | DC_L2H                 | H_2[7:0]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x26     | CFG_DC_H[15:8]       |         |              |                                   | DC_H_                  | _2[15:8]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0,20     | CFG_DC_H[7:0]        |         |              |                                   | DC_H                   | _2[7:0]                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x27     | CFG_DC_L[15:8]       |         |              |                                   | DC_L_                  | 2[15:8]                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0721     | CFG_DC_L[7:0]        |         |              |                                   | DC_L                   | _2[7:0]                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x28     | CFG_L2H_TIME[15:8]   |         |              |                                   | TIME_L2                | H_2[15:8]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0720     | CFG_L2H_TIME[7:0]    |         |              |                                   |                        | 2H_2[7:0]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x29     | CFG_CTRL0[15:8]      | CTRL_MC | DE_2[1:0]    | HHF_EN<br>_2                      | OL_EN_<br>2            | H2L_EN<br>_2                             | RDWE_2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RUPE_2           |                |  |  |  |
|          | CFG_CTRL0[7:0]       |         |              |                                   | RAMP                   | _2[7:0]                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x2A     | CFG_CTRL1[15:8]      | -       | -            | -                                 | -                      | -                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | F_PWN            | 1_2[1:0]       |  |  |  |
|          | CFG_CTRL1[7:0]       | T_BLANK | NG_2[1:0]    | SLEW_RA                           | TE_2[1:0]              | GAIN                                     | N[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SNS              | F[1:0]         |  |  |  |
| 0x2B     | CFG_DPM0[15:8]       | -       | _            | -                                 | _                      |                                          | DPM_THL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _D_2[11:8]       |                |  |  |  |
| 0720     | CFG_DPM0[7:0]        |         |              |                                   | DPM_TH                 | LD_2[7:0]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x2C     | CFG_DPM1[15:8]       | _       | DPM_EN<br>_2 | END_HI<br>T_TO_HI<br>Z_AUTO<br>_2 | END_HI<br>T_AUTO<br>_2 |                                          | DPM_MIN_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | NBR_2[3:0]       |                |  |  |  |
|          | CFG_DPM1[7:0]        |         | 1            |                                   | DPM_ST                 | ART[7:0]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 00D      | CFG_IDC_THLD[15:8]   |         |              |                                   | IDC_THL                | D_2[15:8]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x2D     | CFG_IDC_THLD[7:0]    |         |              |                                   | IDC_TH                 | _D_2[7:0]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 00       | CFG_R_THLD[15:8]     |         |              |                                   | RES_THL                | .D_2[15:8]                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x2E     | CFG_R_THLD[7:0]      |         |              |                                   | RES_TH                 | LD_2[7:0]                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x2F     | CFG_IND_0[15:8]      | -       | -            | -                                 | -                      | DITH_E<br>N_2                            | L_MEAS<br>_EN_2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | L_MEAS<br>_L2H_2 | L_MEAS<br>_H_2 |  |  |  |
|          | CFG_IND_0[7:0]       | L_      | MEAS_WC      | YCLES_2[3                         | :0]                    |                                          | L_NBR_C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ALC_2[3:0]       |                |  |  |  |
| 0x30     | CFG_IND_1[15:8]      | -       | _            | -                                 | _                      |                                          | IAC_THL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | D_2[11:8]        |                |  |  |  |
| 0x30     | CFG_IND_1[7:0]       |         |              |                                   | IAC_THL                | D_2[7:0]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x24     | <u>CFG_P[15:8]</u>   |         |              |                                   | CFG_P                  | _2[15:8]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |
| 0x31     | CFG P[7:0]           |         |              |                                   | CFG_F                  | P_2[7:0]                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                |  |  |  |

| ADDRESS  | NAME                 | MSB                |                          |                                               |                                    |                         |                         |                  | LSB            |  |  |
|----------|----------------------|--------------------|--------------------------|-----------------------------------------------|------------------------------------|-------------------------|-------------------------|------------------|----------------|--|--|
| 0.00     | <u>CFG_I[15:8]</u>   |                    | CFG_I_2[15:8]            |                                               |                                    |                         |                         |                  |                |  |  |
| 0x32     | <u>CFG_I[7:0]</u>    |                    |                          |                                               | CFG_I                              | _2[7:0]                 |                         |                  |                |  |  |
| CONFIGUR | ATION REGISTERS CH 3 | ;<br>;             |                          |                                               |                                    |                         |                         |                  |                |  |  |
| 0.00     | CFG_DC_L2H[15:8]     |                    |                          |                                               | DC_L2H                             | _3[15:8]                |                         |                  |                |  |  |
| 0x33     | CFG_DC_L2H[7:0]      |                    |                          |                                               | DC_L2H                             | 1_3[7:0]                |                         |                  |                |  |  |
| 0.04     | CFG_DC_H[15:8]       |                    |                          |                                               | DC_H_                              | 3[15:8]                 |                         |                  |                |  |  |
| 0x34     | CFG_DC_H[7:0]        |                    |                          |                                               | DC_H                               | _3[7:0]                 |                         |                  |                |  |  |
| 005      | CFG_DC_L[15:8]       |                    |                          |                                               | DC_L_                              | 3[15:8]                 |                         |                  |                |  |  |
| 0x35     | CFG_DC_L[7:0]        |                    |                          |                                               | DC_L                               | _3[7:0]                 |                         |                  |                |  |  |
| 000      | CFG_L2H_TIME[15:8]   |                    |                          |                                               | TIME_L2                            | H_3[15:8]               |                         |                  |                |  |  |
| 0x36     | CFG_L2H_TIME[7:0]    |                    |                          |                                               | TIME_L2                            | H_3[7:0]                |                         |                  |                |  |  |
| 0x37     | CFG_CTRL0[15:8]      | CTRL_MC            | DE_3[1:0]                | HHF_EN<br>_3                                  | OL_EN_<br>3                        | H2L_EN RDWE_3 RMDE_3 RU |                         |                  |                |  |  |
|          | CFG_CTRL0[7:0]       |                    |                          |                                               | RAMP                               | _3[7:0]                 |                         |                  |                |  |  |
| 0x38     | CFG_CTRL1[15:8]      | -                  | -                        | -                                             | -                                  | -                       | HSnLS_<br>3 F_PWM_3[1:0 |                  |                |  |  |
|          | CFG_CTRL1[7:0]       | T_BLANK            | ING_3[1:0]               | SLEW_RA                                       | TE_3[1:0]                          | GAIN                    | IN[1:0] SNSF[1:0]       |                  |                |  |  |
| 000      | CFG_DPM0[15:8]       | -                  | _                        | _                                             | _                                  |                         | DPM_THLD_3[11:8]        |                  |                |  |  |
| 0x39     | CFG_DPM0[7:0]        |                    |                          |                                               | DPM_TH                             | LD_3[7:0]               | ]                       |                  |                |  |  |
| 0x3A     | CFG_DPM1[15:8]       | _                  | DPM_EN<br>_ <sup>3</sup> | END_HI<br>T_TO_HI<br>Z_AUTO<br>_ <sup>3</sup> | END_HI<br>T_AUTO<br>_ <sup>3</sup> |                         | DPM_MIN_NBR_3[3:0]      |                  |                |  |  |
|          | CFG_DPM1[7:0]        |                    |                          |                                               | DPM_ST                             | ART[7:0]                |                         |                  |                |  |  |
| 0.05     | CFG_IDC_THLD[15:8]   |                    |                          |                                               | IDC_THL                            | D_3[15:8]               |                         |                  |                |  |  |
| 0x3B     | CFG_IDC_THLD[7:0]    |                    |                          |                                               | IDC_THL                            | .D_3[7:0]               |                         |                  |                |  |  |
| 0x3C     | CFG_R_THLD[15:8]     |                    |                          |                                               | RES_THL                            | D_3[15:8]               |                         |                  |                |  |  |
| 0x30     | CFG_R_THLD[7:0]      |                    |                          |                                               | RES_TH                             | _D_3[7:0]               |                         | _                | _              |  |  |
| 0x3D     | CFG_IND_0[15:8]      | -                  | -                        | -                                             | -                                  | DITH_E<br>N_3           | L_MEAS<br>_EN_3         | L_MEAS<br>_L2H_3 | L_MEAS<br>_H_3 |  |  |
|          | CFG_IND_0[7:0]       | L_                 | MEAS_WC                  | YCLES_3[3                                     | :0]                                |                         | L_NBR_C                 | ALC_3[3:0]       |                |  |  |
| 0x3E     | CFG_IND_1[15:8]      | -                  | _                        | _                                             | _                                  |                         | IAC_THL                 | D_3[11:8]        |                |  |  |
| UNDL     | CFG_IND_1[7:0]       |                    |                          |                                               | IAC_THL                            | .D_3[7:0]               |                         |                  |                |  |  |
| 0x3F     | <u>CFG_P[15:8]</u>   |                    |                          |                                               | CFG_P                              | _3[15:8]                |                         |                  |                |  |  |
| 0,01     | <u>CFG_P[7:0]</u>    |                    |                          |                                               | CFG_F                              | _3[7:0]                 |                         |                  |                |  |  |
| 0x40     | <u>CFG_I[15:8]</u>   |                    |                          |                                               | CFG_I                              | 3[15:8]                 |                         |                  |                |  |  |
| 0740     | <u>CFG_I[7:0]</u>    |                    |                          |                                               | CFG_I                              | _3[7:0]                 |                         |                  |                |  |  |
| DIAGNOST | ICS_CH 0             |                    |                          |                                               |                                    |                         |                         |                  |                |  |  |
| 0x41     | I_DPM_PEAK[15:8]     | I_DPM_PEAK_0[15:8] |                          |                                               |                                    |                         |                         |                  |                |  |  |
|          | I_DPM_PEAK[7:0]      |                    |                          |                                               | I_DPM_PE                           | AK_0[7:0]               |                         |                  |                |  |  |
| 0x42     | I_DPM_VALLEY[15:8]   |                    |                          |                                               | _DPM_VAL                           | LEY_0[15:8              | ]                       |                  |                |  |  |
| 0172     | I_DPM_VALLEY[7:0]    |                    |                          |                                               | I_DPM_VAL                          |                         |                         |                  |                |  |  |
| 0x43     | TRAVEL_TIME[15:8]    |                    |                          |                                               | TRAVEL_                            | FIME[15:8]              |                         |                  |                |  |  |
| 0,40     | TRAVEL_TIME[7:0]     |                    |                          |                                               | TRAVEL                             | TIME[7:0]               |                         |                  |                |  |  |

| ADDRESS  | NAME                 | MSB                                   |                                               |    |           |             |      |  | LSB |  |  |  |  |
|----------|----------------------|---------------------------------------|-----------------------------------------------|----|-----------|-------------|------|--|-----|--|--|--|--|
| 0        | REACTION_TIME[15:8]  |                                       | ISB   LSB     REACTION_TIME_0[15:8]           |    |           |             |      |  |     |  |  |  |  |
| 0x44     | REACTION_TIME[7:0]   |                                       | REACTION_TIME_0[15:8]<br>REACTION_TIME_0[7:0] |    |           |             |      |  |     |  |  |  |  |
| o 45     | I_MONITOR[15:8]      |                                       |                                               |    | I_MONITO  | DR_0[15:8]  |      |  |     |  |  |  |  |
| 0x45     | I_MONITOR[7:0]       | I_MONITOR_0[15:8]<br>I_MONITOR_0[7:0] |                                               |    |           |             |      |  |     |  |  |  |  |
| 047      | I_AC[15:8]           |                                       | I_AC_0[15:8]                                  |    |           |             |      |  |     |  |  |  |  |
| 0x47     | L_AC[7:0]            |                                       |                                               |    | I_AC      | _0[7:0]     |      |  |     |  |  |  |  |
| 0.40     | <u>RES[15:8]</u>     |                                       | RES[15:8]                                     |    |           |             |      |  |     |  |  |  |  |
| 0x48     | <u>RES[7:0]</u>      |                                       | RES[7:0]                                      |    |           |             |      |  |     |  |  |  |  |
| 0x49     | PWM_DUTY[15:8]       |                                       |                                               | P\ | WM_DUTYC  | CYCLE_0[1   | 5:8] |  |     |  |  |  |  |
| 0849     | <u>PWM_DUTY[7:0]</u> |                                       | PWM_DUTYCYCLE_0[7:0]                          |    |           |             |      |  |     |  |  |  |  |
| DIAGNOST | ICS_CH 1             |                                       |                                               |    |           |             |      |  |     |  |  |  |  |
| 0.44     | I_DPM_PEAK[15:8]     |                                       |                                               |    | I_DPM_PE  | AK_1[15:8]  |      |  |     |  |  |  |  |
| 0x4A     | I_DPM_PEAK[7:0]      |                                       |                                               |    | I_DPM_PI  | EAK_1[7:0]  |      |  |     |  |  |  |  |
| 0x4B     | I_DPM_VALLEY[15:8]   |                                       |                                               |    | _DPM_VAL  | LEY_1[15:8  | 3]   |  |     |  |  |  |  |
| UX4D     | I_DPM_VALLEY[7:0]    |                                       |                                               |    | I_DPM_VA  | LLEY_1[7:0  | ]    |  |     |  |  |  |  |
| 0.40     | TRAVEL_TIME[15:8]    |                                       |                                               |    | TRAVEL_   | TIME[15:8]  |      |  |     |  |  |  |  |
| 0x4C     | TRAVEL_TIME[7:0]     |                                       |                                               |    | TRAVEL_   | TIME[7:0]   |      |  |     |  |  |  |  |
| 0.40     | REACTION_TIME[15:8]  |                                       |                                               | F  | REACTION_ | TIME_1[15:  | :8]  |  |     |  |  |  |  |
| 0x4D     | REACTION_TIME[7:0]   |                                       |                                               |    | REACTION  | _TIME_1[7:0 | 0]   |  |     |  |  |  |  |
| 0x4E     | I_MONITOR[15:8]      |                                       | I_MONITOR_1[15:8]                             |    |           |             |      |  |     |  |  |  |  |
| UX4E     | L_MONITOR[7:0]       | I_MONITOR_1[7:0]                      |                                               |    |           |             |      |  |     |  |  |  |  |
| 0x50     | L_AC[15:8]           | I_AC_1[15:8]                          |                                               |    |           |             |      |  |     |  |  |  |  |
| 0620     | L_AC[7:0]            |                                       |                                               |    | I_AC      | _1[7:0]     |      |  |     |  |  |  |  |
| 0x51     | <u>RES[15:8]</u>     |                                       |                                               |    | RES       | [15:8]      |      |  |     |  |  |  |  |
| 0,01     | <u>RES[7:0]</u>      |                                       |                                               |    | RES       | S[7:0]      |      |  |     |  |  |  |  |
| 0x52     | PWM_DUTY[15:8]       |                                       |                                               | P\ | VM_DUTYC  | CYCLE_1[18  | 5:8] |  |     |  |  |  |  |
| 07.02    | <u>PWM_DUTY[7:0]</u> |                                       |                                               | Р  | WM_DUTY   | CYCLE_1[7   | :0]  |  |     |  |  |  |  |
| DIAGNOST | ICS_CH 2             |                                       |                                               |    |           |             |      |  |     |  |  |  |  |
| 0x53     | I_DPM_PEAK[15:8]     |                                       |                                               |    | I_DPM_PE  | AK_2[15:8]  |      |  |     |  |  |  |  |
| 0,00     | I_DPM_PEAK[7:0]      |                                       |                                               |    | I_DPM_PI  | EAK_2[7:0]  |      |  |     |  |  |  |  |
| 0x54     | I_DPM_VALLEY[15:8]   |                                       |                                               |    | _DPM_VAL  | LEY_2[15:8  | 3]   |  |     |  |  |  |  |
| 0,04     | I_DPM_VALLEY[7:0]    |                                       |                                               |    | I_DPM_VA  | LLEY_2[7:0  | ]    |  |     |  |  |  |  |
| 0x55     | TRAVEL_TIME[15:8]    |                                       |                                               |    | TRAVEL_   | TIME[15:8]  |      |  |     |  |  |  |  |
| 0,00     | TRAVEL_TIME[7:0]     |                                       |                                               |    | TRAVEL_   | _TIME[7:0]  |      |  |     |  |  |  |  |
| 0x56     | REACTION_TIME[15:8]  |                                       |                                               | F  | REACTION_ | TIME_2[15:  | :8]  |  |     |  |  |  |  |
| 0,00     | REACTION_TIME[7:0]   |                                       |                                               |    | REACTION  | _TIME_2[7:0 | 0]   |  |     |  |  |  |  |
| 0x57     | I_MONITOR[15:8]      |                                       |                                               |    | I_MONITO  | DR_2[15:8]  |      |  |     |  |  |  |  |
| 0.01     | I_MONITOR[7:0]       |                                       |                                               |    | I_MONIT   | OR_2[7:0]   |      |  |     |  |  |  |  |
| 0x59     | I_AC[15:8]           | I_AC_2[15:8]                          |                                               |    |           |             |      |  |     |  |  |  |  |
| 0703     | <u>I_AC[7:0]</u>     |                                       |                                               |    | I_AC      | _2[7:0]     |      |  |     |  |  |  |  |
| 0x5A     | <u>RES[15:8]</u>     |                                       |                                               |    | RES       | [15:8]      |      |  |     |  |  |  |  |
| UNJA     | <u>RES[7:0]</u>      |                                       |                                               |    | RES       | 6[7:0]      |      |  |     |  |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| ADDRESS   | NAME                 | MSB  |                                               |       |          |            |      |      | LSB  |  |  |  |
|-----------|----------------------|------|-----------------------------------------------|-------|----------|------------|------|------|------|--|--|--|
| 0x5B      | PWM_DUTY[15:8]       |      | PWM_DUTYCYCLE_2[15:8]<br>PWM_DUTYCYCLE_2[7:0] |       |          |            |      |      |      |  |  |  |
| UX3B      | <u>PWM_DUTY[7:0]</u> |      |                                               | P     | WM_DUTY  | CYCLE_2[7  | :0]  |      |      |  |  |  |
| DIAGNOST  | CS_CH 3              |      |                                               |       |          |            |      |      |      |  |  |  |
| 0         | I_DPM_PEAK[15:8]     |      | I_DPM_PEAK_3[15:8]                            |       |          |            |      |      |      |  |  |  |
| 0x5C      | I_DPM_PEAK[7:0]      |      | I_DPM_PEAK_3[7:0]                             |       |          |            |      |      |      |  |  |  |
| 0.45D     | I_DPM_VALLEY[15:8]   |      | I_DPM_VALLEY_3[15:8]                          |       |          |            |      |      |      |  |  |  |
| 0x5D      | I_DPM_VALLEY[7:0]    |      | I_DPM_VALLEY_3[7:0]                           |       |          |            |      |      |      |  |  |  |
| 0.455     | TRAVEL_TIME[15:8]    |      |                                               |       | TRAVEL_  | TIME[15:8] |      |      |      |  |  |  |
| 0x5E      | TRAVEL_TIME[7:0]     |      |                                               |       | TRAVEL   | TIME[7:0]  |      |      |      |  |  |  |
| 0.455     | REACTION_TIME[15:8]  |      |                                               | R     | EACTION_ | TIME_3[15: | 8]   |      |      |  |  |  |
| 0x5F      | REACTION_TIME[7:0]   |      | REACTION_TIME_3[7:0]                          |       |          |            |      |      |      |  |  |  |
| 0x60      | I_MONITOR[15:8]      |      | I_MONITOR_3[15:8]                             |       |          |            |      |      |      |  |  |  |
| 0x60      | I_MONITOR[7:0]       |      |                                               |       | I_MONIT  | OR_3[7:0]  |      |      |      |  |  |  |
| 0x62      | L_AC[15:8]           |      |                                               |       | I_AC_    | 3[15:8]    |      |      |      |  |  |  |
| 0x02      | I_AC[7:0]            |      |                                               |       | I_AC_    | 3[7:0]     |      |      |      |  |  |  |
| 0x63      | <u>RES[15:8]</u>     |      |                                               |       | RES      | [15:8]     |      |      |      |  |  |  |
| 0x03      | <u>RES[7:0]</u>      |      |                                               |       | RES      | [7:0]      |      |      |      |  |  |  |
| 0x64      | PWM_DUTY[15:8]       |      |                                               | P۷    | VM_DUTYC | YCLE_3[15  | 5:8] |      |      |  |  |  |
| 0X04      | PWM_DUTY[7:0]        |      |                                               | P     | WM_DUTY  | CYCLE_3[7  | :0]  |      |      |  |  |  |
| FAULT LOG | 5                    |      |                                               |       |          |            |      |      |      |  |  |  |
| 0,465     | FAULT0[15:8]         | DPM3 | DPM3 DPM2 DPM1 DPM0 OLF3 OLF2 OLF1 OLF0       |       |          |            |      |      |      |  |  |  |
| 0x65      | FAULT0[7:0]          | HHF3 | HHF2                                          | HHF1  | HHF0     | OCP3       | OCP2 | OCP1 | OCP0 |  |  |  |
| 0,466     | FAULT1[15:8]         | _    | _                                             | _     | _        | _          | RES3 | RES2 | RES1 |  |  |  |
| 0x66      | FAULT1[7:0]          | RES0 | OVT                                           | COMER | UVM      | IND3       | IND2 | IND1 | IND0 |  |  |  |

## **Register Details**

### GLOBAL\_CTRL (0x00)

| BIT            | 15 | 14 | 13         | 12 | 11     | 10    | 9     | 8      |
|----------------|----|----|------------|----|--------|-------|-------|--------|
| Field          | _  | -  | -          | _  | -      | _     | -     | _      |
| Reset          | -  | -  | -          | -  | -      | -     | -     | -      |
| Access<br>Type | -  | _  | _          | _  | _      | -     | -     | -      |
| BIT            | 7  | 6  | 5          | 4  | 3      | 2     | 1     | 0      |
| Field          |    |    | 1_M[3:0]   |    | CNTL3  |       | CNTL1 |        |
| i leiu         |    |    | i_ivi[3.0] |    | CINILS | CNTL2 | CNILI | CNTL0  |
| Reset          |    |    | I_IN[3.0]  |    | CNTLS  | GNTLZ | CNTLT | CINTLU |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD | BITS | DESCRIPTION                                                                                                                                                           | DECODE                                                                                                                                                                               |
|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F_PWM_M  | 7:4  | Master chopping frequency                                                                                                                                             | 0x0: 100kHz<br>0x1: 80kHz<br>0x2: 60kHz<br>0x3: 50kHz<br>0x4: 40kHz<br>0x5: 30kHz<br>0x6: 25kHz<br>0x7: 20kHz<br>0x8: 15kHz<br>0x9: 10kHz<br>0xA: 7.5kHz<br>0xB: 5kHz<br>0xC: 2.5kHz |
| CNTL3    | 3    | Used to control the corresponding channel depending on the CHS register field of the GLOBAL_CFG register. See <u>Table 2</u> and <u>Table 3</u> for more information. | 0x0: Disable the channel<br>0x1: Enable the channel                                                                                                                                  |
| CNTL2    | 2    | Used to control the corresponding channel depending on the CHS register field of the GLOBAL_CFG register. See <u>Table 2</u> and <u>Table 3</u> for more information. | 0x0: Disable the channel<br>0x1: Enable the channel                                                                                                                                  |
| CNTL1    | 1    | Used to control the corresponding channel depending on the CHS register field of the GLOBAL_CFG register. See <u>Table 2</u> and <u>Table 3</u> for more information. | 0x0: Disable the channel<br>0x1: Enable the channel                                                                                                                                  |
| CNTL0    | 0    | Used to control the corresponding channel depending on the CHS register field of the GLOBAL_CFG register. See <u>Table 2</u> and <u>Table 3</u> for more information. | 0x0: Disable the channel<br>0x1: Enable the channel                                                                                                                                  |

#### GLOBAL\_CFG (0x01)

| BIT            | 15          | 14                 | 13                                                                                   | 12              | 11          | 10                                | 9           | 8           |  |  |
|----------------|-------------|--------------------|--------------------------------------------------------------------------------------|-----------------|-------------|-----------------------------------|-------------|-------------|--|--|
| Field          | ACTIVE      | M_OVT              | M_OCP                                                                                | M_OLF           | M_HHF       | M_HHF M_DPM M_COMF M_U            |             |             |  |  |
| Reset          |             |                    |                                                                                      |                 |             |                                   |             |             |  |  |
| Access<br>Type | Write, Read | Write, Read        | Write, Read                                                                          | Write, Read     | Write, Read | Write, Read                       | Write, Read | Write, Read |  |  |
| BIT            | 7           | 6                  | 5                                                                                    | 4               | 3           | 2                                 | 1           | 0           |  |  |
| Field          | CNTL_POL    | STAT_POL           | _                                                                                    | VDRnVDRD<br>UTY |             | CHS                               | §[3:0]      |             |  |  |
| Reset          |             |                    | -                                                                                    |                 |             |                                   |             |             |  |  |
| Access<br>Type | Write, Read | Write, Read        | -                                                                                    | Write, Read     |             | Write,                            | Read        |             |  |  |
| BITFIELD       | BITS        |                    | DESCRIPT                                                                             | ION             |             | D                                 | ECODE       |             |  |  |
| ACTIVE         | 15          | Enable bit to      | ole bit to activate the part 0x0: Disable part, low-power mode is a 0x1: Enable part |                 |             |                                   |             | active      |  |  |
| M_OVT          | 14          | Masks overt<br>pin | emperature de                                                                        | tection for FAL |             | mask detection<br>sk detection fo |             | l           |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD        | BITS | DESCRIPTION                                                                                                                                                                                                                                                                                           | DECODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M_OCP           | 13   | Masks overcurrent protection for FAULT pin                                                                                                                                                                                                                                                            | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M_OLF           | 12   | Masks open-load detection for FAULT pin                                                                                                                                                                                                                                                               | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M_HHF           | 11   | Masks hit current not reached error for the FAULT pin                                                                                                                                                                                                                                                 | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M_DPM           | 10   | Masks the DPM error for the $\overline{FAULT}$ pin                                                                                                                                                                                                                                                    | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M_COMF          | 9    | Masks the COMF error for the FAULT pin                                                                                                                                                                                                                                                                | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M_UVM           | 8    | Masks the UVM detection for the FAULT pin                                                                                                                                                                                                                                                             | 0x0: Unmask detection for FAULT pin<br>0x1: Mask detection for FAULT pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CNTL_POL        | 7    | Polarity of control pins                                                                                                                                                                                                                                                                              | 0x0: Control pins are active-high<br>0x1: Control pins are active-low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| STAT_POL        | 6    | Configures polarity of status pins                                                                                                                                                                                                                                                                    | 0x0: Pin is active-high<br>0x1: Pin is active-low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| VDRnVDRD<br>UTY | 4    | When set Logic High, L2H, DC_H, and DC_L<br>registers for each channel indicate a voltage<br>level in voltage mode.<br>When set Logic Low, L2H, DC_H, and DC_L<br>registers for each channel indicate a duty<br>cycle in voltage mode.<br>This bit does not have any effect in current<br>mode (CDR). | 0x0: Compensation of $V_M$ is turned off 0x1: Compensation of $V_M$ is turned on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CHS             | 3:0  | Hardware Configuration Settings.<br>See <u>Table 1</u> , <u>Table 2</u> , and <u>Table 3</u> for more<br>information.                                                                                                                                                                                 | 0x0: Four individual half-bridges. Either connected to $V_M$ or to GND<br>0x1: Three half-bridges in parallel. One half-bridge independent<br>0x2: Two half-bridges in parallel. Two half-bridges independent<br>0x3: Two half-bridges in parallel. Two half-bridges independent<br>0x3: Two half-bridges in parallel. Two half-bridges independent<br>0x4: Four half-bridges in parallel<br>0x5: Two independent full bridges<br>0x6: One independent full bridge. Two independent<br>half bridges<br>0x7: One independent full bridge. Two half-bridges in parallel<br>0x8: One parallel full-bridge |

### **STATUS (0x02)**

| BIT            | 15  | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
|----------------|-----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Field          | -   | STT3      | STT2      | STT1      | STT0      | MIN_T_ON  | RES       | IND       |
| Reset          | -   |           |           |           |           |           |           |           |
| Access<br>Type | -   | Read Only |
| BIT            | 7   | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| Field          | OVT | OCP       | OLF       | HHF       | DPM       | COMER     | UVM       | RFU       |
| Reset          |     |           |           |           |           |           |           |           |
|                |     |           |           |           |           |           |           |           |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD | BITS | DESCRIPTION                                                                   | DECODE                                                                             |
|----------|------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| STT3     | 14   | Status bit<br>See <u>Table 9</u>                                              |                                                                                    |
| STT2     | 13   | Status bit<br>See <u>Table 9</u>                                              |                                                                                    |
| STT1     | 12   | Status bit<br>See <u>Table 9</u>                                              |                                                                                    |
| STT0     | 11   | Status bit<br>See <u>Table 9</u>                                              |                                                                                    |
| MIN_T_ON | 10   | Read-Only Status bit. All channels combined.                                  | 0x0: MIN_T_ON is compliant<br>0x1: MIN_T_ON is not compliant                       |
| RES      | 9    | Read-Only bit of resistance measurement. All channels combined.               | 0x0: Measured resistance is compliant<br>0x1: Measured resistance is not compliant |
| IND      | 8    | Read-Only bit of inductance measurement.<br>All channels combined.            | 0x0: Measured inductance is compliant<br>0x1: Measured inductance is not compliant |
| OVT      | 7    | Read-Only bit of overtemperature measurement.                                 | 0x0: No over temperature detected<br>0x1: Over temperature detected                |
| OCP      | 6    | Read-Only bit of overcurrent protection. All channels combined.               | 0x0: No overcurrent detected<br>0x1: Overcurrent detected                          |
| OLF      | 5    | Read-Only bit of open-load detection. All channels combined.                  | 0x0: No open-loop detected<br>0x1: Open-loop detected                              |
| HHF      | 4    | Read-Only bit of hit current not reached function. All channels combined.     | 0x0: Hit current is reached<br>0x1: Hit current is not reached                     |
| DPM      | 3    | Read-Only bit of detection of plunger movement status. All channels combined. | 0x0: Plunger moved<br>0x1: Plunger did not move                                    |
| COMER    | 2    | Read-Only bit of detection of SPI communication error.                        | 0x0: No communication error detected<br>0x1: Communication error detected          |
| UVM      | 1    | Read-Only bit of detection of under voltage status.                           | 0x0: No undervoltage detected<br>0x1: Undervoltage detected                        |
| RFU      | 0    | Reserved for future use                                                       |                                                                                    |

#### STATUS\_CFG (0x03)

| BIT            | 15        | 14                                   | 13                                              | 12          |      | 11           | 10                             | 9             | 8         |
|----------------|-----------|--------------------------------------|-------------------------------------------------|-------------|------|--------------|--------------------------------|---------------|-----------|
| Field          | -         | _                                    | _                                               | _           |      | -            | _                              | M_UVM_C<br>MP | V5_nV3    |
| Reset          | _         | _                                    | _                                               | -           |      | -            | _                              |               |           |
| Access<br>Type | _         | _                                    | -                                               | -           |      | _            | -                              | Write, Read   | Read Only |
| BIT            | 7         | 6                                    | 5                                               | 4           |      | 3            | 2                              | 1             | 0         |
| Field          | EN_LDO    | STRETCH_EN[1:0] STAT_SEL STAT_SEL ST |                                                 |             |      | STAT_FUN[2:0 | ]                              |               |           |
| Reset          |           |                                      |                                                 |             |      |              |                                |               |           |
| Access<br>Type | Read Only | Write,                               | Read                                            | Write, Read | Writ | e, Read      |                                | Write, Read   |           |
| BITFIELD       | BITS      |                                      | DESCRIPT                                        | ION         |      |              | D                              | ECODE         |           |
| M_UVM_CM<br>P  | 9         | Mask stretch<br>FAULT pin            | Mask stretched UVM information on the FAULT pin |             |      |              | mask UVM to F<br>sk UVM to FAI | -             |           |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD       | BITS | DESCRIPTION                                                                           | DECODE                                                                                                                                                                                                                                                                                   |
|----------------|------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V5_nV3         | 8    | Internal LDO voltage                                                                  | 0x0: 3.3V<br>0x1: 5V                                                                                                                                                                                                                                                                     |
| EN_LDO         | 7    | Enable of the internal LDO on $V_{IO}$ pin                                            | 0x0: Disable internal LDO on V <sub>IO</sub><br>0x1: Enable internal LDO on V <sub>IO</sub>                                                                                                                                                                                              |
| STRETCH_E<br>N | 6:5  | Stretch the fault indicator pin duration for UVM and OVT faults. See <u>Table 9</u> . | 0x0: No stretch<br>0x1: 1s<br>0x2: 2s<br>0x3: 3s                                                                                                                                                                                                                                         |
| STAT_SEL1      | 4    | Used to select the channel that drives the status pins. See <u>Table 8</u> .          | 0x0: Use STAT2 bit of STATUS register to drive<br>STAT1 pin<br>0x1: Use STAT3 bit of STATUS register to drive<br>STAT1 pin                                                                                                                                                               |
| STAT_SEL0      | 3    | Used to select the channel that drives the status pins. See <u>Table 8</u> .          | 0x0: Use STAT0 bit of STATUS register to drive<br>STAT0 pin<br>0x1: Use STAT1 bit of STATUS register to drive<br>STAT0 pin                                                                                                                                                               |
| STAT_FUN       | 2:0  | Configuration of the value that drives the status pins. See <u>Table 9</u> .          | 0x0: Status detection based on inductance<br>measurement<br>0x1: PWM monitor<br>0x2: Status detection based on resistance<br>measurement<br>0x3: Status detection based on DPM<br>0x4: Status detection based on VM detection<br>0x5: Status detection based on I_MONITOR<br>measurement |

### DC\_H2L (0x04)

| BIT            | 15 | 14            | 13                                        | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 11       | 10        | 9 | 8   |  |  |  |  |  |
|----------------|----|---------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|---|-----|--|--|--|--|--|
| Field          |    | l             | 1                                         | DC_H2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2L[15:8] |           |   | - 1 |  |  |  |  |  |
| Reset          |    |               |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| Access<br>Type |    | Write, Read   |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| BIT            | 7  | 6 5 4 3 2 1 0 |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| Field          |    | DC_H2L[7:0]   |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| Reset          |    |               |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| Access<br>Type |    | Write, Read   |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |           |   |     |  |  |  |  |  |
| BITFIE         | LD | BITS          |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DE       | SCRIPTION |   |     |  |  |  |  |  |
| DC_H2L         |    | 15:0          | Used<br>tied-<br>VDR<br>DC_<br>VOU<br>DC_ | Demagnetization Voltage Setting (Global)         Used to configure the demagnetization voltage of high to low time in britied-load configurations if the H2L_EN bit is set. Depending on the VDR_nDUTY bit, it either configures a voltage or a duty cycle.         DC_H2L indicates a Voltage if VDRnVDRDUTY = "1". The voltage value VOUT (V) = K <sub>VDR</sub> x 36 x DC_H2L [15:0] <sub>DEC</sub> .         DC_H2L indicates a Duty Cycle if VDRnVDRDUTY = "0". The voltage value VOUT (V) = K <sub>VDR</sub> x VM x DC_H2L [15:0] <sub>DEC</sub> . |          |           |   |     |  |  |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### VM\_MONITOR (0x05)

| BIT            | 15 | 14   | 13 | 12                                                   | 11               | 10         | 9 | 8 |  |  |  |
|----------------|----|------|----|------------------------------------------------------|------------------|------------|---|---|--|--|--|
| Field          | -  | -    | _  |                                                      | VM_MONITOR[12:8] |            |   |   |  |  |  |
| Reset          | -  | -    | _  |                                                      |                  |            |   |   |  |  |  |
| Access<br>Type | -  | _    | _  |                                                      | Read Only        |            |   |   |  |  |  |
| BIT            | 7  | 6    | 5  | 4                                                    | 3                | 2          | 1 | 0 |  |  |  |
| Field          |    |      |    | VM_MON                                               | IITOR[7:0]       |            |   |   |  |  |  |
| Reset          |    |      |    |                                                      |                  |            |   |   |  |  |  |
| Access<br>Type |    |      |    | Read                                                 | Read Only        |            |   |   |  |  |  |
| BITFIE         | LD | BITS |    |                                                      | DI               | ESCRIPTION |   |   |  |  |  |
| VM_MONITO      | R  | 12:0 | VN | Measurement: VM = K <sub>VM</sub> x VM_MONITOR[15:0] |                  |            |   |   |  |  |  |

#### VM\_THRESHOLD (0x06)

| BIT            | 15   | 14                        | 13                         | 12               | 11                                                                                                                                                                                     | 10                                                                              | 9         | 8 |  |  |
|----------------|------|---------------------------|----------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------|---|--|--|
| Field          | _    | _                         | _                          | -                | _                                                                                                                                                                                      | -                                                                               | -         | _ |  |  |
| Reset          | -    | _                         | -                          | -                | -                                                                                                                                                                                      | -                                                                               | -         | - |  |  |
| Access<br>Type | _    | -                         | -                          | _                | _                                                                                                                                                                                      | _                                                                               | _         | - |  |  |
| BIT            | 7    | 6                         | 5                          | 4                | 3                                                                                                                                                                                      | 2                                                                               | 1         | 0 |  |  |
| Field          |      | VM_THL                    | D_UP[3:0]                  |                  |                                                                                                                                                                                        | VM_THLD_                                                                        | DOWN[3:0] |   |  |  |
| Reset          |      |                           |                            |                  |                                                                                                                                                                                        |                                                                                 |           |   |  |  |
| Access<br>Type |      | Write,                    | Read                       |                  |                                                                                                                                                                                        | Write, Read                                                                     |           |   |  |  |
| BITFIELD       | BITS |                           | DESCRIPT                   | ION              |                                                                                                                                                                                        | D                                                                               | ECODE     |   |  |  |
| VM_THLD_U<br>P | 7:4  | Rising Edge<br>4.5V-32.5V | VM Threshold<br>n 2V steps | l (from 1 to 15) | 0x0: Dis<br>0x1: 4.5<br>0x2: 6.5<br>0x3: 8.5<br>0x4: 10.<br>0x5: 12.<br>0x6: 14.<br>0x7: 16.<br>0x8: 18.<br>0x9: 20.<br>0xA: 22<br>0xB: 24<br>0xC: 26<br>0xD: 28<br>0xE: 30<br>0xF: 32 | 5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5V<br>5 |           |   |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD         | BITS | DESCRIPTION                                                       | DECODE                                                                                                                                                                                                                       |
|------------------|------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VM_THLD_D<br>OWN | 3:0  | Falling Edge VM Threshold (from 1 to 15)<br>4.3-32.3V in 2V steps | 0x0: Disabled<br>0x1: 4.3V<br>0x2: 6.3V<br>0x3: 8.3V<br>0x4: 10.3V<br>0x5: 12.3V<br>0x6: 14.3V<br>0x7: 16.3V<br>0x8: 18.3V<br>0x9: 20.3V<br>0x8: 22.3V<br>0x8: 24.3V<br>0xC: 26.3V<br>0xC: 26.3V<br>0xC: 30.3V<br>0xF: 32.3V |

### F\_AC (0x07)

| BIT            | 15 | 14   | 13 | 12                                                                                                                                                                     | 11              | 10        | 9 | 8 |  |  |
|----------------|----|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|---|---|--|--|
| Field          | -  | -    | -  | _                                                                                                                                                                      | F_AC_SCAN[11:8] |           |   |   |  |  |
| Reset          | -  | -    | -  | _                                                                                                                                                                      |                 |           |   |   |  |  |
| Access<br>Type | -  | -    | -  | -                                                                                                                                                                      | Write, Read     |           |   |   |  |  |
| BIT            | 7  | 6    | 5  | 4                                                                                                                                                                      | 3 2 1 0         |           |   |   |  |  |
| Field          |    |      |    | F_AC_SCAN[7:0]                                                                                                                                                         |                 |           |   |   |  |  |
| Reset          |    |      |    |                                                                                                                                                                        |                 |           |   |   |  |  |
| Access<br>Type |    |      |    | Write                                                                                                                                                                  | , Read          |           |   |   |  |  |
| BITFIE         | LD | BITS |    |                                                                                                                                                                        | DE              | SCRIPTION |   |   |  |  |
| F_AC_SCAN 11:0 |    |      | i  | Defines the carrier frequency that is used for the AC scan signal of the inductance measurement:<br>F_AC (Hz) = F_PWM_M (Hz) * (F_AC_SCAN[11:0] <sub>DEC</sub> /65535) |                 |           |   |   |  |  |

### U\_AC\_SCAN (0x08)

| BIT            | 15 | 14            | 13              | 12     | 11       | 10 | 9 | 8 |  |  |  |  |
|----------------|----|---------------|-----------------|--------|----------|----|---|---|--|--|--|--|
| Field          | -  |               | U_AC_SCAN[14:8] |        |          |    |   |   |  |  |  |  |
| Reset          | -  |               |                 |        |          |    |   |   |  |  |  |  |
| Access<br>Type | _  | - Write, Read |                 |        |          |    |   |   |  |  |  |  |
| BIT            | 7  | 6             | 6 5 4 3 2 1 0   |        |          |    |   |   |  |  |  |  |
| Field          |    |               |                 | U_AC_S | CAN[7:0] |    |   |   |  |  |  |  |
| Reset          |    |               |                 |        |          |    |   |   |  |  |  |  |
| Access<br>Type |    | Write, Read   |                 |        |          |    |   |   |  |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD  | BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                  |
|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| U_AC_SCAN | 14:0 | Defines the amplitude of the AC signal used for the inductance measurement<br>or for dithering.<br>VDR: VAC(V) = $K_{VDR} \times 36 \times U_AC\_SCAN[14:0]_{DEC}$<br>VDRDUTY: VAC (V) = $K_{VDR} \times VM \times U_AC\_SCAN[14:0]_{DEC}$<br>CDR Mode: IAC (mA) = $K_{CDR} \times GAIN \times SNSF \times U_AC[14:0]_{DEC}$ |

### CFG\_DC\_L2H (0x09, 0x17, 0x25, 0x33)

| BIT                    | 15 | 14              | 13 | 13 12 11 10 9 8                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
|------------------------|----|-----------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|--|--|--|--|--|--|--|
| Field                  |    |                 | •  | DC_L2                                                                                                                                                                                                                                        | H[15:8] |           |  |  |  |  |  |  |  |
| Reset                  |    |                 |    |                                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
| Access<br>Type         |    | Write, Read     |    |                                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
| BIT                    | 7  | 7 6 5 4 3 2 1 0 |    |                                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
| Field                  |    | DC_L2H[7:0]     |    |                                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
| Reset                  |    |                 |    |                                                                                                                                                                                                                                              |         |           |  |  |  |  |  |  |  |
| Access<br>Type         |    |                 |    | Write                                                                                                                                                                                                                                        | Read    |           |  |  |  |  |  |  |  |
| BITFIE                 | LD | BITS            |    |                                                                                                                                                                                                                                              | DE      | SCRIPTION |  |  |  |  |  |  |  |
| DC_L2H 15:0 VDR<br>VDR |    |                 |    | Sets the DC_L2H level:<br>VDR: VOUT (V) = $K_{VDR} \times 36 \times DC_L2H[15:0]_{DEC}$<br>VDRDUTY: VOUT (V) = $K_{VDR} \times VM \times DC_L2H[15:0]_{DEC}$<br>CDR: IOUT (mA) = $K_{CDR} \times GAIN \times SNSF \times DC_L2H[15:0]_{DEC}$ |         |           |  |  |  |  |  |  |  |

### CFG\_DC\_H (0x18, 0x26, 0x34, 0xA)

| BIT            | 15 | 14              | 13 | 12                                                                                                                                                                                                                                   | 11      | 10        | 9 | 8 |  |  |  |  |  |
|----------------|----|-----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|---|---|--|--|--|--|--|
| Field          |    | •               |    | DC_H                                                                                                                                                                                                                                 | l[15:8] |           |   |   |  |  |  |  |  |
| Reset          |    |                 |    |                                                                                                                                                                                                                                      |         |           |   |   |  |  |  |  |  |
| Access<br>Type |    | Write, Read     |    |                                                                                                                                                                                                                                      |         |           |   |   |  |  |  |  |  |
| BIT            | 7  | 7 6 5 4 3 2 1 0 |    |                                                                                                                                                                                                                                      |         |           |   |   |  |  |  |  |  |
| Field          |    | DC_H[7:0]       |    |                                                                                                                                                                                                                                      |         |           |   |   |  |  |  |  |  |
| Reset          |    |                 |    |                                                                                                                                                                                                                                      |         |           |   |   |  |  |  |  |  |
| Access<br>Type |    |                 |    | Write                                                                                                                                                                                                                                | , Read  |           |   |   |  |  |  |  |  |
| BITFIE         | LD | BITS            |    |                                                                                                                                                                                                                                      | DE      | SCRIPTION |   |   |  |  |  |  |  |
| DC_H 15:0      |    |                 |    | Sets the DC_H level:<br>VDR: VOUT (V) = $K_{VDR} \times 36 \times DC_H[15:0]_{DEC}$<br>VDRDUTY: VOUT (V) = $K_{VDR} \times VM \times DC_H[15:0]_{DEC}$<br>CDR: IOUT (mA) = $K_{CDR} \times GAIN \times SNSF \times DC_H[15:0]_{DEC}$ |         |           |   |   |  |  |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### CFG\_DC\_L (0x19, 0x27, 0x35, 0xB)

| BIT            | 15 | 14              | 13         | 12                                                                                                                                                                                                                                         | 11     | 10         | 9 | 8        |  |  |  |  |  |  |
|----------------|----|-----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|---|----------|--|--|--|--|--|--|
| Field          |    |                 |            | DC_L                                                                                                                                                                                                                                       | [15:8] |            |   |          |  |  |  |  |  |  |
| Reset          |    |                 |            |                                                                                                                                                                                                                                            |        |            |   |          |  |  |  |  |  |  |
| Access<br>Type |    | Write, Read     |            |                                                                                                                                                                                                                                            |        |            |   |          |  |  |  |  |  |  |
| BIT            | 7  | 7 6 5 4 3 2 1 0 |            |                                                                                                                                                                                                                                            |        |            |   |          |  |  |  |  |  |  |
| Field          |    | DC_L[7:0]       |            |                                                                                                                                                                                                                                            |        |            |   |          |  |  |  |  |  |  |
| Reset          |    |                 |            |                                                                                                                                                                                                                                            |        |            |   |          |  |  |  |  |  |  |
| Access<br>Type |    |                 |            | Write,                                                                                                                                                                                                                                     | Read   |            |   |          |  |  |  |  |  |  |
| BITFIE         | LD | BITS            |            |                                                                                                                                                                                                                                            | DI     | ESCRIPTION |   | <u> </u> |  |  |  |  |  |  |
| DC_L           |    | 15:0            | VDR<br>VDR | Sets the DC_L level:<br>VDR: VOUT (V) = $K_{VDR} \times 36 \times DC_L2H[15:0]_{DEC}$<br>VDRDUTY: VOUT (V) = $K_{VDR} \times VM \times DC_L2H[15:0]_{DEC}$<br>CDR: IOUT (mA) = $K_{CDR} \times GAIN \times SNSF \times DC_L2H[15:0]_{DEC}$ |        |            |   |          |  |  |  |  |  |  |

#### CFG\_L2H\_TIME (0x1A, 0x28, 0x36, 0xC)

| BIT            | 15                                                                          | 14 | 13 | 12     | 11       | 10 | 9 | 8 |  |  |  |
|----------------|-----------------------------------------------------------------------------|----|----|--------|----------|----|---|---|--|--|--|
| Field          |                                                                             | ÷  |    | TIME_L | 2H[15:8] |    | • |   |  |  |  |
| Reset          |                                                                             |    |    |        |          |    |   |   |  |  |  |
| Access<br>Type | Write, Read                                                                 |    |    |        |          |    |   |   |  |  |  |
| BIT            | 7                                                                           | 6  | 5  | 4      | 3        | 2  | 1 | 0 |  |  |  |
| Field          |                                                                             | ·  |    | TIME_I | 2H[7:0]  | ·  | • |   |  |  |  |
| Reset          |                                                                             |    |    |        |          |    |   |   |  |  |  |
| Access<br>Type | Write, Read                                                                 |    |    |        |          |    |   |   |  |  |  |
| BITFIE         | TFIELD BITS DESCRIPTION                                                     |    |    |        |          |    |   |   |  |  |  |
| TIME_L2H       | H 15:0 Sets the TIME_L2H<br>TIME_L2H = TIME_L2H[15:0] <sub>DEC</sub> /F_PWM |    |    |        |          |    |   |   |  |  |  |

### CFG\_CTRL0 (0x1B, 0x29, 0x37, 0xD)

| BIT            | 15             | 14 | 13          | 12          | 11          | 10          | 9           | 8           |
|----------------|----------------|----|-------------|-------------|-------------|-------------|-------------|-------------|
| Field          | CTRL_MODE[1:0] |    | HHF_EN      | OL_EN       | H2L_EN      | RDWE        | RMDE        | RUPE        |
| Reset          |                |    |             |             |             |             |             |             |
| Access<br>Type | Write, Read    |    | Write, Read |
| BIT            | 7              | 6  | 5           | 4           | 3           | 2           | 1           | 0           |
| Field          |                |    |             | RAM         | P[7:0]      |             | 1           |             |
| Reset          |                |    |             |             |             |             |             |             |
| Access<br>Type |                |    |             | Write,      | Read        |             |             |             |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD      | BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                         | DECODE                                                                                              |
|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| CTRL_MOD<br>E | 15:14 | CTRL_MODE defines the control scheme for<br>DC_L2H and DC_H.<br><u>Table 8</u> shows that VDR stands for VDR or<br>VDRDUTY Mode, depending on the<br>VDR_nDUTY bit.                                                                                                                                                                                                                                                                                 | 0x0: VOLT<br>0x1: CDR<br>0x2: Limiter/VOLT<br>0x3: VOLT (during L2H) and CDR(during H)              |
| HHF_EN        | 13    | Current not reached Fault detection                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0: Disable current not reached fault detection<br>0x1: Enable current not reached fault detection |
| OL_EN         | 12    | Open Load Circuit Enable (enable pullup/dw)                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0: Open-load detection disabled<br>0x1: Open-load detection disabled                              |
| H2L_EN        | 11    | H2L Fast Demagnetization Enable bit. "1"<br>enforces DC_H2L after CNTL H2L transition<br>(For Bridge Operation only).                                                                                                                                                                                                                                                                                                                               | 0x0: Disable fast demagnetization<br>0x1: Enable fast demagnetization                               |
| RDWE          | 10    | Ramp Down Enable bit                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0: Disable ramp down<br>0x1: Enable ramp down                                                     |
| RMDE          | 9     | Ramp Mid Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0: Disable mid ramp<br>0x1: Enable mid ramp                                                       |
| RUPE          | 8     | Ramp UP enable                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0: Disable ramp up<br>0x1: Enable ramp up                                                         |
| RAMP          | 7:0   | $\label{eq:response} \begin{array}{l} RAMP[7:0] \mbox{ Sets the Ramp Slew Rate.} \\ \textbf{VDRDUTY:} \\ Ramp Slew Rate (V/ms) = K_{VDR x VM x} \\ (RAMP[7:0]_{DEC} + 1) x \mbox{ F_PWM (kHz)}) \\ \textbf{VDR:} \\ Ramp Slew Rate (V/ms) = K_{VDR x 36 x} \\ (RAMP[7:0]_{DEC} + 1) x \mbox{ F_PWM (kHz)} \\ \textbf{CDR:} \\ Ramp Slew Rate (mA/ms) = K_{CDR x \mbox{ GAIN } x} \\ SNSF x (RAMP[7:0]_{DEC} + 1) x \mbox{ F_PWM (kHz)} \end{array}$ |                                                                                                     |

### CFG\_CTRL1 (0x1C, 0x2A, 0x38, 0xE)

| BIT            | 15     | 14                                               | 13                     | 12               | 11               | 10                                                                 | 9           | 8      |  |
|----------------|--------|--------------------------------------------------|------------------------|------------------|------------------|--------------------------------------------------------------------|-------------|--------|--|
| Field          | _      | -                                                | -                      | -                | _                | HSnLS                                                              | F_PW        | M[1:0] |  |
| Reset          | —      | -                                                | -                      | -                | -                |                                                                    |             |        |  |
| Access<br>Type | _      | _                                                | _                      | _                | -                | Write, Read                                                        | Write, Read |        |  |
| BIT            | 7      | 6                                                | 5                      | 4                | 3                | 2                                                                  | 1           | 0      |  |
| Field          | T_BLAN | KING[1:0]                                        | NG[1:0] SLEW_RATE[1:0] |                  |                  | N[1:0]                                                             | SNSF[1:0]   |        |  |
| Reset          |        |                                                  |                        |                  |                  |                                                                    |             |        |  |
| Access<br>Type | Write, | Read                                             | Write,                 | Read             | Write            | , Read                                                             | Write,      | Read   |  |
| BITFIELD       | BITS   |                                                  | DESCRIPT               | ION              |                  | DECODE                                                             |             |        |  |
| HSnLS          | 10     | HS/LS: Bit S                                     | Single-Ended M         | lode Only        |                  | 0x0: Low-side driver<br>0x1: High-side driver                      |             |        |  |
| F_PWM          | 9:8    | Defines the<br>the channel<br>See <u>Table 5</u> |                        | y that is used f | 0x1: F<br>0x2: F | 0x0: F_PWM_M<br>0x1: F_PWM_M/2<br>0x2: F_PWM_M/4<br>0x3: F_PWM_M/8 |             |        |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD       | BITS | DESCRIPTION                                                                          | DECODE                                                       |
|----------------|------|--------------------------------------------------------------------------------------|--------------------------------------------------------------|
| T_BLANKIN<br>G | 7:6  | Defines an additional blanking time for the current measurement in single-ended mode | 0x0: 0<br>0x1: 24<br>0x2: 48<br>0x3: 96                      |
| SLEW_RATE      | 5:4  | SRC[1:0]: Slew-rate control bits. ("10", "11"<br>inhibited for F_PWM > 50kHz)        | 0x0: Fast<br>0x1: 400V/μs<br>0x2: 200V/μs<br>0x3: 100V/μs    |
| GAIN           | 3:2  | Sets a digital GAIN for the Current Driver Regulation (CDR)                          | 0x0: Scale 1<br>0x1: Scale 2<br>0x2: Scale 3<br>0x3: Scale 4 |
| SNSF           | 1:0  | Sets the Sense Scaling Factor                                                        | 0x0: Full scale<br>0x1: 2/3<br>0x2: 1/3                      |

#### CFG\_DPM0 (0x1D, 0x2B, 0x39, 0xF)

| BIT            | 15 | 14   | 13            | 12                                                                                                                                                           | 11          | 10        | 9         | 8 |  |
|----------------|----|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|-----------|---|--|
| Field          | -  | _    | -             | -                                                                                                                                                            |             | DPM_TH    | ILD[11:8] |   |  |
| Reset          | _  | -    | _             | -                                                                                                                                                            |             |           |           |   |  |
| Access<br>Type | _  | -    | -             | -                                                                                                                                                            | Write, Read |           |           |   |  |
| BIT            | 7  | 6    | 5             | 4                                                                                                                                                            | 3           | 2         | 1         | 0 |  |
| Field          |    |      | DPM_THLD[7:0] |                                                                                                                                                              |             |           |           |   |  |
| Reset          |    |      |               |                                                                                                                                                              |             |           |           |   |  |
| Access<br>Type |    |      |               | Write                                                                                                                                                        | , Read      |           |           |   |  |
| BITFIE         | LD | BITS |               |                                                                                                                                                              | DE          | SCRIPTION |           |   |  |
| DPM_THLD 11:0  |    |      | F             | DPM Fault Threshold:<br>Fault is detected if the BEMF dip of the current is less than DPM_THLD(mA)<br>= 8 x K <sub>CDR</sub> x GAIN x SNSF x DPM_THLD[11:0]. |             |           |           |   |  |

### CFG\_DPM1 (0x10, 0x1E, 0x2C, 0x3A)

| BIT            | 15 | 14          | 13                          | 12               | 11          | 10      | 9         | 8 |  |
|----------------|----|-------------|-----------------------------|------------------|-------------|---------|-----------|---|--|
| Field          | _  | DPM_EN      | END_HIT_T<br>O_HIZ_AUT<br>O | END_HIT_A<br>UTO |             | DPM_MIN | _NBR[3:0] |   |  |
| Reset          | -  |             |                             |                  |             |         |           |   |  |
| Access<br>Type | -  | Write, Read | Write, Read                 | Write, Read      | Write, Read |         |           |   |  |
| BIT            | 7  | 6           | 5                           | 4                | 3           | 2       | 1         | 0 |  |
| Field          |    |             |                             | DPM_ST           | ART[7:0]    |         |           |   |  |
| Reset          |    |             |                             |                  |             |         |           |   |  |
| Access<br>Type |    |             |                             | Write,           | Read        |         |           |   |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD                    | BITS | DESCRIPTION                                                                                                                                                                           | DECODE                                                                                  |
|-----------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| DPM_EN                      | 14   | DPM enable bit                                                                                                                                                                        | 0x0: DPM disabled<br>0x1: DPM enabled                                                   |
| END_HIT_T<br>O_HIZ_AUT<br>O | 13   | Enable automatic DC_L2H to HiZ switchover                                                                                                                                             | 0x0: Automatic end of hit time is disabled<br>0x1: Automatic end of hit time is enabled |
| END_HIT_A<br>UTO            | 12   | Enable Automatic DC_L2H to DH_H switchover                                                                                                                                            | 0x0: Automatic end of hit time is disabled<br>0x1: Automatic end of hit time is enabled |
| DPM_MIN_N<br>BR             | 11:8 | In order to detect a valid BEMF dip, the<br>condition has to be fulfilled for at least<br>DPM_MIN_NBR*2 consecutive PWM cycles.<br>DPM_DEGLITCH = 2 x<br>DPM_MIN_NBR[3:0]DEC x 1/FPWM |                                                                                         |
| DPM_START                   | 7:0  | The detection starts once the actual current<br>has succeeded DPM_START(mA) = 64 x<br>KCDR x GAIN x SNSF x<br>DPM_START[7:0]DEC                                                       |                                                                                         |

### <u>CFG\_IDC\_THLD (0x11, 0x1F, 0x2D, 0x3B)</u>

| BIT            | 15                                                                                                                        | 14            | 13 | 3           | 12     | 11       | 10     | 9 | 8 |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------|---------------|----|-------------|--------|----------|--------|---|---|--|
| Field          |                                                                                                                           |               |    |             | IDC_TH | LD[15:8] |        |   |   |  |
| Reset          |                                                                                                                           |               |    |             |        |          |        |   |   |  |
| Access<br>Type |                                                                                                                           | Write, Read   |    |             |        |          |        |   |   |  |
| BIT            | 7                                                                                                                         | 6             | 5  |             | 4      | 3        | 2      | 1 | 0 |  |
| Field          |                                                                                                                           | IDC_THLD[7:0] |    |             |        |          |        |   |   |  |
| Reset          |                                                                                                                           |               |    |             |        |          |        |   |   |  |
| Access<br>Type |                                                                                                                           |               |    |             | Write, | Read     |        |   |   |  |
| BITFIEI        | D                                                                                                                         | BITS          |    | DESCRIPTION |        |          |        |   |   |  |
| IDC_THLD       | 15:0 IDC_THLD thresholds IDC for mapping to status output STAT. IDC_THLD<br>(mA) = KCDR x GAIN x SNSF x IDC_THLD[15:0]DEC |               |    |             |        |          | C_THLD |   |   |  |

### CFG\_R\_THLD (0x12, 0x20, 0x2E, 0x3C)

| BIT            | 15          | 14             | 13 | 12     | 11       | 10 | 9 | 8 |  |  |  |
|----------------|-------------|----------------|----|--------|----------|----|---|---|--|--|--|
| Field          |             | RES_THLD[15:8] |    |        |          |    |   |   |  |  |  |
| Reset          |             |                |    |        |          |    |   |   |  |  |  |
| Access<br>Type | Write, Read |                |    |        |          |    |   |   |  |  |  |
| BIT            | 7           | 6              | 5  | 4      | 3        | 2  | 1 | 0 |  |  |  |
| Field          |             |                |    | RES_TH | ILD[7:0] | •  |   |   |  |  |  |
| Reset          |             |                |    |        |          |    |   |   |  |  |  |
| Access<br>Type |             | Write, Read    |    |        |          |    |   |   |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD | BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                         |
|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RES_THLD | 15:0 | $\label{eq:constraint} \begin{array}{l} \mbox{Threshold of measured resistance that triggers the corresponding RES bits of the FAULT register or for mapping to status output STAT. \\ \hline \mbox{RES_THLD}(m\Omega) = \mbox{RES_THLD}[15:0] \ \mbox{x} \ (\ \mbox{K}_R/(\mbox{SNSF} * \mbox{GAIN})) \end{array}$ |

## CFG\_IND\_0 (0x13, 0x21, 0x2F, 0x3D)

| BIT                | 15   | 14                                            | 13                                                                                                                                                                         | 12                               | 11          |                                                                             | 10                                | 9              | 8           |  |
|--------------------|------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------|-----------------------------------------------------------------------------|-----------------------------------|----------------|-------------|--|
| Field              | _    | _                                             | _                                                                                                                                                                          | _                                | DITH_       | _EN                                                                         | L_MEAS_E<br>N                     | L_MEAS_L<br>2H | L_MEAS_H    |  |
| Reset              | _    | -                                             | _                                                                                                                                                                          | -                                |             |                                                                             |                                   |                |             |  |
| Access<br>Type     | -    | _                                             | -                                                                                                                                                                          | -                                | Write, Read |                                                                             | Write, Read                       | Write, Read    | Write, Read |  |
| BIT                | 7    | 6                                             | 5                                                                                                                                                                          | 4                                | 3           |                                                                             | 2                                 | 1              | 0           |  |
| Field              |      | L_MEAS_W                                      | CYCLES[3:0]                                                                                                                                                                |                                  |             |                                                                             | L_NBR_C                           | CALC[3:0]      |             |  |
| Reset              |      |                                               |                                                                                                                                                                            |                                  |             |                                                                             |                                   |                |             |  |
| Access<br>Type     |      | Write, Read                                   |                                                                                                                                                                            |                                  |             |                                                                             | Write, Read                       |                |             |  |
| BITFIELD           | BITS |                                               | DESCRIPTION                                                                                                                                                                |                                  |             |                                                                             | DI                                | ECODE          |             |  |
| DITH_EN            | 11   | Used to ena                                   | Used to enable dithering function.                                                                                                                                         |                                  |             |                                                                             | nering disabled<br>nering enabled |                |             |  |
| L_MEAS_EN          | 10   |                                               |                                                                                                                                                                            | osed onto DC_L<br>rement is enab |             | 0x0: Inductance measurement disabled<br>0x1: Inductance measurement enabled |                                   |                |             |  |
| L_MEAS_L2<br>H     | 9    |                                               | ble inductance<br>excitation time.                                                                                                                                         | measurement                      | -           | 0x0: Disabled during excitation time<br>0x1: Enabled during excitation time |                                   |                |             |  |
| L_MEAS_H           | 8    | Used to ena during hold t                     |                                                                                                                                                                            | measurement                      |             | 0x0: Disabled during hold time<br>0x1: Enabled during hold time             |                                   |                |             |  |
| L_MEAS_W<br>CYCLES | 7:4  | starting from<br>which the in-<br>skipped bec | Number of AC scan periods (Tscan/1/F_AC) starting from a L2H or H2L transition during which the inductance measurement is skipped because of unreliable measurements.      |                                  |             |                                                                             |                                   |                |             |  |
| L_NBR_CAL<br>C     | 3:0  | the inductan from zero ar                     | Number of AC scan periods used to calculate<br>the inductance. If L_NBR_CALC is different<br>from zero and dithering is not enabled,<br>AC_scan is disabled for L_NBR_CALC |                                  |             |                                                                             |                                   |                |             |  |

#### CFG\_IND\_1 (0x14, 0x22, 0x30, 0x3E)

| BIT            | 15 | 14 | 13 | 12 | 11             | 10 | 9 | 8 |  |
|----------------|----|----|----|----|----------------|----|---|---|--|
| Field          | -  | -  | -  | -  | IAC_THLD[11:8] |    |   |   |  |
| Reset          | _  | _  | _  | -  |                |    |   |   |  |
| Access<br>Type | -  | -  | -  | -  | Write, Read    |    |   |   |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BIT                                                                                                                                                                                              | 7                  | 6           | 5 | 4      | 3        | 2      | 1 | 0 |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------|---|--------|----------|--------|---|---|--|--|--|
| Field                                                                                                                                                                                            |                    |             |   | IAC_TH | ILD[7:0] |        |   |   |  |  |  |
| Reset                                                                                                                                                                                            |                    |             |   |        |          |        |   |   |  |  |  |
| Access<br>Type                                                                                                                                                                                   |                    | Write, Read |   |        |          |        |   |   |  |  |  |
| BITFIEI                                                                                                                                                                                          | D BITS DESCRIPTION |             |   |        |          |        |   |   |  |  |  |
| IAC_TLHD thresholds I_AC for mapping to the status output STAT. If measured I_AC value exceeds this value, the status of the inductance measurement gets set to 1.         IAC_THLD         11:0 |                    |             |   |        |          | ctance |   |   |  |  |  |

### <u>CFG\_P (0x15, 0x23, 0x31, 0x3F)</u>

| BIT            | 15                                                                                                        | 14              | 13 | 12     | 11      | 10 | 9 | 8 |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------|-----------------|----|--------|---------|----|---|---|--|--|--|
| Field          |                                                                                                           |                 |    | CFG_I  | P[15:8] | •  |   |   |  |  |  |
| Reset          |                                                                                                           |                 |    |        |         |    |   |   |  |  |  |
| Access<br>Type |                                                                                                           | Write, Read     |    |        |         |    |   |   |  |  |  |
| BIT            | 7                                                                                                         | 7 6 5 4 3 2 1 0 |    |        |         |    |   |   |  |  |  |
| Field          |                                                                                                           | ·               |    | CFG_   | P[7:0]  | •  |   |   |  |  |  |
| Reset          |                                                                                                           |                 |    |        |         |    |   |   |  |  |  |
| Access<br>Type |                                                                                                           |                 |    | Write, | Read    |    |   |   |  |  |  |
| BITFIE         | D BITS DESCRIPTION                                                                                        |                 |    |        |         |    |   |   |  |  |  |
| CFG_P          | 15:0Set the P parameter of the PI controller. The CFG_P_0 value is interpreted in<br>Q8.8 representation. |                 |    |        |         |    |   |   |  |  |  |

#### CFG\_I (0x16, 0x24, 0x32, 0x40)

| BIT            | 15                                                                                                        | 14          | 13 | 12    | 11      | 10 | 9 | 8 |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------|-------------|----|-------|---------|----|---|---|--|--|--|
| Field          |                                                                                                           |             |    | CFG_  | I[15:8] |    |   |   |  |  |  |
| Reset          |                                                                                                           |             |    |       |         |    |   |   |  |  |  |
| Access<br>Type |                                                                                                           | Write, Read |    |       |         |    |   |   |  |  |  |
| BIT            | 7                                                                                                         | 6           | 5  | 4     | 3       | 2  | 1 | 0 |  |  |  |
| Field          |                                                                                                           | CFG_I[7:0]  |    |       |         |    |   |   |  |  |  |
| Reset          |                                                                                                           |             |    |       |         |    |   |   |  |  |  |
| Access<br>Type |                                                                                                           |             |    | Write | Read    |    |   |   |  |  |  |
| BITFIEI        | D BITS DESCRIPTION                                                                                        |             |    |       |         |    |   |   |  |  |  |
| CFG_I          | 15:0Set the I parameter of the PI controller. The CFG_I_0 value is interpreted in<br>Q8.8 representation. |             |    |       |         |    |   |   |  |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### I\_DPM\_PEAK (0x41, 0x4A, 0x53, 0x5C)

|                |                                                                                                                                         |                    |    |         |            |    |   | 1 |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------|----|---------|------------|----|---|---|--|--|--|--|
| BIT            | 15                                                                                                                                      | 14                 | 13 | 12      | 11         | 10 | 9 | 8 |  |  |  |  |
| Field          |                                                                                                                                         |                    |    | I_DPM_F | PEAK[15:8] |    |   |   |  |  |  |  |
| Reset          |                                                                                                                                         |                    |    |         |            |    |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                         | Read Only          |    |         |            |    |   |   |  |  |  |  |
| BIT            | 7                                                                                                                                       | 6                  | 5  | 4       | 3          | 2  | 1 | 0 |  |  |  |  |
| Field          |                                                                                                                                         | I_DPM_PEAK[7:0]    |    |         |            |    |   |   |  |  |  |  |
| Reset          |                                                                                                                                         |                    |    |         |            |    |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                         |                    |    | Read    | d Only     |    |   |   |  |  |  |  |
| BITFIE         | LD                                                                                                                                      | D BITS DESCRIPTION |    |         |            |    |   |   |  |  |  |  |
| I_DPM_PEAK     | K 15:0 BEMF Current Local Peak during ramp-up.<br>I_DPM_PEAK(mA) = 8 x K <sub>CDR</sub> x GAIN x SNSF x I_DPM_PEAK[11:0] <sub>DEC</sub> |                    |    |         |            |    |   |   |  |  |  |  |

#### I\_DPM\_VALLEY (0x42, 0x4B, 0x54, 0x5D)

| BIT            | 15                                                                                                                                                                      | 14                | 13 | 12       | 11         | 10 | 9 | 8 |  |  |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----|----------|------------|----|---|---|--|--|--|--|
| Field          |                                                                                                                                                                         |                   |    | I_DPM_VA | LLEY[15:8] | -  | - |   |  |  |  |  |
| Reset          |                                                                                                                                                                         |                   |    |          |            |    |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                                                         | Read Only         |    |          |            |    |   |   |  |  |  |  |
| BIT            | 7                                                                                                                                                                       | 6                 | 5  | 4        | 3          | 2  | 1 | 0 |  |  |  |  |
| Field          |                                                                                                                                                                         | I_DPM_VALLEY[7:0] |    |          |            |    |   |   |  |  |  |  |
| Reset          |                                                                                                                                                                         |                   |    |          |            |    |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                                                         |                   |    | Read     | Only       |    |   |   |  |  |  |  |
| BITFIE         | LD                                                                                                                                                                      | BITS DESCRIPTION  |    |          |            |    |   |   |  |  |  |  |
| I_DPM_VALLE    | EY 15:0 BEMF Current Local Valley during ramp-up. VDR or Duty Mode only.<br>I_DPM_VALLEY(mA) = 8 x K <sub>CDR</sub> x GAN x SNSF x<br>I_DPM_VALLEY[11:0] <sub>DEC</sub> |                   |    |          |            |    |   |   |  |  |  |  |

### TRAVEL\_TIME (0x43, 0x4C, 0x55, 0x5E)

| BIT            | 15 | 14                | 13 | 12      | 11        | 10 | 9 | 8 |  |  |
|----------------|----|-------------------|----|---------|-----------|----|---|---|--|--|
| Field          |    | TRAVEL_TIME[15:8] |    |         |           |    |   |   |  |  |
| Reset          |    |                   |    |         |           |    |   |   |  |  |
| Access<br>Type |    | Read Only         |    |         |           |    |   |   |  |  |
| BIT            | 7  | 6                 | 5  | 4       | 3         | 2  | 1 | 0 |  |  |
| Field          |    | 1                 |    | TRAVEL_ | TIME[7:0] |    |   |   |  |  |
| Reset          |    |                   |    |         |           |    |   |   |  |  |
| Access<br>Type |    | Read Only         |    |         |           |    |   |   |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BITFIELD    | BITS | DESCRIPTION                                                                                                                                       |
|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| TRAVEL_TIME | 15:0 | Travel time from local maximum to local minimum detection:<br>TRAVEL_TIME in (ms) = TRAVEL_TIME[15:0] <sub>DEC</sub> / (F_PWM_M (kHz) *<br>F_PWM) |

#### **REACTION\_TIME (0x44, 0x4D, 0x56, 0x5F)**

| BIT            | 15                                                                                                                                                         | 14                 | 13 | 3 | 12       | 11          | 10 | 9 | 8 |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----|---|----------|-------------|----|---|---|--|--|--|
| Field          |                                                                                                                                                            |                    |    |   | REACTION | _TIME[15:8] |    |   | • |  |  |  |
| Reset          |                                                                                                                                                            |                    |    |   |          |             |    |   |   |  |  |  |
| Access<br>Type |                                                                                                                                                            | Read Only          |    |   |          |             |    |   |   |  |  |  |
| BIT            | 7                                                                                                                                                          | 6                  | 5  |   | 4        | 3           | 2  | 1 | 0 |  |  |  |
| Field          |                                                                                                                                                            | REACTION_TIME[7:0] |    |   |          |             |    |   |   |  |  |  |
| Reset          |                                                                                                                                                            |                    |    |   |          |             |    |   |   |  |  |  |
| Access<br>Type |                                                                                                                                                            |                    |    |   | Read     | Only        |    |   |   |  |  |  |
| BITFIE         | LD                                                                                                                                                         | D BITS DESCRIPTION |    |   |          |             |    |   |   |  |  |  |
| REACTION_T     | _TIME 15:0 Reaction time from CNTL L2H to local minimum detection:<br>REACTION_TIME in (ms) = REACTION_TIME[15:0] <sub>DEC</sub> / (F_PWM_M (kHz) * F_PWM) |                    |    |   |          |             |    |   |   |  |  |  |

### I\_MONITOR (0x45, 0x4E, 0x57, 0x60)

| BIT            | 15                                                                                                                                                                                  | 14             | 13 | 12     | 11        | 10        | 9 | 8 |  |  |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----|--------|-----------|-----------|---|---|--|--|--|--|
| Field          |                                                                                                                                                                                     |                |    | I_MONI | FOR[15:8] |           |   |   |  |  |  |  |
| Reset          |                                                                                                                                                                                     |                |    |        |           |           |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                                                                     | Read Only      |    |        |           |           |   |   |  |  |  |  |
| BIT            | 7                                                                                                                                                                                   | 6              | 5  | 4      | 3         | 2         | 1 | 0 |  |  |  |  |
| Field          |                                                                                                                                                                                     | I_MONITOR[7:0] |    |        |           |           |   |   |  |  |  |  |
| Reset          |                                                                                                                                                                                     |                |    |        |           |           |   |   |  |  |  |  |
| Access<br>Type |                                                                                                                                                                                     |                |    | Rea    | d Only    |           |   |   |  |  |  |  |
| BITFIE         | LD                                                                                                                                                                                  | BITS           |    |        | DE        | SCRIPTION |   |   |  |  |  |  |
| I_MONITOR      | 15:0       I_MONITOR Instantaneous sampled current. Return latest measured current sample.         I_MONITOR (mA) = K <sub>CDR</sub> x GAIN x SNSF x I_MONITOR[15:0] <sub>DEC</sub> |                |    |        |           |           |   |   |  |  |  |  |

#### <u>I\_AC (0x47, 0x50, 0x59, 0x62)</u>

| BIT            | 15 | 14         | 13 | 12   | 11   | 10 | 9 | 8 |  |  |
|----------------|----|------------|----|------|------|----|---|---|--|--|
| Field          |    | I_AC[15:8] |    |      |      |    |   |   |  |  |
| Reset          |    |            |    |      |      |    |   |   |  |  |
| Access<br>Type |    |            |    | Read | Only |    |   |   |  |  |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BIT            | 7  | 6                | 5    | 4                                                                  | 3     | 2 | 1 | 0 |  |  |
|----------------|----|------------------|------|--------------------------------------------------------------------|-------|---|---|---|--|--|
| Field          |    |                  |      | I_AC                                                               | [7:0] |   |   |   |  |  |
| Reset          |    |                  |      |                                                                    |       |   |   |   |  |  |
| Access<br>Type |    | Read Only        |      |                                                                    |       |   |   |   |  |  |
| BITFIE         | LD | BITS DESCRIPTION |      |                                                                    |       |   |   |   |  |  |
| I_AC           |    | 15:0             | AC c | AC current measured I_AC (mA) = KCDR x GAIN x SNSF x I_AC[15:0]DEC |       |   |   |   |  |  |

#### RES (0x48, 0x51, 0x5A, 0x63)

| BIT            | 15                                                         | 14              | 13 | 12  | 11     | 10 | 9 | 8 |  |  |  |
|----------------|------------------------------------------------------------|-----------------|----|-----|--------|----|---|---|--|--|--|
| Field          |                                                            |                 |    | RES | [15:8] |    |   |   |  |  |  |
| Reset          |                                                            |                 |    |     |        |    |   |   |  |  |  |
| Access<br>Type |                                                            | Read Only       |    |     |        |    |   |   |  |  |  |
| BIT            | 7                                                          | 7 6 5 4 3 2 1 0 |    |     |        |    |   |   |  |  |  |
| Field          |                                                            |                 | -  | RES | [7:0]  |    |   |   |  |  |  |
| Reset          |                                                            |                 |    |     |        |    |   |   |  |  |  |
| Access<br>Type |                                                            | Read Only       |    |     |        |    |   |   |  |  |  |
| BITFIE         | D BITS DESCRIPTION                                         |                 |    |     |        |    |   |   |  |  |  |
| RES            | 15:0 Measured resistance R = R[15:0] x ( KR/(SNSF * GAIN)) |                 |    |     |        |    |   |   |  |  |  |

#### PWM\_DUTY (0x49, 0x52, 0x5B, 0x64)

| BIT            | 15    | 14                  | 13   | 12                 | 11          | 10 | 9 | 8 |  |  |
|----------------|-------|---------------------|------|--------------------|-------------|----|---|---|--|--|
| Field          |       | PWM_DUTYCYCLE[15:8] |      |                    |             |    |   |   |  |  |
| Reset          |       |                     |      |                    |             |    |   |   |  |  |
| Access<br>Type |       | Read Only           |      |                    |             |    |   |   |  |  |
| BIT            | 7     | 6                   | 5    | 5 4 3 2 1 0        |             |    |   |   |  |  |
| Field          |       | •                   |      | PWM_DUT            | YCYCLE[7:0] |    |   |   |  |  |
| Reset          |       |                     |      |                    |             |    |   |   |  |  |
| Access<br>Type |       |                     |      | Read Only          |             |    |   |   |  |  |
| BITFIE         | LD    | BITS                |      | DESCRIPTION        |             |    |   |   |  |  |
| PWM_DUTYC      | CYCLE | 15:0                | Duty | Duty Cycle Monitor |             |    |   |   |  |  |

#### FAULT0 (0x65)

| BIT            | 15                        | 14                        | 13                        | 12                        | 11                        | 10                        | 9                         | 8                         |
|----------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
| Field          | DPM3                      | DPM2                      | DPM1                      | DPM0                      | OLF3                      | OLF2                      | OLF1                      | OLF0                      |
| Reset          |                           |                           |                           |                           |                           |                           |                           |                           |
| Access<br>Type | Write 1 to<br>Clear, Read |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BIT            | 7                         | 6                         | 5                                     | 4          |   | 3                                                              | 2                                                     | 1                         | 0                      |  |  |
|----------------|---------------------------|---------------------------|---------------------------------------|------------|---|----------------------------------------------------------------|-------------------------------------------------------|---------------------------|------------------------|--|--|
| Field          | HHF3                      | HHF2                      | HHF1                                  | HHF0       | 0 | OCP3                                                           | OCP2                                                  | OCP1                      | OCP0                   |  |  |
| Reset          |                           |                           |                                       |            |   |                                                                |                                                       |                           |                        |  |  |
| Access<br>Type | Write 1 to<br>Clear, Read | Write 1 to<br>Clear, Read |                                       |            |   |                                                                | Write 1 to<br>Clear, Read                             | Write 1 to<br>Clear, Read | Write 1 to Clear, Read |  |  |
| BITFIELD       | BITS                      |                           | DESCRIPT                              | ION        |   |                                                                | D                                                     | ECODE                     |                        |  |  |
| DPM3           | 15                        | DPM status                | bit                                   |            |   |                                                                | nger moved<br>nger did not m                          | ove                       |                        |  |  |
| DPM2           | 14                        | DPM status                | bit                                   |            |   |                                                                | nger moved<br>nger did not m                          | ove                       |                        |  |  |
| DPM1           | 13                        | DPM status                | bit                                   |            |   |                                                                | nger moved<br>nger did not m                          | ove                       |                        |  |  |
| DPM0           | 12                        | DPM status                | bit                                   |            |   |                                                                | nger moved<br>nger did not m                          | ove                       |                        |  |  |
| OLF3           | 11                        | Open-loop o               | Open-loop detection bit               |            |   |                                                                | 0x0: No open-loop detected<br>0x1: Open-loop detected |                           |                        |  |  |
| OLF2           | 10                        | Open-loop c               | Open-loop detection bit               |            |   |                                                                | open-loop dete<br>en-loop detecte                     |                           |                        |  |  |
| OLF1           | 9                         | Open-loop o               | letection bit                         |            |   |                                                                | open-loop dete<br>en-loop detecte                     |                           |                        |  |  |
| OLF0           | 8                         | Open-loop c               | letection bit                         |            |   |                                                                | open-loop dete<br>en-loop detecte                     |                           |                        |  |  |
| HHF3           | 7                         | Hit current n             | ot reached det                        | ection bit |   | 0x0: Hit current is reached<br>0x1: Hit current is not reached |                                                       |                           |                        |  |  |
| HHF2           | 6                         | Hit current n             | ot reached det                        | ection bit |   | 0x0: Hit current is reached<br>0x1: Hit current is not reached |                                                       |                           |                        |  |  |
| HHF1           | 5                         | Hit current n             | ot reached det                        | ection bit |   |                                                                | current is reac<br>current is not r                   |                           |                        |  |  |
| HHF0           | 4                         | Hit current n             | Hit current not reached detection bit |            |   |                                                                | current is reac<br>current is not r                   |                           |                        |  |  |
| OCP3           | 3                         | Overcurrent               | Overcurrent protection detection bit  |            |   |                                                                | overcurrent de ercurrent detec                        |                           |                        |  |  |
| OCP2           | 2                         | Overcurrent               | protection dete                       | ection bit |   |                                                                | overcurrent de ercurrent detec                        |                           |                        |  |  |
| OCP1           | 1                         | Overcurrent               | protection dete                       | ection bit |   | 0x0: No overcurrent detected<br>0x1: Overcurrent detected      |                                                       |                           |                        |  |  |
| OCP0           | 0                         | Overcurrent               | Overcurrent protection detection bit  |            |   |                                                                | overcurrent de ercurrent detec                        |                           |                        |  |  |

## FAULT1 (0x66)

| BIT            | 15 | 14 | 13 | 12 | 11 | 10                        | 9                         | 8                         |
|----------------|----|----|----|----|----|---------------------------|---------------------------|---------------------------|
| Field          | -  | -  | -  | -  | -  | RES3                      | RES2                      | RES1                      |
| Reset          | -  | -  | _  | _  | _  |                           |                           |                           |
| Access<br>Type | -  | -  | -  | _  | -  | Write 1 to<br>Clear, Read | Write 1 to<br>Clear, Read | Write 1 to<br>Clear, Read |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BIT            | 7                         | 6                             | 5                                                                                                                                                                                          | 4                                   |      | 3                     | 2                                                                                  | 1                         | 0                         |
|----------------|---------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------|-----------------------|------------------------------------------------------------------------------------|---------------------------|---------------------------|
| Field          | RES0                      | OVT                           | COMER                                                                                                                                                                                      | UVM                                 |      | IND3                  | IND2                                                                               | IND1                      | IND0                      |
| Reset          |                           |                               |                                                                                                                                                                                            |                                     |      |                       |                                                                                    |                           |                           |
| Access<br>Type | Write 1 to<br>Clear, Read | Write 1 to<br>Clear, Read     | Write 1 to<br>Clear, Read                                                                                                                                                                  | Write 1 to<br>Clear, Read           |      | rite 1 to<br>ar, Read | Write 1 to<br>Clear, Read                                                          | Write 1 to<br>Clear, Read | Write 1 to<br>Clear, Read |
| BITFIELD       | BITS                      |                               | DESCRIPT                                                                                                                                                                                   | ION                                 |      |                       | D                                                                                  | ECODE                     |                           |
| RES3           | 10                        |                               |                                                                                                                                                                                            | esistance exce                      |      |                       | asured resistar<br>asured resistar                                                 |                           |                           |
| RES2           | 9                         |                               |                                                                                                                                                                                            | esistance exce<br>according chanr   |      |                       | asured resistar<br>asured resistar                                                 |                           |                           |
| RES1           | 8                         |                               |                                                                                                                                                                                            | esistance exce<br>according chanr   |      |                       | easured resistar<br>easured resistar                                               |                           |                           |
| RES0           | 7                         |                               |                                                                                                                                                                                            | esistance exce<br>according chanr   |      |                       | easured resistar<br>easured resistar                                               |                           |                           |
| OVT            | 6                         | Bit is set if o               | vertemperature                                                                                                                                                                             | e is detected.                      |      |                       | overtemperatu<br>ertemperature                                                     |                           |                           |
| COMER          | 5                         | Bit is set if a               | communicatio                                                                                                                                                                               | on error is detec                   | ted. |                       | communication<br>mmunication e                                                     |                           | d                         |
| UVM            | 4                         | Bit is set if u after IC star |                                                                                                                                                                                            | detected. Is ac                     | tive |                       | undervoltage dete                                                                  |                           |                           |
| IND3           | 3                         |                               |                                                                                                                                                                                            | nductance is no<br>citation Hold or |      |                       | 0x0: Measured inductance is compliant<br>0x1: Measured inductance is not compliant |                           |                           |
| IND2           | 2                         |                               |                                                                                                                                                                                            | nductance is no<br>citation Hold or |      |                       | easured inducta<br>easured inducta                                                 |                           |                           |
| IND1           | 1                         |                               | Bit is set if the measured inductance is not<br>compliant according to Excitation Hold or Low<br>Phase. 0x0: Measured inductance is compliant<br>0x1: Measured inductance is not compliant |                                     |      |                       |                                                                                    |                           |                           |
| IND0           | 0                         |                               | Bit is set if the measured inductance is not<br>compliant according to Excitation Hold or Low<br>Phase. 0x0: Measured inductance is compliant<br>0x1: Measured inductance is not compli    |                                     |      |                       |                                                                                    |                           |                           |

### OTP\_CONTROLLER

The OTP\_CONTROLLER register can be accessed in OTP Programming mode only. To enter OTP Programming mode, the SPI command 0xFD12A7 needs to be issued (see the OTP Programming procedure).

| ADDRESS  | NAME             | MSB              |                  |                  |                                  | <b>0</b> P        |              |               | LSB          |
|----------|------------------|------------------|------------------|------------------|----------------------------------|-------------------|--------------|---------------|--------------|
| MTP_CTRL |                  |                  |                  | •                |                                  |                   |              |               |              |
| 0x68     | OTP_CONTROL[7:0] | -                | -                | -                | -                                | -                 | -            | STOP_P<br>ROG | SRT_PR<br>OG |
| 0x69     | OTP_STATUS[7:0]  | DONE             | ECC_ER<br>R_2BIT | ECC_ER<br>R_1BIT | OV_DUR<br>ING_BU<br>RN_PUL<br>SE | VPP_INI<br>T_FAIL | OTP_FU<br>LL | VERI_FA<br>IL | -            |
| OTP_RECO | RD               | •                |                  |                  |                                  |                   |              | •             |              |
| 0x7A     | OTP_DATA0[7:0]   | OTP_RECORD[7:0]  |                  |                  |                                  |                   |              |               |              |
| 0x7B     | OTP_DATA1[7:0]   | OTP_RECORD[15:8] |                  |                  |                                  |                   |              |               |              |
| 0x7C     | OTP_ADDR[7:0]    |                  |                  |                  | OTP_RECO                         | DRD[23:16]        |              |               |              |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Register Details**

### OTP\_CONTROL (0x68)

**OTP Control Register** 

| BIT            | 7                                                  | 6    | 5     | 4                  | 3                  | 2           | 1                     | 0                     |
|----------------|----------------------------------------------------|------|-------|--------------------|--------------------|-------------|-----------------------|-----------------------|
| Field          | _                                                  | _    | -     | -                  | -                  | _           | STOP_PRO<br>G         | SRT_PROG              |
| Reset          | _                                                  | -    | -     | -                  | -                  | -           | 0b0                   | 0b0                   |
| Access<br>Type | _                                                  | _    | _     | _                  | -                  | -           | Write,<br>Read, Pulse | Write,<br>Read, Pulse |
| BITFIEI        | LD                                                 | BITS |       |                    | DE                 | SCRIPTION   |                       |                       |
| STOP_PROG      |                                                    | 1    | At ar | ny time, writing t | this bit to 1 will | STOP/abando | n a field progra      | m burn.               |
| SRT_PROG       | RT_PROG 0 Start executing the OTP write procedure. |      |       |                    |                    |             |                       |                       |

#### OTP\_STATUS (0x69)

#### OTP Status Register

| BIT                       | 7         | 6                   | 5           |                                                                                                                                                                                                                                                                   | 4                                                     | 3                 | 2               | 1               | 0            |  |
|---------------------------|-----------|---------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------|-----------------|-----------------|--------------|--|
| Field                     | DONE      | ECC_ERR_<br>2BIT    | ECC_E<br>1B |                                                                                                                                                                                                                                                                   | OV_DURIN<br>G_BURN_P<br>ULSE                          | VPP_INIT_<br>FAIL | OTP_FULL        | VERI_FAIL       | -            |  |
| Reset                     | 0b0       | 0b0 0b              |             | 0                                                                                                                                                                                                                                                                 | 0b0                                                   | 0b0               | 0b0             | 0b0             | -            |  |
| Access<br>Type            | Read Only | only Read Only Read |             | Only                                                                                                                                                                                                                                                              | Read Only                                             | Read Only         | Read Only       | Read Only       | _            |  |
| BITFIELD BITS DESCRIPTION |           |                     |             |                                                                                                                                                                                                                                                                   |                                                       |                   |                 |                 |              |  |
| DONE                      |           | 7                   |             | Programming complete                                                                                                                                                                                                                                              |                                                       |                   |                 |                 |              |  |
| ECC_ERR_2B                | іт        | 6                   |             | One of the previously burned records contains an uncorrectible 2-bit error.<br>The record was not loaded, and the registers it was intended to load were n<br>written. If an erronus record is overwritten by a correct record, this status wi<br>not be cleared. |                                                       |                   |                 |                 | oad were not |  |
| ECC_ERR_1B                | іт        | 5                   |             | corre                                                                                                                                                                                                                                                             | of the actively locted. If an error eleared for ea    | neous record is   | overwritten by  |                 |              |  |
| OV_DURING_<br>ULSE        | BURN_P    | 4                   |             | volta                                                                                                                                                                                                                                                             | n the memory is<br>ge has gone ab<br>dered a critical | ove the abs-m     | ax specified in | the data sheet. | This is      |  |
| VPP_INIT_FAI              | L         | 3                   |             | The programming voltage did not reach the desired value before burning.<br>Therefore, the burn was abandoned and not attempted.                                                                                                                                   |                                                       |                   |                 |                 | burning.     |  |
| OTP_FULL                  | P_FULL 2  |                     |             | The OTP is full, and no more records can be burned.                                                                                                                                                                                                               |                                                       |                   |                 |                 |              |  |
| VERI_FAIL 1               |           |                     |             | OTP record was attempted to be burned OTP_REPG_TIMES times, and verification of each attempt produced an incorrect result. Where OTP_REPG_TIMES is a parameter to the IP.                                                                                         |                                                       |                   |                 |                 |              |  |

#### OTP\_DATA0 (0x7A)

Least Significant Byte for OTP write

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

| BIT            | 7  | 6                | 5 | 4  | 3  | 2 | 1 | 0 |  |  |
|----------------|----|------------------|---|----|----|---|---|---|--|--|
| Field          |    | OTP_RECORD[7:0]  |   |    |    |   |   |   |  |  |
| Reset          |    |                  |   | 0x | 00 |   |   |   |  |  |
| Access<br>Type |    | Write, Read      |   |    |    |   |   |   |  |  |
| BITFIEI        | LD | BITS DESCRIPTION |   |    |    |   |   |   |  |  |
| OTP_RECORD     | )  | 7:0              |   |    |    |   |   |   |  |  |

#### OTP\_DATA1 (0x7B)

| Most Significa | Nost Significant Byte for OTP write |                  |  |        |      |  |  |  |  |  |  |
|----------------|-------------------------------------|------------------|--|--------|------|--|--|--|--|--|--|
| BIT            | 7                                   | 7 6 5 4 3 2 1 0  |  |        |      |  |  |  |  |  |  |
| Field          |                                     | OTP_RECORD[15:8] |  |        |      |  |  |  |  |  |  |
| Reset          |                                     | 0x00             |  |        |      |  |  |  |  |  |  |
| Access<br>Type |                                     |                  |  | Write, | Read |  |  |  |  |  |  |
| BITFIEI        | D BITS DESCRIPTION                  |                  |  |        |      |  |  |  |  |  |  |
| OTP_RECORD     | )                                   | 7:0              |  |        |      |  |  |  |  |  |  |

### OTP\_ADDR (0x7C)

#### RegMap Register Address for OTP Write

| BIT            | 7  | 6                 | 5 | 4  | 3  | 2 | 1 | 0 |  |  |
|----------------|----|-------------------|---|----|----|---|---|---|--|--|
| Field          |    | OTP_RECORD[23:16] |   |    |    |   |   |   |  |  |
| Reset          |    |                   |   | 0x | 00 |   |   |   |  |  |
| Access<br>Type |    | Write, Read       |   |    |    |   |   |   |  |  |
| BITFIEI        | LD | BITS DESCRIPTION  |   |    |    |   |   |   |  |  |
| OTP_RECORD     | )  | 7:0               |   |    |    |   |   |   |  |  |

## **Applications Information**

#### **Examples of Use**

The high configurability of the MAX22216/MAX22217 provide flexibility. <u>Figure 14</u> shows some of the typical applications addressed by the device.

- [A] shows a SPI-based application. The MCU and the driver communicate via SPI. Configuration settings are written into the device after power up. Status information is exchanged via SPI too. Different loads are supported (single/ ended/differential solenoids, brushed DC motors, mixed solenoid + brushed).
- [B] and [C] show two typical applications in which the MAX22216/MAX22217 are OTP programmed and controlled by a remote host controller. The number of control signal wires is minimized.
  - [B] refers to a single differential valve driver with minimum wiring (supply and GND only) (see the <u>VM Switching</u> <u>Stand-Alone</u> section).
  - [C] refers to a multi valves and/or DC-motor driver in which the remote host controller outputs the CNTL trigger signals for the actuators.

In these examples, the STAT output pins drive LED diodes.

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic



Figure 14. Examples of Use

### V<sub>M</sub> Switching Stand-Alone

Figure 15 shows an example of an electronic valve application. The driver is locally mounted into the valve housing and controlled remotely by simply switching the supply voltage ( $V_M$ ). The MAX22216/MAX22217 are OTP programmed to drive a solenoid valve differentially with pairs of half bridges connected in parallel. This configuration requires two control wires from a remote controller (VM and GND). The  $V_{IO}$  is internally generated (see the  $V_{IO}$  Pin Description ( $V_{IO}$ ) section). The solenoid energization is triggered by the rising edge of the  $V_M$  supply and starts after a wake-up time ( $T_{WAKE}$ ), which includes the rising time of the supply and the wake-up time of the device (see the Electrical Characteristics table).

The activation and deactivation V<sub>M</sub> thresholds (VM\_THLD\_UP, VM\_THLD\_DW) can be set by writing the corresponding

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

4 bits OTP bitfields in the VM\_THRESHOLD register. If only the VM\_THLD\_DOWN is used, the set voltage in this register will become the deactivation limit if the  $V_M$  falls under it, and it will resume normal functionality when the  $V_M$  goes again over it. When both  $V_M$  thresholds are used, they create a hysteresis effect in which VM\_THLD\_DOWN remains the low voltage deactivation limit, but for reactivation, the  $V_M$  must be bigger than the set voltage for VM\_THLD\_UP. These limits can be set to control the ICs functionality even without the OTP.

FAULT and STAT logic outputs can be used to activate LED diodes, as shown in the diagram. In this example, the STAT output provides the ON/OFF status of the valve.

For fast valves, where the MAX22216/MAX22217 wake-up time would limit the speed performance of the valve, a third wire would be necessary to drive the CNTL signal of the device.



Figure 15. Stand-Alone - VM Switching

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

## **Typical Application Circuits**

### **Typical Application Circuit**



## **Ordering Information**

| PART NUMBER   | TEMPERATURE RANGE | PIN-PACKAGE         | FULL-SCALE CURRENT (IFS) |
|---------------|-------------------|---------------------|--------------------------|
| MAX22216ATJY+ | -40°C to +125°C   | 32 TQFN - 5mm x 5mm | 3.2A                     |
| MAX22217ATJY+ | -40°C to +125°C   | 32 TQFN - 5mm x 5mm | 1A                       |

# Quad Smart Serial-Controlled Solenoid and Motor Driver with Advanced Diagnostic

### **Revision History**

| REVISION<br>NUMBER | REVISION<br>DATE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PAGES<br>CHANGED                                                                               |
|--------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| 0                  | 09/23            | Release for Market Intro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                              |
| 1                  | 04/24            | Updated the table <i>Full Scale and Sense Scale</i> . Updated formula in <i>Setting the</i><br><i>Inductance Measurement</i> . Updated units and formula in <i>Resistance Measurement</i> .<br>Added units under <i>Setting the Sine Wave Generator</i> . Updated values in <i>Voltage Drive</i><br><i>Regulation</i> . Updated few content in <i>Slew Rate and Blanking Configuration</i> . Updated<br>units in <i>Detection of Plunger Movement</i> . Updated few content in <i>SPI Description</i> .<br>Updated <i>Applications</i> list. Updated <i>Detailed Description</i> . Updated units in <i>Minimum</i><br><i>TON Limitations</i> . Updated values in <i>Enabling the Sine Wave Generator for Dithering or</i><br><i>Inductance Measurement</i> . Updated values in <i>Setting the Detection of Plunger</i><br><i>Movement</i> . Updated content in <i>Voltage Drive Regulation</i> . Updated values in <i>Output</i><br><i>Specifications</i> . Updated the values in <i>Control</i> . Update unit in <i>Register Details</i> . Updated<br>units in <i>Digital V<sub>M</sub> Supply Voltage Monitor</i> . | 28, 35, 38, 32,<br>27, 25, 26,<br>35,36, 45, 46,<br>1, 17, 30, 31,<br>37, 27, 9, 10,<br>54, 34 |



Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties that may result from its use. Specifications subject to change without notice. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. Trademarks and registered trademarks are the property of their respective owners.