UM1691 User manual EVAL6470H-DISC: fully integrated stepper motor driver based on the L6470 and STM32™ Introduction The EVAL6470H-DISC can be used together with the STM32™ firmware library V1.0 and constitutes a complete motor control evaluation and a development platform. It is a demonstration board for motor control applications in the range of 8 V to 45 V of DC bus voltage using the STM32F105RB microcontroller with an internal 128 kB Flash size and a 64 kB internal RAM and the L6470 fully integrated solution suitable for driving two-phase bipolar stepper motors up to 1/128 microstepping. The L6470 integrates a dual 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 protection. With dedicated hardware evaluation features, the EVAL6470H-DISC board is designed to help developers evaluate the device and develop their own applications. Figure 1. Board image April 2015 DocID025486 Rev 2 1/41 www.st.com 41 Contents UM1691 Contents 1 Main features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.1 Target applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.2 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 2 Electrical characteristics of the board . . . . . . . . . . . . . . . . . . . . . . . . . . 5 3 Schematics, layout and bill of material . . . . . . . . . . . . . . . . . . . . . . . . . . 6 4 General description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 4.1 Power supply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11 4.2 L6470 stepper motor driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 4.2.1 Charge pump . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 4.2.2 Voltage mode driving . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 4.2.3 Overcurrent and stall detection thresholds . . . . . . . . . . . . . . . . . . . . . . 14 4.2.4 Speed profile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.3 STM32F105RB microcontroller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.4 Firmware loading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.5 4.6 4.4.1 DfuSe installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.4.2 Generate a DFU file from a HEX file . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.4.3 Board settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.4.4 DFU loading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 Using the EVAL6470H-DISC with firmware for the GUI . . . . . . . . . . . . . . 24 4.5.1 Sanity check of the board with firmware for the GUI . . . . . . . . . . . . . . . 24 4.5.2 Parameters exportation from the GUI to the FW library . . . . . . . . . . . . . 33 Using the EVAL6470H-DISC with the firmware library . . . . . . . . . . . . . . . 34 4.6.1 FW library package contents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 4.6.2 FW L6470 library description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 4.6.3 Demonstration sequence description . . . . . . . . . . . . . . . . . . . . . . . . . . 35 4.6.4 Create a project using the FW library package . . . . . . . . . . . . . . . . . . . 39 5 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 6 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 2/41 DocID025486 Rev 2 UM1691 List of figures List of figures Figure 1. Figure 2. Figure 3. Figure 4. Figure 5. Figure 6. Figure 7. Figure 8. Figure 9. Figure 10. Figure 11. Figure 12. Figure 13. Figure 14. Figure 15. Figure 16. Figure 17. Figure 18. Figure 19. Figure 20. Figure 21. Figure 22. Figure 23. Figure 24. Figure 25. Figure 26. Figure 27. Figure 28. Board image . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Schematic (microcontroller supply part) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 Schematic (microcontroller part) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Schematic (motor driver part) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Layout top layer and bottom layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Microcontroller supply section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 L6470 block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Charge pump circuitry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 STM32F105xx and STM32F107xx block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 DFU file manager (action). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 DFU file manager (generation) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Board settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 DFU loading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 DFU file (open) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 DFU file (upgrade) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 DFU file (confirmation) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 DFU file ( download OK) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 Starting board (boot mode) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Starting board (motor power supply) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Starting board (USB connection) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Starting board (error case) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 Starting board (board OK) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Starting board (display board ID) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Starting board (action LEFT key) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Starting board (action RIGHT key) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Starting board (action RESET key). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 Parameters exportation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Parameters exportation (save file) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 DocID025486 Rev 2 3/41 41 Main features 1 UM1691 Main features The characteristics of the EVAL6470H-DISC board are the following: 1.1 DC voltage range from 8 V to 45 V Maximum load phase current at 3 Ar.m.s. Footprint for external resonator or crystal Control interface through trimmer - user keys and switch motor input Control through LED indicators Interface control by USB and debug outputs Compatible with SPINFamily evaluation tool Autonomous board due to an embedded firmware Up to 1/128 microstepping Optimized layout on 2-layer board - low cost and high thermal performance Target applications The demonstration board is designed to fit all typical stepper motor applications - it is an autonomous board due an embedded firmware. 1.2 Description The EVAL6470_DISC is downloaded with an embedded firmware. The possibility with this board is double: Adapt the settings with your specific setup (motor - voltage) by using the dedicated PC application. The user is able to save inside the board the specific parameters depending on a user setup. 4/41 Using the board (with user parameters) directly on a site - without a connected PC. DocID025486 Rev 2 UM1691 2 Electrical characteristics of the board Electrical characteristics of the board Table 1. Electrical specifications Name Value Supply voltage (VS) 8 to 45 V Maximum output current (each phase) 3 A r.m.s Logic supply voltage (VREG) 3 V (L6470 regulator supply) Logic interface voltage (VDD) 3.3 V (USB supply) Low level logic inputs voltage 0V High level logic input voltage VDD Stepping Up to 1/128 microstepping Operating temperature 0 to 85 °C DocID025486 Rev 2 5/41 41 Schematics, layout and bill of material 3 UM1691 Schematics, layout and bill of material Figure 2. Schematic (microcontroller supply part) 9'' 9'' 73 8 - 6+(// 6+(// 6+(// 6+(// 86%B9&& 86%'0 86%'3 ,' 86%B*1' 9 86%'0 86%'3 & 1) .(<6721( & 8) 8 5 0 1& 9287 9287 1& /''7 5 & 1) *1' 9287 9287 9,1 ,2 *1' ,2 ,2 9%86 ,2 86%'0 9'' 86%'3 86%/&3 5 86%B,7 & 1) . $0 6/41 DocID025486 Rev 2 UM1691 Schematics, layout and bill of material Figure 3. Schematic (microcontroller part) 9'' 9'' 9'' 5 . 5 . 5 5 5 5 5 5 . . . . . &21)/$7 ;0 - 5 - 23(1 & 1) 9'' 5(6(7 1) -7$*B7', -7$*B7&. & 1) %227 & 8) -7$*B17657 -7$*B7'2 & 5 5 5 . . . /('B63$5( /('B(5525 /('B%86< /('B5($'< 5 5 5 5 ' 5 ' ' 5(' 25$1*( 6: B02725 %87721B$ %87721B% *5((1 1) 67&. & 8) 9'' & 670)5%7 3$ 966B 9'' 3$ 3$ 3$ 3$ 3& 3& 3% 3% 3% 3% 3% 966B 9''B ' <(//2: 8 9'' *1' 9'' 9'' 9'' *1' 5(6(7 5 5 9''B 966B 3$ 3$ 3$ 3$ 3$ 3$ 3& 3& 3& 3& 3% 3% 3% 3% & 1) 3$B706 86%'3 86%'0 3$B8$57B5 ; 3$B8$57B7 ; 3$B8$57B& . 5 . 9'' 5 . 73 73 73 86%B,7 %2$5'B,'B %2$5'B,'B %2$5'B,'B %2$5'B,'B 5 5 5 5 . 13 13 13 %227 )/$* %86< 3) 5 9%$7 3&7$03(557& 3&26&B,1 3&26&B287 3'26&B,1 3'26&B287 1567 3& 3& 3& 3& 966$ 9''$ 3$:.83 3$ 3$ 9'' & 9'' 5 0 9''B 966B 3% 3% %227 3% 3% 3% 3% 3% 3' 3& 3& 3& 3$ 3$ < 0+] 63,B166 63,B1&. 63,B0,62 63,B026, 6: 67%<B5(6(7 3) & 9'' & 5 . 1) 5 . 5 . 5 . & 1) & 1) & & 6 1) 6 1) 1) 5 - 23(1 6 5 & $0 DocID025486 Rev 2 7/41 41 Schematics, layout and bill of material UM1691 Figure 4. Schematic (motor driver part) 5 96 . 96 5 . & %$9 ' 1) 5 13 $'&,1 6: 67&. 67%<B5(6(7 )/$* %86< 26&,1 - 26&287 8 /+ 96$ 96$ 96% 96% 287$ 287$ & & 1) 1) & 8) 9 - $'&,1 6: 67&. 67%<B5(6 )/$* %86<B6<1& &6 &. 6', 6'2 287% 287% 63,B166 63,B1&. 63,B026, 63,B0,62 &3 9'' 95(* 1) & 73 & 1) 8) (3$' 9'' 96 5 . 73 & 9%227 & 1) & 5 13 '*1' 9 - $*1' 3*1' 3*1' .(<6721( ' 73 1) $0 Figure 5. Layout top layer and bottom layer 8/41 DocID025486 Rev 2 UM1691 Schematics, layout and bill of material Table 2. Bill of material Item Quantity Reference Value Package C1, C16 2 Cap. cer. 10 µF 10 V X7R 0805 10 F 0805 C2 1 Cap. cer. 1 µF 10 V X7R 0805 1 F 0805 C3, C4, C10 C13, C17 C19, C21, C22, C25 C27 14 Cap. cer. 100 nF 50 V X7R 0603 100 nF 0603 C5 1 Cap. cer. 3.3 nF 50 V X7R 0603 3.3 nF 0603 C6 1 Cap. cer. 220 nF 35 V X7R 0603 220 nF 0603 C7 1 Cap. cer. 4.7 nF 50 V X7R 0603 4.7 nF 0603 C8, C15, C20, C28 4 Cap. cer. 10 nF 50 V X7R 0603 10 nF 0603 C9 1 Cap. tant. 47 F 6.3 V 10% PACK-A 47 F 3216 C14 1 Cap. elec. 100 F 63 V 100 F CAPES-R10HXX C23, C24 2 CAP. CER. 20pF 50V COG 0603 20 pF 0603 D1 1 Zener regulator 3.6 V SOD 523 D2 1 Double diode - high speed switching diode BAV99 SOT23 D3 1 LED red - 0805 -2 mcd - 621 nm Red 0805 D4 1 LED green - 0805 -6 mcd - 569 nm Green 0805 D5 1 LED yellow - 0805 -6 mcd - 588 nm Yellow 0805 D6 1 LED orange - 0805 -2 mcd - 602 nm Orange 0805 FIX1 - FIX4 4 Hole 3 mn - J1 - J3 3 Screw connector 2 poles MKDSN 1.5/2 - 5.08 MKDSN 1.5/2 - 5.08 MKDSN 1.5/2 - 5.08 J4 1 JTAG CON-FLAT-10 x 2 - 180 M J5 1 USB_B_MINI_AMP_1734035-1 CN-USB CMS Mini USB J6, J7 2 JUMP254P-M-2 OPEN STRIP 2 x 2.54 MIRE1 MIRE3 3 OPTICAL_TARGET OPTICAL_TARGET Diam. 1 mn R1 1 Trimmer 200 K 200 K Trimm. 100 x 50 x 110 R2 1 27 K 5% 1/10 W 27 K 0603 R3 1 Res. 7.5 K 5% 1/10 W 0603 SMD 7.5 K 0603 R4, R13 2 Res. 1 M 1/10 W 5% 0603 SMD 1 M 0603 R5 1 Res. 1.5 K 1/10 W 5% 0603 SMD 1.5 K 0603 R6, R8 - R11, R14, R19, R30 - R32 10 Res. 10 K 5% 1/10 W 0603 SMD 10 K 0603 CON-FLAT-10 x 2 - 180 M CON-FLAT-10 x 2 -180 M DocID025486 Rev 2 9/41 41 Schematics, layout and bill of material UM1691 Table 2. Bill of material Item Quantity Reference Value Package R7, R12 2 Res. 100 5% 1/10 W 100 0603 R15 - R18 4 Res. 470 5% 1/10 W 0603 470 0603 R20, R33 2 Res. 1 K 5% 1/10 W 0603 SMD 1 K 0603 R21 - R23, R34 4 Res. NP 0603 NP 0603 R24 - R27 4 Res. 4.7 K 5% 1/10 W 0603 SMD 4.7 K 0603 R28 1 Res. 100 K 5% 1/10 W 0603 SMD 100 K 0603 R29 1 Res. NP 0805 NP 0805 S1 - S3 3 Switch button SMD EVQQ2D03W CMS 6.5 x 6 x 3.1 TP1, TP2, TP4 - TP7 6 Test point red KEYSTONE-5000 TH TP3 1 Test point black KEYSTONE-5001 TH U1 1 IC REG 1300MA LN 3.3 V LD1117D33TR SO8 U2 1 USBLC6-2P6 USBLC6-2P6 SOT 666 U3 1 L6470 microstepping motor driven L6470 HTSSOP28 U4 1 IC, MCU, RISC, 72 MHz, 3.6 V, 32-bit, 64-pin, LQFP STM32F105RBT6 LQFP64 10 x 10 Y1 1 XTAL 8 MHz-30 PPM-20 pF 8 MHz HC49/US-SM 10/41 DocID025486 Rev 2 UM1691 General description 4 General description 4.1 Power supply The EVAL6470H-DISC board is designed to be powered via: Connector J1: power of the motor and also motor control driver. USB connector J5: power of the microcontroller and logic control. The USB cable supplies the digital part through a dedicated LDO (U1) providing 3.3 V. The motor power must be set according to the voltage required by the user motor. Note: Both the supply sources (USB connector and J1 connector) must be present to make the board operative. Figure 6. Microcontroller supply section 9'' 9'' 73 8 - 6+(// 6+(// 6+(// 6+(// 86%B9&& 86%'0 86%'3 ,' 86%B*1' 9 86%'0 86%'3 & 1) .(<6721( & 8) 8 5 0 1& 9287 9287 1& /''7 5 & 1) *1' 9287 9287 9,1 ,2 *1' ,2 ,2 9%86 ,2 86%'0 9'' 86%'3 86%/&3 5 86%B,7 & 1) . $0 DocID025486 Rev 2 11/41 41 General description 4.2 UM1691 L6470 stepper motor driver The L6470 is an advanced fully integrated solution suitable for driving two-phase bipolar stepper motors with microstepping. It integrates a dual low RDS(on) DMOS full bridge. Features Operating voltage: 8 - 45 V 7.0 A out peak current (3.0 A r.m.s.) Low RDS(on) power MOSFETs Programmable speed profile and positioning Programmable power MOS slew rate Up to 1/128 microstepping Sensorless stall detection SPI interface Low quiescent and standby currents Programmable non dissipative overcurrent Two levels of overtemperature protection Figure 7. L6470 block diagram 12/41 DocID025486 Rev 2 UM1691 General description Table 3. L6470 recommended operating conditions Symbol Parameter Value Unit VDD Logic Interface supply voltage 3.3 V VS Motor supply voltage VSA = VSB = VS 8 ÷ 45 V VOUT_diff Differential between voltage VSA, OUTI1A, OUT2A, PGND and VSB, OUT1B, OUT2B, PGND pins VSA = VSB = VS Up to 45 V VREG in Logic supply voltage VREG internal 3 V VADC Integrated ADC input voltage range (ADCIN pin) 0 ÷ VREG V 4.2.1 Test condition Charge pump The L6470 device uses an internal charge pump for driving correctly the integrated MOSFETs, a voltage higher than the motor power supply. The charge pump is obtained through an oscillator and few external components. Figure 8. Charge pump circuitry 96 & Q) ' %$9 & Q ) 9%227 &3 8 96$ 96$ 96% 96% /+ $0 DocID025486 Rev 2 13/41 41 General description 4.2.2 UM1691 Voltage mode driving The configuration parameters of the voltage mode driving can be obtained through the BEMF compensation tool embedded into the SPINFamily software. A wrong setup of these parameters could cause several issues, in particular: The phase current decreases with the speed and the motor will stall. The wrong voltage is applied to the motor and the system is very noisy. The phase current reaches the overcurrent limit. The BEMF compensation form uses the application parameters as inputs in order to evaluate the proper device setup. The required inputs are: Supply voltage. Target phase current (r.m.s. value) at different motion conditions (acceleration, deceleration, constant speed and holding). Target operating speed (maximum speed). Motor characteristics. The motor characteristics are: electrical constant (Ke), phase inductance and resistance. The inductance and the resistance of the phase are given in the motor datasheet. The Ke is rarely given in the specification and must be measured. In the help section of the SPINFamily software a step by step procedure is explained. The same procedure can also be found in the application note “AN4144: Voltage mode control operation and parameter optimization” on www.st.com. Click on the “evaluate” button to get the suggested setup for the voltage mode driving. Then click on “write” button to copy the data in the registers of the device. 4.2.3 Overcurrent and stall detection thresholds The overcurrent protection and the stall detection are implemented measuring the current flowing into each integrated MOSFET. The overcurrent protection threshold should be set just above the current rating of the motor: IOCDth > Imax,r.m.s. × √2 For example: if the maximum phase current of the motor is 2 Ar.m.s., the overcurrent protection should be set to about 3 A. Warning: Important - it is strongly discouraged to disable the overcurrent shutdown. It may result in critical failures. The stall detection threshold should be just above the operating peak current of the application. During the preliminary stages of evaluation, it can be set to the maximum value. 14/41 DocID025486 Rev 2 UM1691 4.2.4 General description Speed profile The max. speed parameter is the maximum speed the motor will run. By default, it is about 1000 step/s. That means, if you send a command to run at 2000 step/s, the motor speed is limited at 1000 step/s. This is an important safety feature in the final application, but not necessarily useful to evaluate the device performances. Setting the parameter to high values (e.g. 6000 step/s) allows evaluating the maximum speed which can be achieved by the application under test through the speed tracking command (Run), but it probably limits the possibility to use positioning commands (Move, GoTo, etc.). The Full-step speed parameter indicates the speed at which the system switches from microstepping to full step operation. In voltage mode driving devices it is always recommended to operate in microstepping and not to switch to full step. Hence, this parameter should be greater than the maximum speed. 4.3 STM32F105RB microcontroller The STM32F105xx incorporates the high-performance ARM® Cortex™-M3 32-bit RISC core operating at a 72 MHz frequency, high-speed embedded memories (a Flash memory up to 256 Kbytes and an SRAM 64 Kbytes), and an extensive range of enhanced I/O and peripherals connected to two APB buses. All devices offer two 12-bit ADCs, four generalpurpose 16-bit timers plus a PWM timer, as well as standard and advanced communication interfaces: up to two I2Cs, three SPIs, two I2Ss, five USARTs, a USB OTG FS and two CANs. The STM32F105xx device operates in the -40 to +105 °C temperature range, from a 2.0 to 3.6 V power supply. A comprehensive set of power saving mode allows the design of lowpower applications. The STM32F105xx offers devices in three different package types: from 64 pins to 100 pins. Depending on the device chosen, different sets of peripherals are included. These features make the STM32F105xx and STM32F107xx connectivity line microcontroller family suitable for a wide range of applications such as motor drives and application control, medical and handheld equipment, industrial applications, PLCs, inverters, printers and scanners, alarm systems, video intercom, and HVAC and home audio equipment. Please refer to the STM32F105xx datasheet for an overview of the complete range of peripherals proposed in this family. Please refer to the STM32F105xx reference manual to get more information on the microcontroller operation. The STM32F105RBT6 has a 64-pin LQFP package with a 128-KByte Flash memory and operates in the -40 to +85°C temperature range. DocID025486 Rev 2 15/41 41 General description UM1691 Figure 9 shows the general block diagram of the STM32F105xx and STM32F107xx family. Figure 9. STM32F105xx and STM32F107xx block diagram 16/41 DocID025486 Rev 2 UM1691 4.4 General description Firmware loading This section describes how to load firmware to the board by using the DfuSe demonstration software. 4.4.1 DfuSe installation You need first to download the DfuSe demonstration software from: www.st.com. The DfuSe tool is referenced under the development suite STSW-STM32080. Once downloaded, run the setup.exe file. More details on the DfuSe are given in the UM0412 user manual. 4.4.2 Generate a DFU file from a HEX file If the file you want to download to the discovery board is not a DFU file but a HEX file, you will need first to convert it. In this purpose: Start the DFU file manager (V3.0.3 or greater) which has been installed with the DfuSe. Choose “I want to GENERATE a DFU file from S19, HEX or BIN files”. Figure 10. DFU file manager (action) Click “S19 or HEX”… button. Select in the open dialog box the file of type “hex Files”, select the HEX file and click “OK”. Click on the “Generate…” button. Give a name to the *.DFU file and click on the “Save” button. DocID025486 Rev 2 17/41 41 General description UM1691 Figure 11. DFU file manager (generation) 18/41 DocID025486 Rev 2 UM1691 4.4.3 General description Board settings To be able to download firmware, the discovery board should be started in the “DFU” mode. In this purpose: 1. Remove the jumper from the BOOT pins. 2. Plug a USB cable between the discovery board and the PC. It does not matter if the VS connector is plugged or not to a supply voltage. Figure 12. Board settings DocID025486 Rev 2 19/41 41 General description 4.4.4 UM1691 DFU loading At this step, you are now ready to perform the firmware upgrade. 1. Start the “DfuSeDemo.exe”. 2. You must have an “STM Device in DFU Mode” in the list of the “Available DFU Devices”. Else, it means that your board is not correctly configured or not connected to the PC. Figure 13. DFU loading 3. 20/41 In the “Upgrade or Verify Action” group, click on the “Choose…” button. DocID025486 Rev 2 UM1691 General description 4. Select the *.dfu file of your choice in the open dialog box and click on the “Open” button. Figure 14. DFU file (open) DocID025486 Rev 2 21/41 41 General description 5. UM1691 Click on the “Upgrade” button. Figure 15. DFU file (upgrade) 6. If this dialog box appears, click “Yes”. Figure 16. DFU file (confirmation) 22/41 DocID025486 Rev 2 UM1691 General description 7. Once the download is performed, you should have: Figure 17. DFU file ( download OK) 8. Do no forget to put the jumper back on the BOOT pins in order to restart the discovery board to the normal mode! DocID025486 Rev 2 23/41 41 General description 4.5 UM1691 Using the EVAL6470H-DISC with firmware for the GUI By default the discovery board is loaded with firmware offering the capability to connect the board with the SPINFamily evaluation tool. This GUI provides direct access to all L6470 registers and allows sending application commands. 4.5.1 Sanity check of the board with firmware for the GUI At the startup of the FWGUI, a sanity check is performed to confirm the discovery board is working correctly. The status is returned via the board LEDs. To have a correct execution of the sanity check, please follow the steps below: 1. Place a jumper on the BOOT pins (bottom left corner of the board): Figure 18. Starting board (boot mode) 24/41 DocID025486 Rev 2 UM1691 General description 2. Connect the board to a 5 V - 45 V DC power supply: Figure 19. Starting board (motor power supply) DocID025486 Rev 2 25/41 41 General description 3. UM1691 Plug a USB cable (which must at least provide a power supply). Figure 20. Starting board (USB connection) 4. 26/41 The board should switch on automatically. DocID025486 Rev 2 UM1691 General description 5. At this step: a) If a problem is detected, the “ready” LED (green) and the “error” LED (red) will switch on without blinking. This means that: – either the board ID is not recognized by the FW (bad FW versions used) – or there is a problem with the SPI (no connection between the MCU and the L6470 via the SPI) – or there is no 5 V - 45 V DC power supply. Figure 21. Starting board (error case) DocID025486 Rev 2 27/41 41 General description b) UM1691 If no problem is detected, the LEDs will start an infinite two-step loop: In the first step, the four LEDs will switch on one after the other by starting by the green one and ending by the yellow one. Figure 22. Starting board (board OK) 28/41 DocID025486 Rev 2 UM1691 General description In the second step, only the LEDs which correspond to the board ID are switched on all at the same time. For the L6470 device, there are green, orange, red LEDs. Figure 23. Starting board (display board ID) DocID025486 Rev 2 29/41 41 General description 6. UM1691 Press the LEFT button and check the two-step loop stops after a few seconds. Only green LED remains switched on. Figure 24. Starting board (action LEFT key) 30/41 DocID025486 Rev 2 UM1691 General description 7. Press the RIGHT button and check the two-step loops restarts. Figure 25. Starting board (action RIGHT key) DocID025486 Rev 2 31/41 41 General description 8. UM1691 Press the RESET button and check that the LEDs restart there two-step loop after the board reset. Figure 26. Starting board (action RESET key) Note: 32/41 Please note that once you have connected the discovery board to the GUI, the LEDs meaning is different. You then need to restart the board to perform a new auto-check and to have a valid status from the LEDs. DocID025486 Rev 2 UM1691 4.5.2 General description Parameters exportation from the GUI to the FW library Once you have customized the L6470 parameters with the GUI, you can export them to a header file in order to use it with the FW library. In this purpose: 1. Press the “header file” button on the main window of the GUI. Figure 27. Parameters exportation 2. Replace the existing “dspin_config.h” of your current FW library by the new one. Figure 28. Parameters exportation (save file) 3. Then you only need to recompile your project as usual to use the exported parameters. DocID025486 Rev 2 33/41 41 General description 4.6 UM1691 Using the EVAL6470H-DISC with the firmware library The L6470 firmware library is supplied as an IAR workspace with a source include and project files. If you are using an IAR design environment, you just need to load the “dspin.eww” file and use the fwlibrairies_dspin_discoverykit project which is already active. If you are using a different design environment, you will find instructions in this user manual to build a new project on your preferred IDE. The L6470 firmware library is also supplied as an executable file in a HEX and in a DFU format. It can be loaded into the EVAL6470H-DISC board as explained in Section 4.4 on page 17. 4.6.1 FW library package contents FW L6470 library – Described in Section 4.6.2. CMSIS library – stm32f10x/CMSIS Library used by the L6470 FW library STM32F10x standard peripherals library drivers – /stm32f10x/STM32F10x_StdPeriph_Driver Library used by the L6470 FW library IAR workspace files – /user_motion/project/ewarm6/fwlibraries/dspin/dspin.eww - a workspace file – /user_motion/project/ewarm6/fwlibraries/dspin/settings/dspin.wsdt - a workspace settings file – /user_motion/project/ewarm6/fwlibraries/dspin/discoverykit - a directory containing the L6470 discovery board project files and subdirectories – /user_motion/project/ewarm6/fwlibraries/dspin/discoverykit/Debug/Exe/ - a directory containing the *.HEX and *.DFU executable files – /user_motion/project/ewarm6/fwlibraries/dspin/pcc009v2 - a directory containing the PCC009V2 board project files and subdirectories. 4.6.2 FW L6470 library description The FW L6470 library has the following features: 34/41 Register read, write and check Register values conversion Device configuration Motion commands FLAG and BUSY interrupts management Button interrupts management Step “Clock mode” management Initialization routine using “GoUntil” and “ReleaseSW” commands “Daisy Chain” mode DocID025486 Rev 2 UM1691 General description The FW L6470 library has been tested on the L6470H DISCOVERY board R1. The main program contains a commented demonstration sequence which uses all the FW L6470 library supported features. This sequence is interactive and to proceed to the end some user action is necessary. For the “GoUntil” feature demonstration, when the LED SPARE is blinking for the first time, the user shall close the SW MOTOR jumper J8. This triggers a switch turn on event at the L6470 SW pin. For the “ReleaseSW” feature demonstration, when the LED SPARE is blinking again, the user shall open the SW MOTOR jumper J8. This triggers a L6470 SW pin release. At the end of the demonstration sequence, the GPIO connected to LEFT and RIGHT buttons are configured to trigger interrupts on the microcontroller: On a LEFT button press, the microcontroller starts the motor at quarter of max. speed if it is stopped or doubles the motor speed if it is already running. On a LEFT button press, the microcontroller disables the power bridges after a smooth stop if the motor is running at minimum speed or halves the motor speed if the motor is running above minimum speed. Even if the “Daisy Chain” mode is supported in the L6470 FW library, the L6470 Discovery board HW does not allow it. Please contact ST support if you want more information on “Daisy Chain” mode testing or implementation. The FW L6470 library consists of the following files: 4.6.3 user_motion/dspin/inc/stm32f10x_conf.h Library configuration file user_motion/dspin/src/stm32f10x_it.cInterrupt handlers user_motion/dspin/inc/stm32f10x_it.hHeader for stm32f10x_it.c user_motion/dspin/inc/clock.h System clock setup related header user_motion/dspin/src/clock.c System clock source file user_motion/dspin/inc/dspin.h L6470 definitions header user_motion/dspin/src/dspin.c L6470 routines source file user_motion/dspin/inc/dspin_config.hdSPIN configuration parameters (this file can be generated by the GUI) user_motion/dspin/inc/main.h Main header file user_motion/dspin/src/main.c Main program user_motion/dspin/inc/pre_include.hFirst header file included by the preprocessor user_motion/dspin/readme.txt Information on the files Demonstration sequence description The demonstration sequence description is for one L6470 device without daisy chaining. The application commands used are noted after the pipe character. The application commands traffic can be seen on the SPI interface, pins 18, 19, 20 and 23 which are respectively SDO, CK, SDI and CS. DocID025486 Rev 2 35/41 41 General description UM1691 Initialization and configuration 1. Initialize peripherals used by L6470 2. LED_READY (green) is light up, other LEDs are switched off. 3. LED check sequence: a) LED_ERROR (red) is switched ON b) LED_BUSY (orange) is switched ON c) LED_SPARE (yellow) is switched ON d) LED_ERROR (red), LED_BUSY (orange) and LED_SPARE (yellow) are switched OFF. 4. Resets and puts the L6470 into standby mode. The L6470 STBY_RESET pin goes low for a few hundreds of s and then goes high. 5. Program all L6470 registers | SetParam (PARAM, VALUE). Flag signal management 6. Read status register content | GetStatus 7. Interrupt configuration for FLAG signal 8. Motor runs at constant speed of 400 steps/s forward direction | Run (DIR, SPD) 9. Tentative to write to the current motor absolute position register while the motor is running, as a consequence the LED_ERROR (red) is lighted up | SetParam (PARAM, VALUE) 10. Get Status to clear FLAG due to non-performable command, as a consequence the LED_ERROR (RED) is switched off | GetStatus 11. Motor stops smoothly | SoftStop 12. Wait until not busy - busy pin test (L6470 pin 22). Busy signal management 13. Interrupt configuration for BUSY signal 14. Motor moves by 100,000 steps in reverse direction | Move (DIR, N_STEP) 15. During busy time the LED_BUSY (orange) is switched ON 16. The L6470 disables the power bridges after a deceleration to zero phase | SoftHiZ 17. LED_BUSY (orange) is switched OFF. The LED_BUSY after the point 7 and the LED_ERROR after the point 13 are tied respectively to the BUSY/SYNC pin and the FLAG pin. So for example they are lighted up when motor accelerates or decelerates. This is happening in the remaining part of the demonstration although not mentioned. 36/41 DocID025486 Rev 2 UM1691 General description Various application command examples 18. Motor moves by 60,000 steps forward | Move (DIR, N_STEP) 19. Wait until not busy - busy pin test (L6470 pin 22). 20. Send L6470 command setting hold duty cycle to 0.5%, send L6470 command changing run duty cycle to 5% | SetParam (PARAM, VALUE) 21. Motor runs at constant speed of 50 steps/s in reverse direction | Run (DIR, SPD) 22. Motor softly stops after a few seconds | SoftStop 23. RESET KVAL_HOLD to initial value, RESET KVAL_RUN to initial value | SetParam (PARAM, VALUE) 24. Wait until not busy - busy status check in Status register | GetStatus 25. Motor moves by 100,000 steps forward | Move (DIR, N_STEP) 26. Wait until not busy - busy status check in Status register | GetStatus 27. Test of the Flag pin (L6470 pin 24) by polling, wait in endless cycle if problem is detected. 28. Motor moves to its home position | GoHome 29. Wait until not busy - busy pin test (L6470 pin 22). 30. Motor goes to absolute position 65535 through the shortest path | GoTo (ABS_POS) 31. Wait until not busy - busy pin test (L6470 pin 22). 32. Motor goes in forward direction to absolute position 131071 | GoTo_DIR (DIR, ABS_POS) 33. Wait until not busy - busy pin test (L6470 pin 22). 34. Read run duty cycle (dSPIN_KVAL_RUN) parameter from L6470, read intersect speed (dSPIN_INT_SPD) parameter from L6470 | GetParam(PARAM) 35. Read Status register content | GetStatus 36. Read absolute position (dSPIN_ABS_POS) parameter from L6470 | GetParam(PARAM) 37. Reset position counter, actually | ResetPos 38. Read absolute position (dSPIN_ABS_POS) parameter from L6470 | GetParam(PARAM) 39. L6470 disable power stage (High Impedance) immediately, as a consequence the motor supply current drops | HardHiZ. DocID025486 Rev 2 37/41 41 General description UM1691 “Go Until” example 40. Interrupt configuration for SW MOTOR 41. Motor motion in forward direction at speed 400 steps/s until the user puts a jumper on J8, the LED_SPARE (yellow) toggles until the user puts a jumper on J8 | GoUntil (ACT, DIR, SPD) 42. Motor stops 43. The LED_SPARE (yellow) is switched off. 44. Wait until not busy - busy pin test (L6470 pin 22) 45. Motor moves by 50,000 steps reverse | Move (DIR, N_STEP) 46. Motor moves to the position saved by the GoUntil command into the MARK register, so 50000 steps forward | GoMark 47. Wait until not busy - busy pin test (L6470 pin 22) 48. Nothing happens during a few seconds. Release SW example 49. Motor motion in reverse direction at minimum speed until the user removes the jumper on J8, the LED_SPARE (yellow) toggles until the user removes the jumper on J8 | ReleaseSW (ACT, DIR) 50. The LED_SPARE (yellow) is switched off. 51. Motor moves by 100,000 steps forward | Move (DIR, N_STEP) 52. Wait until not busy - busy pin test (L6470 pin 22) 53. Motor goes to home position set by the ReleaseSW command | GoHome 54. Wait until not busy - busy pin test (L6470 pin 22). Step clock mode example 55. Get Status to clear FLAG due to switch turn-on event (falling edge on the SW pin) | GetStatus 56. Motor runs in step clock mode at 2000 steps/s in forward direction for a few seconds while a 2 kHz clock signal from the MCU is applied to the L6470 STCK pin (25) | StepClock (DIR) 57. The above cited clock is stopped. Buttons interrupt example 58. Buttons interrupt configuration: a) Button_A - Starts the motor at quarter of max speed if it is stopped | Run (DIR, SPD) - Doubles the motor speed if it is already running | Run (DIR, SPD) b) Button_B - Disables the power bridges after a smooth stop if the motor is running at minimum speed | SoftHiZ - Halves the motor speed if the motor is running above minimum speed | Run (DIR, SPD). 38/41 DocID025486 Rev 2 UM1691 4.6.4 General description Create a project using the FW library package Using your preferred IDE, create a new project. In project options, properties or settings, Select for the device, the ST STM32F105xB. Use the CMSIS library. Edit the preprocessor defined symbols and add: STM32F10X_CL USE_STDPERIPH_DRIVER ST_DSPIN_6470H_DISCOVERY Edit the preprocessor include directories and add: $PROJ_DIR$\…\…\…\…\…\…\stm32f10x\CMSIS\CM3\DeviceSupport\ST\STM32F10x $PROJ_DIR$\…\.…\…\…\…\…\stm32f10x\STM32F10x_StdPeriph_Driver\inc $PROJ_DIR$\…\…\…\…\…\dspin\inc Where $PROJ_DIR$ is a variable containing the path to the project directory. Add the required library source files: startup_stm32f10x_cl.s system_stm32f10x.c misc.c stm32f10x_exti.c stm32f10x_flash.c stm32f10x_gpio.c stm32f10x_rcc.c stm32f10x_spi.c stm32f10x_tim.c For the debugger, for example, select the ST-LINK and configure it to run to main, to verify download, to use the Flash loader and to override the default *.board file with the FlashSTM32F105xB.board. DocID025486 Rev 2 39/41 41 References 5 UM1691 References This user manual provides information on the hardware features and use of the EVAL6470H-DISC board along with the demonstration firmware and software. For additional information, refer to the following: 6 1. STM32F105xx/STM32F107xx datasheet (CD00220364) 2. STM32F101xx, STM32F102xx, STM32F103xx, STM32F105xx and STM32F107xx advanced ARM®-based 32-bit MCUs reference manual (RM0008) 3. Voltage mode control operation and parameter optimization application note (AN4144) 4. L6470 and L6472: fully integrated stepper motor drivers (AN4241) 5. L647x, L648x and powerSTEP01 family communication protocol (AN4290). Revision history Table 4. Document revision history Date Revision 29-Nov-2013 1 Initial release. 2 Updated Section : Introduction on page 1 (replaced “L6470H” by “L6470”). Removed Figure 5. Layout (silk screen) from page 9. Replaced “dSPIN” by “L6470” and/or “motor” in the whole document. Updated Table 2 on page 9 and Section 4.2.1 on page 13 (replaced “L6470H” by “L6470”). Updated Table 3 on page 13 (minor modifications). Updated Section 4.5.1 on page 24 (replaced “FWPSPIN” by “FWGUI”). Updated text above Figure 24 on page 30 (removed L6472 device step). Updated Section 4.5.2 on page 33 and Section 4.6.2 on page 34 (removed L6472 device). Updated 20. in Section : Various application command examples on page 37 (minor modifications). Updated 1., 2., 4., and 5. in Section 5 on page 40. Minor modifications throughout document. 17-Apr-2015 40/41 Changes DocID025486 Rev 2 UM1691 IMPORTANT NOTICE – PLEASE READ CAREFULLY STMicroelectronics NV and its subsidiaries (“ST”) reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST’s terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers’ products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2015 STMicroelectronics – All rights reserved DocID025486 Rev 2 41/41 41