# TMC457 – DATA SHEET



S-profile motion controller with PID feedback control and high resolution micro stepping sequencer for stepper motors and piezo motors

TRINAMIC<sup>®</sup> Motion Control GmbH & Co. KG Sternstraße 67 D – 20357 Hamburg GERMANY www.trinamic.com



# 1 Features

The TMC457 is a high end single axis micro stepping motion controller. It adds to any microcontroller or processor with SPI<sup>™</sup> (SPI is Trademark of Motorola) interface. It is intended for applications, where a precise and fast, jerk-free motion profile is desired. An encoder can be added for extremely quick and precise positioning using the internal hardware PID regulator and provides for increased reliability / fault detection. The high-resolution micro step sequencer directly controls stepper motors and piezo motors. Wide range motion control parameters eliminate any "gear switching". The TMC457 supports linear velocity ramps and S-shaped velocity ramps. For maximum flexibility all motion control parameters (target position, target velocity, acceleration, deceleration and bow) can be changed any time during motion.

#### Highlights

- S-shaped and linear ramps with on-the-fly alteration of all parameters
- Programmable high resolution sequencer with (12 bit, 8192 entry) micro step look-up table
- · Incremental encoder interface with flexible up- and down scaling to match drive resolution
- Fast and stable easyPID<sup>™</sup> PID controller
- 32 bit registers from mHz to MHz / from nanometer to meter
- SPI interface to microcontroller
- Reference switch processing / virtual stop switches (programmable soft limits)
- Step / direction output (with programmable timing)
- Position pulse output to trigger external events
- · Synchronization of multiple axis via scalable step / direction input
- Direct interface for TMC246/TMC249 family stepper motor drivers supports StallGuard<sup>™</sup> (pat.)
- ChopSync<sup>™</sup> (pat. fil.) built in for best motor velocity range
- Analog high resolution motor driver control via external dual 12 bit DAC
- · Automatic load angle limitation using encoder for stepless servo behaviour

### **Types of Motors**

- Two phase stepper motors (direct sequencer support)
- PiezoMotors (direct sequencer support for PiezoMotor's PiezoLEGS<sup>®</sup> motor)
- Any type of motor via step/direction interface

#### Applications

- · Medical and laboratory equipment with high speed motion e.g. for liquid handling
- · High end placement and positioning systems / High reliability drives
- Sub-micrometer positioning (piezo motors)
- · Active stabilization with incremental encoder and fast PID regulator

#### Life support policy

TRINAMIC Motion Control GmbH & Co. KG does not authorize or warrant any of its products for use in life support systems, without the specific written consent of TRINAMIC Motion Control GmbH & Co. KG.

Life support systems are equipment intended to support or sustain life, and whose failure to perform, when properly used in accordance with instructions provided, can be reasonably expected to result in personal injury or death.

#### © TRINAMIC Motion Control GmbH & Co. KG 2008

Information given in this data sheet is believed to be accurate and reliable. However no responsibility is assumed for the consequences of its use nor for any infringement of patents or other rights of third parties which may result from its use.

Specification is subject to change without notice.

# 2 Contents

| 1 FEATURES                                                                              | 1                                  |  |  |  |
|-----------------------------------------------------------------------------------------|------------------------------------|--|--|--|
| 2 CONTENTS                                                                              |                                    |  |  |  |
| 2.1 Figures                                                                             |                                    |  |  |  |
|                                                                                         |                                    |  |  |  |
| 3 GENERAL DESCRIPTION                                                                   |                                    |  |  |  |
| 4 TMC457 BLOCK DIAGRAM AND INTERFACES.                                                  |                                    |  |  |  |
| 4.1 Microcontroller Interface (SPI <sup>™</sup> )                                       |                                    |  |  |  |
| 4.2 Step Direction inputs<br>4.3 DAC (LTC2602) Interface                                | б<br>б                             |  |  |  |
| 4.3.1 Piezo Motor Driver                                                                |                                    |  |  |  |
| 4.4 Stepper Motor Driver Interface (TMC236, TMC                                         | 239, TMC246, TMC249)               |  |  |  |
| 4.4.2 Stepper Motor Driver (Ingritesolution micro                                       | o stepping)                        |  |  |  |
| 5 FUNCTIONAL BLOCKS AND REGISTERS                                                       |                                    |  |  |  |
| 5.1 Ramp Generator                                                                      |                                    |  |  |  |
| 5.2 ABN Incremental Encoder Interface                                                   |                                    |  |  |  |
| 5.2.1 Setting the encoder to match the motor re                                         | solution:9<br>a                    |  |  |  |
| 5.3.1 Initialization of vector control mode                                             |                                    |  |  |  |
| 5.4 PID Controller - easyPID <sup>™</sup>                                               |                                    |  |  |  |
| 5.6 Step Direction Output Interface for multi axis inte                                 | erpolation11                       |  |  |  |
| 5.7 Reference Switch and Stop Switch Interface                                          |                                    |  |  |  |
| 5.8 Micro Step Sequencer<br>5.8.1 ChopSync <sup>™</sup> CHOPCLK                         |                                    |  |  |  |
| 5.9 Type and Version Register / Version specific n                                      | otes and known bugs12              |  |  |  |
| 5.10 Interrupt Controller                                                               |                                    |  |  |  |
| 5.11.1 Calculation of the Sine Wave Look-Up-Ta                                          | ble to drive a Piezo Motor         |  |  |  |
| 5.11.2 Calculation of the Sine Wave Look-Up-Ta                                          | ble to drive a Stepper Motor13     |  |  |  |
| 6 REGISTER MAPPING                                                                      |                                    |  |  |  |
| 6.1 SPI Datagram Structure                                                              |                                    |  |  |  |
| 6.1.1 Selection of Write / Read (WRITE_notRE                                            | AD)14<br>15                        |  |  |  |
| 6.2 Register Block Structure – Register Mapping                                         |                                    |  |  |  |
| 6.2.1 Nomenclature of Read / Write / Clear on I                                         | Read / Clear on Write of Registers |  |  |  |
| 6.2.2 Time Scaling by Clock Frequency<br>6.2.3 Real World Units vs. Units of the TMC457 |                                    |  |  |  |
| 7 EXAMPLES                                                                              |                                    |  |  |  |
| 7.1 How to Get a Motor Running                                                          |                                    |  |  |  |
| 7.2 Set Incremental Encoder Interface Parameters                                        | 27<br>27                           |  |  |  |
| 8 NOTATION OF NUMBER SYSTEMS                                                            |                                    |  |  |  |
| 9 PINNING, PACKAGE, AND ELECTRICAL DATA                                                 | OF THE TMC457                      |  |  |  |
| 9.1 Pinning of TMC457                                                                   |                                    |  |  |  |
| 9.1.1 Pull-Up / Pull-Down Resistances                                                   |                                    |  |  |  |
| 9.1.2 Blocking Capacitors                                                               |                                    |  |  |  |
| 5.2 I aonayo Outimes and Dimensions                                                     |                                    |  |  |  |

|    | 9.2.1 | Fine Pitch BGA Package with 144 Balls (FBGA144) of TMC457-BC | . 33 |
|----|-------|--------------------------------------------------------------|------|
| 10 | MIC   | RO CONTROLLER INTERFACE (SPI)                                | . 34 |
| 11 | СНА   | RACTERISTICS                                                 | . 35 |
| 12 | LITE  | RATURE                                                       | . 36 |
| 13 | REV   | ISION HISTORY                                                | . 36 |

# 2.1 Figures

| Figure 1 : Functional Block Diagram of the TMC457                     | 5    |
|-----------------------------------------------------------------------|------|
| Figure 2 : TMC457 with Piezo Motor Interface                          | 6    |
| Figure 3 : High Resolution Micro Stepping Configuration               | 7    |
| Figure 4 : Stepper Motor Driver Configuration (SPI)                   | 7    |
| Figure 5 : Outline of ABN Signals of an Incremental Encoder           | 8    |
| Figure 6 : Incremental Encoder Signals Outline (AB w/o clear pulse N) | . 28 |
| Figure 7 : Package Outline Drawing FBGA144 – (JEDEC MO-192 VAR DAD-1) | . 33 |
| Figure 8 : Timing Diagram of the Serial Micro Controller Interface    | . 34 |
| Figure 9 - General IO Timing Parameters                               | . 35 |
|                                                                       |      |

# 2.2 Tables

| Table 1 : PWM frequency calculation for ChopSync <sup>™</sup>                             | 12 |
|-------------------------------------------------------------------------------------------|----|
| Table 2: TMC457-BC Pin Out                                                                | 32 |
| Table 3 : Dimensions of FBGA144 (Note: BSC = Basis Spacing Between Centers)               | 33 |
| Table 4: Timing Characteristics of the Micro Controller Serial Peripheral Interface (SPI) | 34 |
| Table 5 - Absolute Maximum Ratings                                                        | 35 |
| Table 6 – DC Ccharacteristics Operating Conditions                                        | 35 |
| Table 7 - Power Dissipation                                                               | 35 |
| Table 8 - General IO Timing Parameters                                                    | 35 |

# 3 General Description

The TMC457 has been designed with TRINAMIC's background of more than 10 years of dedicated motion control ICs for stepper motors, like the 6 axis controller TMC406, the low cost 3 axis controller TMC428 and the high end controller TMC453 with its compatible successor TMC454. While there lie 10 years of development and experience between the TMC453 and the TMC457, the basic features look similar, but a lot of ideas, application know-how and customer feedback have been evaluated, sorted and flown into the design. The intention in creating the TMC457 was to provide a motion controller that provides superior performance, which can hardly be achieved by software in a processor system, while providing a very easy-to-use interface to the programmer, which looks similar to the peripherals found in a microcontroller. The electronic gear shift / pre-scaling found in our other motion controllers was eliminated by extending position and velocity registers to 32 bits. This direct control makes it easy to use the full range and precision of parameter setting. The easyPID<sup>™</sup> closed loop PID regulator eases the achievement of control loop stability by providing a programmable hysteresis. Some features found in the TMC453 and TMC428 have been streamlined, to make them easier to use and some options have been removed, like the programmable sequencer for many different motor types, bearing in mind the most common applications.



Figure 1 : Functional Block Diagram of the TMC457

# 4 TMC457 Block Diagram and Interfaces

Figure 1 shows the block diagram of the TMC457 motion controller. The TMC457 is equipped with a SPI interface for communication with the microcontroller. It uses a fixed data length of 40 bit – 8 bit address and 32 data. The TMC457 has a driver SPI to directly control the TRINAMIC stepper motor drivers TMC236, TMC239, TMC246, and TMC249. It supports processing of StallGuard information to emulate a reference switch, when using TMC246 or TMC249. The TMC457 has step direction input and step direction outputs as well to allow the control of step direction power stages (like the TMC332) or for external monitoring of motion by step pulse counting. For high precision micro stepping the TMC457 is equipped with a DAC interface for LTC2602. This allows control of the TMC236 family with extended microstep resolution or control of external power drivers with the classical analog control. An incremental encoder interface is added for processing incremental encoders with digital quadrature signal outputs (ABN). The position available from the quadrature signal decoder is directly available as an input for the PID position regulator. The PID regulator is for position stabilization also during motion. The PID regulator runs at an update rate of 100kHz and thus provides fastest response times.

# 4.1 Microcontroller Interface (SPI<sup>™</sup>)

The SPI for communication with the microcontroller to set motion control parameters (velocity, acceleration, bow, ...) of the TMC457 and to send motion command for positioning (set target position) and continuous motion applications (set velocity).

#### 4.2 Step Direction Inputs

In addition to the SPI for micro controller communication with the TMC457, the motion can be controlled externally via the step direction inputs STEP\_IN and DIR\_IN.

# 4.3 DAC (LTC2602) Interface

The DAC interface directly controls LTC2602 from Linear Technologies to generate analog output signals (two channels for micro stepping of bipolar two phase stepper motors) and four channels as required for PiezoLEGS motors from the company Piezo-Motors.

#### 4.3.1 Piezo Motor Driver

The power four required power stages of the driver for the piezoelectric motor (PiezoLEGS) must be able to drive a 100nF capacitance at 3kHz with an amplitude of 48V each. A power stage with these capabilities is realized for the TMC457 evaluation board.



Figure 2 : TMC457 with Piezo Motor Interface

#### 4.4 Stepper Motor Driver Interface (TMC236, TMC239, TMC246, TMC249)

The direct TRINAMIC driver interface of the TMC457 allows the TRINAMIC drivers to be controlled by the TMC457.

#### 4.4.1 Stepper Motor Driver (high resolution micro stepping)

For high resolution micro stepping the TMC457 has an interface for dual SPI DAC LTC2602.



Figure 3 : High Resolution Micro Stepping Configuration

#### 4.4.2 Stepper Motor Driver (low resolution micro stepping)

For low resolution micro stepping, a TRINAMIC driver can be connected directly via SPI without an additional DAC. With this, one can drive with 16 times micro stepping.



Figure 4 : Stepper Motor Driver Configuration (SPI)

# 5 Functional Blocks and Registers

#### 5.1 Ramp Generator

The ramp generator is the heart of the motion controller. It runs either ramp with linear velocity profile or ramp with s-shape velocity profile. The selection is done by the bow parameter. Setting bow to 0 selects linear velocity profile. Linear ramps perform the quickest motion, by using the maximum available acceleration at all times. But, since the acceleration becomes switched on and off abruptly, system resonances can occur. They appear like an additional load on the motor, thus reducing the available useful portion of motor torque. Further, system resonances need some time to fade away, and this can costs valuable system time, if a complete stand still is required, before other actions can start. With the S-shaped ramp, resonances can be reduced. However, it is advised to choose the bow parameter as high as possible, in order to optimize positioning time.

The ramp generator provides four modes of operation: [...]

It should be noted, that the choice of the microstep resolution directly influences the complete ramp generator parameter settings, because a higher microstep resolution means a higher end velocity setting, and thus a higher acceleration and a higher bow parameter to yield the same results. This way, the settings are scaled in a huge range, e.g. when changing between fullstep and highest resolution microstep.

#### Attention:

At all times, all parameters may be changed, but it should be noted, that unexpected results may occur, when changing the bow parameter to a lower value during an acceleration phase, or when changing the acceleration or deceleration parameter to a lower value. In these cases, the maximum positioning velocity, respectively the target position could be exceeded, in case the new values do not allow decelerating quickly enough. Even an overrun of the register value could occur and lead to unexpected results. Under normal circumstances, the bow parameter will be fixed in an application.



Figure 5 : Outline of ABN Signals of an Incremental Encoder

#### 5.2 ABN Incremental Encoder Interface

The TMC457 is equipped with an incremental encoder interface for ABN encoders that gives positions via digital incremental quadrature signals (usually named A and B) and a clear signal (usually named N for null of Z for zero). The N signal can be used to clear a position. It might be necessary to disable the clearing of the encoder position after the first N signal event because the encoder gives this signal once for each revolution and for most applications a motor turns more than one revolution.

The encoder constant named *enc\_const* is added or subtracted on each position change of the quadrature signals AB of the incremental encoder. The encoder constant *enc\_const* represents an unsigned fixed point number (16.16) to facilitate the generic adaption between motors and encoders. In

decimal mode, the lower 16 bit represent a number between 0 and 9999. This is especially important for piezo motors (PiezoLEGS) because they do not have a fixed step length they achieve their very high positioning precision in the range of nanometers via closed loop control together with a position encoder. For stepper motors equipped with incremental encoders the fixed number representation allows very comfortable parameterization. Additionally, gear can easily be taken into account.

The encoder counter named  $x\_enc$  holds the current determined encoder position. Different modes concerning handling of the signals A, B, and N take active low and active high signals of usual incremental encoders into account. For details please refer to the register mapping section 6 Register Mapping, page 14 ff.

The register *enc\_status* holds the status concerning event of the ABN signals. The register *enc\_latch* stores the actual encoder position on an N signal event. The register  $x_latch$  stores the position while a reference switch event occurs.

A register named *enc\_warn\_dist* (encoder warning distance) is used to generate an interrupt via the TMC457 interrupt controller if the distance between encoder position and actual position is larger then *enc\_warn\_dist*. The calculated error *pid\_e* is available from the PID controller unit. Therefore, the PID controller needs to be enabled.

#### 5.2.1 Setting the encoder to match the motor resolution:

Encoder example settings for motor parameters: 2048  $\mu$ steps, 200FS  $\rightarrow$  409600 / U Factor = FS\* $\mu$ S / EncPOS

| Encoder example settings for a 200 fullstep motor with 2048 microsteps |                         |                                  |  |  |  |
|------------------------------------------------------------------------|-------------------------|----------------------------------|--|--|--|
| Encoder resolution                                                     | required encoder factor | comment                          |  |  |  |
| 200                                                                    | 2048                    |                                  |  |  |  |
| 360                                                                    | 1137,7778               | No exact match possible!         |  |  |  |
|                                                                        | = 74565404,4444 / 2^16  |                                  |  |  |  |
|                                                                        | = 11377777,7778 / 10000 |                                  |  |  |  |
| 500                                                                    | 819,2                   |                                  |  |  |  |
|                                                                        | = 53687091,2 / 2^16     |                                  |  |  |  |
|                                                                        | = 8192000 / 10000       | exact match with decimal setting |  |  |  |
| 1000                                                                   | 409,6                   | exact match with decimal setting |  |  |  |
| 1024                                                                   | 400                     |                                  |  |  |  |
| 3600                                                                   | 113,7778                | No exact match possible!         |  |  |  |
| 4000                                                                   | 102,4                   | exact match with decimal setting |  |  |  |
| 4096                                                                   | 100                     |                                  |  |  |  |
| 8192                                                                   | 50                      |                                  |  |  |  |
| 16384                                                                  | 25                      |                                  |  |  |  |
| 32768                                                                  | 12.5                    |                                  |  |  |  |

#### 5.3 Vector control

The vector control unit allows a load angle based motor control. This makes the motor behave like a servo motor, i.e. it can be overloaded or stopped, and will later on catch up again, using the PID regulator. Therefore, be careful to also activate the PID regulator!

Vector control is only possible using binary encoder resolutions, because no decimal setting is available.

| Vector control example settings for a 200 fullstep motor |                                |               |  |  |
|----------------------------------------------------------|--------------------------------|---------------|--|--|
| Encoder resolution                                       | required vector encoder factor | venc_us_const |  |  |
| 512                                                      | 25                             | 1600          |  |  |
| 1024                                                     | 12.5                           | 800           |  |  |
| 2048                                                     | 6.25                           | 400           |  |  |
| 4096                                                     | 3.125 = 3 1/8                  | 200           |  |  |
| 8192                                                     | 1.5625 = 1 9/16                | 100           |  |  |
| 16384                                                    | 0.78125 = 25/32                | 50            |  |  |
| 32768                                                    | 0.390625 = 25/64               | 25            |  |  |

A 400 fullstep motor needs the double setting

Different load angle limits above 90° allow for field weakening operation, which gives a faster motor operation.

#### 5.3.1 Initialization of vector control mode

A precise initialization of the vector control mode is critical for best functionality. Also, the encoder needs to have an absolute precision, which is at least  $\frac{1}{2}$  fullstep of the motor.

For a newly assembled drive, an initial initialization is necessary. This initialization requires that the motor does not see any mechanical load during initialization. Later on, the vector control can be initialized with a stored offset from the initial initialization, using absolute position information, for example based on the encoder N channel.

For initial initialization, the following procedure can be followed:

The actual encoder position *venc\_us\_pos* needs to be initialized for vector control. The position must match selected *microstep\_adr* bits, when the motor is unloaded in its exact position. This for example can be accomplished, by switching the motor to a high standby torque after power on. Directly after a power on, all *microstep\_adr* bits are zero. Now, the motor will be in the exact zero position, as long as it sees no mechanical load. Therefore, now the *venc\_us\_pos* can be initialized with zero, in order to match the encoder angle to the electrical angle of the motor.

When the absolute position of the encoder is known, the vector control register *venc\_us\_pos* can be initialized based on this information. Therefore, the encoder needs to be read out, or the N channel needs to be found, and afterwards the stored offset can be added to the absolute position and be written to *venc\_us\_pos*. Be sure to do this in a high priority procedure, because the encoder should not advance a step in the meantime. If this can not be guaranteed, a check and iteration should be done.

# 5.4 PID Controller - easyPID<sup>™</sup>

The PID (Proportional Integral Differential) controller calculates a velocity v based on a position difference error pid\_e = enc\_x – x\_actual where enc\_x is the actual position- the real mechanical position -determined by the incremental encoder interface and x\_actual is the actual position of the micro step sequencer –the position the TMC457 assumes to be the actual one. With this, the TMC457 moves with this (signed) velocity v until the actual position- measured by the incremental encoder – match. The velocity v to minimize the error *e* is calculated by

$$v = P \cdot e(t) + \int_{0}^{t} I \cdot e(t) \cdot dt + D \cdot \frac{d}{dt} e(t).$$

The motor moves with this velocity  $v = pid_v_actual until the error e(t) vanishes resp. falls below a programmed limit – the hysteresis pid_tolerance. Primary, the PID regulator is parameterized by its basic parameter P, I, D represented by registers pid_p, pid_i, pid_d. Setting pid_d = 0 makes a PI regulator, additionally setting pid_i = 0 makes a P regulator. For micro controller interaction, the parameter pid_dv_cpu is added to the pid_v_actual. The readable register pid_dv_clip holds the actual value of clipping done by the PID controller of the TMC457.$ 

Due to constraints of practical real word application, the integer part of the PID regulator can be clipped to a limit named pid\_iclip. Without this, the integral part of the PID regulator pid\_isum increases with each time step by pid\_i\*pid\_e as long as the motor does not follow. The actual error can be read out from register pid\_e. The integration over time of the error e is done with a fixed clock frequency of fPID\_INTEGRAL[Hz] = fCLK[Hz] / 128. The time scaling for the deviation with respect to time of the error is controlled by the register named pid\_clk\_div.

A stabilization of the target position by programmable hysteresis is integrated to avoid oscillations of regulation when the actual position is close to the real mechanical position. The PID controller of the TMC457 is fast – programmable up to approximate 100kHz update rate at fCLK = 16 MHz of the TMC457 – so that it can be used during motion to stabilized the motion. The parameterization of the PID controller of the TMC457 occurs in a direct way. Due to this, it is named easyPID<sup>™</sup>. Nevertheless, the parameterization of a PID controller might need a detailed knowledge of the application and the dynamic of the mechanics that is controlled by the PID controller. Additionally, a special control register allows software interaction for additional feedback control algorithms that can be implemented within the micro controller used to parameterize the TMC457.

# 5.5 Step Direction Output Interface

The TMC457 is equipped with step direction outputs (STEP, OUT). In Addition, it is equipped with a so called X\_STEP output. A pulse on this output represents a number of (micro) steps. It is configured by the register named pulse\_xstep\_div. The TMC457 is able to generate step pulses with up to its clock frequency fCLK[Hz]. Because a step frequency in the range of the clock frequency of the TMC457 might be too high for usual step direction drivers, an additional step output named X\_STEP (extended step) is available. The X\_STEP represents a number of steps to be done at a lower frequency. The threshold that selects between step pulses and extended step pulses is programmable. This can be parameterized to give full steps on the XSTEP output of the TMC457.

# 5.6 Step Direction Input Interface for multi axis interpolation

The TMC457 is equipped with step direction inputs (STEP\_IN, DIR\_IN). This allows using the TMC457 with an external ramp generator. A number of TMC457 can be synchronized by interconnecting the step direction inputs and outputs via a switch matrix. One TMC457 is used as master and its step and direction output is fed to the other TMC457. They can be programmed to follow the master pulses scaled by the 15 bit factor sd\_scale (and sign). This way, multi-axis interpolation can be realized. The slave motion thus always is equal or slower than the master. When programming the master axis, the maximum allowed acceleration and velocity values of the slave axis have to be considered.

The step input is sampled once per system clock. Thus, the maximum input frequency is equal to the half system clock frequency. Please remark, that this also limits the master velocity during interpolated moves.

# 5.7 Reference Switch and Stop Switch Interface

The TMC457 is equipped with reference switch that can be programmed for automatic actions. For details please refer to the register mapping section 6 Register Mapping, page 14 ff. The reference switch inputs are available to store a position on a reference switch event. Additionally, these inputs can be enabled to force a stop.

# 5.8 Micro Step Sequencer

The micro step sequencer can be programmed for different micro step resolutions. The sequencer controls the mixed decay feature of TRINAMIC stepper motor drivers. Current scaling is also done under control of the sequencer. When using TMC246 or TMC249 the StallGuard<sup>™</sup> threshold is under control of the sequencer. A readable register holds the TRINAMIC stepper motor driver status bits and diagnosis bits.

# 5.8.1 ChopSync<sup>™</sup> CHOPCLK

To use the ChopSync<sup>™</sup> feature together with a TRINAMIC stepper motor driver the output CHOPCLK of the TMC457 has to be connected to the PWM oscillator input OSC of the TRINAMIC stepper motor driver (TMC236, TMC239, TMC246, or TMC249) – without a capacitor at the OSC input. The recommended chopper frequency fOSC for the TRINAMIC stepper motor driver is 36kHz. The chopper frequency should not be below 25kHz and must be lower than 50kHz. The chopper frequency is programmed via the register chop\_clk\_div.

**Warning:** A chopper clock signal with a too high frequency might damage the stepper motor driver due to dynamic power dissipation overload.

| fCLK[Hz]   | fOSC[Hz] | chop_clk_div        |        |
|------------|----------|---------------------|--------|
| 16.000.000 | 36.000   | 0x1BC               | (=444) |
|            | 25.000   | 0x280               | (=640) |
| 8 000 000  | 36.000   | 0x0DE               | (=222) |
| 8.000.000  | 25.000   | 0x140               | (=320) |
| fCLK[Hz]   | fOSC[Hz] | fCLK[Hz] / fOSC[Hz] |        |

Table 1 : PWM frequency calculation for ChopSync<sup>™</sup>

### 5.9 Type and Version Register / Version specific notes and known bugs

The type of the controller and its version can be read out from a register. For the TMC457 version 1.02 one gets 0x00457102 reading the type and version register. This allows hardware detection. Reading the version allows handling of different version by a single software version.

| Version | Bug                                                                                                          | Description and workaround                                                                                                                                                      |
|---------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.02    | AMAX lower limit with linear ramps                                                                           | When using linear ramps, setting AMAX to a value lower than 128 results in a strange positioning behavior, when AMAX and DMAX differ.                                           |
|         |                                                                                                              | This is due to an internal rounding which results in AMAX being used for deceleration rather than DMAX or vice versa.                                                           |
|         |                                                                                                              | This bug will be corrected in future versions.                                                                                                                                  |
|         |                                                                                                              | Workaround:                                                                                                                                                                     |
|         |                                                                                                              | Use AMAX values above 128, when AMAX and DMAX are required to be different. AMAX values below 128 are typically only required, when working with low microstepping resolutions. |
|         |                                                                                                              | Alternative: Use S-shaped ramps.                                                                                                                                                |
| -1.03   | Stop switches do not<br>become disabled at<br>move in opposite<br>direction while actual<br>velocity is zero | When the motor becomes stopped by a stop switch, a movement into the opposite direction is not possible without disabling the stop switch.                                      |
|         |                                                                                                              | The reason is that the stop switches are active in any direction when velocity is zero.                                                                                         |
|         |                                                                                                              | This bug will be corrected in future versions.                                                                                                                                  |
|         |                                                                                                              | Workaround:                                                                                                                                                                     |
|         |                                                                                                              | Disable stop switch when moving into opposite direction.                                                                                                                        |

# 5.10 Interrupt Controller

The interrupt controller is programmable for different conditions. If an interrupt condition occurs the nINT is pulled to low (activated) if the interrupt mask for the corresponding interrupt condition is enabled.

#### 5.11 Sine Wave Look-up Table (SIN-LUT) Access and Parameterization

The TMC457 is equipped with an internal RAM (8192 addresses x 12 bit data) to hold a sine wave look-up table for micro stepping. This look-up table has to be initialized first after power up of the TMC457. Depending on the type of motor, a dedicated sine wave table has to be written into the internal RAM of the TMC457. For both, 8192 values of 12 bit integer have to be calculated. The sine LUT RAM is accesses via two register addresses, one for read and one for write.

**Important Hint:** When reading data from RAM, the read data are valid with the next read access. So, the read data are pipelined with a delay of one SPI datagram.

#### 5.11.1 Calculation of the Sine Wave Look-Up-Table to drive a Piezo Motor

 $y(x) = 4096 + 4095 * \sin(2\pi * x/8192 - 2*\pi/8)$  with x = 0, 1, 2, 3, ..., 8189, 8190, 8191.

#### 5.11.2 Calculation of the Sine Wave Look-Up-Table to drive a Stepper Motor

 $y(x) = abs(4095 * sin(2\pi * x/8192))$  with x = 0, 1, 2, 3, ..., 8189, 8190, 8191.

With offset, to adjust current zero crossing, the formula becomes

 $y(x) = offset + abs((4095 - offset) * sin(2\pi * x/8192))$  with x = 0, 1, 2, 3, ..., 8189, 8190, 8191.

The offset has a theoretical range of 0 to 4094. For a practical application, the offset will lie between 0 and 100. When using current scaling, the offset also becomes scaled down – this may be needed to be taken into account!

# 6 Register Mapping

### 6.1 SPI Datagram Structure

The TMC457 uses 40 Bit SPI<sup>™</sup> (Serial Peripheral Interface, SPI is Trademark of Motorola) datagrams for communication with a micro controller. Micro controllers which are equipped with hardware SPI are typically able to communicate with integer multiples of 8 bit.

Each datagram of the TMC457 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 TMC457. To have a unified kind of communication, each register is accessed via 32 data bits even if it used less then 32 data bits.

For simplification, each register is specified by a one byte address, where the reading address is given with the most significant bit = '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.

| TMC457 40 Bit SPI Datagram Structure                                                                                |                                                                                                                             |                                    |                                           |                 |  |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------------|-----------------|--|
| MSB (transmitted first) LSB (transmitted last)                                                                      |                                                                                                                             |                                    |                                           |                 |  |
| 39                                                                                                                  |                                                                                                                             |                                    |                                           | 0               |  |
| 8 bit ADDRESS                                                                                                       |                                                                                                                             | 32 bit                             | DATA                                      |                 |  |
| 39 32                                                                                                               |                                                                                                                             | 31                                 | 0                                         |                 |  |
| 8 bit ADDRESS                                                                                                       | 8 bit DATA                                                                                                                  | 8 bit DATA                         | 8 bit DATA                                | 8 bit DATA      |  |
| 39 32                                                                                                               | 31 24                                                                                                                       | 23 16                              | 15 8                                      | 7 0             |  |
| 1 + 7 bit ADDRESS 8 bit DATA 8 bit DATA 8 bit DATA                                                                  |                                                                                                                             |                                    | 8 bit DATA                                | 8 bit DATA      |  |
| 39 / 38 32                                                                                                          | 39 / 38 32 31 24 23 16 15 8 7                                                                                               |                                    |                                           |                 |  |
| ADDRESS 8 bit DATA 8 bit DATA 8 bit DATA                                                                            |                                                                                                                             |                                    | 8 bit DATA                                |                 |  |
| <sup>3</sup> 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 | 2 2 2 2 1 1 1 1<br>3 2 1 0 9 8 7 6 | 1 1 1 1 1 1 1 <u>1</u><br>5 4 3 2 1 0 9 8 | 7 6 5 4 3 2 1 0 |  |

#### 6.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.

Example: For a read access from the register (x\_actual) with the address 0x01, the address byte has to be set to 0x01. For a write access to the register (x\_actual) with the address 0x10, the address byte has to be set to 0x80 + 0x01 = 0x81. For read access, the data bit might have any value ('-'). So, one can set them to '0'.

| READ x_actual                 | datagram ⇔ 0x0100000000; |
|-------------------------------|--------------------------|
| WRITE x_actual := 0x89ABCDEF; | datagram ⇔ 0x8189ABCDEF; |

| TMC457 SPI Datagram Structure      |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|--|--|
| MSB (transmited first              | (transmited first) 40 bit LSB (transmitted last)                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
| 39                                 |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   | 0 |  |  |
| 8 bit ADDRESS 32 bit DATA          |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
| 39 32                              |                                                                                                                                     | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |   |  |  |
| 1 + 7 bit ADDRESS                  | RESS 8 bit DATA 8 bit DATA 8 bit DATA 8 bit DATA                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
| 39 / 38 32                         | 31 24 23 16 15 8 7 0                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
| 3832                               | 3128 2724 2320 1916 1512 118 74 3                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |  |  |
| 3 3 3 3 3 3 3 3<br>9 8 7 6 5 4 3 2 | 3       3       2       2       2       2       2       2       2         1       0       9       8       7       6       5       4 | 3         2         2         2         2         2         2         2         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 |   |   |  |  |

### 6.1.2 Data Alignment

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

# 6.2 Register Block Structure – Register Mapping

All parameterizations take place by register writes. The access to the registers is via SPI. The ramp generator register set enfolds basic motion control parameters, a ramp generator register set, an incremental encoder register set, a PID controller register set – named easyPID<sup>™</sup>, a step direction output configuration register set, a reference switch configuration register set, a micro step sequencer configuration register, a type & version register, an interrupt configuration register, and a sine wave look-up table (LUT) RAM port register.

#### 6.2.1 Nomenclature of Read / Write / Clear on Read / Clear on Write of Registers

Units are written in are given in brackets, e.g. [micro steps]. Read only registers are designated by R. Read only registers with automatic clear (C) on read are designated by R+C. Registers that are cleared on write are designated by W+C. Write only registers are designated by W.

# 6.2.2 Time Scaling by Clock Frequency

Time is scaled by the the clock frequency of the TMC457. This scales velocity, acceleration, and bow. So, velocity is given in unit [micro steps per time] and not as [micro steps per second], acceleration is given in unit [micro steps per time^2] and not unit [micro steps per second^2]. Formulas for the conversion into units based on time in seconds is given in section 0, page 26.

| Ramp | Ramp Generator Register Set – Basic Motion Control Parameters |      |                 |                                                                                                                                                                                                                                                                   |                                                               |
|------|---------------------------------------------------------------|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| R/W  | Addr                                                          | Bits | Register        | Description                                                                                                                                                                                                                                                       | Range [Unit]                                                  |
| RW   | 0x00                                                          | 90   | mode            | bit 1,0: ramp_mode<br>00 = positioning mode<br>01 = reserved<br>10 = velocity mode<br>11 = hold mode<br>bit 2: step_dir_enable<br>bit 4: shaft<br>bit 8: PID_on<br>bit 9: PID_base v_actual                                                                       | default =<br>%0000000010                                      |
| RW   | 0x01                                                          | 310  | x_actual        | Actual position                                                                                                                                                                                                                                                   | ± [µsteps]                                                    |
| R    | 0x02                                                          | 310  | v_actual        | Actual velocity                                                                                                                                                                                                                                                   | ± [µsteps / t]                                                |
| W    | 0x03                                                          | 300  | v_max           | Maximum velocity for positioning mode                                                                                                                                                                                                                             | 0 to \$7FFF0000<br>for any a_max<br>[µsteps / t]              |
| w    | 0x04                                                          | 310  | v_target        | Target velocity<br>The sign determines the direction in velocity<br>mode and hold mode.                                                                                                                                                                           | ± \$7FFF0000 for<br>any a_max<br>[µsteps / t]                 |
| W    | 0x05                                                          | 230  | a_max           | Acceleration, unsigned fixed point 16.8 representation                                                                                                                                                                                                            | 0 to \$FFFFFD<br>[µsteps / t^2]                               |
| W    | 0x06                                                          | 230  | d_max           | Deceleration parameter, unsigned<br>Fixed point 16.8 representation<br>The effective deceleration with s-ramp<br>enabled is 15/16 of <i>d_max</i> .                                                                                                               | 0 to \$FFFFFD<br>[µsteps / t^2]                               |
| W    | 0x07                                                          | 230  | d_stop          | Deceleration for stop event, for security reason it is with bow = $0$                                                                                                                                                                                             | [µsteps / t^2]                                                |
| w    | 0x08                                                          | 40   | bow_max         | S-Ramp configuration<br>0=linear ramp (trapezoid)<br>bow_index = 1, 2, 3,, 18 ⇔<br>bow_value = 1, 2, 4,, 262144                                                                                                                                                   | bow_value<br>[µsteps / t^3]                                   |
| W    | 0x09                                                          | 310  | x_target        | Target position for automatic ramp in unit micro steps                                                                                                                                                                                                            | ± [µsteps]                                                    |
| W    | 0x0A                                                          | 310  | x_compare       | POSCOMP output function:<br>The position $x\_compare$ is compared with<br>either $x\_actual$ or the encoder position<br>$enc\_x$ . (Selection bit: $enc\_clr\_mode.12$ .)<br>POSCOMP becomes<br>0 : for x\_actual < x\_compare<br>1 : for x\_actual > x\_compare; | ± [µsteps]                                                    |
| R    | 0x0B                                                          | 40   | status          | bit 0: target_pos_reached         bit 1: target_v_reached         bit 2: v_is_zero         bit 3: - (reserved)         bit 4: enc_warn_dist                                                                                                                       |                                                               |
| R    | 0x0C                                                          | 310  | a_actual        | Actual acceleration value<br>Important note: <i>a_max</i> resp. <i>d_max</i> can be<br>exceeded by up to 1/1024 of the bow_value<br>if 1/1024*bow_value is not an integer divider<br>of <i>a_max</i> resp. <i>d_max</i>                                           | 0,, ± a_max<br>resp. d_max<br>resp. d_stop;<br>[µsteps / t^2] |
| W    | 0x0D                                                          | 150  | sd_scale        | Step Direction input control:         bit 140: sd_scaler         bit 15: sd_scale_sign                                                                                                                                                                            | dir & c<br>(c⇔accumulatio<br>n constant-1)                    |
|      | 0x0E                                                          | -    | -               | reserved                                                                                                                                                                                                                                                          |                                                               |
| w    | 0X0F                                                          | 230  | a_max_<br>d_max | Sets a_max and d_max to the same value<br>with a single write access to register<br>a_max_d_max                                                                                                                                                                   | [µsteps / t^2]                                                |

| 0x00: | 0x00: <i>mode</i> - Ramp Generator Register |           |       |                                                                                                                                                                                                                                                                                                                                                                   |  |
|-------|---------------------------------------------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| R/W   | Bit                                         | Function  | Value | Description                                                                                                                                                                                                                                                                                                                                                       |  |
| RW    | 1,0                                         | ramp_     | 00    | positioning mode                                                                                                                                                                                                                                                                                                                                                  |  |
|       |                                             | mode      | 01    | reserved                                                                                                                                                                                                                                                                                                                                                          |  |
|       |                                             |           | 10    | velocity mode (default mode on RESET)                                                                                                                                                                                                                                                                                                                             |  |
|       |                                             |           | 11    | hold mode (sets v_actual equal to v_target)                                                                                                                                                                                                                                                                                                                       |  |
| RW    | 2                                           | step_dir_ | 0     | step direction inputs are ignored                                                                                                                                                                                                                                                                                                                                 |  |
|       |                                             | enable    | 1     | The step and direction inputs (STEP_IN, DIR_IN) become scaled<br>by <i>sd_scale</i> . In this mode, <i>x_target</i> becomes directly controlled<br>by the scaled step inputs. In order to allow the motor to directly<br>follow the control signals, set to positioning mode and set a high<br>acceleration value <i>a_max_d_max</i> with <i>bow</i> set to zero. |  |
| RW    | 4                                           | shaft     | 0     | Normal direction of the output pulse generator                                                                                                                                                                                                                                                                                                                    |  |
|       |                                             |           | 1     | Inverts the direction of the output pulse generator                                                                                                                                                                                                                                                                                                               |  |
| RW    | 8                                           | PID_on    | 0     | PID controller is completely off, all values are frozen. The output pulse generator is fed by <i>v_actual</i> directly.                                                                                                                                                                                                                                           |  |
|       |                                             |           | 1     | PID controller is on. This mode also allows access to the PID error <i>pid_e</i> , which is required for a number of other functions. For normal operation, also set <i>PID_base</i> flag to <i>v_actual</i> base.                                                                                                                                                |  |
| RW 9  | 9                                           | PID_base  | 0     | The pulse generator output is controlled by the PID calculation result only. The motor will not move, if PID result is zero.                                                                                                                                                                                                                                      |  |
|       |                                             |           | 1     | PID output base is $v_actual$ . The PID result is added to the velocity output generated by the ramp generator and becomes clipped to 2^31-1.                                                                                                                                                                                                                     |  |

| 0x08: | 0x08: <i>bow_max</i> - Ramp Generator Register |           |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|-------|------------------------------------------------|-----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R/W   | Bit                                            | Function  | Value         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| W     | 40                                             | bow_index | 0             | The ramp generator uses trapezoid ramps. This corresponds to an infinite bow value.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                |           | 1<br>to<br>18 | Bow for s-shaped ramps in logarithmic representation. A high<br>bow value leads to a shorter bow phase. The bow_value is<br>added with 1/1024 f <sub>CLK</sub> [Hz] to acceleration <i>a_actual</i> up to the<br>value set by <i>a_max</i> for acceleration resp. <i>d_max</i> for<br>deceleration.<br>bow_value = 2^(bow_index-1)<br>bow_index = 1, 2, 3,, 18 ⇔<br>bow_value = 1, 2, 4,, 262144<br>Attention on bow setting:<br>The resulting bow_value must not exceed A_MAX or D_MAX<br>setting. Otherwise oscillations may result. |  |  |

| 0x0b: | 0x0b: status - Ramp Generator Register |                          |       |                                                                                                                                                                              |  |  |
|-------|----------------------------------------|--------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R/W   | Bit                                    | Function                 | Value | Description                                                                                                                                                                  |  |  |
| R 0   |                                        | target_pos<br>_reached   | 1     | Signals that the motor has stopped at the target position $(x\_actua \models x\_target)$ , or at a position determined by <i>PositionLimit_L</i> or <i>PositionLimit_R</i> . |  |  |
|       | 1                                      | target_v_<br>reached     | 1     | Signals that <i>v_actual</i> has reached <i>v_target</i> , respectively <i>v_max</i> during an automatic ramp.                                                               |  |  |
|       | 2                                      | v_is_zero                | 1     | Signals that the motor has stopped.                                                                                                                                          |  |  |
|       | 3                                      | -                        | -     | Unused (reserved)                                                                                                                                                            |  |  |
|       | 4                                      | enc_warn_<br>dist_status | 1     | Signals that the deviation between encoder position and actual ramp position exceeds the warning threshold <i>enc_warn_dist</i> .                                            |  |  |

| 0x0D: <i>sd_scale</i> - Ramp Generator Register |                                   |           |   |                                                                              |  |  |
|-------------------------------------------------|-----------------------------------|-----------|---|------------------------------------------------------------------------------|--|--|
| R/W                                             | /W Bit Function Value Description |           |   |                                                                              |  |  |
| W                                               | 140                               | sd_scaler | х | Each step input pulse counts up resp. down <i>x_target</i> by (x+1) / (2^15) |  |  |
|                                                 | 15                                | sd_scale_ | 0 | Count up when direction input is positive                                    |  |  |
|                                                 |                                   | sign      | 1 | Count down when direction input is positive                                  |  |  |

| Encod | Encoder Register Set |      |                   |                                                                                                                                                                                                                                                                                                                     |                                                                                                                                  |  |  |
|-------|----------------------|------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| R/W   | Addr                 | Bits | Register          | Description                                                                                                                                                                                                                                                                                                         | Range [Unit]                                                                                                                     |  |  |
| W     | 0x10                 | 310  | enc_const         | Accumulation constant,<br>16 bit integer part, 16 bit fractional part<br>enc_x accumulates<br>+/- enc_const / (2^16* enc_x) (binary)<br>or<br>+/- enc_const / (10^4* enc_x) (decimal)<br>To switch between decimal and binary<br>setting, see <i>enc_mode</i> bit 13.<br>Use the sign, to match rotation direction! | binary:<br>$\pm$ [µsteps/2^16]<br>$\pm$ (032767.0<br>65535)<br>decimal:<br>$\pm$ (032767.0<br>9999)<br>default = 1.0<br>(=65536) |  |  |
| RW    | 0x11                 | 310  | enc_x             | Actual encoder position                                                                                                                                                                                                                                                                                             | ± [µsteps]                                                                                                                       |  |  |
| w     | 0x12                 | 120  | enc_mode          | bit 0 : pol_A         bit 1 : pol_B         bit 2 : pol_N         bit 3 : ignore_AB         bit 4 : clr_cont         bit 5 : clr_once         bit 6 : pos_edge         bit 7 : neg_edge         bit 8 : clr_enc_x         bit 12 : x_comp_sel_enc         bit 13 : enc_sel_decimal                                  |                                                                                                                                  |  |  |
| R+C   | 0x13                 | 0    | enc_status        | bit 0 : <i>N_event</i><br>Encoder N event detected, status bit is<br>cleared on read: Read (R) + clear (C)                                                                                                                                                                                                          |                                                                                                                                  |  |  |
| R     | 0x14                 | 310  | enc_latch         | Encoder position enc_x latched on N event                                                                                                                                                                                                                                                                           | [µsteps]                                                                                                                         |  |  |
| R     | 0x15                 | 310  | x_act_latch       | Motor position <i>x_actual</i> latched on reference switch event or virtual stop switch event                                                                                                                                                                                                                       | [µsteps]                                                                                                                         |  |  |
| w     | 0x16                 | 190  | enc_warn_<br>dist | Warning threshold for motor to encoder<br>deviation ( $x_actual - enc_x$ ). This function<br>uses <i>pid_e</i> . An interrupt can be triggered<br>when the threshold is exceeded.<br>abs( <i>pid_e</i> ) > <i>enc_warn_dist</i>                                                                                     | [µsteps]                                                                                                                         |  |  |

| 0x12: enc_mode - Encoder Register |     |           |       |                                                                         |  |
|-----------------------------------|-----|-----------|-------|-------------------------------------------------------------------------|--|
| R/W                               | Bit | Function  | Value | Description                                                             |  |
|                                   | 0   | pol_A     | х     | A polarity when N is active                                             |  |
|                                   | 1   | pol_B     | х     | B polarity when N is active                                             |  |
|                                   | 2   | pol_N     | х     | defines polarity of N                                                   |  |
|                                   | 3   | ignore_AB | х     | Ignore A and B polarity                                                 |  |
|                                   | 4   | clr_cont  | 1     | continuous clear while N is active (clear once per revolution)          |  |
|                                   | 5   | clr_once  | 1     | N event enable, clear on next N event                                   |  |
|                                   | 6   | pos_edge  | 1     | N positive edge trigger (when N becomes active)                         |  |
|                                   |     |           |       | Disables N level control                                                |  |
|                                   | 7   | neg_edge  | 1     | N negative edge trigger (when N becomes inactive)                       |  |
|                                   |     |           |       | Disables N level control                                                |  |
|                                   | 8   | clr_enc_x | 0     | Upon N event, the <i>enc_x</i> becomes latched to <i>enc_latch</i> only |  |
|                                   |     |           | 1     | Additionally clear encoder counter <i>enc_x</i> at N-event              |  |
|                                   | 9   | -         |       | - (reserved)                                                            |  |
|                                   | 10  | -         |       | - (reserved)                                                            |  |
|                                   | 11  | -         |       | - (reserved)                                                            |  |
|                                   | 12  | x_comp_   | 0     | Source for POSCOMP: x_compare is compared to x_actual                   |  |
|                                   |     | sel_enc   | 1     | x_compare is compared to enc_x                                          |  |
|                                   | 13  | enc_sel_  | 0     | Encoder divisor binary: Counts in n/65536                               |  |
|                                   |     | decimal   | 1     | Encoder divisor decimal: Counts in n/10000                              |  |

| Vector Control Register Set |      |           |                   |                                                                                                                                                                                                                                                                                                                                             |                                    |  |
|-----------------------------|------|-----------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--|
| R/W                         | Addr | Bits      | Register          | Description                                                                                                                                                                                                                                                                                                                                 | Range [Unit]                       |  |
| W                           | 0x17 | 110       | venc_us_<br>const | Accumulation constant,<br>6 integer part, 6 bit fractional part<br>venc_us_const = 128*(motor full steps per<br>rotation) / encoder resolution<br>0.0: vector control off<br>Use the sign, to match rotation direction!                                                                                                                     | ± [µsteps/64]<br>default = 0 (off) |  |
| RW                          | 0x18 | 70        | venc_us_<br>pos   | Actual encoder position (use for initialization of function – position must match selected <i>microstep_adr</i> bits)                                                                                                                                                                                                                       | [256 / electrical period]          |  |
| W                           | 0x19 | 98,<br>10 | venc_us_<br>sel   | bit 0,1 : venc_microstep_resolution<br>00 = 2048 microsteps<br>01 = 1024 microsteps<br>10 = 256 microsteps<br>11 = 64 microsteps<br>selects bits from microstep_adr (0x33) to<br>match one electrical period<br>bit 8, 9 : venc_phi_load_sel<br>00 = 90°<br>01 = 101,25°<br>10 = 112,5°<br>11 = 121,75°<br>selects maximum motor load angle |                                    |  |

| 0x19: | 0x19: venc_us_sel – Vector Control Register |           |       |                                                                    |  |  |
|-------|---------------------------------------------|-----------|-------|--------------------------------------------------------------------|--|--|
| R/W   | Bit                                         | Function  | Value | Description                                                        |  |  |
| W     | 1, 0                                        | venc_us_  | 00    | 2048 microsteps: <i>microstep_adr</i> bits 12 downto 5 are used to |  |  |
|       |                                             | sel       |       | determine angle within one electrical period                       |  |  |
|       |                                             |           | 01    | 1024 microsteps: <i>microstep_adr</i> bits 11 downto 4 are used to |  |  |
|       |                                             |           |       | determine angle within one electrical period                       |  |  |
|       |                                             |           | 10    | 256 microsteps: <i>microstep_adr</i> bits 9 downto 2 are used to   |  |  |
|       |                                             |           |       | determine angle within one electrical period                       |  |  |
|       |                                             |           | 11    | 64 microsteps: <i>microstep_adr</i> bits 7 downto 0 are used to    |  |  |
|       |                                             |           |       | determine angle within one electrical period                       |  |  |
|       | 9, 8                                        | venc_phi_ | 00    | vector encoder function load angle limit to                        |  |  |
|       |                                             | load_sel  |       | +/- 90° (64/256 of an electrical period) (max. torque)             |  |  |
|       |                                             |           | 01    | +/- 101.25° (72/256 of an electrical period)                       |  |  |
|       |                                             |           | 10    | +/- 112,5° (80/256 of an electrical period)                        |  |  |
|       |                                             |           | 11    | +/- 123,75° (88/256 of an electrical period) (max. velocity)       |  |  |

| PID R    | PID Register Set - easyPID <sup>™</sup> |                  |                  |                                                                                                                                                                                                                                                            |                                             |  |  |
|----------|-----------------------------------------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|--|--|
| R/W      | Addr                                    | Bits             | Register         | Description                                                                                                                                                                                                                                                | Range                                       |  |  |
| w        | 0x20                                    | 230              | pid_p            | P parameter (unsigned)<br>update frequency f <sub>CLK</sub> /128;<br>Result: <i>pid_e*pid_p</i> /256<br>(becomes clipped to +/-2^31)                                                                                                                       | (0: disable)                                |  |  |
| W        | 0x21                                    | 230              | pid_i            | I parameter (unsigned)<br>Result: ( <i>pid_isum</i> /256)* <i>pid_i</i> /256<br>(becomes clipped to +/-2^31)                                                                                                                                               | (0: disable)                                |  |  |
| w        | 0x22                                    | 230              | pid_d            | D parameter (unsigned),<br>pid_e is sampled with a frequency of<br>(f <sub>CLk</sub> [Hz]/128/pid_d_clkdiv).<br>Result: (pid_e_last-pid_e_now) * pid_d<br>(The delta-error (pid_e_last-pid_e_now)<br>becomes clipped to +/-127)                            | (0: disable)                                |  |  |
| W        | 0x23                                    | 140              | pid_iclip        | Clipping parameter for <i>pid_isum</i><br>Clipping of ( <i>pid_isum</i> *2^16* <i>pid_iclip</i> )                                                                                                                                                          | 0\$7F80                                     |  |  |
| R<br>W+C | 0x24                                    | 310              | pid_isum         | PID integrator sum (signed)<br>Updated with f <sub>CLK</sub> [Hz]/128<br>Cleared to zero upon write access                                                                                                                                                 | ±                                           |  |  |
| w        | 0x25                                    | 70               | pid_d_<br>clkdiv | Clock divider for D part calculation<br>D-part is calculated with a frequency of:<br>f <sub>CLK</sub> / ( <i>pid_d_clkdiv</i> *128)<br>(attention: <i>pid_d_clkdiv</i> =0 results in 256)                                                                  | 1255, 0<br>= 1256                           |  |  |
| W        | 0x26                                    | -                | -                | -                                                                                                                                                                                                                                                          | -                                           |  |  |
| w        | 0x27                                    | 300              | pid_dv_clip      | Clipping parameter for PID calculation<br>result <i>pid_v_actual</i><br><i>pid_v_actual</i> = <i>v_actual</i> + clip(PID_result,<br><i>pid_dv_clip</i> )                                                                                                   | bits 70 are<br>always 0<br>(0: disable PID) |  |  |
| R        | 0x28                                    | 230<br>(31<br>0) | pid_e            | Position deviation (for monitoring)<br>$pid_e = enc_x - x_actual$<br>(clipped to +/-2^23)                                                                                                                                                                  | ±2^23                                       |  |  |
| R        | 0x29                                    | 310              | pid_v_actual     | PID calculation result (with <i>PID_base</i> =0)<br>resp. PID_result + <i>v_actual</i> ( <i>PID_base</i> =1)<br>(clipped to +/-2^31)                                                                                                                       | ±                                           |  |  |
| w        | 0x2A                                    | 190              | pid_tolerance    | Tolerance for PID regulation<br>If the absolute value of the error <i>pid_e</i> is<br>below <i>pid_tolerance</i> after an exact hit,<br>then the pid_error_in becomes 0 and<br><i>pid_i_sum</i> is set to zero, until the<br>tolerance zone is left again. |                                             |  |  |

| Step [ | Step Direction Output Configuration Register Set |      |                 |                                                                                                                                                                                               |                           |  |  |
|--------|--------------------------------------------------|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|
| R/W    | Addr                                             | Bits | Register        | Description                                                                                                                                                                                   | Range                     |  |  |
| W      | 0x30                                             | 280  | pulse_max       | Velocity threshold for resolution<br>indication output HIRES_OUT<br>If $v_actual \ge pulse_max$ then output<br>HIRES = 1<br>The driver stage can do extended<br>steps based on XSTEP_OUT      | bits 20…0 are<br>always 0 |  |  |
| W      | 0x31                                             | 150  | pulse_xstep_div | Pulse divisor for XSTEP_OUT output<br>control<br>One XSTEP_OUT pulse is generated<br>after each <i>pulse_xstep_div</i> steps                                                                  | 165535<br>default=16      |  |  |
| W      | 0x32                                             | 0    | step_dir_mode   | 0: disable STEP_OUT delay<br>1: enable STEP_OUT delay after a<br>change of the direction (DIR_OUT)<br>(It is recommended to disable the<br>delay, unless a step / direction drive is<br>used) |                           |  |  |
| RW     | 0x33                                             | 120  | microstep_adr   | Actual micro step position within look-<br>up table                                                                                                                                           |                           |  |  |
| W      | 0x34                                             | 110  | stdby_delay     | Stand-by delay, time is given in 1/f <sub>CLK</sub> / 2^16                                                                                                                                    |                           |  |  |
| W      | 0x35                                             | 70   | pulse_length    | Pulse length in clock periods for<br>STEP_OUT and XSTEP_OUT outputs<br>(DIR_OUT remains stable during<br>STEP_OUT active, XSTEP_OUT<br>occurs 2 clock periods later)                          |                           |  |  |

| Reference Switch Configuration Register Set |      |      |               |                                                                                                                                                                                                                                                                                                                                   |       |
|---------------------------------------------|------|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| R/W                                         | Addr | Bits | Register      | Description                                                                                                                                                                                                                                                                                                                       | Range |
| RW                                          | 0x40 | 130  | switch_mode   | bit 0: stop_L         bit 1: stop_R         bit 2: pol_stop_L         bit 3: pol_stop_R         bit 4: swap_LR         bit 5: soft_stop         bit 6: en_lim_L         bit 7: en_lim_R         bit 8: latch_L_act         bit 10: latch_R_act         bit 11: latch_R_inact         bit 12: en_latch_enc         bit 13: SG_stop |       |
| R,<br>R+C                                   | 0x41 | 60   | switch_status | bit 1: status_stop_L<br>bit 1: status_stop_R<br>bit 2: status_latch_L<br>bit 3: status_latch_R<br>bit 4: event_stop_L<br>bit 5: event_stop_R<br>bit 6: event_stop_SG                                                                                                                                                              |       |
| W                                           | 0x42 | 310  | pos_limit_L   | Software controlled stop position,<br>programmable virtual stop switch<br>If enabled, the motor will automatically<br>slow down and come to a stop at the<br>pos_limit rather than crossing it.                                                                                                                                   |       |
| W                                           | 0x43 | 310  | pos_limit_R   | Software controlled stop position,<br>programmable virtual stop switch<br>If enabled, the motor will automatically<br>slow down and come to a stop at the<br>pos_limit rather than crossing it.                                                                                                                                   |       |

| 0x40: | 0x40: switch_mode – Reference Switch Configuration Register |               |       |                                                                                                                                             |  |
|-------|-------------------------------------------------------------|---------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| R/W   | Bit                                                         | Function      | Value | Description                                                                                                                                 |  |
| R/W   | 0                                                           | stop_L        | 1     | Enable stop switch left                                                                                                                     |  |
|       | 1                                                           | stop_R        | 1     | Enable stop switch right                                                                                                                    |  |
|       | 2                                                           | pol_stop_L    | 0     | Left stop switch is positive active (STOP_L=1 stops motor)                                                                                  |  |
|       |                                                             |               | 1     | Left stop switch is negative active (STOP_L=0 stops motor)                                                                                  |  |
|       | 3                                                           | pol_stop_R    | 0     | Right stop switch is positive active (STOP_R=1 stops motor)                                                                                 |  |
|       |                                                             |               | 1     | Right stop switch is negative active (STOP_R=0 stops motor)                                                                                 |  |
|       | 4                                                           | swap_LR       | 0     | STOP_L stops motor when driving in negative direction,<br>STOP_R stops motor when driving in positive direction                             |  |
|       |                                                             |               | 1     | Stop inputs are swapped:<br>STOP_R stops motor when driving in negative direction,<br>STOP_L stops motor when driving in positive direction |  |
|       | 5                                                           | soft_stop     | 0     | The motor velocity is switched to 0 when hitting a stop switch (hard stop).                                                                 |  |
|       |                                                             |               | 1     | SoftStop enable:<br>The motor is slowed down to 0 using a linear ramp using<br>acceleration <i>d</i> stop when hitting a stop switch.       |  |
|       | 6                                                           | en_lim_L      | 1     | Position limit L pos_limit_L enable (virtual stop switch)                                                                                   |  |
|       | 7                                                           | en_lim_R      | 1     | Position limit R pos_limit_R enable (virtual stop switch)                                                                                   |  |
|       | 8                                                           | latch_L_act   | 1     | Latch ramp position to x_act_latch on stop switch left going active.                                                                        |  |
|       | 9                                                           | latch_L_inact | 1     | Latch ramp position to x_act_latch on stop switch left going inactive.                                                                      |  |
|       | 10                                                          | latch_R_act   | 1     | Latch ramp position to x_act_latch on stop switch right going active.                                                                       |  |
|       | 11                                                          | latch_R_inact | 1     | Latch ramp position to x_act_latch on stop switch right going inactive.                                                                     |  |
|       | 12                                                          | en_latch_enc  | 0     | Encoder position is not latched upon stop switch event.                                                                                     |  |
|       |                                                             |               | 1     | Also latch encoder position together with ramp position to enc_latch.                                                                       |  |
|       | 13                                                          | stop_SG       | 1     | Stop motor on StallGuard event signaled by TMC246 / TMC249                                                                                  |  |

| 0x41: | 0x41: switch_status – Reference Switch Configuration Register |                |                           |                                                                |  |
|-------|---------------------------------------------------------------|----------------|---------------------------|----------------------------------------------------------------|--|
| R/W   | Bit                                                           | Function       | Inction Value Description |                                                                |  |
| R     | 0                                                             | status_stop_L  | 1                         | Stop switch left status (1=active)                             |  |
|       | 1                                                             | status_stop_R  | 1                         | Stop switch right status (1=active)                            |  |
| R+C   | 2                                                             | status_latch_L | 1                         | Latch left ready (corresponding to switch_mode latch_L_act or  |  |
|       |                                                               |                |                           | <i>latch_L_inact</i> ) (Flag is cleared upon reading)          |  |
|       | 3                                                             | status_latch_R | 1                         | Latch right ready (corresponding to switch_mode latch_R_act or |  |
|       |                                                               |                |                           | <i>latch_R_inact</i> ) (Flag is cleared upon reading)          |  |
| R     | 4                                                             | event_stop_L   | 1                         | Signals an active stop left condition due to stop switch       |  |
|       | 5                                                             | event_stop_R   | 1                         | Signals an active stop right condition due to stop switch      |  |
| R+C   | 6                                                             | event_stop_    | 1                         | Signals an active StallGuard stop event                        |  |
|       |                                                               | SG             |                           | (Flag is cleared upon reading)                                 |  |

| Seque | Sequencer Configuration Register |      |                      |                                                                                                                                                                                                                                                                                                                          |                                              |
|-------|----------------------------------|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| R/W   | Addr                             | Bits | Register             | Description                                                                                                                                                                                                                                                                                                              | Range                                        |
|       | 0x50                             |      | - (reserved)         |                                                                                                                                                                                                                                                                                                                          |                                              |
|       | 0x51                             |      | - (reserved)         |                                                                                                                                                                                                                                                                                                                          |                                              |
|       | 0x52                             |      | - (reserved)         |                                                                                                                                                                                                                                                                                                                          |                                              |
|       | 0x53                             |      | - (reserved)         |                                                                                                                                                                                                                                                                                                                          |                                              |
| RW    | 0x54                             | 80   | seq_mode             | bit 30: microstep table length<br>Controls the number of microsteps per<br>electrical period. For a stepper motor,<br>the resulting microstep rate is ¼ of the<br>table length.<br>Values:<br>0: 8192 entries (Default),<br>1: 4096 entries,<br>10: 8 entries,<br>11: 4 entries (full stepping)<br>bit 8: sequencer stop |                                              |
| w     | 0x55                             | 230  | dacscale_icntl       | bit 04: current_op<br>bit 7: mixdecay_op<br>bit 812: current_sb<br>bit 15: mixdecay_sb                                                                                                                                                                                                                                   | default=%<br>00000000<br>0000000<br>10010000 |
| W     |                                  | 20   | stallguard_thrs      | StallGuard threshold                                                                                                                                                                                                                                                                                                     | 07                                           |
| R     | 0x56                             | 20   | stallguard_<br>value | actual StallGuard value reported by TMC249                                                                                                                                                                                                                                                                               | 07                                           |
| R     | 0x57                             | 20   | driver_status        | Driver status read back information:<br>bit 0 : <i>tmcdrv_error</i> (OT, UV, OCHS,<br>OCB, OCA. i.e. all driver shutdown<br>conditions)<br>bit 1 : <i>tmcdrv_otpw</i> (over temperature<br>pre-warning)<br>bit 2 : <i>tmcdrv_stall</i> (StallGuard)                                                                      |                                              |
|       | 0x58                             |      | - (reserved)         |                                                                                                                                                                                                                                                                                                                          |                                              |
| W     | 0x59                             | 110  | chop_clk_div         | chopper clock frequency register<br>(for safety reasons a value below 96 can<br>not be set)                                                                                                                                                                                                                              | 96…818<br>default = 640                      |

| 0x55:                                                                                               | (55: dacscale_icntl – Sequencer Configuration Register |                                                                                                                          |       |                                                                                                                                                                                                                                                                                                                      |  |
|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| R/W                                                                                                 | Bit                                                    | Function                                                                                                                 | Value | Description                                                                                                                                                                                                                                                                                                          |  |
| W                                                                                                   | 40                                                     | current_op                                                                                                               | 016   | Motor current scale during operation (Default=16)<br>Allows a current scaling by scaling the sine table entries<br>before sending to the DACs or to the SPI stepper drivers.<br>This function is available only for stepper motors.<br>16 = 100%<br>151 = 15 / 16 1 / 16<br>0 = DAC disable / stepper driver disable |  |
| 7 <i>mixdecay_op</i> 1 Mixed Decay Enable Operatio<br>Enables the TMC23X / TMC2<br>motor operation. |                                                        | Mixed Decay Enable Operation (Default = 1)<br>Enables the TMC23X / TMC24X mixed decay feature during<br>motor operation. |       |                                                                                                                                                                                                                                                                                                                      |  |
|                                                                                                     | 128                                                    | current_sb                                                                                                               | 016   | Standby current scale (Default=0)<br>The motor is switched to the standby current after a delay<br>time controller by <i>stdby_delay</i> .<br>Same values as for <i>current_op</i> .                                                                                                                                 |  |
|                                                                                                     | 15                                                     | mixdecay_sb                                                                                                              | 1     | Mixed Decay Enable Standby (Default=0)<br>Enables the TMC23X / TMC24X mixed decay feature during<br>motor stand still.                                                                                                                                                                                               |  |

| Туре а | Type & Version Register |      |          |                           |       |
|--------|-------------------------|------|----------|---------------------------|-------|
| R/W    | Addr                    | Bits | Register | Description               | Range |
| R      | 0x60                    | 230  | version  | TMC457 v. 1.00 ⇔ 0x457100 |       |

| Interru  | Interrupt Configuration Register |      |          |                                                                                                                                                                                                                               |       |
|----------|----------------------------------|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| R/W      | Addr                             | Bits | Register | Description                                                                                                                                                                                                                   | Range |
|          |                                  |      |          | bit 0: <i>int_target</i>                                                                                                                                                                                                      |       |
|          |                                  |      |          | bit 1: <i>int_deviation</i>                                                                                                                                                                                                   |       |
|          |                                  |      |          | bit 2: <i>int_N</i>                                                                                                                                                                                                           |       |
| ۱۸/      | 0v61                             | 70   | int_mask | bit 3: <i>int_stop</i>                                                                                                                                                                                                        |       |
| vv       | 0.01                             |      |          | bit 4: <i>int_drvstatus</i>                                                                                                                                                                                                   |       |
|          |                                  |      |          | bit 5: <i>int_ref_L</i>                                                                                                                                                                                                       |       |
|          |                                  |      |          | bit 6: <i>int_ref_R</i>                                                                                                                                                                                                       |       |
|          |                                  |      |          | bit 7: <i>int_x_comp</i>                                                                                                                                                                                                      |       |
| R<br>W+C | 0x62                             | 70   | int_flag | Same assignments as <i>int_mask</i> register. An active interrupt bit reads out as '1'. Writing a 1 to an active bit resets the interrupt flag. The interrupt output becomes active (low) as soon as at least one bit is set. |       |

| 0x61: | 61: <i>int_mask</i> – Interrupt Configuration Register |               |       |                                                                                                                                                 |  |
|-------|--------------------------------------------------------|---------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|
| R/W   | Bit                                                    | Function      | Value | Description                                                                                                                                     |  |
| W     | 0                                                      | int_target    | 1     | Target position reached interrupt:<br>If set, an interrupt is issued when the motor comes to a stand still<br>at <i>x_target</i>                |  |
|       | 1                                                      | int_deviation | 1     | Encoder position mismatch interrupt:<br>If set, an interrupt is issued, when <i>pid_e</i> exceeds the tolerance<br>value <i>pid_tolerance</i> . |  |
|       | 2                                                      | int_N         | 1     | Encoder N event interrupt :<br>If set, an interrupt is issued upon an encoder N event, as defined<br>by <i>enc_clr_mode</i> .                   |  |
|       | 3                                                      | int_stop      | 1     | Stop condition interrupt:<br>If set, an interrupt is issued upon a motor stop condition, as<br>defined by <i>switch_mode</i> .                  |  |
|       | 4                                                      | int_drvstatus | 1     | Driver status interrupt:<br>If set, an interrupt is issued upon a driver error detected in the<br><i>driver_status</i> bits.                    |  |
|       | 5                                                      | int_ref_L     | 1     | Reference switch left interrupt:<br>If set, an interrupt becomes issued upon activation of the left<br>reference switch.                        |  |
|       | 6                                                      | int_ref_R     | 1     | Reference switch right interrupt:<br>If set, an interrupt is issued upon activation of the right reference<br>switch.                           |  |
|       | 7                                                      | int_x_comp    | 1     | X_compare matching interrupt:<br>If set, an interrupt is issued, when <i>x_target</i> matches <i>x_compare</i> .                                |  |

| Sine V | Sine Wave Look-Up Table (LUT) Port Register |             |          |                         |                                        |  |
|--------|---------------------------------------------|-------------|----------|-------------------------|----------------------------------------|--|
| R/W    | Addr                                        | Bits        | Register | Description             | Range                                  |  |
| R      | 0x7F                                        | 3116<br>150 | RAM      | READ (data D of last A) | xxxAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA |  |
| W      | 0xFF                                        | 3116<br>150 | RAM      | WRITE                   | xxxAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA  |  |

#### 6.2.3 Real World Units vs. Units of the TMC457

The units of a TMC457 register content are written as register[457].

| Parameter vs. Units                                             |                  |                                                                                                                                          |
|-----------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Parameter / Symbol                                              | Unit             | calculation / description / comment                                                                                                      |
| f <sub>CLK</sub> [Hz]                                           | [Hz]             | clock frequency of the TMC457 in [Hz]                                                                                                    |
| S                                                               | [S]              | second                                                                                                                                   |
| US                                                              | microstep        |                                                                                                                                          |
| FS                                                              | fullstep         |                                                                                                                                          |
| velocity v[Hz]                                                  | microsteps / s   | v[Hz] = v[457] * ( 2 * f <sub>CLK</sub> [Hz] / 2^31 )                                                                                    |
| acceleration a[Hz/s]                                            | microsteps / s^2 | a[Hz/s] = a[457] * f <sub>CLK</sub> [Hz]^2 / (16*256) / 2^30                                                                             |
| micro step resolution USR<br>(used U instead of μ for<br>micro) | counts           | micro step resolution in number of microsteps<br>(i.e. the number of microsteps between two<br>fullsteps)                                |
| v[FS] @ USR                                                     | US/s             | v[FS/s] = v[US/2] / USR<br>USR ⇔ microstep resolution                                                                                    |
| a[FS/^2] @ USR                                                  | US/s^2           | a[FS/s^2] = a[US/s] / USR                                                                                                                |
| ramp_steps[457] = rs                                            | [457]            | rs = 2 * (v[457])^2 / (a[457]) / 2^18<br>micro steps during linear acceleration ramp<br>(if v_max is really reached during acceleration) |

# 7 Examples

Following, some examples are given how to program the TMC457 to do a desired task. The examples are given as sequences of SPI datagram as 40 bit hexadecimal number with an additional comment.

\$89 12 34 56 78 // set x\_target := \$12 34 56 78

So, for this example the datagram is \$89 12 34 56 78. That datagram sets the register x\_target to the hexadecimal value \$12345678.

#### 7.1 How to Get a Motor Running

// initialize the sine wave look-up table once (either for stepper motor or for piezo motor).

```
for (x=0; x<8192; x++)
{
    y = abs( 8191 * sin(2.0 * 3.141592652 * x / 8192) ); // stepper motor
    datagram = ( 0x7F << 32 ) | ( x << 16 ) | ( y ); // compose datagram
}</pre>
```

This results in a sequence of datagramms for initializing the sine wave look-up table as:

| \$FF \$00 \$00 \$07 \$FF<br>\$FF \$00 \$01 \$08 \$01<br>\$FF \$00 \$02 \$08 \$02 | <pre>// ram[ 0] := 0x07ff;<br/>// ram[ 1] := 0x0801;<br/>// ram[ 2] := 0x0702;</pre>       |  |  |  |  |  |
|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| \$FF \$1F \$FD \$07 \$FA<br>\$FF \$1F \$FE \$07 \$FC<br>\$FF \$1F \$FF \$07 \$FD | <pre>// ram[8189] := 0x07FA;<br/>// ram[8190] := 0x07FC;<br/>// ram[8191] := 0x07FD;</pre> |  |  |  |  |  |
| // now the motion //                                                             |                                                                                            |  |  |  |  |  |
| \$80 xx xx xx xx                                                                 | // mode := %00 = ramp_mode positioning mode with linear ramps                              |  |  |  |  |  |
| \$83 xx xx xx xx                                                                 | // v_max := \$xx xx xx xx                                                                  |  |  |  |  |  |
| \$88 00 00 00 00<br>\$8F xx xx xx xx                                             | // bow_max := 0 = linear ramp<br>// a_max_d_max := \$xx xx xx xx                           |  |  |  |  |  |
| \$89 00 BC 61 4E                                                                 | // x_target := 12345678; => move to target position x_target                               |  |  |  |  |  |

#### 7.2 Set Incremental Encoder Interface Parameters

For this example, we assume to have an incremental encoder with a resolution of 16384 steps per revolution. For the quadrature signals A and B this means that they toggle 8192 tomes per revolution with a phase shift of quarter period.

A stepper motor is assumed to have 200 full steps per revolution and is driven with a micro step revolution of 256 micro steps per full step. So, for this example, the stepper motor has  $200 \times 256 = 51200$  micro steps per revolution.

The axis of the incremental encoder is assumed to be directly connected to the axis of the stepper motor with a gear. With this, a number of 16384 positions of the incremental encoder are equal to 51200 micro steps of the stepper motor.

So, each position count of the encoder is equal to 51200 / 16384 = 3.125 micro steps.



Figure 6 : Incremental Encoder Signals Outline (AB w/o clear pulse N)

So, the accumulation constant enc\_const of the incremental encoder interface of the TMC457 has to be set that each encoder step represents 3.15. This is achieved by setting enc const = 3.125 \* 65536 = 204800 = \$00 03 20 00. The datagram sequence doing the initialization of the encoder interface is:

| \$90 00 03 20 00 | // set enc_const := \$00 03 20 00                    |
|------------------|------------------------------------------------------|
| \$91 00 03 20 00 | // set x_enc := \$00 00 00 00                        |
| \$92 00 03 20 00 | // set enc_clr_mode := \$00 00 00 00, ignore N pulse |

#### **Notation of Number Systems** 8

Decimal numbers are used as usual without additional identification. Binary numbers are identified by a prefixed % character. Hexadecimal numbers are identified by a prefixed \$ character. Alternatively, hexadecimal numbers are identified similar to C language with a prefixed 0x. For better readability of long number spaces are inserted. So, for example the decimal number 42 in the decimal system is written as %101010 in the binary number system, and it is written as \$2A or 0x2A in the hexadecimal number system.

# 9 Pinning, Package, and Electrical data of the TMC457

# 9.1 Pinning of TMC457

The TMC457-BC is available within a 144 ball fine pitch (1 mm) BGA package.

#### **Important Hints:**

All pins specified as (n.c. = not connect) <u>must</u> be left unconnected (open). All power supply pins (named V33 for +3.3V and named V15 for +1.5V) and all ground pins <u>must</u> be connected.

All inputs and all outputs have 3.3V CMOS level. Level shifters are required when using 5V devices (e.g. micro controller with 5V IO, incremental encoder with 5V ABN outputs, ...).

Other unnamed pins have to be left open. Pins with comment "do not connect (must not be connected)" must be left open because these are unused but driving outputs.

| #  | BGA<br>Ball | Signal Name | In/Out | Description / Comment                                                     |
|----|-------------|-------------|--------|---------------------------------------------------------------------------|
| 1  | A1          | GND         |        | ground                                                                    |
| 2  | A2          | V33         |        | +3.3V supply voltage                                                      |
| 3  | A3          | -           | n.c.   | do not connect (must not be connected)                                    |
| 4  | A4          | -           | n.c.   | do not connect (must not be connected)                                    |
| 5  | A5          | DIR_IN      | I      | direction input                                                           |
| 6  | <b>A6</b>   | GND         |        | ground                                                                    |
| 7  | A7          | -           |        |                                                                           |
| 8  | <b>A8</b>   | V15         |        | +1.5V supply voltage                                                      |
| 9  | A9          | -           | n.c.   | do not connect (must not be connected)                                    |
| 10 | A10         | STEP_IN     | I      | step input                                                                |
| 11 | A11         |             |        |                                                                           |
| 12 | A12         | GND         |        | ground                                                                    |
| 13 | B1          | CLK         | I      | clock input                                                               |
| 14 | <b>B2</b>   | GND         |        | ground                                                                    |
| 15 | B3          |             |        |                                                                           |
| 16 | B4          | POSCOMP     | 0      | position comparator output signal (pls. refer x_compare)                  |
| 17 | B5          | ENC_A       | I      | A signal from incremental encoder (ABN) for 3.3V level                    |
| 18 | B6          |             |        |                                                                           |
| 19 | B7          |             |        |                                                                           |
| 20 | <b>B8</b>   | -           | n.c.   | do not connect (must not be connected)                                    |
| 21 | B9          | -           | n.c.   | do not connect (must not be connected)                                    |
| 22 | B10         |             |        |                                                                           |
| 23 | <b>B11</b>  | GND         |        | ground                                                                    |
| 24 | B12         | V33         |        | +3.3V supply voltage                                                      |
| 25 | C1          | nEN         | I      | clock gating input, logical ored with CLK,<br>must be connected to ground |
| 26 | C2          | RES         | I      | active high reset input                                                   |
| 27 | C3          |             |        |                                                                           |
| 28 | C4          | V15         |        | +1.5V supply voltage                                                      |
| 29 | C5          | ENC_B       |        | B signal from incremental encoder (ABN) for 3.3V level                    |
| 30 | C6          |             |        |                                                                           |
| 31 | C7          |             |        |                                                                           |
| 32 | C8          | -           | n.c.   | do not connect (must not be connected)                                    |

| 33 | C9        | -         | n.c.  | do not connect (must not be connected)                 |
|----|-----------|-----------|-------|--------------------------------------------------------|
| 34 | C10       | PZO_EN    | I     | piezo motor enable (0:stepper motor / 1:piezo motor)   |
| 35 | C11       | SDO_DAC_A | 0     | SDO for LTC2602 DAC A input SDI                        |
| 36 | C12       | SDO_DAC_B | 0     | SDO for LTC2602 DAC B input SDI                        |
| 37 | D1        | SCK       | 1     | SPI clock input from microcontroller                   |
| 38 | D2        | nINT      | 0     | active low interrupt output                            |
| 39 | D3        |           |       |                                                        |
| 40 | D4        |           |       |                                                        |
| 41 | D5        | ENC N     | I     | N signal from incremental encoder (ABN) for 3.3V level |
| 42 | D6        |           |       | 5                                                      |
| 43 | D7        |           |       |                                                        |
| 44 | D8        | -         | n.c.  | do not connect (must not be connected)                 |
| 45 | D9        |           | -     |                                                        |
| 46 | D10       |           |       |                                                        |
| 47 | D11       |           |       |                                                        |
| 48 | D12       |           |       |                                                        |
| 49 | E1        | V15       |       | +1.5V supply voltage                                   |
| 50 | E2        |           |       |                                                        |
| 51 | ==<br>F3  |           |       |                                                        |
| 52 | <b>F4</b> | V33       |       | +3.3V supply voltage                                   |
| 53 | E5        |           |       |                                                        |
| 54 | F6        | V33       |       | +3 3V supply voltage                                   |
| 55 | F7        | V33       |       | +3 3V supply voltage                                   |
| 56 | F8        | 100       |       | to.ov supply tollage                                   |
| 57 | FQ        | V33       |       | ±3.3V supply voltage                                   |
| 58 | E10       | V15       |       | +1.5V supply voltage                                   |
| 50 | E11       | 10        |       |                                                        |
| 60 | E12       |           |       |                                                        |
| 61 | F1        | nSCS      |       | chip select input for microcontroller interface        |
| 62 | F2        | GND       |       | around                                                 |
| 63 | F3        |           |       | ground                                                 |
| 64 | F4        |           | nc    | do not connect (must not be connected)                 |
| 65 | E5        | GND       | 11.0. | around                                                 |
| 66 | F6        | GND       |       | ground                                                 |
| 67 | F7        | GND       |       | ground                                                 |
| 68 | F8        |           |       | ground                                                 |
| 60 | FQ        |           |       |                                                        |
| 70 | F10       | GND       |       | ground                                                 |
| 71 | F11       |           |       | ground                                                 |
| 72 | F12       | SCK DAC   | 0     | serial clock for LTC2602 DAC                           |
| 73 | G1        |           |       |                                                        |
| 74 | 62        | GND       |       | ground                                                 |
| 75 | GR        |           | nc    | do not connect (must not be connected)                 |
| 76 | G4        |           | 11.0. |                                                        |
| 77 | G5        | GND       |       | ground                                                 |
| 78 | GA        | GND       |       | ground                                                 |
| 70 | 67        | GND       |       | ground                                                 |
| 80 | GR        |           |       | ground                                                 |
| 81 | C0        |           |       |                                                        |
| 82 | G10       |           |       |                                                        |
| 02 | G10       |           |       |                                                        |
| ంచ | 911       |           | 1     |                                                        |

| 84                                                                                                                                                                                                              | G12                                                                                                                | NCS_DAC                                                                                                           | 0      | chip select for LTC2602 DAC                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 85                                                                                                                                                                                                              | H1                                                                                                                 | V15                                                                                                               |        | +1.5V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 86                                                                                                                                                                                                              | H2                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 87                                                                                                                                                                                                              | H3                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 88                                                                                                                                                                                                              | H4                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 89                                                                                                                                                                                                              | H5                                                                                                                 | V15                                                                                                               |        | +1.5V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 90                                                                                                                                                                                                              | H6                                                                                                                 | unused output                                                                                                     | 0      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 91                                                                                                                                                                                                              | H7                                                                                                                 | unused output                                                                                                     | 0      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 92                                                                                                                                                                                                              | H8                                                                                                                 | unused output                                                                                                     | 0      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 93                                                                                                                                                                                                              | H9                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 94                                                                                                                                                                                                              | H10                                                                                                                | V33                                                                                                               |        | +3.3V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 95                                                                                                                                                                                                              | H11                                                                                                                |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 96                                                                                                                                                                                                              | H12                                                                                                                | V15                                                                                                               |        | +1.5V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 97                                                                                                                                                                                                              | J1                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 98                                                                                                                                                                                                              | J2                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 99                                                                                                                                                                                                              | J3                                                                                                                 | V33                                                                                                               |        | +3.3V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 100                                                                                                                                                                                                             | J4                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 101                                                                                                                                                                                                             | J5                                                                                                                 | РНА                                                                                                               | 0      | phase A polarity output (for stepper motors)                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                 |                                                                                                                    |                                                                                                                   |        | ChopSync <sup>™</sup> PWM clock signal output for TRINAMIC                                                                                                                                                                                                                                                                                                                                                                                                           |
| 102                                                                                                                                                                                                             | J6                                                                                                                 | CHOPCLK                                                                                                           | 0      | stepper motor driver OSC input (TMC236, TMC239,                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 100                                                                                                                                                                                                             |                                                                                                                    |                                                                                                                   |        | TMC246, TMC249)                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 103                                                                                                                                                                                                             | J7                                                                                                                 | V15                                                                                                               |        | +1.5V supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 104                                                                                                                                                                                                             | J8                                                                                                                 | (TCK)                                                                                                             | l      | can be left open with VJTAG tied to GND                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 105                                                                                                                                                                                                             | J9                                                                                                                 | (                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 106                                                                                                                                                                                                             | J10                                                                                                                | (TDO)                                                                                                             | TRST/O | can be left open with VJTAG tied to GND                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 107                                                                                                                                                                                                             | J11                                                                                                                |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 108                                                                                                                                                                                                             | J12                                                                                                                | STOPL                                                                                                             |        | stop switch left                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 109                                                                                                                                                                                                             | K1                                                                                                                 | SDI                                                                                                               |        | serial data input, driven by micro controller output MOSI                                                                                                                                                                                                                                                                                                                                                                                                            |
| 110                                                                                                                                                                                                             | K2                                                                                                                 | SDO                                                                                                               | 0      | serial data output, drives micro controller input MISO                                                                                                                                                                                                                                                                                                                                                                                                               |
| 111                                                                                                                                                                                                             | K3                                                                                                                 |                                                                                                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 112                                                                                                                                                                                                             |                                                                                                                    |                                                                                                                   | 0      | high resolution control output (optional use)<br>0 : low resolution (use higher step width mode, XSTEP or                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                 | K4                                                                                                                 |                                                                                                                   | 0      | full step mode) 1 · high resolution (use micro stepping)                                                                                                                                                                                                                                                                                                                                                                                                             |
| 113                                                                                                                                                                                                             | K4                                                                                                                 | PHR                                                                                                               | 0      | full step mode), 1 : high resolution (use micro stepping) phase B polarity output (for stepper motors)                                                                                                                                                                                                                                                                                                                                                               |
| 113<br>114                                                                                                                                                                                                      | K4<br>K5<br>K6                                                                                                     | PHB<br>SCK_DRV                                                                                                    | 0      | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver                                                                                                                                                                                                                                                                                                        |
| 113<br>114<br>115                                                                                                                                                                                               | K4<br>K5<br>K6                                                                                                     | PHB<br>SCK_DRV                                                                                                    | 0<br>0 | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver                                                                                                                                                                                                                                                                                                        |
| 113<br>114<br>115<br>116                                                                                                                                                                                        | K4<br>K5<br>K6<br>K7<br>K8                                                                                         | PHB<br>SCK_DRV<br>GND                                                                                             | 0      | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground                                                                                                                                                                                                                                                                                              |
| 113<br>114<br>115<br>116<br>117                                                                                                                                                                                 | К4<br>К5<br>К6<br>К7<br>К8<br>К9                                                                                   | PHB<br>SCK_DRV<br>GND                                                                                             | 0      | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground                                                                                                                                                                                                                                                                                              |
| 113<br>114<br>115<br>116<br>117<br>118                                                                                                                                                                          | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10                                                                            | PHB<br>SCK_DRV<br>GND                                                                                             | 0      | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground                                                                                                                                                                                                                                                                                    |
| 113<br>114<br>115<br>116<br>117<br>118<br>119                                                                                                                                                                   | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11                                                                     | PHB<br>SCK_DRV<br>GND<br>GND                                                                                      | 0      | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground                                                                                                                                                                                                                                                                                    |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120                                                                                                                                                            | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12                                                              | PHB<br>SCK_DRV<br>GND<br>GND                                                                                      |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right                                                                                                                                                                                                                                                               |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121                                                                                                                                                     | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12                                                              | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR                                                                             |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground                                                                                                                                                                                                                                                     |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122                                                                                                                                              | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1                                                        | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33                                                               |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3 3V supply voltage                                                                                                                                                                                                                             |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123                                                                                                                                       | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L2<br>L3                                            | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT                                                    |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output                                                                                                                                                                                                         |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124                                                                                                                                | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L2<br>L3<br>L3                                      | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT                                       |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver                                                                                                                                            |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125                                                                                                                         | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L1<br>L2<br>L3<br>L4                                | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT                                       |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage                                                                                                                    |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126                                                 | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L1<br>L3<br>L3<br>L4<br>L5<br>L6                    | PHB<br>SCK_DRV<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV                            |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver                                                                      |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126         127                                     | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L2<br>L3<br>L4<br>L3<br>L4<br>L5<br>L6              | PHB<br>SCK_DRV<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV                            |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver                                                                      |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126         127         128                         | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L3<br>L3<br>L4<br>L3<br>L4<br>L5<br>L6<br>L7<br>L7  | PHB<br>SCK_DRV<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV                            |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver                                                                      |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126         127         128         120             | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L1<br>L2<br>L3<br>L4<br>L5<br>L6<br>L7<br>L8<br>L0  | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV                     |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver                                                                      |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126         127         128         129             | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L2<br>L3<br>L4<br>L5<br>L6<br>L7<br>L8<br>L9<br>L40 | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV<br>(TMS)            |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver<br>can be left open with VJTAG tied to GND                           |
| 113         114         115         116         117         118         119         120         121         122         123         124         125         126         127         128         129         130 | K4<br>K5<br>K6<br>K7<br>K8<br>K9<br>K10<br>K11<br>K12<br>L1<br>L3<br>L3<br>L4<br>L5<br>L6<br>L7<br>L8<br>L9<br>L10 | PHB<br>SCK_DRV<br>GND<br>GND<br>STOPR<br>GND<br>V33<br>DIR_OUT<br>STDBY_OUT<br>V33<br>SDO_DRV<br>(TMS)<br>(VJTAG) |        | full step mode), 1 : high resolution (use micro stepping)<br>phase B polarity output (for stepper motors)<br>serial data clock signal to stepper motor driver<br>ground<br>ground<br>stop switch right<br>ground<br>+3.3V supply voltage<br>direction output<br>stand-by output signal to lower standby current of driver<br>+3.3V supply voltage<br>serial data output to stepper motor driver<br>can be left open with VJTAG tied to GND<br>ground to disable JTAG |

| 132 | L12 | (TRST)    |   | ground to disable JTAG                                                                                          |
|-----|-----|-----------|---|-----------------------------------------------------------------------------------------------------------------|
| 133 | M1  | GND       |   | ground                                                                                                          |
| 134 | M2  | STEP_OUT  | 0 | step output                                                                                                     |
| 135 | М3  | XSTEP_OUT | 0 | extended step output (lower frequency)                                                                          |
| 136 | M4  | nANA_SPI  | Ι | SPI / not analog input selects type of stepper driver control (0: use external DAC, 1: use TMC236 internal DAC) |
| 137 | M5  | nCS_DRV   | 0 | serial data selection signal to stepper driver                                                                  |
| 138 | M6  | SDI_DRV   |   | serial data input from stepper driver                                                                           |
| 139 | M7  |           |   |                                                                                                                 |
| 140 | M8  |           |   |                                                                                                                 |
| 141 | M9  | (TDI)     |   | can be left open with VJTAG tied to GND                                                                         |
| 142 | M10 | V33       |   | +3.3V supply voltage                                                                                            |
| 143 | M11 | PDR       | Ι | connect this input via 1K pull-down resistor to ground                                                          |
| 144 | M12 | GND       |   | ground                                                                                                          |

Table 2: TMC457-BC Pin Out

#### 9.1.1 Pull-Up / Pull-Down Resistances

Some inputs have weak on-chip pull-up resp. weak pull-down resistors. The resistance of these is within the range of 10 kOhm (min.) ... 45 kOhm (max.)

#### 9.1.2 Blocking Capacitors

Ceramic capacitors of 100nF capacitance should be connected as close as possible at each 1V5 power supply pin and at each 3V3 power supply pin. Alternatively, two power planes – one power plane for +1V5 (V15) and one power plane for +3V3 (V33) can be used.

b

D1 / E1

# 9.2 Package Outlines and Dimensions

9.2.1 Fine Pitch BGA Package with 144 Balls (FBGA144) of TMC457-BC





| 0h.e.l | Dime      | ensions in MILLIME | TERS  | Din | nensions in INCH | ES  |
|--------|-----------|--------------------|-------|-----|------------------|-----|
| Symbol | Min       | Тур                | Max   | Min | Тур              | Max |
| Α      | 1.35      | 1.45               | 1.55  |     |                  |     |
| A1     | 0.35      | 0.40               | 0.45  |     |                  |     |
| A2     | 0.65      | 0.70               | 0.75  |     |                  |     |
| aaa    |           | 0.12               |       |     |                  |     |
| b      | 0.45      | 0.50               | 0.55  |     |                  |     |
| bbb    |           | 0.25               |       |     |                  |     |
| с      | -         | 0.35               | -     |     |                  |     |
| CCC    |           | 0.35               |       |     |                  |     |
| D      | 12.80     | 13.00              | 13.20 |     |                  |     |
| D1     |           | 11.00 BSC          |       |     |                  |     |
| D2     | 12.80     | 13.00              | 13.20 |     |                  |     |
| E      | 12.80     | 13.00              | 13.20 |     |                  |     |
| E1     | 11.00 BSC |                    |       |     |                  |     |
| E2     | 12.80     | 13.00              | 13.20 |     |                  |     |
| е      |           | 1.00               |       |     |                  |     |

Table 3 : Dimensions of FBGA144 (Note: BSC = Basis Spacing Between Centers)

# 10 Micro Controller Interface (SPI)

The communication between micro controller and TMC457 takes place via the four via serial interface, the Serial Peripheral Interface (SPI<sup>TM</sup>, SPI is trademark of Motorola). Many types of micro controllers of different vendors are equipped with SPI hardware.



Figure 8 : Timing Diagram of the Serial Micro Controller Interface

| Symbol      | Parameter                                   | Min              | Тур | Max | Unit        |
|-------------|---------------------------------------------|------------------|-----|-----|-------------|
| tSUCSC      | Setup Clocks for nSCS                       | 3                |     | 00  | CLK periods |
| tHDCSC      | Hold Clocks for nSCS                        | 3                |     | 00  | CLK periods |
| tSCKCL      | Serial Clock Low                            | 3                |     | x   | CLK periods |
| tSCKCH      | Serial Clock High                           | 3                |     | ×   | CLK periods |
| tSD         | SDO valid after SCK low                     | 2.5              |     | 3.5 | CLK periods |
| tSI         | SDO valid after nSCS high                   |                  |     | 4.5 | CLK periods |
| tDAMAGRAMuC | Datagram Length                             | 3+3 + 40*6 = 246 |     | ×   | CLK periods |
| tDAMAGRAMuC | Datagram Length                             | 12.3             |     | ×   | μs          |
| fCLK        | Clock Frequency                             | 0                |     | 20  | MHz         |
| tCLK        | Clock Period tCLK = 1 / fCLK                | 50               |     | x   | ns          |
| tPD         | CLK-rising-edge-to-Output Propagation Delay |                  | 5   |     | ns          |

Table 4: Timing Characteristics of the Micro Controller Serial Peripheral Interface (SPI)

# 11 Characteristics

| Symbol    | Parameter           | Conditions                 | Min  | Max  | Unit |
|-----------|---------------------|----------------------------|------|------|------|
| VCORE_AMR | core supply voltage |                            | -0.3 | 1.65 | V    |
| VOI_AMR   | IO supply voltage   |                            | -0.3 | 3.75 | V    |
| VIN_AMR   | input voltage       | 3.3V IO supply voltage VIO | -0.3 | 3.6  | V    |

#### Table 5 - Absolute Maximum Ratings

| Symbol  | Parameter                    | Conditions            | Min  | Тур | Max | Unit |
|---------|------------------------------|-----------------------|------|-----|-----|------|
| тсом    | commercial temperature range |                       | 0    |     | 70  | °C   |
| VCORE   | nominal core voltage         |                       |      | 1.5 |     | V    |
| VIO     | nominal IO voltage           |                       |      | 3.3 |     | V    |
| VIN     | nominal input voltage        |                       | 0.0  |     | 3.3 | V    |
| VINL    | input voltage low level      | 85°C (test condition) | -0.3 |     | 0.8 | V    |
| VINH    | input voltage high level     | 85°C (test condition) | 2.0  |     | 3.6 | V    |
| VOUTL   | output voltage low level     | 85°C (test condition) |      |     | 0.4 | V    |
| VOUTH   | output voltage high level    | 85°C (test condition) | 2.4  |     |     | V    |
| IOUTDRV | output driver strength       | 85°C (test condition) |      | 12  |     | mA   |

### Table 6 – DC Ccharacteristics Operating Conditions

| Symbol | Parameter                 | Conditions   | Min | Тур | Max | Unit |
|--------|---------------------------|--------------|-----|-----|-----|------|
| PDST   | static power dissipation  | 25°C         |     | 15  |     | mW   |
| PDDY   | dynamic power dissipation | 25°C, 16 MHz |     | 75  |     | mW   |
| PD     | total power dissipation   | 25°C, 16 MHz |     | 90  |     | mW   |

#### **Table 7 - Power Dissipation**

| Symbol  | Parameter                 | Conditions                                               | Min | Тур | Max | Unit |
|---------|---------------------------|----------------------------------------------------------|-----|-----|-----|------|
| fCLK    | Operation Frequency       | fCLK = 1 / tCLK                                          |     |     | 20  | MHz  |
| tCLK    | Clock Period              | Raising Edge to Raising Edge of CLK                      |     |     | 50  | ns   |
| tCLK_L  | Clock Time Low            |                                                          | 25  |     |     | ns   |
| tCLK_H  | Clock Time High           |                                                          | 25  |     |     | ns   |
| tRISE_I | Input Signal Rise Time    | 10% to 90%                                               |     | 5   |     | ns   |
| tFALL_I | Input Signal Fall Time    | 90% to 10%                                               |     | 5   |     | ns   |
| tRISE_O | Output Signal Rise        | 10% to 90%                                               |     | 5   |     | ns   |
| tFALL_O | Output Signal Fall Time   | 90% to 10%                                               |     |     |     | ns   |
| tSU     | Setup Time                | relative to falling clock edge at CLK                    |     | 5   |     | ns   |
| tHD     | Hold Time                 | relative to falling clock edge at CLK                    |     | 5   |     | ns   |
| tPD     | Propagation Delay<br>Time | 50% of rising edge of the clock CLK to 50% of the output |     | 30  |     | ns   |

#### **Table 8 - General IO Timing Parameters**



Figure 9 - General IO Timing Parameters

# 12 Literature

LTC2602 Datasheet, www.linear.com

TMC236 Datasheet, www.trinamic.com

TMC239 Datasheet, www.trinamic.com

TMC246 Datasheet, www.trinamic.com

TMC249 Datasheet, www.trinamic.com

PiezoMotor, www.piezomotor.se

PiezoLEGS® Technology Information, http://www.piezomotor.se/pages/PLtechnology.html

PiezoLEGS® Datasheets, http://www.piezomotor.se/pages/PLdownloads.html

| Version | Date (Initials)     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|---------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1.00    | 25.08.2008 (LL)     | First published version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 1.01    | 30.10.2008 (LL)     | Formula for calculation of sine wave look-up table corrected (section 5.11.2, page 13 and section 7.1, page 27).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1.02    | 03.10.2008 (LL)     | load_scale outputs added at pinning table and register mapping<br>(section 9, page 29 ff. & section 6.2, page 15 ff.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1.06    | 27.10.2008 (BD)     | Detail tables for registers with complex content, added some missing register bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 1.07    | 04.01.2009 (LL, BD) | formula for calculation of sine wave look-up table corrected (section 5.11.2, page 13) and calculation of look-up table with offset added, corrected acceleration formula                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 1.08    | 19.01.2009 (LL)     | Pin F4 in Table 2: TMC457-BC Pin Out, page 32 corrected (n.c. instead of ground)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1.09    | 26.03.2009 (BD)     | Reference Switch table corrected (Reference Switch Configuration Register Set)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 1.10    | 31.03.2009 (BD)     | <ul> <li>Changed documentation for Version 1.02 of TMC457:</li> <li>Added vector encoder registers (venc)<br/>Attention: VENC functions are only available starting from V1.02 of TMC457!</li> <li>Register PID_DV_CPU was removed; register bits current_scale and outputs<br/>LOAD_SCALE were removed,</li> <li>Actual TMC249 stallguard value can be read now</li> <li>Encoder constant can now be scaled in 1/10000 steps (enable via bit 13 of<br/>enc_mode)</li> <li>enc_clr_mode register renamed to enc_mode</li> <li>Added how restrictions, corrected formula for how value</li> </ul> |  |  |
| 1.11    | 22.04.2009 (BD)     | (Bernhard Dwersteg 40 <sup>th</sup> birthday version!)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 1.12    | 12.06.2009 (BD)     | Improved some descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 1.13    | 07.09.2009 (LL, BD) | Pin G3 (75) explicitly marked as n.c. / F1 is input / Corrected pinning table according names in Fig.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 1.14    | 09.09.2009 (BD)     | C4 is GND, new method to disable JTAG by tying L10 and L12 to GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 1.15    | 05.10.2009 (LL, BD) | C4 is a +1V5 (correct in pinning table, but comment in history 1.14 needed adaption)<br>V1.02 of TMC457: linear ramp failure when AMAX<128 and AMAX/=DMAX<br>Added known bugs section                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1.16    | 25.11.2009 (BD)     | Documented wrong stop switch behavior, corrected in V1.04 of TMC457                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |

# 13 Revision History

Please refer to <u>www.trinamic.com</u> for updated data sheets and application notes on this product and on other products.

The TMCtechLIB CD-ROM including data sheets, application notes, schematics of evaluation boards, software of evaluation boards, source code examples, parameter calculation spreadsheets, tools, and more is available from TRINAMIC Motion Control GmbH & Co. KG by request to <u>tmc\_info@trinamic.com</u>