# mail

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



# I<sup>2</sup>C Micro-Stepping Motor Driver

# INTRODUCTION

The AMIS-30622 is a single-chip micro-stepping motor driver with a position controller and control/diagnostic interface. It is ready to build intelligent peripheral systems where up to 32 drivers can be connected to one  $I^2C$  master. This significantly reduces system complexity.

The chip receives positioning instructions through the bus and subsequently drives the stator coils so the two-phase stepper motor moves to the desired position. The on-chip position controller is configurable (OTP or RAM) for different motor types, positioning ranges and parameters for speed, acceleration and deceleration. Micro-stepping allows silent motor operation and increased positioning resolution. The advanced motion qualification mode enables verification of the complete mechanical system in function of the selected motion parameters. The AMIS-30622 can easily be connected to an I<sup>2</sup>C bus where the I<sup>2</sup>C master can fetch specific status information like actual position, error flags, etc. from each individual slave node.

The chip is implemented in I2T100 technology, enabling both high voltage analog circuitry and digital functionality on the same chip.

#### PRODUCT FEATURES Motor Driver

- Micro-Stepping Technology
- Peak Current Up to 800 mA
- Fixed Frequency PWM Current-Control
- Automatic Selection of Fast and Slow Decay Mode
- No external Fly-back Diodes Required
- 14 V/24 V Compliant

#### **Controller with RAM and OTP Memory**

- Position Controller
- Configurable Speeds and Acceleration
- Input to Connect Optional Motion Switch

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

- Bi-Directional 2-Wire Bus for Inter IC Control
- Field Programmable Node Addresses
- Full Diagnostics and Status Information

#### Protection

- Overcurrent Protection
- Undervoltage Management
- Open-circuit Detection
- High Temperature Warning and Management
- Low Temperature Flag



# **ON Semiconductor®**

http://onsemi.com



NQFP-32 8 SUFFIX CASE 560AA

#### **ORDERING INFORMATION**

See detailed ordering and shipping information in the package dimensions section on page 2 of this data sheet.

#### EMI Compatibility

- High Voltage Outputs with Slope Control
- This is a Pb-Free Device

# APPLICATIONS

The AMIS-30622 is ideally suited for small positioning applications. Target markets include: automotive (headlamp alignment, HVAC, idle control, cruise control), industrial equipment (lighting, fluid control, labeling, process control, XYZ tables, robots) and building automation (HVAC, surveillance, satellite dish, renewable energy systems). Suitable applications typically have multiple axes or require mechatronic solutions with the driver chip mounted directly on the motor.

#### **Table 1. ORDERING INFORMATION**

| Part No.         | Peak Current | End Market/Version                 | Package*                        | Shipping <sup>†</sup> |
|------------------|--------------|------------------------------------|---------------------------------|-----------------------|
| AMIS30622C6223G  | 800 mA       | Automotive                         | SOIC-20<br>(Pb-Free)            | 38 Rail               |
| AMIS30622C6223RG | 800 mA       | High Voltage Version               | SOIC-20<br>(Pb-Free)            | 1500 Tape & Reel      |
| AMIS30622C6227G  | 800 mA       |                                    | SOIC-20<br>(Pb-Free)            | 38 Rail               |
| AMIS30622C6227RG | 800 mA       | Industrial                         | SOIC-20<br>(Pb-Free)            | 1500 Tape & Reel      |
| AMIS30622C6228G  | 800 mA       | Industrial<br>High Voltage Version | NQFP-32 (7 x 7 mm)<br>(Pb-Free) | 40 Rail               |
| AMIS30622C6228RG | 800 mA       |                                    | NQFP-32 (7 x 7 mm)<br>(Pb-Free) | 2500 Tape & Reel      |

\*For additional information on our Pb-Free strategy and soldering details, please download the ON Semiconductor Soldering and Mounting Techniques Reference Manual, SOLDERRM/D.

+For information on tape and reel specifications, including part orientation and tape sizes, please refer to our Tape and Reel Packaging Specification Brochure, BRD8011/D.

# QUICK REFERENCE DATA

#### Table 2. ABSOLUTE MAXIMUM RATINGS

|                                                                                                     | Parameter                                                      | Min  | Max          | Unit |
|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------|------|--------------|------|
| V <sub>BB</sub> , V <sub>HW</sub> , V <sub>SWI</sub> Supply voltage, hardwired address and SWI pins |                                                                | -0.3 | +40 (Note 1) | V    |
| TJ                                                                                                  | Junction temperature range (Note 2)                            | -50  | +175         | °C   |
| T <sub>st</sub>                                                                                     | Storage temperature                                            | -55  | +160         | °C   |
| V <sub>esd</sub> (Note 3)                                                                           | Human Body Model (HBM) Electrostatic discharge voltage on pins | -2   | +2           | kV   |
|                                                                                                     | Machine Model (MM) Electrostatic discharge voltage on pins     | -200 | +200         | V    |

Stresses exceeding Maximum Ratings may damage the device. Maximum Ratings are stress ratings only. Functional operation above the Recommended Operating Conditions is not implied. Extended exposure to stresses above the Recommended Operating Conditions may affect device reliability.

1. For limited time:  $V_{BB}$  < 0.5 s, SWI and HW pins <1.0 s.

2. The circuit functionality is not guaranteed.

3. HBM according to AEC-Q100: EIA-JESD22-A114-B (100 pF via 1.5 kΩ) and MM according to AEC-Q100: EIA-JESD22-A115-A.

#### **Table 3. OPERATING RANGES**

|                 | Parameter                   |      | Max  | Unit |
|-----------------|-----------------------------|------|------|------|
| V <sub>BB</sub> | Supply voltage              | +6.5 | +29  | V    |
| TJ              | Operating temperature range | -40  | +165 | °C   |

# **Table of Contents**

| General Description 1        |
|------------------------------|
| Product Features 1           |
| Applications 2               |
| Ordering Information 2       |
| Quick Reference Data 2       |
| Maximum Ratings 2            |
| Block Diagram 3              |
| Pin Description 4            |
| Package Thermal Resistance 5 |
| DC Parameters                |
| AC Parameters                |
| Typical Application 10       |

| Positioning Parameters                | 11 |
|---------------------------------------|----|
| Structural Description                | 14 |
| Functions Description                 | 15 |
| Position Controller                   | 15 |
| Main Control and Register             | 22 |
| OTP Register                          | 25 |
| Priority Encoder                      | 30 |
| Motordriver                           |    |
| I <sup>2</sup> C Bus Description      |    |
| I <sup>2</sup> C Application Commands | 40 |
| Package Outlines                      | 48 |



Figure 1. Block Diagram



Figure 2. SOIC-20 and NQFP-32 Pin-out

| Pin Name        | Pin Description                                                      | SOIC-20      | NQFP-32                |
|-----------------|----------------------------------------------------------------------|--------------|------------------------|
| SDA             | l <sup>2</sup> C serial data line                                    | 1            | 8                      |
| SCK             | I <sup>2</sup> C serial clock line                                   | 2            | 9                      |
| V <sub>DD</sub> | Internal supply (needs external decoupling capacitor)                | 3            | 10                     |
| GND             | Ground, heat sink                                                    | 4, 7, 14, 17 | 11, 14, 25, 26, 31, 32 |
| TST1            | Test pin (to be tied to ground in normal operation)                  | 5            | 12                     |
| TST2            | Test pin (to be left open in normal operation: internally pulled up) | 6            | 13                     |
| HW              | Hard wired address bit                                               | 8            | 15                     |
| CPN             | Negative connection of pump-capacitor (charge pump)                  | 9            | 17                     |
| CPP             | Positive connection of pump-capacitor (charge pump)                  | 10           | 18                     |
| VCP             | Charge-pump filter-capacitor                                         | 11           | 19                     |
| $V_{BB}$        | Battery voltage supply                                               | 12, 19       | 3, 4, 5, 20, 21, 22    |
| MOTYN           | Negative end of phase Y coil                                         | 13           | 23, 24                 |
| MOTYP           | Positive end of phase Y coil                                         | 15           | 27, 28                 |
| MOTXN           | Negative end of phase X coil                                         | 16           | 29, 30                 |
| MOTXP           | Positive end of phase X coil                                         | 18           | 1, 2                   |
| SWI             | Switch input                                                         | 20           | 6                      |
| NC              | Not connected (to be tied to ground)                                 |              | 7, 16                  |

#### Table 4. PIN DESCRIPTION

# PACKAGE THERMAL RESISTANCE

The AMIS-30622 is available in SOIC-20 or optimized NQFP-32 packages. For cooling optimizations, the NQFP has an exposed thermal pad which has to be soldered to the PCB ground plane. The ground plane needs thermal vias to conduct the head to the bottom layer. Figures 3 and 4 give examples for good power distribution solutions.

For precise thermal cooling calculations the major thermal resistances of the devices are given. The thermal media to which the power of the devices has to be given are:

- Static environmental air (via the case)
- PCB board copper area (via the device pins and exposed pad)

The thermal resistances are presented in Table 5: DC Parameters.

The major thermal resistances of the device are the Rth from the junction to the ambient (Rthja) and the overall Rth from the junction to the leads (Rthjp).

The NQFP device is designed to provide superior thermal performance. Using an exposed die pad on the bottom surface of the package is mainly contributing to this performance. In order to take full advantage of the exposed pad, it is most important that the PCB has features to conduct heat away from the package. A thermal grounded pad with thermal vias can achieve this.

In the table below, one can find the values for the Rthja and Rthjp, simulated according to the JESD-51 norm:

| Package | Rth<br>Junction-to-Leads and<br>Exposed Pad – Rthjp | Rth<br>Junction-to-Leads<br>Rthjp | Rth<br>Junction-to-Ambient<br>Rthja (1S0P) | Rth<br>Junction-to-Ambient<br>Rthja (2S2P) |
|---------|-----------------------------------------------------|-----------------------------------|--------------------------------------------|--------------------------------------------|
| SOIC-20 |                                                     | 19                                | 62                                         | 39                                         |
| NQFP-32 | 0,95                                                |                                   | 60                                         | 30                                         |

The Rthja for 2S2P is simulated conform to JESD–51 as follows:

- A 4-layer printed circuit board with inner power planes and outer (top and bottom) signal layers is used
- Board thickness is 1.46 mm (FR4 PCB material)
- The 2 signal layers: 70 μm thick copper with an area of 5500 mm<sup>2</sup> copper and 20% conductivity
- The 2 power internal planes: 36 μm thick copper with an area of 5500 mm<sup>2</sup> copper and 90% conductivity

The Rthja for 1S0P is simulated conform to JESD-51 as follows:

- A 1-layer printed circuit board with only 1 layer
- Board thickness is 1.46 mm (FR4 PCB material)
- The layer has a thickness of 70 μm copper with an area of 5500 mm<sup>2</sup> copper and 20% conductivity



Figure 3. Example of SOIC-20 PCB Ground Plane Layout (preferred layout at top and bottom)



Figure 4. Example of NQFP-32 PCB Ground Plane Layout (preferred layout at top and bottom)

# **DC PARAMETERS**

The DC parameters are guaranteed overtemperature and V<sub>BB</sub> in the operating range, unless otherwise specified. Convention: currents flowing into the circuit are defined as positive.

#### **Table 5. DC PARAMETERS**

| Symbol                  | Pin(s)                  | Parameter                                             | Test Conditions                    | Min | Тур  | Max | Unit |
|-------------------------|-------------------------|-------------------------------------------------------|------------------------------------|-----|------|-----|------|
| MOTORDRI                | /ER                     |                                                       |                                    |     |      |     |      |
| I <sub>MSmax,Peak</sub> |                         | Max current through motor coil<br>in normal operation | V <sub>BB</sub> = 14 V             |     | 800  |     | mA   |
| I <sub>MSmax,RMS</sub>  |                         | Max rms current through coil in normal operation      | V <sub>BB</sub> = 14 V             |     | 570  |     | mA   |
| I <sub>MSabs</sub>      |                         | Absolute error on coil<br>current (Note 4)            | $V_{BB} = 14 V$                    | -10 |      | 10  | %    |
| I <sub>MSrel</sub>      | MOTXP<br>MOTXN<br>MOTYP | Matching of X & Y<br>coil currents                    | V <sub>BB</sub> = 14 V             | -7  | 0    | 7   | %    |
| R <sub>DS(on)</sub>     | MOTYN                   | On resistance for each                                | $V_{BB}$ = 12 V, $T_j$ = 50°C      |     | 0.50 | 1   | Ω    |
|                         |                         | motor pin at I <sub>MSmax</sub><br>(Note 5)           | $V_{BB}$ = 8 V, $T_j$ = 50°C       |     | 0.55 | 1   | Ω    |
|                         |                         |                                                       | $V_{BB}$ = 12 V, $T_j$ = 150°C     |     | 0.70 | 1   | Ω    |
|                         |                         |                                                       | $V_{BB} = 8 V, T_j = 150^{\circ}C$ |     | 0.85 | 1   | Ω    |
| I <sub>MSL</sub>        |                         | Pulldown current                                      | HiZ mode, V <sub>BB</sub> = 7.8 V  |     | 2    |     | mA   |

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

| V <sub>IL</sub> |            | Input level low (Note 10)                                                             | -0.5                  | 0.3 * V <sub>DD</sub> | V |
|-----------------|------------|---------------------------------------------------------------------------------------|-----------------------|-----------------------|---|
| V <sub>IH</sub> |            | Input level high (Note 11)                                                            | 0.7 * V <sub>DD</sub> | V <sub>DD</sub> + 0.5 | V |
| V <sub>nL</sub> | SDA<br>SCK | Noise margin at the LOW level<br>for each connected device<br>(including hysteresis)  | 0.1 * V <sub>DD</sub> |                       | V |
| V <sub>nH</sub> |            | Noise margin at the HIGH level<br>for each connected device<br>(including hysteresis) | 0.2 * V <sub>DD</sub> |                       |   |

#### **THERMAL WARNING & SHUTDOWN**

| T <sub>tw</sub>  | Thermal warning<br>(Notes 6 and 7) | 138 | 145                   | 152 | °C |
|------------------|------------------------------------|-----|-----------------------|-----|----|
| T <sub>tsd</sub> | Thermal shutdown (Note 8)          |     | T <sub>tw</sub> + 10  |     | °C |
| T <sub>low</sub> | Low temperature warning (Note 8)   |     | T <sub>tw</sub> – 155 |     | °C |

#### SUPPLY AND VOLTAGE REGULATOR

| V <sub>bbOTP</sub> |                 | Supply voltage for OTP<br>zapping (Note 9) |                                            | 9.0 |      | 10.0 | V  |
|--------------------|-----------------|--------------------------------------------|--------------------------------------------|-----|------|------|----|
| UV <sub>1</sub>    |                 | Stop voltage high threshold                |                                            | 7.7 | 8.3  | 8.9  | V  |
| UV <sub>2</sub>    | V <sub>BB</sub> | Stop voltage low threshold                 |                                            | 7.0 | 7.5  | 8.0  | V  |
| I <sub>bat</sub>   |                 | Total current consumption                  | Unloaded outputs<br>V <sub>BB</sub> = 29 V |     | 3.50 | 10.0 | mA |

4. Tested in production for 800 mA, 400 mA, 200 mA and 100 mA current settings for both X and Y coil.

5. Not measured in production. Guaranteed by design. 6. Parameter guaranteed by trimming relevant OTP's in production test at 143°C ( $\pm$ 5°C) and V<sub>BB</sub> = 14 V.

7. No more than 100 cumulated hours in life time above Tw.

8. Thermal shutdown and low temperature warning are derived from thermal warning. Guaranteed by design. 9. A buffer capacitor of minimum 100  $\mu$ F is needed between V<sub>BB</sub> and GND. Short connections to the power supply are recommended. 10. If input voltages < – 0.3 V, than a resistor between 22  $\Omega$  to 100  $\Omega$  needs to be put in series. 11. If the I<sup>2</sup>C-bus is operated in Fast Mode V<sub>IHmin</sub> = 0.7 \* V<sub>DD</sub>.

# Table 5. DC PARAMETERS

| Symbol               | Pin(s)          | Parameter                                                    | Test Conditions                                            | Min                     | Тур                       | Max                   | Unit |
|----------------------|-----------------|--------------------------------------------------------------|------------------------------------------------------------|-------------------------|---------------------------|-----------------------|------|
| SUPPLY A             |                 | E REGULATOR                                                  |                                                            |                         |                           |                       |      |
| $V_{DD}$             |                 | Regulated internal supply (Note 12)                          | 8 V < V <sub>BB</sub> < 29 V                               | 4.75                    | 5                         | 5.50                  | V    |
| V <sub>ddReset</sub> | V <sub>DD</sub> | Digital supply reset level @ power down (Note 13)            |                                                            |                         |                           | 4.5                   | V    |
| I <sub>ddLim</sub>   |                 | Current limitation                                           | Pin shorted to ground<br>V <sub>BB</sub> = 14 V            |                         |                           | 45                    | mA   |
| SWITCH IN            | PUT AND H       | ARDWIRE ADDRESS INPUT                                        |                                                            |                         |                           |                       |      |
| Rt_OFF               |                 | Switch OPEN resistance<br>(Note 14)                          |                                                            | 10                      |                           |                       | kΩ   |
| Rt_ON                | SWI HW          | Switch ON resistance<br>(Note 14)                            | Switch to GND or $V_{BB}$                                  |                         |                           | 2                     | kΩ   |
| $V_{bb\_sw}$         | 1               | V <sub>BB</sub> range for guaranteed operation of SWI and HW |                                                            | 6                       |                           | 29                    | V    |
| I <sub>lim_sw</sub>  |                 | Current limitation                                           | Short to GND or V <sub>bat</sub><br>V <sub>BB</sub> = 29 V | 20                      | 30                        | 45                    | mA   |
| TEST PINS            | •               |                                                              |                                                            | •                       | 1                         |                       |      |
| V <sub>ihigh</sub>   |                 | Input level high                                             | V <sub>BB</sub> = 14 V                                     | 0.7 * V <sub>dd</sub>   |                           |                       | V    |
| V <sub>ilow</sub>    | TSTx            | Input level low                                              | V <sub>BB</sub> = 14 V                                     |                         |                           | 0.3 * V <sub>dd</sub> | V    |
| V <sub>ihyst</sub>   |                 | Hysteresis                                                   | V <sub>BB</sub> = 14 V                                     | 0.075 * V <sub>dd</sub> |                           |                       | V    |
| CHARGE P             | UMP             |                                                              |                                                            |                         |                           |                       | -    |
| V <sub>cp</sub>      |                 | Output voltage                                               | $7~V \leq V_{BB} \leq 14~V$                                |                         | 2 * V <sub>BB</sub> – 2.5 |                       | V    |
|                      | VCP             |                                                              | $14~V \leq V_{BB} \leq 30~V$                               | V <sub>BB</sub> + 10    |                           | V <sub>BB</sub> + 15  | V    |
| C <sub>buffer</sub>  |                 | External buffer capacitor                                    |                                                            | 220                     |                           | 470                   | nF   |
| C <sub>pump</sub>    | CPP<br>CPN      | External pump capacitor                                      |                                                            | 220                     |                           | 470                   | nF   |
| PACKAGE              | THERMAL         | RESISTANCE VALUES                                            |                                                            |                         |                           |                       |      |
| Rth <sub>ja</sub>    | SO              | Thermal resistance junction to ambient (2S2P)                |                                                            |                         | 39                        |                       | K/W  |
| Rth <sub>jp</sub>    | SO              | Thermal resistance junction to leads                         | Simulated conform                                          |                         | 19                        |                       | K/W  |
| Rth <sub>ja</sub>    | NQ              | Thermal resistance junction to ambient (2S2P)                | JEDEC JESD51                                               |                         | 30                        |                       | K/W  |
| Rth <sub>jp</sub>    | NQ              | Thermal resistance junction to leads and exposed pad         |                                                            |                         | 0.95                      |                       | K/W  |

12. Pin V<sub>DD</sub> must not be used for any external supply
13. The RAM content will not be altered above this voltage.
14. External resistance value seen from pin SWI or HW, including 1 kΩ series resistor. For the switch OPEN, the maximum allowed leakage current is represented by a minimum resistance seen from the pin.

# **AC PARAMETERS**

The AC parameters are guaranteed for temperature and  $V_{BB}$  in the operating range unless otherwise specified.

#### **Table 6. AC PARAMETERS**

| Symbol                  | Pin(s)     | Parameter                                                                                   | Test Conditions        | Min                        | Тур | Max               | Unit |
|-------------------------|------------|---------------------------------------------------------------------------------------------|------------------------|----------------------------|-----|-------------------|------|
| POWERUP                 |            | •                                                                                           |                        |                            |     |                   |      |
| T <sub>pu</sub>         |            | Power-up time                                                                               | Guaranteed by design   |                            |     | 10                | ms   |
| NTERNAL C               | OSCILLA    | TOR                                                                                         |                        |                            |     |                   |      |
| f <sub>osc</sub>        |            | Frequency of internal oscillator                                                            | V <sub>BB</sub> = 14 V | 3.6                        | 4.0 | 4.4               | MHz  |
| <sup>2</sup> C TRANSC   | EIVER (    | STANDARD MODE)                                                                              |                        |                            |     |                   |      |
| f <sub>SCL</sub>        |            | SCL clock frequency                                                                         |                        |                            |     | 100               | kHz  |
| t <sub>HD,START</sub>   |            | Hold time (repeated) START condition. After this period the first clock pulse is generated. |                        | 4.0                        |     |                   | μs   |
| t <sub>LOW</sub>        |            | LOW period of the SCK clock                                                                 |                        | 4.7                        |     |                   | μs   |
| t <sub>HIGH</sub>       |            | HIGH period of the SCK clock                                                                |                        | 4.0                        |     |                   | μs   |
| t <sub>SU,START</sub>   |            | Set-up time for a repeated START condition                                                  |                        | 4.7                        |     |                   | μs   |
| t <sub>HD,DATA</sub>    | SDA<br>SCK | Data hold time for I <sup>2</sup> C bus devices                                             |                        | 0<br>(Note 16)             |     | 3.45<br>(Note 17) | μs   |
| t <sub>SU,DATA</sub>    |            | Data set-up time                                                                            |                        | 250                        |     |                   | ns   |
| t <sub>R</sub>          |            | Rise time of SDA and SCK signals                                                            |                        |                            |     | 1.0               | μs   |
| t <sub>F</sub>          |            | Fall time of SDA and SCK signals                                                            |                        |                            |     | 0.3               | μs   |
| t <sub>SU,STOP</sub>    |            | Set-up time for STOP condition                                                              |                        | 4.0                        |     |                   | μs   |
| t <sub>BUF</sub>        |            | Bus free time between STOP and START condition                                              |                        | 4.7                        |     |                   | μs   |
| I <sup>2</sup> C TRANSC | EIVER (I   | FAST MODE)                                                                                  |                        |                            |     |                   |      |
| f <sub>SCL</sub>        |            | SCL clock frequency                                                                         |                        |                            |     | 360               | kHz  |
| t <sub>HD,START</sub>   |            | Hold time (repeated) START condition. After this period the first clock pulse is generated. |                        | 0.6                        |     |                   | μs   |
| t <sub>LOW</sub>        |            | LOW period of the SCK clock                                                                 |                        | 1.3                        |     |                   | μs   |
| t <sub>HIGH</sub>       |            | HIGH period of the SCK clock                                                                |                        | 0.6                        |     |                   | μs   |
| t <sub>SU,START</sub>   |            | Set-up time for a repeated START condition                                                  |                        | 0.6                        |     |                   | μs   |
| t <sub>HD,DATA</sub>    | SDA        | Data hold time for I <sup>2</sup> C bus devices                                             |                        | 0<br>(Note 16)             |     | 0.9<br>(Note 17)  | μs   |
| t <sub>SU,DATA</sub>    | SCK        | Data set-up time                                                                            |                        | 100<br>(Note 18)           |     |                   | ns   |
| t <sub>R</sub>          |            | Rise time of SDA and SCK signals                                                            |                        | 20 +<br>0.1 C <sub>B</sub> |     | 300               | ns   |
| t <sub>F</sub>          |            | Fall time of SDA and SCK signals                                                            |                        | 20 +<br>0.1 C <sub>B</sub> |     | 300               | ns   |
| t <sub>SU,STOP</sub>    |            | Set-up time for STOP condition                                                              |                        | 0.6                        |     |                   | μs   |
| t <sub>BUF</sub>        |            | Bus free time between STOP and START condition                                              |                        | 1.3                        |     |                   | μs   |

15. The maximum number of connected I<sup>2</sup>C devices is dependent on the number of available addresses and the maximum bus capacitance to still guarantee the rise and fall times of the bus signals. 16. An I<sup>2</sup>C device must internally provide a hold time of at least 300 ns for the SDA signal (referred to the V<sub>IHmin</sub> of the SCL signal) to bridge

the undefined region of the falling edge of SCL.

17. The maximum  $t_{HD,DAT}$  has only to be met if the device does not stretch the LOW period ( $t_{LOW}$ ) of the SCL signal. 18. A Fast-mode I<sup>2</sup>C-bus device can be used in a standard-mode I<sup>2</sup>C bus system, but the requirement  $t_{SU,DATA} \ge 250$  ns must than be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line trmax +  $t_{SU,DATA} = 1000 + 250 = 1250$  ns (according to the standard-mode I<sup>2</sup>C-bus specification) before the SCL line is released.

# Table 6. AC PARAMETERS

| Symbol             | Pin(s)    | Parameter                                | Test Conditions        | Min | Тур                | Max | Unit |
|--------------------|-----------|------------------------------------------|------------------------|-----|--------------------|-----|------|
| WITCH IN           | PUT AND   | HARDWIRE ADDRESS INPUT                   |                        |     |                    |     | -    |
| T <sub>sw</sub>    | 0)4/1     | Scan pulse period (Note 19)              | V <sub>BB</sub> = 14 V |     | 1024               |     | μs   |
| T <sub>sw_on</sub> | SWI<br>HW | Scan pulse duration<br>(Note 19)         | V <sub>BB</sub> = 14 V |     | 64                 |     | μs   |
| IOTORDRI           | VER       | -                                        |                        |     |                    |     | -    |
| F <sub>pwm</sub>   |           | PWM frequency (Note 19)                  |                        | 18  | 20                 | 22  | kHz  |
| T <sub>brise</sub> | MOTIN     | Turn-on transient time                   | Between 10% and 90%    |     | 140                |     | ns   |
| T <sub>bfall</sub> | MOTxx     | Turn-off transient time                  |                        |     | 130                |     | ns   |
|                    |           | Run current stabilization time (Note 19) |                        |     | 1/V <sub>min</sub> |     | ms   |

#### 

19. Derived from the internal oscillator

20.See <u>SetMotorParam</u>



Figure 5. I<sup>2</sup>C Timing Diagrams

# **Typical Application**



Figure 6. Typical Application Diagram for SO Device

NOTES: All resistors are  $\pm$  5%, 1/4 W

C1, C2 minimum value is 2.7 nF, maximum value is 10 nF

Depending on the application, the ESR value and working voltage of C<sub>7</sub> must be carefully chosen C<sub>3</sub> and C<sub>4</sub> must be close to pins V<sub>BB</sub> and GND

 $C_5$  and  $C_6$  must be as close as possible to pins CPN, CPP, VCP, and  $V_{BB}$  to reduce EMC radiation  $C_9$  must be a ceramic capacitor to assure low ESR

# **POSITIONING PARAMETERS**

# **Stepping Modes**

One of four possible stepping modes can be programmed:

- Half-stepping
- 1/4 micro-stepping
- 1/8 micro-stepping
- 1/16 micro-stepping

# Maximum Velocity

For each stepping mode, the maximum velocity Vmax can be programmed to 16 possible values given in the table below.

The accuracy of Vmax is derived from the internal oscillator. Under special circumstances it is possible to change the Vmax parameter while a motion is ongoing. All 16 entries for the Vmax parameter are divided into four groups. When changing Vmax during a motion the application must take care that the new Vmax parameter stays within the same group.

| Vmax | Index |                       |       |                                | Stepping                                              | Mode                                                  |                                                        |
|------|-------|-----------------------|-------|--------------------------------|-------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------|
| Hex  | Dec   | Vmax<br>(full step/s) | Group | Half–stepping<br>(half–step/s) | 1/4 <sup>th</sup><br>Micro–stepping<br>(micro–step/s) | 1/8 <sup>th</sup><br>Micro–stepping<br>(micro–step/s) | 1/16 <sup>th</sup><br>Micro-stepping<br>(micro-step/s) |
| 0    | 0     | 99                    | А     | 197                            | 395                                                   | 790                                                   | 1579                                                   |
| 1    | 1     | 136                   |       | 273                            | 546                                                   | 1091                                                  | 2182                                                   |
| 2    | 2     | 167                   |       | 334                            | 668                                                   | 1335                                                  | 2670                                                   |
| 3    | 3     | 197                   | P     | 395                            | 790                                                   | 1579                                                  | 3159                                                   |
| 4    | 4     | 213                   | В     | 425                            | 851                                                   | 1701                                                  | 3403                                                   |
| 5    | 5     | 228                   |       | 456                            | 912                                                   | 1823                                                  | 3647                                                   |
| 6    | 6     | 243                   |       | 486                            | 973                                                   | 1945                                                  | 3891                                                   |
| 7    | 7     | 273                   |       | 546                            | 1091                                                  | 2182                                                  | 4364                                                   |
| 8    | 8     | 303                   |       | 607                            | 1213                                                  | 2426                                                  | 4852                                                   |
| 9    | 9     | 334                   | с     | 668                            | 1335                                                  | 2670                                                  | 5341                                                   |
| А    | 10    | 364                   | C     | 729                            | 1457                                                  | 2914                                                  | 5829                                                   |
| В    | 11    | 395                   |       | 790                            | 1579                                                  | 3159                                                  | 6317                                                   |
| С    | 12    | 456                   |       | 912                            | 1823                                                  | 3647                                                  | 7294                                                   |
| D    | 13    | 546                   |       | 1091                           | 2182                                                  | 4364                                                  | 8728                                                   |
| E    | 14    | 729                   | D     | 1457                           | 2914                                                  | 5829                                                  | 11658                                                  |
| F    | 15    | 973                   |       | 1945                           | 3891                                                  | 7782                                                  | 15564                                                  |

# Table 7. MAXIMUM VELOCITY SELECTION TABLE

# **Minimum Velocity**

Once the maximum velocity is chosen, 16 possible values can be programmed for the minimum velocity Vmin. The table below provides the obtainable values in full-step/s. The accuracy of Vmin is derived from the internal oscillator.

|      |       |        |    |     |     |     |     |     | Vn  | nax (Fu | II-step | /s) |     |     |     |     |     |     |
|------|-------|--------|----|-----|-----|-----|-----|-----|-----|---------|---------|-----|-----|-----|-----|-----|-----|-----|
| Vmin | Index | Vmax   | Α  |     |     | E   | 3   |     |     |         |         |     | D   |     |     |     |     |     |
| Hex  | Dec   | Factor | 99 | 136 | 167 | 197 | 213 | 228 | 243 | 273     | 303     | 334 | 364 | 395 | 456 | 546 | 729 | 973 |
| 0    | 0     | 1      | 99 | 136 | 167 | 197 | 213 | 228 | 243 | 273     | 303     | 334 | 364 | 395 | 456 | 546 | 729 | 973 |
| 1    | 1     | 1/32   | 3  | 4   | 5   | 6   | 6   | 7   | 7   | 8       | 8       | 10  | 10  | 11  | 13  | 15  | 19  | 27  |
| 2    | 2     | 2/32   | 6  | 8   | 10  | 11  | 12  | 13  | 14  | 15      | 17      | 19  | 21  | 23  | 27  | 31  | 42  | 57  |
| 3    | 3     | 3/32   | 9  | 12  | 15  | 18  | 19  | 21  | 22  | 25      | 27      | 31  | 32  | 36  | 42  | 50  | 65  | 88  |
| 4    | 4     | 4/32   | 12 | 16  | 20  | 24  | 26  | 28  | 30  | 32      | 36      | 40  | 44  | 48  | 55  | 65  | 88  | 118 |
| 5    | 5     | 5/32   | 15 | 21  | 26  | 31  | 32  | 35  | 37  | 42      | 46      | 51  | 55  | 61  | 71  | 84  | 111 | 149 |
| 6    | 6     | 6/32   | 18 | 25  | 31  | 36  | 39  | 42  | 45  | 50      | 55      | 61  | 67  | 72  | 84  | 99  | 134 | 179 |
| 7    | 7     | 7/32   | 21 | 30  | 36  | 43  | 46  | 50  | 52  | 59      | 65      | 72  | 78  | 86  | 99  | 118 | 156 | 210 |
| 8    | 8     | 8/32   | 24 | 33  | 41  | 49  | 52  | 56  | 60  | 67      | 74      | 82  | 90  | 97  | 113 | 134 | 179 | 240 |
| 9    | 9     | 9/32   | 28 | 38  | 47  | 55  | 59  | 64  | 68  | 76      | 84      | 93  | 101 | 111 | 128 | 153 | 202 | 271 |
| А    | 10    | 10/32  | 31 | 42  | 51  | 61  | 66  | 71  | 75  | 84      | 93      | 103 | 113 | 122 | 141 | 168 | 225 | 301 |
| В    | 11    | 11/32  | 34 | 47  | 57  | 68  | 72  | 78  | 83  | 93      | 103     | 114 | 124 | 135 | 156 | 187 | 248 | 332 |
| С    | 12    | 12/32  | 37 | 51  | 62  | 73  | 79  | 85  | 91  | 101     | 113     | 124 | 135 | 147 | 170 | 202 | 271 | 362 |
| D    | 13    | 13/32  | 40 | 55  | 68  | 80  | 86  | 93  | 98  | 111     | 122     | 135 | 147 | 160 | 185 | 221 | 294 | 393 |
| Е    | 14    | 14/32  | 43 | 59  | 72  | 86  | 93  | 99  | 106 | 118     | 132     | 145 | 158 | 172 | 198 | 237 | 317 | 423 |
| F    | 15    | 15/32  | 46 | 64  | 78  | 93  | 99  | 107 | 113 | 128     | 141     | 156 | 170 | 185 | 214 | 256 | 340 | 454 |

| Table 8. OBTAINABLE VALUES IN FULL-STEP/s FOR THE MINIM |  |
|---------------------------------------------------------|--|
| Table 6. OBTAINABLE VALUES IN FULL-STEP/S FOR THE MINIM |  |

NOTES: The Vmax factor is an approximation.

In case of motion without acceleration (AccShape = 1) the length of the steps = 1/Vmin. In case of accelerated motion (AccShape = 0) the length of the first step is shorter than 1/Vmin depending of Vmin, Vmax and Acc.

# Acceleration and Deceleration

Sixteen possible values can be programmed for Acc (acceleration and deceleration between Vmin and Vmax). The table below provides the obtainable values in full–step/s<sup>2</sup>. One observes restrictions for some

combinations of acceleration index and maximum speed (gray cells).

The accuracy of Acc is derived from the internal oscillator.

#### Table 9. ACCELERATION AND DECELERATION SELECTION TABLE

|      | Vmax (FS/s) → | 99    | 136 | 167 | 197 | 213  | 228 | 243    | 273     | 303     | 334    | 364 | 395 | 456 | 546 | 729 | 973 |
|------|---------------|-------|-----|-----|-----|------|-----|--------|---------|---------|--------|-----|-----|-----|-----|-----|-----|
| ↓ Ac | c Index       |       |     |     |     |      |     |        |         |         |        |     |     |     |     |     |     |
| Hex  | Dec           |       |     |     |     |      | Ac  | celera | tion (F | ull-ste | ep/s²) |     |     |     |     |     |     |
| 0    | 0             |       |     |     | 49  |      |     |        |         |         | 10     | 06  |     |     |     | 473 |     |
| 1    | 1             |       |     |     |     |      |     |        |         | 218     |        |     |     |     |     | 735 |     |
| 2    | 2             |       |     |     |     |      |     |        |         | 1004    |        |     |     |     |     |     |     |
| 3    | 3             |       |     |     |     |      |     |        |         | 3609    |        |     |     |     |     |     |     |
| 4    | 4             |       |     |     |     |      |     |        |         | 6228    |        |     |     |     |     |     |     |
| 5    | 5             |       |     |     |     |      |     |        |         | 8848    |        |     |     |     |     |     |     |
| 6    | 6             |       |     |     |     |      |     |        |         | 11409   |        |     |     |     |     |     |     |
| 7    | 7             |       |     |     |     |      |     |        |         | 13970   |        |     |     |     |     |     |     |
| 8    | 8             |       |     |     |     |      |     |        |         | 16531   |        |     |     |     |     |     |     |
| 9    | 9             |       |     |     |     |      |     |        |         | 19092   |        |     |     |     |     |     |     |
| А    | 10            |       |     |     |     |      |     |        |         | 21886   |        |     |     |     |     |     |     |
| В    | 11            |       |     |     |     |      |     |        |         | 24447   |        |     |     |     |     |     |     |
| С    | 12            | 14785 |     |     |     |      |     |        |         | 27008   |        |     |     |     |     |     |     |
| D    | 13            |       |     |     |     |      |     |        |         | 29570   |        |     |     |     |     |     |     |
| E    | 14            |       |     |     | 201 | = 70 |     |        |         | 34925   |        |     |     |     |     |     |     |
| F    | 15            |       |     |     | 29: | 570  |     |        |         | 40047   |        |     |     |     |     |     |     |

The formula to compute the number of equivalent full-steps during acceleration phase is:

$$Nstep = \frac{Vmax^2 - Vmin^2}{2 \times Acc}$$

#### Positioning

The position programmed in command <u>SetPosition</u> is given as a number of (micro-)steps. According to the chosen stepping mode, the position words must be aligned as described in the table below. When using command <u>GotoSecurePosition</u>, data is automatically aligned.

#### Table 10. POSITION WORD ALIGNMENT

| Stepping Mode      |   |     |     |     |     | Po  | ositior | n Word | d: Pos | [15:0 | ומ  |    |     |     |     |     | Shift           |
|--------------------|---|-----|-----|-----|-----|-----|---------|--------|--------|-------|-----|----|-----|-----|-----|-----|-----------------|
| 1/16 <sup>th</sup> | S | B14 | B13 | B12 | B11 | B10 | B9      | B8     | B7     | B6    | B5  | B4 | B3  | B2  | B1  | LSB | No shift        |
| 1/8 <sup>th</sup>  | S | B13 | B12 | B11 | B10 | B9  | B8      | B7     | B6     | B5    | B4  | B3 | B2  | B1  | LSB | 0   | 1–bit left ⇔ ×2 |
| 1/4 <sup>th</sup>  | S | B12 | B11 | B10 | B9  | B8  | B7      | B6     | B5     | B4    | B3  | B2 | B1  | LSB | 0   | 0   | 2–bit left ⇔×4  |
| Half-stepping      | S | B11 | B10 | B9  | B8  | B7  | B6      | B5     | B4     | B3    | B2  | B1 | LSB | 0   | 0   | 0   | 3–bit left ⇔×8  |
| SecurePosition     | S | B9  | B8  | B7  | B6  | B5  | B4      | B3     | B2     | B1    | LSB | 0  | 0   | 0   | 0   | 0   | No shift        |

NOTES: LSB: Least Significant Bit S: Sign bit

# **Position Ranges**

A position is coded by using the binary two's complement format. According to the positioning commands used and to the chosen stepping mode, the position range will be as shown in the following table.

| Command     | Stepping Mode                     | Position Range   | Full Range Excursion | Number of Bits |
|-------------|-----------------------------------|------------------|----------------------|----------------|
|             | Half-stepping                     | -4096 to +4095   | 8192 half-steps      | 13             |
|             | 1/4 <sup>th</sup> micro-stepping  | -8192 to +8191   | 16384 micro-steps    | 14             |
| SetPosition | 1/8 <sup>th</sup> micro-stepping  | -16384 to +16383 | 32768 micro-steps    | 15             |
|             | 1/16 <sup>th</sup> micro-stepping | -32768 to +32767 | 65536 micro-steps    | 16             |

#### Table 11. POSITION RANGE

When using the command <u>SetPosition</u>, although coded on 16 bits, the position word will have to be shifted to the left by a certain number of bits, according to the stepping mode.

#### Secure Position

A secure position can be programmed. It is coded in 11-bits, thus having a lower resolution than normal positions, as shown in the following table. See also command <u>GotoSecurePosition</u>.

# Table 12. SECURE POSITION

| Stepping Mode                     | Secure Position Resolution           |
|-----------------------------------|--------------------------------------|
| Half-stepping                     | 4 half-steps                         |
| 1/4 <sup>th</sup> micro-stepping  | 8 micro-steps (1/4 <sup>th</sup> )   |
| 1/8 <sup>th</sup> micro-stepping  | 16 micro-steps (1/8 <sup>th</sup> )  |
| 1/16 <sup>th</sup> micro-stepping | 32 micro-steps (1/16 <sup>th</sup> ) |

#### Important

NOTES: The secure position is disabled in case the programmed value is the reserved code "1000000000" (0x400 or most negative position).

The resolution of the secure position is limited to 9 bit at start-up. The OTP register is copied in RAM as illustrated below. The RAM bits SecPos1 and SecPos0 are set to 0.



#### Shaft

A shaft bit, which can be programmed in <u>OTP</u> or with command <u>SetMotorParam</u>, defines whether a positive motion is a clockwise (CW) or counter-clockwise rotation (CCW) (an outer or an inner motion for linear actuators):

# STRUCTURAL DESCRIPTION

See also the Block Diagram in Figure 1.

#### **Stepper Motordriver**

The Motordriver receives the control signals from the control logic. The main features are:

• Two H-bridges, designed to drive a stepper motor with two separated coils. Each coil (X and Y) is driven by one H-bridge, and the driver controls the currents flowing through the coils. The rotational position of the rotor, in unloaded condition, is defined by the ratio of current flowing in X and Y. The torque of the stepper motor when unloaded is controlled by the magnitude of the currents in X and Y.

• Shaft =  $0 \Rightarrow$  MOTXP is used as positive pin of the X

• The control block for the H-bridges, including the PWM control, the synchronous rectification and the

coil, while MOTXN is the negative one.

• Shaft =  $1 \Rightarrow$  opposite situation

- The charge pump to allow driving of the H-bridges'
- high side transistors.Two pre-scale 4-bit DAC's to set the maximum
- Two pre-scale 4-bit DAC's to set the maximum magnitude of the current through X and Y.
- Two DAC's to set the correct current ratio through X and Y.

Battery voltage monitoring is also performed by this block, which provides the required information to the control logic part. The same applies for detection and reporting of an electrical problem that could occur on the coils or the charge pump.

#### **Control Logic (Position Controller and Main Control)**

The control logic block stores the information provided by the  $I^2C$  interface (in a RAM or an OTP memory) and digitally controls the positioning of the stepper motor in terms of speed and acceleration, by feeding the right signals to the motordriver state machine.

It will take into account the successive positioning commands to properly initiate or stop the stepper motor in order to reach the set point in a minimum time.

It also receives feedback from the motordriver part in order to manage possible problems and decide on internal actions and reporting to the  $I^2C$  interface.

Miscellaneous

The AMIS-30622 also contains the following:

- An internal oscillator, needed for the control logic handler as well as the control logic and the PWM control of the motordriver.
- An internal trimmed voltage source for precise referencing.
- A protection block featuring a thermal shutdown and a power-on-reset circuit.
- A 5 V regulator (from the battery supply) to supply the internal logic circuitry.

# **FUNCTIONS DESCRIPTION**

This chapter describes the following functional blocks in more detail:

#### Position controller

- Main control and register, OTP memory + ROM
- Motordriver

# **Position Controller**

#### **Positioning and Motion Control**

A positioning command will produce a motion as illustrated in Figure 7. A motion starts with an acceleration phase from minimum velocity (Vmin) to maximum velocity (Vmax) and ends with a symmetrical deceleration. This is defined by the control logic according to the position required by the application and the parameters programmed by the application during the configuration phase. The current in the coils is also programmable.



Figure 7. Positioning and Motion Control

# Table 13. POSITION RELATED PARAMETERS

| Parameter                     | Reference                         |
|-------------------------------|-----------------------------------|
| Pmax – Pmin                   | See Positioning                   |
| Zero Speed Hold Current       | See <u>lhold</u>                  |
| Maximum Current               | See Irun                          |
| Acceleration and Deceleration | See Acceleration and Deceleration |
| Vmin                          | See <u>Minimum Velocity</u>       |
| Vmax                          | See Maximum Velocity              |

Different positioning examples are shown in the table below.

# Table 14. POSITIONING EXAMPLES

| Short motion.                                                                                                        | Velocity   |
|----------------------------------------------------------------------------------------------------------------------|------------|
|                                                                                                                      | time       |
| New positioning command in same dir-<br>ection, shorter or longer, while a motion<br>is running at maximum velocity. | Velocity   |
| New positioning command in same dir-<br>ection while in deceleration phase<br>(Note 21)                              | ▲ Velocity |
| Note: there is no wait time between the deceleration phase and the new acceleration phase.                           | time       |
| New positioning command in reverse<br>direction while motion is running at max-<br>imum velocity.                    | Velocity   |
| New positioning command in reverse<br>direction while in deceleration phase.                                         | Velocity   |
| New velocity programming while motion is running.                                                                    | Velocity   |

21. Reaching the end position is always guaranteed, however velocity rounding errors might occur after consecutive accelerations during a deceleration phase. The velocity rounding error will be removed at Vmin (e.g. at end of acceleration or when AccShape=1).

#### **Dual Positioning**

A <u>SetDualPosition</u> command allows the user to perform a positioning using two different velocities. The first motion is done with the specified Vmin and Vmax velocities in the <u>SetDualPosition</u> command, with the acceleration (deceleration) parameter already in RAM, to a position Pos1[15:0] also specified in <u>SetDualPosition</u>.

Then a second motion to a physical position Pos2[15:0] is done at the specified Vmin velocity in the

<u>SetDualPosition</u> command (no acceleration). Once the second motion is achieved, the ActPos register is reset to zero, whereas TagPos register is not changed.

When the Secure position is enabled, after the dual positioning, the secure positioning is executed. The figure below gives a detailed overview of the dual positioning function. After the dual positioning is executed an internal flag is set to indicate the AMIS-30622 is referenced.



Figure 8. Dual Positioning

**Remark:** This operation cannot be interrupted or influenced by any further command unless the occurrence of the conditions driving to a motor shutdown or by a <u>HardStop</u> command. Sending a <u>SetDualPosition</u> command while a motion is already ongoing is not recommended.

22. The priority encoder is describing the management of states and commands.

- 23. A DualPosition sequence starts by setting TagPos buffer register to SecPos value, provided secure position is enabled otherwise TagPos is reset to zero. If a SetPosition(Short) command is issued during a DualPosition sequence, it will be kept in the position buffer memory and executed afterwards. This applies also for the command <u>GotoSecurePosition</u>.
- 24. Commands such as GetFullStatus1 or GetFullStatus2 will be executed while a Dual Positioning is running.
- 25. The Pos1, Pos2, Vmax and Vmin values programmed in a <u>SetDualPosition</u> command apply only for this sequence. All other motion parameters are used from the RAM registers (programmed for instance by a former SetMotorParam command). After the DualPosition motion is completed, the former Vmin and Vmax become active again.
- 26. Commands ResetPosition, SetDualPosition, and SoftStop will be ignored while a DualPosition sequence is ongoing, and will not be executed afterwards.
- 27. Recommendation: a SetMotorParam command should not be sent during a <u>SetDualPosition</u> sequence: all the motion parameters defined in the command, except Vmin and Vmax, become active immediately.

#### **Position Periodicity**

Depending on the stepping mode the position can range from -4096 to +4095 in half-step to -32768 to +32767 in 1/16th micro-stepping mode. One can project all these positions lying on a circle. When executing the command <u>SetPosition</u>, the position controller will set the movement direction in such a way that the traveled distance is minimal. The figure below illustrates that the moving direction going from ActPos = +30000 to TagPos = -30000 is clockwise.

If a counter clockwise motion is required in this example, several consecutive <u>SetPosition</u> commands can be used.



Figure 9. Motion Direction is Function of Difference between ActPos and TagPos

#### Hardwired Address HW

In the drawing below, a simplified schematic diagram is shown of the HW comparator circuit.

The HW pin is sensed via 2 switches. The DriveHS and DriveLS control lines are alternatively closing the top and bottom switch connecting HW pin with a current to resistor converter. Closing  $S_{TOP}$  (DriveHS = 1) will sense a current to GND. In that case the top I $\rightarrow$  R converter output is low, via the closed passing switch  $S_{PASS_T}$  this signal is fed to the "R" comparator which output HW\_Cmp is high. Closing bottom switch  $S_{BOT}$  (DriveLS = 1) will sense a current to  $V_{BAT}$ . The corresponding I  $\rightarrow$  R converter output is low and via  $S_{PASS_B}$  fed to the comparator. The output HW\_Cmp will be high.



Figure 10. Simplified Schematic Diagram of the HW Comparator

3 cases can be distinguished (see also Figure 10 above):

- HW is connected to ground: R2GND or drawing 1
- HW is connected to VBAT: R2VBAT or drawing 2
- HW is floating: OPEN or drawing 3

| Previous State | DriveLS | DriveHS | HW_Cmp | New State | Condition      | Drawing |
|----------------|---------|---------|--------|-----------|----------------|---------|
| Float          | 1       | 0       | 0      | Float     | R2GND or OPEN  | 1 or 3  |
| Float          | 1       | 0       | 1      | High      | R2VBAT         | 2       |
| Float          | 0       | 1       | 0      | Float     | R2VBAT or OPEN | 2 or 3  |
| Float          | 0       | 1       | 1      | Low       | R2GND          | 1       |
| Low            | 1       | 0       | 0      | Low       | R2GND or OPEN  | 1 or 3  |
| Low            | 1       | 0       | 1      | High      | R2VBAT         | 2       |
| Low            | 0       | 1       | 0      | Float     | R2VBAT or OPEN | 2 or 3  |
| Low            | 0       | 1       | 1      | Low       | R2GND          | 1       |
| High           | 1       | 0       | 0      | Float     | R2GND or OPEN  | 1 or 3  |
| High           | 1       | 0       | 1      | High      | R2VBAT         | 2       |
| High           | 0       | 1       | 0      | High      | R2VBAT or OPEN | 2 or 3  |
| High           | 0       | 1       | 1      | Low       | R2GND          | 1       |

# Table 15. STATE DIAGRAM OF THE HW COMPARATOR

The logic is controlling the correct sequence in closing the switches and in interpreting the 32  $\mu$ s debounced HW\_Cmp output accordingly. The output of this small state-machine is corresponding to:

As illustrated in the table above (Table 15), the state is depending on the previous state, the condition of the 2 switch controls (DriveLS and DriveHS) and the output of HW\_Cmp. Figure 11 shows an example of a practical case where a connection to VBAT is interrupted.

- High or address = 1
- Low or address = 0
- Floating



Figure 11. Timing Diagram Showing the Change in States for HW Comparator

#### R2VBAT

A resistor is connected between VBAT and HW. Every 1024  $\mu$ s S<sub>BOT</sub> is closed and a current is sensed. The output of the I  $\Rightarrow$  R converter is low and the HW\_Cmp output is high. Assuming the previous state was floating, the internal logic will interpret this as a change of state and the new state will be high (see also Table 15). The next time S<sub>BOT</sub> is closed the same conditions are observed. The previous state was high so based on Table 15 the new state remains unchanged. This high state will be interpreted as HW address = 1.

#### OPEN

In case the HW connection is lost (broken wire, bad contact in connector) the next time  $S_{BOT}$  is closed, this will be sensed. There will be no current, the output of the corresponding I  $\Rightarrow$  R converter is high and the HW\_Cmp will be low. The previous state was high. Based in Table 15 one can see that the state changes to float. This will trigger

a motion to secure position after a debounce time of 64 ms, which prevents false triggering in case of microinterruptions of the power supply.

#### R2GND

If a resistor is connected between HW and the GND, a current is sensed every 1024  $\mu$ s when S<sub>TOP</sub> is closed. The output of the top I  $\Rightarrow$  R converter is low and as a result the HW\_Cmp output switches to high. Again based on the stated diagram in Table 15 one can see that the state will change to Low. This low state will be interpreted as HW address = 0.

#### **External Switch SWI**

As illustrated in Figure 12 the SWI comparator is almost identical to HW. The major difference is in the limited number of states. Only open or closed is recognized leading to respectively ESW = 0 and ESW = 1.



Figure 12. Simplified Schematic Diagram of the SWI Comparator

As illustrated in the drawing above, a change in state is always synchronized with DriveHS or DriveLS. The same synchronization is valid for updating the internal position register. This means that after every current pulse (or closing of  $S_{TOP}$  or  $S_{BOT}$ ) the state of the position switch together with the corresponding position is memorized. The <u>FullStatus1</u> command reads back the <ActPos> register and the status of ESW. In this way the master node may get synchronous information about the state of the switch together with the position of the motor. See Table 16 below.

|      | GetFullStatus1 Response Frame |             |                        |       |       |            |       |       |        |  |
|------|-------------------------------|-------------|------------------------|-------|-------|------------|-------|-------|--------|--|
|      |                               | Structure   |                        |       |       |            |       |       |        |  |
| Byte | Content                       | Bit 7       | Bit 6                  | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1 | Bit 0  |  |
| 0    | Address                       | 1           | 1                      | OTP3  | OTP2  | OTP1       | OTP0  | HW    | 1      |  |
| 1    | Address                       | 1           | 1                      | 1     | OTP3  | OTP2       | OTP1  | OTP0  | HW     |  |
| 2    | Data 1                        | Irun[3:0]   |                        |       |       | Ihold[3:0] |       |       |        |  |
| 3    | Data 2                        |             | Vmax[                  | 3:0]  |       | Vmin[3:0]  |       |       |        |  |
| 4    | Data 3                        | AccShape    | AccShape StepMode[1:0] |       |       | Acc[3:0]   |       |       |        |  |
| 5    | Data 4                        | VddReset    | StepLoss               | ElDef | UV2   | TSD        | TW    | Tinfo | p[1:0] |  |
| 6    | Data 5                        | Motion[2:0] |                        |       | ESW   | OVC1       | OVC2  | 1     | CPFail |  |
| 7    | Data 6                        | 1           | 1                      | 1     | 1     | 1          | 1     | 1     | 1      |  |
| 8    | Data 7                        | 1           | 1                      | 1     | 1     | 1          | 1     | 1     | 1      |  |

#### Table 16. GetFullStatus1 I<sup>2</sup>C COMMAND



Figure 13. Simplified Timing Diagram Showing the Change in States for SWI Comparator

#### Main Control and Register, OTP memory + ROM

#### Power-up Phase

Power–up phase of the AMIS–30622 will not exceed 10 ms. After this phase, the AMIS–30622 is in standby mode, ready to receive I<sup>2</sup>C messages and execute the associated commands. After power–up, the registers and flags are in the reset state, while some of them are being loaded with the OTP memory content (see Table 19: RAM Registers).

#### Reset

After power-up, or after a reset occurrence (e.g. a micro-cut on pin  $V_{BB}$  has made  $V_{DD}$  to go below VddReset

level), the H-bridges will be in high-impedance mode, and the registers and flags will be in a predetermined position. This is documented in Table 19: RAM Registers and Table 20: Flags Table.

#### Soft-stop

A soft-stop is an immediate interruption of a motion, but with a deceleration phase. At the end of this action, the register <TagPos> is loaded with the value contained in register <ActPos>, see Table 19: Ram Registers). The circuit is then ready to execute a new positioning command, provided thermal and electrical conditions allow for it.

# **Thermal Shutdown Mode**

When thermal shutdown occurs, the circuit performs a <SoftStop> command and goes to motor shutdown mode (see Figure 14: State Diagram Temperature Management).

#### **Temperature Management**

The AMIS-30622 monitors temperature by means of two thresholds and one shutdown level, as illustrated in the state

diagram and illustration of Figure 14: State Diagram Temperature Management below. The only condition to reset flags <TW> and <TSD> (respectively thermal warning and thermal shutdown) is to be at a temperature lower than Ttw and to get the occurrence of a GetFullStatus1  $I^2C$  frame.



Figure 14. State Diagram Temperature Management



Figure 15. Illustration of Thermal Management Situation

#### **Battery Voltage Management**

The AMIS-30622 monitors the battery voltage by means of one threshold and one shutdown level. The only condition

to reset flags <UV2> and <StepLoss> is to recover by a battery voltage higher than UV1 and to receive a <u>GetFullStatus1</u> command.



Figure 16. State Diagram Battery Voltage Management

In **Stop mode 1** the motor is put in shutdown state. The <UV2> **flag** is set. In case  $V_{BB}$  > UV1, AMIS-30622 accepts updates of the target position by means of the reception of <u>SetPosition</u> or <u>GotoSecurePosition</u> commands, only AFTER the <UV2> flag is cleared by receiving a <u>GetFullStatus1</u> or <u>GetFullStatus2</u> command.

In **Stop mode 2** the motor is stopped immediately and put in shutdown state. The <UV2> and <Steploss> **flags** are set. In case  $V_{BB}$  > UV1, AMIS-30622 accepts updates of the target position by means of the reception of <u>SetPosition</u> or <u>GotoSecurePosition</u> commands, only AFTER the <UV2> and <Steploss> flags are cleared by receiving a <u>GetFullStatus1</u> or <u>GetFullStatus2</u> command.

#### Important Notes:

- In the case of Stop mode 2, care needs to be taken because the accumulated steploss can cause a significant deviation between physical and stored actual position.
- The <u>SetDualPosition</u> command will only be executed after clearing the <UV2> and <Steploss> flags.
- RAM reset occurs when V<sub>DD</sub> < V<sub>DD</sub>Reset (digital POR level).

# **OTP Register**

#### **OTP Memory Structure**

The table below shows how the parameters to be stored in the OTP memory are located.

|         |          |         | -       | -       | -         |           |         |         |
|---------|----------|---------|---------|---------|-----------|-----------|---------|---------|
| Address | Bit 7    | Bit 6   | Bit 5   | Bit 4   | Bit 3     | Bit 2     | Bit 1   | Bit 0   |
| 0x00    | OSC3     | OSC2    | OSC1    | OSC0    | IREF3     | IREF2     | IREF1   | IREF0   |
| 0x01    | 0        | TSD2    | TSD1    | TSD0    | BG3       | BG2       | BG1     | BG0     |
| 0x02    |          |         |         |         | PA3       | PA2       | PA1     | PA0     |
| 0x03    | Irun3    | Irun2   | Irun1   | lrun0   | lhold3    | lhold2    | lhold1  | lhold0  |
| 0x04    | Vmax3    | Vmax2   | Vmax1   | Vmax0   | Vmin3     | Vmin2     | Vmin1   | Vmin0   |
| 0x05    | SecPos10 | SecPos9 | SecPos8 | Shaft   | Acc3      | Acc2      | Acc1    | Acc0    |
| 0x06    | SecPos7  | SecPos6 | SecPos5 | SecPos4 | SecPos3   | SecPos2   | SecPos1 | SecPos0 |
| 0x07    |          |         |         |         | StepMode1 | StepMode0 | LOCKBT  | LOCKBG  |

#### Table 17. OTP MEMORY STRUCTURE

Parameters stored at address 0x00 and 0x01 and bit <LOCKBT> are already programmed in the OTP memory at circuit delivery. They correspond to the calibration of the circuit and are just documented here as an indication.

Each OTP bit is at '0' when not zapped. Zapping a bit will set it to '1'. Thus only bits having to be at '1' must be zapped. Zapping of a bit already at '1' is disabled. Each OTP byte will be programmed separately (see command <u>SetOTPparam</u>). Once OTP programming is completed, bit <LOCKBG> can be zapped to disable future zapping, otherwise any OTP bit at '0' could still be zapped by using a <u>SetOTPparam</u> command.

 Table 18. OTP OVERWRITE PROTECTION

| Lock Bit                                   | Protected Bytes |  |  |
|--------------------------------------------|-----------------|--|--|
| LOCKBT (factory zapped<br>before delivery) | 0x00 to 0x01    |  |  |
| LOCKBG                                     | 0x00 to 0x07    |  |  |

The command used to load the application parameters via the  $I^2C$  bus in the RAM prior to an OTP Memory

programming is <u>SetMotorParam</u>. This allows for a functional verification before using a <u>SetOTPparam</u> command to program and zap separately one OTP memory byte. A <u>GetOTPparam</u> command issued after each <u>SetOTPparam</u> command allows verifying the correct byte zapping.

**Note:** Zapped bits will become active only after a power cycle. After programming the  $I^2C$  bits the power cycle has to be performed first to guarantee further communication with the device.

#### **Application Parameters Stored in OTP Memory**

Except for the physical address <PA[3:0]> these parameters, although programmed in a non-volatile memory can still be overridden in RAM by a I<sup>2</sup>C writing operation.

**PA[3:0]** In combination with hired wired (HW) address, it forms the physical address AD[6:0] of the stepper-motor. Up to 32 stepper motors can theoretically be connected to the same I<sup>2</sup>C bus.