



Allegro MicroSystems reserves the right to make, from time to time, revisions to the anticipated product life cycle plan for a product to accommodate changes in production capabilities, alternative product availabilities, or market demand. The information included herein is believed to be accurate and reliable. However, Allegro MicroSystems assumes no responsibility for its use; nor for any infringements of patents or other rights of third parties which may result from its use.



## FEATURES AND BENEFITS

- WLCSP package for minimum footprint
- Ramp control circuit
- Fixed I<sup>2</sup>C logic thresholds
- 10-bit D-to-A converter
- 100  $\mu A$  resolution
- Low voltage I<sup>2</sup>C serial interface
- Low current draw sleep mode-active low
- 2.3 to 5.5 V operation

### **APPLICATIONS:**

Camera focus motor

PACKAGE: 6-Bump Chip Scale Package (suffix CG)



## DESCRIPTION

Designed for linear control of small form factor voice coil motors, the A3907 is capable of peak output currents to 102 mA and operating voltages to 5.5 V.

Internal circuit protection includes thermal shutdown with hysteresis, flyback clamp diode, and undervoltage monitoring of  $V_{\rm DD}.$ 

## **Functional Block Diagram**



#### **Selection Guide**

| Part Number | Packing              | Package                                       | Pb-free                                                          |
|-------------|----------------------|-----------------------------------------------|------------------------------------------------------------------|
| A3907ECGTR  | 4000 pieces per reel | Bumped wafer-level chip-scale package (WLCSP) | Pb-free chip with high-temperature solder balls (RoHS compliant) |

#### **ABSOLUTE MAXIMUM RATINGS**

| Characteristic                | Symbol               | Notes   | Rating                        | Unit |
|-------------------------------|----------------------|---------|-------------------------------|------|
| Supply Voltage                | V <sub>DD</sub>      |         | 6                             | V    |
| Logic Input Voltage Range     | V <sub>IN</sub>      |         | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Operating Ambient Temperature | T <sub>A</sub>       | Range E | -40 to 85                     | °C   |
| Junction Temperature          | T <sub>J</sub> (max) |         | 150                           | °C   |
| Storage Temperature           | T <sub>stg</sub>     |         | -40 to 150                    | °C   |

#### **Thermal Characteristics**

| Characteristic             | Symbol          | Test Conditions*                       | Value | Unit |
|----------------------------|-----------------|----------------------------------------|-------|------|
| Package Thermal Resistance | $R_{\theta JA}$ | On 4-layer PCB based on JEDEC standard | 64    | °C/W |

\*Additional thermal information available on the Allegro website



Top Side View



| Pin Name | Pin Description        |    |
|----------|------------------------|----|
| IOUT     | Sink Drive Output      | A1 |
| SLEEPZ   | Standby Mode Control   | A2 |
| GND      | Ground                 | B1 |
| SDA      | I <sup>2</sup> C data  | B2 |
| VDD      | Power Supply In        | C1 |
| SCL      | I <sup>2</sup> C clock | C2 |



### **ELECTRICAL CHARACTERISTICS** Valid at $T_A = 25^{\circ}C$ , $V_{DD} = 2.3$ to 5.5 V; unless otherwise noted

| Characteristics                            | Symbol                 | Test Conditions                                                      | Min. | Тур.  | Max.                 | Unit   |
|--------------------------------------------|------------------------|----------------------------------------------------------------------|------|-------|----------------------|--------|
| Supply Current                             |                        |                                                                      | _    | 0.5   | 2                    | mA     |
|                                            | I <sub>DD</sub>        | Sleep Mode (SLEEPZ = low), V <sub>DD</sub> = 2.3 to 3.5 V            | _    | < 100 | 500                  | nA     |
| UVLO Enable Threshold                      | V <sub>UVLO(th)</sub>  | V <sub>DD</sub> rising                                               | _    | 2     | 2.295                | V      |
| UVLO Hysteresis                            | V <sub>UVLO(hys)</sub> |                                                                      | -    | 100   | -                    | mV     |
| Thermal Shutdown Temperature               | T <sub>JTSD</sub>      | Temperature increasing                                               | -    | 165   | -                    | °C     |
| Thermal Shutdown Hysteresis                | T <sub>JTSD(hys)</sub> | Recovery = T <sub>JTSD</sub> - T <sub>JTSD(hys)</sub>                | -    | 15    | -                    | °C     |
| Power-Up Delay                             | t <sub>dPO</sub>       |                                                                      | -    | 10    | -                    | μs     |
| D-to-A Converter                           |                        | ·                                                                    |      |       |                      |        |
| Resolution                                 | Res                    | Target = 100 µA/LSB                                                  | _    | 10    | -                    | bit    |
| Relative Accuracy                          | err <sub>INL</sub>     | Code = 64 to 1023, Endpoint method                                   | _    | ±4    | -                    | LSB    |
| Differential Nonlinearity                  | err <sub>DNL</sub>     | Guaranteed monotonic                                                 | -    | _     | ±1                   | LSB    |
| Maximum Output Current                     | I <sub>MAX</sub>       | Code = 1023                                                          | -    | 102.3 | -                    | mA     |
| Gain Error                                 | err <sub>A</sub>       | $T_J = 25^{\circ}C$ , Code 64 to 1023, $V_{DD} = 2.6$ to 3.0 V       | -10  | < 3   | 10                   | %FS    |
| Gain Error Drift <sup>1</sup>              | ∆err <sub>A</sub>      | $T_J = -40^{\circ}C$ to 125°C                                        | -    | 0.2   | -                    | LSB/°C |
| Minimum Code Error                         | I <sub>OS1</sub>       | Code = 1                                                             | 0    | 1     | 5                    | mA     |
| Offset Error                               | I <sub>OS</sub>        | Code = 64                                                            | _    | 0.5   | -                    | mA     |
| Output                                     |                        | <u>`</u>                                                             |      |       |                      |        |
| Slew Rate Timer                            | err <sub>TS</sub>      | Relative to target value                                             | -10  | _     | 10                   | %      |
| Output Voltage Range                       | V <sub>OUT</sub>       |                                                                      | 0.35 | _     | V <sub>DD</sub> -0.1 | V      |
| Output On Resistance                       | R <sub>DS(on)</sub>    | R <sub>SENSE</sub> + R <sub>SINK</sub> , I <sub>OUT</sub> = 102.3 mA | -    | 2     | -                    | Ω      |
| I <sup>2</sup> C Interface                 |                        |                                                                      |      |       |                      |        |
| Bus Free Time Between Stop and Start       | t <sub>BUF</sub>       |                                                                      | 1.3  | -     | -                    | μs     |
| Hold Time Start Condition                  | t <sub>HD:STA</sub>    |                                                                      | 0.6  | _     | -                    | μs     |
| Setup Time for Repeated Start<br>Condition | t <sub>SU:STA</sub>    |                                                                      | 0.6  | _     | -                    | μs     |
| SCL Low Time                               | t <sub>LOW</sub>       |                                                                      | 1.3  | _     | -                    | μs     |
| SCL High Time                              | t <sub>HIGH</sub>      |                                                                      | 0.6  | _     | -                    | μs     |
| Data Setup Time                            | t <sub>SU:DAT</sub>    |                                                                      | 100  | _     | -                    | ns     |
| Data Hold Time                             | t <sub>HD:DAT</sub>    |                                                                      | 0    | 900   | _                    | ns     |



### **ELECTRICAL CHARACTERISTICS (continued)** Valid at $T_A = 25$ °C, $V_{DD} = 2.3$ to 5.5 V; unless otherwise noted

| Characteristics                        | Symbol              | Test Conditions                    | Min. | Тур. | Max. | Unit |
|----------------------------------------|---------------------|------------------------------------|------|------|------|------|
| I <sup>2</sup> C Interface             |                     |                                    |      |      |      |      |
| Setup Time for Stop Condition          | t <sub>su:sto</sub> |                                    | 0.6  | -    | -    | μs   |
| Logic Input (SDA, SCL Pins) Low Level  | V <sub>IL</sub>     |                                    | -    | _    | 0.84 | V    |
| Logic Input (SDA, SCL Pins) High Level | V <sub>IH</sub>     |                                    | 1.26 | -    | -    | V    |
| SLEEP Pin Input Low Level              | V <sub>SLPINL</sub> |                                    | -    | -    | 0.7  | V    |
| SLEEP Pin Input High Level             | V <sub>SLPINH</sub> |                                    | 1.5  | -    | -    | V    |
| Input Hysteresis                       | V <sub>HYS</sub>    | SDA and SCL only                   | -    | 100  | -    | mV   |
| Logic Input Current                    | I <sub>IN</sub>     | $V_{IN} = 0 V \text{ to } V_{DD}$  | -1   | 0    | 1    | μA   |
| SDA Pin Output Voltage                 | V <sub>OL</sub>     | I <sub>LOAD</sub> = 1.5 mA         | -    | -    | 0.36 | V    |
| SCL Clock Frequency                    | f <sub>CLK</sub>    |                                    | _    | _    | 400  | kHz  |
| SDA Output Fall Time                   | t <sub>OF</sub>     | V <sub>IH</sub> to V <sub>IL</sub> | _    | _    | 250  | ns   |

<sup>1</sup>Assured by design and characterization, not production tested.

#### I<sup>2</sup>C Timing Diagram





### **Functional Description**

#### **OUTPUT CURRENT LEVEL CONTROL**

The A3907 output current level,  $I_{OUT}$ , is controlled dynamically by programming the D-to-A converter (DAC) value via the I<sup>2</sup>C serial port. A 10-bit Level Control code, having a decimal equivalent value from 0 through 1023, is clocked into the SDA pin.

The target output current can be calculated by:

$$I_{OUT} = n_{DAC} \times 100 \ \mu A \ , \tag{1}$$

where  $n_{\text{DAC}}$  is the decimal equivalent of the Level Control code. For example, a code of 5 (00000101<sub>2</sub>) sets an output current target of 500  $\mu$ A.

Programming Level Control code 0 disables the output sink drive. In addition, the DAC is automatically set to code 0 at power-up and also at a fault condition on VDD.

#### **OUTPUT CURRENT SLEW RATE CONTROL**

When a new current level control instruction is received on the SDA input, the A3907 moves to the new target currrent level by incrementing or decrementing through each of the intermediate current levels until it arrives at the new programmed value.

The control instruction received at the SDA input includes both the 10-bit Level Control code and a 4-bit Ramp Control code. The Level Control code is used to determine the absolute value of the changes in  $I_{OUT}$  (see equation 1), and the Ramp Control code maps to a lookup table of time intervals (represented in table 1). Together, these two codes determine the shape of the current level change function.

**Step or Ramp Function** The A3907 can change to the new target level using either a step or a ramp slew rate function. When a step function is selected, the A3907 moves to the new target level without imposing any additional time delays between DAC updates. To select a step function, program one of the four Ramp Control codes in table 1 that disable the ramp feature.

When a ramp function is selected, the A3907 imposes time delays between each DAC update, calculated according to the particular function option selected. To select a ramp function, program one of the twelve Ramp Control codes in table 1 that enable the ramp feature.

**Single or Dual Subintervals** For either the step or the ramp slew rate method, the total change can be accomplished in either

one continuous time interval, or divided over two sequential time subintervals. When the single-interval method is selected, the total change in  $I_{OUT}$  is accomplished over the total time interval determined by the Rate Control code in table 1, calculated as follows:

$$Code_T = |(Code_{NewTarget} - Code_{PreviousTarget})| / 2$$
, (2)

and

$$T = Code_T \times t_{dT} , \qquad (3)$$

where  $t_{dT}$  is the delay factor, in table 1.

When the dual-subintervals method is selected, the elapsed time for each subinterval is determined separately by the Rate Control code in table 1. The time interval from initiation, T0, to the switchover point, T1, is calculated as follows:

$$Code_{Switchover} = |(Code_{NewTarget} - Code_{PreviousTarget})| / 2$$
, (4)  
and

$$TI = Code_{Switchover} \times t_{dTI} , \qquad (5)$$

where  $t_{dT1}$  is the delay factor for the initial time subinterval, in table 1.

The current amplitude at the switchover point is calculated based on equation 1, as follows:

$$I_{Switchover} = (Code_{Low} + Code_{Switchover}) \times 100 \ \mu A , \qquad (6)$$

where  $Code_{Low}$  is the lesser of  $Code_{NewTarget}$  and  $Code_{PreviousTarget}$ .

The time interval from the switchover point, T1, until the target current level is reached, T2, is calculated as follows:

$$T2-T1 = Code_{Switchover} \times t_{dT2} , \qquad (7)$$

where  $t_{dT2}$  is the delay factor for the second time subinterval, in table 1.

#### **OUTPUT FUNCTION PROGRAMMING**

Two examples of output level and slew rate programming are shown in figure 1. Both examples are ramp slew rate functions, using the dual-subinterval method. In example A, an increment in  $I_{OUT}$  is shown, and example B shows a decrement in  $I_{OUT}$ .



Example A

- The A3907 has been previously programmed to Level Control code 100 (1100100<sub>2</sub>), for a target  $I_{OUT}$  of 100 × 100  $\mu$ A = 10 mA (equation 1).
- The new target current level is 20 mA, so Level Control code 200  $(11001000_2)$  is programmed (invert equation 1).
- For this example, the slew rate function selected is represented by Ramp Control code  $1100_2$ : ramp, dual-subinterval, initial subinterval delay factor 781 ns, second subinterval delay factor 50  $\mu$ s.
- The A3907 determines the switchover point, T1, as follows:

 $Code_{Switchover} = |(200 - 100)|/2 = 50$  (equation 2),

 $T1 = 50 \times 0.781 \ \mu s = 39 \ \mu s$  (equation 5),

 $I_{\text{T1}} = 50 + 100 \times 100 \ \mu\text{A} = 150 \ \mu\text{A}$  (equation 6).

• The A3907 determines the target time final point, T2, as follows:

 $Code_{Switchover} = |(200 - 100)|/2 = 50 \text{ (equation 2)}$ ,

 $T2-T1 = 50 \times 50 \ \mu s = 2.5 \ ms$  (equation 5).

Example B

• The A3907 has been previously programmed to Level Control code 1000 (1111101000<sub>2</sub>), for a target  $I_{OUT}$  of 1000 × 100  $\mu$ A = 100 mA (equation 1).

| Slew Rate<br>Method | Time | er Bit | s Set | tings | Delay Factor<br>(μs)      |                  |  |
|---------------------|------|--------|-------|-------|---------------------------|------------------|--|
| methoa              | Т3   | T2     | T1    | Т0    | t <sub>dT</sub>           |                  |  |
|                     | 0    | 0      | 0     | 0     | 0 (ramp feature disabled  |                  |  |
|                     | 0    | 0      | 0     | 1     | 6.25                      |                  |  |
|                     | 0    | 0      | 1     | 0     | 12.5                      |                  |  |
| Single Interval     | 0    | 0      | 1     | 1     | 25                        |                  |  |
| Single Interval     | 0    | 1      | 0     | 0     | 50                        |                  |  |
|                     | 0    | 1      | 0     | 1     | 100                       |                  |  |
| -                   | 0    | 1      | 1     | 0     | 200                       |                  |  |
|                     | 0    | 1      | 1     | 1     | 0 (ramp feature disabled) |                  |  |
|                     | Т3   | T2     | T1    | Т0    | t <sub>dT1</sub>          | t <sub>dT2</sub> |  |
|                     | 1    | 0      | 0     | 0     | 0 (ramp feature disabled) |                  |  |
|                     | 1    | 0      | 0     | 1     |                           | 6.25             |  |
|                     | 1    | 0      | 1     | 0     |                           | 12.5             |  |
| Dual Interval       | 1    | 0      | 1     | 1     | 0.781                     | 25               |  |
|                     | 1    | 1      | 0     | 0     | 0.781                     | 50               |  |
|                     | 1    | 1      | 0     | 1     |                           | 100              |  |
|                     | 1    | 1      | 1     | 0     |                           | 200              |  |
|                     | 1    | 1      | 1     | 1     | 0 (ramp feat              | ure disabled)    |  |

#### **Table 1. Slew Rate Function Table**

- The new target current level is 30 mA, so Level Control code 300 (100101100<sub>2</sub>) is programmed (invert equation 1).
- For this example, the slew rate function selected is represented by Ramp Control code 1101<sub>2</sub>: ramp, dual-subinterval, initial subinterval delay factor 781 ns, second subinterval delay factor 100 μs.
- The A3907 determines the switchover point, T2, as follows:

 $Code_{Switchover} = |(1000 - 300)|/2 = 350$  (equation 2),

 $T1 = 350 \times 0.781 \ \mu s = 273 \ \mu s$  (equation 5),

 $I_{\rm T1} = 350 + 300 \times 100 \ \mu A = 65 \ \mu A$  (equation 6).

• The A3907 determines the target time final point, T1, as follows:

 $Code_{Switchover} = |(1000 - 300)|/2 = 350 (equation 2)$ ,

 $T2-T1 = 350 \times 100 \ \mu s = 35 \ ms$  (equation 5).



Figure 1. Examples of programmed I<sub>OUT</sub> change



#### **I<sup>2</sup>C INTERFACE**

This is a serial interface that uses two bus lines, SCL and SDA, to access the internal control registers. Data is exchanged between a microcontroller (master) and the A3907 (slave). The clock input to SCL is generated by the master, while SDA functions as either an input or an open drain output, depending on the direction of the data. The I<sup>2</sup>C input thresholds do not depend on the VDD voltage of the A3907. The levels are fixed at approximately 1V. The fixed levels allow the SDA and SCL lines to be pulled-up to a different logic level than the VDD supply of the 3907.

Timing Considerations The control sequence of the communication through the I<sup>2</sup>C interface is composed of several steps in sequence:

1. Start Condition. Defined by a negative edge on the SDA line, while SCL is high.

2. Address Cycle. 7 bits of address, plus 1 bit to indicate write (0) or read(1), and an acknowledge bit. The address setting is 0x18, 0x1A, 0x1C, or 0x1E.

3. Data Cycles. Write requires 7 bits of address data selecting the internal control register, followed by an acknowledge bit.

4. Stop Condition. Defined by a positive edge on the SDA line, while SCL is high.

Except to indicate a Start or Stop condition, SDA must be stable while the clock is high. SDA can only be changed while SCL is low. It is possible for the Start or Stop condition to occur at any time during a data transfer. The A3907 always responds by resetting the data transfer sequence.

To indicate a write cycle, the Read/Write bit is set to low. Mulitple writes are allowed. If desired, the readback bit can be set to high to check what was last written.

The Acknowledge bit is used by the master to determine if the slave device is responding to its address and data transmissions. When the A3907 decodes the 7-bit address field as a valid address, it responds by pulling SDA low during the ninth clock cycle.

During a data write from the master, the A3907 pulls SDA low during the clock cycle that follows the last data byte, in order to indicate that the data has been successfully received. In both cases, the master device must release the SDA line before the ninth clock cycle, in order to allow this handshaking to occur.

| Slave (ASSUT) Address |   |   |   |   |   |     |   |
|-----------------------|---|---|---|---|---|-----|---|
| Device Identifier     |   |   |   |   |   | R/W |   |
| 0                     | 0 | 0 | 1 | 1 | Х | Х   | 0 |

#### MC Dute /120 Muite

| Control Regi | ster MS Byte | (I <sup>2</sup> C Write register) | Control Reg | ster MS Byte | (I <sup>2</sup> C Write register) |
|--------------|--------------|-----------------------------------|-------------|--------------|-----------------------------------|
| Bit          | Name         | Function                          | Bit         | Name         | Function                          |
| 0            | D4           | DAC                               | 0           | T0           | Time Setting LSB                  |
| 1            | D5           | DAC                               | 1           | T1           | Time Setting Bit 1                |
| 2            | D6           | DAC                               | 2           | T2           | Time Setting Bit2                 |
| 3            | D7           | DAC                               | 3           | Т3           | Time Setting Bit 3                |
| 4            | D8           | DAC                               | 4           | D0           | DAC LSB                           |
| 5            | D9           | DAC MSB                           | 5           | D1           | DAC                               |
| 6            | Т5           | Not used                          | 6           | D2           | DAC                               |
| 7            | SLEEP        | 1=Sleep 0=Normal                  | 7           | D3           | DAC                               |

Slove (A2007) Address

#### Write Operation





#### **OUTPUT VOLTAGE RANGE**

To guarantee the accuracy and linearity of the programmed current, the voltage on the IOUT pin,  $V_{OUT}$ , should be greater than 350 mV. The output voltage is a function of the battery voltage, motor resistance, and the programmed load current,  $I_{OUT}$ .

#### **CLAMP DIODE**

When the IC output is turned off, the load inductance causes the

output voltage,  $V_{OUT}$ , to rise. An internal clamp diode, connected between the IOUT and VDD pins, is integrated into the IC to ensure the output voltage remains at a safe level.

#### **SLEEP** PIN

The SLEEP pin is an active low input. A logic low signal disables all of the internal circuitry and prevents the IC from draining battery power.

### **Applications Information**

#### HEADROOM

The current may not reach the programmed level if there is not adequate headroom in the output circuit. The IC output voltage must be over 350mV to guarantee normal linear operation.  $V_{DD}$ ,  $I_{LOAD}$ , and  $R_{LOAD}$  can be adjusted to ensure the device operates in the linear range. When equation 7 is not satisfied, the load current will be limited by the series impedance and may not reach the programmed level.

$$V_{DD}(min) - R_{LOAD}(max) \times I_{OUT}(max) \ge 350 \text{ mV} . \tag{7}$$

#### IOUT ERRORS DEFINED

**Relative Accuracy (INL)** This error is calculated by measuring the worse case deviation from a straight line defined from endpoints. The straight line endpoints are defined by the actual measured values at Level Control code 63 and 1023 (see figure 2).

**Differential Nonlinearity (DNL)** A measure of the monotonicity of the DAC (see equation 8). The slope of the line must always be positive for each incremental step.

$$DNL = (I_{OUT}(n+1) - I_{OUT}(n)) / LSB , \qquad (8)$$

where (n = 64 to 1023). DNL should be < 1 LSB.

**Offset Error** The measured output current at Level Control code 64, compared to the ideal value according to the transfer function: 6.4 mA.

**Gain Error** The difference between the slopes of the ideal transfer function and the actual transfer function. The gain error is calculated by subtracting the offset error at Level Control code 16 from the actual transfer function. This calculated value is compared to the ideal transfer function and reported as a percentage of the ideal full scale value: 102.3 mA (see figure 3).

**Gain Error Drift** The change in slope of the transfer function due to temperature, expressed as LSB/°C.





Figure 2. Relative Accuracy



Figure 3. Gain Error



С

А

В

 $\mathbb{A}(\mathfrak{A})$ 

# Low Voltage Voice Coil Motor Driver

## CG Package, 6-Ball WLCSP





0.233

0.233

#### **Revision History**

| Number | Date              | Description                            |  |
|--------|-------------------|----------------------------------------|--|
| 2      | April 10, 2019    | Minor editorial updates                |  |
| 3      | February 11, 2025 | Changed product status to discontinued |  |

Copyright 2025, Allegro MicroSystems.

Allegro MicroSystems reserves the right to make, from time to time, such departures from the detail specifications as may be required to permit improvements in the performance, reliability, or manufacturability of its products. Before placing an order, the user is cautioned to verify that the information being relied upon is current.

Allegro's products are not to be used in any devices or systems, including but not limited to life support devices or systems, in which a failure of Allegro's product can reasonably be expected to cause bodily harm.

The information included herein is believed to be accurate and reliable. However, Allegro MicroSystems assumes no responsibility for its use; nor for any infringement of patents or other rights of third parties which may result from its use.

Copies of this document are considered uncontrolled documents.

For the latest version of this document, visit our website:

www.allegromicro.com

