# mail

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

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

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



# Contact us

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



# TMC5031 DATASHEET

Dual, cost-effective controller and driver for up to two 2-phase bipolar stepper motors. Integrated motion controller with SPI interface.

++**APPLICATIONS** CCTV, Security Antenna Positioning Heliostat Controller Battery powered applications Office Automation ATM, Cash recycler, POS Lab Automation coolStep™ Liquid Handling Medical stallGuard Printer and Scanner Pumps and Valves ++

#### **FEATURES AND BENEFITS**

2-phase stepper motors Drive Capability up to 2 x 1.1A coil current Motion Controller with sixPoint<sup>™</sup> ramp Voltage Range 4.75... 16V DC SPI Interface 2x Ref.-Switch input per axis Highest Resolution 256 microsteps per full step Full Protection & Diagnostics stallGuard2<sup>™</sup> high precision sensorless motor load detection coolStep<sup>™</sup> load dependent current saves up to 75% energy spreadCycle<sup>™</sup> high-precision chopper for best current sine wave form and zero crossing with additional chopSync2<sup>™</sup> Compact Size 7x7mm QFN48 package

#### DESCRIPTION

The TMC5031 is a low cost motion controller and driver IC for up to two stepper motors. It combines two flexible ramp motion controllers with energy efficient stepper motor drivers. The drivers support two-phase stepper motors and offer an industry-leading including high-resolution feature set, microstepping, sensorless mechanical load measurement, load-adaptive power optimization, and low-resonance chopper operation. All features are controlled by a standard SPI<sup>™</sup> interface. Integrated protection and diagnostic features support robust and reliable operation. High integration, high energy efficiency and small form factor enable miniaturized designs with low external component count for cost-effective and highly competitive solutions.





#### BLOCK DIAGRAM

## **APPLICATION EXAMPLES: HIGH FLEXIBILITY – MULTIPURPOSE USE**

The TMC5031 scores with power density, complete motion controlling features and integrated power stages. It offers a versatility that covers a wide spectrum of applications from battery systems up to embedded applications with 1.1A current per motor. The small form factor keeps costs down and allows for miniaturized layouts. Extensive support at the chip, board, and software levels enables rapid design cycles and fast time-to-market with competitive products. High energy efficiency and reliability from TRINAMIC's coolStep technology deliver cost savings in related systems such as power supplies and cooling.

#### MINIATURIZED DESIGN FOR UP TO TWO STEPPER MOTORS



Two reference switch inputs can be used for each motor. A single CPU controls the whole system, which is highly economical and space saving.



#### TMC5031-EVAL EVALUATION BOARD EVALUATION & DEVELOPMENT PLATFORM

The TMC5031-EVAL is a tiny evaluation board, combining the TMC5031 with its basic external components and a 32 bit microcontroller interfacing to a PC. The firmware source code is available from the TRINAMIC website to allow own modifications and to make design-in easy.

#### **ORDER CODES**

| Order code   | Description                                              | Size [mm <sup>2</sup> ] |
|--------------|----------------------------------------------------------|-------------------------|
| TMC5031-LA   | Dual stallGuard2™ and coolStep™ controller/driver, QFN48 | 7 x 7                   |
| TMC5031-EVAL | Evaluation board for TMC5031                             | 85 x 55                 |

18.1

18.2

18.3

18.4

19.1

19.2

20 DISCLAIMER

24 REFERENCES

EXPOSED DIE PAD

SUPPLY FILTERING

LAYOUT EXAMPLE

PACKAGE CODES

**21 ESD SENSITIVE DEVICE** 

22 TABLE OF FIGURES

23 REVISION HISTORY

**19 PACKAGE MECHANICAL DATA** 

DIMENSIONAL DRAWINGS

WIRING GND

#### TABLE OF CONTENTS

| 1 | PRI                                           | NCIPLES OF OPERATION                                                                                                                                                                                                                  | 4                            |
|---|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
|   | 1.1<br>1.2<br>1.3<br>1.4<br>1.5<br>1.6<br>1.7 | KEY CONCEPTS<br>SPI CONTROL INTERFACE<br>SOFTWARE<br>MOVING AND CONTROLLING THE MOTOR<br>PRECISION DRIVER WITH PROGRAMMABLE<br>MICROSTEPPING WAVE<br>STALLGUARD2 – MECHANICAL LOAD SENSING<br>COOLSTEP – LOAD ADAPTIVE CURRENT CONTRO | 4<br>5<br>5<br>5<br>5<br>016 |
| 2 | PIN                                           | ASSIGNMENTS                                                                                                                                                                                                                           | 7                            |
|   | 2.1<br>2.2                                    | PACKAGE OUTLINE<br>SIGNAL DESCRIPTIONS                                                                                                                                                                                                | 7<br>7                       |
| 3 | SAM                                           | IPLE CIRCUITS                                                                                                                                                                                                                         | 10                           |
|   | 3.1<br>3.2<br>3.3<br>3.4<br>3.5               | STANDARD APPLICATION CIRCUIT<br>5 V ONLY SUPPLY<br>EXTERNAL VCC SUPPLY<br>OPTIMIZING ANALOG PRECISION<br>DRIVER PROTECTION AND EME CIRCUITRY                                                                                          | 10<br>12<br>13<br>14<br>15   |
| 4 | SPI                                           | INTERFACE                                                                                                                                                                                                                             | 16                           |
|   | 4.1<br>4.2<br>4.3                             | SPI DATAGRAM STRUCTURE<br>SPI SIGNALS<br>TIMING                                                                                                                                                                                       | 16<br>17<br>18               |
| 5 | REG                                           | ISTER MAPPING                                                                                                                                                                                                                         | 19                           |
|   | 5.1<br>5.2<br>5.3                             | General Configuration Registers<br>Ramp Generator Registers<br>Motor Driver Registers                                                                                                                                                 | 20<br>21<br>26               |
| 6 | CUR                                           | RENT SETTING                                                                                                                                                                                                                          | 32                           |
|   | 6.1                                           | Sense Resistors                                                                                                                                                                                                                       | 33                           |
| 7 | СНО                                           | PPER OPERATION                                                                                                                                                                                                                        | 34                           |
|   | 7.1<br>7.2<br>7.3<br>7.4                      | SPREADCYCLE CHOPPER<br>CLASSIC 2-PHASE MOTOR CONSTANT OFF TIME<br>CHOPPER<br>RANDOM OFF TIME<br>CHOPSYNC2 FOR QUIET MOTORS                                                                                                            | 35<br>38<br>39<br>40         |
| 8 | DRI                                           | VER DIAGNOSTIC FLAGS                                                                                                                                                                                                                  | 41                           |
|   | 8.1<br>8.2<br>8.3                             | Temperature Measurement<br>Short to GND Protection<br>Open Load Diagnostics                                                                                                                                                           | 41<br>41<br>41               |
| 9 | RAM                                           | IP GENERATOR                                                                                                                                                                                                                          | 42                           |
|   | 9.1<br>9.2<br>9.3<br>9.4<br>9.5               | Real World Unit Conversion<br>Motion Profiles<br>Interrupt Handling<br>Velocity Thresholds<br>Reference Switches                                                                                                                      | 42<br>43<br>44<br>44<br>46   |

| 9.             | 6                               | RESTRICTIONS OF RAMP GENERATOR (ERRATA)                                                                                                                            | 47                         |
|----------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| 10             | STA                             | LLGUARD2 LOAD MEASUREMENT                                                                                                                                          | 50                         |
| 10<br>10<br>10 | ).1<br>).2<br>).3<br>).4<br>).5 | TUNING THE STALLGUARD2 THRESHOLD SGT<br>STALLGUARD2 UPDATE RATE AND FILTER<br>DETECTING A MOTOR STALL<br>HOMING WITH STALLGUARD<br>LIMITS OF STALLGUARD2 OPERATION | 51<br>53<br>53<br>53<br>53 |
| 11             | COC                             | OLSTEP OPERATION                                                                                                                                                   | 54                         |
| 11             | 1<br>2<br>3                     | User Benefits<br>Setting up for coolStep<br>Tuning coolStep                                                                                                        | 54<br>54<br>56             |
| 12             | SIN                             | E-WAVE LOOK-UP TABLE                                                                                                                                               | 57                         |
|                | 2.1<br>2.2                      | User Benefits<br>Microstep Table                                                                                                                                   | 57<br>57                   |
| 13             | QUI                             | CK CONFIGURATION GUIDE                                                                                                                                             | 59                         |
| 14             | GET                             | TING STARTED                                                                                                                                                       | 62                         |
| 14             | .1                              | INITIALIZATION EXAMPLES                                                                                                                                            | 62                         |
| 15             | CLO                             | CK OSCILLATOR AND CLOCK INPUT                                                                                                                                      | 63                         |
| 15             | 5.1<br>5.2<br>5.3               | USING THE INTERNAL CLOCK<br>USING AN EXTERNAL CLOCK<br>CONSIDERATIONS ON THE FREQUENCY                                                                             | 63<br>63<br>63             |
| 16             | ABS                             | OLUTE MAXIMUM RATINGS                                                                                                                                              | 65                         |
| 17             | ELEC                            | CTRICAL CHARACTERISTICS                                                                                                                                            | 65                         |
|                | 7.1<br>7.2                      | Operational Range<br>DC Characteristics and Timing<br>Characteristics                                                                                              | 65<br>66                   |
| 17             | .3                              | THERMAL CHARACTERISTICS                                                                                                                                            | 68                         |
| 18             | LAY                             | OUT CONSIDERATIONS                                                                                                                                                 | 69                         |

69

69

69

70

71

71

71

72

72

73

74

74





Figure 1.1 Basic application and block diagram

The TMC5031 motion controller and driver chip is an intelligent power component interfacing between the CPU and up to two stepper motors. All stepper motor logic is completely within the TMC5031. No software is required to control the motor – just provide target positions. The TMC5031 offers a number of unique enhancements which are enabled by the system-on-chip integration of driver and controller. The sixPoint ramp generator of the TMC5031 uses coolStep and stallGuard2 automatically to optimize every motor movement: TRINAMICs special features contribute toward lower system cost, greater precision, greater energy efficiency, smoother motion, and cooler operation in stepper motor applications. The clear concept and the comprehensive solution save design-in time.

# **1.1** Key Concepts

The TMC5031 implements several advanced features which are exclusive to TRINAMIC products. These features contribute toward greater precision, greater energy efficiency, higher reliability, smoother motion, and cooler operation in many stepper motor applications.

stallGuard2<sup>™</sup> High-precision load measurement using the back EMF on the motor coils.

- **coolStep™** Load-adaptive current control which reduces energy consumption by as much as 75%.
- *spreadCycle*<sup>™</sup> High-precision chopper algorithm available as an alternative to the traditional constant off-time algorithm.
- *sixPoint*<sup>™</sup> Fast and precise positioning using a hardware ramp generator with a set of four acceleration *I* deceleration settings. Quickest response due to dedicated hardware.

In addition to these performance enhancements, TRINAMIC motor drivers also offer safeguards to detect and protect against shorted outputs, output open-circuit, overtemperature, and undervoltage conditions for enhancing safety and recovery from equipment malfunctions.

# **1.2** SPI Control Interface

The SPI interface is a bit-serial interface synchronous to a bus clock. For every bit sent from the bus master to the bus slave, another bit is sent simultaneously from the slave to the master. Communication between an SPI master and the TMC5031 slave always consists of sending one 40-bit command word and receiving one 40-bit status word.

The SPI command rate typically is a few commands per complete motor motion.

# **1.3** Software

From a software point of view the TMC5031 is a peripheral with a number of control and status registers. Most of them can either be written only or read only, some of the registers allow both read and write access. In case read-modify-write access is desired for a write only register, a shadow register can be realized in master software.

# 1.4 Moving and Controlling the Motor

#### 1.4.1 Integrated Motion Controller

The integrated 32 bit motion controller automatically drives the motors to target positions, or accelerates to target velocities. All motion parameters can be changed on the fly. The motion controller recalculates immediately. A minimum set of configuration data consists of acceleration and deceleration values and the maximum motion velocity. A start and stop velocity is supported as well as a second acceleration and deceleration setting. The integrated motion controller supports immediate reaction to mechanical reference switches and to the sensorless stall detection stallGuard2.

#### Benefits are:

- Flexible ramp programming
- Efficient use of motor torque for acceleration and deceleration allows higher machine throughput
- Immediate reaction to stop and stall conditions

# **1.5** Precision Driver with Programmable Microstepping Wave

Current into the motor coils is controlled using a cycle-by-cycle chopper mode. Two chopper modes are available: a traditional constant off-time mode and the new spreadCycle mode. Constant off-time mode provides higher torque at the highest velocity, while spreadCycle mode offers smoother operation and greater power efficiency over a wide range of speed and load. The spreadCycle chopper scheme automatically integrates a fast decay cycle and guarantees smooth zero crossing performance. Programmable microstep shapes allow optimizing the motor performance.

#### Benefits are:

- Significantly improved microstepping with low cost motors
- Motor runs smooth and quiet
- Reduced mechanical resonances yields improved torque

# 1.6 stallGuard2 – Mechanical Load Sensing

stallGuard2 provides an accurate measurement of the load on the motor. It can be used for stall detection as well as other uses at loads below those which stall the motor, such as coolStep load-adaptive current reduction. This gives more information on the drive allowing functions like sensorless homing and diagnostics of the drive mechanics.

# **1.7** coolStep – Load Adaptive Current Control

coolStep drives the motor at the optimum current. It uses the stallGuard2 load measurement information to adjust the motor current to the minimum amount required in the actual load situation. This saves energy and keeps the components cool, making the drive an efficient and precise solution.

#### Benefits are:

- Energy efficiency power consumption decreased up to 75%
  - Motor generates less heat improved mechanical precision
- Less or no cooling improved reliability
- Use of smaller motor less torque reserve required  $\rightarrow$  cheaper motor does the job

Figure 1.2 shows the efficiency gain of a 42mm stepper motor when using coolStep compared to standard operation with 50% of torque reserve. coolStep is enabled above 60RPM in the example.



Figure 1.2 Energy efficiency with coolStep (example)

# **2** Pin Assignments

# 2.1 Package Outline



Figure 2.1 TMC5031 pin assignments.

# 2.2 Signal Descriptions

| Pin    | Number                  | Туре | Function                                                                                                                                                                      |  |
|--------|-------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| GND    | 6, 9, 10,<br>12, 24, 34 | GND  | Digital ground pin for IO pins and digital circuitry.                                                                                                                         |  |
| VCC_IO | 7                       |      | 3.3V or 5V I/O supply voltage pin for all digital pins.                                                                                                                       |  |
| VSA    | 30                      |      | Analog supply voltage for 5V regulator – typically supplied with driver supply voltage. An additional 100nF capacitor to GND (GND plane) is recommended for best performance. |  |
| GNDA   | 31                      | GND  | Analog GND                                                                                                                                                                    |  |
| 5VOUT  | 32                      |      | Output of internal 5V regulator. Attach $2.2\mu$ F or larger ceramic capacitor to GNDA near to pin for best performance. May be used to supply VCC of chip.                   |  |

| Pin     | Number | Туре | Function                                                                                                                                                                                                                                                                                                                |
|---------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VCC     | 33     |      | 5V supply input for digital circuitry within chip and charge pump.<br>Attach 470nF capacitor to GND (GND plane). May be supplied by<br>5VOUT. A 2.2 $\Omega$ resistor is recommended for decoupling noise from<br>5VOUT. When using an external supply, make sure, that VCC comes<br>up before or in parallel to 5VOUT. |
| DIE_PAD | -      | GND  | Connect the exposed die pad to a GND plane. Provide as many as possible vias for heat transfer to GND plane.                                                                                                                                                                                                            |

#### Table 2.1 Low voltage digital and analog power supply pins

| Pin | Number | Туре   | Function                                                                                                   |
|-----|--------|--------|------------------------------------------------------------------------------------------------------------|
| СРО | 35     | O(VCC) | Charge pump driver output. Outputs 5V (GND to VCC) square wave with 1/16 of internal oscillator frequency. |
| CPI | 36     | I(VCP) | Charge pump capacitor input: Provide external 22 nF / 50V capacitor to CPO.                                |
| VCP | 37     |        | Output of charge pump. Provide external 100 nF capacitor to VS.                                            |

#### Table 2.2 Charge pump pins

| Pin      | Number     | Туре  | Function                                                               |  |
|----------|------------|-------|------------------------------------------------------------------------|--|
| INT      | 1          | 0 (Z) | Tristate interrupt output. Can be programmed to provide interrupt      |  |
|          |            |       | output based on ramp generator flags RAMP_STAT bits 4, 5, 6 & 7        |  |
|          |            |       | (poscmp_enable=1).                                                     |  |
| PP       | 2          | 0 (Z) | Tristate position compare output for motor 1 (poscmp_enable=1).        |  |
| CSN      | 3          | I     | Chip select input of SPI interface                                     |  |
| SCK      | 4          | Ι     | Serial clock input of SPI interface                                    |  |
| SDI      | 5          | Ι     | Data input of SPI interface                                            |  |
| SDO      | 8          | 0 (Z) | Tristate data output of SPI interface (enabled with CSN=0)             |  |
| CLK      | 11         | Ι     | Clock input. Tie to GND using short wire for internal clock or supply  |  |
|          |            |       | external clock. The first high signal disables the internal oscillator |  |
|          |            |       | until power down.                                                      |  |
| REFR2    | 25         | Ι     | Right reference switch input for motor 2                               |  |
| REFL2    | 26         | Ι     | Left reference switch input for motor 2                                |  |
| REFR1    | 27         | Ι     | Right reference switch input for motor 1                               |  |
| REFL1    | 28         | Ι     | Left reference switch input for motor 1                                |  |
| DRV_ENN  | 29         | Ι     | Enable input for motor drivers. The power stage becomes switched       |  |
|          |            |       | off (all motor outputs floating) when this pin becomes driven to a     |  |
|          |            |       | high level. Tie to GND for normal operation.                           |  |
| TST_MODE | 48         | Ι     | Test mode input. Puts IC into test mode. Tie to GND for normal         |  |
|          |            |       | operation.                                                             |  |
| -        | 13, 23, 38 | N.C.  | Unused pins - no internal electrical connection. Leave open or tie to  |  |
|          |            |       | GND for compatibility with future devices.                             |  |

| Table 2.3 Digital I/ | ) pins (all related to | VCC_IO supply) |
|----------------------|------------------------|----------------|
|----------------------|------------------------|----------------|

| Pin  | Number | Туре   | Function                                                                                                                       |  |
|------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------|--|
| 02A1 | 14     | 0 (VS) | Motor 2 coil A output 1                                                                                                        |  |
| BR2A | 15     |        | Sense resistor connection for motor 2 coil A. Place sense resistor to GND near pin.                                            |  |
| 02A2 | 16     | 0 (VS) | Motor 2 coil A output 2                                                                                                        |  |
| VS   | 17, 19 |        | Motor supply voltage. Provide filtering capacity near pin with shortest loop to nearest GNDP pin (respectively via GND plane). |  |
| GNDP | 18     | GND    | Power GND. Connect to GND plane near pin.                                                                                      |  |
| 02B1 | 20     | 0 (VS) | Motor 2 coil B output 1                                                                                                        |  |
| BR2B | 21     |        | Sense resistor connection for motor 2 coil B. Place sense resistor to GND near pin.                                            |  |
| O2B2 | 22     | 0 (VS) | Motor 2 coil B output 2                                                                                                        |  |
| 01B2 | 39     | 0 (VS) | Motor 1 coil B output 2                                                                                                        |  |
| BR1B | 40     |        | Sense resistor connection for motor 1 coil B. Place sense resistor to GND near pin.                                            |  |
| 01B1 | 41     | 0 (VS) | Motor 1 coil B output 1                                                                                                        |  |
| VS   | 42, 44 |        | Motor supply voltage. Provide filtering capacity near pin with shortest loop to nearest GNDP pin (respectively via GND plane). |  |
| GNDP | 43     | GND    | Power GND. Connect to GND plane near pin.                                                                                      |  |
| 01A2 | 45     | 0 (VS) | Motor 1 coil A output 2                                                                                                        |  |
| BR1A | 46     |        | Sense resistor connection for motor 1 coil A. Place sense resistor to GND near pin.                                            |  |
| 01A1 | 47     | 0 (VS) | Motor 1 coil A output 1                                                                                                        |  |

Table 2.4 Power driver pins

# 3 Sample Circuits

The sample circuits show the connection of the external components in different operation and supply modes. The connection of the bus interface and further digital signals is left out for clarity.

# **3.1 Standard Application Circuit**



\*) For a reliable start-up it is essential that VCC\_IO comes up to a minimum of 1.5V before the TMC5031 leaves the reset condition. Therefore, TRINAMIC recommends using a fast-start-up voltage regulator (e.g. TS3480CX33) in a 3.3V environment.

#### Figure 3.1 Standard application circuit

The standard application circuit uses a minimum set of additional components in order to operate the motor. Use low ESR capacitors for filtering the power supply capable to cope with the current ripple. The current ripple often depends on the power supply and cable length. The VCC\_IO voltage can be supplied from 5VOUT, or from a fast startup 3.3V regulator. In order to minimize linear voltage regulator power dissipation of the internal 5V voltage regulator in applications where VM is high, a different (lower) supply voltage can be used for VSA, if available. For best motor chopper performance, an optional R/C-filter de-couples 5VOUT from digital noise cause by power drawn from VCC.

#### Basic layout hints

Place sense resistors and all filter capacitors as close as possible to the related IC pins. Use a solid common GND for all GND connections, also for sense resistor GND. Connect 5VOUT filtering capacitor directly to 5VOUT and GNDA pin. See layout hints for more details. Low ESR electrolytic capacitors are recommended for VS filtering.

#### Attention

In case VSA is supplied by a different voltage source, make sure that VSA does not exceed VS by more than one diode drop upon power up or power down.

### 3.1.1 VCC\_IO Requirements

For a reliable start-up it is essential that VCC\_IO comes up to a minimum of 1.5V before the TMC5031 leaves the reset condition. The reset condition ends earliest 50µs after the time when VSA exceeds its undervoltage threshold of typically 4.2V, or when 5VOUT exceeds its undervoltage threshold of typically 3.5V, whichever comes last.

#### THERE ARE THREE WAYS TO COME UP TO VCC\_IO REQUIREMENTS

- 5VOUT can be used directly to supply VCC\_IO. In this case there are no further requirements.
- An external low drop regulator can be used in a 3.3V environment as shown in Figure 3.1. Note, that most voltage regulators are not suitable for this application because they show a delayed boot up. The following external regulators are proved by TRINAMIC:

TS3480CX33 This regulator can be used within the full supply voltage range when tied to the motor supply voltage.

LD1117-3.3 This regulator can be used to supply VCC\_IO from 5VOUT, or from a supply voltage of up to 15V.

- VCC\_IO can be supplied externally as shown in Figure 3.2 . In this case it is mandatory to connect the Schottky diode to the logic supply of the external circuitry. Please note, that the 2K resistor is not to be used with 5V I/O voltage.



#### Figure 3.2 External supply of VCC\_IO (showing optional filtering for VCC)

Refer to application note no. 028 *Supply Voltage Considerations: VCC\_IO in TMC50xx Designs* (www.trinamic.com). Here you will find complete information about connecting VCC\_IO.

# 3.2 5 V Only Supply



Figure 3.3 5V only operation

While the standard application circuit is limited to roughly 5.5 V lower supply voltage, a 5 V only application lets the IC run from a normal 5 V +/-5% supply. In this application, linear regulator drop must be minimized. Therefore, the major 5 V load is removed by supplying VCC directly from the external supply. In order to keep supply ripple away from the analog voltage reference, 5 VOUT should have an own filtering capacity and the 5 VOUT pin does not become bridged to the 5 V supply.

# 3.3 External VCC Supply

Supplying VCC from an external supply is advised, when cooling of the chip is critical, e.g. at high environment temperatures in combination with high supply voltages (16 V), as the linear regulator is a major source of on-chip power dissipation. It must be made sure that the external VCC supply comes up before or synchronously with the 5VOUT supply, because otherwise the power-up reset event may be missed by the TMC5031. A diode from 5VOUT to VCC ensures this, in case the external voltage regulator is not a low drop type linear regulator. In order to prevent overload of the internal 5V regulator when using this diode, an additional series resistor has been added to VSA.

An alternative for reduced power dissipation is using a lower supply voltage for VSA, e.g. 6V to 12V. If power dissipation is critical, but no external supply is available, the clock frequency can be reduced as a first step by supplying external 12 MHz clock.



Figure 3.4 Using an external 5V supply to reduce linear regulator power dissipation

### 3.3.1 Internal Regulator Bridged

In case a clean external 5V supply is available, it can be used for complete supply of analog and digital part (Figure 3.5). The circuit will benefit from a well-regulated supply, e.g. when using a +/-1% regulator. A precise supply guarantees increased motor current precision, because the voltage at 5VOUT directly is the reference voltage for all internal units of the driver, especially for motor current control. For best performance, the power supply should have low ripple to give a precise and stable supply at 5VOUT pin with remaining ripple well below 5mV. Some switching regulators have a higher remaining ripple, or different loads on the supply may cause lower frequency ripple. In this case, increase capacity attached to 5VOUT. In case the external supply voltage has poor stability or low frequency ripple, this would affect the precision of the motor current regulation as well as add chopper noise.



Figure 3.5 Using an external 5V supply to bypass internal regulator

# 3.4 Optimizing Analog Precision

The 5VOUT pin is used as an analog reference for operation of the TMC5031. Performance will degrade when there is voltage ripple on this pin. Most of the high frequency ripple in a TMC5031 design results from the operation of the internal digital logic. The digital logic switches with each edge of the clock signal. Further, ripple results from operation of the charge pump, which operates with roughly 1MHz and draws current from the VCC pin. In order to keep this ripple as low as possible, an additional filtering capacitor can be put directly next to the VCC pin with vias to the GND plane giving a short connection to the digital GND pins (pin 6 and pin 34). Analog performance is best, when this ripple is kept away from the analog supply pin 5VOUT, using an additional series resistor of 2.2  $\Omega$  to 3.3  $\Omega$ . The voltage drop on this resistor will be roughly 100 mV (I<sub>VCC</sub> \* R).



Figure 3.6 Adding an RC-Filter on VCC for reduced ripple

# 3.5 Driver Protection and EME Circuitry

Some applications have to cope with ESD events caused by motor operation or external influence. Despite ESD circuitry within the driver chips, ESD events occurring during operation can cause a reset or even a destruction of the motor driver, depending on their energy. Especially plastic housings and belt drive systems tend to cause ESD events. It is best practice to avoid ESD events by attaching all conductive parts, especially the motors themselves to PCB ground, or to apply electrically conductive plastic parts. In addition, the driver can be protected up to a certain degree against ESD events or live plugging / pulling the motor, which also causes high voltages and high currents into the motor connector terminals. A simple scheme uses capacitors at the driver outputs to reduce the dV/dt cause additional current flow in each chopper cycle, and thus increase driver power dissipation, especially at high supply voltages. The values shown are example values – they might be varied between 100pF and 1nF. The capacitors also dampen high frequency noise injected from digital parts of the circuit and thus reduce electromagnetic emission. A more elaborate scheme uses LC filters to de-couple the driver outputs from the motor connector. Varistors in between of the coil terminals eliminate coil overvoltage caused by live plugging. Optionally protect all outputs by a varistor against ESD voltage.



Figure 3.7 Simple ESD enhancement and more elaborate motor output protection

# 4 SPI Interface

# 4.1 SPI Datagram Structure

The TMC5031 uses 40 bit SPI<sup>™</sup> (Serial Peripheral Interface, SPI is Trademark of Motorola) datagrams for communication with a microcontroller. Microcontrollers which are equipped with hardware SPI are typically able to communicate using integer multiples of 8 bit. The NCS line of the TMC5031 must be handled in a way, that it stays active (low) for the complete duration of the datagram transmission.

Each datagram sent to the TMC5031 is composed of an address byte followed by four data bytes. This allows direct 32 bit data word communication with the register set of the TMC5031. Each register is accessed via 32 data bits even if it uses less than 32 data bits.

For simplification, each register is specified by a one byte address:

- For a read access the most significant bit of the address byte is 0.
- For a write access the most significant bit of the address byte is 1.

Most registers are write only registers, some can be read additionally, and there are also some read only registers.

| TMC5031 SPI DATAGRAM STRUCTURE                                                                                      |                                                                                                                             |            |                                    |                        |  |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------------|------------------------------------|------------------------|--|
| MSB (transmitted first)                                                                                             |                                                                                                                             | 40 bit     |                                    | LSB (transmitted last) |  |
| 39                                                                                                                  |                                                                                                                             |            |                                    | 0                      |  |
| <ul> <li>→ 8 bit address</li> <li>← 8 bit SPI status</li> </ul>                                                     | $\leftarrow \rightarrow 32$ hit data                                                                                        |            |                                    |                        |  |
| 39 32                                                                                                               |                                                                                                                             | 31         | 0                                  |                        |  |
| <ul> <li>→ to TMC5031:</li> <li>RW + 7 bit address</li> <li>← from TMC5031:</li> <li>8 bit SPI status</li> </ul>    | 8 bit data                                                                                                                  | 8 bit data | 8 bit data                         | 8 bit data             |  |
| 39 / 38 32                                                                                                          | 31 24                                                                                                                       | 23 16      | 15 8                               | 7 0                    |  |
| w 3832                                                                                                              | 3128 2724                                                                                                                   | 2320 1916  | 1512 118                           | 74 30                  |  |
| 3       3       3       3       3       3       3         9       8       7       6       5       4       3       2 | 3       3       2       2       2       2       2       2         1       0       9       8       7       6       5       4 |            | 1 1 1 1 1 1 1 5<br>5 4 3 2 1 0 9 8 | 7 6 5 4 3 2 1 0        |  |

## 4.1.1 Selection of Write / Read (WRITE\_notREAD)

The read and write selection is controlled by the MSB of the address byte (bit 39 of the SPI datagram). This bit is 0 for read access and 1 for write access. So, the bit named W is a WRITE\_notREAD control bit. The active high write bit is the MSB of the address byte. So, 0x80 has to be added to the address for a write access. The SPI interface always delivers data back to the master, independent of the W bit. The data transferred back is the data read from the address which was transmitted with the *previous* datagram, if the previous access was a read access. If the previous access was a write access, then the data read back mirrors the previously received write data. So, the difference between a read and a write access is that the read access does not transfer data to the addressed register but it transfers the address only and its 32 data bits are dummies, and, further the following read or write access delivers back the data read from the address transmitted in the preceding read cycle.

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

Whenever data is read from or written to the TMC5031, the MSBs delivered back contain the SPI status, *SPI\_STATUS*, a number of eight selected status bits.

For a read access to the register (*XACTUAL*) with the address 0x21, the address byte has to be set to 0x21 in the access preceding the read access. For a write access to the register (*VMAX*), the address byte has to be set to 0x80 + 0x27 = 0xA7. For read access, the data bit might have any value (-). So, one can set them to 0.

| action                  | data sent to TMC5031       | data received from TMC5031      |
|-------------------------|----------------------------|---------------------------------|
| read XACTUAL            | → 0x210000000              | $\leftarrow$ 0xSS & unused data |
| read XACTUAL            | → 0x2100000000             | $\leftarrow$ 0xss & xactual     |
| write VMAX:= 0x00ABCDEF | $\rightarrow$ 0xa700abcdef | $\leftarrow$ 0xss & Xactual     |
| write VMAX:= 0x00123456 | → 0xA700123456             | ← 0xss00abcdef                  |
|                         |                            |                                 |

\*) S: is a placeholder for the status bits SPI\_STATUS

### 4.1.2 SPI Status Bits Transferred with Each Datagram Read Back

New status information becomes latched at the end of each access and is available with the next SPI transfer.

| SPI_ | SPI_STATUS - status flags transmitted with each SPI access in bits 39 to 32 |                                                                           |  |  |
|------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------|--|--|
| Bit  | Bit Name Comment                                                            |                                                                           |  |  |
| 7    | -                                                                           | reserved (0)                                                              |  |  |
| 6    | status_stop_l(2)                                                            | RAMP_STAT2[0] – 1: Signals motor 2 stop left switch status                |  |  |
| 5    | status_stop_l(1)                                                            | RAMP_STAT1[0] – 1: Signals motor 1 stop left switch status                |  |  |
| 4    | velocity_reached(2)                                                         | RAMP_STAT2[8] – 1: Signals motor 2 has reached its target velocity        |  |  |
| 3    | velocity_reached(1)                                                         | RAMP_STAT1[8] – 1: Signals motor 1 has reached its target velocity        |  |  |
| 2    | driver_error(2)                                                             | GSTAT[2] – 1: Signals driver 2 driver error (clear by reading GSTAT)      |  |  |
| 1    | driver_error(1)                                                             | GSTAT[1] – 1: Signals driver 1 driver error (clear by reading GSTAT)      |  |  |
| 0    | reset_flag                                                                  | GSTAT[0] - 1: Signals, that a reset has occurred (clear by reading GSTAT) |  |  |

### 4.1.3 Data Alignment

All data are right aligned. Some registers represent unsigned (positive) values, some represent integer values (signed) as two's complement numbers, single bits or groups of bits are represented as single bits respectively as integer groups.

# 4.2 SPI Signals

The SPI bus on the TMC5031 has four signals:

- SCK bus clock input
- SDI serial data input
- SDO serial data output
- CSN chip select input (active low)

The slave is enabled for an SPI transaction by a low on the chip select input CSN. Bit transfer is synchronous to the bus clock SCK, with the slave latching the data from SDI on the rising edge of SCK and driving data to SDO following the falling edge. The most significant bit is sent first. A minimum of 40 SCK clock cycles is required for a bus transaction with the TMC5031.

If more than 40 clocks are driven, the additional bits shifted into SDI are shifted out on SDO after a 40-clock delay through an internal shift register. This can be used for daisy chaining multiple chips.

CSN must be low during the whole bus transaction. When CSN goes high, the contents of the internal shift register are latched into the internal control register and recognized as a command from the master to the slave. If more than 40 bits are sent, only the last 40 bits received before the rising edge of CSN are recognized as the command.

# 4.3 Timing

The SPI interface is synchronized to the internal system clock, which limits the SPI bus clock SCK to half of the system clock frequency. If the system clock is based on the on-chip oscillator, an additional 10% safety margin must be used to ensure reliable data transmission. All SPI inputs as well as the ENN input are internally filtered to avoid triggering on pulses shorter than 20ns. Figure 4.1 shows the timing parameters of an SPI bus transaction, and the table below specifies their values.



#### Figure 4.1 SPI timing

| Hint                                                                      |
|---------------------------------------------------------------------------|
| Usually this SPI timing is referred to as SPI MODE 3 (CPOL=1 and CPHA=1). |

| SPI interface timing                                | AC-Characteristics |                                                                                                       |                     |                        |                      |      |  |  |  |  |
|-----------------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------|---------------------|------------------------|----------------------|------|--|--|--|--|
|                                                     | clock perio        | clock period: t <sub>CLK</sub>                                                                        |                     |                        |                      |      |  |  |  |  |
| Parameter                                           | Symbol             | Conditions                                                                                            | Min                 | Тур                    | Мах                  | Unit |  |  |  |  |
| SCK valid before or after change of CSN             | t <sub>cc</sub>    |                                                                                                       | 10                  |                        |                      | ns   |  |  |  |  |
| CSN high time                                       | t <sub>csH</sub>   | *) Min time is for<br>synchronous CLK<br>with SCK high one<br>t <sub>CH</sub> before CSN high<br>only | t <sub>CLK</sub> *) | >2t <sub>CLK</sub> +10 |                      | ns   |  |  |  |  |
| SCK low time                                        | t <sub>CL</sub>    | *) Min time is for<br>synchronous CLK<br>only                                                         | t <sub>CLK</sub> *) | >t <sub>CLK</sub> +10  |                      | ns   |  |  |  |  |
| SCK high time                                       | t <sub>CH</sub>    | *) Min time is for<br>synchronous CLK<br>only                                                         | t <sub>CLK</sub> *) | >t <sub>CLK</sub> +10  |                      | ns   |  |  |  |  |
| SCK frequency using internal clock                  | f <sub>scк</sub>   | assumes minimum<br>OSC frequency                                                                      |                     |                        | 4                    | MHz  |  |  |  |  |
| SCK frequency using external<br>16MHz clock         | f <sub>scк</sub>   | assumes<br>synchronous CLK                                                                            |                     |                        | 8                    | MHz  |  |  |  |  |
| SDI setup time before rising edge of SCK            | t <sub>DU</sub>    |                                                                                                       | 10                  |                        |                      | ns   |  |  |  |  |
| SDI hold time after rising edge of SCK              | t <sub>DH</sub>    |                                                                                                       | 10                  |                        |                      | ns   |  |  |  |  |
| Data out valid time after falling<br>SCK clock edge | t <sub>DO</sub>    | no capacitive load<br>on SDO                                                                          |                     |                        | t <sub>FILT</sub> +5 | ns   |  |  |  |  |
| SDI, SCK and CSN filter delay time                  | t <sub>FILT</sub>  | rising and falling<br>edge                                                                            | 12                  | 20                     | 30                   | ns   |  |  |  |  |

# 5 Register Mapping

This chapter gives an overview of the complete register set. Some of the registers bundling a number of single bits are detailed in extra tables. The functional practical application of the settings is detailed in dedicated chapters.

Note

All registers become reset to 0 upon power up, unless otherwise noted.
Add 0x80 to the address Addr for write accesses!

| NOTATION OF HEXADECIMAL AND BINARY NUMBERS |                                               |
|--------------------------------------------|-----------------------------------------------|
| 0x                                         | precedes a hexadecimal number, e.g. 0x04      |
| %                                          | precedes a multi-bit binary number, e.g. %100 |

| NOTATION OF R/W FIELD |                                                               |
|-----------------------|---------------------------------------------------------------|
| R                     | Read only                                                     |
| W                     | Write only                                                    |
| R/W                   | Read- and writable register                                   |
| R+C                   | Clear upon read (i.e. status bit becomes reset after readout) |

#### **OVERVIEW REGISTER MAPPING**

| REGISTER                                           | DESCRIPTION                                                                   |
|----------------------------------------------------|-------------------------------------------------------------------------------|
| General Configuration Registers                    | These registers contain                                                       |
|                                                    | - global configuration                                                        |
|                                                    | - global status flags                                                         |
| Ramp Generator Motion Control Register Set         | This register set offers registers for                                        |
|                                                    | - choosing a ramp mode                                                        |
|                                                    | <ul> <li>choosing velocities</li> </ul>                                       |
|                                                    | - homing                                                                      |
|                                                    | <ul> <li>acceleration and deceleration</li> </ul>                             |
|                                                    | - target positioning                                                          |
| Ramp Generator Driver Feature Control Register Set | This register set offers registers for                                        |
|                                                    | - driver current control                                                      |
|                                                    | <ul> <li>setting thresholds for coolStep operation</li> </ul>                 |
|                                                    | <ul> <li>setting thresholds for different chopper modes</li> </ul>            |
|                                                    | <ul> <li>a reference switch and stallGuard2 event</li> </ul>                  |
|                                                    | configuration                                                                 |
|                                                    | <ul> <li>a ramp and reference switch status register</li> </ul>               |
| Motor Driver Register Set                          | This register set offers registers for                                        |
|                                                    | <ul> <li>setting / reading out microstep table and</li> </ul>                 |
|                                                    | counter                                                                       |
|                                                    | - chopper and driver configuration                                            |
|                                                    | <ul> <li>coolStep and stallGuard2 configuration</li> </ul>                    |
|                                                    | <ul> <li>reading out stallGuard2 values and driver error<br/>flags</li> </ul> |

# 5.1 General Configuration Registers

GENERAL CONFIGURATION REGISTERS (0x00...0x1F) R/W Addr Description I bit names n Register **GCONF** – Global configuration flags Bit 0..2 Reserved, set to 0 poscmp\_enable 3 Outputs INT and PP are tristated. 0: 1: Position compare pulse (PP) and interrupt output (INT) are available Attention - do not leave the outputs floating in tristate condition, provide an external pull-up or set this bit 1. 4..6 Reserved, set to 0 test mode 7 0x00 RW 11 GCONF Normal operation 0: 1: Enable analog test output on pin REFR2 REFR2: TEST\_SEL selects the function of 0...4: T120, DAC1, VDDH1, DAC2, VDDH2 Attention: Not for user, set to 0 for normal operation! 8 shaft1 1: Inverse motor 1 direction 9 shaft2 Inverse motor 2 direction 1: 10 lock gconf 1: GCONF is locked against further write access. Bit **GSTAT** – Global status flags 0 reset Indicates that the IC has been reset since the last 1: read access to GSTAT. drv\_err1 1 Indicates, that driver 1 has been shut down due 1: to overtemperature or short circuit detection since the last read access. Read DRV\_STATUS1 for details. The flag can only be reset when all error R+C 0x01 GSTAT 4 conditions are cleared. 2 drv err2 1: Indicates, that driver 2 has been shut down due to overtemperature or short circuit detection since the last read access. Read DRV\_STATUS2 for details. The flag can only be reset when all error conditions are cleared. 3 uv\_cp Indicates an undervoltage on the charge pump. 1: The driver is disabled in this case. **SLAVECONF** Bit TEST\_SEL: 3..0 selects the function of REFR2 in test mode: W 0x03 4 TEST\_SEL 0...4: T120, DAC1, VDDH1, DAC2, VDDH2 Attention: Not for user, set to 0 for normal operation! Bit INPUT 0..6 Unused, ignore these bits 8 R 0x04 + INPUT 7 Reads the state of the DRV\_ENN pin 8 31.. VERSION: 0x01=first version of the IC 24 Identical numbers mean full digital compatibility.

| GENER | GENERAL CONFIGURATION REGISTERS (0x000x1F) |    |           |                                                                                                                                 |  |  |  |  |
|-------|--------------------------------------------|----|-----------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| R/W   | Addr                                       | n  | Register  | Description I bit names                                                                                                         |  |  |  |  |
|       |                                            |    |           | Position comparison register for motor 1 position strobe.<br>Activate <i>poscmp_enable</i> to get position pulse on output PP.  |  |  |  |  |
| W     | 0x05                                       | 32 | X_COMPARE | <ul> <li>XACTUAL = X_COMPARE:</li> <li>Output PP becomes high. It returns to a low state, if the positions mismatch.</li> </ul> |  |  |  |  |

# 5.2 Ramp Generator Registers

Addresses **Addr** are specified for motor 1 (upper value) and motor 2 (second address).

# 5.2.1 Ramp Generator Motion Control Register Set

| RAMP | RAMP GENERATOR MOTION CONTROL REGISTER SET (MOTOR 1: 0x200x2D, MOTOR 2: 0x400x4D) |    |          |                                                                                                                                                                                                                                                                                                                     |                             |  |  |  |
|------|-----------------------------------------------------------------------------------|----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|--|
| R/W  | Addr                                                                              | n  | Register | Description <i>I bit names</i>                                                                                                                                                                                                                                                                                      | Range [Unit]                |  |  |  |
| RW   | 0x20<br>0x40                                                                      | 2  | RAMPMODE | <ul> <li>RAMPMODE:</li> <li>O: Positioning mode (using all A, D and V parameters)</li> <li>1: Velocity mode to positive VMAX (using AMAX acceleration)</li> <li>2: Velocity mode to negative VMAX (using AMAX acceleration)</li> <li>3: Hold mode (velocity remains unchanged, unless stop event occurs)</li> </ul> | 03                          |  |  |  |
| RW   | 0x21<br>0x41                                                                      | 32 | XACTUAL  | Actual motor position (signed)<br><i>Hint:</i> This value normally should only be<br>modified, when homing the drive. In<br>positioning mode, modifying the register<br>content will start a motion.                                                                                                                | -2^31<br>+(2^31)-1          |  |  |  |
| R    | 0x22<br>0x42                                                                      | 24 | VACTUAL  | Actual motor velocity from ramp generator<br>(signed)<br>The sign matches the motion direction. A<br>negative sign means motion to lower<br>XACTUAL.                                                                                                                                                                | +-(2^23)-1<br>[µsteps / t]  |  |  |  |
| W    | 0x23<br>0x43                                                                      | 18 | VSTART   | Motor start velocity (unsigned)<br>Set VSTOP ≥ VSTART!                                                                                                                                                                                                                                                              | 0(2^18)-1<br>[µsteps / t]   |  |  |  |
| W    | 0x24<br>0x44                                                                      | 16 | A1       | First acceleration between VSTART and V1 (unsigned)                                                                                                                                                                                                                                                                 | 0(2^16)-1<br>[µsteps / ta²] |  |  |  |
| W    | 0x25<br>0x45                                                                      | 20 | V1       | <ul><li>First acceleration / deceleration phase target velocity (unsigned)</li><li>0: Disables A1 and D1 phase, use AMAX, DMAX only</li></ul>                                                                                                                                                                       | 0(2^20)-1<br>[µsteps / t]   |  |  |  |
| W    | 0x26<br>0x46                                                                      | 16 | ΑΜΑΧ     | Second acceleration between V1 and VMAX<br>(unsigned)<br>This is the acceleration and deceleration value<br>for velocity mode.                                                                                                                                                                                      | 0(2^16)-1<br>[µsteps / ta²] |  |  |  |

|     | RAMP GENERATOR MOTION CONTROL REGISTER SET (MOTOR 1: 0x200x2D, MOTOR 2: 0x400x4D) |    |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                             |  |  |  |  |
|-----|-----------------------------------------------------------------------------------|----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|--|--|
| R/W | Addr                                                                              | n  | Register  | Description <i>I bit names</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Range [Unit]                |  |  |  |  |
| W   | 0x27<br>0x47                                                                      | 23 | VMAX      | Motion ramp target velocity (for positioning<br>ensure VMAX ≥ VSTART) (unsigned)<br>This is the target velocity in velocity mode. It<br>can be changed any time during a motion.                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0(2^23)-512<br>[µsteps / t] |  |  |  |  |
| W   | 0x28<br>0x48                                                                      | 16 | DMAX      | Deceleration between VMAX and V1 (unsigned)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0(2^16)-1<br>[µsteps / ta²] |  |  |  |  |
| W   | 0x2A<br>0x4A                                                                      | 16 | D1        | Deceleration between V1 and VSTOP<br>(unsigned)<br>Attention: Do not set 0 in positioning mode,<br>even if V1=0!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1(2^16)-1<br>[µsteps / ta²] |  |  |  |  |
| W   | 0x2B<br>0x4B                                                                      | 18 | VSTOP     | Motor stop velocity (unsigned)<br>Attention: Set VSTOP ≥ VSTART!<br>Attention: Do not set 0 in positioning mode!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1(2^18)-1<br>[µsteps / t]   |  |  |  |  |
| W   | 0x2C<br>0x4C                                                                      | 16 | TZEROWAIT | Waiting time after ramping down to zero<br>velocity before next movement or direction<br>inversion can start and before motor power<br>down starts. Time range is about 0 to 2                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |  |  |  |  |
| RW  | 0x2D<br>0x4D                                                                      | 32 | XTARGET   | Target position for ramp mode (signed). Write<br>a new target position to this register in order<br>to activate the ramp generator positioning in<br><i>RAMPMODE=</i> 0. Initialize all velocity,<br>acceleration and deceleration parameters<br>before. <i>Hint:</i> The position is allowed to wrap around,<br>thus, <i>XTARGET</i> value optionally can be treated<br>as an unsigned number. <i>Hint:</i> The maximum possible displacement is<br>+/-((2^31)-1). <i>Hint:</i> When increasing V1, D1 or DMAX during<br>a motion, rewrite XTARGET afterwards in order<br>to trigger a second acceleration phase, if<br>desired. | -2^31<br>+(2^31)-1          |  |  |  |  |

## 5.2.2 Ramp Generator Driver Feature Control Register Set

| RAMP G | RAMP GENERATOR DRIVER FEATURE CONTROL REGISTER SET (MOTOR 1: 0x300x36, MOTOR 2: 0x500x56) |          |            |                                                         |                                                                            |  |  |  |  |
|--------|-------------------------------------------------------------------------------------------|----------|------------|---------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|
| R/W    | Addr                                                                                      | n        | Register   | Descriptio                                              | n I bit names                                                              |  |  |  |  |
|        |                                                                                           |          |            | Bit                                                     | IHOLD_IRUN - Driver current control                                        |  |  |  |  |
|        |                                                                                           |          |            | 40                                                      | IHOLD                                                                      |  |  |  |  |
|        |                                                                                           |          |            | 1.0.0                                                   | Standstill current (0=1/3231=32/32)                                        |  |  |  |  |
|        |                                                                                           |          | 128        |                                                         |                                                                            |  |  |  |  |
|        |                                                                                           |          |            | Motor run current (0=1/3231=32/32)                      |                                                                            |  |  |  |  |
|        |                                                                                           | 5        |            |                                                         | Hint: Choose sense resistors in a way, that normal                         |  |  |  |  |
|        | +                                                                                         |          |            | <i>IRUN</i> is 16 to 31 for best microstep performance. |                                                                            |  |  |  |  |
| W      | 0x30                                                                                      | 5        | IHOLD_IRUN | 1916                                                    | IHOLDDELAY                                                                 |  |  |  |  |
|        | 0x50                                                                                      | +        | _          |                                                         | Controls the number of clock cycles for motor                              |  |  |  |  |
|        |                                                                                           | 4        |            |                                                         | power down after a motion as soon as TZEROWAIT                             |  |  |  |  |
|        |                                                                                           |          |            |                                                         | has expired. The smooth transition avoids a motor                          |  |  |  |  |
|        |                                                                                           |          |            |                                                         | jerk upon power down.                                                      |  |  |  |  |
|        |                                                                                           |          |            |                                                         |                                                                            |  |  |  |  |
|        |                                                                                           |          |            |                                                         | 0: instant power down<br>115: Delay per current reduction step in multiple |  |  |  |  |
|        |                                                                                           |          |            | of 2^18 clocks                                          |                                                                            |  |  |  |  |
|        |                                                                                           |          |            | This is the                                             | e lower threshold velocity for switching on smart                          |  |  |  |  |
|        |                                                                                           |          | VCOOLTHRS  |                                                         | olStep. (unsigned)                                                         |  |  |  |  |
|        |                                                                                           | 23       |            | Set this pa                                             | arameter to disable coolStep at low speeds, where it                       |  |  |  |  |
|        | 0x31                                                                                      |          |            | cannot wo                                               | rk reliably.                                                               |  |  |  |  |
| W      | W 0x51                                                                                    |          |            |                                                         |                                                                            |  |  |  |  |
|        |                                                                                           |          |            | -                                                       | ACT  ≥ VCOOLTHRS:<br>olStep is enabled, if configured                      |  |  |  |  |
|        |                                                                                           |          |            | 0                                                       | olotep is enabled, in configured                                           |  |  |  |  |
|        |                                                                                           |          |            | (Only bits                                              | 228 are used for value and for comparison)                                 |  |  |  |  |
|        |                                                                                           |          |            |                                                         | ity setting allows velocity dependent switching into                       |  |  |  |  |
|        |                                                                                           |          |            |                                                         | chopper mode and fullstepping to maximize torque.                          |  |  |  |  |
|        |                                                                                           |          |            | (unsigned)                                              |                                                                            |  |  |  |  |
|        |                                                                                           |          |            | VACT  ≥ VI                                              | нтан                                                                       |  |  |  |  |
|        |                                                                                           |          |            |                                                         | olStep is disabled (motor runs with normal current                         |  |  |  |  |
| W      | 0x32                                                                                      | 23       | VHIGH      |                                                         | ale)                                                                       |  |  |  |  |
|        | 0x52                                                                                      |          |            |                                                         | <i>vhighchm</i> is set, the chopper switches to <i>chm</i> =1              |  |  |  |  |
|        |                                                                                           |          |            |                                                         | th <i>TFD</i> =0 (constant off time with slow decay, only).                |  |  |  |  |
|        |                                                                                           |          |            |                                                         | opSync2 is switched off (SYNC=0)                                           |  |  |  |  |
|        |                                                                                           |          |            | - 11                                                    | <i>vhighfs</i> is set, the motor operates in fullstep mode.                |  |  |  |  |
|        |                                                                                           |          |            | (Only bits                                              | 228 are used for value and for comparison)                                 |  |  |  |  |
|        | 0x34                                                                                      | 11       | SW_MODE    |                                                         | de configuration                                                           |  |  |  |  |
| RW     | 0x54                                                                                      | 11       | _          | See separa                                              | ite table!                                                                 |  |  |  |  |
| R+C    | 0x35                                                                                      | 14       | RAMP_STAT  | •                                                       | us and switch event status                                                 |  |  |  |  |
|        | 0x55                                                                                      | <u> </u> |            | See separa                                              |                                                                            |  |  |  |  |
| R      | 0x36                                                                                      | 32       | XLATCH     |                                                         | nerator latch position, latches XACTUAL upon a                             |  |  |  |  |
|        | 0x56                                                                                      |          |            | programm                                                | able switch event (see SW_MODE).                                           |  |  |  |  |

time reference t for velocities: t = 2^24 / f<sub>CLK</sub> time reference ta² for accelerations: ta² = 2^41 / (f<sub>CLK</sub>)²

| 6.2.2.1 | SW_MODE  | - | Reference | Switch | and | stallGuard2 | Event | Configuration |
|---------|----------|---|-----------|--------|-----|-------------|-------|---------------|
|         | Register |   |           |        |     |             |       |               |

| 0x34 | , 0x54: <i>SW_MODE</i> | - REFERENCE SWITCH AND STALLGUARD2 EVENT CONFIGURATION REGISTER                                                                                                                                                                                      |
|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit  | Name                   | Comment                                                                                                                                                                                                                                              |
| 11   | en_softstop            | 0: Hard stop<br>1: Soft stop<br>The soft stop mode always uses the deceleration ramp settings DMAX, V1,                                                                                                                                              |
|      |                        | D1, VSTOP and TZEROWAIT for stopping the motor. A stop occurs when<br>the velocity sign matches the reference switch position (REFL for negative<br>velocities, REFR for positive velocities) and the respective switch stop<br>function is enabled. |
|      |                        | A hard stop also uses <i>TZEROWAIT</i> before the motor becomes released.                                                                                                                                                                            |
|      |                        | Attention: Do not use soft stop in combination with stallGuard2.                                                                                                                                                                                     |
| 10   | sg_stop                | 1: Enable stop by stallGuard2. Disable to release motor after stop event.                                                                                                                                                                            |
|      |                        | Attention: Do not enable during motor spin-up, wait until the motor velocity exceeds a certain value, where stallGuard2 delivers a stable result.                                                                                                    |
| 9    | -                      | Reserved, set to 0                                                                                                                                                                                                                                   |
| 8    | latch_r_inactive       | 1: Activates latching of the position to <i>XLATCH</i> upon an inactive going edge on the right reference switch input REFR. The active level is defined                                                                                             |
| 7    |                        | by pol_stop_r.                                                                                                                                                                                                                                       |
| 7    | latch_r_active         | 1: Activates latching of the position to <i>XLATCH</i> upon an active going edge on the right reference switch input REFR.                                                                                                                           |
|      |                        | <i>Hint:</i> Activate <i>latch_r_active</i> to detect any spurious stop event by reading <i>status_latch_r.</i>                                                                                                                                      |
| 6    | latch_l_inactive       | 1: Activates latching of the position to <i>XLATCH</i> upon an inactive going edge on the left reference switch input REFL. The active level is defined by <i>pol_stop_l</i> .                                                                       |
| 5    | latch_l_active         | 1: Activates latching of the position to <i>XLATCH</i> upon an active going edge<br>on the left reference switch input REFL.                                                                                                                         |
|      |                        | <i>Hint:</i> Activate <i>latch_l_active</i> to detect any spurious stop event by reading <i>status_latch_l.</i>                                                                                                                                      |
| 4    | swap_lr                | 1: Swap the left and the right reference switch input                                                                                                                                                                                                |
| 3    | pol_stop_r             | Sets the active polarity of the right reference switch input<br>0=non-inverted, high active: a high level on REFR stops the motor<br>1=inverted, low active: a low level on REFR stops the motor                                                     |
| 2    | pol_stop_l             | Sets the active polarity of the left reference switch input<br>0=non-inverted, high active: a high level on REFL stops the motor<br>1=inverted, low active: a low level on REFL stops the motor                                                      |
| 1    | stop_r_enable          | 1: Enables automatic motor stop during active right reference switch input                                                                                                                                                                           |
| 0    | stop_l_enable          | Hint: The motor restarts in case the stop switch becomes released.1: Enables automatic motor stop during active left reference switch input                                                                                                          |
|      |                        | <i>Hint:</i> The motor restarts in case the stop switch becomes released.                                                                                                                                                                            |

# 6.2.2.2 RAMP\_STAT – Ramp and Reference Switch Status Register

|     | 1   | RAMP_STAT – R/        |                                                                                                                                             |
|-----|-----|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| R/W | Bit | Name                  | Comment                                                                                                                                     |
| R   | 13  | status_sg             | 1: Signals an active stallGuard2 input from the coolStep driver, if enabled.                                                                |
|     |     |                       | <i>Hint:</i> When polling this flag, stall events may be missed – activate <i>sg_stop</i> to be sure not to miss the stall event.           |
| R+C | 12  | second_move           | 1: Signals that the automatic ramp requires moving back in the                                                                              |
| N°C | 12  | second_move           | opposite direction, e.g. due to on-the-fly parameter change<br>(Flag is cleared upon reading)                                               |
| R   | 11  | t_zerowait_<br>active | 1: Signals, that <i>TZEROWAIT</i> is active after a motor stop. During this time, the motor is in standstill.                               |
| R   | 10  | vzero                 | 1: Signals, that the actual velocity is 0.                                                                                                  |
| R   | 9   | position_             | 1: Signals, that the target position is reached.                                                                                            |
|     |     | reached               | This flag becomes set while XACTUAL and XTARGET match.                                                                                      |
| R   | 8   | velocity_             | 1: Signals, that the target velocity is reached.                                                                                            |
|     |     | reached               | This flag becomes set while VACTUAL and VMAX match.                                                                                         |
| R+C | 7   | event_pos_            | 1: Signals, that the target position has been reached                                                                                       |
|     |     | reached               | (position_reached becoming active).                                                                                                         |
|     |     |                       | (Flag and interrupt condition are cleared upon reading)                                                                                     |
|     |     |                       | This bit is ORed to the <i>interrupt output</i> signal.                                                                                     |
| R+C | 6   | event_stop_           | 1: Signals an active StallGuard2 stop event.                                                                                                |
|     |     | sg                    | Reading the register will clear the stall condition and the motor may                                                                       |
|     |     |                       | re-start motion, unless the motion controller has been stopped.                                                                             |
|     |     |                       | (Flag and interrupt condition are cleared upon reading)                                                                                     |
| _   | _   |                       | This bit is ORed to the <i>interrupt output</i> signal.                                                                                     |
| R   | 5   | event_stop_r          | 1: Signals an active stop right condition due to stop switch.                                                                               |
|     |     |                       | The stop condition and the interrupt condition can be removed by                                                                            |
|     |     |                       | setting RAMP_MODE to hold mode or by commanding a move to the                                                                               |
|     |     |                       | opposite direction. In <i>soft_stop</i> mode, the condition will remain active until the motor has stopped motion into the direction of the |
|     |     |                       | stop switch. Disabling the stop switch or the stop function also                                                                            |
|     |     |                       | clears the flag, but the motor will continue motion.                                                                                        |
|     |     |                       | This bit is ORed to the <i>interrupt output</i> signal.                                                                                     |
|     | 4   | event_stop_l          | 1: Signals an active stop left condition due to stop switch.                                                                                |
|     | •   | event_stop_t          | The stop condition and the interrupt condition can be removed by                                                                            |
|     |     |                       | setting RAMP_MODE to hold mode or by commanding a move to the                                                                               |
|     |     |                       | opposite direction. In <i>soft stop</i> mode, the condition will remain                                                                     |
|     |     |                       | active until the motor has stopped motion into the direction of the                                                                         |
|     |     |                       | stop switch. Disabling the stop switch or the stop function also                                                                            |
|     |     |                       | clears the flag, but the motor will continue motion.                                                                                        |
|     |     |                       | This bit is ORed to the <i>interrupt output</i> signal.                                                                                     |
| R+C | 3   | status_latch_r        | 1: Latch right ready                                                                                                                        |
|     |     |                       | (enable position latching using SWITCH_MODE settings                                                                                        |
|     |     |                       | latch_r_active or latch_r_inactive)                                                                                                         |
|     |     |                       | (Flag is cleared upon reading)                                                                                                              |
|     | 2   | status_latch_l        | 1: Latch left ready                                                                                                                         |
|     |     |                       | (enable position latching using SWITCH_MODE settings                                                                                        |
|     |     |                       | latch_l_active or latch_l_inactive)                                                                                                         |
|     |     |                       | (Flag is cleared upon reading)                                                                                                              |
| R   | 1   | status_stop_r         | Reference switch right status (1=active)                                                                                                    |
|     | 0   | status_stop_l         | Reference switch left status (1=active)                                                                                                     |