# dSPIN fully integrated microstepping motor driver with motion engine and SPI ### **Features** - Operating voltage: 8 45 V - 7.0 A output peak current (3.0 A r.m.s.) - Low R<sub>DSon</sub> power MOSFETS - Programmable speed profile and positioning - Programmable power MOS slew-rate - Up to 1/128 microstepping - Sensorless stall detection - SPI interface - Low guiescent and standby currents - Programmable non dissipative overcurrent protection on high and low-side - Two levels overtemperature protection # **Applications** ■ Bipolar stepper motor # **Description** The L6470, realized in analog mixed signal technology, is an advanced fully integrated solution suitable for driving two phase bipolar stepper motors with microstepping. It integrates a dual low R<sub>DSon</sub> DMOS full bridge with all of the power switches equipped with an accurate on chip current sensing circuitry suitable for non dissipative current control and overcurrent protections. Thanks to a unique control system a true 1/128 steps resolution is achieved. The digital control core can generate user defined motion profiles with acceleration, deceleration, speed or target position easily programmed through a dedicated registers set. All commands and data registers, including those used to set analogue values (i.e. current control value, current protection trip point, dead time, PWM frequency etc.) are sent through a standard 5 Mbit/s SPI. A very rich set of protections (thermal, low bus voltage, overcurrent, motor stall) allows designing a fully protected application, as required by most demanding motor control applications. Table 1. Device summary | Order codes | Package Packing | | |-------------|-----------------|---------------| | L6470H | HTSSOP28 | Tube | | L6470HTR | HTSSOP28 | Tape and reel | Contents L6470 # **Contents** | 1 | Bloc | k diagra | ım | |---|-------|-----------|-----------------------------------------| | 2 | Elec | trical da | ta9 | | | 2.1 | Absolut | te maximum ratings | | | 2.2 | Recom | mended operating conditions | | 3 | Elec | trical ch | aracteristics11 | | 4 | Pin d | connecti | on | | | 4.1 | Pin list | | | 5 | Турі | cal appli | cations18 | | 6 | Fund | ctional d | escription19 | | | 6.1 | Device | power-up | | | 6.2 | Logic I/ | O | | | 6.3 | Charge | pump | | | 6.4 | Microst | epping | | | | 6.4.1 | Automatic full-step mode21 | | | 6.5 | Absolut | te position counter | | | 6.6 | Prograr | mmable speed profiles21 | | | | 6.6.1 | Infinite acceleration/deceleration mode | | | 6.7 | Motor o | control commands | | | | 6.7.1 | Constant speed commands | | | | 6.7.2 | Positioning commands | | | | 6.7.3 | Motion commands | | | | 6.7.4 | Stop commands | | | | 6.7.5 | Step-clock mode | | | | 6.7.6 | GoUntil and ReleaseSW commands | | | 6.8 | | l oscillator and oscillator driver | | | | 6.8.1 | Internal oscillator | | | | 6.8.2 | External clock source | | | 6.9 | Overcu | rrent detection | L6470 Contents | | 6.10 | Undervoltage lock-out (UVLO) | 2 | 8 | |---|-------|------------------------------------------------------------|----|---| | | 6.11 | Thermal warning and thermal shutdown | 2 | 8 | | | 6.12 | Reset and standby | 2 | 8 | | | 6.13 | External switch (SW pin) | 2 | 9 | | | 6.14 | Programmable DMOS slew-rate, dead-time and blanking-time . | 3 | 0 | | | 6.15 | Integrated analog to digital converter | 3 | 0 | | | 6.16 | Internal voltage regulator | | | | | 6.17 | BUSY\SYNC pin | 3 | 1 | | | | 6.17.1 BUSY operation mode | 3 | 1 | | | | 6.17.2 SYNC operation mode | 3 | 1 | | | 6.18 | FLAG pin | 3 | 1 | | 7 | Phas | e current control | 3/ | 2 | | | 7.1 | PWM sinewave generators | 3 | 2 | | | 7.2 | Sensorless stall detection | 3 | 3 | | | 7.3 | Low speed optimization | 3 | 3 | | | 7.4 | BEMF compensation | | | | | 7.5 | Motor supply voltage compensation | 3 | 4 | | | 7.6 | Winding resistance thermal drift compensation | 3 | 5 | | 8 | Seria | l interface | 30 | 6 | | 9 | Prog | ramming manual | 3 | 8 | | | 9.1 | Registers and flags description | 3 | 8 | | | | 9.1.1 ABS_POS | | | | | | 9.1.2 EL_POS | 3 | 9 | | | | 9.1.3 MARK | 4 | 0 | | | | 9.1.4 SPEED | 4 | 0 | | | | 9.1.5 ACC | 4 | 0 | | | | 9.1.6 DEC | | | | | | 9.1.7 MAX_SPEED | | | | | | 9.1.8 MIN_SPEED | | | | | | 9.1.9 FS_SPD | | | | | | 9.1.10 KVAL_HOLD, KVAL_RUN, KVAL_ACC and KVAL_DEC | | | | | | 9.1.11 INT_SPEED | | | | | | 0.1.12 | 4 | J | | 11 | Revis | sion his | tory66 | |----|-------|----------|-------------------------| | 10 | Pack | age me | chanical data | | | | 9.2.20 | GetStatus | | | | 9.2.19 | HardHiZ62 | | | | 9.2.18 | SoftHiZ | | | | 9.2.17 | HardStop62 | | | | 9.2.16 | SoftStop | | | | 9.2.15 | ResetDevice | | | | 9.2.14 | ResetPos 6 | | | | 9.2.13 | GoMark | | | | 9.2.12 | GoHome | | | | 9.2.11 | ReleaseSW (ACT, DIR)60 | | | | 9.2.10 | GoUntil (ACT, DIR, SPD) | | | | 9.2.9 | GoTo_DIR (DIR, ABS_POS) | | | | 9.2.8 | GoTo (ABS_POS) | | | | 9.2.7 | Move (DIR, N_STEP) | | | | 9.2.6 | StepClock (DIR) | | | | 9.2.5 | Run (DIR, SPD) | | | | 9.2.4 | GetParam (PARAM) | | | | 9.2.3 | SetParam (PARAM, VALUE) | | | | 9.2.2 | Nop | | | | 9.2.1 | Command management | | | 9.2 | | ation commands | | | | 9.1.22 | STATUS | | | | 9.1.21 | CONFIG | | | | 9.1.20 | ALARM_EN | | | | 9.1.19 | STEP_MODE | | | | 9.1.18 | STALL_TH | | | | 9.1.17 | OCD_TH | | | | 9.1.16 | ADC_OUT | | | | 9.1.15 | K_THERM | | | | 9.1.14 | FN_SLP_DEC | | | | 9.1.13 | FN_SLP_ACC | List of tables # List of tables | Table 1. | Device summary | | |-----------|--------------------------------------------------------------|------| | Table 2. | Absolute maximum ratings | . 9 | | Table 3. | Recommended operating conditions | . 10 | | Table 4. | Thermal data | . 10 | | Table 5. | Electrical characteristics | . 11 | | Table 6. | Pin description | . 16 | | Table 7. | Typical application values | . 18 | | Table 8. | CL values according to external oscillator frequency | 26 | | Table 9. | Registers map | . 38 | | Table 10. | EL_POS register | 39 | | Table 11. | MIN_SPEED register | 41 | | Table 12. | Voltage amplitude regulation registers | 43 | | Table 13. | Winding resistance thermal drift compensation coefficient | 44 | | Table 14. | ADC_OUT value and motor supply voltage compensation feature | 44 | | Table 15. | Overcurrent detection threshold | | | Table 16. | Stall detection threshold | 45 | | Table 17. | STEP_MODE register | 45 | | Table 18. | Step mode selection | 46 | | Table 19. | SYNC output frequency | | | Table 20. | SYNC signal source | 47 | | Table 21. | ALARM_EN register | | | Table 22. | CONFIG register | | | Table 23. | Oscillator management | | | Table 24. | External switch hard stop interrupt mode | | | Table 25. | Overcurrent event | | | Table 26. | Programmable power bridge output slew-rate values | | | Table 27. | Motor supply voltage compensation enable | | | Table 28. | PWM frequency: integer division factor | | | Table 29. | PWM frequency: multiplication factor | | | Table 30. | Available PWM frequencies [kHz]: 8 MHz oscillator frequency | | | Table 31. | Available PWM frequencies [kHz]: 16 MHz oscillator frequency | | | Table 32. | Available PWM frequencies [kHz]: 24 MHz oscillator frequency | | | Table 33. | Available PWM frequencies [kHz]: 32 MHz oscillator frequency | | | Table 34. | STATUS register | | | Table 35. | STATUS register DIR bit | | | Table 36. | STATUS register MOT_STATE bits | | | Table 37. | Application commands | | | Table 38. | Nop command structure | | | Table 39. | SetParam command structure | | | Table 40. | GetParam command structure | | | Table 41. | Run command structure | | | Table 42. | Stepclock command structure | | | Table 43. | Move command structure | | | Table 44. | GoTo command structure | | | Table 45. | GoTo_DIR command structure | | | Table 46. | GoUntil command structure | | | Table 47. | ReleaseSW command structure | | | Table 48. | GoHome command structure | 60 | List of tables L6470 | Table 49. | GoMark command structure | 60 | |-----------|-------------------------------|----| | Table 50. | ResetPos command structure | 61 | | Table 51. | ResetDevice command structure | 61 | | Table 52. | SoftStop command structure | 61 | | Table 53. | HardStop command structure | 62 | | Table 54. | SoftHiZ command structure | 62 | | Table 55. | HardHiZ command structure | 62 | | Table 56. | GetStatus command structure | 63 | | Table 57. | HTSSOP28 mechanical data | 64 | | Table 58. | Document revision history | 66 | List of figures # **List of figures** | Figure 1. | Block diagram | . 8 | |------------|----------------------------------------------------------|-----| | Figure 2. | Pin connection (top view) | | | Figure 3. | Bipolar stepper motor control application using L6470 | 18 | | Figure 4. | Charge pump circuitry | 20 | | Figure 5. | Normal mode and microstepping (128 microsteps) | 20 | | Figure 6. | Automatic full-step switching | 21 | | Figure 7. | Speed profile in infinite acceleration/deceleration mode | 22 | | Figure 8. | Constant speed commands examples | 23 | | Figure 9. | Positioning command examples | 24 | | Figure 10. | Motion commands examples | 24 | | Figure 11. | OSCIN and OSCOUT pins configurations | 27 | | Figure 12. | External switch connection | 29 | | Figure 13. | Internal 3 V linear regulator | 30 | | Figure 14. | Current distortion and compensation | 33 | | Figure 15. | BEMF compensation curve | 34 | | Figure 16. | Motor supply voltage compensation circuit | 35 | | Figure 17. | SPI timings diagram | 36 | | Figure 18. | Daisy-chain configuration | 37 | | Figure 19. | Command with three byte argument | 55 | | Figure 20. | Command with three byte responset | 55 | | Figure 21. | Command response aborted | 55 | | Figure 22. | HTSSOP28 mechanical data | 65 | Block diagram L6470 # 1 Block diagram Figure 1. Block diagram L6470 Electrical data # 2 Electrical data # 2.1 Absolute maximum ratings Table 2. Absolute maximum ratings | Symbol | Parameter | Test condition | Value | Unit | |---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--------------|------| | $V_{\mathrm{DD}}$ | Logic interface supply voltage | | 5.5 | V | | V <sub>S</sub> | Motor supply voltage | $V_{SA} = V_{SB} = V_{S}$ | 48 | V | | V <sub>GND, diff</sub> | Differential voltage between AGND, PGND and DGND | | ±0.3 | V | | V <sub>boot</sub> | Bootstrap peak voltage | | 55 | V | | V <sub>REG</sub> | Internal voltage regulator output pin and logic supply voltage | | 3.6 | V | | V <sub>ADCIN</sub> | Integrated ADC input voltage range (ADCIN pin) | | -0.3 to +3.6 | V | | V <sub>OSC</sub> | OSCIN and OSCOUT pin voltage range | | -0.3 to +3.6 | V | | V <sub>out_diff</sub> | Differential voltage between V <sub>SA</sub> ,<br>OUT1 <sub>A</sub> , OUT2 <sub>A</sub> , PGND and V <sub>SB</sub> ,<br>OUT1 <sub>B</sub> , OUT2 <sub>B</sub> , PGND pins | $V_{SA} = V_{SB} = V_{S}$ | 48 | V | | V <sub>LOGIC</sub> | Logic inputs voltage range | | -0.3 to +5.5 | V | | I <sub>out</sub> (1) | R.m.s. output current | | 3 | Α | | I <sub>out_peak</sub> (1) | Pulsed output current | T <sub>PULSE</sub> < 1 ms | 7 | Α | | T <sub>OP</sub> | Operating junction temperature | | 150 | °C | | T <sub>s</sub> | Storage temperature range | | -55 to 150 | °C | | P <sub>tot</sub> | Total power dissipation (T <sub>A</sub> = 25°C) | (2) | 3 | W | | All pins | Maximum withstanding voltage range | CDF-AEC-Q100-002- "human body<br>model" Acceptance criteria "normal<br>performance" all pins vs. all pins | ± 2000 | V | | | Maximum withstanding voltage range | TBD - "charge device model" all pins vs. all pins | TBD | V | Maximum output current limit is related to metal connection and bonding characteristics. Actual limit must satisfy maximum thermal dissipation constraints. <sup>2.</sup> HTSSOP28 mounted on EVAL6470 Rev 1.0 Electrical data L6470 # 2.2 Recommended operating conditions Table 3. Recommended operating conditions | Symbol | Parameter | Test condition | Value | | Unit | | |-----------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------|-----|------------------|----| | V | Logio interface cumply voltage | 3.3 V logic outputs | | 3.3 | | V | | V <sub>DD</sub> | Logic interface supply voltage | 5 V logic outputs | | 5 | | v | | V <sub>S</sub> | Motor supply voltage | $V_{SA} = V_{SB} = V_{S}$ | 8 | | 45 | V | | V <sub>out_diff</sub> | Differential voltage between $V_{SA}$ , $OUT1_A$ , $OUT2_A$ , $PGND$ and $V_{SB}$ , $OUT1_B$ , $OUT2_B$ , $PGND$ pins | $V_{SA} = V_{SB} = V_{S}$ | | | 45 | V | | V <sub>REG,in</sub> | Logic supply voltage | V <sub>REG</sub> voltage imposed by external source | 3.2 | 3.3 | | ٧ | | V <sub>ADC</sub> | Integrated ADC input voltage (ADCIN pin) | | 0 | | V <sub>REG</sub> | V | | Tj | Operating junction temperature | | - 25 | | 125 | °C | Table 4. Thermal data | Symbol | Parameter | Value | Unit | |-------------------|-----------------------------------------|-------|------| | R <sub>thJA</sub> | Thermal resistance junction-ambient (1) | 40 | °C/W | <sup>1.</sup> HTSSOP28 mounted on EVAL6470 Rev 1.0 board: two-layer FR4 PCB with a dissipating copper surface of about 3.5 cm2 on the top side plus 9 cm2 ground layer connected through via holes (12 below the IC). # 3 Electrical characteristics $V_{SA} = V_{SB} = 36 \text{ V}; V_{DD} = 3.3 \text{ V}; \text{ internal 3 V regulator}; T_{J} = 25 ^{\circ}\text{C}, \text{ unless otherwise specified.}$ Table 5. Electrical characteristics | Symbol | Parameter | Test condition | Min | Тур | Max | Unit | |-----------------------|----------------------------------------------|-------------------------------------------------------------------|------|------|------|------| | General | | | | | | | | V <sub>SthOn</sub> | V <sub>S</sub> UVLO turn on threshold | | 7.5 | 8.2 | 8.9 | V | | V <sub>SthOff</sub> | V <sub>S</sub> UVLO turn off threshold | | 6.6 | 7.2 | 7.8 | ٧ | | V <sub>SthHyst</sub> | V <sub>S</sub> UVLO threshold hysteresis | | 0.7 | 1 | 1.3 | V | | I <sub>q</sub> | Quiescent motor supply current | Internal oscillator selected;<br>VREG = 3.3V ext;<br>CP floating | | 0.5 | 0.65 | mA | | T <sub>j(WRN)</sub> | Thermal warning temperature | | | 130 | | °C | | T <sub>j(SD)</sub> | Thermal shutdown temperature | | | 160 | | °C | | Charge pun | np | | | | | | | V <sub>pump</sub> | Voltage swing for charge pump oscillator | | | 10 | | ٧ | | f <sub>pump,min</sub> | Minimum charge pump oscillator frequency (1) | | | 660 | | kHz | | f <sub>pump,max</sub> | Maximum charge pump oscillator frequency (1) | | | 800 | | kHz | | l <sub>boot</sub> | Average boot current | f <sub>sw,A</sub> = f <sub>sw,B</sub> = 15.6 kHz<br>POW_SR = '10' | | 1.1 | 1.4 | mA | | Output DMC | OS transistor | | | • | | , | | | High side switch ON resistance | $T_j = 25 ^{\circ}\text{C},$ $I_{out} = 3\text{A}$ | | 0.37 | | | | D | High side switch ON resistance | T <sub>j</sub> = 125 °C, <sup>(2)</sup><br>I <sub>out</sub> = 3A | | 0.51 | | - Ω | | R <sub>DS(on)</sub> | Low side switch ON resistance | $T_j = 25$ °C,<br>$I_{out} = 3A$ | | 0.18 | | | | | Low side switch on resistance | $T_j = 125 ^{\circ}\text{C}, ^{(2)}$<br>$I_{out} = 3\text{A}$ | | 0.23 | | | | l | Leakage current | OUT = V <sub>S</sub> | | | 3.1 | mA | | I <sub>DSS</sub> | Leakage current | OUT = GND | -0.3 | | | ША | | | | POW_SR = '00', I <sub>out</sub> = +1A | | 100 | | | | | | POW_SR = '00', I <sub>out</sub> = -1A | | 80 | | ns | | t <sub>r</sub> | Rise time <sup>(3)</sup> | $POW\_SR = '11', I_{out} = \pm 1A$ | | 100 | | | | | | $POW\_SR = '10', I_{lout} = \pm 1A$ | | 200 | | | | | | POW_SR = '01', $I_{out} = \pm 1A$ | | 300 | | | Electrical characteristics L6470 Table 5. Electrical characteristics (continued) | Symbol | Parameter | Test condition | Min | Тур | Max | Unit | |---------------------|---------------------------------------|--------------------------------------------|-----|-----|-----|------| | | | POW_SR = '00'; lout = +1A | | 90 | | | | | | POW_SR = '00'; lout = -1A | | 110 | | | | t <sub>f</sub> | Fall time (3) | POW_SR = '11', I <sub>out</sub> = ±1A | | 110 | | ns | | | | POW_SR = '10', $I_{out} = \pm 1A$ | | 260 | | | | | | $POW_SR = '01', I_{load} = \pm 1A$ | | 375 | | | | | | POW_SR = '00', I <sub>out</sub> = +1A | | 285 | | | | | | POW_SR = '00', I <sub>out</sub> = -1A | | 360 | | | | SR <sub>out_r</sub> | Output rising slew-rate | POW_SR = '11', I <sub>out</sub> = ±1A | | 285 | | V/µs | | | | POW_SR = '10', I <sub>out</sub> = ±1A | | 150 | | | | | | POW_SR = '01', I <sub>out</sub> = ±1A | | 95 | | | | | | POW_SR = '00', I <sub>out</sub> = +1A | | 320 | | | | | | POW_SR = '00', I <sub>out</sub> = -1A | | 260 | | | | $SR_{out\_f}$ | Output falling slew-rate | POW_SR = '11', I <sub>out</sub> = ±1A | | 260 | | V/µs | | _ | | POW_SR = '10', I <sub>out</sub> = ±1A | | 110 | | | | | | POW_SR = '01', I <sub>out</sub> = ±1A | | 75 | | | | Dead time a | and blanking | | ı | I. | | | | | | POW_SR = '00' | | 250 | | | | | Dead time <sup>(1)</sup> | POW_SR = '11', | | 075 | | ns | | | | $f_{OSC} = 16MHz$ | | 375 | | | | $t_{DT}$ | | POW_SR = '10', | | 625 | | | | | | $f_{OSC} = 16MHz$ | | 0_0 | | | | | | POW_SR = '01', | | 875 | | | | | | f <sub>OSC</sub> = 16MHz | | 050 | | | | | | POW_SR = '00' | | 250 | | _ | | | | POW_SR = '11',<br>f <sub>OSC</sub> = 16MHz | | 375 | | | | t <sub>blank</sub> | Blanking time <sup>(1)</sup> | POW_SR = '10', | | | | ns | | DIATIK | | $f_{OSC} = 16MHz$ | | 625 | | | | | | POW_SR = '01', | | 075 | | _ | | | | f <sub>OSC</sub> = 16MHz | | 875 | | | | Source-drai | in diodes | | | | | | | V <sub>SD,HS</sub> | High side diode forward ON voltage | I <sub>out</sub> = 1 A | | 1 | 1.1 | ٧ | | V <sub>SD,LS</sub> | Low side diode forward ON voltage | I <sub>out</sub> = 1 A | | 1 | 1.1 | ٧ | | t <sub>rrHS</sub> | High side diode reverse recovery time | I <sub>out</sub> = 1 A | | 30 | | ns | | t <sub>rrLS</sub> | Low side diode reverse recovery time | I <sub>out</sub> = 1 A | | 100 | | ns | Table 5. Electrical characteristics (continued) | Table 5. Electrical characteristics (continued) | | | | | | | | |-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----|-----|-----|------|--| | Symbol | Parameter | Test condition | Min | Тур | Max | Unit | | | Logic input | s and outputs | | | | | | | | $V_{IL}$ | Low logic level input voltage | | | | 0.8 | ٧ | | | V <sub>IH</sub> | High logic level input voltage | | 2 | | | ٧ | | | I <sub>IH</sub> | High logic level input current (4) | V <sub>IN</sub> = 5 V | | | 1 | μΑ | | | I <sub>IL</sub> | Low logic level input current (5) | V <sub>IN</sub> = 0 V | -1 | | | μΑ | | | V | Low logic level output voltage (6) | V <sub>DD</sub> = 3.3 V,<br>I <sub>OL</sub> = 4 mA | | | 0.3 | V | | | V <sub>OL</sub> | Low logic level output voltage | $V_{DD} = 5 V$ ,<br>$I_{OL} = 4 \text{ mA}$ | | | 0.3 | v | | | V | High logic level output voltage | $V_{DD} = 3.3 \text{ V},$ $I_{OH} = 4 \text{ mA}$ | 2.4 | | | V | | | V <sub>OH</sub> | Trigit logic level output voltage | $V_{DD} = 5 V$ ,<br>$I_{OH} = 4 \text{ mA}$ | 4.7 | | | V | | | R <sub>PU</sub><br>R <sub>PD</sub> | CS Pull-up and STBY pull-down resistors | CS = GND;<br>STBY/RST = 5 V | 335 | 430 | 565 | kΩ | | | I <sub>logic</sub> | Internal logic supply current 3.3 V V <sub>REG</sub> externally supplied, internal oscillate | | | 3.7 | 4.3 | mA | | | I <sub>logic,STBY</sub> | Standby mode internal logic supply current | 3.3 V V <sub>REG</sub> externally supplied | | 2 | 2.5 | μA | | | f <sub>STCK</sub> | Step clock input frequency | | | | 2 | MHz | | | Internal osc | illator and external oscillator driver | | | | | | | | f <sub>osc,i</sub> | Internal oscillator frequency $ T_{j} = 25^{\circ}C, $ $V_{REG} = 3.3 \text{ V} $ | | -3% | 16 | +3% | MHz | | | f <sub>osc,e</sub> | Programmable external oscillator frequency | l oscillator frequency | | | 32 | MHz | | | V <sub>OSCOUTH</sub> | OSCOUT clock source high level voltage | Internal oscillator 3.3 V V <sub>REG</sub> externally supplied; I <sub>OSCOUT</sub> = 4 mA | | | | V | | | V <sub>OSCOUTL</sub> | OSCOUT clock source low level voltage Internal oscillator 3.3 V V <sub>REG</sub> externally supplied; I <sub>OSCOUT</sub> = 4 mA | | | | 0.3 | V | | | t <sub>rOSCOUT</sub> | OSCOUT clock source rise and fall time | ce rise and fall time Internal oscillator | | | 20 | ns | | | t <sub>extosc</sub> | Internal to external oscillator switching delay | | | 3 | | ms | | | t <sub>intosc</sub> | External to internal oscillator switching delay | | | 1.5 | | μs | | | SPI | | | | | | | | | f <sub>CK,MAX</sub> | Maximum SPI clock frequency (7) | | 5 | | | MHz | | | t <sub>rCK</sub><br>t <sub>fCK</sub> | SPI clock rise and fall time <sup>(7)</sup> | C <sub>L</sub> = 30pF | | | 25 | ns | | Electrical characteristics L6470 Table 5. Electrical characteristics (continued) | Symbol | Parameter | Test condition | Min | Тур | Max | Unit | |--------------------------------------|----------------------------------------------------------------------|--------------------------------------------------|-----|-------|------|------| | t <sub>hCK</sub><br>t <sub>ICK</sub> | SPI clock high and low time <sup>(7)</sup> | | 75 | | | ns | | t <sub>setCS</sub> | Chip select setup time (7) | | 350 | | | ns | | t <sub>holCS</sub> | Chip select hold time (7) | | 10 | | | ns | | t <sub>disCS</sub> | Deselect time (7) | | 800 | | | ns | | t <sub>setSDI</sub> | Data input setup time (7) | | 25 | | | ns | | t <sub>holSDI</sub> | Data input hold time (7) | | 20 | | | ns | | t <sub>enSDO</sub> | Data output enable time (7) | | | | 38 | ns | | t <sub>disSDO</sub> | Data output disable time (7) | | | | 47 | ns | | t <sub>vSDO</sub> | Data output valid time (7) | | | | 57 | ns | | t <sub>holSDO</sub> | Data output hold time (7) | | 37 | | | ns | | Switch inpu | it (SW) | , | 1 | • | l | ı | | R <sub>PUSW</sub> | SW input pull-up resistance | SW = GND | 60 | 85 | 110 | kΩ | | PWM modu | lators | | • | • | • | , | | | (1) | f <sub>osc</sub> = 16MHz | 2.8 | | 62.5 | | | f <sub>PWM</sub> | Programmable PWM frequency (1) | f <sub>osc</sub> = 32MHz | 5.6 | | 125 | kHz | | N <sub>PWM</sub> | PWM resolution | | | 8 | | bit | | Stall detect | ion | | | | | | | I <sub>STALL,MAX</sub> | Maximum programmable stall threshold | STALL_TH = '1111111' | | 4 | | Α | | I <sub>STALL,MIN</sub> | Minimum programmable stall threshold | STALL_TH = '0000000' | | 31.25 | | mA | | I <sub>STALL,RES</sub> | Programmable stall threshold resolution | | | 31.25 | | mA | | Overcurren | t protection | | l. | | I | | | I <sub>OCD,MAX</sub> | Maximum programmable overcurrent detection threshold | OCD_TH = '1111' | | 6 | | А | | I <sub>OCD,MIN</sub> | Minimum programmable overcurrent detection threshold OCD_TH = '0000' | | | 0.375 | | Α | | I <sub>OCD,RES</sub> | Programmable overcurrent detection threshold resolution | | | 0.375 | | Α | | t <sub>OCD,Flag</sub> | OCD to Flag signal delay time | $dI_{out}/dt = 350A/\mu s,$<br>$R_{FLAG} = TBD$ | | 650 | 1000 | ns | | t <sub>OCD,SD</sub> | OCD to shut-down delay time | dl <sub>out</sub> /dt = 350A/µs<br>POW_SR = '10' | | 600 | | μs | | Standby | | | · | • | | • | | 1 | Quiescent motor supply current in standby | V <sub>S</sub> = 8V | | 26 | 34 | | | I <sub>qSTBY</sub> | conditions | V <sub>S</sub> = 36V | | 30 | 36 | μA | Table 5. Electrical characteristics (continued) | Symbol | Parameter | Test condition | Min | Тур | Max | Unit | |---------------------------------------------------|-----------------------------------------------|------------------------------------------------------------|-----|------------------|-----|------| | t <sub>STBY,min</sub> | Minimum standby time | | | 10 | | μS | | t <sub>logicwu</sub> | Logic power-on and wake-up time | | | 38 | 45 | μs | | t <sub>cpwu</sub> | Charge pump power-on and wake-up time | Power bridges disabled, $C_p = 10 nF,$ $C_{boot} = 220 nF$ | | 650 | | μS | | Internal vol | tage regulator | | • | | | | | V <sub>REG</sub> | Voltage regulator output voltage | | 2.9 | 3 | 3.2 | V | | I <sub>REG</sub> | Voltage regulator output current | | | | 40 | mA | | V <sub>REG, drop</sub> | Voltage regulator output voltage drop | I <sub>REG</sub> = 40mA | | 50 | | mV | | I <sub>REG,STBY</sub> | Voltage regulator standby output current | | | | 10 | mA | | Integrated a | nnalog to digital converter | | | | | | | N <sub>ADC</sub> | Analog to digital converter resolution | | | 5 | | bit | | V <sub>ADC,ref</sub> | Analog to digital converter reference voltage | | | $V_{REG}$ | | ٧ | | fs Analog to digital converter sampling frequency | | | | f <sub>PWM</sub> | | kHz | - 1. Accuracy depends on oscillator frequency accuracy. - 2. Tested at 25°C in a restricted range and guaranteed by characterization. - Rise and fall time depends on motor supply voltage value. Refer to SR<sub>out</sub> values in order to evaluate the actual rise and fall time. - 4. Not valid for STBY/RST pin which have internal pull-down resistor. - 5. Not valid for SW and CS pins which have internal pull-up resistor - 6. FLAG, BUSY and SYNC open drain outputs included. - 7. See Figure 17- SPI timings diagram for details. Pin connection L6470 # 4 Pin connection Figure 2. Pin connection (top view) # 4.1 Pin list Table 6. Pin description | N. | Name | Туре | Function | |----|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 17 | VDD | Power | Logic outputs supply voltage (pull-up reference) | | 6 | VREG | Power | Internal 3 V voltage regulator output and 3.3 V external logic supply | | 7 | OSCIN | Analog input | Oscillator pin 1. To connect an external oscillator or clock source. If this pin is unused, it should be left floating. | | 8 | OSCOUT | Analog output | Oscillator pin 2. To connect an external oscillator. When the internal oscillator is used this pin can supply a 2/4/8/16 MHz. If this pin is unused, it should be left floating. | | 10 | СР | Output | Charge pump oscillator output | | 11 | VBOOT | Supply voltage | Bootstrap voltage needed for driving the high side power DMOS of both bridges (A and B) | | 5 | ADCIN | Analog input | Internal analog to digital converter input | | 2 | VSA | Power supply | Full bridge A power supply pin. It must be connected to | | 26 | VSA | Fower supply | VSB | | 12 | VSB | Power supply | Full bridge B power supply pin. It must be connected to | | 16 | VOD | i ower suppry | VSA | L6470 Pin connection Table 6. Pin description (continued) | N. | Name | Туре | Function | |------|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27 | PGND | Ground | Power ground pin | | 13 | PGND | Ground | Fower ground pin | | 1 | OUT1A | Power output | Full bridge A output 1 | | 28 | OUT2A | Power output | Full bridge A output 2 | | 14 | OUT1B | Power output | Full bridge B output 1 | | 15 | OUT2B | Power output | Full bridge B output 2 | | 9 | AGND | Ground | Analog ground. | | 4 | SW | Logical input | External switch input pin. If not used the pin should be connected to VDD. | | 21 | DGND | Ground | Digital ground | | 22 | BUSY\SYNC | Open drain output | By default this BUSY pin is forced low when the device is performing a command. Otherwise the pin can be configured to generate a synchronization signal. | | 18 | SDO | Logic output | Data output pin for serial interface | | 20 | SDI | Logic input | Data input pin for serial interface | | 19 | CK | Logic input | Serial interface clock | | 23 | CS | Logic input | Chip Select input pin for serial interface | | 24 | FLAG | Open drain output | Status Flag pin. An internal open drain transistor can pull the pin to GND when a programmed alarm condition occurs (step loss, OCD, thermal pre-warning or shutdown, UVLO, wrong command, non performable command) | | 3 | STBY\RST | Logic input | Standby and reset pin. LOW logic level reset the logic and puts the device in standby mode. If not used, should be connected to VDD | | 25 | STCK | Logic input | Step clock input | | EPAD | Exposed pad | Ground | Internally connected to PGND, AGND and DGND pins | Typical applications L6470 # 5 Typical applications Table 7. Typical application values | Name | value | |---------------------|--------------------| | C <sub>VS</sub> | 220 nF | | C <sub>VSPOL</sub> | 100 μF | | C <sub>REG</sub> | 100 nF | | C <sub>REGPOL</sub> | 47 μF | | C <sub>DD</sub> | 100 nF | | C <sub>DDPOL</sub> | 10 μF | | D1 | Charge pump diodes | | C <sub>BOOT</sub> | 220 nF | | C <sub>FLY</sub> | 10 nF | | R <sub>PU</sub> | 39 kΩ | | R <sub>SW</sub> | 100 Ω | | C <sub>SW</sub> | 10 nF | | R <sub>A</sub> | 2.7 kΩ (VS = 36 V) | | R <sub>B</sub> | 62 kΩ (VS = 36 V) | Figure 3. Bipolar stepper motor control application using L6470 # 6 Functional description ### 6.1 Device power-up At power-up end, the device state is the following: - Registers are set to default, - Internal logic is driven by internal oscillator and a 2MHz clock is provided by OSCOUT pin, - Bridges are disabled (High Z), - UVLO bit in STATUS register is forced low (fail condition), - FLAG output is forced low During power-up the device is under reset (all logic IO disabled and power bridges in high impedance state) until the following conditions are satisfied: - V<sub>S</sub> is greater than V<sub>SthOn</sub>, - V<sub>REG</sub> is greater than V<sub>REGth</sub> = 2.8 V typical - Internal oscillator is operative. Any motion command makes the device exiting from High Z state (HardStop and SoftStop included). ### 6.2 Logic I/O Pins $\overline{\text{CS}}$ , CK, SDI, STCK, SW and $\overline{\text{STBY}}\backslash\overline{\text{RST}}$ are TTL/CMOS 3.3V-5V compatible logic inputs. Pin SDO is a TTL/CMOS compatible logic output. VDD pin voltage sets the logic output pin voltage range; when it is connected to VREG or 3.3V external supply voltage, the output is 3.3V compatible. When VDD is connected to a 5V supply voltage, SDO is 5V compatible. VDD is not internally connected to V<sub>REG</sub>, an external connection is always needed. A 10 $\mu$ F capacitor should be connected to $V_{DD}$ pin in order to obtain a proper operation. Pins FLAG and BUSY\SYNC are open drain outputs. # 6.3 Charge pump To ensure the correct driving of the high side integrated mosfets a voltage higher than the motor power supply voltage needs to be applied to the VBOOT pin. The high side gate driver supply voltage $V_{boot}$ is obtained through an oscillator and a few external components realizing a charge pump (see *Figure 4*). Figure 4. Charge pump circuitry # 6.4 Microstepping The driver is able to divide the single step into up to 128 microsteps. Stepping mode can be programmed by STEP\_SEL parameter in STEP\_MODE register (see *Table 18*). Step mode can be only changed when bridges are disabled. Every time the step mode is changed the electrical position (i.e. the point of microstepping sinewave that is generated) is reset to first microstep and the absolute position counter value (see *Section 6.5*) becomes meaningless. Figure 5. Normal mode and microstepping (128 microsteps) ### 6.4.1 Automatic full-step mode When motor speed is greater than a programmable full step speed threshold, the L6470 switches automatically to full-step mode (see *Figure 6*); the driving mode returns to microstepping when motor speed decrease below the full step speed threshold. Full step speed threshold is set through the FS SPD register (see *Section 9.1.9*). Figure 6. Automatic full-step switching # 6.5 Absolute position counter An internal 22 bit register (ABS\_POS) takes memory of motor motion according to the selected step mode; the stored value unit is equal to the selected step mode (full, half, quarter, etc.). The position range is from -2<sup>21</sup>to +2<sup>21</sup>-1 ( $\mu$ )steps (see *Section 9.1.1*). # 6.6 Programmable speed profiles The user can easily program a customized speed profile defining independently acceleration, deceleration, maximum and minimum speed values by ACC, DEC, MAX\_SPEED and MIN\_SPEED registers respectively (see *Section 9.1.5*, *9.1.6*, *9.1.7* and *9.1.8*). When a command is sent to the device, the integrated logic generates the microstep frequency profile that performs a motor motion compliant to speed profile boundaries. All acceleration parameters are expressed in step/tick<sup>2</sup> and all speed parameters are expressed in step/tick; the unit of measure does not depend on selected step mode. Acceleration and deceleration parameters range from 2<sup>-40</sup> to (2<sup>12</sup>-2)•2<sup>-40</sup> step/tick<sup>2</sup> (equivalent to 14.55 to 59590 step/s<sup>2</sup>). Minimum speed parameter ranges from 0 to $(2^{12}-1) \cdot 2^{-24}$ step/tick (equivalent to 0 to 976.3 step/s). Maximum speed parameter ranges from $2^{-18}$ to $(2^{10}-1) \cdot 2^{-18}$ step/tick (equivalent to 15.25 to 15610 step/s). ### 6.6.1 Infinite acceleration/deceleration mode When ACC register value is set to max (0xFFF), system works in "infinite acceleration mode": acceleration and deceleration phases are totally skipped as shown in *Figure 7*. It is not possible to skip the acceleration or deceleration phase independently. Figure 7. Speed profile in infinite acceleration/deceleration mode ### 6.7 Motor control commands The L6470 can accept different types of commands: - constant speed commands (Run, GoUntil, ReleaseSW), - absolute positioning commands (GoTo, GoTo\_DIR, GoHome, GoMark), - motion commands (Move), - stop commands (SoftStop, HardStop, SoftHiz, HardHiz). For detailed command descriptions refer to Section 9.2 on page 54. ### 6.7.1 Constant speed commands A constant speed command produces a motion in order to reach and maintain a userdefined target speed starting from the programmed minimum speed (set in MIN\_SPEED register) and with the programmed acceleration/deceleration value (set in ACC and DEC registers). A new constant speed command can be requested anytime. Figure 8. Constant speed commands examples ### 6.7.2 Positioning commands An absolute positioning command produces a motion in order to reach a user-defined position that is sent to the device together with the command. The position can be reached performing the minimum path (minimum physical distance) or forcing a direction (see *Figure 9*). Performed motor motion is compliant to programmed speed profile boundaries (acceleration, deceleration, minimum and maximum speed). Note that with some speed profiles or positioning commands, the deceleration phase can start before the maximum speed is reached. Figure 9. Positioning command examples ### 6.7.3 Motion commands Motion commands produce a motion in order to perform a user-defined number of microsteps in a user-defined direction that are sent to the device together with the command (see *Figure 10*). Performed motor motion is compliant to programmed speed profile boundaries (acceleration, deceleration, minimum and maximum speed). Note that with some speed profiles or motion commands, the deceleration phase can start before the maximum speed is reached. Figure 10. Motion commands examples ### 6.7.4 Stop commands A stop command forces the motor to stop. Stop commands can be sent anytime. Doc ID 16737 Rev 3 SoftStop command causes the motor to decelerate with programmed deceleration value until MIN\_SPEED value is reached and then stops the motor keeping the rotor position (a holding torque is applied). HardStop command stops the motor instantly ignoring deceleration constrain and keeping the rotor position (a holding torque is applied). SoftHiZ command causes the motor to decelerate with programmed deceleration value until MIN\_SPEED value is reached and then forces the bridges in high impedance state (no holding torque is present). HardHiZ command instantly forces the bridges in high impedance state (no holding torque is present). ### 6.7.5 Step-clock mode In step clock mode the motor motion is defined by the step clock signal applied to STCK pin. At each step clock rising edge, the motor is moved of one microstep in the programmed direction and absolute position is consequently updated. When the system is in step clock mode the SCK\_MOD flag in STATUS register is raised, SPEED register is set to zero and motor status is considered stopped whatever the STCK signal frequency (MOT\_STATUS parameter in STATUS register equal to "00"). ### 6.7.6 GoUntil and ReleaseSW commands In most applications the power-up position of the stepper motor is undefined, so an initialization algorithm driving the motor to a known position is necessary. The GoUntil and ReleaseSW commands can be used in combination with external switch input (see *Section 6.13*) to easily initialize the motor position. GoUntil command makes the motor run at target constant speed until the SW input is forced low (falling edge). When this event occurs, one of the following actions can be performed: - ABS\_POS register is set to zero (home position) and the motor decelerates to zero speed (as a SoftStop command); - ABS\_POS register value is stored into MARK register and the motor decelerates to zero speed (as a SoftStop command). If the SW\_MODE bit of CONFIG register is set to '0', the motor do not decelerates but it immediately stops (as a HardStop command). ReleaseSW command makes the motor run at programmed minimum speed until the SW input is forced high (rising edge). When this event occurs, one of the following actions can be performed: - ABS\_POS register is set to zero (home position) and the motor immediately stops (as a HardStop command); - ABS\_POS register value is stored into MARK register and the motor immediately stops (as a HardStop command). If the programmed minimum speed is lesser than 5 step/s, the motor is driven at 5 step/s. #### 6.8 Internal oscillator and oscillator driver The control logic clock can be supplied by the internal 16 MHz oscillator, an external oscillator (crystal or ceramic resonator) or a direct clock signal. These working modes can be selected by EXT\_CLK and OSC\_SEL parameters in the CONFIG register (see Table 23). At power-up the device starts using the internal oscillator and provides a 2 MHz clock signal on the OSCOUT pin. Attention: In any case, before changing clock source configuration, a hardware reset is mandatory. Switching to different clock configurations during operation could cause unexpected behavior. #### 6.8.1 Internal oscillator In this mode the internal oscillator is activated and OSCIN is unused. If OSCOUT clock source is enabled, OSCOUT pin provides a 2, 4, 8 or 16 MHz clock signal (according to OSC\_SEL value); otherwise it is unused (see *Figure 11*). #### 6.8.2 **External clock source** Two types of external clock source can be selected: crystal/ceramic resonator or direct clock source. Four programmable clock frequencies are available for each external clock source: 8, 16, 24 and 32 MHz. When an external crystal/resonator is selected, OSCIN and OSCOUT pins are used to drive the crystal/resonator (see *Figure 11*). Crystal/resonator and load capacitors (C<sub>1</sub>) must be placed as close as possible to the pins. Refer to Table 8 for the choice of the load capacitor value according to the external oscillator frequency. | <del>_</del> | · · · · · · · · · · · · · · · · · · · | |-----------------------------|-----------------------------------------| | Crystal/resonator freq. (1) | C <sub>L</sub> <sup>(2)</sup> | | 8MHz | 25pF (ESR <sub>max</sub> = $80\Omega$ ) | | 16MHz | 18pF (ESR <sub>max</sub> = $50\Omega$ ) | | 24MHz | 15pF (ESR <sub>max</sub> = $40\Omega$ ) | | 32MHz | 10pF (ESR <sub>max</sub> = $40\Omega$ ) | Table 8. CL values according to external oscillator frequency If a direct clock source is used, it must be connected to OSCIN pin and OSCOUT pin supplies the inverted OSCIN signal (see Figure 11). First harmonic resonance frequency. <sup>2.</sup> Lower ESR value allows driving greater load capacitors. Figure 11. OSCIN and OSCOUT pins configurations Note: When OSCIN is UNUSED, it should be left floating. When OSCOUT is UNUSED it should be left floating. ### 6.9 Overcurrent detection When the current in any of the power MOSFETs exceeds a programmed overcurrent threshold, STATUS register OCD flag is forced low until the overcurrent event is expired and a GetStatus command is sent to the IC (see paragraphs 9.1.22 and 9.1.17). Overcurrent event expires when all the power MOSFET currents fall below the programmed overcurrent threshold. The overcurrent threshold can be programmed through the OCD\_TH register in one of 16 available values ranging from 375 mA to 6 A with steps of 375 mA (see *Table 9*, paragraph 9.1.17). It is possible to set if an overcurrent event causes or not the MOSFETs turn-off (bridges in high impedance status) acting on OC\_SD bit in the CONFIG register (see paragraph 9.1.21). The OCD flag in the STATUS register is raised anyway (see *Table 34*, paragraph 9.1.22). When the IC outputs are turned-off by an OCD event, they cannot be turned on until the OCD flag is released by a GetStatus command. Attention: The overcurrent shutdown is a critical protection feature. It is not recommended to disable it. # 6.10 Undervoltage lock-out (UVLO) The L6470 provides a motor supply UVLO protection. When the motor supply voltage falls below the $V_{SthOff}$ threshold voltage, STATUS register UVLO flag is forced low. When a GetStatus command is sent to the IC, and the undervoltage condition is expired, the UVLO flag is released (see paragraphs 9.1.22 and 9.2.20). Undervoltage condition expires when the motor supply voltage goes over the $V_{SthOn}$ threshold voltage. When the device is in undervoltage condition no motion command can be performed. UVLO flag is forced low by logic reset (power-up included) even if no UVLO condition is present. # 6.11 Thermal warning and thermal shutdown An internal sensor allows the L6470 to detect when the device internal temperature exceeds a thermal warning or an overtemperature threshold. When the thermal warning threshold $(T_{j(WRN)})$ is reached the TH\_WRN bit in the STATUS register is forced low (see paragraph 9.1.22) until the temperature decrease below $T_{j(WRN)}$ and a GetStatus command is sent to the IC (see paragraphs 9.1.22 and 9.2.20). When the thermal shutdown threshold $(T_{j(OFF)})$ is reached the device goes in thermal shutdown condition: the TH\_SD bit in the STATUS register is forced low, the power bridges are disabled bridges in high impedance state and the HiZ bit in the STATUS register is raised (see paragraph 9.1.22). Thermal shutdown condition only expires when the temperature goes below the thermal warning threshold $(T_{i(WRN)})$ . On exit from thermal shutdown condition the bridges are still disabled (HiZ flag high); whichever motion command makes the device exiting from High Z state (HardStop and SoftStop included). # 6.12 Reset and standby The device can be reset and put into standby mode through a dedicated pin. When \$\overline{STBY}\RST\$ pin is driven low, the bridges are left open (High Z state), the internal charge pump is stopped, the SPI interface and control logic are disabled and the internal 3 V voltage regulator maximum output current is reduced to \$I\_{REG,STBY}\$; as a result the L6470 heavily reduces the power consumption. At the same time the registers values are reset to default and all protection functions are disabled. \$\overline{STBY}\RST\$ input has to be forced low at least for \$t\_{STBY,min}\$ in order to ensure the complete switch to standby mode. On exit from standby mode, as well as for IC power-up, a delay of up to $t_{logicwu}$ must be given before applying a new command to allow proper oscillator and logic startup and a delay of up to $t_{cpwu}$ must be given to allow the charge pump startup. On exit from standby mode the bridges are disabled (HiZ flag high) and whichever motion command makes the device exiting from High Z state (HardStop and SoftStop included). Attention: It is not recommended to reset device when outputs are active. The device should be switched to high impedance state before being reset. # 6.13 External switch (SW pin) The SW input is internally pulled-up to $V_{DD}$ and detects if the pin is open or connected to ground (see *Figure 12*). The SW\_F bit of STATUS register indicates if the switch is open ('0') or closed ('1') (see paragraph 9.1.22); the bit value is refreshed at every system clock cycle (125 ns). SW\_EVN flag of STATUS register is raised when a switch turn-on event (SW input falling edge) is detected (see paragraph 9.1.22). A GetStatus command releases the SW\_EVN flag (see paragraph 9.2.20. By default a switch turn-on event causes a HardStop interrupt (SW\_MODE bit of CONFIG register set to '0'). Otherwise (SW\_MODE bit of CONFIG register set to '1'), switch input events do not cause interrupts and the switch status information are at user disposal (see *Table 34*, paragraph *9.1.22*). The switch input can used by GoUntil and ReleaseSW commands as described in paragraph *9.2.10* and *9.2.11*. If the SW input is not used, it should be connected to VDD. Figure 12. External switch connection # 6.14 Programmable DMOS slew-rate, dead-time and blanking-time Using the POW\_SR parameter in the CONFIG register, it is possible to set the commutation speed of the power bridges output (see *Table 26*, paragraph *9.1.21*). # 6.15 Integrated analog to digital converter The L6470 integrates a N<sub>ADC</sub> bit ramp-compare analog to digital converter with a reference voltage equal to VREG. The analog to digital converter input is available through the ADCIN pin and the conversion result is available in the ADC\_OUT register (see paragraph *9.1.16*). Sampling frequency is equal to the programmed PWM frequency. The ADC\_OUT value can be used for motor supply voltage compensation or can be at user disposal. ## 6.16 Internal voltage regulator The L6470 integrates a voltage regulator which generates a 3 V voltage starting from motor power supply (VSA and VSB). In order to make the voltage regulator stable, at least 22 $\mu$ F should be connected between VREG pin and ground (suggested value is 47 $\mu$ F). The internal voltage regulator can be used to supply the VDD pin in order to make the device digital output range 3.3 V compatible (*Figure 13*). A digital output range 5 V compatible can be obtained connecting VDD pin to an external 5 V voltage source. In both cases, a 10 $\mu$ F capacitance should be connected to VDD pin in order to obtain a correct operation. The internal voltage regulator is able to supply a current up to $I_{REG,MAX}$ , internal logic consumption included ( $I_{logic}$ ). When the device is in standby mode the maximum current that can be supplied is $I_{REG,STBY}$ , internal consumption included ( $I_{logic}$ , STBY). If an external 3.3 V regulated voltage is available, it can be applied to the VREG pin in order to supply all the internal logic and avoiding power dissipation of the internal 3 V voltage regulator (*Figure 13*). External voltage regulator should never sink current from VREG pin. Pigure 13. Internal 3 V linear regulator V<sub>SAN</sub> V<sub>REG</sub> V<sub>RE</sub> Figure 13. Internal 3 V linear regulator ## 6.17 BUSY\SYNC pin This pin is an open drain output which can be used as busy flag or synchronization signal according to SYNC\_EN bit value (STEP\_MODE register). ### 6.17.1 BUSY operation mode The pin works as busy signal when SYNC\_EN bit is set low (default condition). In this mode the output is forced low while a constant speed, absolute positioning or motion command is under execution. The BUSY pin is released when command has been executed (target speed or target position reached). The STATUS register includes a BUSY flag that is the BUSY pin mirror (see paragraph 9.1.22). In case of daisy-chain configuration, BUSY pins of different ICs can be hard-wired to save host controller GPIOs. ### 6.17.2 SYNC operation mode The pin works as synchronization signal when SYNC\_EN bit is set high. In this mode a step clock signal is provided on output according to SYNC\_SEL and STEP\_SEL parameters combination (see paragraph *9.1.19*). ## 6.18 FLAG pin By default an internal open drain transistor pulls the $\overline{FLAG}$ pin to ground when at least one of the following conditions occurs: - Power-up or standby/reset exit, - Stall detection on A bridge, - Stall detection on B bridge, - Overcurrent detection, - Thermal warning, - Thermal shutdown, - UVLO. - Switch turn-on event, - Wrong command, - Non performable command. It is possible to mask one or more alarm conditions by programming the ALARM\_EN register (see paragraph *9.1.20*, *Table 21*). If the corresponding bit of ALARM\_EN register is low, the alarm condition is masked and it does not cause a FLAG pin transition; all other actions imposed by alarm conditions are performed anyway. In case of daisy-chain configuration, FLAG pins of different ICs can be or-wired to save host controller GPIOs. Phase current control L6470 ### 7 Phase current control The L6470 controls the phase current applying a sinusoidal voltage to motor windings. Phase current amplitude is not directly controlled but depends on phase voltage amplitude, load torque, motor electrical characteristics and rotation speed. Sinewave amplitude is proportional to the motor supply voltage multiplied by a coefficient (K<sub>VAL</sub>). K<sub>VAL</sub> ranges from 0 to 100% and the sinewave amplitude can be obtained through the following formula: ### **Equation 1** $$V_{OLIT} = V_S \cdot K_{VAL}$$ Different K<sub>VAL</sub> values can be programmed for acceleration, deceleration and constant speed phases and when motor is stopped (HOLD phase) through KVAL\_ACC, KVAL\_DEC, KVAL\_RUN and KVAL\_HOLD registers (see paragraph *9.1.10*). KVAL value is calculated according following formula: ### **Equation 2** $$\mathsf{K}_{\mathsf{VAL}} = \big(\!\big(\mathsf{K}_{\mathsf{VAL}_{-}\!\mathsf{X}} + \mathsf{BEMF}_{-}\!\mathsf{COMP}\big) \!\times \mathsf{VSCOMP} \times \mathsf{K}_{-}\!\mathsf{THERM}\big) \!\times \mathsf{microstep}$$ Where $K_{VAL\_X}$ is the starting $K_{VAL}$ value programmed for present motion phase (KVAL\_ACC, KVAL\_DEC, KVAL\_RUN or KVAL\_HOLD), BEMF\_COMP is the BEMF compensation curve value, VSCOMP and K\_THERM are the motor supply voltage and winding resistance compensation factors and microstep is the current microstep value (fraction of target peak current). L6470 offers various methods to guarantee a stable current value, allowing the compensation of: - low speed optimization (see paragraph 7.3) - back electromotive force value (see paragraph 7.4); - motor supply voltage variation (see paragraph 7.5); - windings resistance variation (see paragraph 7.6). ### 7.1 PWM sinewave generators The two voltage sinewaves applied to stepper motor phases are generated by two PWM modulators. The PWM frequency ( $f_{PWM}$ ) is proportional to the oscillator frequency ( $f_{OSC}$ ) and can be obtained through the following formula: ### **Equation 3** $$f_{PWM} = \frac{f_{OSC}}{512 \cdot N} \cdot m$$ 'N' is the integer division factor and 'm' is the multiplication factor. 'N' and 'm' values can be programmed by F\_PWM\_INT and F\_PWM\_DEC parameters in CONFIG register (see *Table 28* and *Table 29*, paragraph *9.1.21*). L6470 Phase current control Available PWM frequencies are listed in paragraph 9.1.21 from Table 30 to Table 33. ### 7.2 Sensorless stall detection Depending on motor speed and load angle characteristics, L6470 offers a motor stall condition detection using a programmable current comparator. When a stall event occurs, the respective flag (STEP\_LOSS\_A or STEP\_LOSS\_B) is forced low until a GetStaus command or a system reset occurs (see paragraph *9.2.20*). ### 7.3 Low speed optimization When motor is driven at a very low speed using a small driving voltage, the resulting phase current can be distorted. As a consequence, the motor position is different from the ideal one (see *Figure 14*). L6470 implements a low speed optimization in order to remove this effect. Figure 14. Current distortion and compensation The optimization can be enabled setting high the LSPD\_OPT bit in MIN\_SPEED register (see paragraph *9.1.8*) and is active into speed range from zero to MIN\_SPEED. When low speed optimization is enabled, speed profile minimum speed is forced to zero. Phase current control L6470 # 7.4 BEMF compensation Using the speed information, a compensation curve is added to the amplitude of the voltage waveform applied to the motor winding in order to compensate the BEMF variations during acceleration and deceleration (see *Figure 15*). Compensation curve is approximated by a stacked line with a starting slope (ST\_SLP) when speed is lower than a programmable threshold speed (INT\_SPEED) and a fine slope (FN\_SLP\_ACC and FN\_SLP\_DEC) when speed is greater than the threshold speed (see paragraphs 9.1.11, 9.1.12, 9.1.13 and 9.1.14). Figure 15. BEMF compensation curve To obtain different current values during acceleration and deceleration phase two different final slope values, and consequently two different compensation curves, can be programmed. Acceleration compensation curve is applied when the motor runs. No BEMF compensation is applied when the motor is stopped. # 7.5 Motor supply voltage compensation The sinewave amplitude generated by the PWM modulators is directly proportional to the motor supply voltage ( $V_S$ ). When the motor supply voltage is different from its nominal value, the motor phases are driven with an incorrect voltage. The L6470 can compensate motor supply voltage variations in order to avoid this effect. The motor supply voltage should be connected to the integrated ADC input through a resistor divider in order to obtain $V_{REG}/2$ voltage at the ADCIN pin when $V_S$ is at its nominal value (see *Figure 16*). The ADC input is sampled at f<sub>S</sub> frequency, which is equal to PWM frequency. L6470 Phase current control $V_{ADCIN} = V_S \times R_B / (R_A + R_B)$ $R_A = \frac{V_{REG}}{ADC}$ $R_B = \frac{V_{REG}}{f_{PWM}}$ AM0238991 Figure 16. Motor supply voltage compensation circuit Motor supply voltage compensation can be enabled setting high the EN\_VSCOMP bit of the CONFIG register (see *Table 22*, paragraph *9.1.21*). If EN\_VSCOMP bit is low the compensation is disabled and the internal analog to digital converter is at user disposal; sampling rate is always equal to PWM frequency. # 7.6 Winding resistance thermal drift compensation The higher is the winding resistance the greater is the voltage to be applied in order to obtain the same phase current. The L6470 integrates a register (K\_THERM) which can be used to compensate phase resistance increment due by temperature rising. The value in K\_THERM register (see paragraph *9.1.15*) multiplies duty cycle value allowing to face higher phase resistance value. The compensation algorithm and the eventual motor temperature measurement should be implemented by microcontroller firmware. Serial interface L6470 ### 8 Serial interface The integrated 8bit serial peripheral interface (SPI) is used for a synchronous serial communication between the host microprocessor (always master) and the L6470 (always slave). The SPI uses chip select $(\overline{CS})$ , serial clock (CK), serial data input (SDI) and serial data output (SDO) pins. When $\overline{CS}$ is high the device is unselected and the SDO line is inactive (high-impedance). The communication starts when $\overline{\text{CS}}$ is forced low. The CK line is used for synchronization of data communication. All commands and data bytes are shifted into the device through the SDI input, most significant bit first. The SDI is sampled on the rising edges of the CK. All output data bytes are shifted out of the device through the SDO output, most significant bit first. The SDO is latched on the falling edges of the CK. When a return value from the device is not available, an all zero byte is sent. After each byte transmission the $\overline{\text{CS}}$ input must be raised and be kept high for at least $t_{\text{disCS}}$ in order to allow the device to decode the received command and put into the shift register the return value. All timing requirements are shown in *Figure 17* (see respective electrical characteristics section for values). Multiple devices can be connected in daisy-chain configuration, as shown in Figure 18. Doc ID 16737 Rev 3 Figure 17. SPI timings diagram L6470 Serial interface AM02391v1 # 9 Programming manual ## 9.1 Registers and flags description Following a map of the user registers available (detailed description in respective paragraphs): Table 9. Registers map | Address<br>[Hex] | Register name | Register function | Len.<br>[bit] | Reset<br>Hex | Reset<br>Value | Remarks<br>(1) | |------------------|---------------|----------------------------------------|---------------|-------------------|-----------------------------------------------------------------|----------------| | h01 | ABS_POS | Current position | 22 | 000000 | 0 | R, WS | | h02 | EL_POS | Electrical position | 9 | 000 | 0 | R, WS | | h03 | MARK | Mark position | 22 | 000000 | 0 | R, WR | | h04 | SPEED | Current speed | 20 | 00000 | 0 step/tick<br>(0 step/s) | R | | h05 | ACC | Acceleration | 12 | 08A | 125.5e-12 step/tick <sup>2</sup> (2008 step/s <sup>2</sup> ) | R, WS | | h06 | DEC | Deceleration | 12 | 08A | 125.5e-12 step/tick <sup>2</sup><br>(2008 step/s <sup>2</sup> ) | R, WS | | h07 | MAX_SPEED | Maximum speed | 10 | 041 | 248e-6 step/tick<br>(991.8 step/s) | R, WR | | h08 | MIN_SPEED | Minimum speed | 13 | 000 | 0 step/tick<br>(0 step/s) | R, WS | | h15 | FS_SPD | Full step speed | 10 | 027 | 150.7e-6 step/tick<br>(602.7 step/s) | R, WR | | h09 | KVAL_HOLD | Holding K <sub>VAL</sub> | 8 | 29 | 0.16·VS | R, WR | | h0A | KVAL_RUN | Constant speed K <sub>VAL</sub> | 8 | 29 | 0.16·VS | R, WR | | h0B | KVAL_ACC | Acceleration starting K <sub>VAL</sub> | 8 | 29 | 0.16·VS | R, WR | | h0C | KVAL_DEC | Deceleration starting K <sub>VAL</sub> | 8 | 29 | 0.16·VS | R, WR | | h0D | INT_SPD | Intersect speed | 14 | 0408 | 61.5e-6 step/tick (246 step/s) | R, WH | | h0E | ST_SLP | Start slope | 8 | 19 | 0.038% s/step | R, WH | | h0F | FN_SLP_ACC | Acceleration final slope | 8 | 29 | 0.063% s/step | R, WH | | h10 | FN_SLP_DEC | Deceleration final slope | 8 | 29 | 0.063% s/step | R, WH | | h11 | K_THERM | Thermal compensation factor | 4 | 0 | 1.0 | R, WR | | h12 | ADC_OUT | ADC output | 5 | XX <sup>(2)</sup> | | R | | h13 | OCD_TH | OCD threshold | 4 | 8 | 3.38A | R, WR | | h14 | STALL_TH | STALL threshold | 7 | 40 | 2.03A | R, WR | | h16 | STEP_MODE | Step mode | 8 | 7 | 128 microsteps | R, WH | | h17 | ALARM_EN | Alarms enables | 8 | FF | All alarms enabled | R, WS | **Address** Reset Reset Len. Remarks Register name **Register function** [bit] [Hex] Hex Value Internal oscillator, 2MHz OSCOUT clock, supply voltage compensation h18 **CONFIG** IC configuration 16 2E88 disabled. R, WH overcurrent shutdown enabled, slew-rate = 290 V/µs PWM frequency = 15.6kHz. High impedance state, XXXX<sup>(2)</sup> **STATUS** h19 Status R 16 UVLO/Reset flag set. h1A **RESERVED** Reserved address h<sub>1</sub>B **RESERVED** Reserved address Table 9. Registers map (continued) #### 9.1.1 ABS\_POS The ABS\_POS register contains the current motor absolute position in agreement to the selected step mode; the stored value unit is equal to the selected step mode (full, half, quarter, etc.). The value is in two's complement format and it ranges from $-2^{21}$ to $+2^{21}$ -1. At power-on the register is initialized to "0" (HOME position). Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). #### 9.1.2 EL POS The EL\_POS register contains the current electrical position of the motor. The two MSbits indicate the current step and the other bits indicate the current microstep (expressed in step/128) within the step. Table 10. EL POS register | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | |-------|-------|-------|-----------|-------|-------|-------|-------|-------|--|--| | ST | EP | | MICROSTEP | | | | | | | | When the EL\_POS register is written by the user the new electrical position is instantly imposed. When the EL\_POS register is written its value must be masked in order to match with the step mode selected in STEP\_MODE register in order to avoid a wrong microstep value generation (see paragraph *9.1.19*); otherwise the resulting microstep sequence will be incorrect. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). R: Readable, WH: writable only when outputs are in high impedance, WS: writable only when motor is stopped, WR: always writable. <sup>2.</sup> According to startup conditions. #### 9.1.3 MARK The MARK register contains an absolute position called MARK in according to the selected step mode; the stored value unit is equal to the selected step mode (full, half, quarter, etc.). It is in two's complement format and it ranges from $-2^{21}$ to $+2^{21}$ -1. #### 9.1.4 SPEED The SPEED register contains the current motor speed, expressed in step/tick (format unsigned fixed point 0.28). In order to convert the SPEED value in step/s the following formula can be used: #### **Equation 4** $$[\text{step/s}] = \frac{\text{SPEED} \cdot 2^{-28}}{\text{tick}}$$ where SPEED is the integer number stored into the register and tick is 250 ns. The available range is from 0 to 15625 step/s with a resolution of 0.015 step/s. Note: The range effectively available to the user is limited by the MAX\_SPEED parameter. Any attempt to write the register causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph *9.1.22*). #### 9.1.5 ACC The ACC register contains the speed profile acceleration expressed in step/tick<sup>2</sup> (format unsigned fixed point 0.40). In order to convert ACC value in step/s<sup>2</sup> the following formula can be used: #### **Equation 5** $$\left[ \text{step/s}^2 \right] = \frac{\text{ACC} \cdot 2^{-40}}{\text{tick}^2}$$ where ACC is the integer number stored into the register and tick is 250 ns. The available range is from 14.55 to 59590 step/s<sup>2</sup> with a resolution of 14.55 step/s<sup>2</sup>. When the ACC value is set to 0xFFF the device works in infinite acceleration mode. Any attempt to write to the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph *9.1.22*). #### 9.1.6 DEC The DEC register contains the speed profile deceleration expressed in step/tick<sup>2</sup> (format unsigned fixed point 0.40). In order to convert DEC value in step/s<sup>2</sup> the following formula can be used: #### **Equation 6** $$\left[ \text{step/s}^2 \right] = \frac{\text{DEC} \cdot 2^{-40}}{\text{tick}^2}$$ where DEC is the integer number stored into the register and tick is 250 ns. The available range is from 14.55to 59590 step/s2 with a resolution of 14.55 step/s2. When the device is working in infinite acceleration mode this value is ignored. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). #### 9.1.7 MAX SPEED The MAX\_SPEED register contains the speed profile maximum speed expressed in step/tick (format unsigned fixed point 0.18). In order to convert it in step/s the following formula can be used: #### **Equation 7** $$[step/s] = \frac{MAX\_SPEED \cdot 2^{-18}}{tick}$$ where MAX\_SPEED is the integer number stored into the register and tick is 250 ns. The available range is from 15.25 to 15610 step/s with a resolution of 15.25 step/s. #### **9.1.8 MIN SPEED** The MIN\_SPEED register contains following parameters: Table 11. MIN\_SPEED register | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |----------|--------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | LSPD_OPT | | MIN_SPEED | | | | | | | | | | | The MIN\_SPEED parameter contains the speed profile minimum speed. Its value is expressed in step/tick and to convert it in step/s the following formula can be used: $$[step/s] = \frac{MIN\_SPEED \cdot 2^{-24}}{tick}$$ where MIN\_SPEED is the integer number stored into the register and tick is the ramp 250 ns. The available range is from 0 to 976.3 step/s with a resolution of 0.238 step/s. When LSPD\_OPT bit is set high, low speed optimization feature is enabled and MIN\_SPEED value indicates the speed threshold below which the compensation works. In this case the minimum speed of speed profile is set to zero. An attempt to write the register when the motor is running causes the NOTPERF\_CMD flag to rise. ## 9.1.9 FS\_SPD The FS\_SPD register contains the threshold speed. When the actual speed exceeds this value the step mode is automatically switched to Full Step two-phase on. Its value is expressed in step/tick (format unsigned fixed point 0.18) and to convert it in step/s the following formula can be used. #### **Equation 8** $$[\text{step/s}] = \frac{(\text{FS}_{\text{SPD}} + 0.5) \cdot 2^{-18}}{\text{tick}}$$ If FS\_SPD value is set to hFF (max) the system always works in microstepping mode (SPEED must go beyond the threshold to switch to full step mode). Setting FS\_SPD to zero has not the same effect as setting step mode to full step two phase on: zero FS\_SPD value is equivalent to a speed threshold of about 7.63 step/s. The available range is from 7.63 to 15625 step/s with a resolution of 15.25 step/s. #### 9.1.10 KVAL HOLD, KVAL RUN, KVAL ACC and KVAL DEC The KVAL\_HOLD register contains the K<sub>VAL</sub> value that is assigned to the PWM modulators when the motor is stopped (compensations excluded). The KVAL\_RUN register contains the $K_{VAL}$ value that is assigned to the PWM modulators when the motor is running at constant speed (compensations excluded). The KVAL\_ACC register contains the starting $K_{VAL}$ value that can be assigned to the PWM modulators during acceleration (compensations excluded). The KVAL\_DEC register contains the starting K<sub>VAL</sub> value that can be assigned to the PWM modulators during deceleration (compensations excluded). The available range is from 0 to 0.996 x $V_S$ with a resolution of 0.004 x $V_S$ as shown in *Table 12*. | | | | Output voltage | | | | | | |---|---|---|----------------|---|---|---|---|----------------------------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | V <sub>S</sub> x (1/256) | | : | ÷ | : | : | : | ÷ | : | ÷ | : | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | V <sub>S</sub> x (254/256) | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | V <sub>S</sub> x (255/256) | Table 12. Voltage amplitude regulation registers ## 9.1.11 INT\_SPEED The INT\_SPEED register contains the speed value at which the BEMF compensation curve changes slope (see paragraph 7.4 for details). Its value is expressed in step/tick and to convert it in [step/s] the following formula can be used: #### **Equation 9** $$[step/s] = \frac{INT\_SPEED \cdot 2^{-24}}{tick}$$ where INT\_SPEED is the integer number stored into the register and tick is 250 ns. The available range is from 0 to 3906 step/s with a resolution of 0.238 step/s. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). #### 9.1.12 ST SLP The ST\_SLP register contains the BEMF compensation curve slope that is used when the speed is lower than the intersect speed (see paragraph *7.4* for details). Its value is expressed in s/step and the available range is from 0 to 0.004 with a resolution of 0.000015. When ST\_SLP, FN\_SLP\_ACC and FN\_SLP\_DEC parameters are set to zero no BEMF compensation is performed. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). #### 9.1.13 FN SLP ACC The FN\_SLP\_ACC register contains the BEMF compensation curve slope that is used when the speed is greater than the intersect speed during acceleration (see paragraph 7.4 for details). Its value is expressed in s/step and the available range is from 0 to 0.004 with a resolution of 0.000015. When ST\_SLP, FN\_SLP\_ACC and FN\_SLP\_DEC parameters are set to zero no BEMF compensation is performed. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). ## 9.1.14 FN SLP DEC The FN\_SLP\_DEC register contains the BEMF compensation curve slope that is used when the speed is greater than the intersect speed during deceleration (see paragraph 7.4 for details). Its value is expressed in s/step and the available range is from 0 to 0.004 with a resolution of 0.000015. When ST\_SLP, FN\_SLP\_ACC and FN\_SLP\_DEC parameters are set to zero no BEMF compensation is performed. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). #### 9.1.15 K THERM The K\_THERM register contains the value used by the winding resistance thermal drift compensation system (see paragraph 7.6). The available range is from 1 to 1.46875 with a resolution of 0.03125 as shown in *Table 13*. | | | | | · | |---|--------|---------|---|---------------------| | | K_THEF | RM [30] | | Compensation coeff. | | 0 | 0 | 0 | 0 | 1 | | 0 | 0 | 0 | 1 | 1.03125 | | : | : | : | : | : | | 1 | 1 | 1 | 0 | 1.4375 | | 1 | 1 | 1 | 1 | 1.46875 | Table 13. Winding resistance thermal drift compensation coefficient ## 9.1.16 ADC\_OUT The ADC\_OUT register contains the result of the analog to digital conversion of the ADCIN pin voltage; the result is available even if the supply voltage compensation is disabled. Any attempt to write to the register causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). Table 14. ADC\_OUT value and motor supply voltage compensation feature | Vs | V <sub>ADCIN</sub> /V <sub>REG</sub> | | ADC_OUT<br>[40] | | | | Compensation coefficient | |----------------------------------------------------|--------------------------------------|---|-----------------|---|---|---|--------------------------| | Greater than V <sub>S</sub> , <sub>nom</sub> + 50% | > 24/32 | 1 | 1 | Χ | Χ | Χ | 0.65625 | | V <sub>S'nom</sub> + 50% | 24/32 | 1 | 1 | 0 | 0 | 0 | 0.65625 | | : | : | : | : | : | : | | i i | | V <sub>S</sub> ,nom | 16/32 | 1 | 0 | 0 | 0 | 0 | 1 | | : | : | : | : | : | : | | i i | | V <sub>S'nom</sub> – 50% | 8/32 | 0 | 1 | 0 | 0 | 0 | 1.968875 | | Lower than V <sub>S</sub> , <sub>nom</sub> – 50% | < 8/32 | 0 | 0 | Х | Χ | Х | 1.968875 | 45/67 ## 9.1.17 OCD\_TH The OCD\_TH register contains the overcurrent threshold value (see paragraph 6.9 for details). The available range is from 375 mA to 6 A, steps of 375 mA as shown in *Table 15*. Table 15. Overcurrent detection threshold | | OCD_TH [30] | | | Overcurrent detection threshold | |---|-------------|---|---|---------------------------------| | 0 | 0 | 0 | 0 | 375 mA | | 0 | 0 | 0 | 1 | 750 mA | | | | | | | | 1 | 1 | 1 | 0 | 5.625 A | | 1 | 1 | 1 | 1 | 6 A | ## 9.1.18 STALL\_TH The STALL\_TH register contains the stall detection threshold value (see paragraph 7.2 for details). The available range is from 31.25 mA to 4 A with a resolution of 31.25 mA. Table 16. Stall detection threshold | | | STAI | LL_th | [60] | | | Stall detection threshold | |---|---|------|-------|------|---|---|---------------------------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 31.25 mA | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 62.5 mA | | | | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 3.969 A | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 4 A | ## 9.1.19 **STEP\_MODE** The STEP\_MODE register has the following structure: Table 17. STEP\_MODE register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------|-------|----------|-------|-------|----------|-------|-------| | SYNC_EN | | SYNC_SEL | | 0 (1) | STEP_SEL | | | <sup>1.</sup> When the register is written this bit should be set to 0. The STEP\_SEL parameter selects one of eight possible stepping modes: Table 18. Step mode selection | | STEP_SEL[20] | | Step mode | |---|--------------|---|-----------------| | 0 | 0 | 0 | Full step | | 0 | 0 | 1 | Half step | | 0 | 1 | 0 | 1/4 microstep | | 0 | 1 | 1 | 1/8 microstep | | 1 | 0 | 0 | 1/16 microstep | | 1 | 0 | 1 | 1/32 microstep | | 1 | 1 | 0 | 1/64 microstep | | 1 | 1 | 1 | 1/128 microstep | Every time the step mode is changed the electrical position (i.e. the point of microstepping sinewave that is generated) is reset to the first microstep. Warning: Every time STEP\_SEL is changed the value in ABS\_POS register looses meaning and should be reset. Any attempt to write the register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). When when SYNC\_EN bit is set low BUSY/SYNC output is forced low during commands execution, otherwise, when SYNC\_EN bit is set high, BUSY/SYNC output provides a clock signal according to SYNC\_SEL parameter. Table 19. SYNC output frequency | | | STEP_SEL<br>(f <sub>FS</sub> is the full step frequency) | | | | | | | | | | |-----|----------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------|--|--|--| | | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | | | | | 000 | f <sub>FS</sub> /2 | | | | 001 | NA | f <sub>FS</sub> | | | | 010 | NA | NA | 2∙ f <sub>FS</sub> | 2∙ f <sub>FS</sub> | 2∙ f <sub>FS</sub> | 2∙ f <sub>FS</sub> | 2∙ f <sub>FS</sub> | 2⋅ f <sub>FS</sub> | | | | | 011 | NA | NA | NA | 4∙ f <sub>FS</sub> | 4∙ f <sub>FS</sub> | 4∙ f <sub>FS</sub> | 4∙ f <sub>FS</sub> | 4⋅ f <sub>FS</sub> | | | | | 100 | NA | NA | NA | NA | 8∙ f <sub>FS</sub> | 8⋅ f <sub>FS</sub> | 8⋅ f <sub>FS</sub> | 8⋅ f <sub>FS</sub> | | | | | 101 | NA | NA | NA | NA | NA | 16⋅ f <sub>FS</sub> | 16⋅ f <sub>FS</sub> | 16⋅ f <sub>FS</sub> | | | | | 110 | NA | NA | NA | NA | NA | NA | 32∙ f <sub>FS</sub> | 32⋅ f <sub>FS</sub> | | | | | 111 | NA 64∙ f <sub>FS</sub> | | | | | | 001<br>010<br>011<br>100<br>101<br>110 | 000 f <sub>FS</sub> /2 001 NA 010 NA 011 NA 100 NA 101 NA | 000 000 001 000 f <sub>FS</sub> /2 f <sub>FS</sub> /2 001 NA f <sub>FS</sub> 010 NA NA 011 NA NA 100 NA NA 101 NA NA 110 NA NA | (f <sub>FS</sub> ) 000 001 010 000 f <sub>FS</sub> /2 f <sub>FS</sub> /2 f <sub>FS</sub> /2 001 NA f <sub>FS</sub> f <sub>FS</sub> 010 NA NA 2. f <sub>FS</sub> 011 NA NA NA 100 NA NA NA 101 NA NA NA 110 NA NA NA | STE (f <sub>FS</sub> is the full of f i | STEP_SEL (f <sub>FS</sub> is the full step freq 000 001 010 011 100 000 f <sub>FS</sub> /2 f <sub>FS</sub> /2 f <sub>FS</sub> /2 f <sub>FS</sub> /2 001 NA f <sub>FS</sub> f <sub>FS</sub> f <sub>FS</sub> 010 NA NA 2· f <sub>FS</sub> 2· f <sub>FS</sub> 011 NA NA NA 4· f <sub>FS</sub> 100 NA NA NA NA 101 NA NA NA NA 110 NA NA NA NA 110 NA NA NA NA | STEP_SEL | STEP_SEL | | | | the synchronization signal is obtained starting from electrical position information (EL\_POS register) according to following *Table 10*: Table 20. SYNC signal source | | SYNC_SEL[20] | | Source | |---|--------------|---|-----------| | 0 | 0 | 0 | EL_POS[7] | | 0 | 0 | 1 | EL_POS[6] | | 0 | 1 | 0 | EL_POS[5] | | 0 | 1 | 1 | EL_POS[4] | | 1 | 0 | 0 | EL_POS[3] | | 1 | 0 | 1 | EL_POS[2] | | 1 | 1 | 0 | EL_POS[1] | | 1 | 1 | 1 | EL_POS[0] | ## 9.1.20 ALARM\_EN The ALARM\_EN register allows selecting which alarm signals are used to generate the FLAG output. If the respective bit of ALARM\_EN register is set high, the alarm condition forces the FLAG pin output down. Table 21. ALARM\_EN register | ALARM_EN bit | Alarm condition | |--------------|----------------------------------| | 0 (LSB) | Overcurrent | | 1 | Thermal shutdown | | 2 | Thermal warning | | 3 | Under-voltage | | 4 | Stall detection (Bridge A) | | 5 | Stall detection (Bridge B) | | 6 | Switch turn-on event | | 7 (MSB) | Wrong or not performable command | ## 9.1.21 **CONFIG** The CONFIG register has the following structure: Table 22. CONFIG register | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | |-----------|----------|-----------|-----------|---------|---------|--------|-------|--| | F_PWM_INT | | | F_PWM_DEC | | | POW_SR | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | OC_SD | RESERVED | EN_VSCOMP | SW_MODE | EXT_CLK | OSC_SEL | | | | The OSC\_SEL and EXT\_CLK bits set the system clock source: Table 23. Oscillator management | EXT_CLK | 0 | SC_SEL[2 | 0] | Clock source | OSCIN | OSCOUT | |---------|---|----------|----|-------------------------------------------------------------------|----------------------------|-----------------------------------| | 0 | 0 | 0 | 0 | | | | | 0 | 0 | 0 | 1 | Internal Oscillator: 16MHz | Unused | Unused | | 0 | 0 | 1 | 0 | micrial Oscillator. Town 12 | Onasca | Ondsed | | 0 | 0 | 1 | 1 | | | | | 1 | 0 | 0 | 0 | Internal Oscillator: 16MHz | Unused | Supplies a 2MHz<br>clock | | 1 | 0 | 0 | 1 | Internal Oscillator: 16MHz | Unused | Supplies a 4MHz<br>clock | | 1 | 0 | 1 | 0 | Internal oscillator: 16MHz | Unused | Supplies a 8MHz<br>clock | | 1 | 0 | 1 | 1 | Internal oscillator: 16MHz | Unused | Supplies a 16MHz clock | | 0 | 1 | 0 | 0 | External crystal or resonator: 8MHz | Crystal/reson ator driving | Crystal/resonator driving | | 0 | 1 | 0 | 1 | External crystal or resonator: 16MHz | Crystal/reson ator driving | Crystal/resonator driving | | 0 | 1 | 1 | 0 | External crystal or resonator: 24MHz | Crystal/reson ator driving | Crystal/resonator driving | | 0 | 1 | 1 | 1 | External crystal or resonator: 32MHz | Crystal/reson ator driving | Crystal/resonator driving | | 1 | 1 | 0 | 0 | Ext clock source: 8MHz<br>(Crystal/resonator driver<br>disabled) | Clock source | Supplies inverted OSCIN signal | | 1 | 1 | 0 | 1 | Ext clock source: 16MHz<br>(Crystal/resonator driver<br>disabled) | Clock source | Supplies inverted<br>OSCIN signal | | 1 | 1 | 1 | 0 | Ext clock source: 24MHz<br>(Crystal/resonator driver<br>disabled) | Clock source | Supplies inverted<br>OSCIN signal | | 1 | 1 | 1 | 1 | Ext clock source: 32MHz<br>(Crystal/resonator driver<br>disabled) | Clock source | Supplies inverted<br>OSCIN signal | The SW\_MODE bit sets the external switch to act as HardStop interrupt or not: Table 24. External switch hard stop interrupt mode | SW_MODE | Switch mode | |---------|--------------------| | 0 | HardStop interrupt | | 1 | User disposal | The OC\_SD bit sets if an overcurrent event causes or not the bridges to turn-off; the OCD flag in status register is forced low anyway: Table 25. Overcurrent event | OC_SD | Overcurrent event | |-------|--------------------------| | 1 | Bridges shut down | | 0 | Bridges do not shut down | The POW\_SR bits set the slew rate value of power bridge output: Table 26. Programmable power bridge output slew-rate values | | /_SR<br>0] | Output Slew-rate <sup>(1)</sup><br>[V/μs] | |---|------------|-------------------------------------------| | 0 | 0 | 180 | | 0 | 1 | 180 | | 1 | 0 | 290 | | 1 | 1 | 530 | <sup>1.</sup> See $S_{Rout\_r}$ and $S_{Rout\_f}$ parameters in the electrical characteristics *Table 5* for details. The EN\_VSCOMP bit sets if the motor supply voltage compensation is enabled or not. Table 27. Motor supply voltage compensation enable | EN_VSCOMP | Motor supply voltage compensation | |-----------|-----------------------------------| | 0 | Disabled | | 1 | Enabled | The F\_PWM\_INT bits set the integer division factor of PWM frequency generation. Table 28. PWM frequency: integer division factor | F_PWM_INT<br>[20] | | | Integer division factor | |-------------------|---|---|-------------------------| | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 2 | | 0 | 1 | 0 | 3 | | 0 | 1 | 1 | 4 | | 1 | 0 | 0 | 5 | | 1 | 0 | 1 | 6 | | 1 | 1 | 0 | 7 | | 1 | 1 | 1 | | The F\_PWM\_DEC bits set the multiplication factor of PWM frequency generation. Table 29. PWM frequency: multiplication factor | | F_PWM_DEC [20] | | Multiplication factor | |---|----------------|---|-----------------------| | 0 | 0 | 0 | 0.625 | | 0 | 0 | 1 | 0.75 | | 0 | 1 | 0 | 0.875 | | 0 | 1 | 1 | 1 | | 1 | 0 | 0 | 1.25 | | 1 | 0 | 1 | 1.5 | | 1 | 1 | 0 | 1.75 | | 1 | 1 | 1 | 2 | In the following tables all available PWM frequencies are listed according to oscillator frequency, F\_PWM\_INT and F\_PWM\_DEC values (CONFIG register OSC\_SEL parameter has to be correctly programmed). Table 30. Available PWM frequencies [kHz]: 8 MHz oscillator frequency | | | F_PWM_DEC | | | | | | | | | |---------------|-----|-----------|------|------|------|------|------|------|--|--| | F_PWM_<br>INT | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | | | | 000 | 9.8 | 11.7 | 13.7 | 15.6 | 19.5 | 23.4 | 27.3 | 31.3 | | | | 001 | 4.9 | 5.9 | 6.8 | 7.8 | 9.8 | 11.7 | 13.7 | 15.6 | | | | 010 | 3.3 | 3.9 | 4.6 | 5.2 | 6.5 | 7.8 | 9.1 | 10.4 | | | | 011 | 2.4 | 2.9 | 3.4 | 3.9 | 4.9 | 5.9 | 6.8 | 7.8 | | | | 100 | 2.0 | 2.3 | 2.7 | 3.1 | 3.9 | 4.7 | 5.5 | 6.3 | | | | 101 | 1.6 | 2.0 | 2.3 | 2.6 | 3.3 | 3.9 | 4.6 | 5.2 | | | | 110 | 1.4 | 1.7 | 2.0 | 2.2 | 2.8 | 3.3 | 3.9 | 4.5 | | | Table 31. Available PWM frequencies [kHz]: 16 MHz oscillator frequency | | F_PWM_DEC | | | | | | | | |-----------|-----------|------|------|------|------|------|------|------| | F_PWM_INT | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | | 000 | 19.5 | 23.4 | 27.3 | 31.3 | 39.1 | 46.9 | 54.7 | 62.5 | | 001 | 9.8 | 11.7 | 13.7 | 15.6 | 19.5 | 23.4 | 27.3 | 31.3 | | 010 | 6.5 | 7.8 | 9.1 | 10.4 | 13.0 | 15.6 | 18.2 | 20.8 | | 011 | 4.9 | 5.9 | 6.8 | 7.8 | 9.8 | 11.7 | 13.7 | 15.6 | | 100 | 3.9 | 4.7 | 5.5 | 6.3 | 7.8 | 9.4 | 10.9 | 12.5 | | 101 | 3.3 | 3.9 | 4.6 | 5.2 | 6.5 | 7.8 | 9.1 | 10.4 | | 110 | 2.8 | 3.3 | 3.9 | 4.5 | 5.6 | 6.7 | 7.8 | 8.9 | Table 32. Available PWM frequencies [kHz]: 24 MHz oscillator frequency | | F_PWM_DEC | | | | | | | | |-----------|-----------|------|------|------|------|------|------|------| | F_PWM_INT | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | | 000 | 29.3 | 35.2 | 41.0 | 46.9 | 58.6 | 70.3 | 82.0 | 93.8 | | 001 | 14.6 | 17.6 | 20.5 | 23.4 | 29.3 | 35.2 | 41.0 | 46.9 | | 010 | 9.8 | 11.7 | 13.7 | 15.6 | 19.5 | 23.4 | 27.3 | 31.3 | | 011 | 7.3 | 8.8 | 10.3 | 11.7 | 14.6 | 17.6 | 20.5 | 23.4 | | 100 | 5.9 | 7.0 | 8.2 | 9.4 | 11.7 | 14.1 | 16.4 | 18.8 | | 101 | 4.9 | 5.9 | 6.8 | 7.8 | 9.8 | 11.7 | 13.7 | 15.6 | | 110 | 4.2 | 5.0 | 5.9 | 6.7 | 8.4 | 10.0 | 11.7 | 13.4 | Programming manual L6470 F\_PWM\_DEC F PWM 000 001 010 011 100 101 110 111 INT 000 39.1 46.9 54.7 62.5 78.1 93.8 109.4 125.0 31.3 001 19.5 23.4 27.3 39.1 46.9 54.7 62.5 010 13.0 15.6 18.2 20.8 26.0 31.3 36.5 41.7 9.8 011 11.7 13.7 15.6 19.5 23.4 27.3 31.3 100 7.8 9.4 10.9 12.5 15.6 18.8 21.9 25.0 101 6.5 7.8 9.1 10.4 13.0 15.6 18.2 20.8 6.7 7.8 110 5.6 8.9 11.2 13.4 15.6 17.9 Table 33. Available PWM frequencies [kHz]: 32 MHz oscillator frequency Any attempt to write the CONFIG register when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph *9.1.22*). ## 9.1.22 STATUS Table 34. STATUS register | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | |-------------|-------------|-------------|--------|--------|--------|-------|-----------| | SCK_MOD | STEP_LOSS_B | STEP_LOSS_A | OCD | TH_SD | TH_WRN | UVLO | WRONG_CMD | | Bit 7 | Bit 6 | Bit 5 | | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | NOTPERF_CMD | MOT_S | DIR | SW_EVN | SW_F | BUSY | HiZ | | When HiZ flag is high it indicates that the bridges are in high impedance state. Whichever motion command makes the device to exit from High Z state (HardStop and SoftStop included), unless error flags forcing a High Z state are active. The UVLO flag is active low and is set by an under-voltage lock out or reset events (power-up included). The TH\_WRN, TH\_SD, OCD flags are active low and indicate respectively thermal warning, thermal shutdown and over-current detection events. STEP\_LOSS\_A and STEP\_LOSS\_B flags are forced low when a stall is detected on bridge A or bridge B respectively. The NOTPERF\_CMD and WRONG\_CMD flags are active high and indicate respectively that the command received by SPI can't be performed or does not exist at all. The SW\_F report the SW input status (low for open and high for closed). The SW\_EVN flag is active high and indicates a switch turn-on event (SW input falling edge). The UVLO, TH\_WRN, TH\_SD, OCD, STEP\_LOSS\_A, STEP\_LOSS\_B, NOTPERF\_CMD, WRONG\_CMD and SW\_EVN flags are latched: when the respective conditions make them active (low or high) they remain in that state until a GetStatus command is sent to the IC. The BUSY bit reflects the BUSY pin status. The BUSY flag is low when a constant speed, positioning or motion command is under execution and is released (high) after the command have been completed. The SCK\_MOD bit is an active high flag indicating that the device is working in step clock mode. In this case the step clock signal should be provided through STCK input pin. The DIR bit indicates the current motor direction: Table 35. STATUS register DIR bit | DIR | Motor direction | |-----|-----------------| | 1 | Forward | | 0 | Reverse | MOT\_STATUS indicates the current motor status: Table 36. STATUS register MOT\_STATE bits | MOT_S | STATUS | Motor status | | | | |-------|--------|----------------|--|--|--| | 0 | 0 | Stopped | | | | | 0 | 1 | Acceleration | | | | | 1 | 0 | Deceleration | | | | | 1 | 1 | Constant speed | | | | Any attempt to write to the register causes the command to be ignored and the NOTPERF\_CMD to rise (see paragraph *9.1.22*). ## 9.2 Application commands The commands summary is given in the *Table 37*. Table 37. Application commands | Command Mnemonic | Con | nma | nd bir | nary co | de | Action | | | |------------------------|------|-----|--------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | [75] | [4] | [3] | [21] | [0] | | | | | NOP | 000 | 0 | 0 | 00 | 0 | Nothing | | | | SetParam(PARAM, VALUE) | 000 | | [PA | RAM] | | Writes VALUE in PARAM register | | | | GetParam(PARAM) | 001 | | [PA | RAM] | | Returns the stored value in PARAM register | | | | Run(DIR,SPD) | 010 | 1 | 0 | 00 | DIR | Sets the target speed and the motor direction | | | | StepClock(DIR) | 010 | 1 | 1 | 00 | DIR | Put the device in step clock mode and impose DIR direction | | | | Move(DIR,N_STEP) | 010 | 0 | 0 | 00 | DIR | Makes N_STEP (micro)steps in DIR direction (Not performable when motor is running) | | | | GoTo(ABS_POS) | 011 | 0 | 0 | 00 | 0 | Brings motor in ABS_POS position (minimum path) | | | | GoTo_DIR(DIR,ABS_POS) | 011 | 0 | 1 | 00 | DIR | Brings motor in ABS_POS position forcing DIR direction | | | | GoUntil(ACT,DIR,SPD) | 100 | 0 | ACT | 01 | DIR | Perform a motion in DIR direction with speed SPD until SW is closed, the ACT action is executed then a SoftStop takes place | | | | ReleseSW(ACT, DIR) | 100 | 1 | ACT | 01 | DIR | Performs a motion in DIR direction at minimum speed until the SW is released (open), the ACT action is executed then a HardStop takes place | | | | GoHome | 011 | 1 | 0 | 00 | 0 | Brings the motor in HOME position | | | | GoMark | 011 | 1 | 1 | 00 | 0 | Brings the motor in MARK position | | | | ResetPos | 110 | 1 | 1 | 00 | 0 | Resets the ABS_POS register (set HOME position) | | | | ResetDevice | 110 | 0 | 0 | 00 | 0 | Device is reset to power-up conditions. | | | | SoftStop | 101 | 1 | 0 | 00 | 0 | Stops motor with a deceleration phase | | | | HardStop | 101 | 1 | 1 | 00 | 0 | Stops motor immediately | | | | SoftHiZ | 101 | 0 | 0 | 00 | 0 | Puts the bridges in High Impedance status after a deceleration phase | | | | HardHiZ | 101 | 0 | 1 | 00 | 0 | Puts the bridges in High Impedance status immediately | | | | GetStatus | 110 | 1 | 0 | 00 | 0 | Returns the status register value | | | | RESERVED | 111 | 0 | 1 | 01 | 1 | RESERVED COMMAND | | | | RESERVED | 111 | 1 | 1 | 00 | 0 | RESERVED COMMAND | | | ## 9.2.1 Command management The host microcontroller can control motor motion and configure the L6470 through a complete set of commands. All commands are composed by a single byte. After the command byte, some bytes of arguments should be needed (see *Figure 19*). Argument length can vary from 1 to 3 bytes. Figure 19. Command with three byte argument By default the device returns an all zeroes response for any received byte, the only exceptions are GetParam and GetStatus commands. When one of these commands is received the following response bytes represents the related register value (see *Figure 20*). Response length can vary from 1 to 3 bytes. Figure 20. Command with three byte responset During response transmission, new commands can be sent. If a command requiring a response is sent before the previous response is completed, the response transmission is aborted and the new response is loaded into output communication buffer (see *Figure 21*). Figure 21. Command response aborted When a byte that does not correspond to a command is sent to the IC it is ignored and the WRONG\_CMD flag in STATUS register is raised (see paragraph 9.1.22). #### 9.2.2 Nop Table 38. Nop command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | From host | Nothing is performed. ## 9.2.3 SetParam (PARAM, VALUE) Table 39. SetParam command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-----------|-----------|-------|-------|-------|-------|--| | 0 | 0 | 0 | | | PARAM | | | | | | | From hoot | | | | | | | | | | VAL | From host | | | | | | | | | | | | | | | | The SetParam command sets the PARAM register value equal to VALUE; PARAM is the respective register address listed in *Table 12*. The command should be followed by the new register VALUE (most significant byte first). The number of bytes composing the VALUE argument depends on the length of the target register (see *Table 12*). Some registers cannot be written (see *Table 12*); any attempt to write one of those registers causes the command to be ignored and the WRONG\_CMD flag to rise at the end of command byte as like as unknown command code is sent (see paragraph *9.1.22*). Some registers can only be written in particular conditions (see *Table 12*); any attempt to write one of those registers when the conditions are not satisfied causes the command to be ignored and the NOTPERF\_CMD flag to rise at the end of last argument byte (see paragraph *9.1.22*). Any attempt to set an inexistent register (wrong address value) causes the command to be ignored and WRONG\_CMD flag to rise at the end of command byte as like as unknown command code is sent. #### 9.2.4 GetParam (PARAM) Table 40. GetParam command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | | |-------|-------|---------|-------|-------|-----------| | 0 | 0 | 1 | | | from host | | | | to host | | | | | | | to host | | | | | | | to host | | | | This command reads the current PARAM register value; PARAM is the respective register address listed in *Table 12*. The command response is the current value of the register (most significant byte first). The number of bytes composing the command response depends on the length of the target register (see *Table 12*). Returned value is the register one at the moment of GetParam command decoding. If register values changes after this moment the response will not be accordingly updated. All registers can be read anytime. Any attempt to read an inexistent register (wrong address value) causes the command to be ignored and WRONG\_CMD flag to rise at the end of command byte as like as unknown command code is sent. #### 9.2.5 Run (DIR, SPD) Table 41. Run command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|--------|---------|--------|-----------|-------|-----------| | 0 | 1 | 0 | 1 | 0 | 0 | from host | | | | Х | Х | Х | Х | | SPD (I | from host | | | | | | | SPD (I | Byte 1) | | from host | | | | | | | SPD (I | Byte 0) | | | | from host | The Run command produces a motion at SPD speed; the direction is selected by DIR bit: '1' forward or '0' reverse. The SPD value is expressed in step/tick (format unsigned fixed point 0.28) that is the same format that SPEED register (see paragraph 9.1.4). Note: The SPD value should be lower than MAX\_SPEED and greater than MIN\_SPEED otherwise the Run command will be executed at MAX\_SPEED or MIN\_SPEED respectively. This command keeps the BUSY flag low until the target speed is reached. This command can be given anytime and is immediately executed. #### 9.2.6 StepClock (DIR) Table 42. Stepclock command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 0 | 1 | 0 | 1 | 1 | 0 | 0 | DIR | from host | The StepClock command switches the device in step clock mode (see paragraph 6.7.5) and impose the forward (DIR = '1') or reverse (DIR = '0') direction. When the device is in step clock mode the SCK\_MOD flag in STATUS register is raised and the motor is always considered stopped (see paragraphs 6.7.5 and 9.1.22). Device exits from step clock mode when a constant speed, absolute positioning or motion command is sent through SPI. Motion direction is imposed by the respective StepClock command argument and can by changed by a new StepClock command without exiting the step clock mode. Events that cause bridges to be forced in high impedance state (overtemperature, overcurrent, etc.) do not cause the device to leave step clock mode. StepClock command does not force the BUSY flag low. This command can only be given when the motor is stopped. If a motion is in progress the motor should be stopped and then it is possible to send a StepClock command. Any attempt to perform a StepClock command when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22). ## 9.2.7 Move (DIR, N\_STEP) Table 43. Move command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | | | | | | | |-------|-----------------|-------|--------|-----------|--|--|--|-----------|--| | 0 | 1 | 0 | 0 | from host | | | | | | | Х | Х | | | from host | | | | | | | | N_STEP (Byte 1) | | | | | | | | | | | | | N_STEF | (Byte 0) | | | | from host | | The move command produces a motion of N\_STEP microsteps; the direction is selected by DIR bit ('1' forward or '0' reverse). The N\_STEP value is always in agreement with the selected step mode; the parameter value unit is equal to the selected step mode (full, half, quarter, etc.). This command keeps the BUSY flag low until the target number of steps is performed. This command can be only performed when the motor is stopped. If a motion is in progress the motor must be stopped and then it is possible to perform a Move command. Any attempt to perform a Move command when the motor is running causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph *9.1.22*). ## 9.2.8 GoTo (ABS\_POS) Table 44. GoTo command structure | Bit 7 | Bit 6 | Bit 5 | | | | | | | | | | |-------|------------------|-----------|---|-----------|--|--|--|--|--|--|--| | 0 | 1 | 1 | 0 | from host | | | | | | | | | Х | Х | | | from host | | | | | | | | | | | from host | | | | | | | | | | | | ABS_POS (Byte 0) | | | | | | | | | | | The GoTo command produces a motion to ABS\_POS absolute position through the shortest path. The ABS\_POS value is always in agreement with the selected step mode; the parameter value unit is equal to the selected step mode (full, half, quarter, etc.). GoTo command keeps the BUSY flag low until the target position is reached. This command can be given only when the previous motion command as been completed (BUSY flag released). Any attempt to perform a GoTo command when a previous command is under execution (BUSY low) causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22) ## 9.2.9 GoTo\_DIR (DIR, ABS\_POS) Table 45. GoTo\_DIR command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | |-------|----------------------|-------|-------|-----------|-------|-------|-------|--|--|--| | 0 | 1 | 1 | 0 | from host | | | | | | | | Х | X X ABS_POS (Byte 2) | | | | | | | | | | | | ABS_POS (Byte 1) | | | | | | | | | | | | from host | | | | | | | | | | The GoTo\_DIR command produces a motion to ABS\_POS absolute position imposing a forward (DIR = '1') or a reverse (DIR = '0') rotation. The ABS\_POS value is always in agreement with the selected step mode; the parameter value unit is equal to the selected step mode (full, half, quarter, etc.). GoTo\_DIR command keeps the BUSY flag low until the target speed is reached. This command can be given only when the previous motion command has been completed (BUSY flag released). Any attempt to perform a GoTo\_DIR command when a previous command is under execution (BUSY low) causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22) ## 9.2.10 GoUntil (ACT, DIR, SPD) Table 46. GoUntil command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|--------------|-------|-------|--------------|-------|-------|-------|-----------| | 1 | 0 | 0 | 0 | ACT | 0 | 1 | DIR | from host | | X | Х | Х | Х | SPD (Byte 2) | | | | from host | | | SPD (Byte 1) | | | | | | | from host | | | from host | | | | | | | | The GoUntil command produces a motion at SPD speed imposing a forward (DIR = '1') or a reverse (DIR = '0') direction. When an external switch turn-on event occurs (see paragraph 6.13), the ABS\_POS register is reset (if ACT = '0') or the ABS\_POS register value is copied into the MARK register (if ACT = '1'); then the system performs a SoftStop command. The SPD value is expressed in step/tick (format unsigned fixed point 0.28) that is the same format that SPEED register (see paragraph 9.1.4). SPD value should be lower than MAX\_SPEED and greater than MIN\_SPEED, otherwise the target speed will be imposed at MAX\_SPEED or MIN\_SPEED respectively. If SW\_MODE bit of CONFIG register is set low, the external switch turn-on event causes a HardStop interrupt instead of the SoftStop one (see paragraphs 6.13 and 9.1.21). This command keeps the BUSY flag low until the switch turn-on event occurs and the motor is stopped. This command can be given anytime and is immediately executed. ## 9.2.11 ReleaseSW (ACT, DIR) Table 47. ReleaseSW command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 0 | 0 | 1 | ACT | 0 | 1 | DIR | from host | The ReleaseSW command produces a motion at minimum speed imposing a forward (DIR = $^{11}$ ) or reverse (DIR = $^{10}$ ) rotation. When SW is released (opened) the ABS\_POS register is reset (ACT = $^{10}$ ) or the ABS\_POS register value is copied in MARK register (ACT = $^{11}$ ); then the system performs a HardStop command. Note that to resetting the ABS\_POS register is equivalent to setting the HOME position. If minimum speed value is lesser than 5 step/s or low speed optimization is enabled, the motion is performed at 5 step/s. ReleaseSW command keeps the BUSY flag low until the switch input is released and the motor is stopped. #### 9.2.12 GoHome Table 48. GoHome command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | from host | The GoHome command produces a motion to the HOME position (zero position) via the shortest path. Note that this command is equivalent to "GoTo(0...0)" command. If a motor direction is mandatory the GoTo\_DIR command has to be used (see paragraph 9.2.9). GoHome command keeps the BUSY flag low until the home position is reached. This command can be given only when the previous motion command has been completed. Any attempt to perform a GoHome command when a previous command is under execution (BUSY low) causes the command to be ignored and the NOTPERF\_CMD to rise (see paragraph 9.1.22) #### 9.2.13 GoMark Table 49. GoMark command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | from host | The GoMark command produces a motion to MARK position performing the minimum path. Note that this command is equivalent to "GoTo (MARK)" command. If a motor direction is mandatory the GoTo\_DIR command has to be used. GoMark command keeps the BUSY flag low until the MARK position is reached. This command can be given only when the previous motion command has been completed (BUSY flag released). Any attempt to perform a GoMark command when a previous command is under execution (BUSY low) causes the command to be ignored and the NOTPERF\_CMD flag to rise (see paragraph 9.1.22) #### 9.2.14 ResetPos Table 50. ResetPos command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | from host | The ResetPos command resets the ABS\_POS register to zero. The zero position is also defined as HOME position (see paragraph *6.5*). #### 9.2.15 ResetDevice Table 51. ResetDevice command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | from host | The ResetDevice command resets the device to power-up conditions (see paragraph 6.1). Note: At power-up the power bridges are disabled. #### **9.2.16** SoftStop Table 52. SoftStop command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | from host | The SoftStop command causes an immediate deceleration to zero speed and a consequent motor stop; the deceleration value used is the one stored in DEC register (see paragraph 9.1.6). When the motor is in high-impedance state, a SoftStop command forces the bridges to exit from high impedance state; no motion is performed. This command can be given anytime and is immediately executed. This command keeps the BUSY flag low until the motor is stopped. ## 9.2.17 HardStop Table 53. HardStop command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | from host | The HardStop command causes an immediate motor stop with infinite deceleration. When the motor is in high-impedance state, a HardStop command forces the bridges to exit from high impedance state; no motion is performed. This command can be given anytime and is immediately executed. This command keeps the BUSY flag low until the motor is stopped. #### 9.2.18 SoftHiZ Table 54. SoftHiZ command structure | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |---|-------|-------|-------|-------|-------|-------|-------|-------|-----------| | - | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | from host | The SoftHiZ command disables the power bridges (high-impedance state) after a deceleration to zero; the deceleration value used is the one stored in DEC register (see paragraph *9.1.6*). When bridges are disabled the HiZ flag is raised. When the motor is stopped, a SoftHiZ command forces the bridges to enter in high-impedance state. This command can be given anytime and is immediately executed. This command keeps the BUSY flag low until the motor is stopped. #### 9.2.19 HardHiZ Table 55. HardHiZ command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|-----------| | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | from host | The HardHiZ command immediately disables the power bridges (high-impedance state) and raises the HiZ flag. When the motor is stopped, a HardHiZ command forces the bridges to enter in high-impedance state. This command can be given anytime and is immediately executed. This command keeps the BUSY flag low until the motor is stopped. 63/67 ## 9.2.20 GetStatus Table 56. GetStatus command structure | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | |-------|---------------|-------|-------|-------|-------|-------|-------|-----------|--| | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | from host | | | | | | | | | | | | | | | STATUS MSByte | | | | | | | | | | | to host | | | | | | | | | The GetStatus command returns the Status register value. GetStatus command resets the STATUS register warning flags. The command forces the system to exit from any error state. The GetStatus command DO NOT reset HiZ flag. ## 10 Package mechanical data In order to meet environmental requirements, ST offers these devices in different grades of ECOPACK® packages, depending on their level of environmental compliance. ECOPACK® specifications, grade definitions and product status are available at: www.st.com. ECOPACK is an ST trademark. Table 57. HTSSOP28 mechanical data | Dim | | mm | | |-------------------|------|------|------| | Dim | Min | Тур | Max | | А | | | 1.2 | | A1 | | | 0.15 | | A2 | 0.8 | 1.0 | 1.05 | | b | 0.19 | | 0.3 | | С | 0.09 | | 0.2 | | D <sup>(1)</sup> | 9.6 | 9.7 | 9.8 | | D1 | | 5.5 | | | Е | 6.2 | 6.4 | 6.6 | | E1 <sup>(2)</sup> | 4.3 | 4.4 | 4.5 | | E2 | | 2.8 | | | Е | | 0.65 | | | L | 0.45 | 0.6 | 0.75 | | L1 | | 1.0 | | | K | 0° | | 8° | | Aaa | | 0.1 | | Dimension "D" does not include mold flash, protrusions or gate burrs. Mold flash, protrusions or gate burrs shall not exceed 0.15 mm per side. Dimension "E1" does not include interlead flash or protrusions. Interlead flash or protrusions shall not exceed 0.25 mm per side. Figure 22. HTSSOP28 mechanical data Revision history L6470 # 11 Revision history Table 58. Document revision history | Date | Revision | Changes | |-------------|----------|---------------------------------------------------------------------------------------------| | 06-Nov-2009 | 1 | Initial release | | 05-Nov-2010 | 2 | Document status promoted from preliminary data to datasheet | | 18-May-2011 | 3 | Updated: <i>Table 4</i> , <i>Table 5</i> Added: <i>Section 6.7.6</i> , <i>Section 6.4.1</i> | #### Please Read Carefully: Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice. All ST products are sold pursuant to ST's terms and conditions of sale. Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein. UNLESS OTHERWISE SET FORTH IN ST'S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER'S OWN RISK. Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST. ST and the ST logo are trademarks or registered trademarks of ST in various countries. Information in this document supersedes and replaces all information previously supplied. The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners. © 2011 STMicroelectronics - All rights reserved STMicroelectronics group of companies Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan - Malaysia - Malta - Morocco - Philippines - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com