# TMC4671 Datasheet

IC Version V1.3 | Document Revision V2.05 • 2021-Jan-06

The TMC4671 is a fully integrated servo controller, providing Field Oriented Control for BLDC/PMSM and 2-phase Stepper Motors as well as DC motors and voice coils. All control functions are implemented in hardware. Integrated ADCs, position sensor interfaces, position interpolators, enable a fully functional servo controller for a wide range of servo applications.



#### **Features**

- Servo Controller
   w/ Field Oriented Control (FOC)
- Torque Control (FOC), Velocity Control, Position Control
- Integrated ADCs,  $\Delta\Sigma$ -ADC Frontend
- Encoder Engine: Hall analog/digital, Encoder analog/digital
- Supports 3-Phase PMSM/BLDC, 2-Phase Stepper Motors, and 1-Phase DC Motors
- Fast PWM Engine (25kHz...100kHz)
- Application SPI + Debug (UART, SPI)
- Step-Direction Interface (S/D)

# **Applications**

- Robotics
- Pick and Place Machines
- Factory Automation
- E-Mobility
- · Laboratory Automation
- Blowers

Pumps

# Simplified Block Diagram



©2021 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany Terms of delivery and rights to technical change reserved. Download newest version at: www.trinamic.com





# **Contents**

| 1 | Ord                             | er Code                     | s                                                                                | 6                                                       |
|---|---------------------------------|-----------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------|
| 2 | Fun                             | ctional S                   | Summary                                                                          | 7                                                       |
| 3 | 3.1<br>3.2<br>3.3<br>3.4<br>3.5 | What is<br>Why FO<br>How do | Pes FOC work?                                                                    | 9<br>10<br>11<br>11<br>11<br>12<br>12<br>12<br>13<br>14 |
| 4 | Fun                             | ctional I                   | Description                                                                      | 16                                                      |
| • | 4.1                             | Function                    | nal Blocks                                                                       |                                                         |
|   |                                 |                             | unication Interfaces                                                             |                                                         |
|   |                                 | 4.2.1                       | SPI Slave User Interface                                                         |                                                         |
|   |                                 | 4.2.2                       | TRINAMIC Real-Time Monitoring Interface (SPI Master)                             |                                                         |
|   |                                 | 4.2.3                       | UART Interface                                                                   |                                                         |
|   |                                 | 4.2.4                       | Step/Direction Interface                                                         |                                                         |
|   |                                 | 4.2.5                       | Single Pin Interface                                                             |                                                         |
|   | 4.3                             | 4.2.6                       | GPIO Interface                                                                   | 23<br>24                                                |
|   | 4.5                             | 4.3.1                       | Numerical Representation                                                         |                                                         |
|   |                                 | 4.3.2                       | N_POLE_PAIRS, PHI_E, PHI_M                                                       |                                                         |
|   |                                 | 4.3.3                       | Numerical Representation of Angles PHI                                           | 26                                                      |
|   | 4.4                             | ADC En                      | gine                                                                             | 28                                                      |
|   |                                 | 4.4.1                       | ADC current sensing channels ADC_I1 and ADC_I0                                   |                                                         |
|   |                                 | 4.4.2                       | ADC for analog Hall signals or analog sin-cos-encoders AENC_UX, AENC_VN, AENC_WY |                                                         |
|   |                                 | 4.4.3                       | ADC supply voltage measurement ADC_VM                                            |                                                         |
|   |                                 | 4.4.4<br>4.4.5              | ADC_VM for Brake Choppper                                                        |                                                         |
|   |                                 | 4.4.5<br>4.4.6              | ADC EXT register option                                                          |                                                         |
|   |                                 | 4.4.7                       | ADC RAW values                                                                   |                                                         |
|   |                                 | 4.4.8                       | ADC_SCALE and ADC_OFFSET                                                         |                                                         |
|   |                                 | 4.4.9                       | ADC Gain Factors for Real World Values                                           |                                                         |
|   |                                 | 4.4.10                      | Internal Delta Sigma ADCs                                                        |                                                         |
|   |                                 | 4.4.11                      | Internal Delta Sigma ADC Input Stage Configuration                               | 30                                                      |
|   |                                 | 4.4.12                      | External Delta Sigma ADCs                                                        |                                                         |
|   |                                 | 4.4.13                      | ADC Group A and ADC Group B                                                      |                                                         |
|   |                                 | 4.4.14                      | Delta Sigma Configuration and Timing Configuration                               |                                                         |
|   |                                 | 4.4.15                      | Internal Delta Sigma Modulators - Mapping of V_RAW to ADC_RAW                    | 36<br>37                                                |
|   |                                 | 4416                        | External Delta Sigma Modulator Interface                                         | <b>∀</b> /                                              |



|   | 4.5  | Analog   | Signal Conditioning                                                               | . 39 |
|---|------|----------|-----------------------------------------------------------------------------------|------|
|   |      | 4.5.1    | FOC3 - Stator Coil Currents I_U, I_V, I_W and associated Voltages U_U, U_V, U_W . |      |
|   |      | 4.5.2    | FOC2 - Stepper Coil Currents I_X, I_Y and associated Voltages U_X, U_Y            |      |
|   |      | 4.5.3    | FOC1 - DC Motor Coil Current I_X1, I_X2, and associated Voltage U_X1, U_X2        | . 40 |
|   |      | 4.5.4    | ADC Selector & ADC Scaler w/ Offset Correction                                    |      |
|   | 4.6  | Encode   | r Engine                                                                          |      |
|   |      | 4.6.1    | Open-Loop Encoder                                                                 | . 42 |
|   |      | 4.6.2    | Incremental ABN Encoder                                                           |      |
|   |      | 4.6.3    | Secondary Incremental ABN Encoder                                                 |      |
|   |      | 4.6.4    | Digital Hall Sensor Interface with optional Interim Position Interpolation        |      |
|   |      | 4.6.5    | Digital Hall Sensor - Interim Position Interpolation                              |      |
|   |      | 4.6.6    | Digital Hall Sensors - Masking, Filtering, and PWM center sampling                |      |
|   |      | 4.6.7    | Digital Hall Sensors together with Incremental Encoder                            |      |
|   |      | 4.6.8    | Analog Hall and Analog Encoder Interface (SinCos of 0° 90° or 0° 120° 240°)       | . 48 |
|   |      | 4.6.9    | Analog Position Decoder (SinCos of 0°90° or 0°120°240°)                           |      |
|   |      | 4.6.10   | Encoder Initialization Support                                                    |      |
|   |      | 4.6.11   | Velocity Measurement                                                              |      |
|   |      | 4.6.12   | Reference Switches                                                                |      |
|   | 4.7  |          | Engine                                                                            |      |
|   | 7.7  | 4.7.1    | ENI and ENO pins                                                                  |      |
|   |      | 4.7.2    | PI Controllers                                                                    |      |
|   |      | 4.7.3    | PI Controller Calculations - Classic Structure                                    |      |
|   |      | 4.7.4    | PI Controller Calculations - Advanced Structure                                   |      |
|   |      | 4.7.5    | PI Controller - Clipping                                                          |      |
|   |      | 4.7.6    | PI Flux & PI Torque Controller                                                    |      |
|   |      | 4.7.7    | PI Velocity Controller                                                            |      |
|   |      | 4.7.8    | P Position Controller                                                             |      |
|   |      | 4.7.9    | Inner FOC Control Loop - Flux & Torque                                            |      |
|   |      | 4.7.10   | FOC Transformations and PI(D) for control of Flux & Torque                        |      |
|   |      | 4.7.11   | Motion Modes                                                                      |      |
|   |      | 4.7.12   | Brake Chopper                                                                     |      |
|   | 4.8  |          | g and Feed-Forward Control                                                        |      |
|   | 4.0  | 4.8.1    | Biguad Filters                                                                    |      |
|   |      | 4.8.2    | Standard Velocity Filter                                                          |      |
|   |      | 4.8.3    | Feed-Forward Control Structure                                                    |      |
|   | 4.9  |          | ngine                                                                             |      |
|   | 4.5  | 4.9.1    | PWM Polarities                                                                    |      |
|   |      | 4.9.2    | PWM Engine and associated Motor Connectors                                        |      |
|   |      | 4.9.3    | PWM Frequency                                                                     |      |
|   |      | 4.9.4    | PWM Resolution                                                                    |      |
|   |      | 4.9.5    | PWM Modes                                                                         |      |
|   |      | 4.9.6    | Break-Before-Make (BBM)                                                           |      |
|   |      | 4.9.7    | Space Vector PWM (SVPWM)                                                          |      |
|   |      | 4.9.7    | Real- and Integer-Conversions                                                     |      |
|   |      | 4.3.0    | Real- and integer-conversions                                                     | . 65 |
| 5 | Safe | ety Func | tions                                                                             | 66   |
| 6 | FOC  | Setup -  | How to Turn a Motor                                                               | 69   |
| _ | 6.1  |          | Motor Type                                                                        |      |
|   |      | 6.1.1    | FOC1 Setup - How to Turn a Single Phase DC Motor                                  |      |
|   |      | 6.1.2    | FOC2 Setup - How to Turn a Two Phase Motor (Stepper)                              |      |
|   |      | 6.1.3    | FOC3 Setup - How to Turn a Three Phase Motor (PMSM or BLDC)                       |      |
|   | 6.2  |          | mber of Pole Pairs (NPP)                                                          |      |
|   |      |          | otor Open Loop                                                                    | . 70 |



|    |      |                      | Determi<br>Determi |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|----|------|----------------------|--------------------|---------|-------|--------|--------|-------|-------|-------|------|-----|------------|-----|---------|------|-------|------|-------|
|    | 6.4  | Selection            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      |                      | Selection          |         |       |        |        | _     | -     |       |      |     |            |     |         |      |       |      |       |
|    |      |                      | Selection          |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      |                      | Selection          |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Modes of             |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    | 0.0  | Controlle            | r runni            | 3       |       |        |        |       | • • • |       | • •  |     |            | • • | <br>• • | <br> | <br>• | <br> | . / 1 |
| 7  | Reg  | ister Map            | )                  |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 71    |
|    | 7.1  | Register I           | Map - O            |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Register I           |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    | 7.3  | Register I           | Map - D            | efaults | , Dat | ta Fie | elds ( | Bit N | Mask  | s), r | nin, | max | <b>.</b> . |     | <br>    | <br> |       | <br> | .110  |
| 8  | Pinr | ning                 |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 128   |
| 9  | тмс  | 24671 Pin            | Table              |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 130   |
| 10 | Elec | trical Cha           | aracteri           | stics   |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 134   |
|    |      | Absolute             |                    |         | ings  |        |        |       |       |       |      |     |            |     | <br>    | <br> |       | <br> | . 134 |
|    |      | Electrical           |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      |                      | Operation          |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | 10.2.2               | DC Char            | acteris | tics  |        |        |       |       |       |      |     |            |     | <br>    | <br> |       | <br> | . 135 |
| 11 |      | ple Circui           |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 136   |
|    |      | Supply Pi            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Clock and            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Digital En Analog Fr |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Phase Cu             |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Power Sta            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
| 12 |      | ıp Guideli           |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 140   |
|    |      |                      |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
| 13 | Pacl | kage Dim             | ensions            | i       |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 141   |
| 14 |      | plementa             |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 144   |
|    |      | Producer             |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Copyright            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Tradema<br>Target Us |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Disclaime            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Disclaime            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Collatera            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
| 15 | Erra | ita of TMC           | C4674 I            | A / EC2 | / EC  |        |        |       |       |       |      |     |            |     |         |      |       |      | 146   |
| 13 |      | Errata of            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Fixes of T           |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    |      | Errata of            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
|    | 15.4 | Actions to           | o Avoid            | Troubl  | e     |        |        |       |       |       |      |     |            |     | <br>    | <br> |       | <br> | .148  |
|    |      | Recomme              |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      |       |
| 16 | Figu | ıres Index           | (                  |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 149   |
| 17 | Tab  | les Index            |                    |         |       |        |        |       |       |       |      |     |            |     |         |      |       |      | 150   |



| 18 Revision History    | 151 |
|------------------------|-----|
| 18.1 IC Revision       |     |
| 18.2 Document Revision | 151 |



# 1 Order Codes

| Order Code                      | Description                     | Size           |
|---------------------------------|---------------------------------|----------------|
| TMC4671-LA                      | TMC4671 FOC Servo Controller IC | 10.5mm x 6.5mm |
| TMC4671-ES2                     | TMC4671-LA 1936 35735           | 10.5mm x 6.5mm |
|                                 | (Engineering Sample)            |                |
| TMC4671-EVAL                    | TMC4671 Evaluation Board        | 55mm x 85mm    |
| TMC4671-BOB                     | TMC4671 Breakout Board          | 38mm x 40mm    |
| Landungsbruecke                 | MCU Board                       | 85mm x 55mm    |
| TMC-UPS-2A24V-A-EVAL            | Power Stage Board               | 85mm x 55mm    |
| TMC-UPS-10A70V-A-EVAL           | Power Stage Board               | 85mm x 55mm    |
| TMC4671+TMC-UPS-2A24V-EVAL-KIT  | Evaluation Kit                  | _              |
| TMC4671+TMC-UPS-10A70V-EVAL-KIT | Evaluation Kit                  | _              |
| USB-2-RTMI                      | Interface Adapter to use RTMI   | 40mm x 20mm    |

Table 1: Order codes

| AI |     |  |
|----|-----|--|
| IV | ore |  |
|    |     |  |

TMC4671-ES2 labeled TMC4671-LA 1936 35735 are pre-series production engineering samples for evaluation of final silicone functionality of the TMC4671-LA.



# **2 Functional Summary**

## Servo Controller with Field Oriented Control (FOC)

- Torque (and flux) control mode
- Velocity control mode
- Position control mode

#### · Control Functions/PI Controllers

- Programmable clipping of inputs and outputs of interim results
- Integrator windup protection for all controllers
- Status output with programmable mask for internal status signal selection

### Supported Motor Types

- FOC3: 3-phase permanent magnet synchronous motors (PMSM) / brushless DC motor (BLDC)
- FOC2: 2-phase stepper motors
- FOC1: 1-phase brushed DC motors, or linear voice coil motors

### ADC Engine with Offset Correction and Scaling

- Integrated Delta Sigma ADCs for current sense voltage, supply voltage, analog encoder, AGPIs
- Interface for isolated external current sensing Delta Sigma modulators

#### Position Feedback

- Open loop position generator (programmable [rpm], [rpm/s]) for initial setup
- Digital incremental encoder (ABN resp. ABZ, up to 2 MHz)
- Secondary digital incremental encoder
- Digital Hall sensor interface (H1, H2, H3 resp. H\_U, H\_V, H\_W) with interim position interpolation
- Analog encoder/analog Hall sensor interface (SinCos (0°, 90°) or 0°, 120°, 240°)
- Position target, velocity and target torque filters (Biquad)
- multi-turn position counter (32-bit)

## PWM Engine Including SVPWM

- Programmable PWM frequency within the range of 25 kHz ... 100 kHz
- PWM auto scaling for transparent change of PWM frequency during motion
- Programmable Brake-Before-Make (BBM) times (0 ns  $\dots$  2.5  $\mu$ s) for digital gate control signals
- Single bit SVPWM control (on/off) for Space Vector Modulation (switchable during operation)



# SPI Application Communication Interface

- 40 bit datagram length (1 ReadWrite bit + 7 address bits + 32 data bits)
- Immediate SPI read response (register read access by single datagram)
- SPI clock frequency fSCK up to 2 MHz (8 MHz write, 8 MHz read w/ 500 ns pause after address)

# • TRINAMIC Real Time Monitoring Interface

- High frequency sampling of real-time data via TRINAMIC's real-time monitoring system
- Only single 10 pin high density connector on PCB needed
- Enables frequency response identification and auto tuning options with TRINAMIC's IDE

## UART Debug Interface

- Three pin (GND, RxD, TxD) 3.3 V UART interface (1N8; 9600 (default), 115200, 921600, 3M bps)
- Available as port for external position sensors (e.g. absolute encoder together with processor)
- Transparent register access parallel to embedded user application interface (SPI)

# Supply Voltages

- 5V and 3.3V; VCC\_CORE is internally generated

# · IO Voltage

- 3.3V for all digital IOs (choosable by VCCIO Supply)
- 5V common mode analog input voltage range (1.25V ... 2.5V differential operating range)

# Clock Frequency

- 25 MHz (from external oscillator)

#### Packages

- QFN76



# 3 FOC Basics

This section gives a short introduction into some basics of Field Oriented Control (FOC) of electric motors.

# 3.1 Why FOC?

The Field Oriented Control (FOC), alternatively named Vector Control (VC), is a method for the most energy-efficient way of turning an electric motor.

#### 3.2 What is FOC?

The Field Oriented Control was independently developed by K. Hasse, TU Darmstadt, 1968, and by Felix Blaschke, TU Braunschweig, 1973. The FOC is a current regulation scheme for electro motors that takes the orientation of the magnetic field and the position of the rotor of the motor into account, regulating the strength in such way that the motor gives that amount of torque that is requested as target torque. The FOC maximizes active power and minimizes idle power - that finally results in power dissipation - by intelligent closed-loop control illustrated by figure 1.



Figure 1: Illustration of the FOC basic principle by cartoon: Maximize active power and minimize idle power and power dissipation by intelligent closed-loop control.

# 3.3 Why FOC as pure Hardware Solution?

The initial setup of the FOC is usually very time consuming and complex, although source code is freely available for various processors. This is because the FOC has many degrees of freedom that all need to fit together in a chain in order to work.

The hardware FOC as an existing standard building block drastically reduces the effort in system setup. With that off the shelf building block, the starting point of FOC is the setup of the parameters for the FOC. Setting up and implement the FOC itself and building and programming required interface blocks is no longer necessary. The real parallel processing of hardware blocks de-couples the higher lever application software from high speed real-time tasks and simplifies the development of application software. With the TMC4671, the user is free to use its qualified CPU together with its qualified tool chain, freeing the user from fighting with processer-specific challenges concerning interrupt handling and direct memory access. There is no need for a dedicated tool chain to access the TMC4671 registers and to operate it just SPI (or UART) communication needs to be enabled for any given CPU.

The hardware integration of the FOC drastically reduces the number of required components and reduces the required PCB space. This is in contrast to classical FOC servos formed by motor block and separate



controller box wired with motor cable and encoder cable. The high integration of FOC, together with velocity controller and position controller, enables the FOC as a standard peripheral component that transforms digital information into physical motion. Compact size together with high performance and energy efficiency especially for battery powered mobile systems are enabling factors when embedded goes autonomous.

#### 3.4 How does FOC work?

Two force components act on the rotor of an electric motor. One component is just pulling in radial direction (ID) where the other component is applying torque by pulling tangentially (IQ). The ideal FOC performs a closed loop current control that results in a pure torque generating current IQ – without direct current ID.



Figure 2: FOC optimizes torque by closed loop control while maximizing IQ and minimizing ID to 0

From top point of view, the FOC for 3-phase motors uses three phase currents of the stator interpreted as a current vector (Iu; Iv; Iw) and calculates three voltages interpreted as a voltage vector (Uu; Uv; Uw) taking the orientation of the rotor into account in a way that only a torque generating current IQ results.

From top point of view, the FOC for 2-phase motors uses two phase currents of the stator interpreted as a current vector (Ix; Iy) and calculates two voltages interpreted as a voltage vector (Ux; Uy) taking the orientation of the rotor into account in a way that only a torque generating current IQ results.

To do so, the knowledge of some static parameters (number of pole pairs of the motor, number of pulses per revolution of an used encoder, orientation of encoder relative to magnetic axis of the rotor, count direction of the encoder) is required together with some dynamic parameters (phase currents, orientation of the rotor).

The adjustment of P parameter P and I parameters of two PI controllers for closed loop control of the phase currents depends on electrical parameters of the motor (resistance, inductance, back EMF constant of the motor that is also the torque constant of the motor, supply voltage).

# 3.5 What is Required for FOC?

The FOC needs to know the direction of the magnetic axis of the rotor of the motor in reference to the magnetic axis of the stator of the motor. The magnetic flux of the stator is calculated from the currents through the phases of the motor. The magnetic flux of the rotor is fixed to the rotor and thereby determined by an encoder device.

For the FOC, the user needs to measure the currents through the coils of the stator and the angle of the rotor. The measured angle of the rotor needs to be adjusted to the magnetic axes.

The challenge of the FOC is the high number of degrees of freedom in all parameters.



## 3.5.1 Coordinate Transformations - Clarke, Park, iClarke, iPark

The FOC requires different coordinate transformations formulated as a set of matrix multiplications. These are the Clarke Transformation (Clarke), the Park Transformation (Park), the inverse Park Transformation (iPark) and the inverse Clarke Transformation (iClarke). The Park transformation is also known as DQ transformation, whereas the Clarke transformation is known as  $\alpha\beta$  transformation.

The TMC4671 takes care of the required transformations so the user no longer has to fight with implementation details of these transformations.

#### 3.5.2 Measurement of Stator Coil Currents

The measurement of the stator coil currents is required for the FOC to calculate a magnetic axis out of the stator field caused by the currents flowing through the stator coils.

Coil current stands for motor torque in context of FOC. This is because motor torque is proportional to motor current, defined by the torque constant of a motor. In addition, the torque depends on the orientation of the rotor of the motor relative to the magnetic field produced by the current through the coils of the stator of the motor.

### 3.5.3 Stator Coil Currents I\_U, I\_V, I\_W and Association to Terminal Voltages U\_U, U\_V, U\_W

The correct association between stator terminal voltages U\_U, U\_V, U\_W and stator coil currents I\_U, I\_V, I\_W is essential for the FOC. In addition to the association, the signs of each current channel need to fit. Signs of the current can be adapted numerically by the ADC scaler. The mapping of ADC channels is programmable via configuration registers for the ADC selector. Initial setup is supported by the integrated open loop encoder block, that can support the user to turn a motor open loop.

#### 3.5.3.1 Chain of Gains for ADC Raw Values

An ADC raw value is a result of a chain of gains that determine it. A coil current I\_SENSE flowing through a sense resistor causes a voltage difference according to Ohm's law. The resulting ADC raw value is a result of the analog signal path according to

$$ADC\_RAW = (I\_SENSE * ADC\_GAIN) + ADC\_OFFSET.$$
 (1)

The ADC\_GAIN is a result of a chain of gains with individual signs. The sign of the ADC\_GAIN is positive or negative, depending on the association of connections between sense amplifier inputs and the sense resistor terminals. The ADC\_OFFSET is the result of electrical offsets of the phase current measurement signal path. For the TMC4671, the maximum ADC\_RAW value ADC\_RAW\_MAX =  $(2^{16}-1)$  and the minimum ADC raw value is ADC\_RAW\_MIN = 0.

For the FOC, the ADC\_RAW is scaled by the ADC scaler of the TMC4671 together with subtraction of offset to compensate it. Internally, the TMC4671 FOC engine calculates with s16 values. Thus, the ADC scaling needs to be chosen so that the measured currents fit into the s16 range. With the ADC scaler, the user can choose a scaling with physical units like [mA].



## 3.5.4 IgainADC[A/LSB] - ADC Integer Current Value to Real World Unit

Together with ADC\_I0\_SCALE and ADC\_I0\_OFFSET and ADC\_I1\_SCALE and ADC\_I1\_OFFSET, measured ADC currents represented as 16 bit signed interger numbers (s16) represent real world currents. Multiplication of integer current value with gain scaling factor in unit Ampere per LSB (Low Significant Bit) gives the real world value of current in unit Ampere.

$$I_0[A] = \text{IgainADC}[A/LSB] * \text{ADC\_I0}$$
 (3) 
$$I_1[A] = \text{IgainADC}[A/LSB] * \text{ADC\_I1}$$

Different scalings between two associated current ADC channels can be trimmed by programing ADC\_I0\_SCALE and ADC\_I1\_SCALE. The IgainADC[A/LSB] needs to be determined from ADC gain factors, ADC reference voltage selection, and actual ADC scaling factor settings.

### 3.5.5 UgainADC[V/LSB] - ADC Integer Voltage Value to Real World Unit

Measured ADC voltages represented as 16 bit signed interger numbers (s16) represent real world voltages. Multiplication of integer voltage value with gain scaling factor in unit Volt per LSB (Low Significant Bit) gives the real world value of voltage in unit Volt.

$$U[V] = UgainADC[V/LSB] * ADC_U$$
 (4)

The UgainADC[V/LSB] needs to be determined from ADC gain factors, actual ADC gains, and ADC reference voltage settings.

## 3.5.6 Measurement of Rotor Angle

Determination of the rotor angle is either done by sensors (digital encoder, analog encoder, digital Hall sensors, analog Hall sensors) or sensorless by a reconstruction of the rotor angle. Currently, there are no sensorless methods available for FOC that work in a general purpose way as a sensor down to velocity zero.

The TMC4671 does not support sensorless FOC.

### 3.5.7 Measured Rotor Angle vs. Magnetic Axis of Rotor vs. Magnetic Axis of Stator

The rotor angle, measured by an encoder, needs to be adjusted to the magnetic axis of the rotor. This is because an incremental encoder has an arbitrary orientation relative to the magnetic axis of the rotor, and the rotor has an arbitrary orientation to magnetic axis of the stator.

The direction of counting depends on the encoder, its mounting, and wiring and polarities of encoder signals and motor type. So, the direction of encoder counting is programmable for comfortable definition for a given combination of motor and encoder.



## 3.5.7.1 Direction of Motion - Magnetic Field vs. Position Sensor

For FOC it is essential, that the direction of revolution of the magnetic field is compatible with the direction of motion of the rotor position reconstructed from encoder signals: For revolution of magnetic field with positive direction, the decoder position needs to turn into the same positive direction. For revolution of magnetic field with negative direction, the decoder position needs to turn into the same negative direction.

With an absolute encoder, once adjusted to the relative orientation of the rotor and to the relative orientation of the stator, one could start the FOC without initialization of the relative orientations.

## 3.5.7.2 Bang-Bang Initialization of the Encoder

A Bang-Bang initialization is an initialization where the motor is forced with high current into a specific position. For Bang-Bang initialization, the user sets a current into direction D that is strong enough to move the rotor into the desired direction. Other initialization methods ramp up the current smoothly and adjust the current vector to rotor movement detected by the encoder.

### 3.5.7.3 Encoder Initialization using Hall Sensors

The encoder can be initialized using digital Hall sensor signals. Digital Hall sensor signals give absolute positions within each electrical period with a resolution of sixty degrees. If the Hall sensor signals are used to initialize the encoder position on the first change of a Hall sensor signal, an absolute reference within the electrical period for commutation is given.

#### 3.5.7.4 Minimum Movement Initialization of the Encoder

For minimal movement initialization of the encoder, the user slowly increases a current into direction D and adjusts an offset of the measured angle in a way that the rotor of the motor does not move during initialization while the offset of the measured angle is determined.

#### 3.5.8 Knowledge of Relevant Motor Parameters and Position Sensor (Encoder) Parameters

#### 3.5.8.1 Number of Pole Pairs of a Motor

The number of pole pairs is an essential motor parameter. It defines the ratio between electrical revolutions and mechanical revolutions. For a motor with one pole pair, one mechanical revolution is equivalent to one electrical revolution. For a motor with npp pole pairs, one mechanical revolution is equivalent to npp electrical revolutions, with  $n = 1, 2, 3, 4, \ldots$ 

Some define the number of poles NP instead of number of pole pairs NPP for a motor, which results in a factor of two that might cause confusion. For the TMC4671, we use NPP number of pole pairs.

#### 3.5.8.2 Number of Encoder Positions per Revolution

For the encoder, the number of positions per revolution (PPR) is an essential parameter. The number of positions per revolution is essential for the FOC.

Some encoder vendors give the number of lines per revolution (LPR) or just named line count (LC) as encoder parameter. Line count and positions per revolution might differ by a factor of four. This is because of the quadrature encoding - A signal and B signal with phase shift - that give four positions per



line, enabling the determination of the direction of revolution. Some encoder vendors associate counts per revolution (CPR) or pulses per revolution associated to PPR acronym.

The TMC4671 uses Positions Per Revolution (PPR) as encoder parameter.

### 3.5.9 Proportional Integral (PI) Controllers for Closed Loop Current Control

Last but not least, two PI controllers are required for the FOC. The TMC4671 is equipped with two PI controllers - one for control of torque generating current I\_Q and one to control current I\_D to zero.

#### 3.5.10 Pulse Width Modulation (PWM) and Space Vector Pulse Width Modulation (SVPWM)

The PWM power stage is a must-have for energy efficient motor control. The PWM engine of the TMC4671 just needs a couple of parameters to set PWM frequency fPWM and switching pauses for both high side switches tBBM\_H and low side switches tBBM\_L. Some control bits are for the programming of power switch polarities for maximum flexibility in the selection in gate drivers for the power MOS-FETs. An additional control bit selects SVPWM on or off. The TMC4671 allows for change of PWM frequency by a single parameter during operation.

With this, the TMC4671 is advanced compared to software solutions where PWM and SVPM configuration of CPU internal peripherals normally needs settings of many parameters.



#### 3.5.11 Orientations, Models of Motors, and Coordinate Transformations

The orientation of magnetic axes (U, V, W for FOC3 resp. X, Y for FOC2) is essential for the FOC together with the relative orientation of the rotor. Here, the rotor is modeled by a bar magnet with one pole pair (n\_pole\_pairs = 1) with magnetic axis in north-south direction.

The actual magnetic axis of the stator - formed by the motor coils - is determined by measurement of the coil currents.

The actual magnetic axis of the rotor is determined by incremental encoder or by Hall sensors. Incremental encoders need an initialization of orientation, where Hall sensors give an absolute orientation, but with low resolution. A combination of Hall sensor and incremental encoder is useful for start-up initialization.



Figure 3: Orientations UVW (FOC3) and XY (FOC2)





Figure 4: Compass Motor Model w/ 3 Phases UVW (FOC3) and Compass Motor Model w/ 2 Phases (FOC2)



# 4 Functional Description

The TMC4671 is a fully integrated controller for field-oriented control (FOC) of either one 3-phase brushless motor (FOC3) or one 2-phase stepper motor (FOC2) or, as well as 1-phase DC motor or voice coil actuator (FOC1). Containing the complete control loop core architecture (position, velocity, torque), the TMC4671 also has the required peripheral interfaces for communication with an application controller, for feedback (digital encoder, analog interpolator encoder, digital Hall with interpolator, analog inputs for current and voltage measurement), and helpful additional IOs. The TMC4671 supports highest control loop speed and PWM frequencies.

The TMC4671 is the building block which takes care of all real-time critical tasks of field-oriented motor control. It decouples the real-time field-oriented motor control and its real-time sub-tasks such as current measurement, real-time sensor signal processing, and real-time PWM signal generation from the user application layer as outlined by figure 5.



Figure 5: Hardware FOC Application Diagram

# 4.1 Functional Blocks

The Application interface, register bank, ADC engine, encoder engine, FOC torque PI controller, velocity PI controller, position P controller, and PWM engine make up the TMC4671.



Figure 6: Hardware FOC Block Diagram



The ADC engine interfaces the integrated ADC channels and maps raw ADC values to signed 16 bit (s16) values for the inner FOC current control loop based on programmable offset and scaling factors. The FOC torque PI controller forms the inner base component including required transformations (Clark, Park, inverse Park, inverse Clark). All functional blocks are pure hardware.

### 4.2 Communication Interfaces

The TMC4671 is equipped with an SPI slave user interface for access to all registers of the TMC4671. The SPI slave user interface is the main application interface.

An additional UART interface is intended for system setup. With that interface, the user can access all registers of the TMC4671 in parallel to the application accessing them via the SPI communication interface - via the user's firmware or via evaluation boards and the TMCL-IDE. The data format of the UART interface is similar to the SPI communication interface - SPI 40 bit datagrams sent to the TMC4671 and SPI 40 bit datagrams received by the MCU vs. five bytes sent via UART and five bytes received via UART. Sending a burst of different real-time data for visualization and analysis via the TMCL-IDE can be triggered using special datagrams. With that, the user can set up an embedded application together with the TMCL-IDE, without having to write a complex set of visualization and analysis functions. The user can focus on its application.

The TMC4671 is also equipped with an additional SPI master interface (TRINAMIC Real-time Monitoring Interface, DBGSPI) for high-speed visualization of real-time data together with the TMCL-IDE.

#### 4.2.1 SPI Slave User Interface

The SPI of the TMC4671 for the user application has an easy command and control structure. The TMC4671 user SPI acts as a slave. The SPI datagram length is 40 bit with a clock rate up to 8 MHz (1 MHz for the TMC4671-ES).

- The MSB (bit#39) is sent first. The LSB (bit#0) is sent last.
- The MSB (bit#39) is the WRITE\_notREAD (WRnRD) bit.
- The bits (bit#39 to bit#32) are the address bits (ADDR).
- Bits (bit#31) to (bit#0) are 32 data bits.

The SPI of the TMC4671 immediately responses within the actual SPI datagram on read and write for ease-of-use communication and uses SPI mode 3 with CPOL = 1 and CPHA = 1.

|       | 40 BIT DATAGRAM |         |  |  |  |  |  |
|-------|-----------------|---------|--|--|--|--|--|
|       | 8 BIT ADDR      | 32 DATA |  |  |  |  |  |
| WRnRD | 7 BIT ADDR      | 32 DATA |  |  |  |  |  |

Figure 7: SPI Datagram Structure

A simple SPI datagram example:

```
0x8100000000 // 1st write 0x00000000 into address 0x01 (CHIPINFO_ADDR)
0x0000000000 // 2nd read register 0x00 (CHIPINFO_DATA), returns 0x34363731 <=> ACSII "4671"
```





Figure 8: SPI Timing

| SPI Interface Timing                             | Characteristics, fCLK = 25MHz |      |     |     |      |  |  |
|--------------------------------------------------|-------------------------------|------|-----|-----|------|--|--|
| Parameter                                        | Symbol                        | Min  | Тур | Max | Unit |  |  |
| SCK valid before or after change of nSCS         | $t_{CC}$                      | 62.5 |     |     | ns   |  |  |
| nSCS high time                                   | $t_{CSH}$                     | 62.5 |     |     | ns   |  |  |
| nSCS low time                                    | $t_{CSL}$                     | 62.5 |     |     | ns   |  |  |
| SCK high time                                    | $t_{CH}$                      | 62.5 |     |     | ns   |  |  |
| SCK low time                                     | $t_{CL}$                      | 62.5 |     |     | ns   |  |  |
| SCK low time                                     | $t_{CL}$                      | 62.5 |     |     | ns   |  |  |
| tSCKpause time after read address byte           | $t_{SCKpause}$                | 500  |     |     | ns   |  |  |
| SCK frequency with tSCKpause after write address | $f_{SCKpauseWR}$              |      |     | 8   | MHz  |  |  |
| SCK frequency for write access without pause     | $f_{SCKwr}$                   |      |     | 8   | MHz  |  |  |
| SCK frequency with tSCKpause after read address  | $f_{SCKpauseRD}$              |      |     | 8   | MHz  |  |  |
| SCK frequency for read access without tSCKpause  | $f_{SCKrd}$                   |      |     | 2   | MHz  |  |  |
| MOSI setup time before rising edge of SCK        | $t_{DU}$                      | 62.5 |     |     | ns   |  |  |
| MOSI hold time after falling edge of SCK         | $t_{DH}$                      | 62.5 |     |     | ns   |  |  |
| MISO data valid time after falling edge of SCK   | $t_{DO}$                      |      |     | 10  | ns   |  |  |

Table 2: SPI Timing Parameter



1 Info

SPI write access can be performed up to 8 MHz SPI clock frequency. SPI read access can be performed up to 8 MHz SPI clock frequency if a pause of at least 500 ns is inserted after transfer of the address byte of the SPI datagram. Without a pause of 500 ns after address byte, SPI read access can be performed up to 2 MHz SPI clock frequency.



Figure 9: SPI Timing of Write Access without pause with fSCK up to 8MHz



Figure 10: SPI Timing of Read Access with pause (tPAUSE) of 500 ns with fSCK up to 8MHz.



## 4.2.2 TRINAMIC Real-Time Monitoring Interface (SPI Master)

The TRINAMIC Real-Time Monitoring Interface (RTMI, SPI Master) is an additional fast interface enabling real-time identification of motor and system parameters. The user can check configuration and access registers in the TMC4671 via the TMCL-IDE with its build-in configuration wizards for FOC setup in parallel to the user firmware. TRINAMIC provides a Monitoring Adapter to access the interface, which connects easily to a single 10 pin high density connector (Type: Hirose DF20F-10DP-1V) on the user's PCB or on the evaluation board. If the interface is not needed, pins can be left open or can be used as GPIOs according to the specification. The connector needs to be placed near the TMC4671. Its assignment is pictured in figure 11.



Figure 11: Connector for Real-Time Monitoring Interface (Connector Type: Hirose DF20F-10DP-1V)



#### 4.2.3 UART Interface

The UART interface is a simple three pin (GND, RxD, TxD) 3.3V UART interface with up to 3 Mbit/s transfer speed with one start bit, eight data bits, one stop bit, and no parity bits (1N8). The default speed is 9600 bps. Other supported speeds are 115200 bps, 921600 bps, and 3000000 bps. The speed must be changed manually in register 0x79 UART\_BPS.

1 Info

The baudrates must be entered as hexadecimal numbers. Table 3 lists the register value and its corresponding baudrate.

| Value of register 0x79 | selected baudrate |
|------------------------|-------------------|
| 0x00009600             | 9600 bps          |
| 0x00115200             | 115200 bps        |
| 0x00921600             | 921600 bps        |
| 0x03000000             | 3000000 bps       |

Table 3: Possible baudrates and corresponding values for register 0x79

With an 3.3V-UART-to-USB adapter cable (e.g. FTDI TTL-232R-RPi), the user can use the full maximum data rate. The UART port enables In-System-Setup-Support by multiple-ported register access.

An UART datagram consists of five bytes - similar to the datagrams of the SPI. In contrast to SPI, the UART interface has a time out feature. So, the five bytes of a UART datagram need to be send within one second. A pause of sending more than one second causes a time out and sets the UART protocol handler back into IDLE state. In other words, waiting for more than one second in sending via UART ensures that the UART protocol handler is in IDLE state.

A simple UART example (similar to the simple SPI example):

```
0x81 0x00 0x00 0x00 0x00 // 1st write 0x00000000 into address 0x01 (CHIPINFO_ADDR)
0x00 0x00 0x00 0x00 0x00 // 2nd read register 0x00 (CHIPINFO_DATA), returns 0x34363731
```

Why UART Interface? It might become necessary during the system setup phase to simply access some internal registers without disturbing the application, without changing the actual user application software, and without adding additional debugging code that might disturb the application software itself. The UART enables this supporting function. In addition, it also enables easy access for monitoring purposes with its very simple and direct five byte protocol. The UART interface is available to write periodically positions into the TMC4671 via an external CPU used as a protocol translator to enable absolute encoders for the TMC4671.





Figure 12: UART Read Datagram (TMC4671 register read via UART)



|                   | 40 BIT DATAGRAM (UART) WRITE response from TMC4671 |                 |             |             |                 |  |  |  |  |
|-------------------|----------------------------------------------------|-----------------|-------------|-------------|-----------------|--|--|--|--|
| 8 BIT ADDR BYTE#5 |                                                    | MSB DATA BYTE#4 | DATA BYTE#3 | DATA BYTE#2 | LSB DATA BYTE#1 |  |  |  |  |
| WRnRD             | 7 BIT ADDR                                         |                 | 32 D        | ATA         |                 |  |  |  |  |

Figure 13: UART Write Datagram (TMC4671 register write via UART)

#### 4.2.4 Step/Direction Interface

The user can manipulate the target position via the step direction interface. It can be enabled by setting the STEP\_WIDTH (s32) register to a proper step width. The power-on default value of STEP\_WIDTH is 0 that causes position target update with 0 step width that is no stepping. With STEP\_WIDTH  $\neq$  0 each step pulse on STEP input causes incrementing or decrementing of target position depending on polarity of DIR input. For positive STEP\_WIDTH, DIR = 0 causes incrementing and the DIR = 1 causes decrementing of the target position. For negative STEP\_WIDTH, DIR = 0 causes decrementing and DIR = 1 causes incrementing of the target position. This is because the STEP\_WIDTH is represented as a signed number.

## 4.2.5 Single Pin Interface

The TMC4671 can be operated in Motion Modes in which the main target value is calculated from either a PWM input signal on PIN PWM\_I or by analog input to AGPI\_A.

| Number | Motion Mode        | Using PWM_I or AGPI_A |
|--------|--------------------|-----------------------|
| 0      | Stopped Mode       | no                    |
| 1      | Torque Mode        | no                    |
| 2      | Velocity Mode      | no                    |
| 3      | Position Mode      | no                    |
| 4      | PRBS Flux Mode     | no                    |
| 5      | PRBS Torque Mode   | no                    |
| 6      | PRBS Velocity Mode | no                    |



| Number | Motion Mode          | Using PWM_I or AGPI_A |
|--------|----------------------|-----------------------|
| 7      | PRBS Position Mode   | no                    |
| 8      | UQ UD Ext Mode       | no                    |
| 9      | (reserved)           | no                    |
| 10     | AGPI_A Torque Mode   | AGPI_A                |
| 11     | AGPI_A Velocity Mode | AGPI_A                |
| 12     | AGPI_A Position Mode | AGPI_A                |
| 13     | PWM_I Torque Mode    | PWM_I                 |
| 14     | PWM_I Velocity Mode  | PWM_I                 |
| 15     | PWM_I Position Mode  | PWM_I                 |

Table 4: Single Pin Interface Motion Modes

Registers SINGLE\_PIN\_IF\_OFFSET and SINGLE\_PIN\_IF\_SCALE can be used to scale the value to desired range. In case of the PWM input, a permanent low input signal or permanent high signal is treated as input error and chosen target value is set to zero.

Register SINGLE\_PIN\_IF\_CFG configures the length of a digital filter for the PWM\_I signal. Spikes on the signal can be thereby suppressed. Bit 0 in register SINGLE\_PIN\_IF\_STATUS is set high when PWM\_I is constant low, Bit 1 is set high when the PWM\_I is constant high. Writing to this register resets these flags. Maximum PWM period of the PWM signal must be 65000 x 40 ns. The calculation of the normalized duty cycle is started on the rising edge of PWM\_I. The PWM frequency needs to be constant as big variations (tolerance of 4 us in PWM period) in the PWM frequency are treated as error.

A duty cycle of 50% equals an input value of 32768. With the offset and scaling factors it can be mapped to desired range.

#### 4.2.6 GPIO Interface

The TMC4671 has eight GPIO-pins that are arranged in group A (GPIO 0 to 3) and group B (GPIO 4 to 7). These pins can be configured using bits 0 to 6 of the register GPIO\_dsADCI\_CONFIG (0x7B). The configurations include RTMI, GPI or GPO as well as clock signals, in and out, for external delta sigma modulators. Groups A and B can individually be configured as in or outputs. Single pins within these groups can not be individually configured. Bits 16 to 19 set the GPO values for group A and bits 20 to 23 set the GPO values for group B. If configured as GPIs bits 24 to 27 display the input on group A whereas bits 28 to 31 display the input on the group B GPIs.

| GPIO_dsADCI_CONFIG (bits 6 to 0) | Configured as | group A | group B |
|----------------------------------|---------------|---------|---------|
| xxxxxx0 <sub>b</sub>             | RTMI          | 0: Z    | 4: SCK  |
|                                  |               | 1: Z    | 5: MOSI |
|                                  |               | 2: Z    | 6: MISO |
|                                  |               | 3: /CS  | 7: TRG  |
| xx11001 <sub>b</sub>             | GPIO          | GPO     | GPO     |
| $xx00001_b$                      | GPIO          | GPI     | GPI     |
| $xx01001_{b}$                    | GPIO          | GPO     | GPI     |
| xx10001 <sub>b</sub>             | GPIO          | GPI     | GPO     |



| GPIO_dsADCI_CONFIG (bits 6 to 0) | Configured as   | group A      | group B      |
|----------------------------------|-----------------|--------------|--------------|
| $11xx111_b$                      | Delta Sigma ADC | MCLK_out     | MCLK_out     |
|                                  |                 | 0: ADCI0     | 4: ADCAGPI_B |
|                                  |                 | 1: ADCI1     | 5: AENC_UX   |
|                                  |                 | 2: ADCVM     | 6: AENC_VN   |
|                                  |                 | 3: ADCAGPI_A | 7: AENC_WY   |
| $00xx111_{b}$                    | Delta Sigma ADC | MCLK_in      | MCLK_in      |
|                                  |                 | 0: ADCI0     | 4: ADCAGPI_B |
|                                  |                 | 1: ADCI1     | 5: AENC_UX   |
|                                  |                 | 2: ADCVM     | 6: AENC_VN   |
|                                  |                 | 3: ADCAGPI_A | 7: AENC_WY   |

Table 5: GPIO Configuration Overview with 'x' as don't care

1nfo

When the RTMI-option is selected it is not possible to use the GPIOs and the other way around. On default the RTMI-Mode is chosen and the unused GPIOs 0,1 and 2 are configured as inputs on high impedance Z.

# 4.3 Numerical Representation, Electrical Angle, Mechanical Angle, and Pole Pairs

The TMC4671 uses different numerical representations for different parameters, measured values, and interim results. The terms electrical angle PHI\_E, mechanical angle PHI\_M, and number of pole pairs (N\_POLE\_PAIRS) of the motor are important for setup of FOC. This section describes the different numerical representations of parameters and terms.

# 4.3.1 Numerical Representation

The TMC4671 uses signed and unsigned values of different lengths and fixed point representations for parameters that require a non-integer granularity.

| Symbol | Description                                                               | Min         | Max                              |
|--------|---------------------------------------------------------------------------|-------------|----------------------------------|
| u16    | unsigned 16 bit value                                                     | 0           | 65535                            |
| s16    | signed 16 bit values, 2'th complement                                     | -32767      | 32767                            |
| u32    | unsigned 32 bit value                                                     | 0           | 2 <sup>32</sup> = 4294967296     |
| s32    | signed 32 bit values, 2'th complement                                     | -2147483647 | 2 <sup>31</sup> - 1 = 2147483647 |
| q8.8   | signed fix point value with 8 bit integer part and 8 bit fractional part  | -32767/256  | 32767/256                        |
| q4.12  | signed fix point value with 4 bit integer part and 12 bit fractional part | -32767/4096 | 32767/4096                       |

Table 6: Numerical Representations



Two's complement of n bit is  $-2^{(n-1)}\dots-2^{(n-1)}-1$ . To avoid unwanted overflow, the range is clipped to  $-2^{(n-1)}+1\dots-2^{(n-1)}-1$ .

Because the zero is interpreted as a positive number for 2'th complement representation of integer n bit number, the smallest negative number is  $-2^{(n-1)}$  where the largest positive number is  $2^{(n-1)}-1$ . Using the smallest negative number  $-2^{(n-1)}$  might cause critical underflow or overflow. Internal clipping takes this into account by mapping  $-2^{(n-1)}$  to  $-2^{(n-1)}+1$ .

| Hexadecimal Value   | u16   | s16    | q8.8         | q4.12         |
|---------------------|-------|--------|--------------|---------------|
| 0x0000 <sub>h</sub> | 0     | 0      | 0.0          | 0.0           |
| 0x0001 <sub>h</sub> | 1     | 1      | 1 / 256      | 1 / 4096      |
| 0x0002 <sub>h</sub> | 2     | 2      | 2 / 256      | 2 / 4096      |
| 0x0080 <sub>h</sub> | 128   | 128    | 0.5          | 0.03125       |
| 0x0100 <sub>h</sub> | 256   | 256    | 1.0          | 0.0625        |
| 0x0200 <sub>h</sub> | 512   | 512    | 2.0          | 0.125         |
| 0x3FFF <sub>h</sub> | 16383 | 16383  | 16383 / 256  | 16383 / 4096  |
| 0x5A81 <sub>h</sub> | 23169 | 23169  | 23169 / 256  | 23169 / 4096  |
| 0x7FFF <sub>h</sub> | 32767 | 32767  | 32767 / 256  | 32767 / 4096  |
| 0x8000 <sub>h</sub> | 32768 | -32768 | -32768 / 256 | -32768 / 4096 |
| 0x8001 <sub>h</sub> | 32769 | -32767 | -32767 / 256 | -32767 / 4096 |
| 0x8002 <sub>h</sub> | 32770 | -32766 | -32766 / 256 | -32766 / 4096 |
| 0xC001 <sub>h</sub> | 49153 | -16383 | -16383 / 256 | -16383 / 4096 |
| 0xFFFE <sub>h</sub> | 65534 | -2     | -2 / 256     | -2 / 4096     |
| 0xFFFF <sub>h</sub> | 65535 | -1     | -1 / 256     | -1 / 4096     |

Table 7: Examples of u16, s16, q8.8, q4.12

The q8.8 and q4.12 are used for P and I parameters which are positive numbers. Note that q8.8 and q4.12 are used as signed numbers. This is because theses values are multiplied with signed error values resp. error integral values.

# 4.3.2 N\_POLE\_PAIRS, PHI\_E, PHI\_M

The parameter N\_POLE\_PAIRS defines the factor between electrical angle PHI\_E and mechanical angle PHI M of a motor (pls. refer figure 14).

A motor with one (1) pole pair turns once for each electrical period. A motor with two (2) pole pairs turns once for every two electrical periods. A motor with three (3) pole pairs turns once for every three electrical periods. A motor with four pole (4) pairs turns once for every four electrical periods.

The electrical angle PHI\_E is relevant for the commutation of the motor. It is relevant for the torque control of the inner FOC loop.



$$PHI_E = PHI_M \cdot N_POLE_PAIRS$$
 (5)

The mechanical angle PHI\_M is primarily relevant for velocity control and for positioning. This is because one wants to control the motor speed in terms of mechanical turns and not in terms of electrical turns.

$$PHI_M = PHI_E/N_POLE_PAIRS$$
 (6)

Different encoders give different kinds of position angles. Digital Hall sensors normally give the electrical position PHI\_E that can be used for commutation. Analog encoders give - depending on their resolution - angles that have to be scaled first to mechanical angles PHI\_M and to electrical angles PHI\_E for commutation.



Figure 14: N POLE PAIRS - Number of Pole Pairs (Number of Poles)

# 4.3.3 Numerical Representation of Angles PHI

Electrical angles and mechanical angles are represented as 16 bit integer values. One full revolution of  $360\deg$  is equivalent to  $2^{16}=65536$  steps. Any position coming from a sensor is mapped to this integer range. Adding an offset of PHI\_OFFSET causes a rotation of an angle PHI\_OFFSET/ $2^{16}$ . Subtraction of an offset causes a rotation of an angle PHI\_OFFSET in opposite direction.





Figure 15: Integer Representation of Angles as 16 Bit signed (s16) resp. 16 Bit unsigned (u16)

| Hexadecimal Value   | u16   | s16    | PHI[°] <sub>u16</sub> | PHI[°] <sub>s16</sub> |
|---------------------|-------|--------|-----------------------|-----------------------|
| 0x0000 <sub>h</sub> | 0     | 0      | 0.0                   | 0.0                   |
| 0x1555 <sub>h</sub> | 5461  | 5461   | 30.0                  | 30.0                  |
| 0x2AAA <sub>h</sub> | 10922 | 10922  | 60.0                  | 60.0                  |
| 0x4000 <sub>h</sub> | 16384 | 16384  | 90.0                  | 90.0                  |
| 0x5555 <sub>h</sub> | 21845 | 21845  | 120.0                 | 120.0                 |
| 0x6AAA <sub>h</sub> | 27306 | 27768  | 150.0                 | 150.0                 |
| 0x8000 <sub>h</sub> | 32768 | -32768 | 180.0                 | -180.0                |
| 0x9555 <sub>h</sub> | 38229 | -27307 | 210.0                 | -150.0                |
| 0xAAAA <sub>h</sub> | 43690 | -21846 | 240.0                 | -120.0                |
| 0xC000 <sub>h</sub> | 49152 | -16384 | 270.0                 | -90.0                 |
| 0xD555 <sub>h</sub> | 54613 | -10923 | 300.0                 | -60.0                 |
| 0xEAAA <sub>h</sub> | 60074 | -5462  | 330.0                 | -30.0                 |

Table 8: Examples of u16, s16, q8.8

The option of adding an offset is for adjustment of angle shift between the motor and stator and the rotor and encoder. Finally, the relative orientations between the motor and stator and the rotor and encoder can be adjusted by just one offset. Alternatively, one can set the counter position of an incremental encoder to zero on initial position. For absolute encoders, one needs to use the offset to set an initial position.



# 4.4 ADC Engine

The ADC engine controls the sampling, selection, scaling and offset correction of different available ADC channels. Two ADC channels are for phase current measurement, three ADC channels are for analog Hall signals or for analog sin-cos-encoder, one ADC channel is for optional measurement of the motor spupply voltage, two additional ADC channels are general purpose where one general purpose analog input can be used as analog target value by the single pin interface.

#### 4.4.1 ADC current sensing channels ADC\_I1 and ADC\_I0

The ADC channels (ADC\_I0\_POS, ADC\_I0\_NEG, ADC\_I1\_POS, ADC\_I1\_NEG) are for current sensing in differential input configuration. In differential configuration, the ADC\_I0\_POS and ADC\_I0\_POS are the inputs for the sense amplifier output signals where ADC\_I1\_NEG and ADC\_I0\_NEG) are for the zero current sensing reference of the sense amplifiers. In single ended configuration, the ADC\_I0\_POS and ADC\_I0\_POS are the inputs for the sense amplifier output signals where ADC\_I1\_NEG and ADC\_I0\_NEG) are internally connected to ground. The third current channel ADC\_I2 as required for three phase FOC is calculated using Kirchhoff's law ADC\_I2 = - (ADC\_I1 + ADC\_I0).

| 1 Info | ADC_I0_POS, ADC_I0_NEG, ADC_I1_POS, ADC_I1_NEG are low voltage analog inputs and must not directly connected to in-line sense resistors. The TMC4671 |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | requires external dfferential motor supply common mode range current sensing amplifiers for in-line current sensing.                                 |

#### 4.4.2 ADC for analog Hall signals or analog sin-cos-encoders AENC\_UX, AENC\_VN, AENC\_WY

For analog Hall and for analog encoder, the ADC engine has three disserential input channles (AENC\_UX\_POS, AENC\_UX\_NEG), (AENC\_VN\_POS, AENC\_VN\_NEG), and AENC\_WY\_POS, AENC\_WY\_NEG). The analog encoder ADC inputs can be configured single ended (AENC\_UX\_POS, AENC\_VN\_POS, AENC\_WY\_POS) with negative inputs (AENC\_UX\_NEG, AENC\_VN\_NEG, AENC\_WY\_NEG) internally connected to ground.

The three channels AENC\_UX, AENC\_VN, AENC\_WY are for three phase analog sine (with +/-120° phase shift) wave Hall signals. The Signals AENC\_UX and AENC\_WY are for two phase analog sine wave and cosin wave Hall signals. The Signals AENC\_UX and AENC\_WY are for analog sin-cos-encoder. The AENC\_VN is for an optional zero pulse channel of sin-cos-encoders. The AENC\_VN is available for read out by the application software but it is not hardware handled by the TMC4671 for position zerroing.

For long analog signal lines, it might be necessary to use external differential receivers with twisted pair line termination resistors to drive the single ended analog encoder inputs of the TMC4671.

# 4.4.3 ADC supply voltage measurement ADC\_VM

The ADC channel for measurement of supply voltage (ADC\_VM) and is associated with the brake chopper. The ADC\_VM is available as raw value only without digital scaling. This is because it is not directly processed by the FOC engine.

| <b>1</b> Info | ADC_VM must be scaled down electrically by voltage divider to the allowed volt- |
|---------------|---------------------------------------------------------------------------------|
| •             | age range, and might require additional supply voltage spike protection.        |



# 4.4.4 ADC\_VM for Brake Choppper

The ADC\_VM is available as input for optional brake chopper as raw value u16. The brake chopper thresholds have to be set as absolute u16 values to activate and deactivate the brake chopper output depending on the ADC\_VM value.

#### 4.4.5 ADC EXT register option

The user can write ADC values into the ADC\_EXT registers of the register bank from external sources or for evaluation purposes. These values can be selected as raw current ADC values by selection. ADC\_EXT registers are primarily intended for test purposes as optional inputs for external current measurement sources.

# 4.4.6 ADC general purpose analog inputs AGPI\_A and AGPI\_B

Two general purpose ADC channels are single-ended analog inputs (AGPI\_A, AGPI\_B). The general purpose analog ADC inputs AGPI\_A and AGPI\_B are available as raw values only without digital scaling. This is because these values are not directly processed by the FOC engine. These general purpose analog inputs (AGPI) are intended to monitor analog voltage signals representing MOSFET temperature or motor temperature. They are two additional ADC channels for the user. Optional, the AGPI\_A is availabe as analog target value signal.

#### 4.4.7 ADC RAW values

The sampled raw ADC values are available for read out by the user. This is important during the system setup phase to determine offset and scaling factors.

#### 4.4.8 ADC\_SCALE and ADC\_OFFSET

The FOC engine expects offset corrected ADC current values scaled to the used 16 bit (s16) fixed point representation. The integrated scaler and offset compensator maps raw ADC samples of current measurement channels to 16 bit two's complement values (s16). While the offset is compensated by subtraction, the offset is represented as an unsigned value. The scaling value is signed to compensate wrong measurement direction. The s16 scaled ADC values are available for read out from the register (ADC\_I1, ADC\_I0) resp. (AENC\_UX, AENC\_VN, AENC\_WY) by the user.

| 1 Info | Wrong scaling factors (ADC_SCALE) or wrong offsets (ADC_OFFSET) might cause     |
|--------|---------------------------------------------------------------------------------|
| •      | damages when the FOC is active. Integrated hardware limiters allow protection - |
|        | especially in the setup phase when using careful limits.                        |

# 4.4.9 ADC Gain Factors for Real World Values

Each ADC channel of the TMC4671 has an individual gain factor determined by its associated chain of gain factors and by digital scaling factors if available for an ADC channel. ADC register values are either 16 bit unsigned vaulues (u16) or 16 bit signed vaules (s16). With gain factors one can calculate ADC values as real world values if required.



Gain factors IgainADC for ADC current values are typical in units [A/LSB] or [mA/LSB]. Gain factors UgainADC for ADC voltage values are typical in units [V/LSB] or [mV/LSB].

$$ADC measured Voltage[V] = Ugain ADC[V/LSB] * ADC_VOLTAGE_S16$$
 (8)

### 4.4.10 Internal Delta Sigma ADCs

The TMC4671 is equipped with internal delta sigma ADCs for current measurement, supply voltage measurement, analog GPIs and analog encoder signal measurement. Delta sigma ADCs, as integrated within the TMC4671, together with programmable digital filters are flexible in parameterizing concerning resolution vs. speed. The advantage of delta sigma ADCs is that the user can adjust measurement from lower speed with higher resolution to higher speed with lower resolution. This fits with motor control application. Higher resolution is required for low speed signals, while lower resolution satisfies the needs for high speed signals.

Due to high oversampling, the analog input front-end is easier to implement than for successive approximation register ADCs as anti aliasing filters can be chosen to a much higher cutoff frequency. The ADC Engine processes all ADC channels in parallel hardware - avoiding phase shifts between the channels compared to ADC channels integrated in MCUs.

#### 4.4.11 Internal Delta Sigma ADC Input Stage Configuration

ADC channels can be configured either as differential ended analog inputs (ADC\_I0, ADC\_I1, AENC\_UX, AENC\_VN, AENC\_WY) or as single ended analog inputs (ADC\_VM, AGPI\_A, AGPI\_B). Additionally, the ADC all channels can be set to fixed voltages (0V, VREF/4, VREF/2, 3\*VREF/4) for calibrations purposes.

| STAGE_CFG(n+2:n) | CONFIGURATION | DESCRIPTION                       | COMMENT                      |
|------------------|---------------|-----------------------------------|------------------------------|
| 0                | INP vs. INN   | differential mode                 | default configuration        |
| 1                | GND vs. INN   | single ended negative INN vs. GND | (for test purposes only)     |
| 2                | VDD/4         | 25% ADC reference voltage         | calibration aid              |
| 3                | 3*VDD/4       | 75% ADC reference voltage         | calibration aid              |
| 4                | INP vs. GND   | single ended mode INP vs. GND     | (half voltage range, offset) |
| 5                | VDD/2         | 50% ADC reference voltage         | calibration aid              |
| 6                | VDD/4         | 25% ADC reference voltage         | (redundant configuration)    |
| 7                | 3*VDD/4       | 75% ADC reference voltage         | (redundant configuration)    |

Table 9: Delta Sigma ( $\Delta\Sigma$ ) ADC Input Stage Configurations

The three bit vector ADC\_STAGES\_CFG(n+2:n) is part of the DS\_ANALOG\_INPUT\_STAGE\_CFG(31:0) with  $n=0,\,4,\,8,\,12,\,16,\,20,\,24,\,28$  for the eight delta sigma ADC channels. DS\_ANALOG\_INPUT\_STAGE\_CFG



configures the associated delta sigma ADC input stages according to table 17. For association of the bit position (bit n+2 to bit n) refere register bank section 7.2.

| STAGE_CFG(n+2:n) | ADC channel | function                                 |
|------------------|-------------|------------------------------------------|
| STAGE_CFG(2:0)   | ADC_I0      | sense voltage of current I0              |
| STAGE_CFG(6:4)   | ADC_I1      | sense voltage of current I1              |
| STAGE_CFG(9:8)   | ADC_VM      | down divided supply voltage              |
| STAGE_CFG(10)    | ′1′         | fixed for ADC_VM (STAGE_CFG=4,5,6,7)     |
| STAGE_CFG(13:12) | ADC_AGPI_A  | general purpose analog input A           |
| STAGE_CFG(14)    | ′1′         | fixed for ADC_AGPI_A (STAGE_CFG=4,5,6,7) |
| STAGE_CFG(17:16) | ADC_AGPI_B  | general purpose analog input B           |
| STAGE_CFG(18)    | ′1′         | fixed for ADC_AGPI_B (STAGE_CFG=4,5,6,7) |
| STAGE_CFG(22:20) | ADC_AENC_UX | analog Hall UX / analog encoder COS      |
| STAGE_CFG(26:24) | ADC_AENC_VN | analog Hall V / analog encoder N         |
| STAGE_CFG(30:28) | ADC_AENC_WY | analog Hall WY / analog encoder SIN      |

Table 10: Delta Sigma ( $\Delta\Sigma$ ) ADC Input Stage Configurations



Figure 16: Input Voltage Ranges of internal Delta Sigma ADC Channels)



Figure 16 illustrates typical relation between input voltage and corresponding raw ADC output. For differential operation the input range between 25% and 75% corresponds to voltage values between 1.25V to 3.75V. This is the recommended operation area of the ADC. Below 25% and above 75% the ADC shows significant non-linearity due to the Delta Sigma measurement principle.

In single ended operation the recommended input range starts at 0V and ends at 1.25V. Measurement below GND might be distorted and is not recommended.

1 Info

Due to manufacturing tolerances calibration of offset and amplitude is always recommended. Please also consider stability of the reference voltage.

## 4.4.12 External Delta Sigma ADCs

The delta sigma front-end of the ADC engine supports external delta sigma modulators to enable isolated delta sigma modulators for the TMC4671. Additionally, the delta sigma front-end supports low-cost comparators together with two resistors and one capacitor (R-C-R-CMP) forming first order delta sigma modulators, as generic analog front-end for pure digital variants of the TMC4671 core.

### 4.4.13 ADC Group A and ADC Group B

ADC channels of the TMC4671 are grouped into two groups, to enable different sample rates for two groups of analog signals if needed. Running both ADC groups with same sampling frequency is recommended for almost all applications. It might be necessary to run its ADC channels of analog encoder with a much higher frequency than the ADC channels for current measurement in case of using a high resolution analog encoder.

# 4.4.14 Delta Sigma Configuration and Timing Configuration

The delta sigma configuration is programmed via MCFG register that selects the mode (internal/external delta sigma modulator with programmable MCLK; delta sigma modulator clock mode (MCLK output, MCLK input, MCLK used as MDAC output with external R-C-R-CMP configuration); delta sigma modulator clock and its polarity; and the polarity of the delta sigma modulator data signal MDAT).

1 Info

The power-on delta sigma configuration should fit with most applications when using the intergated delta sigma ADCs of the TMC4671. Primarily, the default delta sigma configuration needs to be adapted when using external delta sigma modulators or to select differential ADC input configurations, or in case of enhanced sampling requirenment for high resolution analog encoders.





Figure 17: Delta Sigma ADC Configurations dsADC\_CONFIG (internal: ANALOG vs. external: MCLKO, MCLKI, MDAC)

| dsADC_CONFIG | Description                                                                                | NC_MCLKO_MCLKI_MDAC      | VIN_MDAT           |
|--------------|--------------------------------------------------------------------------------------------|--------------------------|--------------------|
| ANALOG       | integrated internal ADC mode, VIN_MDAT is analog input VIN                                 | MCLK not connected (NC)  | VIN (analog)       |
| MCLKO        | external dsModulator (e.g. AD7403) with MCLK input driven by MCLKO                         | MCLK output              | MDAT input         |
| MCLKI        | external dsModulator (e.g. AD7400) with MCLK output that drives MCLKI                      | MCLK input               | MDAT input         |
| MDAC         | external dsModulator (e.g. LM339) realized by external comparator CMP with two R and one C | MDAC output (= MCLK out) | MDAT input for CMP |

Table 11: Delta Sigma ADC Configurations (figure 17), selected with dsADC\_MCFG\_A and dsADC\_MCFG\_B.



| register     | function                                                                       |
|--------------|--------------------------------------------------------------------------------|
| dsADC_MCFG_B | delta sigma modulator configuration MCFG (ANALOG, MCLKI, MCLKO, MDAC), group B |
| dsADC_MCFG_A | delta sigma modulator configuration MCFG (ANALOG, MCLKI, MCLKO, MDAC), group A |
| dsADC_MCLK_B | delta sigma modulator clock MCLK, group B                                      |
| dsADC_MCLK_A | delta sigma modulator clock MCLK, group A                                      |
| dsADC_MDEC_B | delta sigma decimation parameter MDEC, group B                                 |
| dsADC_MDEC_A | delta sigma decimation parameter MDEC, group A                                 |

Table 12: Registers for Delta Sigma Configuration

## 4.4.14.1 Timing Configuration MCLK

When the programmable MCLK is selected, the MCLK\_A and MCLK\_B parameter registers define the programmable clock frequency fMCLK of the delta sigma modulator clock signal MCLK for delta sigma modulator group A and group B. For a given target delta sigma modulator frequency fMCLK, together with the internal clock frequency fCLK = 100MHz, the MCLK frequency parameter is calculated by

$$\mathsf{MCLK} = 2^{31} \cdot \mathsf{fMCLK}[Hz]/\mathsf{fCLK}[Hz] \tag{10}$$

Due to the 32 bit's length of the MCLK frequency parameter, the resulting frequency fMCLK might differ from the desired frequency fMCLK. The back calculation of the resulting frequency fMCLK for a calculated MCLK parameter with 32 bit length is defined by

$$\mathsf{fMCLK}[Hz] = \mathsf{fCLK}[Hz] \cdot \mathsf{MCLK}/2^{31} \tag{11}$$

The precise programming of the MCLK frequency is primarily intended for external delta sigma modulators to meet given EMI requirements. With that, the user can programm frequencies fMCLK with a resolution better than 0.1 Hz. This advantage concerning EMI might cause trouble when using external delta sigma modulators if they are sensitive to slight frequency alternating. This is not an issue when using external first-order delta sigma modulators based on R-C-R-CMP (e.g. LM339). But for external second-order delta sigma modulators, it is recommended to configure the MCLK parameter for frequencies fMCLK with kHz quantization (e.g. 10,001,000 Hz instead of 10,000,001 Hz).

| fMCLK_target | MCLK       | fMCLK_resulting    | comment                                             |
|--------------|------------|--------------------|-----------------------------------------------------|
| 25 MHz       | 0x20000000 | 25 MHz             | w/o fMCLK frequency jitter, recommended             |
| 20 MHz       | 0x19000000 | 20 MHz -468750 Hz  | recommended for ext. $\Delta\Sigma$ modulator       |
| 20 MHz       | 0x19999999 | 20 MHz -0.03 Hz    | might be critical for ext. $\Delta\Sigma$ modulator |
| 12.5 MHz     | 0x10000000 | 12.5 MHz           | w/o fMCLK frequency jitter, recommended             |
| 10 MHz       | 0x0CCCCCC  | 10 MHz -0.04 Hz    | might be critical for ext. $\Delta\Sigma$ modulator |
| 10 MHz       | 0x0CC00000 | 10 MHz -39062.5 Hz | recommended for ext. $\Delta\Sigma$ modulator       |

Table 13: Delta Sigma MCLK Configurations



#### 4.4.14.2 Decimation Parameter MDEC

The high oversampled single bit delta sigma data stream (MDAT) is digitally filtered by Sinc3 filters. To get raw ADC data, the actual digitally filtered values need to be sampled periodically with a lower rate called decimation ratio. The decimation is controlled by parameter MDEC\_A for ADC group A and MDEC\_B for ADC group B. A new ADC\_RAW value is available after MDEC delta sigma pulses of MCLK. As such, the parameters MCLK and MDEC together define the sampling rate of the 16 bit ADC\_RAW values.

The delta sigma modulator with Sinc3 filter works with best noise reduction performance when the length of the step response time tSINC3 of the Sinc3 filter is equal to the length of the PWM period tPWM = (PWM\_MAXCNT+1) / fPWMCLK = ((PWM\_MAXCNT+1) \* 10 ns) of the period. The length of the step function response of a Sinc3 filter is

$$tSINC3 = (3 \cdot (MDEC - 1) + 1) \cdot tMCLK \tag{12}$$

$$MDEC_{recommended} = \frac{tPWM}{3 \cdot tMCLK} - 2$$
 (13)

| fMCLK    | tMCLK  | MDEC25 (25 kHz, 40μs) | MDEC50 (50 kHz, 20μs) | MDEC100 (100 kHz, 10μs) |
|----------|--------|-----------------------|-----------------------|-------------------------|
| 50 MHz   | 20 ns  | 665                   | 331                   | 165                     |
| 25 MHz   | 40 ns  | 331                   | 165                   | 81                      |
| 20 MHz   | 50 ns  | 265                   | 131                   | 65                      |
| 12.5 MHz | 80 ns  | 165                   | 81                    | 40                      |
| 10 MHz   | 100 ns | 131                   | 65                    | 31                      |

Table 14: Optimal Decimation Parameter MDEC (according to equation (13) for different PWM frequencies fPWM (MDEC25 for fPWM=25kHz w/ PWM\_MAXCNT=3999, MDEC50 for fPWM=50kHz w/ PWM\_MAXCNT=1999, MDEC100 for fPWM=100kHz w/ PWM\_MAXCNT=999).

| 1 Info | MDEC parameter can be changed during operation. This enables adaptive adjustment of performance with respect to resolution versus speed on demand. |  |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        | For most applications, the power-on decimation setting of MDEC should be sufficient.                                                               |  |  |  |  |



# 4.4.15 Internal Delta Sigma Modulators - Mapping of V\_RAW to ADC\_RAW

Generally, delta sigma modulators work best for a typical input voltage range of  $25\% \, V_MAX \dots 75\% \, V_MAX$  (unsigned  $0\% \dots 100\%$ ) resp. -75%  $V_MAX \dots +75\% \, V_MAX$  (signed -100% ... +100%). For the integrated delta sigma modulators, this input voltage operation range is recommended with  $V_MAX = 5V$  where  $V_MAX = 3.3V$  is possible. The table 15 defines the recommended voltage ranges for both 5V and 3.3V analog supply voltages.

| V_SUPPLY[V] | (V_MIN[V]) | V_MIN25%[V] | V_MAX50%[V] | V_MAX75%[V] | (V_MAX[V]) |
|-------------|------------|-------------|-------------|-------------|------------|
| (3.3)       | (0.0)      | (0.825)     | (1.65)      | (2.75)      | (3.3)      |
| 5.0         | (0.0)      | 1.250       | 2.50        | 3.75        | (5.0)      |

Table 15: Recommended input voltage range from V\_MIN25%[V] to V\_MAX75%[V] for internal Delta Sigma Modulators; V\_SUPPLY[V] = 5V is recommended for the analog part of the TMC4671.

$$V_{RAW} = \begin{cases} V_{MAX} & \text{for} & V_{IN} > V_{MAX} \\ (V_{IN} - V_{REF}) & \text{for} & V_{MIN} < (V_{IN} - V_{REF}) < V_{MAX} \\ V_{MIN} & \text{for} & V_{IN} < V_{MIN} \end{cases}$$
(14)

The resulting raw ADC value is

$$\label{eq:add_rate} \text{ADC\_RAW} = (2^{\mbox{$16$}} - 1) \cdot \frac{\mbox{$V\_RAW$}}{\mbox{$V\_MAX$}} \qquad \text{for} \qquad \mbox{$V\_MIN25\%[V]$} < \mbox{$V\_RAW$} < \mbox{$V\_MAX75\%[V]$}. \tag{15}$$

The idealized expression (equation 14) is valid for recommended voltage ranges (table 15) neglecting deviations in linearities. These deviations primarily depend on different impedance on the analog signal path, but also on digital parameterization. Finally, the deviation is quantified in terms of resulting ADC resolution. So, the Delta Sigma ADC engine maps the analog input voltages V\_RAW = V\_IN - V\_REF of voltage range V\_MIN < V\_RAW < V\_MAX to ADC\_RAW values of range  $\{0\dots(2^{16})-1\} <=>\{0\dots65535\} <=>0x0000\dots0xFFFF.$ 

| Vmin[V] | Vref[V] | Vmax[V] | VIN[V] | DUTY[%] | ADC_RAW  |
|---------|---------|---------|--------|---------|----------|
| 0.0     | 2.5     | 5.0     | (0.0)  | (0%)    | (0x0000) |
| 0.0     | 2.5     | 5.0     | 1.0    | 25%     | 0x4000   |
| 0.0     | 2.5     | 5.0     | 2.5    | 50%     | 0x7fff   |
| 0.0     | 2.5     | 5.0     | 3.75   | 75%     | 0xC000   |
| 0.0     | 2.5     | 5.0     | (5.0)  | (100%)  | (0xffff) |

Table 16: Delta Sigma input voltage mapping of internal Delta Sigma Modulators



For calibrating purposes, the input voltage of the delta sigma ADC inputs can be programmed to fixed voltages (25%, 50%, 75% of analog supply voltage) via the associated configuration register DS\_ANALOG\_INPUT\_STAGE\_CFG.



## 4.4.16 External Delta Sigma Modulator Interface

The TMC4671 is equipped with integrated digital filters for extraction of ADC raw values from delta sigma data stream for both internal and external delta sigma modulators. The interface for external delta sigma modulators is intended for external isolated sigma delta modulators, such as AD7401 (with MCLK input driven by TMC4671), or AD7402 (with MCLK output to drive TMC4671). In addition, the external delta sigma interface supports the use of simple comparator with a R-C-R network as external low cost delta sigma modulators (R-C-R-CMP, e.g. LM339).



When selecting the external delta sigma ADC Interface, the high-performance Debug SPI Interface (RTMI) it not available in parallel due to pin sharing. The UART is always available, but with less performance than the RTMI.

Each external delta sigma modulator channel (dsMOD) has two signals (pls. refer figure 17), one dedicated input, and one programmable input/output. The configuration of the external delta sigma modulator interface is defined by programming associated registers. When selecting external delta sigma ADC, the associated analog ADC inputs are configured as digital inputs for the delta sigma signal data stream MDAT.

# 4.4.16.1 External Delta Sigma Modulator Interface - MDAC Configuration



Figure 18:  $\Delta\Sigma$  ADC Configuration - MDAC (Comparator-R-C-R as  $\Delta\Sigma$ -Modulator)

In the MDAC delta sigma modulator, the delay of the comparator CMP determines the MCLK of the comparator modulator. A capacitor  $C_{MCCMP}$  within a range of 100 pF ...1nF fits in most cases. The time constant  $\tau$ RC should be in a range of 0.1 tCMP ...tCMP of the comparator. The resistors should be in the range of 1K to 10K. The fMAXtyp depends also on the choice of the decimation ratio.

| CMP   | tCMPtyp [ns] | $R_{MCMP}\left[k\Omega\right]$ | $R_{MDAC}\left[k\Omega\right]$ | $C_{MCMP}\left[pF\right]$ | fMCLKmaxTYP |
|-------|--------------|--------------------------------|--------------------------------|---------------------------|-------------|
| LM339 | 1000         | 1                              | 1                              | 100                       | 1 MHz       |
| LM339 | 1000         | 10                             | 10                             | 100                       | 100 kHz     |
| LM339 | 1000         | 100                            | 100                            | 100                       | 10 kHz      |

Table 17: Delta Sigma R-C-R-CMP Configurations (pls. refer 17)



For external Delta Sigma R-C-R-CMP modulators, one gets the Delta Sigma input voltage mapping according to table 18. The support of low-cost external comparators used as first order delta sigmal modulators is intended as an generic analog interface option for compatibility of the TMC4671 core in case it would be embedded within a pure digital technology environment.

| Vmin[V] | Vref[V] | Vmax[V] | VIN[V] | DUTY[%] | ADC_RAW |
|---------|---------|---------|--------|---------|---------|
| 0.0     | 1.65    | 3.3     | 0.0    | 0%      | 0x0000  |
| 0.0     | 1.65    | 3.3     | 0.825  | 25%     | 0x4000  |
| 0.0     | 1.65    | 3.3     | 1.65   | 50%     | 0x7fff  |
| 0.0     | 1.65    | 3.3     | 2.475  | 75%     | 0xC000  |
| 0.0     | 1.65    | 3.3     | 3.3    | 100%    | 0xffff  |
| Vmin[V] | Vref[V] | Vmax[V] | VIN[V] | DUTY[%] | ADC_RAW |
| 0.0     | 2.5     | 5.0     | 0.0    | 0%      | 0x0000  |
| 0.0     | 2.5     | 5.0     | 1.0    | 25%     | 0x4000  |
| 0.0     | 2.5     | 5.0     | 2.5    | 50%     | 0x7fff  |
| 0.0     | 2.5     | 5.0     | 3.75   | 75%     | 0xC000  |
| 0.0     | 2.5     | 5.0     | 5.0    | 100%    | 0xffff  |

Table 18: Delta Sigma input voltage mapping of external comparator (CMP)



# 4.5 Analog Signal Conditioning

The range of measured coil currents, resp. the measured voltages of sense resistors, needs to be mapped to the valid input voltage range of the delta sigma ADC inputs. This analog preprocessing is the task of the analog signal conditioning.

#### 4.5.0.1 Chain of Gains for ADC Raw Values

An ADC raw value is a result of a chain of gains that determine it. A coil current I\_SENSE flowing through a sense resistor causes a voltage difference according to Ohm's law. Finally, a current is mapped to an ADC raw value

$$ADC_RAW = (I_SENSE \cdot ADC_GAIN) + ADC_OFFSET.$$
 (16)

The ADC\_GAIN is a result of a chain of gains with individual signs. The sign of the ADC\_GAIN is positive or negative, depending on the association of connections between sense amplifier inputs and the sense resistor terminals. The ADC\_OFFSET is the result of electrical offsets of the phase current measurement signal path. For the TMC4671, the maximum ADC\_RAW value is ADC\_RAW\_MAX =  $(2^{16}-1)$  and the minimum ADC raw value is ADC\_RAW\_MIN = 0.

| Rsense $[m\Omega]$ | Isense $[A]$ | Usense $[mV]$ | GAIN[V/V] | $ADC\_GAIN[A/V]$ | Sense Amplifier |
|--------------------|--------------|---------------|-----------|------------------|-----------------|
| 5                  | 10           | 50            | 20        | 10               | AD8418          |
| 10                 | 5            | 50            | 20        | 5                | AD8418          |

Table 19: Example Parameters for ADC\_GAIN

For the FOC, the ADC\_RAW is scaled by the ADC scaler of the TMC4671 together with subtraction of offset to compensate it. Internally, the TMC4671 FOC engine calculates with s16 values. So, the ADC scaling needs to be chosen so that the measured currents fit into the s16 range. With the ADC scaler, the user can choose a scaling with physical units like [mA]. A scaling to [mA] covers a current range of  $-32A\ldots +32A$  with m[A] resolution. For higher currents, the user can choose unusual units like centi Ampere [cA] covering  $-327A\ldots +327A$  or deci Ampere  $-3276A\ldots +3276A$ .

ADC scaler and offset compensators are for mapping raw ADC values to s16 scaled and offset cleaned current measurement values that are adequate for the FOC.

#### 4.5.1 FOC3 - Stator Coil Currents I\_U, I\_V, I\_W and associated Voltages U\_U, U\_V, U\_W

The correct association between stator terminal voltages U\_U, U\_V, U\_W and stator coil currents I\_U, I\_V, I\_W is essential for the FOC.

For three-phase motors with three terminals U, V, W, the voltage U\_U is in phase with the current I\_U, U\_V is in phase with I\_V, and U\_W is in phase with I\_W according to equations (18) and (19) for FOC3.



$$U_{L}UVW_{FOC3}(U_{D}, PHI_{E}) = \begin{cases} U_{U}(\phi_{e}) = U_{D} & \cdot & sin(\phi_{e}) \\ U_{V}(\phi_{e}) = U_{D} & \cdot & sin(\phi_{e} + 120^{o}) \\ U_{W}(\phi_{e}) = U_{D} & \cdot & sin(\phi_{e} - 120^{o}) \end{cases}$$

$$(18)$$

I\_UVW\_FOC3(I\_D, PHI\_E) = 
$$\begin{cases} I_U(\phi_e) = I_D & \cdot & sin(\phi_e) \\ I_V(\phi_e) = I_D & \cdot & sin(\phi_e + 120^o) \\ I_W(\phi_e) = I_D & \cdot & sin(\phi_e - 120^o) \end{cases}$$
 (19)

# 4.5.2 FOC2 - Stepper Coil Currents I\_X, I\_Y and associated Voltages U\_X, U\_Y

For two-phase motors (stepper) with four terminals UX1, VX2, and WY1, Y2, voltage  $U_Ux = U_X1 - U_X2$  is in phase with the measured current  $I_X$  and  $U_Wy = U_Y1 - U_Y2$  is in phase with the measured current  $I_Y$  according to equations (20) and (21) for FOC2.

$$U_XY_FOC2 = \begin{cases} U_X(\phi_e) = U_X & \cdot & sin(\phi_e) \\ U_Y(\phi_e) = U_Y & \cdot & sin(\phi_e + 90^o) \end{cases}$$
 (20)

I\_XY\_FOC2 = 
$$\begin{cases} I_X(\phi_e) = I_D & \cdot & sin(\phi_e) \\ I_Y(\phi_e) = I_D & \cdot & sin(\phi_e + 90^o) \end{cases}$$
 (21)

# 4.5.3 FOC1 - DC Motor Coil Current I\_X1, I\_X2, and associated Voltage U\_X1, U\_X2

For DC motor with with two terminals UX1, VX2, voltage  $U_X = U_X1 - U_X2$  is in phase (same sign) with the measured current  $I_X$ .  $U_X$  is in phase (same sign) with the measured current  $I_X$  according to equations (22) and (23) for FOC1.

$$U_XY_FOC1 = U_{X1} - V_{X2}$$
 (22)

$$I_XY_FOC1 = I_{X1}$$
 (23)



#### 4.5.4 ADC Selector & ADC Scaler w/ Offset Correction

The ADC selector selects ADC channels for FOC. The 3-phase FOC uses two ADC channels for measurement and calculates the third channel via Kirchhoff's Law using the scaled and offset-corrected ADC values. The 2-phase FOC just uses two ADC channels because for a 2-phase stepper motor, the two phases are independent from each other.

**Note**The open-loop encoder is useful for setting up ADC channel selection, scaling, and offset by running a motor open-loop.

The FOC23 Engine processes currents as 16 bit signed (s16) values. Raw ADC values are expanded to 16 bit width, regardless of their resolution. With this, each ADC is available for read out as a 16 bit number. The ADC scaler w/ offset correction is for the preprocessing of measured raw current values. It might be used to map to user's own units (e.g. A or mA). For scaling, gains of current amplifiers, reference voltages, and offsets have to be taken into account.





Figure 19: ADC Selector & Scaler w/ Offset Correction

ADC offsets and ADC scalers for the analog current measurement input channels need to be programmed into the associated registers. Each ADC\_I\_U, ADC\_I\_V, ADC\_I0\_EXT, and ADC\_I1\_EXT are mapped either to ADC\_I0\_RAW or to ADC\_I1\_RAW by ADC\_I0\_SELECT and ADC\_I1\_SELECT.



In addition, the ADC\_OFFSET is for conversion of unsigned ADC values into signed ADC values as required for the FOC. For FOC3, the third current ADC\_I2 is calculated via Kirchhoff's Law. This requires the correct scaling and offset correction beforehand. For FOC2, there is no calculation of a third current. The scaling factors ADC\_I0\_SCALE and ADC\_I1\_SCALE are displayed in a Q8.8 format which results in the following equations:

$$ADC_I0 = (ADC_I0_RAW - ADC_I0_OFFSET) \cdot ADC_I0_SCALE / 256$$
 (24)

$$ADC_{I1} = (ADC_{I1}_{RAW} - ADC_{I1}_{OFFSET}) \cdot ADC_{I1}_{SCALE} / 256$$
(25)

The ADC\_UX\_SELECT selects one of the three ADC channels ADC\_I0, ADC\_I1, or ADC\_I2 for ADC\_UX.

The ADC\_V\_SELECT selects one of the three ADC channels ADC\_I0, ADC\_I1, or ADC\_I2 for ADC\_V.

The ADC\_WY\_SELECT selects one of the three ADC channels ADC\_I0, ADC\_I1, or ADC\_I2 for ADC\_WY.

The ADC UX, ADC V, and ADC WY are for the FOC3 (U, V, W).

The ADC UX and ADC WY (X, Y) are for the FOC2 (UX, WY).

Note

The open-loop encoder is useful to run a motor open loop for setting up the ADC channel selection with correct association between phase currents I\_U, I\_V, I\_W and phase voltages U\_U, U\_V, U\_W.

# 4.6 Encoder Engine

The encoder engine is an unified position sensor interface. It maps the selected encoder position information to electrical position (phi\_e) and to mechanical position (phi\_m). Both are 16 bit values. The encoder engine maps single turn positions from position sensors to multi-turn positions. The user can overwrite the multi-turn position for initialization.

The different position sensors are the position sources for torque and flux control via FOC, for velocity control, and for position control. The PHI\_E\_SELECTION selects the source of the electrical angle phi\_e for the inner FOC control loop. VELOCITY\_SELECTION selects the source for velocity measurement. With phi\_e selected as source for velocity measurement, one gets the electrical velocity. With the mechanical angle phi\_m selected as source for velocity measurement, one gets the mechanical velocity taking the set number of pole pairs (N\_POLE\_PAIRS) of the motor into account. Nevertheless, for a highly precise positioning, it might be useful to do positioning based on the electrical angle phi\_e.

# 4.6.1 Open-Loop Encoder

For initial system setup, the encoder engine is equipped with an open-loop position generator. This allows for turning the motor open-loop by specifying speed in rpm and acceleration in rpm/s, together with a voltage UD\_EXT in D direction. As such, the open-loop encoder is not a real encoder. It simply gives positions as an encoder does. The open-loop decoder has a direction bit to define direction of motion for the application.



#### Note

The open-loop encoder is useful for initial ADC setup, encoder setup, Hall signal validation, and for validation of the number of pole pairs of a motor. The open-loop encoder turns a motor open with programmable velocity in unit [RPM] with programmable acceleration in unit [RPM/s].

With the open-loop encoder, the user can turn a motor without any position sensor and without any current measurement as a first step of doing the system setup. With the turning motor, the user can adjust the ADC scales and offsets and set up positions sensors (Hall, incremental encoder, ...) according to resolution, orientation, and direction of rotation.

#### 4.6.2 Incremental ABN Encoder

The incremental encoders give two phase shifted incremental pulse signals A and B. Some incremental encoders have an additional null position signal N or zero pulse signal Z. An incremental encoder (called ABN encoder or ABZ encoder) has an individual number of incremental pulses per revolution. The number of incremental pulses define the number of positions per revolution (PPR). The PPR might mean pulses per revolution or periods per revolution. Instead of positions per revolution, some incremental encoder vendors call these CPR counts per revolution.

The PPR parameter is the most important parameter of the incremental encoder interface. With that, it forms a modulo (PPR) counter, counting from 0 to (PPR-1). Depending on the direction, it counts up or down. The modulo PPR counter is mapped into the register bank as a dual ported register. The user can overwrite it with an initial position. The ABN encoder interface provides both the electrical position and the multi-turn position, which are accessible through dual-ported read-write registers.

#### Note

The PPR parameter must be set exactly according to the used encoder.



Figure 20: Number of Pole Pairs NPP vs. mechanical angle phi\_m and electrical angle phi\_e



The goal of the initialization of an incremental encoder is to set it up so that the magnetic axis of the rotor fits with the electrical angle phi\_e with the angle zero on D axis. For this, one needs to know the number of pole pairs NPP, the resolution of the incremental encoder in pulses per revolution PPR, and the orientation between measured encoder angle of the rotor and the electrical angle of the field orientation. An encoder measures mechanical angle phi\_m were the FOC needs the electrical angle phi\_e for commutation. The number of pole pairs NPP determines the ratio between mechanical angle phi\_m and electrical angle phi\_e. The parameters phi\_m\_offset and phi\_e\_offset are for compensation of differences in orientation angle by adjustments.



Figure 21: ABN Incremental Encoder N Pulse

The N pulse from an encoder triggers either sampling of the actual encoder count to fetch the position at the N pulse or it re-writes the fetched n position on an N pulse. The N pulse can either be used as stand alone pulse or and-ed with NAB = N and A and B. It depends on the decoder what kind of N pulse has to be used - either N or NAB. For those encoders with precise N pulse within one AB quadrant, the N pulse must be used. For those encoders with N pulse over four AB quadrants the user can enhance the precision of the N pulse position detection by using NAB instead of N.

| Note  | Incremental encoders are available with N pulse and without N pulse.  |
|-------|-----------------------------------------------------------------------|
| 71010 | meremental encoders are available with in palse and without in palse. |

The polarity of N pulse, A pulse and B pulse are programmable. The N pulse is for re-initialization with each turn of the motor. Once fetched, the ABN decoder can be configured to write back the fetched N pulse position with each N pulse.

| Note | The ABN encoder interface has a direction bit to set to match wiring of motor to |
|------|----------------------------------------------------------------------------------|
|      | direction of encoder.                                                            |

Logical ABN = A and B and N might be useful for incremental encoders with low resolution N pulse to enhance the resolution. On the other hand, for incremental encoders with high resolution N pulse a logical ABN = A and B and N might totally suppress the resulting N pulse.





Figure 22: Encoder ABN Timing - high precise N pulse and less precise N pulse

## 4.6.3 Secondary Incremental ABN Encoder

For commutating a motor with FOC, the user selects a position sensor source (digital incremental encoder, digital Hall, analog Hall, analog incremental encoder, ...) that is mounted close to the motor. The inner FOC loop controls torque and flux of the motor based on the measured phase currents and the electrical angle of the rotor.

The TMC4671 is equipped with a secondary incremental encoder interface. This secondary encoder interface is available as source for velocity control or position control. This is for applications where a motor with a gearing positions an object.

1 Info

The secondary incremental encoder is not available for commutation (phi\_e) for the inner FOC. In others words, there is no electrical angle phi\_e selectable from the secondary encoder.

# 4.6.4 Digital Hall Sensor Interface with optional Interim Position Interpolation

The digital Hall interface is the position sensor interface for digital Hall signals. The digital Hall signal interface first maps the digital Hall signals to an electrical position PHI\_E\_RAW. An offset PHI\_E\_OFFSET can be used to rotate the orientation of the Hall signal angle. The electrical angle PHI\_E is for commutation. Optionally, the default electrical positions of the Hall sensors can be adjusted by writes into the associated registers.





Figure 23: Hall Sensor Angles

Hall sensors give absolute positions within an electrical period with a resolution of 60° as 16 bit positions (s16 resp. u16) PHI. With activated interim Hall position interpolation, the user gets high resolution interim positions when the motor is running at a speed above 60 rpm.

## 4.6.5 Digital Hall Sensor - Interim Position Interpolation

For lower torque ripple the user can switch on the position interpolation of interim Hall positions. This function is useful for motors that are compatible with sine wave commutation, but equipped with digital Hall sensors. When the position interpolation is switched on, it becomes active on speeds above 60 rpm. For lower speeds it automatically disables itself. This is especially important when the motor has to be at rest. Hall sensor position interpolation might fail when Hall sensors are not properly placed in the motor. Please adjust Hall sensor positions for this case.

1 Info

Hall interpolation is not intended for positioning applications, especially not with changes of direction. Please check errata section if you want to use hall interpolation and positioning. When using interpolated angles PID\_POSITION\_ACTUAL might glitch when direction is changed or the motor operates at very low velocity.

## 4.6.6 Digital Hall Sensors - Masking, Filtering, and PWM center sampling

Sometimes digital Hall sensor signals get disturbed by switching events in the power stage. The TMC4671 can automatically mask switching distortions by correct setting of the HALL\_MASKING register. When a switching event occurs, the Hall sensor signals are held for HALL\_MASKING value times 10 ns. This way, Hall sensor distortions are eliminated.

Uncorrelated distortions can be filtered via a digital filter of configurable length. If the input signal to the filter does not change for HALL\_DIG\_FILTER\_LENGTH times 5 us, the signal can pass the filter. This filter eliminates issues with bouncing Hall signals. naming with Elliot: Masking is better then Blanking

Spikes on Hall signals (Hx that stands for H1, H2, H3) disturb the FOC loop when Hall signals are used for commutation or for initialization of incremental encoders. Spikes on hall signal lines might occur when



Hall signals are feed on singled ended signal lines in parallel to motor power lines due to electromagnetic cross talk in a single cable. Long Hall signal lines might cause digital Hall signal cross talk even in separate fed cables. Cables that provide Hall signals without spikes should be preferred. A good ground for digital Hall signals is important for clean Hall signals. A good ground shield of the motor might help for clean Hall signals. In best case, Hall signals are fed within separate shielded signal lines together with differential line drivers.



Figure 24: Outline of noisy Hall signals (left) due to electromagnetic interference with PWM switching and noise cleaned Hall signals (right) by PWM center synced sampling of Hall signal vector (H1 H2 H3)

The best is avoiding spikes on digital Hall signals. Nevertheless, to enable lower cost motors with lower performance Hall signal shielding, the TMC4671 is equipped with Hall Signal spike suppression and PWM centered Hall signal vector sampling.

To reduce possible current ripple that might be caused by noisy Hall signals, the sampling of the Hall signal vector can be programmed for sampling once per PWM period at its center for the desired noise reduction. The PWM centered Hall signal sampling is programmable by HALL\_MODE(4) control bit. Continuous sampling is default. This function is not available for TMC4671-ES engineering samples.



Figure 25: Hall Signal PWM Center Sampling on PWM\_CENTER

The PWM center synchronization needs to be qualified for high speed applications due to reduction of Hall signals for PWM frequency. The PWM center might have an influence on Hall signal interpolation and needs to be qualified if Hall signal interpolation is enabled.

For additional spike suppression, the TMC4671 is equipped with a digital hall signal blanking, to support lower performance cabling environments. The blank time for the Hall signals is programmable (HALL\_BLANK) in steps of 10 ns from 0 ns up to 4095 ns. The Hall signal blanking time should be programmed as long as necessary for safe suppression of spikes of maximum duration. On the other side, the Hall signal blanking should be programmed as short as possible to avoid disturbance by too strong filtering that might also disturbe the FOC.





Figure 26: Hall Signal Blanking

# 4.6.7 Digital Hall Sensors together with Incremental Encoder

If a motor is equipped with both Hall sensors and incremental encoder, the Hall sensors can be used for the initialization as a low resolution absolute position sensor. Later on, the incremental encoder can be used as a high resolution sensor for commutation.

# 4.6.8 Analog Hall and Analog Encoder Interface (SinCos of 0° 90° or 0° 120° 240°)

An analog encoder interface is part of the decoder engine. It is able to handle analog position signals of 0° and 90° and of 0° 120° 240°. The analog decoder engine adds offsets and scales the raw analog encoder signals, while also calculating the electrical angle PHI\_E from these analog position signals by an ATAN2 algorithm.



Figure 27: Analog Encoder (AENC) signal waveforms

An individual signed offset is added to each associated raw ADC channel and scaled by its associated scaling factors according to

$$AENC_VALUE = (AENC_RAW + AENC_OFFSET) \cdot AENC_SCALE$$
 (26)



In addition, the AENC\_OFFSET is for conversion of unsigned ADC values into signed ADC values as required for the FOC.

1 Info

The control bit 0 in register AENC\_DECODER\_MODE (0x3B) selects either processing of analog position signals of 0° and 90° (0b0) or analog signals of 0° 120° 240° on (0b1).



Figure 28: Analog Encoder (AENC) Selector & Scaler w/ Offset Correction

In Fig. 27 possible waveforms are shown. The graphs show usual SIN/COS track signals with one and multiple periods per revolution as well as typical waveforms of three phase analog Hall signals for one electrical revolution. The number of periods per revolution can be configured by register AENC\_DECODER\_PPR. The position in one period (AENC\_DECODER\_PHI\_A) is calculated by an ATAN2 algorithm. The periods are counted with respect to the number of periods per revolution to calculate AENC\_DECODER\_PHI\_E and AENC\_DECODER\_PHI\_M. If PPR is the same as the number of pole pairs, AENC\_DECODER\_PHI\_E and AENC\_DECODER\_PHI\_A are identical. This is usually the case for analog hall signals.

1 Info

The analog N pulse is just a raw ADC value. Handling of analog N pulse similar to N pulse handling of digital encoder N pulse is not implemented for analog encoder.

# 4.6.9 Analog Position Decoder (SinCos of 0°90° or 0°120°240°)

The extracted positions from the analog decoder are available for read out from registers.



#### 4.6.9.1 Multi-Turn Counter

Electrical angles are mapped to a multi-turn position counter. The user can overwrite this multi-turn position for initialization purposes.

# 4.6.9.2 Encoder Engine Phi Selector

The angle selector selects the source for the commutation angle PHI\_E. That electrical angle is available for commutation.

## 4.6.9.3 External Position Register

A register value written into the register bank via the application interface is available for commutation as well. With this, the user can interface to any encoder by just writing positions extracted from external encoder into this regulator. From the decoder engine point of view this is just one more selectable encoder source.

## 4.6.10 Encoder Initialization Support

The TMC4671 needs proper feedback for correct and stable operation. One main parameter is the commutation angle offset PHI\_E\_OFFSET. This offset must not be calculated when an absolute sensor system like analog or digital Hall sensors is used. All other supported feedback systems need to be initialized - their PHI\_E\_OFFSETs need to be identified. The user has several options to determine PHI\_E\_OFFSET with support of the TMC4671.

## 4.6.10.1 Encoder Initialization in Open-Loop Mode

In the case of a free driving motor, the motor can be switched to Open-Loop Mode. In this mode, the used commutation angle (PHI\_OPEN\_LOOP) can be used to match the measured PHI\_E. This method is supported by the TMCL-IDE.

#### 4.6.10.2 Encoder Initialization by Hall sensors

The TMC4671 can calculate PHI\_E\_OFFSET very precisely at a Hall state change for a second encoder system, when Hall sensors are correctly aligned. Therefore, the function needs to be enabled and calculate a new offset at the next Hall state change. After disabling of the module, the process can be started again. This function can also be used as a rough plausibility check during longer operation.

### 4.6.10.3 Encoder Initialization by N Pulse Detection

After determination of a correct offset, the value can be used again after power cycle. The encoder's N pulse can be used as reference for this. For starters the user can drive the motor in open-loop mode or by using digital Hall sensor signals. After passing the encoder's N pulse, the ABN encoder is initialized and can be used for operation.

# 4.6.11 Velocity Measurement

Servo control comprises position, velocity and current control. The position and the current are measured by separate sensors. The actual velocity has to be calculated by time discrete differentiation from the position signal. the user can choose a calculated position from the various encoder interfaces for velocity measurement by parameter VELOCITY\_SELECTION.



The user can switch between two different velocity calculation algorithms with the parameter VELOC-ITY\_METER\_SELECTION. Default setting (VELOCITY\_METER\_SELECTION = 0) is the standard velocity meter, which calculates the velocity at a sampling rate of about 4369.067 Hz by differentiation. Output value is displayed in rpm (revolutions per minute). This option is recommended for usage with the standard PI controller structure.

By choosing the second option (VELOCITY\_METER\_SELECTION = 1), the sampling frequency is synchronized to the PWM frequency. This option is recommended for usage with the advanced PI controller structure. Otherwise, the controller structure might tend to be unstable due to non-matched sampling. Velocity filters can be applied to reduce noise on velocity signals. Section 4.8 describes filtering opportunities in detail.

#### 4.6.12 Reference Switches

The TMC4671 is equipped with three input pins for reference switches (REF\_SW\_L, REF\_SW\_H and REF\_SW\_R). These pins can be used to determine three reference positions. The TMC4671 displays the status of the reference switches in the register TMC\_INPUTS\_RAW and is able to store the actual position at rising edge of the corresponding signal. The signal polarities are programmable and the module reacts only on toggling the ENABLE register. The signals can be filtered with a configurable digital filter, which suppresses spike errors.

With the STATUS\_FLAGS and STATUS\_MASK register the STATUS output can be configured as an IRQ for passing a reference switch.

The actual position can be latched when passing a reference switch. The latched positions can be displayed in register INTERIM\_DATA (0x6E). Register INTERIM\_ADDR (0x6F) selects the data displayed in INTERIM\_DATA with HOME\_POSITION at address 31, LEFT\_POSITION at address 32 and RIGHT\_POSITION at address 33.

The position latching can be enabled via register CONFIG\_DATA (0x4D) with CONFIG\_ADDR (0x4E) set to 51 (ref\_switch\_config). Position latching is enabled by setting bit 0 of ref\_switch\_config to 1.If a reference switched is passed the corresponding status bit (HOME\_SWITCH\_PASSED, LEFT\_SWITCH\_PASSED, and RIGHT\_SWITCH\_PASSED) in REF\_SWITCH\_STATUS (INTERIM\_DATA with INTERIM\_ADDRESS = 30) is enabled. The bits can only be cleared by toggling/disabling the enable bit in ref\_switch\_config.



The polarity registers do not affect the status registers. The status flag only represents the current logical state of the switch.



# 4.7 FOC23 Engine

The FOC23 engine performs the inner current control loop for the torque current  $I_Q$  and the flux current  $I_D$  including the required transformations. Programmable limiters take care of clipping of interim results. Per default, the programmable circular limiter clips U\_D and U\_Q to U\_D\_R =  $\sqrt(2) \cdot$  U\_Q and U\_R\_R =  $\sqrt(2) \cdot$  U\_D. PI controllers perform the regulation tasks. Please make sure to enable controllers by pulling ENI pin to high level.

## 4.7.1 ENI and ENO pins

The ENI (Enable input) can be used to start and stop control action. During reset ENO (Enable out) is low and afterwards it forwards ENI signal. Thereby it can be used to enable the power stage. When ENI is low, all controllers are deactivated and PWM operates at 50% duty cycle. ENI input value can be read through TMC4671\_INPUTS\_RAW register.

### 4.7.2 PI Controllers

PI controllers are used for current control and velocity control. A P controller is used for position control. The derivative part is not yet supported but might be added in the future. The user can choose between two PI controller structures: The classic PI controller structure, which is also used in the TMC4670, and the advanced PI controller structure. The advanced PI controller structure shows better performance in dynamics and is recommended for high performance applications. User can switch between controllers by setting register MODE\_PID\_TYPE. Controller type can not be switched individually for each cascade level.

#### 4.7.3 PI Controller Calculations - Classic Structure

The PI controllers in the classic structure perform the following calculation

$$Y = P \cdot e + I \cdot \int_0^t e(t) dt$$
 (27)

with

$$e = X_TARGET - X (28)$$

where X\_TARGET stands for target flux (s16), target torque (s16), target velocity (s32), or target position (s32) with error e, which is the difference between target value and actual values. The Y stands for the output of the PI controller feed as target input to the successive PI controller of the FOC servo controller cascade (position  $\rightarrow$  PI  $\rightarrow$  velocity  $\rightarrow$  PI  $\rightarrow$  current  $\rightarrow$  PI  $\rightarrow$  voltage).

Y\_PID\_FLUX = PID\_FLUX\_P \* ERROR\_FLUX / 256

Y\_PID\_FLUX\_RATE = PID\_FLUX\_I \* ERROR\_FLUX / 65536 / (32  $\mu$ s)

Y\_PID\_TORQUE = PID\_FLUX\_P \* ERROR\_TORQUE / 256

Y\_PID\_TORQUE\_RATE = PID\_TORQUE\_I \* ERROR\_TORQUE / 65536 / (32  $\mu$ s)

Y\_PID\_VELOCITY = PID\_VELOCITY\_P \* ERROR\_VELOCITY / 256

Y\_PID\_VELOCITY\_RATE = PID\_VELOCITY\_I \* ERROR\_VELOCITY / 65536 / (256  $\mu$ s)



Y\_PID\_POSITION = PID\_POSITION\_P \* ERROR\_POSITION / 65536

Y\_PID\_POSITION\_RATE = PID\_POSITION\_I \* ERROR\_POSITION / 65536 / (256  $\mu$ s)

Table 20: Scalings and Change Rate Timings of PID controllers (classic structure) for currents, velocity, and position for clock frequency fCLK = 25MHz

| Number | Motion Mode          | Description                                            |
|--------|----------------------|--------------------------------------------------------|
| 0      | Stopped Mode         | Disabling all controllers                              |
| 1      | Torque Mode          | Standard Torque Control Mode                           |
| 2      | Velocity Mode        | Standard Velocity Control Mode                         |
| 3      | Position Mode        | Standard Position Control Mode                         |
| 4      | PRBS Flux Mode       | PRBS Value is used as Target Flux Value for Ident.     |
| 5      | PRBS Torque Mode     | PRBS Value is used as Target Torque Value for Ident.   |
| 6      | PRBS Velocity Mode   | PRBS Value is used as Target Velocity Value for Ident. |
| 7      | PRBS Position Mode   | PRBS Value is used as Target Position Value for Ident. |
| 8      | UQ UD Ext Mode       | Voltage control mode (Software Mode)                   |
| 9      | reserved             | reserved                                               |
| 10     | AGPI_A Torque Mode   | AGPI_A used as Target Torque value                     |
| 11     | AGPI_A Velocity Mode | AGPI_A used as Target Velocity value                   |
| 12     | AGPI_A Position Mode | AGPI_A used as Target Position value                   |
| 13     | PWM_I Torque Mode    | PWM_I used as Target Torque value                      |
| 14     | PWM_I Velocity Mode  | PWM_I used as Target Velocity value                    |
| 15     | PWM_I Position Mode  | PWM_I used as Target Position value                    |

Table 21: Motion Modes





Figure 29: Classic PI Controller

1 Info

Changing the I-parameter of the classic PI controller during operation causes the controller output to jump, as the control error is first integrated and then gained by the I parameter. Jumps can be avoided by incremental changes of I-parameter.

1 Info

Support for the TMC4671 is integrated into the TMCL-IDE including wizards for set up and configuration. With the TMCL-IDE, configuration and operation can be done in a few steps and the user gets direct access to all registers of the TMC4671.

# 4.7.4 PI Controller Calculations - Advanced Structure

The PI controllers in the advanced controller structure perform the calculation

$$dXdT = P \cdot e + \int_0^t P \cdot I \cdot e(t) dt$$
 (29)

with

$$e = X_TARGET - X \tag{30}$$

where X\_TARGET represents target flux, target torque, target velocity, or target position with control error e, which is the difference between target value and actual values. The time constant  $\mathrm{d}t$  is set according to the PWM period but can be downsampled for the position controller by register MODE\_PID\_SMPL. Position controller evaluation can be downsampled by a constant factor when needed.





Figure 30: Advanced PI Controller

1 Info

The P Factor normalization as Q8.8 of the advanced PI controller of the TMC4671-ES is selectable for the TMC4671-LA as either Q8.8 or Q4.12. This can be configured in register 0x4D CONFIG\_DATA when register 0x4E CONFIG\_ADDR is set to 0x3E. For more information refer to section 7.2. Using Q4.12 needs changes in the user's application controller software when using the Advanced PI position controller.

The transfer function of the advanced PI controller can be described by the following pseudo code:

$$\label{eq:dxdT} \begin{split} dXdT &= e \cdot P + integrator \\ integrator &= integrator + P \cdot I \cdot e \end{split} \tag{31}$$

P and I are either displayed as Q8.8 (P = P\_FAK/256) or Q4.12 (P = P\_FAK/4096). This is individually configurable for each controller parameter in the controller cascade.

Downsampling of the advanced position controller can be configured by register MODE\_PID\_SMPL. When the register is 0 the controllers will sample on the PWM-frequency  $f_{PWM}$ . The new samplerate will be derived from  $f_{PWM}$  and the downsampling-value assigned to register MODE\_PID\_SMPL (range: 0 to 127). The derived sampling frequency is calculated as follows:

$$Samplerate_{new} = \frac{f_{PWM}}{downsampling + 1}$$
 (32)

## 4.7.5 PI Controller - Clipping

The limiting of target values for PI controllers and output values of PI controllers is programmable. Per power on default these limits are set to maximum values. During initialization, these limits should be set properly for correct operation and clipping.

The target input is clipped to X\_TARGET\_LIMIT. The output of a PI controller is named dXdT because it gives the desired derivative d/dt as a target value to the following stage: The position (x) controller gives velocity (dx/dt). The output of the PI Controller is clipped to dXdT\_LIMIT. The error integral of (27) is clipped to dXdT\_LIMIT / I in the classic controller structure, and the integrator output is clipped to dXdT\_output\_limit in the advanced controller structure.









Figure 31: PI Controllers for position, velocity and current

# 4.7.6 PI Flux & PI Torque Controller

The P part is represented as q8.8 and I is the I part represented as q0.15.

# 4.7.7 PI Velocity Controller

The P part is represented as q8.8 and I is the I part represented as q0.15.



#### 4.7.8 P Position Controller

For the position regulator, the P part is represented as q4.12 to be compatible with the high resolution positions - one single rotation is handled as an s16. For the advanced controller structure the P part is represented by q8.8.

## 4.7.9 Inner FOC Control Loop - Flux & Torque

The inner FOC loop (figure 32) controls the flux current to the flux target value and the torque current to the desired torque target. The inner FOC loop performs the desired transformations according to figure 33 for 3-phase motors (FOC3). For 2-phase motors (FOC2) both Clarke (CLARKE) transformation and inverse Clarke (iCLARKE) are bypassed. For control of DC motors, transformations are bypassed and only the first full bridge (connected to X1 and X2) is used.

The inner FOC control loop gets a target torque value (I\_Q\_TARGET) which represents acceleration, the rotor position, and the measured currents as input data. Together with the programmed P and I parameters, the inner FOC loop calculates the target voltage values as input for the PWM engine.



Figure 32: Inner FOC Control Loop

# 4.7.10 FOC Transformations and PI(D) for control of Flux & Torque

The Clarke transformation (CLARKE) maps three motor phase currents  $(I_U, I_V, I_W)$  to a two-dimensional coordinate system with two currents  $(I_\alpha, I_\beta)$ . Based on the actual rotor angle determined by an encoder or via sensorless techniques, the Park transformation (PARK) maps these two currents to a quasi-static coordinate system with two currents  $(I_D, I_Q)$ . The current  $I_D$  represents flux and the current  $I_Q$  represents torque. The flux just pulls on the rotor but does not affect torque. The torque is affected by  $I_Q$ . Two PI controllers determine two voltages  $(U_D, U_Q)$  to drive desired currents for a target torque and a target flux. The determined voltages  $(U_D, U_Q)$  are re-transformed into the stator system by the inverse Park transformation (iPARK). The inverse Clarke Transformation (iCLARKE) transforms these two currents into three voltages  $(U_U, U_V, U_W)$ . Theses three voltage are the input of the PWM engine to drive the power stage.

In case of the FOC2, Clarke transformation CLARKE and inverse Clarke Transformation iCLARKE are skipped.





Figure 33: FOC3 Transformations (FOC2 just skips CLARKE and iCLARKE)

## 4.7.11 Motion Modes

The user can operate the TMC4671 in several motion modes. Standard motion modes are position control, velocity control and torque control, where target values are fed into the controllers via register access. The motion mode UD\_UQ\_EXTERN allows the user to set voltages for open-loop operation and for tests during setup.



Figure 34: Standard Motion Modes

In position control mode, the user can feed the step and direction interface to generate a position target value for the controller cascade. In additional motion modes target values are fed into the TMC4671 via PWM interface (Pin: PWM\_IN) or analog input via pin AGPI\_A.



There are additional motion modes, which are using input from the PWM\_I input or the AGPI\_A input. Input signals can be scaled via a standard scaler providing offset and gain correction. The interface can be configured via the registers SINGLE\_PIN\_IF\_OFFSET\_SCALE and SINGLE\_PIN\_IF\_STATUS\_CFG, where the status of the interface can be monitored as well. PWM input signals which are out of frequency range can be neglected. In case of wrong input data, last correct position is used or velocity and torque are set to zero.

| Number | Motion Mode          | Description                                            |
|--------|----------------------|--------------------------------------------------------|
| 0      | Stopped Mode         | Disabling all controllers                              |
| 1      | Torque Mode          | Standard Torque Control Mode                           |
| 2      | Velocity Mode        | Standard Velocity Control Mode                         |
| 3      | Position Mode        | Standard Position Control Mode                         |
| 4      | PRBS Flux Mode       | PRBS Value is used as Target Flux Value for Ident.     |
| 5      | PRBS Torque Mode     | PRBS Value is used as Target Torque Value for Ident.   |
| 6      | PRBS Velocity Mode   | PRBS Value is used as Target Velocity Value for Ident. |
| 7      | PRBS Position Mode   | PRBS Value is used as Target Position Value for Ident. |
| 8      | UQ UD Ext Mode       | Voltage control mode (Software Mode)                   |
| 9      | reserved             | reserved                                               |
| 10     | AGPI_A Torque Mode   | AGPI_A used as Target Torque value                     |
| 11     | AGPI_A Velocity Mode | AGPI_A used as Target Velocity value                   |
| 12     | AGPI_A Position Mode | AGPI_A used as Target Position value                   |
| 13     | PWM_I Torque Mode    | PWM_I used as Target Torque value                      |
| 14     | PWM_I Velocity Mode  | PWM_I used as Target Velocity value                    |
| 15     | PWM_I Position Mode  | PWM_I used as Target Position value                    |

Table 22: Motion Modes

#### 4.7.12 Brake Chopper

During regenerative braking of the motor, current is driven into the DC link. If the power frontend is not actively controlled, the DC link voltage will rise. The brake chopper output pin (BRAKE) can be used for control of an external brake chopper, which burns energy over a brake resistor. The BRAKE pin is set to high for a complete PWM cycle if measured voltage is higher then ADC\_VM\_LIMIT\_HIGH. Once active it will be deactivated when voltage drops below ADC\_VM\_LIMIT\_LOW. This acts like a hysteresis. BRAKE can be deactivated by setting both registers to Zero. By setting proper values in the registers it is automatically enabled.



# 4.8 Filtering and Feed-Forward Control

The TMC4671 uses different filters for certain target and actual values. When using standard velocity meter, a standard velocity filter is used which is optimized for velocity signals from Hall sensors. Additional Biquad filters can be used to suppress measurement noise or damp resonances.

# 4.8.1 Biguad Filters

The TMC4671 uses standard biguad filters (standard IIR filter of second order, Wikipedia Article) in the following structure.

$$Y(n) = X(n) \cdot b \cdot 0 + X(n-1) \cdot b \cdot 1 + X(n-2) \cdot b \cdot 2 + Y(n-1) \cdot a \cdot 1 + Y(n-2) \cdot a \cdot 2$$
 (33)

In this equation X(n) is the actual input sample, while Y(n-1) is the filter output of the last cycle. All coefficients are S32 values and are normalized to a Q3.29 format. Users must take care of correct parametrization of the filter. There is no built-in plausibility or stability check. All filters can be disabled or enabled via register access. Biquad state variables are reset when parameters are changed. The TRINAMIC IDE supports parametrization with wizards.

A standard biquad filter has the following transfer function in the Laplace-Domain:

$$G(s) = \frac{b_2 - cont \cdot s^2 + b_1 - cont \cdot s + b_0 - cont}{a_2 - cont \cdot s^2 + a_1 - cont \cdot s + a_0 - cont}$$
(34)

The transfer function needs to be transformed to time discrete domain by Z-Transformation and coefficients need to be normalized. This is done by the following equations.

$$b\_2\_z = (b\_0\_cont \cdot T^2 + 2 \cdot b\_1\_cont \cdot T + 4 \cdot b\_2\_cont) / (T^2 - 2 \cdot a\_1\_cont \cdot T + 4 \cdot a\_2\_cont)$$
 (35)

$$b_1z = (2 \cdot b_0 - cont \cdot T^2 - 8 \cdot b_2 - cont) / (T^2 - 2 \cdot a_1 - cont \cdot T + 4 \cdot a_2 - cont)$$
(36)

$$b_0z = (b_0 - cont \cdot T^2 - 2 \cdot b_1 - cont \cdot T + 4 \cdot b_2 - cont) / (T^2 - 2 \cdot a_1 - cont \cdot T + 4 \cdot a_2 - cont)$$
 (37)

$$a_2z = (T^2 + 2 \cdot a_1 \cdot a_2 \cdot a_1 \cdot T + 4 \cdot a_2 \cdot a_1 \cdot a_1 \cdot a_2 \cdot a_2 \cdot a_1 \cdot a_2 \cdot a_2 \cdot a_1 \cdot a_2 \cdot a_$$

$$a_1z = (2 \cdot T^2 - 8 \cdot a_2z_{cont})/(T^2 - 2 \cdot a_1z_{cont} \cdot T + 4 \cdot a_2z_{cont})$$
(39)

$$b_0 = round(b_0 z \cdot 2^{29}) \tag{40}$$

$$b_1 = round(b_1 - z \cdot 2^{29})$$
 (41)

$$b_2 = round(b_2 - z \cdot 2^{29})$$

$$a_1 = round(-a_1 z \cdot 2^{29})$$
(42)

$$a_2 = round(-a_2z \cdot 2^{29})$$
 (44)

while T is the sampling time according to PWM\_MAX\_COUNT · 10 ns and variables with index z are auxiliary

A standard second order lowpass filter with given cutoff frequency  $\omega_c$  and damping factor D has the following transfer function in the Laplace-Domain:

$$G_{LP}(s) = \frac{1}{\frac{1}{\omega^2} \cdot s^2 + \frac{2D}{\omega_0} \cdot s + 1}$$
 (45)

Users can determine filter coefficients with the upper equations by comparing coefficients of both transfer functions. The TMCL-IDE also provides a dimensioning tool.

There are four biquad filters in the control structure. Figure 35 illustrates their placement in the control structure.



 $b \ 2 = round(b \ 2 \ z \cdot 2^{29})$ 



Figure 35: Biquad Filters

The biquad filter for the position target value is intended to be used as a low-pass filter for smoothening position input to the control structure. It is evaluated in every PWM cycle, or down-sampled according to the down-sampling factor for the position controller. After powering on it is disabled.

The biquad filter for the flux target value is also intended to be used as a low-pass filter for input values from the user's microcontroller. Sampling frequency is fixed to the PWM frequency.

The biquad filter for the torque target value can be used as a low-pass filter for bandwidth limitation and noise suppression. Moreover, it can be designed to suppress a resonance or anti-resonance. Same statements are correct for the velocity biquad filter. Both filters' sampling times are fixed to the PWM period.

The velocity target value biquad is configured as a second order low-pass with a cutoff frequency at 200 Hz - by default at a sampling frequency of 25 kHz. Biquad filters can be activated separately.

# 4.8.2 Standard Velocity Filter

By using the standard velocity measurement algorithm, the default velocity filter is enabled and can not be switched off. The standard velocity filter is a low-pass filter with a cutoff frequency of 20 Hz (slope of -20 dB/Decade). In this configuration, a new velocity is calculated at a sample rate of approx. 4369.067 Hz. This configuration is intended to be used in low-performance applications with a simple position feedback system like digital Hall sensors.

#### 4.8.3 Feed-Forward Control Structure

#### Note

Software feed forward control via offset registers is recommended, due to missing amplification possibility. Utilize feedforward to actively increase the target value of a controller besides the normal target input. For Torque/Flux use register 0x65 PID\_TORQUE\_FLUX\_OFFSET and for the velocity use register 0x67 PID\_VELOCITY\_OFFSET.



# 4.9 PWM Engine

The PWM engine takes care of converting voltage vectors to pulse width modulated (PWM) control signals. These digital PWM signals control the gate drivers of the power stage. For a detailed description of the PWM control registers and PWM register control bits pls. refer section 7 page 71.

The ease-of-use PWM engine requires just a couple of parameter settings. Primarily, the polarities for the gate control signal of high-side and low-side must be set. The power on default PWM mode is 0, meaning PWM = OFF. For operation, the centered PWM mode must be switched on by setting the PWM mode to 7. A single bit switches the space vector PWM (SVPWM) on. For 3-phase PMSM, the SVPWM = ON gives more effective voltage. Nevertheless, for some applications it makes sense to switch the SVPWM = OFF to keep the star point voltage of a motor almost at rest.

## 4.9.1 PWM Polarities

The PWM polarities register (PWM\_POLARITIES) controls the polarities of the logic level gate control signals. The polarities of the gate control signals are individually programmable for low-side gate control and for high-side gate control. The PWM polarities register controls the polarity of other control signals as well. PWM\_POLARITIES[1] controls the polarity of the logic level high side gate control signal. PWM\_POLARITIES[0] controls the polarity of the logic level low side gate control signal.



Figure 36: PWM Gate Driver Control Polarities

| PWM_POLARITIES[10] | PWM_HIGH_SIDE | PWM_LOW_SIDE |
|--------------------|---------------|--------------|
| 0 0                | PWM_H         | PWM_L        |
| 0 1                | PWM_H         | not PWM_L    |
| 1 0                | not PWM_H     | PWM_L        |
| 1 1                | not PWM_H     | not PWM_L    |

Table 23: Status Flags Register



## 4.9.2 PWM Engine and associated Motor Connectors

The PWM engine of the TMC4671 has eight gate control outputs to control up to four power MOS half bridges. For three-phase motors three half bridges are used (U, V, W). For two-phase stepper motors four half bridges are used for (U, V, W, Y). For DC motor control, the first two half bridges (U, V) are used.

| Gate Control Signals | FOC3: 3 Phase Motor | FOC2: 2 Phase Stepper | FOC1: Single Phase DC Motor |
|----------------------|---------------------|-----------------------|-----------------------------|
| PWM_UX1_H            | U                   | X1                    | X1                          |
| PWM_UX1_L            | O                   |                       |                             |
| PWM_VX2_H            | V                   | X2                    | X2                          |
| PWM_VX2_L            | V                   | ΛZ                    | ΛZ                          |
| PWM_WY1_H            | W                   | Y1                    | _                           |
| PWM_WY1_L            | VV                  | 11                    |                             |
| PWM_Y2_H             | _                   | Y2                    | _                           |
| PWM_Y2_L             | -                   | 12                    | -                           |

Table 24: FOC321 Gate Control Signal Configurations

For the DC motor current control (here named FOC1), the number of pole pairs is not relevant - in contrast to closed loop current control of two-phase stepper motors (FOC2) and three-phase permanent magnet motors (FOC3). For DC motor control, the number of pole pairs should be set to 1 to equal mechanical angle and electrical angle for velocity control and for position control.



Figure 37: FOC3 (three phase motor), FOC2 (two phase stepper motor), FOC1 (single phase DC motor)



## 4.9.3 PWM Frequency

The PWM counter maximum length register PWM\_MAXCNT controls the PWM frequency. For a clock frequency fCLK =  $25 \,\text{MHz}$ , the PWM frequency fPWM[Hz] =  $(4.0 \cdot \text{fCLK [Hz]}) / \text{(PWM_MAXCNT + 1)}$ . With fCLK =  $25 \,\text{MHz}$  and power-on reset (POR) default of PWM\_MAXCNT=3999, the PWM frequency fPWM =  $25 \,\text{kHz}$ .

#### Note

The PWM frequency is the fundamental frequency of the control system. It can be changed at any time, also during motion for the classic PI controller structure. The advanced PI controller structure is tied to the PWM frequency and integrator gains have to be changed. Please make sure to set current measurement decimation rates to fit PWM period in high performance applications.

#### 4.9.4 PWM Resolution

The base resolution of the PWM is 12 bit internally mapped to 16 bit range. The minimal PWM increment is 20ns due to the symmetrical PWM with 100 MHz counter frequency. MAX\_PWMCNT = 4095 gives the full resolution of 12 bit with  $\approx$  25 kHz w/ fCLK=25 MHz. MAX\_PWMCNT=2047 results in 11 bit resolution, but with  $\approx$  50kHz w/ fCLK=25 MHz. So the PWM\_MAXCNT defines the PWM frequency, but also affects the resolution of the PWM.

#### 4.9.5 PWM Modes

The power-on reset (POR) default of the PWM is OFF. The standard PWM scheme is the centered PWM. Passive braking and freewheeling modes are available on demand. Please refer to section 7 concerning the settings.

# 4.9.6 Break-Before-Make (BBM)

One register controls BBM time for the high side, another register controls BBM time for the low side. The BBM times are programmable in 10 ns steps. The BBM time can be set to zero for gate drivers that have their own integrated BBM timers.



Figure 38: BBM Timing



| 1 Info | Measured BBM times at MOS-FET gates differ from programmed BBM times due to driver delays and possible additional gate driver BBM times. The programmed BBM times are for the digital control signals. |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note   | Too short BBM times cause electrical shortcuts of the MOS-FET bridges - so called shoot through - that short the power supply and might damage the power stage and the power supply.                   |

### 4.9.7 Space Vector PWM (SVPWM)

A single bit enables the Space Vector PWM (SVPWM). No further settings are required for the space vector PWM - just ON or OFF. The power on default for the SVPWM is OFF. Space Vector PWM can be enabled to maximize voltage utilization in the case of an isolated star point of the motor. If the star point is not isolated, SVPWM might cause unintended current flows through the star point. Space Vector PWM is only used for three-phase motors. For other motors the SVPWM must be switched off.

| Note | For engineering samples TMC4671-ES, the Space Vector PWM does not allow       |
|------|-------------------------------------------------------------------------------|
|      | higher voltage utilization. This is fixed for the release version TMC4671-LA. |

# 4.9.8 Real- and Integer-Conversions

The TMC4671 displays voltages and currents as integer values. The following tables show how one can convert integer values to real values, see table 25, and the other way round, see table 26. Equation 2 in section 4.5.0.1 describes the chain of gains and introduces ADC\_GAIN. This variable depends on resistance of the shuntresistor as well as the properties of the senseamplifier. It is needed for the current conversions. The voltage conversion depends on the supply voltage  $V_{\rm M}$ .

Senseamps and their respective shunt resistors can deviate in their properties due to part tolerances or aging. However, their values must still be comparable. This is done by using a scaling factor for both ADCs in order to harmonize their signals.

$$ADC\_GAIN_{scaled} = (ADC\_GAIN \cdot \frac{ADC\_SCALE}{256})$$
(46)

|                         | integer to real                                                             |
|-------------------------|-----------------------------------------------------------------------------|
| l <sub>uvw,real</sub>   | $\frac{I_{\mathrm{uvw,s16}}}{\mathrm{ADC\_GAIN_{scaled}}}$                  |
| $I_{lphaeta,real}$      | $\frac{\mathrm{I}_{\alpha\beta,\mathrm{s}16}}{\mathrm{ADC\_GAIN_{scaled}}}$ |
| I <sub>dq,real</sub>    | $\frac{\rm I_{\rm dq,s16}}{\rm ADC\_GAIN_{\rm scaled}}$                     |
| $U_{dq,real}$           | $U_{dq,s16} \cdot \frac{V_M}{2^{15}}$                                       |
| $U_{lphaeta,real}$      | $U_{\alpha\beta,s16} \cdot \frac{V_M}{2^{15}}$                              |
| FOC <sub>uvw,real</sub> | $FOC_{uvw,s16} \cdot \frac{V_M}{2^{15}}$                                    |
| PWM <sub>uvw,real</sub> | $PWM_{uvw,s16} \cdot \frac{V_M}{2^{15}}$                                    |

Table 25: Factors for integer to real conversion



|                        | real to integer                                                               |
|------------------------|-------------------------------------------------------------------------------|
| I <sub>uvw,s16</sub>   | $I_{uvw,real} \cdot ADC\_GAIN_{scaled}$                                       |
| $I_{\alpha\beta,s16}$  | $I_{\alpha\beta,\mathrm{real}} \cdot \mathrm{ADC\_GAIN_{scaled}}$             |
| I <sub>dq,s16</sub>    | $I_{\rm dq,real} \cdot ADC\_GAIN_{\rm scaled}$                                |
| U <sub>dq,s16</sub>    | $ m U_{dq,real} \cdot rac{2^{15}}{V_{M}}$                                    |
| $U_{lphaeta,s16}$      | $\mathrm{U}_{lphaeta,\mathrm{real}}\cdotrac{2^{15}}{\mathrm{V}_\mathrm{M}}$  |
| FOC <sub>uvw,s16</sub> | $FOC_{uvw,real} \cdot \frac{2^{15}}{V_M}$                                     |
| PWM <sub>uvw,s16</sub> | $\mathrm{PWM}_{\mathrm{dq,real}} \cdot rac{2^{15}}{\mathrm{V}_{\mathrm{M}}}$ |

Table 26: Factors for real to integer conversion

The PWM value defines the outputvoltage. It is calculated using the content of register INTERIM\_DATA while INTERIM\_ADDR is 0x11 or 0x12. The s16 PWM value is converted to an u16 value by adding 0x8000. Equation 47 applies for the highside PWM when connected to a DC- or Stepper-motor as well as the three phases of a BLDC-motor when spacevector pwm is inactive:

$$U_{\text{clamp}} = (PWM_{uvw,s16} + 0x8000) \cdot \frac{V_M}{2^{16}}$$
(47)

Equation 48 describes the outputvoltage on the clamps for the lowside PWM when connected to a DC- or Stepper-motor:

$$U_{\text{clamp}} = (-PWM_{\text{uxwy,s16}} + 0x8000) \cdot \frac{V_{\text{M}}}{2^{16}}$$
 (48)

The following equation describes the integer to real transformation for three-phase spacevector-PWM:

$$\begin{aligned} & FOC_{MIN} = min(FOC_u, FOC_v, FOC_w) \\ & FOC_{MAX} = max(FOC_u, FOC_v, FOC_w) \\ & U_{clamp,uvw} = (\frac{2}{\sqrt{3}} \cdot (PWM_{uvw,s16} - \frac{FOC_{MAX} + FOC_{MIN}}{2}) + 0x8000) \cdot \frac{V_M}{2^{16}} \end{aligned} \tag{49}$$

# **5** Safety Functions

Different safety functions are integrated and mapped to status bits. A programmable mask register selects bits for activation of the STATUS output.

Internal hardware limiters for real time clipping and monitoring of interim values are available. LIMIT or LIMITS is part of register names of registers associated to internal limiters. Please refer to table 27.

| Bit | Source                 |  |
|-----|------------------------|--|
| 0   | pid_x_target_limit     |  |
| 1   | pid_x_target_ddt_limit |  |
| 2   | pid_x_errsum_limit     |  |
| 3   | pid_x_output_limit     |  |
| 4   | pid_v_target_limit     |  |



| 5pid_v_target_ddt_limit6pid_v_errsum_limit7pid_v_output_limit8pid_id_target_limit9pid_id_target_ddt_limit10pid_id_errsum_limit11pid_id_output_limit12pid_iq_target_limit13pid_iq_target_ddt_limit14pid_iq_errsum_limit15pid_iq_output_limit16ipark_cirlim_limit_u_d17ipark_cirlim_limit_u_r19not_PLL_locked20ref_sw_r21ref_sw_l22ref_sw_l2324pwm_min25pwm_max26adc_i_clipped27adc_aenc_clipped28ENC_N29ENC2_N30AENC_N31reserved |    | T                       |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------------------|--|
| pid_v_output_limit  pid_id_target_limit  pid_id_target_ddt_limit  pid_id_errsum_limit  pid_id_output_limit  pid_iq_target_limit  pid_iq_target_limit  pid_iq_target_ddt_limit  pid_iq_errsum_limit  pid_iq_errsum_limit  pid_iq_output_limit  pid_iq_output_limit  ipark_cirlim_limit_u_d  ref_sw_r  ref_sw_r  ref_sw_l  ref_sw_l  pwm_min  pwm_max  adc_i_clipped  RNC_N  ENC2_N  AENC_N                                       | 5  | pid_v_target_ddt_limit  |  |
| 8 pid_id_target_limit 9 pid_id_target_ddt_limit 10 pid_id_errsum_limit 11 pid_id_output_limit 12 pid_iq_target_limit 13 pid_iq_target_ddt_limit 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N    | 6  | pid_v_errsum_limit      |  |
| 9 pid_id_target_ddt_limit 10 pid_id_errsum_limit 11 pid_id_output_limit 12 pid_iq_target_limit 13 pid_iq_target_ddt_limit 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 ——— 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                      | 7  | pid_v_output_limit      |  |
| 10 pid_id_errsum_limit  11 pid_id_output_limit  12 pid_iq_target_limit  13 pid_iq_target_ddt_limit  14 pid_iq_errsum_limit  15 pid_iq_output_limit  16 ipark_cirlim_limit_u_d  17 ipark_cirlim_limit_u_q  18 ipark_cirlim_limit_u_r  19 not_PLL_locked  20 ref_sw_r  21 ref_sw_h  22 ref_sw_l  23  24 pwm_min  25 pwm_max  26 adc_i_clipped  27 adc_aenc_clipped  28 ENC_N  29 ENC2_N  30 AENC_N                                | 8  | pid_id_target_limit     |  |
| 11 pid_id_output_limit 12 pid_iq_target_limit 13 pid_iq_target_ddt_limit 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 ——— 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                       | 9  | pid_id_target_ddt_limit |  |
| 12 pid_iq_target_limit 13 pid_iq_target_ddt_limit 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                  | 10 | pid_id_errsum_limit     |  |
| 13 pid_iq_target_ddt_limit 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 —— 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                      | 11 | pid_id_output_limit     |  |
| 14 pid_iq_errsum_limit 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                    | 12 | pid_iq_target_limit     |  |
| 15 pid_iq_output_limit 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                                           | 13 | pid_iq_target_ddt_limit |  |
| 16 ipark_cirlim_limit_u_d 17 ipark_cirlim_limit_u_q 18 ipark_cirlim_limit_u_r 19 not_PLL_locked 20 ref_sw_r 21 ref_sw_h 22 ref_sw_l 23 —— 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                                                               | 14 | pid_iq_errsum_limit     |  |
| 17       ipark_cirlim_limit_u_q         18       ipark_cirlim_limit_u_r         19       not_PLL_locked         20       ref_sw_r         21       ref_sw_h         22       ref_sw_l         23          24       pwm_min         25       pwm_max         26       adc_i_clipped         27       adc_aenc_clipped         28       ENC_N         29       ENC2_N         30       AENC_N                                     | 15 | pid_iq_output_limit     |  |
| 18         ipark_cirlim_limit_u_r           19         not_PLL_locked           20         ref_sw_r           21         ref_sw_h           22         ref_sw_l           23            24         pwm_min           25         pwm_max           26         adc_i_clipped           27         adc_aenc_clipped           28         ENC_N           29         ENC2_N           30         AENC_N                             | 16 | ipark_cirlim_limit_u_d  |  |
| 19                                                                                                                                                                                                                                                                                                                                                                                                                              | 17 | ipark_cirlim_limit_u_q  |  |
| 20       ref_sw_r         21       ref_sw_h         22       ref_sw_l         23       ——         24       pwm_min         25       pwm_max         26       adc_i_clipped         27       adc_aenc_clipped         28       ENC_N         29       ENC2_N         30       AENC_N                                                                                                                                             | 18 | ipark_cirlim_limit_u_r  |  |
| 21       ref_sw_h         22       ref_sw_l         23          24       pwm_min         25       pwm_max         26       adc_i_clipped         27       adc_aenc_clipped         28       ENC_N         29       ENC2_N         30       AENC_N                                                                                                                                                                               | 19 | not_PLL_locked          |  |
| 22       ref_sw_I         23       ——         24       pwm_min         25       pwm_max         26       adc_i_clipped         27       adc_aenc_clipped         28       ENC_N         29       ENC2_N         30       AENC_N                                                                                                                                                                                                 | 20 | ref_sw_r                |  |
| 23 ——— 24 pwm_min 25 pwm_max 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                                                                                                                                                                                                  | 21 | ref_sw_h                |  |
| 24         pwm_min           25         pwm_max           26         adc_i_clipped           27         adc_aenc_clipped           28         ENC_N           29         ENC2_N           30         AENC_N                                                                                                                                                                                                                     | 22 | ref_sw_l                |  |
| 25         pwm_max           26         adc_i_clipped           27         adc_aenc_clipped           28         ENC_N           29         ENC2_N           30         AENC_N                                                                                                                                                                                                                                                  | 23 |                         |  |
| 26 adc_i_clipped 27 adc_aenc_clipped 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                                                                                                                                                                                                                               | 24 | pwm_min                 |  |
| 27         adc_aenc_clipped           28         ENC_N           29         ENC2_N           30         AENC_N                                                                                                                                                                                                                                                                                                                  | 25 | pwm_max                 |  |
| 28 ENC_N 29 ENC2_N 30 AENC_N                                                                                                                                                                                                                                                                                                                                                                                                    | 26 | adc_i_clipped           |  |
| 29 ENC2_N<br>30 AENC_N                                                                                                                                                                                                                                                                                                                                                                                                          | 27 | adc_aenc_clipped        |  |
| 30 AENC_N                                                                                                                                                                                                                                                                                                                                                                                                                       | 28 | ENC_N                   |  |
| _                                                                                                                                                                                                                                                                                                                                                                                                                               | 29 | ENC2_N                  |  |
| 31 reserved                                                                                                                                                                                                                                                                                                                                                                                                                     | 30 | AENC_N                  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                 | 31 | reserved                |  |

Table 27: Status Flags Register

All controllers have input limiters as offsets can be added to target values and they can be limited to remain in certain ranges. Also all controller outputs can be limited and the integrating parts (error sum) of the PI controllers are also limited to controller outputs. If d/dt-limiters are enabled they are also capable of limiting target values.

If one of these limiters gets active, the flag will go to high state. This is usually a normal operation, when controllers are working on the borders of their working area. With STATUS\_MASK register corresponding flags can be activated.



Other status flags go to high state whether the voltage limitation is reached (circular limiter in iPark transformation) or PWM is saturated (pwm\_min and pwm\_max). This is also usual operation as the current controller has to deal with voltage limitation at high velocity operation.

The user can also use the status output to generate an IRQ on reference switch or N-channel of encoder. Also ADC clipping can be monitored which is a good indicator of wrong or faulty behavior.

Remaining wd\_error status flag indicates an error on the clock input of the TMC4671 (see following section).

Status flags register can be written directly. It is not possible to clear individual bits.



# 6 FOC Setup - How to Turn a Motor

This section summarizes the basic steps that are required to turn a motor with TMC4671. The wizard of the TMCL-IDE guides the user through theses basic steps. Schematics and Layout of the TMC4671 evaluation kit are open source and available for download from www.trinamic.com

**Note**TRINAMIC recommends to use a TMC4671 evaluation kit together with the TMCL-IDE with its integrated wizards for initial evaluation and setup.

In order to create own application software please check TRINAMIC's API to reduce software development efforts.

# **6.1 Select Motor Type**

The TMC4671 supports closed loop control of single phase DC motors, stepper motors, and three phase motors. The selection of the motor type defines the configuration of the gate control channels for the power stage and either the usage or bypass of FOC transformations (Clarke, Park, iPark, iClark).

# 6.1.1 FOC1 Setup - How to Turn a Single Phase DC Motor

In case of DC motor, the mechanical commutator of the DC motor realizes something like mechanical field oriented control where the TMC4671 just realizes closed loop current control of the DC motor. From FOC point of view, the FOC converts a brushless motor (BLDC) resp. Permanent Magnet Synchronous Motor (PMSM) into a closed loop current controlled DC motor.

From closed loop velocity control point of view and from closed loop position control point of view there is no difference between electronically FOC controlled BLDC motor or PMSM motor and a mechanical commutated DC motor with electronic closed loop current control.

#### 6.1.2 FOC2 Setup - How to Turn a Two Phase Motor (Stepper)

The TMC4671 is able to turn a two-phase stepper motor with FOC by internal skip of Clarke transformation and iClarke transformation. A special feature of stepper motors is the high number of pole pairs (NPP) that are typical 50. For stepper motors it is usual to give the number of full steps (FS) per revolution, with NPP = (FS/revolution) / 4. A stepper with 200 full steps per revolution has 50 pole pairs.

## 6.1.3 FOC3 Setup - How to Turn a Three Phase Motor (PMSM or BLDC)

A three phase motor is the classical FOC controlled brushless motor. Users have to take care concerning number of pole pairs (NPP) and the number of poles (NP) with NPP = NP/2.

# 6.2 Set Number of Pole Pairs (NPP)

The number of (magnetic) pole pairs (NPP) is characteristic for each motor and it is essential for commutation of two phase motors and three phase motors with FOC. For DC motor the NPP is not important for commutation itself, but is should be set to one to have same scaling for electrical angle and mechanical angle.



# 6.3 Run Motor Open Loop

Initial turning a motor open loop is useful for determination of the association between phase voltage, phase currents and for position sensor setup. Position sensors that are mounted on a motor might have an opposite direction of rotation compared to the motor. The same direction of rotation is essential for the FOC. In addition, the phase shift between rotor angle and angle that is measured by a position sensor needs to be zero in best case. Otherwise the motor is operated at lower efficiency or turns in wrong direction which causes instability.

# 6.3.1 Determination of Association between Phase Voltage and Phase Currents

For starters, the motor should be turned open loop to measure ADC offsets and set ADC scaler offset. Additionally, the open loop turn is useful to validate (or to determine) the association between motor phase currents and motor phase terminal voltages. This association is essential for the FOC. With proper ADC channel selection setup, voltage U\_UX1 is in phase with current I\_UX1, voltage U\_VX2 is in phase with current I\_VX2, and voltage U\_WY1 is in phase with I\_WY1. For two phase stepper motor, the voltage U\_Y2 is in phase with current I\_Y2. Only two currents are measured and the other current is calculated by TMC4671. For DC motor only one current is measured.

## 6.3.2 Determination of Direction of Rotation and Phase Shift of Angles

For absolute position sensors like Hall sensors, the phase shift an the direction of rotation only need to be determined once initially. For relative position sensors, like incremental encoders, the direction of turning needs to be determined everytime after power cycle. The relative orientation between measured incremental encoder angle and rotor angle needs to be determined on each power-up.

## **6.4 Selection of Position Sensors**

For closed loop operation, the type of encoder (digital hall, ABN encoder, analog Hall, SinCos) needs to be set. For analog Hall signals or analog incremental encoders the user needs to adjust the analog ADC channels for the analog encoders - similar to ADC offset and ADC scaling as for current measuring ADC channels. The TMC4671 allows the selection of different types of position sensors for different tasks. One position sensor is for the inner FOC closed loop current control loop.

#### 6.4.1 Selection of FOC sensor for PHI\_E

One sensor needs to be selected for the FOC to measure the electrical angle PHI\_E. This sensor is used for the inner closed loop control loop for closed loop current control.

#### 6.4.2 Selection of sensor for VELOCITY

One sensor needs to be selected for measurement of velocity. This can be the sensor selected for measurement of PHI\_E but it is more common to use the mechanical angle PHI\_M for measurement of velocity. Using electrical angles can give advantages for applications with slow motion for NPP more than one because the minimum velocity in RPM [revolutions per minute] is one and the electrical angles have higher speed than mechanical angles.

### 6.4.3 Selection of sensor for POSITION

One sensor needs to be selected for measurement of position of the rotor, the angle of the rotor. This can be the sensor selected for measurement PHI\_E but it is more usual to use the mechanical angle PHI\_M for measurement of position. For stepper motors it might make sense to select the electrical angle PHI\_E for



positioning to have a benefit from higher resolution using electrical angles. This is because each period electrical or mechanical - is normalized to  $2^{16}=65536$  positions.

# 6.5 Modes of Operation - (Open Loop), Torque, Velocity, Positioning

The TMC4671 can operate in torque mode, velocity mode, or position mode. The control loops (current, velocity, position) are cascaded, thus the outer loops depend on the tuning of the inner loops. So, the current loop must be adjusted first. The velocity loop must be adjusted after the current control loop is adjusted. The position control loop must be adjusted last.

# 6.6 Controller Tuning

PI controller tuning is described throughout the control theory literature. In general there are two main strategies to tune the controllers. First strategy is to observe controller step response for different parameter sets and tune parameters to fit dynamics and settling time. With this approach sampling target and actual value as well as controller output (check for saturation) at fixed frequency is recommended. The USB-2-RTMI adapter in combination with the TMCL-IDE provide tuning tools to support this strategy. Another approach is to identify controller plant parameters and calculate controller parameters from these parameters. This is also supported by the TMCL-IDE for the current control loop. For the other control loops the first strategy is recommended.

# 7 Register Map

The TMC4671 has an register address range of 128 addresses with registers up to 32 bit data width. Some registers hold 32 bit data fields, some hold 2 x 16 bit data fileds and other hold combinations of different data fields with individual data types. Data fields need to extracted by masking and shifting after read from a TMC4671 register within the application. Data fields need to be composed by masking and shifting by the application before writing into a TMC4671 register. Please check TRINAMIC's API to reduce software development efforts. This section describes the register bank of the TMC4671.

Section 7.1 gives an overview over all registers. It is is intended to give an initial over view of all registers.

Section 7.2 is the detailed reference of all registers and the register fields.

Section 7.3 gives the description of power-on-reset default values of all registers.



# 7.1 Register Map - Overview

Registers in TMC4671 have different purposes. Some registers are used for test only, other can be used to monitor internal states (e.g. ADC values). Most registers are only accessed during initialisation (e.g. calibration or control parameters). Control registers are used for input of target values to controllers and should be updated regularly according to chosen motion modes (e.g PID\_VELOCITY\_TARGET should be updated in velocity mode). If users don't use a certain functional block they don't need to parametrize it.

The TMC4671 has an address space of 128 addresses. In order to display more then 128 registers, so called stacked registers were added. These are CHIPINFO\_DATA, ADC\_RAW\_DATA, PID\_ERROR\_DATA, CONFIG\_DATA and INTERIM\_DATA. These data registers display or give access to different subregisters according to their corresponding address registers (CHIPINFO\_ADDR, ADC\_RAW\_ADDR, PID\_ERROR\_ADDR, CONFIG\_ADDR and INTERIM\_ADDR). Read access to a subregister requires a write access to address register and a read access to the data register.

| Address           | Registername              | Access | Usage   |
|-------------------|---------------------------|--------|---------|
| 0x00 <sub>h</sub> | CHIPINFO_DATA             | R      | Test    |
| 0x01 <sub>h</sub> | CHIPINFO_ADDR             | RW     | Test    |
| 0x02 <sub>h</sub> | ADC_RAW_DATA              | R      | Monitor |
| 0x03 <sub>h</sub> | ADC_RAW_ADDR              | RW     | Monitor |
| 0x04 <sub>h</sub> | dsADC_MCFG_B_MCFG_A       | RW     | Init    |
| 0x05 <sub>h</sub> | dsADC_MCLK_A              | RW     | Init    |
| 0x06 <sub>h</sub> | dsADC_MCLK_B              | RW     | Init    |
| 0x07 <sub>h</sub> | dsADC_MDEC_B_MDEC_A       | RW     | Init    |
| 0x08 <sub>h</sub> | ADC_I1_SCALE_OFFSET       | RW     | Init    |
| 0x09 <sub>h</sub> | ADC_I0_SCALE_OFFSET       | RW     | Init    |
| 0x0A <sub>h</sub> | ADC_I_SELECT              | RW     | Init    |
| 0x0B <sub>h</sub> | ADC_I1_I0_EXT             | RW     | Test    |
| 0x0C <sub>h</sub> | DS_ANALOG_INPUT_STAGE_CFG | RW     | Test    |
| 0x0D <sub>h</sub> | AENC_0_SCALE_OFFSET       | RW     | Init    |
| 0x0E <sub>h</sub> | AENC_1_SCALE_OFFSET       | RW     | Init    |
| 0x0F <sub>h</sub> | AENC_2_SCALE_OFFSET       | RW     | Init    |
| 0x11 <sub>h</sub> | AENC_SELECT               | RW     | Init    |
| 0x12 <sub>h</sub> | ADC_IWY_IUX               | R      | Monitor |
| 0x13 <sub>h</sub> | ADC_IV                    | R      | Monitor |
| 0x15 <sub>h</sub> | AENC_WY_UX                | R      | Monitor |
| 0x16 <sub>h</sub> | AENC_VN                   | R      | Monitor |
| 0x17 <sub>h</sub> | PWM_POLARITIES            | RW     | Init    |
| 0x18 <sub>h</sub> | PWM_MAXCNT                | RW     | Init    |
| 0x19 <sub>h</sub> | PWM_BBM_H_BBM_L           | RW     | Init    |
| 0x1A <sub>h</sub> | PWM_SV_CHOP               | RW     | Init    |



| Address           | Registername                   | Access | Usage             |
|-------------------|--------------------------------|--------|-------------------|
| 0x1B <sub>h</sub> | MOTOR_TYPE_N_POLE_PAIRS        | RW     | Init              |
| 0x1C <sub>h</sub> | PHI_E_EXT                      | RW     | Test              |
| 0x1F <sub>h</sub> | OPENLOOP_MODE                  | RW     | Init              |
| 0x20 <sub>h</sub> | OPENLOOP_ACCELERATION          | RW     | Init              |
| 0x21 <sub>h</sub> | OPENLOOP_VELOCITY_TARGET       | RW     | Init              |
| 0x22 <sub>h</sub> | OPENLOOP_VELOCITY_ACTUAL       | RW     | Monitor           |
| 0x23 <sub>h</sub> | OPENLOOP_PHI                   | RW     | Monitor/Test      |
| 0x24 <sub>h</sub> | UQ_UD_EXT                      | RW     | Init/Test         |
| 0x25 <sub>h</sub> | ABN_DECODER_MODE               | RW     | Init              |
| 0x26 <sub>h</sub> | ABN_DECODER_PPR                | RW     | Init              |
| 0x27 <sub>h</sub> | ABN_DECODER_COUNT              | RW     | Init/Test/Monitor |
| 0x28 <sub>h</sub> | ABN_DECODER_COUNT_N            | RW     | Init/Test/Monitor |
| 0x29 <sub>h</sub> | ABN_DECODER_PHI_E_PHI_M_OFFSET | RW     | Init              |
| 0x2A <sub>h</sub> | ABN_DECODER_PHI_E_PHI_M        | R      | Monitor           |
| 0x2C <sub>h</sub> | ABN_2_DECODER_MODE             | RW     | Init              |
| 0x2D <sub>h</sub> | ABN_2_DECODER_PPR              | RW     | Init              |
| 0x2E <sub>h</sub> | ABN_2_DECODER_COUNT            | RW     | Init/Test/Monitor |
| 0x2F <sub>h</sub> | ABN_2_DECODER_COUNT_N          | RW     | Init/Test/Monitor |
| 0x30 <sub>h</sub> | ABN_2_DECODER_PHI_M_OFFSET     | RW     | Init              |
| 0x31 <sub>h</sub> | ABN_2_DECODER_PHI_M            | R      | Monitor           |
| 0x33 <sub>h</sub> | HALL_MODE                      | RW     | Init              |
| 0x34 <sub>h</sub> | HALL_POSITION_060_000          | RW     | Init              |
| 0x35 <sub>h</sub> | HALL_POSITION_180_120          | RW     | Init              |
| 0x36 <sub>h</sub> | HALL_POSITION_300_240          | RW     | Init              |
| 0x37 <sub>h</sub> | HALL_PHI_E_PHI_M_OFFSET        | RW     | Init              |
| 0x38 <sub>h</sub> | HALL_DPHI_MAX                  | RW     | Init              |
| 0x39 <sub>h</sub> | HALL_PHI_E_INTERPOLATED_PHI_E  | R      | Monitor           |
| 0x3A <sub>h</sub> | HALL_PHI_M                     | R      | Monitor           |
| 0x3B <sub>h</sub> | AENC_DECODER_MODE              | RW     | Init              |
| 0x3C <sub>h</sub> | AENC_DECODER_N_THRESHOLD       | RW     | Init              |
| 0x3D <sub>h</sub> | AENC_DECODER_PHI_A_RAW         | R      | Monitor           |
| 0x3E <sub>h</sub> | AENC_DECODER_PHI_A_OFFSET      | RW     | Init              |
| 0x3F <sub>h</sub> | AENC_DECODER_PHI_A             | R      | Monitor           |
| 0x40 <sub>h</sub> | AENC_DECODER_PPR               | RW     | Init              |



| Address           | Registername                    | Access | Usage        |
|-------------------|---------------------------------|--------|--------------|
| 0x41 <sub>h</sub> | AENC_DECODER_COUNT              | R      | Monitor      |
| 0x42 <sub>h</sub> | AENC_DECODER_COUNT_N            | RW     | Monitor/Init |
| 0x45 <sub>h</sub> | AENC_DECODER_PHI_E_PHI_M_OFFSET | RW     | Init         |
| 0x46 <sub>h</sub> | AENC_DECODER_PHI_E_PHI_M        | R      | Monitor      |
| 0x4B <sub>h</sub> | PIDIN_VELOCITY_TARGET           | R      | Monitor      |
| 0x4C <sub>h</sub> | PIDIN_POSITION_TARGET           | R      | Monitor      |
| 0x4D <sub>h</sub> | CONFIG_DATA                     | RW     | Init         |
| 0x4E <sub>h</sub> | CONFIG_ADDR                     | RW     | Init         |
| 0x50 <sub>h</sub> | VELOCITY_SELECTION              | RW     | Init         |
| 0x51 <sub>h</sub> | POSITION_SELECTION              | RW     | Init         |
| 0x52 <sub>h</sub> | PHI_E_SELECTION                 | RW     | Init         |
| 0x53 <sub>h</sub> | PHI_E                           | R      | Monitor      |
| 0x54 <sub>h</sub> | PID_FLUX_P_FLUX_I               | RW     | Init         |
| 0x56 <sub>h</sub> | PID_TORQUE_P_TORQUE_I           | RW     | Init         |
| 0x58 <sub>h</sub> | PID_VELOCITY_P_VELOCITY_I       | RW     | Init         |
| 0x5A <sub>h</sub> | PID_POSITION_P_POSITION_I       | RW     | Init         |
| 0x5D <sub>h</sub> | PIDOUT_UQ_UD_LIMITS             | RW     | Init         |
| 0x5E <sub>h</sub> | PID_TORQUE_FLUX_LIMITS          | RW     | Init         |
| 0x60 <sub>h</sub> | PID_VELOCITY_LIMIT              | RW     | Init         |
| 0x61 <sub>h</sub> | PID_POSITION_LIMIT_LOW          | RW     | Init         |
| 0x62 <sub>h</sub> | PID_POSITION_LIMIT_HIGH         | RW     | Init         |
| 0x63 <sub>h</sub> | MODE_RAMP_MODE_MOTION           | RW     | Init         |
| 0x64 <sub>h</sub> | PID_TORQUE_FLUX_TARGET          | RW     | Control      |
| 0x65 <sub>h</sub> | PID_TORQUE_FLUX_OFFSET          | RW     | Control      |
| 0x66 <sub>h</sub> | PID_VELOCITY_TARGET             | RW     | Control      |
| 0x67 <sub>h</sub> | PID_VELOCITY_OFFSET             | RW     | Control      |
| 0x68 <sub>h</sub> | PID_POSITION_TARGET             | RW     | Control      |
| 0x69 <sub>h</sub> | PID_TORQUE_FLUX_ACTUAL          | R      | Monitor      |
| 0x6A <sub>h</sub> | PID_VELOCITY_ACTUAL             | R      | Monitor      |
| 0x6B <sub>h</sub> | PID_POSITION_ACTUAL             | RW     | Monitor/Init |
| 0x6C <sub>h</sub> | PID_ERROR_DATA                  | R      | Test         |
| 0x6D <sub>h</sub> | PID_ERROR_ADDR                  | RW     | Test         |
| 0x6E <sub>h</sub> | INTERIM_DATA                    | RW     | Monitor      |
| 0x6F <sub>h</sub> | INTERIM_ADDR                    | RW     | Monitor      |



| Address           | Registername        | Access | Usage        |
|-------------------|---------------------|--------|--------------|
| 0x75 <sub>h</sub> | ADC_VM_LIMITS       | RW     | Init         |
| 0x76 <sub>h</sub> | TMC4671_INPUTS_RAW  | R      | Test/Monitor |
| 0x77 <sub>h</sub> | TMC4671_OUTPUTS_RAW | R      | Test/Monitor |
| 0x78 <sub>h</sub> | STEP_WIDTH          | RW     | Init         |
| 0x79 <sub>h</sub> | UART_BPS            | RW     | Init         |
| 0x7B <sub>h</sub> | GPIO_dsADCI_CONFIG  | RW     | Init         |
| 0x7C <sub>h</sub> | STATUS_FLAGS        | RW     | Monitor      |
| 0x7D <sub>h</sub> | STATUS_MASK         | RW     | Monitor      |

Table 28: TMC4671 Registers



## 7.2 Register Map - Functional Description

|                   |                   | DATA TYPE  |                                                                                                                   |
|-------------------|-------------------|------------|-------------------------------------------------------------------------------------------------------------------|
| ADDR              | NAME              | (BIT MASK) | FUNCTION                                                                                                          |
| 0x00 <sub>h</sub> | CHIPINFO_DATA     |            | This register displays name and version information of the accessed IC. It can be used for test of communication. |
|                   | SI_TYPE           | u32(31:0)  | 0: Hardware type (ASCII).                                                                                         |
|                   | SI_VERSION        | u32(31:0)  | 0: Hardware version (u16.u16).                                                                                    |
|                   | SI_DATE           | u32(31:0)  | 0: Hardware date (nibble wise date stamp yyyymmdd).                                                               |
|                   | SI_TIME           | u32(31:0)  | 0: Hardware time (nibble wise time stamp –hhmmss)                                                                 |
|                   | SI_VARIANT        | u32(31:0)  |                                                                                                                   |
|                   | SI_BUILD          | u32(31:0)  |                                                                                                                   |
| 0x01 <sub>h</sub> | CHIPINFO_ADDR     |            | This register is used to change displayed information in register CHIPINFO_DATA.                                  |
|                   | CHIP_INFO_ADDRESS | u8(7:0)    | 0: SI_TYPE                                                                                                        |
|                   |                   |            | 1: SI_VERSION                                                                                                     |
|                   |                   |            | 2: SI_DATE                                                                                                        |
|                   |                   |            | 3: SI_TIME                                                                                                        |
|                   |                   |            | 4: SI_VARIANT                                                                                                     |
|                   |                   |            | 5: SI_BUILD                                                                                                       |
| 0x02 <sub>h</sub> | ADC_RAW_DATA      |            | This registers displays ADC values. Th displayed registers can be switched by register ADC_RAW_ADDR.              |
|                   | ADC_I0_RAW        | u16(15:0)  | Raw phase current l0                                                                                              |
|                   | ADC_I1_RAW        | u16(31:16) | Raw phase current l1                                                                                              |
|                   | ADC_VM_RAW        | u16(15:0)  | Raw supply voltage value.                                                                                         |
|                   | ADC_AGPI_A_RAW    | u16(31:16) | Raw analog gpi A value.                                                                                           |
|                   | ADC_AGPI_B_RAW    | u16(15:0)  | Raw analog gpi B value.                                                                                           |
|                   | ADC_AENC_UX_RAW   | u16(31:16) | Raw analog encoder signal.                                                                                        |
|                   | ADC_AENC_VN_RAW   | u16(15:0)  | Raw analog encoder signal.                                                                                        |
|                   | ADC_AENC_WY_RAW   | u16(31:16) | Raw analog encoder signal.                                                                                        |
| 0x03 <sub>h</sub> | ADC_RAW_ADDR      |            | This register is used to change displayed information in register ADC_RAW_DATA.                                   |



|                   | ADC_RAW_ADDR        | u8(7:0)   | 0: ADC_I1_RAW & ADC_I0_RAW 1: ADC_AGPI_A_RAW & ADC_VM_ RAW                                                                                                      |
|-------------------|---------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                     |           | 2: ADC_AENC_UX_RAW & ADC_<br>AGPI_B_RAW                                                                                                                         |
|                   |                     |           | 3: ADC_AENC_WY_RAW & ADC_<br>AENC_VN_RAW                                                                                                                        |
| 0x04 <sub>h</sub> | dsADC_MCFG_B_MCFG_A |           | This register is used to configure internal ADCs (delta sigma modulators). Don't modify if you want to use internal Delta Sigma modulators (Standard use case). |
|                   | cfg_dsmodulator_a   | u2(1:0)   | 0: int. dsMOD                                                                                                                                                   |
|                   |                     |           | 1: ext. MCLK input                                                                                                                                              |
|                   |                     |           | 2: ext. MCLK output                                                                                                                                             |
|                   |                     |           | 3: ext. CMP                                                                                                                                                     |
|                   | mclk_polarity_a     | bit(2)    | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | mdat_polarity_a     | bit(3)    | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | sel_nclk_mclk_i_a   | bit(4)    | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | blanking_a          | u8(15:8)  |                                                                                                                                                                 |
|                   | cfg_dsmodulator_b   | u2(17:16) | 0: int. dsMOD                                                                                                                                                   |
|                   |                     |           | 1: ext. MCLK input                                                                                                                                              |
|                   |                     |           | 2: ext. MCLK output                                                                                                                                             |
|                   |                     |           | 3: ext. CMP                                                                                                                                                     |
|                   | mclk_polarity_b     | bit(18)   | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | mdat_polarity_b     | bit(19)   | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | sel_nclk_mclk_i_b   | bit(20)   | 0: off                                                                                                                                                          |
|                   |                     |           | 1: on                                                                                                                                                           |
|                   | blanking_b          | u8(31:24) |                                                                                                                                                                 |
| 0x05 <sub>h</sub> | dsADC_MCLK_A        |           | This register is used to modify Delta Sigma modulator clock. Do not modify if you use internal delta sigma modulators (Standard use case).                      |



|                   | dsADC_MCLK_A        | u32(31:0)  | fMCLK_A = 2^31 / (fCLK * (dsADC_<br>MCLK_A+1)), dsADC_MCLK_A =<br>(2^31 / (fMCLK * fCLK)) - 1                                                                                                                                                 |
|-------------------|---------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x06 <sub>h</sub> | dsADC_MCLK_B        |            | This register is used to modify Delta Sigma modulator clock. Do not modify if you use internal delta sigma modulators (Standard use case).                                                                                                    |
|                   | dsADC_MCLK_B        | u32(31:0)  | fMCLK_B = 2^31 / (fCLK * (dsADC_<br>MCLK_B+1)), dsADC_MCLK_B =<br>(2^31 / (fMCLK * fCLK)) - 1                                                                                                                                                 |
| 0x07 <sub>h</sub> | dsADC_MDEC_B_MDEC_A |            | This register is used to change decimation rates of SINC3 filters for Delta Sigma modulators. Set values according to actual PWM frequency. See functional description of ADC engine.                                                         |
|                   | dsADC_MDEC_A        | u16(15:0)  | 0: PWM synchronous, others according to register content                                                                                                                                                                                      |
|                   | dsADC_MDEC_B        | u16(31:16) | 0: PWM synchronous, others according to register content                                                                                                                                                                                      |
| 0x08 <sub>h</sub> | ADC_I1_SCALE_OFFSET |            | This register is used to set calibration data for ADC channel I1 (Offset and amplitude correction).                                                                                                                                           |
|                   | ADC_I1_OFFSET       | u16(15:0)  | Offset for current ADC channel 1.                                                                                                                                                                                                             |
|                   | ADC_I1_SCALE        | s16(31:16) | Scaling factor for current ADC channel 1.                                                                                                                                                                                                     |
| 0x09 <sub>h</sub> | ADC_I0_SCALE_OFFSET |            | This register is used to set calibration data for ADC channel I0 (Offset and amplitude correction).                                                                                                                                           |
|                   | ADC_I0_OFFSET       | u16(15:0)  | Offset for current ADC channel 0.                                                                                                                                                                                                             |
|                   | ADC_I0_SCALE        | s16(31:16) | Scaling factor for current ADC channel 0.                                                                                                                                                                                                     |
| 0x0A <sub>h</sub> | ADC_I_SELECT        |            | This register is used to assign correct ADC channel to PWM output channel. For each FOC input current either an ADC value or the calculated sum of the currents (I2) can be assigned to match internal data processing to power stage design. |
|                   | ADC_I0_SELECT       | u8(7:0)    | Select input for raw current ADC_<br>I0_RAW.                                                                                                                                                                                                  |
|                   |                     |            | 0: ADCSD_I0_RAW (sigma delta ADC)                                                                                                                                                                                                             |



| 2: ADC_I0_EXT (from register) 3: ADC_I1_SELECT  u8(15:8)  Select input for raw current ADC_I1_RAW. 0: ADCSD_I0_RAW (sigma delta ADC) 1: ADCSD_I1_RAW (sigma delta ADC) 2: ADC_I0_EXT (from register) 3: ADC_I1_EXT (from register) 3: ADC_I1_EXT (from register) 3: ADC_I1_EXT (from register) 1: U2(25:24) 0: UX = ADC_I0 (default) 1: UX = ADC_I1 2: UX = ADC_I0 1: V = ADC_I0 1: V = ADC_I1 2: V = ADC_I0 1: V = ADC_I1 2: V = ADC_I0 1: V = ADC_I1 2: V = ADC_I1 2: V = ADC_I1 2: V = ADC_I1 3: ADC_I1_EXT  ADC_I1_OEXT  ADC_I1_OEXT  ADC_I1_OEXT  ADC_I0_EXT  ADC_I0_EXT  ADC_I0_EXT  ADC_I1_EXT  U16(15:0) ADC_I0_EXT  ADC_I1_EXT  U16(31:16) Register for write of ADC_I0 value from external source (eg. CPU). Register for write of ADC_I1 value from external source (eg. CPU). ADC_I0_EXT  ADC_I0_EXT  U16(31:16) Register for write of ADC_I1 value from external source (eg. CPU). Register for write of ADC_I1 value from external source (eg. CPU). CXCO_h ADC_I0  U4(3:0) U18(3:0) 0: INP vs. INN 1: GND vs. INN 1: GND vs. INN 2: VDD/4 4: INP vs. GND 5: VDD/2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                           |            | 1: ADCSD_I1_RAW (sigma delta ADC)                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC_I1_SELECT  U8(15:8)  Select input for raw current ADC_I1_RAW.  0: ADCSD_I0_RAW (sigma delta ADC)  1: ADCSD_I1_RAW (sigma delta ADC)  2: ADC_I0_EXT (from register)  3: ADC_I1_EXT (from register)  3: ADC_I1_EXT (from register)  0: UX = ADC_I0 (default)  1: UX = ADC_I1  2: V = ADC_I2  ADC_I_WY_SELECT  U2(29:28)  0: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I1  3: WY = ADC_I1  3: WY = ADC_I1  4: WY = ADC_I1  5: WY = ADC_I1  6: WY = ADC_I1  6: WY = ADC_I1  7: WY = ADC_I1  8: WY = ADC_I1  9:  |                   |                           |            | 2: ADC_I0_EXT (from register)                                                                                                                                         |
| I1_RAW.     0: ADCSD_I0_RAW (sigma delta ADC)     1: ADCSD_I1_RAW (sigma delta ADC)     2: ADC_I0_EXT (from register)     3: ADC_I1_EXT (from register)     3: ADC_I1_EXT (from register)     0: UX = ADC_I0 (default)     1: UX = ADC_I1 (default)     2: UX = ADC_I2     ADC_I_V_SELECT     u2(27:26)     0: V = ADC_I0     1: V = ADC_I1 (default)     2: V = ADC_I2     ADC_I_WY_SELECT     u2(29:28)     0: WY = ADC_I0     1: WY = ADC_I1 (default)     2: WY = ADC_I1 (default)     2: WY = ADC_I2 (default)     1: WY = ADC_I1 (default)     2: WY = ADC_I2 (default)     0x0Bh     ADC_I1_I0_EXT     This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be teach using external ADCs will probably effect control performance is not recommended.     ADC_I0_EXT     ADC_I1_EXT     u16(15:0)     Register for write of ADC_I0 value from external source (eg. CPU).     Register for write of ADC_I1 value from external source (eg. CPU).     This register is used to configure ADC channels for different input configurations and test modes.     ADC_I0     DS_ANALOG_INPUT_STAGE_CFG     O: INP vs. INN     1: GND vs. INN     2: VDD/4     3: 3*VDD/4     4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                           |            | 3: ADC_I1_EXT (from register)                                                                                                                                         |
| ADC)  1: ADCSD_I1_RAW (sigma delta ADC)  2: ADC_I0_EXT (from register)  3: ADC_I1_EXT (from register)  3: ADC_I1_EXT (from register)  0: UX = ADC_I0 (default)  1: UX = ADC_I1  2: UX = ADC_I1  2: UX = ADC_I1  2: UX = ADC_I1  2: V = ADC_I2  0: V = ADC_I0  1: V = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I2  ADC_I_WY_SELECT  U2(29:28)  0: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I1  3: ADC_I1_EXT  U16(15:0)  ADC_I1_EXT  U16(15:0)  In Register for write of ADC_I0 value from external source (eg. CPU).  ADC_I1_EXT  U16(31:16)  DS_ANALOG_INPUT_STAGE_CFG  ADC_I0  U4(3:0)  U16(3:0)  |                   | ADC_I1_SELECT             | u8(15:8)   |                                                                                                                                                                       |
| ADC_I_UX_SELECT  ADC_I_ |                   |                           |            |                                                                                                                                                                       |
| ADC_I_UX_SELECT  ADC_I_UX_SELECT  ADC_I_UX_SELECT  ADC_I_V_SELECT  ADC_I_V_SELECT  ADC_I_V_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_UX_SELECT  ADC_I_UX_ |                   |                           |            |                                                                                                                                                                       |
| ADC_I_UX_SELECT  u2(25:24)  0: UX = ADC_I0 (default)  1: UX = ADC_I1  2: UX = ADC_I2  ADC_I_V_SELECT  u2(27:26)  0: V = ADC_I0  1: V = ADC_I0  1: V = ADC_I1  2: UX = ADC_I1  2: V = ADC_I2  ADC_I_WY_SELECT  u2(29:28)  0: WY = ADC_I1  1: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I2  ADC_I1_EXT  This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested using external ADCs will probably effect control performance is not recommended.  ADC_I0_EXT  ADC_I1_EXT  u16(15:0)  DS_ANALOG_INPUT_STAGE_CFG  This register for write of ADC_I0 value from external source (eg. CPU).  Register for write of ADC_I1 value from external source (eg. CPU).  This register is used to configure ADC channels for different input configurations and test modes.  0: INP vs. INN  1: GND vs. INN  2: VDD/4  3: 3*VDD/4  4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                           |            | 2: ADC_I0_EXT (from register)                                                                                                                                         |
| 1: UX = ADC_I1 2: UX = ADC_I2 0: V = ADC_I0 1: V = ADC_I1 (default) 2: V = ADC_I2 0: WY = ADC_I2 0: WY = ADC_I2 0: WY = ADC_I0 1: WY = ADC_I1 2: WY = ADC_I0 1: WY = ADC_I1 2: WY = ADC_I1 1: WY = ADC_I1 2: WY = ADC_I1 3: WY = ADC_I1 |                   |                           |            | 3: ADC_I1_EXT (from register)                                                                                                                                         |
| ADC_I_V_SELECT  ADC_I_V_SELECT  ADC_I_V_SELECT  ADC_I_V_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  ADC_I_WY_SELECT  BADC_I_U  ADC_I_WY_SELECT  BADC_I_U  BADC |                   | ADC_I_UX_SELECT           | u2(25:24)  | 0: UX = ADC_I0 (default)                                                                                                                                              |
| ADC_I_V_SELECT    u2(27:26)   0: V = ADC_I0     1: V = ADC_I1 (default)     2: V = ADC_I2     0: WY = ADC_I0     1: WY = ADC_I0     1: WY = ADC_I1     2: WY = ADC_I1     2: WY = ADC_I2 (default)     1: WY = ADC_I1     2: WY = ADC_I2 (default)     ADC_I1_I0_EXT     This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested, using external ADCs will probably effect control performance is not recommended.    ADC_I0_EXT   u16(15:0)   Register for write of ADC_I0 value from external source (eg. CPU).   ADC_I1_EXT   u16(31:16)   Register for write of ADC_I1 value from external source (eg. CPU).    DS_ANALOG_INPUT_STAGE_CFG   This register is used to configure ADC channels for different input configurations and test modes.   ADC_I0   u4(3:0)   0: INP vs. INN     1: GND vs. INN     2: VDD/4     3: 3*VDD/4     4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                           |            | 1: UX = ADC_I1                                                                                                                                                        |
| 1: V = ADC_I1 (default) 2: V = ADC_I2  ADC_I_WY_SELECT  u2(29:28)  0: WY = ADC_I0 1: WY = ADC_I1 2: WY = ADC_I1 2: WY = ADC_I1 2: WY = ADC_I1 2: WY = ADC_I1 3: WY = ADC_I1 3: WY = ADC_I1 4: WY = ADC_I1 5: WY = ADC_I1 6: WY = ADC_I1 6: WY = ADC_I1 6: WY = ADC_I1 7: WY = ADC_I1 7: WY = ADC_I1 7: WY = ADC_I0 |                   |                           |            | 2: UX = ADC_I2                                                                                                                                                        |
| 2: V = ADC_I2  ADC_I_WY_SELECT  u2(29:28)  0: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I1  2: WY = ADC_I2 (default)  This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not recommended.  ADC_I0_EXT  ADC_I1_EXT  u16(15:0)  Register for write of ADC_I0 value from external source (eg. CPU).  ADC_I1_EXT  u16(31:16)  Register for write of ADC_I1 value from external source (eg. CPU).  This register is used to configure ADC channels for different input configurations and test modes.  ADC_I0  u4(3:0)  0: INP vs. INN  1: GND vs. INN  2: VDD/4  3: 3*VDD/4  4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   | ADC_I_V_SELECT            | u2(27:26)  | 0: V = ADC_I0                                                                                                                                                         |
| ADC_I_WY_SELECT  u2(29:28)  0: WY = ADC_I0  1: WY = ADC_I1  2: WY = ADC_I2 (default)  This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not recommended.  ADC_I0_EXT  ADC_I1_EXT  u16(15:0)  Register for write of ADC_I0 value from external source (eg. CPU).  Register for write of ADC_I1 value from external source (eg. CPU).  This register is used to configure ADC channels for different input configurations and test modes.  ADC_I0  u4(3:0)  u1(3:0)  0: INP vs. INN  1: GND vs. INN  2: VDD/4  3: 3*VDD/4  4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                   |                           |            | 1: V = ADC_I1 (default)                                                                                                                                               |
| 1: WY = ADC_I1 2: WY = ADC_I2 (default)  Ox0B <sub>h</sub> ADC_I1_I0_EXT  This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not recommended.  ADC_I0_EXT  u16(15:0)  Register for write of ADC_I0 value from external source (eg. CPU).  ADC_I1_EXT  u16(31:16)  Register for write of ADC_I1 value from external source (eg. CPU).  This register is used to configure ADC channels for different input configurations and test modes.  ADC_I0  u4(3:0)  0: INP vs. INN 1: GND vs. INN 2: VDD/4 3: 3*VDD/4 4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   |                           |            | 2: V = ADC_I2                                                                                                                                                         |
| 2: WY = ADC_I2 (default)    DX0Bh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   | ADC_I_WY_SELECT           | u2(29:28)  | 0: WY = ADC_I0                                                                                                                                                        |
| 0x0Bh       ADC_I1_I0_EXT       This register can be used to write ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not recommended.         ADC_I0_EXT       u16(15:0)       Register for write of ADC_I0 value from external source (eg. CPU).         ADC_I1_EXT       u16(31:16)       Register for write of ADC_I1 value from external source (eg. CPU).         0x0Ch       DS_ANALOG_INPUT_STAGE_CFG       This register is used to configure ADC channels for different input configurations and test modes.         ADC_I0       u4(3:0)       0: INP vs. INN         1: GND vs. INN       2: VDD/4         3: 3*VDD/4       4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                   |                           |            | 1: WY = ADC_I1                                                                                                                                                        |
| ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not recommended.  ADC_I0_EXT  ADC_I1_EXT  ADC_I1_EXT  DS_ANALOG_INPUT_STAGE_CFG  ADC_I0  U4(3:0)  ADC_I0  U4(3:0)  ADC_I0  ADC_IO  A |                   |                           |            | 2: WY = ADC_I2 (default)                                                                                                                                              |
| from external source (eg. CPU).  ADC_I1_EXT  u16(31:16)  Register for write of ADC_I1 value from external source (eg. CPU).  This register is used to configure ADC channels for different input configurations and test modes.  ADC_I0  u4(3:0)  0: INP vs. INN 1: GND vs. INN 2: VDD/4 3: 3*VDD/4 4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0B <sub>h</sub> | ADC_I1_I0_EXT             |            | ADC values via SPI in case external ADCs are used or controller cascade function shall be tested. using external ADCs will probably effect control performance is not |
| from external source (eg. CPU).  DS_ANALOG_INPUT_STAGE_CFG  This register is used to configure ADC channels for different input configurations and test modes.  ADC_I0  u4(3:0)  0: INP vs. INN  1: GND vs. INN  2: VDD/4  3: 3*VDD/4  4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                   | ADC_I0_EXT                | u16(15:0)  |                                                                                                                                                                       |
| ADC channels for different input configurations and test modes.  ADC_IO  u4(3:0)  0: INP vs. INN  1: GND vs. INN  2: VDD/4  3: 3*VDD/4  4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                   | ADC_I1_EXT                | u16(31:16) |                                                                                                                                                                       |
| 1: GND vs. INN 2: VDD/4 3: 3*VDD/4 4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0C <sub>h</sub> | DS_ANALOG_INPUT_STAGE_CFG |            | ADC channels for different input                                                                                                                                      |
| 2: VDD/4<br>3: 3*VDD/4<br>4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   | ADC_I0                    | u4(3:0)    | 0: INP vs. INN                                                                                                                                                        |
| 3: 3*VDD/4<br>4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                           |            | 1: GND vs. INN                                                                                                                                                        |
| 4: INP vs. GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                           |            | 2: VDD/4                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                           |            | 3: 3*VDD/4                                                                                                                                                            |
| 5: VDD/2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                           |            | 4: INP vs. GND                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                           |            | 5: VDD/2                                                                                                                                                              |



|             |           | 6: VDD/4       |
|-------------|-----------|----------------|
|             |           | 7: 3*VDD/4     |
| ADC_I1      | u4(7:4)   | 0: INP vs. INN |
|             |           | 1: GND vs. INN |
|             |           | 2: VDD/4       |
|             |           | 3: 3*VDD/4     |
|             |           | 4: INP vs. GND |
|             |           | 5: VDD/2       |
|             |           | 6: VDD/4       |
|             |           | 7: 3*VDD/4     |
| ADC_VM      | u4(11:8)  | 0: INP vs. INN |
|             |           | 1: GND vs. INN |
|             |           | 2: VDD/4       |
|             |           | 3: 3*VDD/4     |
|             |           | 4: INP vs. GND |
|             |           | 5: VDD/2       |
|             |           | 6: VDD/4       |
|             |           | 7: 3*VDD/4     |
| ADC_AGPI_A  | u4(15:12) | 0: INP vs. INN |
|             |           | 1: GND vs. INN |
|             |           | 2: VDD/4       |
|             |           | 3: 3*VDD/4     |
|             |           | 4: INP vs. GND |
|             |           | 5: VDD/2       |
|             |           | 6: VDD/4       |
|             |           | 7: 3*VDD/4     |
| ADC_AGPI_B  | u4(19:16) | 0: INP vs. INN |
|             |           | 1: GND vs. INN |
|             |           | 2: VDD/4       |
|             |           | 3: 3*VDD/4     |
|             |           | 4: INP vs. GND |
|             |           | 5: VDD/2       |
|             |           | 6: VDD/4       |
|             |           | 7: 3*VDD/4     |
| ADC_AENC_UX | u4(23:20) | 0: INP vs. INN |
|             |           | 1: GND vs. INN |



|                   |                     |            | 2: VDD/4                                                                                                |
|-------------------|---------------------|------------|---------------------------------------------------------------------------------------------------------|
|                   |                     |            | 3: 3*VDD/4                                                                                              |
|                   |                     |            | 4: INP vs. GND                                                                                          |
|                   |                     |            | 5: VDD/2                                                                                                |
|                   |                     |            | 6: VDD/4                                                                                                |
|                   |                     |            | 7: 3*VDD/4                                                                                              |
|                   | ADC_AENC_VN         | u4(27:24)  | 0: INP vs. INN                                                                                          |
|                   |                     |            | 1: GND vs. INN                                                                                          |
|                   |                     |            | 2: VDD/4                                                                                                |
|                   |                     |            | 3: 3*VDD/4                                                                                              |
|                   |                     |            | 4: INP vs. GND                                                                                          |
|                   |                     |            | 5: VDD/2                                                                                                |
|                   |                     |            | 6: VDD/4                                                                                                |
|                   |                     |            | 7: 3*VDD/4                                                                                              |
|                   | ADC_AENC_WY         | u4(31:28)  | 0: INP vs. INN                                                                                          |
|                   |                     |            | 1: GND vs. INN                                                                                          |
|                   |                     |            | 2: VDD/4                                                                                                |
|                   |                     |            | 3: 3*VDD/4                                                                                              |
|                   |                     |            | 4: INP vs. GND                                                                                          |
|                   |                     |            | 5: VDD/2                                                                                                |
|                   |                     |            | 6: VDD/4                                                                                                |
|                   |                     |            | 7: 3*VDD/4                                                                                              |
| 0x0D <sub>h</sub> | AENC_0_SCALE_OFFSET |            | This register is used to set calibration data for ADC channel AENC 0 (Offset and amplitude correction). |
|                   | AENC_0_OFFSET       | u16(15:0)  | Offset for Analog Encoder ADC channel 0.                                                                |
|                   | AENC_0_SCALE        | s16(31:16) | Scaling factor for Analog Encoder ADC channel 0.                                                        |
| 0x0E <sub>h</sub> | AENC_1_SCALE_OFFSET |            | This register is used to set calibration data for ADC channel AENC 1 (Offset and amplitude correction). |
|                   | AENC_1_OFFSET       | u16(15:0)  | Offset for Analog Encoder ADC channel 1.                                                                |
|                   | AENC_1_SCALE        | s16(31:16) | Scaling factor for Analog Encoder ADC channel 1.                                                        |
| 0x0F <sub>h</sub> | AENC_2_SCALE_OFFSET |            | This register is used to set calibration data for ADC channel AENC 2 (Offset and amplitude correction). |



|                   | AENC_2_OFFSET | u16(15:0)  | Offset for Analog Encoder ADC channel 2.                                                                       |
|-------------------|---------------|------------|----------------------------------------------------------------------------------------------------------------|
|                   | AENC_2_SCALE  | s16(31:16) | Scaling factor for Analog Encoder ADC channel 2.                                                               |
| 0x11 <sub>h</sub> | AENC_SELECT   |            | This register is used to select correct ADC to compensate wiring twists.                                       |
|                   | AENC_0_SELECT | u8(7:0)    | Select analog encoder ADC channel for raw analog encoder signal AENC_0_RAW.                                    |
|                   |               |            | 0: <aenc_ux_raw></aenc_ux_raw>                                                                                 |
|                   |               |            | 1: AENC_VN_RAW                                                                                                 |
|                   |               |            | 2: AENC_WY_RAW                                                                                                 |
|                   | AENC_1_SELECT | u8(15:8)   | Select analog encoder ADC channel for raw analog encoder signal AENC_1_RAW.                                    |
|                   |               |            | 0: AENC_UX_RAW                                                                                                 |
|                   |               |            | 1: <aenc_vn_raw></aenc_vn_raw>                                                                                 |
|                   |               |            | 2: AENC_WY_RAW                                                                                                 |
|                   | AENC_2_SELECT | u8(23:16)  | Select analog encoder ADC channel for raw analog encoder signal AENC_2_RAW.                                    |
|                   |               |            | 0: AENC_UX_RAW                                                                                                 |
|                   |               |            | 1: AENC_VN_RAW                                                                                                 |
|                   |               |            | 2: <aenc_wy_raw></aenc_wy_raw>                                                                                 |
| 0x12 <sub>h</sub> | ADC_IWY_IUX   |            | This register can be used to monitor phase current values (offset-compensated, scaled and correctly assigned). |
|                   | ADC_IUX       | s16(15:0)  | Register of scaled current ADC value including signed added offset as input for the FOC.                       |
|                   | ADC_IWY       | s16(31:16) | Register of scaled current ADC value including signed added offset as input for the FOC.                       |
| 0x13 <sub>h</sub> | ADC_IV        |            | This register can be used to monitor phase current ADC_IV (offset-compensated, scaled and correctly assigned). |
|                   | ADC_IV        | s16(15:0)  | Register of scaled current ADC value including signed added offset as input for the FOC.                       |



| 0x15 <sub>h</sub> | AENC_WY_UX        |            | This register displays AENC input signals (offset-compensated, scaled and correctly assigned).                                                |
|-------------------|-------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|                   | AENC_UX           | s16(15:0)  | Register of scaled analog encoder value including signed added offset as input for the interpolator.                                          |
|                   | AENC_WY           | s16(31:16) | Register of scaled analog encoder value including signed added offset as input for the interpolator.                                          |
| 0x16 <sub>h</sub> | AENC_VN           |            | This register displays AENC input signal AENC_VN (offset-compensated, scaled and correctly assigned).                                         |
|                   | AENC_VN           | s16(15:0)  | Register of scaled analog encoder value including signed added offset as input for the interpolator.                                          |
| 0x17 <sub>h</sub> | PWM_POLARITIES    |            | This register sets the polarity of PWM output signal to match gate driver.                                                                    |
|                   | PWM_POLARITIES[0] | bit(0)     | Low Side gate control                                                                                                                         |
|                   |                   |            | 0: off                                                                                                                                        |
|                   |                   |            | 1: on                                                                                                                                         |
|                   | PWM_POLARITIES[1] | bit(1)     | High Side gate control                                                                                                                        |
|                   |                   |            | 0: off                                                                                                                                        |
|                   |                   |            | 1: on                                                                                                                                         |
| 0x18 <sub>h</sub> | PWM_MAXCNT        |            | This register is used to configure PWM output frequency.                                                                                      |
|                   | PWM_MAXCNT        | u12(11:0)  | PWM maximum (count-1),<br>PWM frequency is fPWM[Hz]<br>= 100MHz/(PWM_MAXCNT+1)                                                                |
| 0x19 <sub>h</sub> | PWM_BBM_H_BBM_L   |            | This register sets the BBM times for PWM output signals. BBM time must be matched power stage needs to avoid cross conduction in half bridge. |
|                   | PWM_BBM_L         | u8(7:0)    | Break Before Make time tBBM_<br>L[10ns] for low side MOS-FET gate<br>control                                                                  |
|                   | PWM_BBM_H         | u8(15:8)   | Break Before Make time tBBM_<br>H[10ns] for high side MOS-FET<br>gate control                                                                 |



| 0x1A <sub>h</sub> | PWM_SV_CHOP             |           | This register is used to enable PWM, set different PWM test modes and switch on the SVPWM feature for higher voltage utilization (BLDC/PMSM only). |
|-------------------|-------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | PWM_CHOP                | u8(7:0)   | PWM chopper mode, defining how to chopper                                                                                                          |
|                   |                         |           | 0: off, free running                                                                                                                               |
|                   |                         |           | 1: off, low side permanent = ON                                                                                                                    |
|                   |                         |           | 2: off, high side permanent = ON                                                                                                                   |
|                   |                         |           | 3: off, free running                                                                                                                               |
|                   |                         |           | 4: off, free running                                                                                                                               |
|                   |                         |           | 5: low side chopper, high side off                                                                                                                 |
|                   |                         |           | 6: high side chopper, low side off                                                                                                                 |
|                   |                         |           | 7: centered PWM for FOC                                                                                                                            |
|                   | PWM_SV                  | bit(8)    | use Space Vector PWM                                                                                                                               |
|                   |                         |           | 0: Space Vector PWM disabled                                                                                                                       |
|                   |                         |           | 1: Space Vector PWM enabled                                                                                                                        |
| 0x1B <sub>h</sub> | MOTOR_TYPE_N_POLE_PAIRS |           | This register is used to set motor type and number of pole pairs.                                                                                  |
|                   | N_POLE_PAIRS            | u16(15:0) | Number n of pole pairs of the motor for calcualtion phi_e = phi_m / N_POLE_PAIRS.                                                                  |
|                   | MOTOR_TYPE              | u8(23:16) | 0: No motor                                                                                                                                        |
|                   |                         |           | 1: Single phase DC                                                                                                                                 |
|                   |                         |           | 2: Two phase Stepper                                                                                                                               |
|                   |                         |           | 3: Three phase BLDC                                                                                                                                |
| 0x1C <sub>h</sub> | PHI_E_EXT               |           | This register is used to set an electrical angle for SW mode when encoder is connected to MCU and not to TMC4671.                                  |
|                   | PHI_E_EXT               | s16(15:0) | Electrical angle phi_e_ext for external writing into this register.                                                                                |
| 0x1F <sub>h</sub> | OPENLOOP_MODE           |           | This register is used to change direction of openloop angle.                                                                                       |
|                   | OPENLOOP_PHI_DIRECTION  | bit(12)   | Open loop phi direction.                                                                                                                           |
|                   |                         |           | 0: positive                                                                                                                                        |
|                   | I                       |           | 1: negative                                                                                                                                        |



| 0x20 <sub>h</sub> | OPENLOOP_ACCELERATION    |            | This register is used to change acceleration when openloop angle velocity should change.                                                                                   |
|-------------------|--------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | OPENLOOP_ACCELERATION    | u32(31:0)  | Acceleration of open loop phi.                                                                                                                                             |
| 0x21 <sub>h</sub> | OPENLOOP_VELOCITY_TARGET |            | This register is used to set a target velocity for openloop angle generator. The velocity is ramped up and down according to OPENLOOP_ACCELERATION and PID_VELOCITY_LIMIT. |
|                   | OPENLOOP_VELOCITY_TARGET | s32(31:0)  | Target velocity of open loop phi.                                                                                                                                          |
| 0x22 <sub>h</sub> | OPENLOOP_VELOCITY_ACTUAL |            | This register displays actual openloop angle velocity in RPM.                                                                                                              |
|                   | OPENLOOP_VELOCITY_ACTUAL | s32(31:0)  | Actual velocity of open loop generator.                                                                                                                                    |
| 0x23 <sub>h</sub> | OPENLOOP_PHI             |            | This register displays actual output of openloop angle generator                                                                                                           |
|                   | OPENLOOP_PHI             | s16(15:0)  | Angle phi open loop (either mapped to electrical angel phi_e or mechanical angle phi_m).                                                                                   |
| 0x24 <sub>h</sub> | UQ_UD_EXT                |            | This register is used to set voltage values for openllop current control mode (UQ_UD_EXT_MODE).                                                                            |
|                   | UD_EXT                   | s16(15:0)  | External writable parameter for open loop voltage control mode, usefull during system setup, U_D component.                                                                |
|                   | UQ_EXT                   | s16(31:16) | External writable parameter for open loop voltage control mode, usefull during system setup, U_Q component.                                                                |
| 0x25 <sub>h</sub> | ABN_DECODER_MODE         |            | This register is used to configure decoder input signals and N pulse action as well as count direction.                                                                    |
|                   | apol                     | bit(0)     | Polarity of A pulse.                                                                                                                                                       |
|                   |                          |            | 0: off                                                                                                                                                                     |
|                   |                          |            | 1: on                                                                                                                                                                      |
|                   | bpol                     | bit(1)     | Polarity of B pulse.                                                                                                                                                       |
|                   |                          |            | 0: off                                                                                                                                                                     |
|                   |                          |            | 1: on                                                                                                                                                                      |
|                   | npol                     | bit(2)     | Polarity of N pulse.                                                                                                                                                       |
|                   |                          |            | 0: off                                                                                                                                                                     |
|                   |                          |            | 1: on                                                                                                                                                                      |



|                   | use_abn_as_n                   | bit(3)     | N and A and B                                                                                                                                                              |
|-------------------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                                |            | 0: Ignore A and B polarity with Npulse = N                                                                                                                                 |
|                   |                                |            | 1: Npulse = N and A and B                                                                                                                                                  |
|                   | cln                            | bit(8)     | Write direction at Npulse event between ABN_DECODER_COUNT_N and ABN_DECODER_COUNT.                                                                                         |
|                   |                                |            | 0: COUNT => COUNT_N                                                                                                                                                        |
|                   |                                |            | 1: COUNT_N => COUNT                                                                                                                                                        |
|                   | direction                      | bit(12)    | Decoder count direction.                                                                                                                                                   |
|                   |                                |            | 0: positive                                                                                                                                                                |
|                   |                                |            | 1: negative                                                                                                                                                                |
| 0x26 <sub>h</sub> | ABN_DECODER_PPR                |            | This register is used to set PPR number of encoder.                                                                                                                        |
|                   | ABN_DECODER_PPR                | u24(23:0)  | Decoder pulses per mechanical revolution.                                                                                                                                  |
| 0x27 <sub>h</sub> | ABN_DECODER_COUNT              |            | This register displays the actual count of encoder steps. It can be overwritten for initialization.                                                                        |
|                   | ABN_DECODER_COUNT              | u24(23:0)  | Raw decoder count; the digital decoder engine counts modulo (decoder_ppr).                                                                                                 |
| 0x28 <sub>h</sub> | ABN_DECODER_COUNT_N            |            | This register displays the count value at last N pulse event. It can also be used to overwrite Decoder count at N pulse evenet accroding to decoder mode register setting. |
|                   | ABN_DECODER_COUNT_N            | u24(23:0)  | Decoder count latched on N pulse, when N pulse clears decoder_count_n is 0.                                                                                                |
| 0x29 <sub>h</sub> | ABN_DECODER_PHI_E_PHI_M_OFFSET |            | This register can be used to set off-<br>sets for electrical and mechanical<br>angle calculated from decoder.                                                              |
|                   | ABN_DECODER_PHI_M_OFFSET       | s16(15:0)  | ABN_DECODER_PHI_M_OFFSET to shift (rotate) angle DECODER_PHI_M.                                                                                                            |
|                   | ABN_DECODER_PHI_E_OFFSET       | s16(31:16) | ABN_DECODER_PHI_E_OFFSET to shift (rotate) angle DECODER_PHI_E.                                                                                                            |
| 0x2A <sub>h</sub> | ABN_DECODER_PHI_E_PHI_M        |            | This register displays actual angle values for ABN encoder.                                                                                                                |



|                   | ABN_DECODER_PHI_M  | s16(15:0)  | ABN_DECODER_PHI_M = ABN_<br>DECODER_COUNT * 2^16 / ABN_<br>DECODER_PPR + ABN_DECODER_<br>PHI_M_OFFSET;                                          |
|-------------------|--------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | ABN_DECODER_PHI_E  | s16(31:16) | ABN_DECODER_PHI_E = (ABN_<br>DECODER_PHI_M * N_POLE_<br>PAIRS_) + ABN_DECODER_PHI_E_<br>OFFSET                                                  |
| 0x2C <sub>h</sub> | ABN_2_DECODER_MODE |            | This register is used to configure decoder input signals and N pulse action as well as count direction.                                         |
|                   | apol               | bit(0)     | Polarity of A pulse.                                                                                                                            |
|                   |                    |            | 0: off                                                                                                                                          |
|                   |                    |            | 1: on                                                                                                                                           |
|                   | bpol               | bit(1)     | Polarity of B pulse.                                                                                                                            |
|                   |                    |            | 0: off                                                                                                                                          |
|                   |                    |            | 1: on                                                                                                                                           |
|                   | npol               | bit(2)     | Polarity of N pulse.                                                                                                                            |
|                   |                    |            | 0: off                                                                                                                                          |
|                   |                    |            | 1: on                                                                                                                                           |
|                   | use_abn_as_n       | bit(3)     | 0: Ignore A and B polarity with Npulse = N, 1 : Npulse = N and A and B                                                                          |
|                   |                    |            | 0: Ignore A and B polarity with Npulse = N                                                                                                      |
|                   |                    |            | 1: Npulse = N and A and B                                                                                                                       |
|                   | cln                | bit(8)     | Write direction at Npulse event between ABN_2_DECODER_COUNT_N and ABN_2_DECODER_COUNT.                                                          |
|                   |                    |            | 0: COUNT => COUNT_N                                                                                                                             |
|                   |                    |            | 1: COUNT_N => COUNT                                                                                                                             |
|                   | direction          | bit(12)    | Decoder count direction.                                                                                                                        |
|                   |                    |            | 0: positive                                                                                                                                     |
|                   |                    |            | 1: negative                                                                                                                                     |
| 0x2D <sub>h</sub> | ABN_2_DECODER_PPR  |            | This register is used to set PPR number of encoder.                                                                                             |
|                   | ABN_2_DECODER_PPR  | u24(23:0)  | Decoder_2 pules per mechanical revolution. This 2nd ABN encoder interface is for positioning or velocity control but NOT for motor commutation. |



| 0x2E <sub>h</sub> | ABN_2_DECODER_COUNT        |           | This register displays the actual count of encoder steps. It can be overwritten for initialization.                                                                       |
|-------------------|----------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | ABN_2_DECODER_COUNT        | u24(23:0) | Raw decoder_2 count; the digital decoder engine counts modulo (decoder_2_ppr).                                                                                            |
| 0x2F <sub>h</sub> | ABN_2_DECODER_COUNT_N      |           | This register displays the count value at last N pulse event. It can also be used to overwrite decoder count at N pulse event according to decoder mode register setting. |
|                   | ABN_2_DECODER_COUNT_N      | u24(23:0) | Decoder_2 count latched on N pulse, when N pulse clears decoder_2_count_ also decoder_2_count_n is 0.                                                                     |
| 0x30 <sub>h</sub> | ABN_2_DECODER_PHI_M_OFFSET |           | This register can be used to set off-<br>sets for electrical and mechanical<br>angle calculated from decoder.                                                             |
|                   | ABN_2_DECODER_PHI_M_OFFSET | s16(15:0) | ABN_2_DECODER_PHI_M_OFFSET to shift (rotate) angle DECODER_2_PHI_M.                                                                                                       |
| 0x31 <sub>h</sub> | ABN_2_DECODER_PHI_M        |           | This register displays actual angle values for ABN encoder.                                                                                                               |
|                   | ABN_2_DECODER_PHI_M        | s16(15:0) | ABN_2_DECODER_PHI_M = ABN_<br>2_DECODER_COUNT * 2^16 /<br>ABN_2_DECODER_PPR + ABN_2_<br>DECODER_PHI_M_OFFSET;                                                             |
| 0x33 <sub>h</sub> | HALL_MODE                  |           | This register is used to set basic settings for the digital Hall interface.                                                                                               |
|                   | polarity                   | bit(0)    | polarity                                                                                                                                                                  |
|                   |                            |           | 0: off                                                                                                                                                                    |
|                   |                            |           | 1: on                                                                                                                                                                     |
|                   | synchronous PWM sampling   | bit(4)    | enable sampling synchronous to PWM                                                                                                                                        |
|                   |                            |           | 0: off                                                                                                                                                                    |
|                   |                            |           | 1: on                                                                                                                                                                     |
|                   | interpolation              | bit(8)    | interpolation                                                                                                                                                             |
|                   |                            |           | 0: off                                                                                                                                                                    |
|                   |                            |           | 1: on                                                                                                                                                                     |
|                   | direction                  | bit(12)   | direction                                                                                                                                                                 |
|                   |                            |           | 0: off                                                                                                                                                                    |
|                   |                            |           | 1: on                                                                                                                                                                     |



|                   | HALL_BLANK                    | u12(27:16) | tBLANK = 10ns * HALL_BLANK                                                                                      |
|-------------------|-------------------------------|------------|-----------------------------------------------------------------------------------------------------------------|
| 0x34 <sub>h</sub> | HALL_POSITION_060_000         |            | This register is used to calibrate hall sensor offset.                                                          |
|                   | HALL_POSITION_000             | s16(15:0)  | s16 hall sensor position at 0°                                                                                  |
|                   | HALL_POSITION_060             | s16(31:16) | s16 hall sensor position at 60°.                                                                                |
| 0x35 <sub>h</sub> | HALL_POSITION_180_120         |            | This register is used to calibrate hall sensor offset.                                                          |
|                   | HALL_POSITION_120             | s16(15:0)  | s16 hall sensor position at 120°.                                                                               |
|                   | HALL_POSITION_180             | s16(31:16) | s16 hall sensor position at 180°.                                                                               |
| 0x36 <sub>h</sub> | HALL_POSITION_300_240         |            | This register is used to calibrate hall sensor offset.                                                          |
|                   | HALL_POSITION_240             | s16(15:0)  | s16 hall sensor position at 240°.                                                                               |
|                   | HALL_POSITION_300             | s16(31:16) | s16 hall sensor position at 300°.                                                                               |
| 0x37 <sub>h</sub> | HALL_PHI_E_PHI_M_OFFSET       |            | This register is used to set offsets for calculated angles from hall interface.                                 |
|                   | HALL_PHI_M_OFFSET             | s16(15:0)  | Offset of mechanical angle hall_phi_m of hall decoder.                                                          |
|                   | HALL_PHI_E_OFFSET             | s16(31:16) | Offset for electrical angle hall_phi_<br>e of hall decoder.                                                     |
| 0x38 <sub>h</sub> | HALL_DPHI_MAX                 |            | This register is used to set a maxim difference of two hall sensor transitions for Hall position extrapolation. |
|                   | HALL_DPHI_MAX                 | u16(15:0)  | Maximum dx for interpolation (default for digital hall: u16/6).                                                 |
| 0x39 <sub>h</sub> | HALL_PHI_E_INTERPOLATED_PHI_E |            | This register displays interpolated and raw angle of Hall interface.                                            |
|                   | HALL_PHI_E                    | s16(15:0)  | Raw electrical angle hall_phi_e of hall decoder, selection programmed via HALL_MODE control bit.                |
|                   | HALL_PHI_E_INTERPOLATED       | s16(31:16) | Interpolated electrical angle hall_phi_e_interpolated, selection programmed via HALL_MODE controlbit.           |
| 0x3A <sub>h</sub> | HALL_PHI_M                    |            | This register displays the mechanical angle calculated in Hall sensor interface.                                |
|                   | HALL_PHI_M                    | s16(15:0)  | Mechanical angle hall_phi_m of hall decoder.                                                                    |



| 0x3B <sub>h</sub> | AENC_DECODER_MODE         |           | This register sets basic information for the analog encoder interface.                                                                                                                                          |
|-------------------|---------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | AENC_DECODER_MODE[0]      | bit(0)    | 120deg_n90deg                                                                                                                                                                                                   |
|                   |                           |           | 0: 90 degree                                                                                                                                                                                                    |
|                   |                           |           | 1: 120 degree                                                                                                                                                                                                   |
|                   | AENC_DECODER_MODE[12]     | bit(12)   | decoder count direction                                                                                                                                                                                         |
|                   |                           |           | 0: positive                                                                                                                                                                                                     |
|                   |                           |           | 1: negative                                                                                                                                                                                                     |
| 0x3C <sub>h</sub> | AENC_DECODER_N_THRESHOLD  |           | This registers sets analog encoder N pulse processing function.                                                                                                                                                 |
|                   | AENC_DECODER_N_THRESHOLD  | u16(15:0) | Threshold for generating of N pulse from analog AENC_N signal (only needed for analog SinCos encoders with analog N signal).                                                                                    |
| 0x3D <sub>h</sub> | AENC_DECODER_PHI_A_RAW    |           | Displays raw angle after ATAN2 calculation.                                                                                                                                                                     |
|                   | AENC_DECODER_PHI_A_RAW    | s16(15:0) | Raw analog angle phi calculated from analog AENC inputs (analog hall, analog SinCos,).                                                                                                                          |
| 0x3E <sub>h</sub> | AENC_DECODER_PHI_A_OFFSET |           | This register sets the offset of PHI_A for phase alignment.                                                                                                                                                     |
|                   | AENC_DECODER_PHI_A_OFFSET | s16(15:0) | Offset for angle phi from analog decoder (analog hall, analog Sin-Cos,).                                                                                                                                        |
| 0x3F <sub>h</sub> | AENC_DECODER_PHI_A        |           | This register displays offset compensated PHI_A angle.                                                                                                                                                          |
|                   | AENC_DECODER_PHI_A        | s16(15:0) | Resulting phi available for the FOC (phi_e might need to be calculated from this angle via aenc_decoder_ppr, for analog hall sensors phi_a might be used directly as phi_e depends on analog hall signal type). |
| 0x40 <sub>h</sub> | AENC_DECODER_PPR          |           | This register sets the number of periods per revolution for analog encoder.                                                                                                                                     |
|                   | AENC_DECODER_PPR          | s16(15:0) | Number of periods per revolution also called lines per revolution (different nomenclatur compared to digital ABN encoders).                                                                                     |
| 0x41 <sub>h</sub> | AENC_DECODER_COUNT        |           | Displays the count value of Analog encoder periods.                                                                                                                                                             |
|                   | AENC_DECODER_COUNT        | s32(31:0) | Decoder position, raw unscaled.                                                                                                                                                                                 |



| 0x42 <sub>h</sub> | AENC_DECODER_COUNT_N            |            | Displays the count value at last N pulse event. Can also be used to auto-overwrite decoder count at N pulse event.       |
|-------------------|---------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------|
|                   | AENC_DECODER_COUNT_N            | s32(31:0)  | Latched decoder position on analog N pulse event.                                                                        |
| 0x45 <sub>h</sub> | AENC_DECODER_PHI_E_PHI_M_OFFSET |            | This register sets offsets for electrical and mechanical angle calculated from AENC interface.                           |
|                   | AENC_DECODER_PHI_M_OFFSET       | s16(15:0)  | Offset for mechanical angle phi_m.                                                                                       |
|                   | AENC_DECODER_PHI_E_OFFSET       | s16(31:16) | Offset for electrical angle phi_e.                                                                                       |
| 0x46 <sub>h</sub> | AENC_DECODER_PHI_E_PHI_M        |            | Displays actual angle values of analog encoder interface.                                                                |
|                   | AENC_DECODER_PHI_M              | s16(15:0)  | Resulting angle phi_m.                                                                                                   |
|                   | AENC_DECODER_PHI_E              | s16(31:16) | Resulting angle phi_e.                                                                                                   |
| 0x4B <sub>h</sub> | PIDIN_VELOCITY_TARGET           |            | Displays actual target velocity at input of velocity controller.                                                         |
|                   | PIDIN_VELOCITY_TARGET           | s32(31:0)  | Target velocity at PI controller input.                                                                                  |
| 0x4C <sub>h</sub> | PIDIN_POSITION_TARGET           |            | Displays actual target position at input of position controller.                                                         |
|                   | PIDIN_POSITION_TARGET           | s32(31:0)  | Target position at PI controller input.                                                                                  |
| 0x4D <sub>h</sub> | CONFIG_DATA                     |            | This multi-purpose register is used to set configuration parameters of controller cascade and input signal conditioning. |
|                   | biquad_x_a_1                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_x_a_2                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_x_b_0                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_x_b_1                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_x_b_2                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_x_enable                 | bit(31)    | 0: off                                                                                                                   |
|                   |                                 |            | 1: on                                                                                                                    |
|                   | biquad_v_a_1                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_v_a_2                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_v_b_0                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_v_b_1                    | s32(31:0)  |                                                                                                                          |
|                   | biquad_v_b_2                    | s32(31:0)  |                                                                                                                          |



| biquad_v_enable          | bit(31)    | 0: off                                                                                                                                    |
|--------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|                          |            | 1: on                                                                                                                                     |
| biquad_t_a_1             | s32(31:0)  |                                                                                                                                           |
| biquad_t_a_2             | s32(31:0)  |                                                                                                                                           |
| biquad_t_b_0             | s32(31:0)  |                                                                                                                                           |
| biquad_t_b_1             | s32(31:0)  |                                                                                                                                           |
| biquad_t_b_2             | s32(31:0)  |                                                                                                                                           |
| biquad_t_enable          | bit(31)    | 0: off                                                                                                                                    |
|                          |            | 1: on                                                                                                                                     |
| biquad_f_a_1             | s32(31:0)  |                                                                                                                                           |
| biquad_f_a_2             | s32(31:0)  |                                                                                                                                           |
| biquad_f_b_0             | s32(31:0)  |                                                                                                                                           |
| biquad_f_b_1             | s32(31:0)  |                                                                                                                                           |
| biquad_f_b_2             | s32(31:0)  |                                                                                                                                           |
| biquad_f_enable          | bit(31)    | 0: off                                                                                                                                    |
|                          |            | 1: on                                                                                                                                     |
| prbs_amplitude           | s32(31:0)  |                                                                                                                                           |
| prbs_down_sampling_ratio | s32(31:0)  |                                                                                                                                           |
| ref_switch_config        | u16(15:0)  |                                                                                                                                           |
| Encoder_Init_hall_Enable | bit(0)     | 0: off                                                                                                                                    |
|                          |            | 1: on                                                                                                                                     |
| SINGLE_PIN_IF_CFG        | u8(7:0)    |                                                                                                                                           |
| SINGLE_PIN_IF_STATUS     | u16(31:16) |                                                                                                                                           |
| SINGLE_PIN_IF_OFFSET     | u16(15:0)  | Offset for scaling of Single pin Interface input                                                                                          |
| SINGLE_PIN_IF_SCALE      | s16(31:16) | Gain factor of Single pin Interface input                                                                                                 |
| CURRENT_I_nQ8.8_Q4.12    | bit(0)     | If this bit is set Q4.12 representation of I parameter for torque/flux control is used. If bit is not set Q8.8 representation is used     |
|                          |            | 0: Q8.8 representation is used                                                                                                            |
|                          |            | 1: Q4.12 representation is used                                                                                                           |
| CURRENT_P_nQ8.8_Q4.12    | bit(1)     | If this bit is set Q4.12 representation of P for parameter for torque/flux control is used. If bit is not set Q8.8 representation is used |
|                          |            | 0: Q8.8 representation is used                                                                                                            |



|                   |                        |           | 1: Q4.12 representation is used                                                                                                        |
|-------------------|------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
|                   | VELOCITY_I_nQ8.8_Q4.12 | bit(2)    | If this bit is set Q4.12 representation of I parameter for velocity control is used. If bit is not set Q8.8 representation is used     |
|                   |                        |           | 0: Q8.8 representation is used                                                                                                         |
|                   |                        |           | 1: Q4.12 representation is used                                                                                                        |
|                   | VELOCITY_P_nQ8.8_Q4.12 | bit(3)    | If this bit is set Q4.12 representation of P for parameter for velocity control is used. If bit is not set Q8.8 representation is used |
|                   |                        |           | 0: Q8.8 representation is used                                                                                                         |
|                   |                        |           | 1: Q4.12 representation is used                                                                                                        |
|                   | POSITION_I_nQ8.8_Q4.12 | bit(4)    | If this bit is set Q4.12 representation of I parameter for position control is used. If bit is not set Q8.8 representation is used     |
|                   |                        |           | 0: Q8.8 representation is used                                                                                                         |
|                   |                        |           | 1: Q4.12 representation is used                                                                                                        |
|                   | POSITION_P_nQ8.8_Q4.12 | bit(5)    | If this bit is set Q4.12 representation of P for parameter for position control is used. If bit is not set Q8.8 representation is used |
|                   |                        |           | 0: Q8.8 representation is used                                                                                                         |
|                   |                        |           | 1: Q4.12 representation is used                                                                                                        |
| 0x4E <sub>h</sub> | CONFIG_ADDR            |           | This register is used to select function of CONFIG_DATA register.                                                                      |
|                   | CONFIG_ADDR            | u32(31:0) | 1: biquad_x_a_1                                                                                                                        |
|                   |                        |           | 2: biquad_x_a_2                                                                                                                        |
|                   |                        |           | 4: biquad_x_b_0                                                                                                                        |
|                   |                        |           | 5: biquad_x_b_1                                                                                                                        |
|                   |                        |           | 6: biquad_x_b_2                                                                                                                        |
|                   |                        |           | 7: biquad_x_enable                                                                                                                     |
|                   |                        |           | 9: biquad_v_a_1                                                                                                                        |
|                   |                        |           | 10: biquad_v_a_2                                                                                                                       |
|                   |                        |           | 12: biquad_v_b_0                                                                                                                       |
|                   |                        |           | 13: biquad_v_b_1                                                                                                                       |
|                   |                        |           | 14: biquad_v_b_2                                                                                                                       |
|                   |                        |           | 15: biquad_v_enable                                                                                                                    |
|                   |                        |           | 17: biquad_t_a_1                                                                                                                       |



|                   |                                        | I       | 40.1: 14.0                                                                                                                                                                                                                                                                                                        |
|-------------------|----------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                                        |         | 18: biquad_t_a_2                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 20: biquad_t_b_0                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 21: biquad_t_b_1                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 22: biquad_t_b_2                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 23: biquad_t_enable                                                                                                                                                                                                                                                                                               |
|                   |                                        |         | 25: biquad_f_a_1                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 26: biquad_f_a_2                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 28: biquad_f_b_0                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 29: biquad_f_b_1                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 30: biquad_f_b_2                                                                                                                                                                                                                                                                                                  |
|                   |                                        |         | 31: biquad_f_enable                                                                                                                                                                                                                                                                                               |
|                   |                                        |         | 32: prbs_amplitude                                                                                                                                                                                                                                                                                                |
|                   |                                        |         | 33: prbs_down_sampling_ratio                                                                                                                                                                                                                                                                                      |
|                   |                                        |         | 51: ref_switch_config                                                                                                                                                                                                                                                                                             |
|                   |                                        |         | 52: Encoder_Init_hall_Enable                                                                                                                                                                                                                                                                                      |
|                   |                                        |         | 60: SINGLE_PIN_IF_STATUS_CFG                                                                                                                                                                                                                                                                                      |
|                   |                                        |         | 61: SINGLE_PIN_IF_SCALE_OFFSET                                                                                                                                                                                                                                                                                    |
|                   |                                        |         | 62: ADVANCED_PI_REPRESENT.                                                                                                                                                                                                                                                                                        |
| 0                 | l                                      |         |                                                                                                                                                                                                                                                                                                                   |
| 0x50 <sub>h</sub> | VELOCITY_SELECTION                     |         | This register is used to select an angle signal for the velocity control loop and velocity calculation.                                                                                                                                                                                                           |
| 0x50 <sub>h</sub> | VELOCITY_SELECTION  VELOCITY_SELECTION | u8(7:0) | angle signal for the velocity con-                                                                                                                                                                                                                                                                                |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation. Selects the source of the velocity                                                                                                                                                                                                           |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.                                                                                                                                                                         |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION                                                                                                                                                     |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext                                                                                                                                       |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop                                                                                                                    |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn                                                                                                      |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved                                                                                         |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal                                                                           |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal  6: phi_e_aenc                                                            |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal  6: phi_e_aenc  7: phi_a_aenc                                             |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal  6: phi_e_aenc  7: phi_a_aenc  8: reserved                                |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal  6: phi_e_aenc  7: phi_a_aenc  8: reserved  9: phi_m_abn                  |
| UX5U <sub>h</sub> |                                        | u8(7:0) | angle signal for the velocity control loop and velocity calculation.  Selects the source of the velocity source for velocity measurement.  0: PHI_E_SELECTION  1: phi_e_ext  2: phi_e_openloop  3: phi_e_abn  4: reserved  5: phi_e_hal  6: phi_e_aenc  7: phi_a_aenc  8: reserved  9: phi_m_abn  10: phi_m_abn_2 |



|                   |                       |            | 1: advanced                                                                                              |
|-------------------|-----------------------|------------|----------------------------------------------------------------------------------------------------------|
| 0x51 <sub>h</sub> | POSITION_SELECTION    |            | This register is used to select an angle signal for the position calculation and control loop.           |
|                   | POSITION_SELECTION    | u8(7:0)    | 0: phi_e selected via PHI_E_<br>SELECTION                                                                |
|                   |                       |            | 1: phi_e_ext                                                                                             |
|                   |                       |            | 2: phi_e_openloop                                                                                        |
|                   |                       |            | 3: phi_e_abn                                                                                             |
|                   |                       |            | 4: reserved                                                                                              |
|                   |                       |            | 5: phi_e_hal                                                                                             |
|                   |                       |            | 6: phi_e_aenc                                                                                            |
|                   |                       |            | 7: phi_a_aenc                                                                                            |
|                   |                       |            | 8: reserved                                                                                              |
|                   |                       |            | 9: phi_m_abn                                                                                             |
|                   |                       |            | 10: phi_m_abn_2                                                                                          |
|                   |                       |            | 11: phi_m_aenc                                                                                           |
|                   |                       |            | 12: phi_m_hal                                                                                            |
| 0x52 <sub>h</sub> | PHI_E_SELECTION       |            | This register is used to select an angle signal for FOC transformation as electrical angle of the motor. |
|                   | PHI_E_SELECTION       | u8(7:0)    | 0: reserved                                                                                              |
|                   |                       |            | 1: phi_e_ext                                                                                             |
|                   |                       |            | 2: phi_e_openloop                                                                                        |
|                   |                       |            | 3: phi_e_abn                                                                                             |
|                   |                       |            | 4: reserved                                                                                              |
|                   |                       |            | 5: phi_e_hal                                                                                             |
|                   |                       |            | 6: phi_e_aenc                                                                                            |
|                   |                       |            | 7: phi_a_aenc                                                                                            |
| 0x53 <sub>h</sub> | PHI_E                 |            | This register displays the actual chosen electrical angle value.                                         |
|                   | PHI_E                 | s16(15:0)  | Angle used for the inner FOC loop.                                                                       |
| 0x54 <sub>h</sub> | PID_FLUX_P_FLUX_I     |            | This registers sets control parameters for flux controller.                                              |
|                   | PID_FLUX_I            | s16(15:0)  |                                                                                                          |
|                   | PID_FLUX_P            | s16(31:16) |                                                                                                          |
| 0x56 <sub>h</sub> | PID_TORQUE_P_TORQUE_I |            | This registers sets control parameters for torque controller.                                            |



|                   | PID_TORQUE_I              | s16(15:0)  |                                                                                                                                                           |
|-------------------|---------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | PID_TORQUE_P              | s16(31:16) |                                                                                                                                                           |
| 0x58 <sub>h</sub> | PID_VELOCITY_P_VELOCITY_I |            | This registers sets control parameters for velocity controller.                                                                                           |
|                   | PID_VELOCITY_I            | s16(15:0)  |                                                                                                                                                           |
|                   | PID_VELOCITY_P            | s16(31:16) |                                                                                                                                                           |
| 0x5A <sub>h</sub> | PID_POSITION_P_POSITION_I |            | This registers sets control parameters for position controller.                                                                                           |
|                   | PID_POSITION_I            | s16(15:0)  |                                                                                                                                                           |
|                   | PID_POSITION_P            | s16(31:16) |                                                                                                                                                           |
| 0x5D <sub>h</sub> | PIDOUT_UQ_UD_LIMITS       |            | This register sets the output voltage/duty cycle limit for the current controllers. iPARK CIRLIM block limits voltage output vector length to this value. |
|                   | PIDOUT_UQ_UD_LIMITS       | s16(15:0)  | Two dimensional circular limiter for inputs of iPark. HINT: The absolute value of the register is used (possible values: 0 32767).                        |
| 0x5E <sub>h</sub> | PID_TORQUE_FLUX_LIMITS    |            | This register is used to set target current limit for both controllers.                                                                                   |
|                   | PID_TORQUE_FLUX_LIMITS    | u16(15:0)  | PID torque limt and PID flux limit, limits the target values coming from the target registers.                                                            |
| 0x60 <sub>h</sub> | PID_VELOCITY_LIMIT        |            | This register is used to set an absolute velocity limit for velocity controller input.                                                                    |
|                   | PID_VELOCITY_LIMIT        | u32(31:0)  | Velocity limit.                                                                                                                                           |
| 0x61 <sub>h</sub> | PID_POSITION_LIMIT_LOW    |            | This register is used to set a lower limit for position controller input.                                                                                 |
|                   | PID_POSITION_LIMIT_LOW    | s32(31:0)  | Position limit low, programmable position barrier.                                                                                                        |
| 0x62 <sub>h</sub> | PID_POSITION_LIMIT_HIGH   |            | This register is used to set a higher limit for position controller input.                                                                                |
|                   | PID_POSITION_LIMIT_HIGH   | s32(31:0)  | Position limit high, programmable position barrier.                                                                                                       |
| 0x63 <sub>h</sub> | MODE_RAMP_MODE_MOTION     |            | This register is used to set a motion mode, a downsampling factor for velocity and position control loop, and the PI controller structure type.           |
|                   | MODE_MOTION               | u8(7:0)    | 0: stopped_mode<br>1: torque_mode                                                                                                                         |



|                   |                        |            | 2: velocity_mode                                                                   |
|-------------------|------------------------|------------|------------------------------------------------------------------------------------|
|                   |                        |            | 3: position_mode                                                                   |
|                   |                        |            | 4: prbs_flux_mode                                                                  |
|                   |                        |            | 5: prbs_torque_mode                                                                |
|                   |                        |            | 6: prbs_velocity_mode                                                              |
|                   |                        |            | 7: prbs_position_mode                                                              |
|                   |                        |            | 8: uq_ud_ext                                                                       |
|                   |                        |            | 9: reserved                                                                        |
|                   |                        |            | 10: AGPI_A torque_mode                                                             |
|                   |                        |            | 11: AGPI_A velocity_mode                                                           |
|                   |                        |            | 12: AGPI_A position_mode                                                           |
|                   |                        |            | 13: PWM_I torque_mode                                                              |
|                   |                        |            | 14: PWM_I velocity_mode                                                            |
|                   |                        |            | 15: PWM_I position_mode                                                            |
|                   | MODE_PID_SMPL          | u7(30:24)  |                                                                                    |
|                   | MODE_PID_TYPE          | bit(31)    | 0: parallel/classic PI                                                             |
|                   |                        |            | 1: sequential/advanced PI                                                          |
| 0x64 <sub>h</sub> | PID_TORQUE_FLUX_TARGET |            | Target values for torque and flux controllers in torque mode.                      |
|                   | PID_FLUX_TARGET        | s16(15:0)  |                                                                                    |
|                   | PID_TORQUE_TARGET      | s16(31:16) |                                                                                    |
| 0x65 <sub>h</sub> | PID_TORQUE_FLUX_OFFSET |            | Offsets for software torque and flux control loop inputs for feed-forward control. |
|                   | PID_FLUX_OFFSET        | s16(15:0)  | Flux offset for feed forward control.                                              |
|                   | PID_TORQUE_OFFSET      | s16(31:16) | Torque offset for feed forward control.                                            |
| 0x66 <sub>h</sub> | PID_VELOCITY_TARGET    |            | Target velocity value for velocity controller in velocity mode.                    |
|                   | PID_VELOCITY_TARGET    | s32(31:0)  | Target velocity register (for velocity mode).                                      |
| 0x67 <sub>h</sub> | PID_VELOCITY_OFFSET    |            | Offset velocity value for velocity controller in velocity and position mode.       |
|                   | PID_VELOCITY_OFFSET    | s32(31:0)  | Velocity offset for feed forward control.                                          |
| 0x68 <sub>h</sub> | PID_POSITION_TARGET    |            | Target position value for position controller in position mode.                    |



|                   | PID_POSITION_TARGET    | s32(31:0)  | Target position register (for position mode).                                                                                                                                                                                                                                   |
|-------------------|------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x69 <sub>h</sub> | PID_TORQUE_FLUX_ACTUAL |            | Target position offset value for position controller in position mode.                                                                                                                                                                                                          |
|                   | PID_FLUX_ACTUAL        | s16(15:0)  |                                                                                                                                                                                                                                                                                 |
|                   | PID_TORQUE_ACTUAL      | s16(31:16) |                                                                                                                                                                                                                                                                                 |
| 0x6A <sub>h</sub> | PID_VELOCITY_ACTUAL    |            | Filtered actual velocity derived from chosen angle signal.                                                                                                                                                                                                                      |
|                   | PID_VELOCITY_ACTUAL    | s32(31:0)  | Actual velocity.                                                                                                                                                                                                                                                                |
| 0x6B <sub>h</sub> | PID_POSITION_ACTUAL    |            | Actual position derived from chosen position signal.                                                                                                                                                                                                                            |
|                   | PID_POSITION_ACTUAL    | s32(31:0)  | Actual multi turn position for positioning. Input position differences are accumulated. Lower 16 bits display one revolution of input angle. Upper 16 bits display revolutions. WRITE on PID_POSITION_ACTUAL writes same value into PID_POSITION_TARGET to avoid unwanted move. |
| 0x6C <sub>h</sub> | PID_ERROR_DATA         |            | Register displays control errors of controllers for testing according to selection PID_ERROR_ADDR .                                                                                                                                                                             |
|                   | PID_TORQUE_ERROR       | s32(31:0)  | PID torque error.                                                                                                                                                                                                                                                               |
|                   | PID_FLUX_ERROR         | s32(31:0)  | PID flux error.                                                                                                                                                                                                                                                                 |
|                   | PID_VELOCITY_ERROR     | s32(31:0)  | PID velocity error.                                                                                                                                                                                                                                                             |
|                   | PID_POSITION_ERROR     | s32(31:0)  | PID position error.                                                                                                                                                                                                                                                             |
|                   | PID_TORQUE_ERROR_SUM   | s32(31:0)  | PID torque error.                                                                                                                                                                                                                                                               |
|                   | PID_FLUX_ERROR_SUM     | s32(31:0)  | PID flux error sum.                                                                                                                                                                                                                                                             |
|                   | PID_VELOCITY_ERROR_SUM | s32(31:0)  | PID velocity error sum.                                                                                                                                                                                                                                                         |
|                   | PID_POSITION_ERROR_SUM | s32(31:0)  | PID position error sum.                                                                                                                                                                                                                                                         |
| 0x6D <sub>h</sub> | PID_ERROR_ADDR         |            | Register is used to set function of PID_ERROR_DATA register.                                                                                                                                                                                                                    |
|                   | PID_ERROR_ADDR         | u8(7:0)    | 0: PID_TORQUE_ERROR                                                                                                                                                                                                                                                             |
|                   |                        |            | 1: PID_FLUX_ERROR                                                                                                                                                                                                                                                               |
|                   |                        |            | 2: PID_VELOCITY_ERROR                                                                                                                                                                                                                                                           |
|                   |                        |            | 3: PID_POSITION_ERROR                                                                                                                                                                                                                                                           |
|                   |                        |            | 4: PID_TORQUE_ERROR_SUM                                                                                                                                                                                                                                                         |
|                   |                        |            | 5: PID_FLUX_ERROR_SUM                                                                                                                                                                                                                                                           |
|                   |                        |            | 6: PID_VELOCITY_ERROR_SUM                                                                                                                                                                                                                                                       |



|                   |                          |            | 7: PID_POSITION_ERROR_SUM                                                                 |
|-------------------|--------------------------|------------|-------------------------------------------------------------------------------------------|
| 0x6E <sub>h</sub> | INTERIM_DATA             |            | This register is used to display internal signals from controller cascade for monitoring. |
|                   | PIDIN_TARGET_TORQUE      | s32(31:0)  | PIDIN target torque.                                                                      |
|                   | PIDIN_TARGET_FLUX        | s32(31:0)  | PIDIN target flux.                                                                        |
|                   | PIDIN_TARGET_VELOCITY    | s32(31:0)  | PIDIN target velocity.                                                                    |
|                   | PIDIN_TARGET_POSITION    | s32(31:0)  | PIDIN target position.                                                                    |
|                   | PIDOUT_TARGET_TORQUE     | s32(31:0)  | PIDOUT target torque.                                                                     |
|                   | PIDOUT_TARGET_FLUX       | s32(31:0)  | PIDOUT target flux.                                                                       |
|                   | PIDOUT_TARGET_VELOCITY   | s32(31:0)  | PIDOUT target velocity.                                                                   |
|                   | PIDOUT_TARGET_POSITION   | s32(31:0)  | PIDOUT target position.                                                                   |
|                   | FOC_IUX                  | s16(15:0)  |                                                                                           |
|                   | FOC_IWY                  | s16(31:16) |                                                                                           |
|                   | FOC_IV                   | s16(15:0)  |                                                                                           |
|                   | FOC_IA                   | s16(15:0)  |                                                                                           |
|                   | FOC_IB                   | s16(31:16) |                                                                                           |
|                   | FOC_ID                   | s16(15:0)  |                                                                                           |
|                   | FOC_IQ                   | s16(31:16) |                                                                                           |
|                   | FOC_UD                   | s16(15:0)  |                                                                                           |
|                   | FOC_UQ                   | s16(31:16) |                                                                                           |
|                   | FOC_UD_LIMITED           | s16(15:0)  |                                                                                           |
|                   | FOC_UQ_LIMITED           | s16(31:16) |                                                                                           |
|                   | FOC_UA                   | s16(15:0)  |                                                                                           |
|                   | FOC_UB                   | s16(31:16) |                                                                                           |
|                   | FOC_UUX                  | s16(15:0)  |                                                                                           |
|                   | FOC_UWY                  | s16(31:16) |                                                                                           |
|                   | FOC_UV                   | s16(15:0)  |                                                                                           |
|                   | PWM_UX                   | s16(15:0)  |                                                                                           |
|                   | PWM_WY                   | s16(31:16) |                                                                                           |
|                   | PWM_V                    | s16(15:0)  |                                                                                           |
|                   | ADC_I_0                  | s16(15:0)  |                                                                                           |
|                   | ADC_I_1                  | s16(31:16) |                                                                                           |
|                   | PID_FLUX_ACTUAL_DIV256   | s8(7:0)    |                                                                                           |
|                   | PID_TORQUE_ACTUAL_DIV256 | s8(15:8)   |                                                                                           |
|                   | PID_FLUX_TARGET_DIV256   | s8(23:16)  |                                                                                           |
|                   | PID_TORQUE_TARGET_DIV256 | s8(31:24)  |                                                                                           |



|                   | PID_TORQUE_ACTUAL               | s16(15:0)  |                                         |
|-------------------|---------------------------------|------------|-----------------------------------------|
|                   | PID_TORQUE_TARGET               | s16(31:16) |                                         |
|                   | PID_FLUX_ACTUAL                 | s16(15:0)  |                                         |
|                   | PID_FLUX_TARGET                 | s16(31:16) |                                         |
|                   | PID_VELOCITY_ACTUAL_DIV256      | s16(15:0)  |                                         |
|                   | PID_VELOCITY_TARGET_DIV256      | s16(31:16) |                                         |
|                   | PID_VELOCITY_ACTUAL_LSB         | s16(15:0)  |                                         |
|                   | PID_VELOCITY_TARGET_LSB         | s16(31:16) |                                         |
|                   | PID_POSITION_ACTUAL_DIV256      | s16(15:0)  |                                         |
|                   | PID_POSITION_TARGET_DIV256      | s16(31:16) |                                         |
|                   | PID_POSITION_ACTUAL_LSB         | s16(15:0)  |                                         |
|                   | PID_POSITION_TARGET_LSB         | s16(31:16) |                                         |
|                   | FF_VELOCITY                     | s32(31:0)  |                                         |
|                   | FF_TORQUE                       | s16(15:0)  |                                         |
|                   | ACTUAL_VELOCITY_PPTM            | s32(31:0)  |                                         |
|                   | REF_SWITCH_STATUS               | u16(15:0)  |                                         |
|                   | HOME_POSITION                   | s32(31:0)  |                                         |
|                   | LEFT_POSITION                   | s32(31:0)  |                                         |
|                   | RIGHT_POSITION                  | s32(31:0)  |                                         |
|                   | ENC_INIT_HALL_STATUS            | u16(15:0)  |                                         |
|                   | ENC_INIT_HALL_PHI_E_ABN_OFFSET  | u16(15:0)  |                                         |
|                   | ENC_INIT_HALL_PHI_E_AENC_OFFSET | u16(15:0)  |                                         |
|                   | ENC_INIT_HALL_PHI_A_AENC_OFFSET | u16(15:0)  |                                         |
|                   | SINGLE_PIN_IF_TARGET_TORQUE     | s16(15:0)  |                                         |
|                   | SINGLE_PIN_IF_PWM_DUTY_CYCLE    | s16(31:16) |                                         |
|                   | SINGLE_PIN_IF_TARGET_VELOCITY   | s32(31:0)  |                                         |
|                   | SINGLE_PIN_IF_TARGET_POSITION   | s32(31:0)  |                                         |
| 0x6F <sub>h</sub> | INTERIM_ADDR                    |            | Sets function of register INTERIM_DATA. |
|                   | INTERIM_ADDR                    | u8(7:0)    | 0: PIDIN_TARGET_TORQUE                  |
|                   |                                 |            | 1: PIDIN_TARGET_FLUX                    |
|                   |                                 |            | 2: PIDIN_TARGET_VELOCITY                |
|                   |                                 |            | 3: PIDIN_TARGET_POSITION                |
|                   |                                 |            | 4: PIDOUT_TARGET_TORQUE                 |
|                   |                                 |            | 5: PIDOUT_TARGET_FLUX                   |
|                   |                                 |            | 6: PIDOUT_TARGET_VELOCITY               |
|                   |                                 | •          | •                                       |



- 7: PIDOUT\_TARGET\_POSITION
- 8: FOC\_IWY\_IUX
- 9: FOC\_IV
- 10: FOC\_IB\_IA
- 11: FOC\_IQ\_ID
- 12: FOC\_UQ\_UD
- 13: FOC\_UQ\_UD\_LIMITED
- 14: FOC\_UB\_UA
- 15: FOC\_UWY\_UUX
- 16: FOC\_UV
- 17: PWM\_WY\_UX
- 18: PWM\_UV
- 19: ADC\_I1\_I0
- 20: PID\_TORQUE\_TARGET\_FLUX\_ TARGET\_TORQUE\_ACTUAL\_FLUX\_ ACTUAL\_DIV256
- 21: PID\_TORQUE\_TARGET\_ TORQUE\_ACTUAL
- 22: PID\_FLUX\_TARGET\_FLUX\_ ACTUAL
- 23: PID\_VELOCITY\_TARGET\_ VELOCITY\_ACTUAL\_DIV256
- 24: PID\_VELOCITY\_TARGET\_ VELOCITY\_ACTUAL
- 25: PID\_POSITION\_TARGET\_ POSITION\_ACTUAL\_DIV256
- 26: PID\_POSITION\_TARGET\_ POSITION\_ACTUAL
- 27: FF\_VELOCITY
- 28: FF\_TORQUE
- 29: ACTUAL\_VELOCITY\_PPTM
- 30: REF\_SWITCH\_STATUS
- 31: HOME\_POSITION
- 32: LEFT\_POSITION
- 33: RIGHT POSITION
- 34: ENC\_INIT\_HALL\_STATUS
- 35: ENC\_INIT\_HALL\_PHI\_E\_ABN\_ OFFSET



|                   |                    |            | 36: ENC_INIT_HALL_PHI_E_AENC_<br>OFFSET                                    |
|-------------------|--------------------|------------|----------------------------------------------------------------------------|
|                   |                    |            | 37: ENC_INIT_HALL_PHI_A_AENC_<br>OFFSET                                    |
|                   |                    |            | 42: SINGLE_PIN_IF_PWM_DUTY_<br>CYCLE_TORQUE_TARGET                         |
|                   |                    |            | 43: SINGLE_PIN_IF_VELOCITY_<br>TARGET                                      |
|                   |                    |            | 44: SINGLE_PIN_IF_POSITION_<br>TARGET                                      |
| 0x75 <sub>h</sub> | ADC_VM_LIMITS      |            | Sets supply voltage limits for brake chopper output action.                |
|                   | ADC_VM_LIMIT_LOW   | u16(15:0)  | Low limit for brake chopper output BRAKE_OUT.                              |
|                   | ADC_VM_LIMIT_HIGH  | u16(31:16) | High limit for brake chopper output BRAKE_OUT.                             |
| 0x76 <sub>h</sub> | TMC4671_INPUTS_RAW |            | Displays actual input signals of IC for monitoring and connection testing. |
|                   | A of ABN_RAW       | bit(0)     | A of ABN_RAW                                                               |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | B of ABN_RAW       | bit(1)     | B of ABN_RAW                                                               |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | N of ABN_RAW       | bit(2)     | N of ABN_RAW                                                               |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | -                  | bit(3)     | _                                                                          |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | A of ABN_2_RAW     | bit(4)     | A of ABN_2_RAW                                                             |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | B of ABN_2_RAW     | bit(5)     | B of ABN_2_RAW                                                             |
|                   |                    |            | 0: off                                                                     |
|                   |                    |            | 1: on                                                                      |
|                   | N of ABN_2_RAW     | bit(6)     | N of ABN_2_RAW                                                             |
|                   |                    |            | 0: off                                                                     |



|                       | bit(7)  | 1: on               |
|-----------------------|---------|---------------------|
| -                     | Dit(7)  | 0: off              |
|                       |         | 1: on               |
| HALL_UX of HALL_RAW   | bit(8)  | HALL_UX of HALL_RAW |
| TIALL_OX OF TIALL_NAW | Dit(o)  | 0: off              |
|                       |         | 1: on               |
| HALL V of HALL DAW    | hi+(O)  |                     |
| HALL_V of HALL_RAW    | bit(9)  | HALL_V of HALL_RAW  |
|                       |         | 0: off              |
|                       | 1:440   | 1: on               |
| HALL_WY of HALL_RAW   | bit(10) | HALL_WY of HALL_RAW |
|                       |         | 0: off              |
|                       |         | 1: on               |
| -                     | bit(11) | _                   |
|                       |         | 0: off              |
|                       |         | 1: on               |
| REF_SW_R_RAW          | bit(12) | REF_SW_R_RAW        |
|                       |         | 0: off              |
|                       |         | 1: on               |
| REF_SW_H_RAW          | bit(13) | REF_SW_H_RAW        |
|                       |         | 0: off              |
|                       |         | 1: on               |
| REF_SW_L_RAW          | bit(14) | REF_SW_L_RAW        |
|                       |         | 0: off              |
|                       |         | 1: on               |
| ENABLE_IN_RAW         | bit(15) | ENABLE_IN_RAW       |
|                       |         | 0: off              |
|                       |         | 1: on               |
| STP of DIRSTP_RAW     | bit(16) | STP of DIRSTP_RAW   |
|                       |         | 0: off              |
|                       |         | 1: on               |
| DIR of DIRSTP_RAW     | bit(17) | DIR of DIRSTP_RAW   |
|                       |         | 0: off              |
|                       |         | 1: on               |
| PWM_IN_RAW            | bit(18) | PWM_IN_RAW          |
|                       |         | 0: off              |
|                       | I       |                     |



|                |         | 1: on            |
|----------------|---------|------------------|
| -              | bit(19) | _                |
|                |         | 0: off           |
|                |         | 1: on            |
| HALL_UX_FILT   | bit(20) | ESI_0 of ESI_RAW |
|                |         | 0: off           |
|                |         | 1: on            |
| HALL_V_FILT    | bit(21) | ESI_1 of ESI_RAW |
|                |         | 0: off           |
|                |         | 1: on            |
| HALL_WY_FILT   | bit(22) | ESI_2 of ESI_RAW |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(23) | _                |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(24) | CFG_0 of CFG     |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(25) | CFG_1 of CFG     |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(26) | CFG_2 of CFG     |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(27) | CFG_3 of CFG     |
|                |         | 0: off           |
|                |         | 1: on            |
| PWM_IDLE_L_RAW | bit(28) | PWM_IDLE_L_RAW   |
|                |         | 0: off           |
|                |         | 1: on            |
| PWM_IDLE_H_RAW | bit(29) | PWM_IDLE_H_RAW   |
|                |         | 0: off           |
|                |         | 1: on            |
| -              | bit(30) | DRV_ERR_IN_RAW   |
|                |         | 0: off           |
| I              | 1       | I                |



|                   |                        |         | 1: on                                                                                                                                                 |
|-------------------|------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | _                      | bit(31) | _                                                                                                                                                     |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
| 0x77 <sub>h</sub> | TMC4671_OUTPUTS_RAW    |         | Displays actual output signals of IC for monitoring and connection testing.                                                                           |
|                   | TMC4671_OUTPUTS_RAW[0] | bit(0)  | PWM_UX1_L                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[1] | bit(1)  | PWM_UX1_H                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[2] | bit(2)  | PWM_VX2_L                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[3] | bit(3)  | PWM_VX2_H                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[4] | bit(4)  | PWM_WY1_L                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[5] | bit(5)  | PWM_WY1_H                                                                                                                                             |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[6] | bit(6)  | PWM_Y2_L                                                                                                                                              |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
|                   | TMC4671_OUTPUTS_RAW[7] | bit(7)  | PWM_Y2_H                                                                                                                                              |
|                   |                        |         | 0: off                                                                                                                                                |
|                   |                        |         | 1: on                                                                                                                                                 |
| 0x78 <sub>h</sub> | STEP_WIDTH             |         | Sets a Step width of an acutal input step signal on STEP/DIR interface. Target position is decreased/increased by this value according to Dir signal. |



|                   | STEP_WIDTH            | s32(31:0) | STEP WIDTH = 0 => STP pulses ignored, resulting direction = DIR XOR sign(STEP_WIDTH), effects PID_POSITION_TARGET                              |
|-------------------|-----------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x79 <sub>h</sub> | UART_BPS              |           | Sets the desired UART baudrate.<br>Must be entered as hexadecimal<br>number (e.g baudrate 9600 is set<br>by entering 0x00009600 <sub>h</sub> ) |
|                   | UART_BPS              | u24(23:0) | $\begin{array}{ccc} 0x00009600_h, & 0x00115200_h, \\ 0x00921600_h, & 0x030000000_h \\ (default=0x00009600) \end{array}$                        |
| 0x7B <sub>h</sub> | GPIO_dsADCI_CONFIG    |           | Sets the function and controls the GPIOs if RTMI is not used. Check functional description for detailed explanation of options.                |
|                   | GPIO_dsADCI_CONFIG[0] | bit(0)    | SEL_nDBGSPIM_GPIO                                                                                                                              |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[1] | bit(1)    | SEL_nGPIO_dsADCS_A                                                                                                                             |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[2] | bit(2)    | SEL_nGPIO_dsADCS_B                                                                                                                             |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[3] | bit(3)    | SEL_GPIO_GROUP_A_nIN_OUT                                                                                                                       |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[4] | bit(4)    | SEL_GPIO_GROUP_B_nIN_OUT                                                                                                                       |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[5] | bit(5)    | SEL_GROUP_A_DSADCS_nCLKIN_<br>CLKOUT                                                                                                           |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPIO_dsADCI_CONFIG[6] | bit(6)    | SEL_GROUP_B_DSADCS_nCLKIN_<br>CLKOUT                                                                                                           |
|                   |                       |           | 0: off                                                                                                                                         |
|                   |                       |           | 1: on                                                                                                                                          |
|                   | GPO                   | u8(23:16) |                                                                                                                                                |
|                   | GPI                   | u8(31:24) |                                                                                                                                                |



| 0x7C <sub>h</sub> | STATUS_FLAGS     |         | Displays actual status flags to set status output. The register is also used to reset status flags. |
|-------------------|------------------|---------|-----------------------------------------------------------------------------------------------------|
|                   | STATUS_FLAGS[0]  | bit(0)  | pid_x_target_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[1]  | bit(1)  | pid_x_target_ddt_limit                                                                              |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[2]  | bit(2)  | pid_x_errsum_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[3]  | bit(3)  | pid_x_output_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[4]  | bit(4)  | pid_v_target_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[5]  | bit(5)  | pid_v_target_ddt_limit                                                                              |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[6]  | bit(6)  | pid_v_errsum_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[7]  | bit(7)  | pid_v_output_limit                                                                                  |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[8]  | bit(8)  | pid_id_target_limit                                                                                 |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[9]  | bit(9)  | pid_id_target_ddt_limit                                                                             |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |
|                   | STATUS_FLAGS[10] | bit(10) | pid_id_errsum_limit                                                                                 |
|                   |                  |         | 0: off                                                                                              |
|                   |                  |         | 1: on                                                                                               |



| 0: off   1: on   pid_iq_target_limit   0: off   1: on   pid_iq_target_limit   0: off   1: on   pid_iq_target_dot_limit   0: off   1: on   pid_iq_target_limit   0: off   0: | STATUS_FLAGS[11] | bit(11) | pid_id_output_limit     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------|-------------------------|
| STATUS_FLAGS[12]         bit(12)         pid_iq_target_limit 0: off 1: on 1: on pid_iq_target_ddt_limit 0: off 1: on pid_iq_target_ddt_limit 0: off 1: on pid_iq_errsum_limit 0: off 1: on pid_iq_errsum_limit 0: off 1: on pid_iq_output_limit 0: off 1: on pid_iq_output_limit_u_d 0: off 1: on pid_id_output_limit_u_d 0: off 1:                                        |                  |         | 0: off                  |
| 0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 1: on                   |
| 1: on   pid_iq_target_ddt_limit   0: off   1: on   pid_iq_target_ddt_limit   0: off   1: on   pid_iq_errsum_limit   0: off   1: on   pid_iq_errsum_limit   0: off   1: on   pid_iq_output_limit   0: off   1: on   pid_iq_output_limit_u_d   0: off   1: o | STATUS_FLAGS[12] | bit(12) | pid_iq_target_limit     |
| STATUS_FLAGS[13]         bit(13)         pid_iq_target_ddt_limit           0: off         1: on           STATUS_FLAGS[14]         bit(14)         pid_iq_errsum_limit           0: off         1: on           STATUS_FLAGS[15]         bit(15)         pid_iq_output_limit           0: off         1: on           STATUS_FLAGS[16]         bit(16)         ipark_cirlim_limit_u_d           0: off         1: on           STATUS_FLAGS[17]         bit(17)         ipark_cirlim_limit_u_q           0: off         1: on           STATUS_FLAGS[18]         bit(18)         ipark_cirlim_limit_u_r           0: off         1: on           STATUS_FLAGS[19]         bit(19)         not_PLL_locked           0: off         1: on           STATUS_FLAGS[20]         bit(20)         ref_sw_r           0: off         1: on           STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off         0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                  |         | 0: off                  |
| D: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 1: on                   |
| 1: on   pid_iq_errsum_limit   0: off   1: on   pid_iq_errsum_limit   0: off   1: on   pid_iq_errsum_limit   0: off   1: on   pid_iq_output_limit   0: off   1: on   pid_iq_output_limit_u_d   0: off   1: on   pid_id_output_limit_u_d   0: off   0: | STATUS_FLAGS[13] | bit(13) | pid_iq_target_ddt_limit |
| STATUS_FLAGS[14]         bit(14)         pid_iq_errsum_limit           0: off         1: on           STATUS_FLAGS[15]         bit(15)         pid_iq_output_limit           0: off         1: on           STATUS_FLAGS[16]         bit(16)         ipark_cirlim_limit_u_d           0: off         1: on           STATUS_FLAGS[17]         bit(17)         ipark_cirlim_limit_u_q           0: off         1: on           STATUS_FLAGS[18]         bit(18)         ipark_cirlim_limit_u_r           0: off         1: on           STATUS_FLAGS[19]         bit(19)         not_PLL_locked           0: off         1: on           STATUS_FLAGS[20]         bit(20)         ref_sw_r           0: off         1: on           STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off         1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 0: off                  |
| 0: off   1: on   pid_iq_output_limit   0: off   1: on   pid_iq_output_limit_u_d   0: off   1: on   pid_id_id_id_id_id_id_id_id_id_id_id_id_i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |         | 1: on                   |
| 1: on   pid_iq_output_limit   0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | STATUS_FLAGS[14] | bit(14) | pid_iq_errsum_limit     |
| STATUS_FLAGS[15]         bit(15)         pid_iq_output_limit 0: off 1: on ipark_cirlim_limit_u_d 0: off 1: on ipark_cirlim_limit_u_d 0: off 1: on ipark_cirlim_limit_u_q 0: off 1: on ipark_cirlim_limit_u_q 0: off 1: on ipark_cirlim_limit_u_r                                         |                  |         | 0: off                  |
| 0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 1: on                   |
| STATUS_FLAGS[16]   bit(16)   ipark_cirlim_limit_u_d   0: off   1: on   ipark_cirlim_limit_u_d   0: off   1: on   ipark_cirlim_limit_u_q   0: off   1: on   ipark_cirlim_limit_u_q   0: off   1: on   ipark_cirlim_limit_u_r   0: off   1: on   ipark_cirlim_limit_u_q   0: off   1: on   | STATUS_FLAGS[15] | bit(15) | pid_iq_output_limit     |
| STATUS_FLAGS[16]         bit(16)         ipark_cirlim_limit_u_d           0: off         1: on           STATUS_FLAGS[17]         bit(17)         ipark_cirlim_limit_u_q           0: off         1: on           STATUS_FLAGS[18]         bit(18)         ipark_cirlim_limit_u_q           0: off         1: on           STATUS_FLAGS[19]         bit(19)         not_PLL_locked           0: off         1: on           STATUS_FLAGS[20]         bit(20)         ref_sw_r           0: off         1: on           STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off         0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |         | 0: off                  |
| D: off   1: on   ipark_cirlim_limit_u_q   O: off   1: on   ipark_cirlim_limit_u_q   O: off   1: on   ipark_cirlim_limit_u_r   O: off   ipark_cirlim_limi |                  |         | 1: on                   |
| STATUS_FLAGS[17]   bit(17)   ipark_cirlim_limit_u_q     0: off     1: on     1: on     0: off     1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | STATUS_FLAGS[16] | bit(16) | ipark_cirlim_limit_u_d  |
| STATUS_FLAGS[17]         bit(17)         ipark_cirlim_limit_u_q           0: off         1: on           STATUS_FLAGS[18]         bit(18)         ipark_cirlim_limit_u_r           0: off         1: on           STATUS_FLAGS[19]         bit(19)         not_PLL_locked           0: off         1: on           STATUS_FLAGS[20]         bit(20)         ref_sw_r           0: off         1: on           STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                  |         | 0: off                  |
| 0: off   1: on   ipark_cirlim_limit_u_r   0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |         | 1: on                   |
| 1: on   ipark_cirlim_limit_u_r   0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | STATUS_FLAGS[17] | bit(17) | ipark_cirlim_limit_u_q  |
| STATUS_FLAGS[18]         bit(18)         ipark_cirlim_limit_u_r           0: off         1: on           STATUS_FLAGS[19]         bit(19)         not_PLL_locked           0: off         1: on           STATUS_FLAGS[20]         bit(20)         ref_sw_r           0: off         1: on           STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off         1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |         | 0: off                  |
| 0: off   1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 1: on                   |
| 1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STATUS_FLAGS[18] | bit(18) | ipark_cirlim_limit_u_r  |
| STATUS_FLAGS[19]       bit(19)       not_PLL_locked         0: off       1: on         STATUS_FLAGS[20]       bit(20)       ref_sw_r         0: off       1: on         STATUS_FLAGS[21]       bit(21)       ref_sw_h         0: off       1: on         STATUS_FLAGS[22]       bit(22)       ref_sw_l         0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |         | 0: off                  |
| 0: off 1: on  STATUS_FLAGS[20]  bit(20)  ref_sw_r 0: off 1: on  STATUS_FLAGS[21]  bit(21)  ref_sw_h 0: off 1: on  STATUS_FLAGS[22]  bit(22)  ref_sw_l 0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  |         | 1: on                   |
| 1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STATUS_FLAGS[19] | bit(19) | not_PLL_locked          |
| STATUS_FLAGS[20]       bit(20)       ref_sw_r         0: off       1: on         STATUS_FLAGS[21]       bit(21)       ref_sw_h         0: off       1: on         STATUS_FLAGS[22]       bit(22)       ref_sw_l         0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |         | 0: off                  |
| 0: off 1: on  STATUS_FLAGS[21]  bit(21)  ref_sw_h 0: off 1: on  STATUS_FLAGS[22]  bit(22)  ref_sw_l 0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                  |         | 1: on                   |
| 1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STATUS_FLAGS[20] | bit(20) | ref_sw_r                |
| STATUS_FLAGS[21]         bit(21)         ref_sw_h           0: off         1: on           STATUS_FLAGS[22]         bit(22)         ref_sw_l           0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                  |         | 0: off                  |
| 0: off 1: on STATUS_FLAGS[22] bit(22) ref_sw_l 0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |         | 1: on                   |
| 1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STATUS_FLAGS[21] | bit(21) | ref_sw_h                |
| STATUS_FLAGS[22] bit(22) ref_sw_l 0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |         | 0: off                  |
| 0: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                  |         | 1: on                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | STATUS_FLAGS[22] | bit(22) | ref_sw_l                |
| 1: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |         | 0: off                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |         | 1: on                   |



|                   | STATUS_FLAGS[23] | bit(23)   | <u> </u>                                                                           |
|-------------------|------------------|-----------|------------------------------------------------------------------------------------|
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[24] | bit(24)   | pwm_min                                                                            |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[25] | bit(25)   | pwm_max                                                                            |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[26] | bit(26)   | adc_i_clipped                                                                      |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[27] | bit(27)   | aenc_clipped                                                                       |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[28] | bit(28)   | enc_n                                                                              |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[29] | bit(29)   | enc_2_n                                                                            |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[30] | bit(30)   | aenc_n                                                                             |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
|                   | STATUS_FLAGS[31] | bit(31)   | reserved                                                                           |
|                   |                  |           | 0: off                                                                             |
|                   |                  |           | 1: on                                                                              |
| 0x7D <sub>h</sub> | STATUS_MASK      |           | Register is used to set a mask for STATUS_FLAGS register to set STATUS output pin. |
|                   | STATUS_MASK      | u32(31:0) |                                                                                    |
|                   |                  |           |                                                                                    |



# 7.3 Register Map - Defaults, Data Fields (Bit Masks), min, max

| RD/WR | ADDR              | NAME                    | DEFAULT          | MIN              | MAX                    | COMMENT |
|-------|-------------------|-------------------------|------------------|------------------|------------------------|---------|
| R     | 0x00 <sub>h</sub> | CHIPINFO_DATA           |                  |                  |                        |         |
|       |                   | SI_TYPE                 | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFFF <sub>h</sub> |         |
|       |                   | SI_VERSION              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFFF <sub>h</sub> |         |
|       |                   | SI_DATE                 | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFFF <sub>h</sub> |         |
|       |                   | SI_TIME                 | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFF <sub>h</sub>  |         |
|       |                   | SI_VARIANT              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFFF <sub>h</sub> |         |
|       |                   | SI_BUILD                | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0xFFFFFFF <sub>h</sub> |         |
| RW    | 0x01 <sub>h</sub> | CHIPINFO_ADDR           |                  |                  |                        |         |
|       |                   | CHIP_INFO_ADDRESS       | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x5 <sub>h</sub>       |         |
| R     | 0x02 <sub>h</sub> | ADC_RAW_DATA            |                  |                  |                        |         |
|       |                   | ADC_I0_RAW              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_I1_RAW              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_VM_RAW              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_AGPI_A_RAW          | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_AGPI_B_RAW          | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_AENC_UX_RAW         | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_AENC_VN_RAW         | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFF <sub>h</sub>    |         |
|       |                   | ADC_AENC_WY_RAW         | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0xFFFF <sub>h</sub>    |         |
| RW    | 0x03 <sub>h</sub> | ADC_RAW_ADDR            |                  |                  |                        |         |
|       |                   | ADC_RAW_ADDR            | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x3 <sub>h</sub>       |         |
| RW    | 0x04 <sub>h</sub> | dsADC_MCFG_B_<br>MCFG_A |                  |                  |                        |         |
|       |                   | cfg_dsmodulator_a       | 0x0 <sub>h</sub> | $0x0_h$          | 0x3 <sub>h</sub>       |         |
|       |                   | mclk_polarity_a         | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | mdat_polarity_a         | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | sel_nclk_mclk_i_a       | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | blanking_a              | 0x0 <sub>h</sub> | $0x0_h$          | 0xFF <sub>h</sub>      |         |
|       |                   | cfg_dsmodulator_b       | 0x0 <sub>h</sub> | $0x0_h$          | 0x3 <sub>h</sub>       |         |
|       |                   | mclk_polarity_b         | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | mdat_polarity_b         | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | sel_nclk_mclk_i_b       | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |         |
|       |                   | blanking_b              | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0xFF <sub>h</sub>      |         |
| RW    | 0x05 <sub>h</sub> | dsADC_MCLK_A            |                  |                  |                        |         |



|         |                | dsADC_MCLK_A                  | 0xCCCCCD <sub>h</sub> | 0x0 <sub>h</sub>     | 0xFFFFFFF <sub>h</sub> |
|---------|----------------|-------------------------------|-----------------------|----------------------|------------------------|
| RW 0x06 | 6 <sub>h</sub> | dsADC_MCLK_B                  |                       |                      |                        |
|         |                | dsADC_MCLK_B                  | 0xCCCCCD <sub>h</sub> | $0x0_h$              | 0xFFFFFFF <sub>h</sub> |
| RW 0x07 | 7 <sub>h</sub> | dsADC_MDEC_B_<br>MDEC_A       |                       |                      |                        |
|         |                | dsADC_MDEC_A                  | 0x100 <sub>h</sub>    | $0x0_h$              | 0xFFFF <sub>h</sub>    |
|         |                | dsADC_MDEC_B                  | 0x100 <sub>h</sub>    | $0x0_h$              | 0xFFFF <sub>h</sub>    |
| RW 0x08 | 8 <sub>h</sub> | ADC_I1_SCALE_<br>OFFSET       |                       |                      |                        |
|         |                | ADC_I1_OFFSET                 | 0x0 <sub>h</sub>      | $0x0_h$              | 0xFFFF <sub>h</sub>    |
|         |                | ADC_I1_SCALE                  | 0x100 <sub>h</sub>    | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>    |
| RW 0x09 | 9 <sub>h</sub> | ADC_I0_SCALE_<br>OFFSET       |                       |                      |                        |
|         |                | ADC_I0_OFFSET                 | 0x0 <sub>h</sub>      | $0x0_h$              | 0xFFFF <sub>h</sub>    |
|         |                | ADC_I0_SCALE                  | 0x100 <sub>h</sub>    | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>    |
| RW 0x0A | A <sub>h</sub> | ADC_I_SELECT                  |                       |                      |                        |
|         |                | ADC_I0_SELECT                 | 0x0 <sub>h</sub>      | $0x0_h$              | 0x3 <sub>h</sub>       |
|         |                | ADC_I1_SELECT                 | 0x1 <sub>h</sub>      | $0x0_h$              | 0x3 <sub>h</sub>       |
|         |                | ADC_I_UX_SELECT               | 0x0 <sub>h</sub>      | $0x0_h$              | 0x2 <sub>h</sub>       |
|         |                | ADC_I_V_SELECT                | 0x1 <sub>h</sub>      | $0x0_h$              | 0x2 <sub>h</sub>       |
|         |                | ADC_I_WY_SELECT               | 0x2 <sub>h</sub>      | $0x0_h$              | 0x2 <sub>h</sub>       |
| RW 0x0E | B <sub>h</sub> | ADC_I1_I0_EXT                 |                       |                      |                        |
|         |                | ADC_I0_EXT                    | 0x0 <sub>h</sub>      | $0x0_h$              | 0xFFFF <sub>h</sub>    |
|         |                | ADC_I1_EXT                    | 0x0 <sub>h</sub>      | $0x0_h$              | 0xFFFF <sub>h</sub>    |
| RW 0x00 | C <sub>h</sub> | DS_ANALOG_INPUT_<br>STAGE_CFG |                       |                      |                        |
|         |                | ADC_I0                        | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_I1                        | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_VM                        | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_AGPI_A                    | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_AGPI_B                    | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_AENC_UX                   | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_AENC_VN                   | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
|         |                | ADC_AENC_WY                   | 0x0 <sub>h</sub>      | $0x0_h$              | 0x7 <sub>h</sub>       |
| RW 0x0E | D <sub>h</sub> | AENC_0_SCALE_<br>OFFSET       |                       |                      |                        |
|         |                | AENC_0_OFFSET                 | 0x0 <sub>h</sub>      | $0x0_h$              | 0xFFFF <sub>h</sub>    |



|    |                   | AENC_0_SCALE                | 0x100 <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|----|-------------------|-----------------------------|--------------------|----------------------|---------------------|--|
| RW | 0x0E <sub>h</sub> | AENC_1_SCALE_<br>OFFSET     |                    |                      |                     |  |
|    |                   | AENC_1_OFFSET               | 0x0 <sub>h</sub>   | 0x0 <sub>h</sub>     | 0xFFFF <sub>h</sub> |  |
|    |                   | AENC_1_SCALE                | 0x100 <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x0F <sub>h</sub> | AENC_2_SCALE_<br>OFFSET     |                    |                      |                     |  |
|    |                   | AENC_2_OFFSET               | 0x0 <sub>h</sub>   | $0x0_h$              | 0xFFFF <sub>h</sub> |  |
|    |                   | AENC_2_SCALE                | 0x100 <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x11 <sub>h</sub> | AENC_SELECT                 |                    |                      |                     |  |
|    |                   | AENC_0_SELECT               | 0x0 <sub>h</sub>   | $0x0_h$              | 0x2 <sub>h</sub>    |  |
|    |                   | AENC_1_SELECT               | 0x1 <sub>h</sub>   | $0x0_h$              | 0x2 <sub>h</sub>    |  |
|    |                   | AENC_2_SELECT               | 0x2 <sub>h</sub>   | $0x0_h$              | $0x2_h$             |  |
| R  | 0x12 <sub>h</sub> | ADC_IWY_IUX                 |                    |                      |                     |  |
|    |                   | ADC_IUX                     | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|    |                   | ADC_IWY                     | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| R  | 0x13 <sub>h</sub> | ADC_IV                      |                    |                      |                     |  |
|    |                   | ADC_IV                      | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| R  | 0x15 <sub>h</sub> | AENC_WY_UX                  |                    |                      |                     |  |
|    |                   | AENC_UX                     | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | $0x7FFF_h$          |  |
|    |                   | AENC_WY                     | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| R  | 0x16 <sub>h</sub> | AENC_VN                     |                    |                      |                     |  |
|    |                   | AENC_VN                     | 0x0 <sub>h</sub>   | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x17 <sub>h</sub> | PWM_POLARITIES              |                    |                      |                     |  |
|    |                   | PWM_POLARITIES[0]           | 0x0 <sub>h</sub>   | $0x0_h$              | 0x1 <sub>h</sub>    |  |
|    |                   | PWM_POLARITIES[1]           | 0x0 <sub>h</sub>   | $0x0_h$              | 0x1 <sub>h</sub>    |  |
| RW | 0x18 <sub>h</sub> | PWM_MAXCNT                  |                    |                      |                     |  |
|    |                   | PWM_MAXCNT                  | 0xF9F <sub>h</sub> | $0x0_h$              | 0xFFFF <sub>h</sub> |  |
| RW | 0x19 <sub>h</sub> | PWM_BBM_H_BBM_L             |                    |                      |                     |  |
|    |                   | PWM_BBM_L                   | 0x14 <sub>h</sub>  | $0x0_h$              | 0xFF <sub>h</sub>   |  |
|    |                   | PWM_BBM_H                   | 0x14 <sub>h</sub>  | $0x0_h$              | 0xFF <sub>h</sub>   |  |
| RW | 0x1A <sub>h</sub> | PWM_SV_CHOP                 |                    |                      |                     |  |
|    |                   | PWM_CHOP                    | 0x0 <sub>h</sub>   | $0x0_h$              | 0x7 <sub>h</sub>    |  |
|    |                   | PWM_SV                      | 0x0 <sub>h</sub>   | $0x0_h$              | 0x1 <sub>h</sub>    |  |
| RW | 0x1B <sub>h</sub> | MOTOR_TYPE_N_<br>POLE_PAIRS |                    |                      |                     |  |



|     |                   | N BOLE BY:55                 |                      | ٠                        |                        |
|-----|-------------------|------------------------------|----------------------|--------------------------|------------------------|
|     |                   | N_POLE_PAIRS                 | 0x1 <sub>h</sub>     | 0x1 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|     |                   | MOTOR_TYPE                   | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x3 <sub>h</sub>       |
| RW  | 0x1C <sub>h</sub> | PHI_E_EXT                    |                      |                          |                        |
|     |                   | PHI_E_EXT                    | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| RW  | 0x1F <sub>h</sub> | OPENLOOP_MODE                |                      |                          |                        |
|     |                   | OPENLOOP_PHI_<br>DIRECTION   | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
| RW  | 0x20 <sub>h</sub> | OPENLOOP_<br>ACCELERATION    |                      |                          |                        |
|     |                   | OPENLOOP_<br>ACCELERATION    | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0xFFFFF <sub>h</sub>   |
| RW  | 0x21 <sub>h</sub> | OPENLOOP_<br>VELOCITY_TARGET |                      |                          |                        |
|     |                   | OPENLOOP_<br>VELOCITY_TARGET | 0x0 <sub>h</sub>     | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RW  | 0x22 <sub>h</sub> | OPENLOOP_<br>VELOCITY_ACTUAL |                      |                          |                        |
|     |                   | OPENLOOP_<br>VELOCITY_ACTUAL | 0x0 <sub>h</sub>     | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RWI | 0x23 <sub>h</sub> | OPENLOOP_PHI                 |                      |                          |                        |
|     |                   | OPENLOOP_PHI                 | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| RW  | 0x24 <sub>h</sub> | UQ_UD_EXT                    |                      |                          |                        |
|     |                   | UD_EXT                       | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
|     |                   | UQ_EXT                       | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| RW  | 0x25 <sub>h</sub> | ABN_DECODER_<br>MODE         |                      |                          |                        |
|     |                   | apol                         | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|     |                   | bpol                         | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|     |                   | npol                         | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|     |                   | use_abn_as_n                 | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|     |                   | cln                          | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|     |                   | direction                    | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
| RW  | 0x26 <sub>h</sub> | ABN_DECODER_PPR              |                      |                          |                        |
|     |                   | ABN_DECODER_PPR              | 0x10000 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFFFF <sub>h</sub>  |
| RW  | 0x27 <sub>h</sub> | ABN_DECODER_<br>COUNT        |                      |                          |                        |



|    |                   | ABN_DECODER_<br>COUNT              | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>     | 0xFFFFFF <sub>h</sub> |  |
|----|-------------------|------------------------------------|----------------------|----------------------|-----------------------|--|
| RW | 0x28 <sub>h</sub> | ABN_DECODER_<br>COUNT_N            |                      |                      |                       |  |
|    |                   | ABN_DECODER_<br>COUNT_N            | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>     | 0xFFFFFF <sub>h</sub> |  |
| RW | 0x29 <sub>h</sub> | ABN_DECODER_PHI_<br>E_PHI_M_OFFSET |                      |                      |                       |  |
|    |                   | ABN_DECODER_PHI_<br>M_OFFSET       | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>   |  |
|    |                   | ABN_DECODER_PHI_<br>E_OFFSET       | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>   |  |
| R  | 0x2A <sub>h</sub> | ABN_DECODER_PHI_<br>E_PHI_M        |                      |                      |                       |  |
|    |                   | ABN_DECODER_PHI_<br>M              | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>   |  |
|    |                   | ABN_DECODER_PHI_<br>E              | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>   |  |
| RW | 0x2C <sub>h</sub> | ABN_2_DECODER_<br>MODE             |                      |                      |                       |  |
|    |                   | apol                               | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
|    |                   | bpol                               | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
|    |                   | npol                               | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
|    |                   | use_abn_as_n                       | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
|    |                   | cln                                | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
|    |                   | direction                          | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>      |  |
| RW | 0x2D <sub>h</sub> | ABN_2_DECODER_<br>PPR              |                      |                      |                       |  |
|    |                   | ABN_2_DECODER_<br>PPR              | 0x10000 <sub>h</sub> | 0x1 <sub>h</sub>     | 0xFFFFFF <sub>h</sub> |  |
| RW | 0x2E <sub>h</sub> | ABN_2_DECODER_<br>COUNT            |                      |                      |                       |  |
|    |                   | ABN_2_DECODER_<br>COUNT            | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>     | 0xFFFFFF <sub>h</sub> |  |
| RW | 0x2F <sub>h</sub> | ABN_2_DECODER_<br>COUNT_N          |                      |                      |                       |  |
|    |                   | ABN_2_DECODER_<br>COUNT_N          | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>     | 0xFFFFFF <sub>h</sub> |  |
| RW | 0x30 <sub>h</sub> | ABN_2_DECODER_<br>PHI_M_OFFSET     |                      |                      |                       |  |



|    |                   | ABN_2_DECODER_<br>PHI_M_OFFSET        | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|----|-------------------|---------------------------------------|----------------------|----------------------|---------------------|--|
| R  | 0x31 <sub>h</sub> | ABN_2_DECODER_<br>PHI_M               |                      |                      |                     |  |
|    |                   | ABN_2_DECODER_<br>PHI_M               | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x33 <sub>h</sub> | HALL_MODE                             |                      |                      |                     |  |
|    |                   | polarity                              | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>    |  |
|    |                   | synchronous PWM sampling              | 0x0 <sub>h</sub>     | 0x0 <sub>h</sub>     | 0x1 <sub>h</sub>    |  |
|    |                   | interpolation                         | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>    |  |
|    |                   | direction                             | 0x0 <sub>h</sub>     | $0x0_h$              | 0x1 <sub>h</sub>    |  |
|    |                   | HALL_BLANK                            | 0x0 <sub>h</sub>     | $0x0_h$              | 0xFFF <sub>h</sub>  |  |
| RW | 0x34 <sub>h</sub> | HALL_POSITION_<br>060_000             |                      |                      |                     |  |
|    |                   | HALL_POSITION_000                     | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|    |                   | HALL_POSITION_060                     | 0x2AAA <sub>h</sub>  | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x35 <sub>h</sub> | HALL_POSITION_<br>180_120             |                      |                      |                     |  |
|    |                   | HALL_POSITION_120                     | 0x5555 <sub>h</sub>  | -0x8000 <sub>h</sub> | $0x7FFF_h$          |  |
|    |                   | HALL_POSITION_180                     | -0x8000 <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x36 <sub>h</sub> | HALL_POSITION_<br>300_240             |                      |                      |                     |  |
|    |                   | HALL_POSITION_240                     | -0x5556 <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|    |                   | HALL_POSITION_300                     | -0x2AAB <sub>h</sub> | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x37 <sub>h</sub> | HALL_PHI_E_PHI_M_<br>OFFSET           |                      |                      |                     |  |
|    |                   | HALL_PHI_M_OFFSET                     | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|    |                   | HALL_PHI_E_OFFSET                     | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| RW | 0x38 <sub>h</sub> | HALL_DPHI_MAX                         |                      |                      |                     |  |
|    |                   | HALL_DPHI_MAX                         | 0x2AAA <sub>h</sub>  | $0x0_h$              | 0xFFFF <sub>h</sub> |  |
| R  | 0x39 <sub>h</sub> | HALL_PHI_E_<br>INTERPOLATED_<br>PHI_E |                      |                      |                     |  |
|    |                   | HALL_PHI_E                            | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
|    |                   | HALL_PHI_E_<br>INTERPOLATED           | 0x0 <sub>h</sub>     | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub> |  |
| R  | 0x3A <sub>h</sub> | HALL_PHI_M                            |                      |                      |                     |  |



|    |                   | HALL_PHI_M                          | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
|----|-------------------|-------------------------------------|------------------|--------------------------|------------------------|--|
| RW | 0x3B <sub>h</sub> | AENC_DECODER_<br>MODE               |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>MODE[0]            | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
|    |                   | AENC_DECODER_<br>MODE[12]           | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
| RW | 0x3C <sub>h</sub> | AENC_DECODER_N_<br>THRESHOLD        |                  |                          |                        |  |
|    |                   | AENC_DECODER_N_<br>THRESHOLD        | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |  |
| R  | 0x3D <sub>h</sub> | AENC_DECODER_<br>PHI_A_RAW          |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>PHI_A_RAW          | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
| RW | 0x3E <sub>h</sub> | AENC_DECODER_<br>PHI_A_OFFSET       |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>PHI_A_OFFSET       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
| R  | 0x3F <sub>h</sub> | AENC_DECODER_<br>PHI_A              |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>PHI_A              | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x40 <sub>h</sub> | AENC_DECODER_PPR                    |                  |                          |                        |  |
|    |                   | AENC_DECODER_PPR                    | 0x1 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
| R  | 0x41 <sub>h</sub> | AENC_DECODER_<br>COUNT              |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>COUNT              | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x42 <sub>h</sub> | AENC_DECODER_<br>COUNT_N            |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>COUNT_N            | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x45 <sub>h</sub> | AENC_DECODER_<br>PHI_E_PHI_M_OFFSET |                  |                          |                        |  |
|    |                   | AENC_DECODER_<br>PHI_M_OFFSET       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
|    |                   | AENC_DECODER_<br>PHI_E_OFFSET       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |



|   | R 02  | x46 <sub>h</sub> | AENC_DECODER_<br>PHI_E_PHI_M |                  |                          |                        |  |
|---|-------|------------------|------------------------------|------------------|--------------------------|------------------------|--|
|   |       |                  | AENC_DECODER_<br>PHI_M       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
|   |       |                  | AENC_DECODER_<br>PHI_E       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
|   | R 0>  | k4B <sub>h</sub> | PIDIN_VELOCITY_<br>TARGET    |                  |                          |                        |  |
|   |       |                  | PIDIN_VELOCITY_<br>TARGET    | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   | R 0   | x4C <sub>h</sub> | PIDIN_POSITION_<br>TARGET    |                  |                          |                        |  |
|   |       |                  | PIDIN_POSITION_<br>TARGET    | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| F | KO WS | (4D <sub>h</sub> | CONFIG_DATA                  |                  |                          |                        |  |
|   |       |                  | biquad_x_a_1                 | $0x0_h$          | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_x_a_2                 | $0x0_h$          | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_x_b_0                 | $0x0_h$          | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_x_b_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_x_b_2                 | $0x0_h$          | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_x_enable              | $0x0_h$          | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
|   |       |                  | biquad_v_a_1                 | $0x0_h$          | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_v_a_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_v_b_0                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_v_b_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_v_b_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_v_enable              | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
|   |       |                  | biquad_t_a_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_t_a_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_t_b_0                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_t_b_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_t_b_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_t_enable              | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
|   |       |                  | biquad_f_a_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_f_a_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_f_b_0                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_f_b_1                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
|   |       |                  | biquad_f_b_2                 | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |



|    |                   | biquad_f_enable                               | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|----|-------------------|-----------------------------------------------|------------------|--------------------------|------------------------|
|    |                   | prbs_amplitude                                | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | prbs_down_<br>sampling_ratio                  | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | feed_forward_<br>velocity_gain                | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | feed_forward_<br>velocity_filter_<br>constant | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | feed_forward_<br>torque_gain                  | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | feed_forward_<br>torgue_filter_<br>constant   | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|    |                   | VELOCITY_METER_<br>PPTM_MIN_POS_DEV           | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|    |                   | ref_switch_config                             | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|    |                   | Encoder_Init_hall_<br>Enable                  | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | SINGLE_PIN_IF_CFG                             | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | $0xFF_h$               |
|    |                   | SINGLE_PIN_IF_<br>STATUS                      | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|    |                   | SINGLE_PIN_IF_<br>OFFSET                      | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|    |                   | SINGLE_PIN_IF_<br>SCALE                       | 0x0 <sub>h</sub> | -0x7FFF <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
|    |                   | CURRENT_P_nQ8.8_<br>Q4.12                     | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | CURRENT_I_nQ8.8_<br>Q4.12                     | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | VELOCITY_P_nQ8.8_<br>Q4.12                    | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | VELOCITY_I_nQ8.8_<br>Q4.12                    | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | POSITION_P_nQ8.8_<br>Q4.12                    | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | POSITION_I_nQ8.8_<br>Q4.12                    | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
| RW | 0x4E <sub>h</sub> | CONFIG_ADDR                                   |                  |                          |                        |
|    |                   | CONFIG_ADDR                                   | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>         | 0x3E <sub>h</sub>      |
| RW | 0x50 <sub>h</sub> | VELOCITY_<br>SELECTION                        |                  |                          |                        |



|    |                   | VELOCITY_<br>SELECTION        | 0x0 <sub>h</sub>       | 0x0 <sub>h</sub>     | 0xC <sub>h</sub>       |  |
|----|-------------------|-------------------------------|------------------------|----------------------|------------------------|--|
|    |                   | VELOCITY_METER_<br>SELECTION  | 0x0 <sub>h</sub>       | $0 \times 0_h$       | 0x1 <sub>h</sub>       |  |
| RW | 0x51 <sub>h</sub> | POSITION_<br>SELECTION        |                        |                      |                        |  |
|    |                   | POSITION_<br>SELECTION        | 0x0 <sub>h</sub>       | $0 \times 0_h$       | 0xC <sub>h</sub>       |  |
| RW | 0x52 <sub>h</sub> | PHI_E_SELECTION               |                        |                      |                        |  |
|    |                   | PHI_E_SELECTION               | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7 <sub>h</sub>       |  |
| R  | 0x53 <sub>h</sub> | PHI_E                         |                        |                      |                        |  |
|    |                   | PHI_E                         | 0x0 <sub>h</sub>       | -0x8000 <sub>h</sub> | 0x7FFF <sub>h</sub>    |  |
| RW | 0x54 <sub>h</sub> | PID_FLUX_P_FLUX_I             |                        |                      |                        |  |
|    |                   | PID_FLUX_I                    | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
|    |                   | PID_FLUX_P                    | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x56 <sub>h</sub> | PID_TORQUE_P_<br>TORQUE_I     |                        |                      |                        |  |
|    |                   | PID_TORQUE_I                  | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
|    |                   | PID_TORQUE_P                  | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x58 <sub>h</sub> | PID_VELOCITY_P_<br>VELOCITY_I |                        |                      |                        |  |
|    |                   | PID_VELOCITY_I                | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
|    |                   | PID_VELOCITY_P                | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x5A <sub>h</sub> | PID_POSITION_P_<br>POSITION_I |                        |                      |                        |  |
|    |                   | PID_POSITION_I                | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
|    |                   | PID_POSITION_P                | 0x0 <sub>h</sub>       | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x5D <sub>h</sub> | PIDOUT_UQ_UD_<br>LIMITS       |                        |                      |                        |  |
|    |                   | PIDOUT_UQ_UD_<br>LIMITS       | 0x5A81 <sub>h</sub>    | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x5E <sub>h</sub> | PID_TORQUE_FLUX_<br>LIMITS    |                        |                      |                        |  |
|    |                   | PID_TORQUE_FLUX_<br>LIMITS    | 0x7FFF <sub>h</sub>    | $0x0_h$              | 0x7FFF <sub>h</sub>    |  |
| RW | 0x5F <sub>h</sub> | PID_ACCELERATION_<br>LIMIT    |                        |                      |                        |  |
|    |                   | PID_ACCELERATION_<br>LIMIT    | 0x7FFFFFF <sub>h</sub> | 0x0 <sub>h</sub>     | 0xFFFFFFF <sub>h</sub> |  |
| RW | 0x60 <sub>h</sub> | PID_VELOCITY_LIMIT            |                        |                      |                        |  |



|    |                   | PID_VELOCITY_LIMIT          | 0x7FFFFFF <sub>h</sub>   | 0x0 <sub>h</sub>         | 0xFFFFFFF <sub>h</sub> |  |
|----|-------------------|-----------------------------|--------------------------|--------------------------|------------------------|--|
| RW | 0x61 <sub>h</sub> | PID_POSITION_<br>LIMIT_LOW  |                          |                          |                        |  |
|    |                   | PID_POSITION_<br>LIMIT_LOW  | -0x7FFFFFFF <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x62 <sub>h</sub> | PID_POSITION_<br>LIMIT_HIGH |                          |                          |                        |  |
|    |                   | PID_POSITION_<br>LIMIT_HIGH | 0x7FFFFFFF <sub>h</sub>  | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x63 <sub>h</sub> | MODE_RAMP_<br>MODE_MOTION   |                          |                          |                        |  |
|    |                   | MODE_MOTION                 | 0x0 <sub>h</sub>         | 0x0 <sub>h</sub>         | $0xF_h$                |  |
|    |                   | MODE_RAMP                   | 0x0 <sub>h</sub>         | 0x0 <sub>h</sub>         | $0x7_h$                |  |
|    |                   | MODE_FF                     | 0x0 <sub>h</sub>         | 0x0 <sub>h</sub>         | $0x2_h$                |  |
|    |                   | MODE_PID_SMPL               | 0x0 <sub>h</sub>         | 0x0 <sub>h</sub>         | $0x7F_h$               |  |
|    |                   | MODE_PID_TYPE               | 0x0 <sub>h</sub>         | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |  |
| RW | 0x64 <sub>h</sub> | PID_TORQUE_FLUX_<br>TARGET  |                          |                          |                        |  |
|    |                   | PID_FLUX_TARGET             | 0x0 <sub>h</sub>         | -0x8000 <sub>h</sub>     | $0x7FFF_h$             |  |
|    |                   | PID_TORQUE_<br>TARGET       | 0x0 <sub>h</sub>         | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
| RW | 0x65 <sub>h</sub> | PID_TORQUE_FLUX_<br>OFFSET  |                          |                          |                        |  |
|    |                   | PID_FLUX_OFFSET             | 0x0 <sub>h</sub>         | -0x8000 <sub>h</sub>     | $0x7FFF_h$             |  |
|    |                   | PID_TORQUE_<br>OFFSET       | 0x0 <sub>h</sub>         | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |  |
| RW | 0x66 <sub>h</sub> | PID_VELOCITY_<br>TARGET     |                          |                          |                        |  |
|    |                   | PID_VELOCITY_<br>TARGET     | 0x0 <sub>h</sub>         | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x67 <sub>h</sub> | PID_VELOCITY_<br>OFFSET     |                          |                          |                        |  |
|    |                   | PID_VELOCITY_<br>OFFSET     | 0x0 <sub>h</sub>         | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| RW | 0x68 <sub>h</sub> | PID_POSITION_<br>TARGET     |                          |                          |                        |  |
|    |                   | PID_POSITION_<br>TARGET     | 0x0 <sub>h</sub>         | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |  |
| R  | 0x69 <sub>h</sub> | PID_TORQUE_FLUX_<br>ACTUAL  |                          |                          |                        |  |



| 1                                            | ı                |                          |                        |
|----------------------------------------------|------------------|--------------------------|------------------------|
| PID_FLUX_ACTUAL                              | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_TORQUE_<br>ACTUAL                        | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| R 0x6A <sub>h</sub> PID_VELOCITY_<br>ACTUAL  |                  |                          |                        |
| PID_VELOCITY_<br>ACTUAL                      | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RW 0x6B <sub>h</sub> PID_POSITION_<br>ACTUAL |                  |                          |                        |
| PID_POSITION_<br>ACTUAL                      | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| R 0x6C <sub>h</sub> PID_ERROR_DATA           |                  |                          |                        |
| PID_TORQUE_ERROR                             | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_FLUX_ERROR                               | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_VELOCITY_<br>ERROR                       | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_POSITION_<br>ERROR                       | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_TORQUE_<br>ERROR_SUM                     | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_FLUX_ERROR_<br>SUM                       | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_VELOCITY_<br>ERROR_SUM                   | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PID_POSITION_<br>ERROR_SUM                   | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RW 0x6D <sub>h</sub> PID_ERROR_ADDR          |                  |                          |                        |
| PID_ERROR_ADDR                               | 0x0 <sub>h</sub> | $0x0_h$                  | 0x7 <sub>h</sub>       |
| RW 0x6E <sub>h</sub> INTERIM_DATA            |                  |                          |                        |
| PIDIN_TARGET_<br>TORQUE                      | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PIDIN_TARGET_FLUX                            | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PIDIN_TARGET_<br>VELOCITY                    | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PIDIN_TARGET_<br>POSITION                    | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| PIDOUT_TARGET_<br>TORQUE                     | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|                                              |                  |                          |                        |



| PIDOUT_TARGET_<br>VELOCITY   | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFFF <sub>h</sub> |
|------------------------------|------------------|--------------------------|-------------------------|
| PIDOUT_TARGET_<br>POSITION   | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub>  |
| FOC_IUX                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_IWY                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_IV                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_IA                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_IB                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_ID                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_IQ                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UD                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UQ                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UD_LIMITED               | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UQ_LIMITED               | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UA                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UB                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UUX                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UWY                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| FOC_UV                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| PWM_UX                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| PWM_WY                       | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| PWM_V                        | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| ADC_I_0                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| ADC_I_1                      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| PID_FLUX_ACTUAL_<br>DIV256   | 0x0 <sub>h</sub> | -0x80 <sub>h</sub>       | 0x7F <sub>h</sub>       |
| PID_TORQUE_<br>ACTUAL_DIV256 | 0x0 <sub>h</sub> | -0x80 <sub>h</sub>       | 0x7F <sub>h</sub>       |
| PID_FLUX_TARGET_<br>DIV256   | 0x0 <sub>h</sub> | -0x80 <sub>h</sub>       | 0x7F <sub>h</sub>       |
| PID_TORQUE_<br>TARGET_DIV256 | 0x0 <sub>h</sub> | -0x80 <sub>h</sub>       | 0x7F <sub>h</sub>       |
| PID_TORQUE_<br>ACTUAL        | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |
| PID_TORQUE_<br>TARGET        | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>     |



| PID_FLUX_ACTUAL                     | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
|-------------------------------------|------------------|--------------------------|------------------------|
| PID_FLUX_TARGET                     | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_VELOCITY_<br>ACTUAL_DIV256      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_VELOCITY_<br>TARGET_DIV256      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_VELOCITY_<br>ACTUAL_LSB         | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_VELOCITY_<br>TARGET_LSB         | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_POSITION_<br>ACTUAL_DIV256      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_POSITION_<br>TARGET_DIV256      | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_POSITION_<br>ACTUAL_LSB         | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| PID_POSITION_<br>TARGET_LSB         | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| FF_VELOCITY                         | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| FF_TORQUE                           | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x7FFF <sub>h</sub>    |
| ACTUAL_VELOCITY_<br>PPTM            | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| REF_SWITCH_STATUS                   | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
| HOME_POSITION                       | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| LEFT_POSITION                       | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RIGHT_POSITION                      | 0x0 <sub>h</sub> | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| ENC_INIT_HALL_<br>STATUS            | 0x0 <sub>h</sub> | 0×0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
| ENC_INIT_HALL_PHI_<br>E_ABN_OFFSET  | 0x0 <sub>h</sub> | 0×0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
| ENC_INIT_HALL_PHI_<br>E_AENC_OFFSET | 0x0 <sub>h</sub> | $0x0_h$                  | 0xFFFF <sub>h</sub>    |
| ENC_INIT_HALL_PHI_<br>A_AENC_OFFSET | 0x0 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
| SINGLE_PIN_IF_<br>TARGET_TORQUE     | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x8000 <sub>h</sub>    |
| SINGLE_PIN_IF_<br>PWM_DUTY_CYCLE    | 0x0 <sub>h</sub> | -0x8000 <sub>h</sub>     | 0x8000 <sub>h</sub>    |



|       |                  | SINGLE_PIN_IF_<br>TARGET_VELOCITY | 0x0 <sub>h</sub>    | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
|-------|------------------|-----------------------------------|---------------------|--------------------------|------------------------|
|       |                  | SINGLE_PIN_IF_<br>TARGET_POSITION | 0x0 <sub>h</sub>    | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RW 0x | κ6F <sub>h</sub> | INTERIM_ADDR                      |                     |                          |                        |
|       |                  | INTERIM_ADDR                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0xD7 <sub>h</sub>      |
| RW 0x | (75 <sub>h</sub> | ADC_VM_LIMITS                     |                     |                          |                        |
|       |                  | ADC_VM_LIMIT_LOW                  | 0xFFFF <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
|       |                  | ADC_VM_LIMIT_HIGH                 | 0xFFFF <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFF <sub>h</sub>    |
| R 0x  | (76 <sub>h</sub> | TMC4671_INPUTS_<br>RAW            |                     |                          |                        |
|       |                  | A of ABN_RAW                      | 0x0 <sub>h</sub>    | $0x0_h$                  | 0x1 <sub>h</sub>       |
|       |                  | B of ABN_RAW                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | N of ABN_RAW                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | -                                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | A of ABN_2_RAW                    | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | B of ABN_2_RAW                    | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | N of ABN_2_RAW                    | $0x0_h$             | $0x0_h$                  | 0x1 <sub>h</sub>       |
|       |                  | -                                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_UX of HALL_<br>RAW           | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_V of HALL_RAW                | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_WY of HALL_<br>RAW           | 0x0 <sub>h</sub>    | 0×0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | -                                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | REF_SW_R_RAW                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | REF_SW_H_RAW                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | REF_SW_L_RAW                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | ENABLE_IN_RAW                     | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | STP of DIRSTP_RAW                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | DIR of DIRSTP_RAW                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | PWM_IN_RAW                        | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | -                                 | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_UX_FILT                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_V_FILT                       | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|       |                  | HALL_WY_FILT                      | 0x0 <sub>h</sub>    | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |



|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|----|-------------------|----------------------------|-------------------------|--------------------------|------------------------|
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | PWM_IDLE_L_RAW             | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | PWM_IDLE_H_RAW             | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | -                          | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
| R  | 0x77 <sub>h</sub> | TMC4671_OUTPUTS_<br>RAW    |                         |                          |                        |
|    |                   | TMC4671_OUTPUTS_<br>RAW[0] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[1] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[2] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[3] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[4] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[5] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[6] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | TMC4671_OUTPUTS_<br>RAW[7] | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
| RW | 0x78 <sub>h</sub> | STEP_WIDTH                 |                         |                          |                        |
|    |                   | STEP_WIDTH                 | 0x0 <sub>h</sub>        | -0x80000000 <sub>h</sub> | 0x7FFFFFF <sub>h</sub> |
| RW | 0x79 <sub>h</sub> | UART_BPS                   |                         |                          |                        |
|    |                   | UART_BPS                   | 0x00009600 <sub>h</sub> | 0x0 <sub>h</sub>         | 0xFFFFFF <sub>h</sub>  |
| RW | 0x7B <sub>h</sub> | GPIO_dsADCI_<br>CONFIG     |                         |                          |                        |
|    |                   | GPIO_dsADCI_<br>CONFIG[0]  | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | GPIO_dsADCI_<br>CONFIG[1]  | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |
|    |                   | GPIO_dsADCI_<br>CONFIG[2]  | 0x0 <sub>h</sub>        | 0x0 <sub>h</sub>         | 0x1 <sub>h</sub>       |



|      |                  | GPIO_dsADCI_<br>CONFIG[3] | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>  |  |
|------|------------------|---------------------------|------------------|------------------|-------------------|--|
|      |                  | GPIO_dsADCI_<br>CONFIG[4] | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>  |  |
|      |                  | GPIO_dsADCI_<br>CONFIG[5] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | GPIO_dsADCI_<br>CONFIG[6] | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>  |  |
|      |                  | GPO                       | 0x0 <sub>h</sub> | $0x0_h$          | 0xFF <sub>h</sub> |  |
|      |                  | GPI                       | 0x0 <sub>h</sub> | $0x0_h$          | 0xFF <sub>h</sub> |  |
| RW 0 | x7C <sub>h</sub> | STATUS_FLAGS              |                  |                  |                   |  |
|      |                  | STATUS_FLAGS[0]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[1]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[2]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[3]           | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[4]           | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[5]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[6]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[7]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[8]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[9]           | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[10]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[11]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[12]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[13]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[14]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[15]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[16]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[17]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[18]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[19]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[20]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[21]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[22]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[23]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[24]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |
|      |                  | STATUS_FLAGS[25]          | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>  |  |



|    |                   | STATUS_FLAGS[26] | 0x0 <sub>h</sub> | 0x0 <sub>h</sub> | 0x1 <sub>h</sub>       |
|----|-------------------|------------------|------------------|------------------|------------------------|
|    |                   | STATUS_FLAGS[27] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |
|    |                   | STATUS_FLAGS[28] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |
|    |                   | STATUS_FLAGS[29] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |
|    |                   | STATUS_FLAGS[30] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |
|    |                   | STATUS_FLAGS[31] | 0x0 <sub>h</sub> | $0x0_h$          | 0x1 <sub>h</sub>       |
| RW | 0x7D <sub>h</sub> | STATUS_MASK      |                  |                  |                        |
|    |                   | WARNING_MASK     | 0x0 <sub>h</sub> | $0x0_h$          | 0xFFFFFFF <sub>h</sub> |



# 8 Pinning



Figure 39: TMC4671 Pinout with 3 phase Power stage and BLDC Motor



Figure 40: TMC4671 Pinout with Stepper Motor





Figure 41: TMC4671 Pinout with DC Motor or Voice Coil

1 Info

All power supply pins (VCC, VCC\_CORE) must be connected.

All ground pins (GND, GNDA, ...) must be connected.

Analog inputs (AI) are 5V single ended or differential inputs (Input range: GNDA to V5). Use voltage dividers or operational amplifiers to scale down higher input voltages.

Digital inputs (I) resp. (IO) are 3.3V single ended inputs.

| 10 | Description                                                   |
|----|---------------------------------------------------------------|
| Al | analog input, 3.3V                                            |
| I  | digital input, 3.3V                                           |
| Ю  | digital input or digital output, direction programmable, 3.3V |
| 0  | digital output, 3.3V                                          |

Table 31: Pin Type Definition



# 9 TMC4671 Pin Table

| Name       | Pin | 10 | Description                                                                           |
|------------|-----|----|---------------------------------------------------------------------------------------|
| nRST       | 50  | I  | active low reset input                                                                |
| CLK        | 51  | I  | clock input; needs to be 25 MHz for correct timing                                    |
| TEST       | 54  | I  | TEST input, must be connected to GND                                                  |
| ENI        | 55  | I  | enable input; If high, controllers and PWM are enabled                                |
| ENO        | 32  | 0  | enable output; feeds through ENI when CLK is applied and IC is not in reset condition |
| STATUS     | 12  | 0  | output for interrupt of CPU (Warning & Status Change)                                 |
| SPI_nSCS   | 6   | I  | SPI active low chip select input                                                      |
| SPI_SCK    | 7   | I  | SPI clock input                                                                       |
| SPI_MOSI   | 8   | I  | SPI master out slave input                                                            |
| SPI_MISO   | 9   | 0  | SPI master in slave output, high impedance, when SPI_nSCS = '1'                       |
| UART_RXD   | 10  | I  | UART receive data RxD for in-system-user communication channel                        |
| UART_TXD   | 11  | 0  | UART transmit data TXD for in-system-user communication channel                       |
| PWM_I      | 58  | I  | PWM input for target value generation                                                 |
| DIR        | 56  | I  | direction input of step-direction interface                                           |
| STP        | 57  | I  | step pulse input for step-direction interface                                         |
| HALL_UX    | 38  | I  | digital hall input H1 for 3-phase (U) or 2-phase (X)                                  |
| HALL_V     | 37  | I  | digital hall input H2 for 3-phase (V)                                                 |
| HALL_WY    | 36  | I  | digital hall input H3 for 3-phase (W) or 2-phase (Y)                                  |
| ENC_A      | 35  | I  | A input of incremental encoder                                                        |
| ENC_B      | 34  | I  | B input of incremental encoder                                                        |
| ENC_N      | 33  | I  | N input of incremental encoder                                                        |
| ENC2_A     | 64  | I  | A input of incremental encoder                                                        |
| ENC2_B     | 65  | ı  | B input of incremental encoder                                                        |
| ENC2_N     | 66  | I  | N input of incremental encoder                                                        |
| REF_L      | 67  | I  | Left (L) reference switch                                                             |
| REF_H      | 68  | I  | Home (H) reference switch                                                             |
| REF_R      | 69  | I  | Right (R) reference switch                                                            |
| ADC_I0_POS | 16  | Al | pos. input for phase current signal measurement I0 (I_U, I_X)                         |



| Name                              | Pin | 10 | Description                                                                                                                                              |
|-----------------------------------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC_I0_NEG                        | 17  | Al | neg. input for phase current signal measurement I0 (I_U, I_X)                                                                                            |
| ADC_I1_POS                        | 18  | Al | pos. input for phase current signal measurement I1 (I_V, I_W, I_Y)                                                                                       |
| ADC_I1_NEG                        | 19  | Al | neg. input for phase current signal measurement I1 (I_V, I_W, I_Y)                                                                                       |
| ADC_VM                            | 20  | AI | analog input for motor supply voltage divider (VM) measurement                                                                                           |
| AGPI_A                            | 21  | Al | analog general purpose input A (analog GPI)                                                                                                              |
| AGPI_B                            | 22  | Al | analog general purpose input B (analog GPI)                                                                                                              |
| AENC_UX_POS                       | 25  | AI | pos. analog input for Hall or analog encoder signal, 3-phase (U) or 2-phase (X (cos))                                                                    |
| AENC_UX_NEG                       | 26  | AI | neg. analog input for Hall or analog encoder signal, 3-phase (U) or 2-phase (X (cos))                                                                    |
| AENC_VN_POS                       | 27  | Al | pos. analog input for Hall or analog encoder signal, 3-phase (V) or 2-phase (N)                                                                          |
| AENC_VN_NEG                       | 28  | Al | neg. analog input for Hall or analog encoder signal, 3-phase (V) or 2-phase (N)                                                                          |
| AENC_WY_POS                       | 29  | AI | pos. analog input for Hall or analog encoder signal, 3-phase (W) or 2-phase (Y (sin))                                                                    |
| AENC_WY_NEG                       | 30  | Al | neg. analog input for Hall or analog encoder signal, 3-phase (W) or 2-phase (Y (sin))                                                                    |
| GPIO0 / ADC_I0_MCD                | 70  | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for ADC_I_0                                     |
| GPIO1 / ADC_I1_MCD                | 71  | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for ADC_I_1                                     |
| GPIO2 / ADC_VM_MCD                | 74  | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for ADC_VM_MCD                                  |
| GPIO3 / AGPI_A_MCD / DBGSPI_nSCS  | 75  | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for AENC_UX_MCD, SPI debug port pin DBGSPI_nSCS |
| GPIO4 / AGPI_B_MCD / DBGSPI_SCK   | 76  | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for AENC_VN_MCD, SPI debug port pin DBGSPI_SCK  |
| GPIO5 / AENC_UX_MCD / DBGSPI_MOSI | 1   | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for AENC_WY_MCD, SPI debug port pin DBGSPI_MOSI |



| Name                              | Pin | 10 | Description                                                                                                                                             |
|-----------------------------------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIO6 / AENC_VN_MCD / DBGSPI_MISO | 4   | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for AGPI_A_MCD, SPI debug port pin DBGSPI_MISO |
| GPIO7 / AENC_WY_MCD / DBGSPI_TRG  | 5   | Ю  | GPIO or $\Delta\Sigma$ -Demodulator clock input MCLKI, clock output MCLKO, or single bit DAC output MDAC for AGPI_B_MCD, SPI debug port pin DBGSPI_TRG  |
| PWM_IDLE_H                        | 59  | I  | idle level of high side gate control signals (not used)                                                                                                 |
| PWM_IDLE_L                        | 60  | I  | idle level of low side gate control signals (not used)                                                                                                  |
| PWM_UX1_H                         | 39  | 0  | high side gate control output U (3-phase) resp. X1 (2-phase)                                                                                            |
| PWM_UX1_L                         | 40  | 0  | low side gate control output U (3-phase) resp. X1 (2-phase)                                                                                             |
| PWM_VX2_H                         | 41  | 0  | high side gate control output V (3-phase) resp. X2 (2-phase)                                                                                            |
| PWM_VX2_L                         | 42  | 0  | low side gate control output V (3-phase) resp. X2 (2-phase)                                                                                             |
| PWM_WY1_H                         | 46  | 0  | high side gate control output W (3-phase) resp. Y1 (2-phase)                                                                                            |
| PWM_WY1_L                         | 47  | 0  | low side gate control output W (3-phase) resp. Y1 (2-phase)                                                                                             |
| PWM_Y2_H                          | 48  | 0  | high side gate control output Y2 (2-phase only)                                                                                                         |
| PWM_Y2_L                          | 49  | 0  | low side gate control output Y2 (2-phase only)                                                                                                          |
| BRAKE                             | 31  | 0  | brake chopper control output signal                                                                                                                     |

Table 32: Functional Pin Description

Feedback input pins that are not needed in target application can be left open or tied to GND.



| Name     | Pin | 10   | Description                                                         |
|----------|-----|------|---------------------------------------------------------------------|
| VCCIO1   | 2   | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| VCCIO2   | 13  | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| VCCIO3   | 43  | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| VCCIO4   | 52  | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| VCCIO5   | 61  | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| VCCIO6   | 72  | 3.3V | digital IO supply voltage; use 100 nF decoupling capacitor          |
| GNDIO1   | 3   | 0V   | digital IO ground                                                   |
| GNDIO2   | 14  | 0V   | digital IO ground                                                   |
| GNDIO3   | 44  | 0V   | digital IO ground                                                   |
| GNDIO4   | 53  | 0V   | digital IO ground                                                   |
| GNDIO5   | 62  | 0V   | digital IO ground                                                   |
| GNDIO6   | 73  | 0V   | digital IO ground                                                   |
| VCCCORE1 | 15  | 1.8V | digital core supply voltage output; use 100 nF decoupling capacitor |
| VCCCORE2 | 45  | 1.8V | digital core supply voltage output; use 100 nF decoupling capacitor |
| VCCCORE3 | 63  | 1.8V | digital core supply voltage output; use 100 nF decoupling capacitor |
| V5       | 23  | 5V   | analog reference voltage                                            |
| GNDA     | 24  | 0V   | analog reference ground                                             |
| GNDPAD   | _   | 0V   | bottom ground pad                                                   |

Table 33: Supply Voltage Pins and Ground Pins



# 10 Electrical Characteristics

# **10.1 Absolute Maximum Ratings**

The maximum ratings may not be exceeded under any circumstances. Operating the circuit at or near more than one maximum rating at a time for extended periods shall be avoided by application design.

| Parameter                                                          | Symbol   | Min | Max | Unit |
|--------------------------------------------------------------------|----------|-----|-----|------|
| Digital I/O supply voltage                                         | VCCIO    |     | 3.6 | ٧    |
| Logic input voltage                                                | VI       |     | 3.6 | ٧    |
| Maximum current drawn on VCCIO with no load on pins                | I_IO     |     | 70  | mA   |
| Maximum current drawn on VCCIO with no load on pins and clock off  | I_IO_0Hz |     | 3   | mA   |
| Maximum current drawn on V5 at fCLK = 25MHz                        | I_V5     |     | 25  | mA   |
| Maximum current to / from digital pins and analog low voltage I/Os | IIO      |     | 10  | mA   |
| Junction temperature                                               | TJ       | -40 | 125 | °C   |
| Storage temperature                                                | TSTG     | -55 | 150 | °C   |
| ESD-Protection for interface pins (Human body model, HBM)          | VESDAP   |     | 2   | kV   |
| ESD-Protection for handling (Human body model, HBM)                | VESD1    |     | 2   | kV   |
| ADC input voltage                                                  | VAI      | 0   | 5   | V    |

Table 34: Absolute Maximum Ratings

VCCCORE is generated internally from VCCIO and shall not be overpowered by external supply.

### 10.2 Electrical Characteristics

### 10.2.1 Operational Range

| Parameter                       | Symbol   | Min  | Max  | Unit |
|---------------------------------|----------|------|------|------|
| Junction temperature            | TJ       | -40  | 125  | °C   |
| Digital I/O 3.3V supply voltage | VIO3V    | 3.15 | 3.45 | ٧    |
| Core supply voltage             | VCC_CORE | 1.65 | 1.95 | V    |

Table 35: Operational Range

The  $\Delta\Sigma$  ADCs can operate in differential or single ended mode. In differential mode the differential input voltage range must be in between -2.5V and +2.5V. However, it is recommended to use the input voltage range from -1.25V to 1.25V, due to non-linearity of  $\Delta\Sigma$  ADCs. In Single ended mode the operational input range of the positive input channel should be between 0V and 2.5V. Recommended maximum input voltage is 1.25V. ADCs have



#### 10.2.2 DC Characteristics

DC characteristics contain the spread of values guaranteed within the specified supply voltage range unless otherwise specified. Typical values represent the average value of all parts measured at +25 °C. Temperature variation also causes stray to some values. A device with typical values will not leave Min/Max range within the full temperature range.

| Parameter                       | Symbol   | Condition    | Min  | Тур | Max | Unit     |
|---------------------------------|----------|--------------|------|-----|-----|----------|
| Input voltage low level         | VINL     | VCCIO = 3.3V | -0.3 |     | 0.8 | ٧        |
| Input voltage high level        | VINH     | VCCIO = 3.3V | 2.3  |     | 3.6 | <b>V</b> |
| Input with pull-down            |          | VIN = 3.3V   | 5    | 30  | 110 | $\mu$ A  |
| Input with pull-up              |          | VIN = 0V     | -110 | -30 | -5  | $\mu$ A  |
| Input low current               |          | VIN = 0V     | -10  |     | 10  | $\mu$ A  |
| Input high current              |          | VIN = VCCIO  | -10  |     | 10  | $\mu$ A  |
| Output voltage low level        | VOUTL    | VCCIO = 3.3V | 0.4  |     |     | V        |
| Output voltage high level       | VOUTH    | VCCIO = 3.3V | 2.64 |     |     | V        |
| Output driver strength standard | IOUT_DRV |              | 4    |     |     | mA       |
| Input impedance of Analog Input | R_ADC    | TJ = 25°C    | 85   | 100 | 115 | kΩ       |

Table 36: DC Characteristics

All I/O lines include Schmitt-Trigger inputs to enhance noise margin.



# 11 Sample Circuits

Please consider electrical characteristics while designing electrical circuitry. Most Sample Circuits in this chapter were taken from the evalutation board for the TMC4671 (TMC4671-EVAL).

# 11.1 Supply Pins

Please provide VCCIO and V5 to the TMC4671. VCC\_CORE is internally generated and needs just an external decoupling capacitor. Place one 100nF decoupling capacitor at every supply pin. Table 37 lists additional needed decoupling capacitors.

| Pin Name | Supply Voltage | Additional Cap. |
|----------|----------------|-----------------|
| V5       | 5V             | 4.7uF           |
| VCCIO    | 3.3V           | 4.7uF & 470nF   |
| VCCCORE  | 1.8V           | none            |

Table 37: Additional decoupling capacitors for supply voltages

# 11.2 Clock and Reset Circuitry

The TMC4671 needs an external oscillator for correct operation at 25 MHz. Lower frequency results in respective scaling of timings. Higher frequency is not supported. The internally generated active low reset can be externally overwritten. If users want to toggle the reset, a pulse length of at least 500 ns is recommended. When not used, please apply a 10k Pull up resistor and make sure all supply voltages are stable.

## 11.3 Digital Encoder, Hall Sensor Interface and Reference Switches

Digital encoders, Hall sensors and reference switches usually operate on a supply voltage of 5V. As the TMC4671 is usually operated at a VCCIO Voltage of 3.3V, a protection circuit for the TMC4671 input pin is needed. In fig. 42 a sample circuit for the ENC\_A signal is shown, which can be reused for all encoder and Hall signals as well as for reference switch signals. Parametrization of the components is given in table 38 for different operations.



Figure 42: Sample Circuit for Interfacing of an Encoder Signal



| Application        | $R_{PU}$ | $R_{PD}$ | $R_{LN}$ | $C_P$ |
|--------------------|----------|----------|----------|-------|
| 5 V Encoder signal | 4K7      | n.c.     | 100R     | 100pF |

*Table 38: Reference Values for circuitry components* 

The raw signal (ENC\_A\_RAW) is divided by a voltage divider and filtered by a low-pass filter. A pull up resistor is applied for open collector encoder output signals. Diodes protect the input pin (ENC\_A) against over- and undervoltage. The cutoff-frequency of the low-pass is:

$$f_c = \frac{1}{2\pi R_{PD}C_P} \tag{50}$$

## 11.4 Analog Frontend

Analog Encoders are encoding the motor position into sinusoidal signals. These signals need to be digitalized by the TMC4671 in order to determine the rotor position. The input voltage range depends on V5 input, which is usually 5V and GNDA (usually 0V). Due to nonlinearity issues of the ADC near input limits, an ADC input value from 1V to 4V is recommended. For a single ended application, the sample circuit from fig. 43 can be used. All single ended analog input pins (AGPI\_A, AGPI\_B and ADC\_VM) have their negative input value tied to GNDA internally, so this sample circuit can also be used for them.



Figure 43: Sample Circuit for Interfacing of a single ended analog signal

If the power stage and the TMC4671 share a common ground, the ADC\_VM input signal can be generated by a voltage divider to scale the voltage down to the needed range.

If the analog encoder has differential output signals, these can be used without signal conditioning (no OP AMPs), when voltage range matches. Differential analog inputs can be used to digitize differential analog input signals with high common mode voltage error suppression.

### 11.5 Phase Current Measurement

The TMC4671 requires two phase currents of a 2 or 3 phase motor to be measured. For a DC Motor only one current in the phase needs to be measured (see Fig. 45). In the ADC engine mapping of current signals to motor phases can be changed. Default setting is I0 to be the current running into the motor in phase U for a 3 phase motor. Respectively the current running into the motor from half-bridge X1 of a 2 phase motor. Figs. 44 and 45 illustrates the currents to be measured and their positive direction.





Figure 44: Phase current measurement: Current directions for 2 and 3 phase motors



Figure 45: Phase current measurement: Current direction for DC or Voice Coil Motor

There are two main options for measuring the phase currents as described above. First option is to use a shunt resistor and a shunt amplifier like the LT1999 or the AD8418A. The other option is to use a real current sensor, which uses the Hall effect or other magnetic effects to implement an isolated current measurement. Shunt measurement might be the more cost-effective solution for low voltage applications up to 100V, while current sensors are more useful at higher voltage levels.

In general the sample circuit in fig. 46 can be used for shunt measurement circuitry. Please consider design guidelines of shunt amplifier supplier additionally. TRINAMIC also supplies power stage boards



with current shunt measurement circuitry (TMC-UPS10A/70V-EVAL). For current measurement also current sensors with voltage output can be used. These could use the Hall effect or other magnetic effects. Main concerns to take about is bandwidth, accuracy and measurement range.



Figure 46: Current Shunt Amplifier Sample Circuit

# 11.6 Power Stage Interface

The TMC4671 is equipped with a configurable PWM engine for control of various gate drivers. Gate driver switch signals can be matched to power stage needs. This includes signal polarities, frequency, BBM-times for low and high side switches, and an enable signal. Please consider gate driver circuitry, when connecting to the TMC4671.



# 12 Setup Guidelines

For easy setup of the TMC4671 on a given hardware platform like the TMC4671 Evaluation-Kit, the user should follow these general guidelines in order to safely set up the system for various modes of operation.

1 Info

These guidelines fit to hardware platforms which are comparable to the TMC4671-Evaluation Kit. If system structure differs, configuration has to be adiusted.

Please also make use of the RTMI Adapter and the TMCL IDE to setup the system as it reduces commissioning time significantly.

#### **Step 0: Setup of SPI communication**

As a first step of the configuration of the TMC4671 the SPI communication should be tested by reading and writing for example to the first registers for identification of the silicon. If communication fails, please check CLK and nRST signals. For easy software setup the TMC API provided on the TRINAMIC website can be used.

### **Step 1: Check connections**

Register TMC\_INPUTS\_RAW can be accessed to see if all connected digital inputs are working correctly e.g. sensor signals can be checked by turning the motor manually.

#### **Step 2: Setup of PWM and Gatedriver configuration**

The user should choose the connected motor and the number of polepairs by setting register MOTOR\_TYPE\_N\_POLE\_PAIRS. For a DC motor the number of pole pairs should be set to one. The PWM can be configured with the corresponding registers PWM\_POLARITIES (Gate Driver Polarities), PWM\_MAXCNT (PWM Frequency), PWM\_BBM\_H\_BBM\_L (BBM times), and PWM\_SV\_CHOP (PWM mode). After setting the register PWM\_SV\_CHOP to 7 the PWM is on and ready to use.

Please check PWM outputs after turning on the PWM, if you are using a new hardware design.

#### Step 3: Open Loop Mode

In the Open Loop Mode the motor is turned by applying voltage to the motor. This mode is useful for test and setup of ADCs and position sensors. It is activated by setting the corresponding registers for PHI\_E\_SELECTION, and MODE\_MOTION. With UD\_EXT the applied voltage can be regulated upwards until the motor starts to turn. Acceleration and target velocity can be changed by their respective registers.

### Step 4: Setup of ADC for current measurement

Please setup the current measurement by choosing your applications ADC configuration. Make sure to match decimation rate of the Delta Sigma ADCs to your choosen PWM frequency.

When the motor turns in Open Loop Mode the current measurement can be easily calibrated. Please match offset and gain of phase current signals by setting the corresponding registers. Please also make sure for a new hardware setup, that current measurements and PWM channels are matched. This can be done by matching phase voltages and phase currents. Register ADC\_I\_SELECT can be used to switch relations.

### **Step 5: Setup of Feedback Systems**

In Open Loop Mode also the feedback systems can be checked for correct operation. Please configure registers related to used position sensor(s) and compare against Open Loop angles. Use encoder initialization routines to set angle offsets for relative position encoders according to application needs.

# **Step 6: Setup of FOC Controllers**

Please configure your application's feedback system and configure position and velocity signal switches accordingly inside the FOC. Configure controller output limits according to you needs.

Setup PI controller parameters for used FOC controllers. Start with the current controller, followed by the velocity controller, followed by the position controller. Stop configuration at your desired cascade level. TRINAMIC recommends to set the PI controller parameters by support of the RTMI, as it supports real-time access to registers and the TMCL IDE offers tools for automated controller tuning. Controller tuning without realtime access might lead to poor performance.

Please choose afterwards your desired Motion Mode and feed in reference values.



# **Step 7: Advanced Functions**

For performance improvements Biquad filters and feed forward control can be applied.

# 13 Package Dimensions

Package: QFN76, 0.4 mm pitch, size 11.5 mm x 6.5 mm.



Figure 47: QFN76 Package Outline

| QFN76 Package Dimensions in mm |               |               |         |      |  |  |
|--------------------------------|---------------|---------------|---------|------|--|--|
| Description                    | Dimension[mm] | min. typ. max |         |      |  |  |
| Total Thickness                | A             | 0.80 0.85 0.9 |         | 0.90 |  |  |
| Stand Off                      | A1            | 0.00 0.035 0. |         | 0.05 |  |  |
| Mold Thickness                 | A2            | — 0.65 -      |         | _    |  |  |
| L/F Thickness                  | A3            | 0.203 REF     |         |      |  |  |
| Lead Width                     | b             | 0.15 0.2 0.2  |         | 0.25 |  |  |
| Body Width                     | D             |               | 10.5 BS | 2    |  |  |



| QFN76 Package Dimensions in mm |     |         |         |      |  |  |  |
|--------------------------------|-----|---------|---------|------|--|--|--|
| Body Length                    | Е   | 6.5 BSC |         |      |  |  |  |
| Lead Pitch                     | е   |         | 0.4 BSC |      |  |  |  |
| EP Size                        | J   | 8.9     | 9       | 9.1  |  |  |  |
| EP Size                        | К   | 4.9     | 5       | 5.1  |  |  |  |
| Lead Length                    | L   | 0.35    | 0.40    | 0.45 |  |  |  |
| Lead Length                    | L1  | 0.30    | 0.40    |      |  |  |  |
| Package Edge Tolerance         | aaa |         | 0.1     |      |  |  |  |
| Mold Flatness                  | bbb |         | 0.1     |      |  |  |  |
| Coplanarity                    | ссс |         | 0.08    |      |  |  |  |
| Lead Offset                    | ddd |         | 0.1     |      |  |  |  |
| Exposed Pad Offset             | eee |         | 0.1     |      |  |  |  |

Table 39: Package Outline Dimensions

Figure 48 shows the package from top view. Decals for some CAD programs are available on the product's website.





Figure 48: Pinout of TMC4671 (Top View)



# 14 Supplemental Directives

### 14.1 Producer Information

# 14.2 Copyright

TRINAMIC owns the content of this user manual in its entirety, including but not limited to pictures, logos, trademarks, and resources. © Copyright 2021 TRINAMIC. All rights reserved. Electronically published by TRINAMIC, Germany.

Redistributions of source or derived format (for example, Portable Document Format or Hypertext Markup Language) must retain the above copyright notice, and the complete Datasheet User Manual documentation of this product including associated Application Notes; and a reference to other available product-related documentation.

# 14.3 Trademark Designations and Symbols

Trademark designations and symbols used in this documentation indicate that a product or feature is owned and registered as trademark and/or patent either by TRINAMIC or by other manufacturers, whose products are used or referred to in combination with TRINAMIC's products and TRINAMIC's product documentation.

This Datasheet is a non-commercial publication that seeks to provide concise scientific and technical user information to the target user. Thus, trademark designations and symbols are only entered in the Short Spec of this document that introduces the product at a quick glance. The trademark designation /symbol is also entered when the product or feature name occurs for the first time in the document. All trademarks and brand names used are property of their respective owners.

# 14.4 Target User

The documentation provided here, is for programmers and engineers only, who are equipped with the necessary skills and have been trained to work with this type of product.

The Target User knows how to responsibly make use of this product without causing harm to himself or others, and without causing damage to systems or devices, in which the user incorporates the product.

# 14.5 Disclaimer: Life Support Systems

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.

Information given in this document 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. Specifications are subject to change without notice.

### 14.6 Disclaimer: Intended Use

The data specified in this user manual is intended solely for the purpose of product description. No representations or warranties, either express or implied, of merchantability, fitness for a particular purpose



or of any other nature are made hereunder with respect to information/specification or the products to which information refers and no guarantee with respect to compliance to the intended use is given.

In particular, this also applies to the stated possible applications or areas of applications of the product. TRINAMIC products are not designed for and must not be used in connection with any applications where the failure of such products would reasonably be expected to result in significant personal injury or death (safety-Critical Applications) without TRINAMIC's specific written consent.

TRINAMIC products are not designed nor intended for use in military or aerospace applications or environments or in automotive applications unless specifically designated for such use by TRINAMIC. TRINAMIC conveys no patent, copyright, mask work right or other trade mark right to this product. TRINAMIC assumes no liability for any patent and/or other trade mark rights of a third party resulting from processing or handling of the product and/or any other use of the product.

#### 14.7 Collateral Documents & Tools

This product documentation is related and/or associated with additional tool kits, firmware and other items, as provided on the product page at: www.trinamic.com.



# 15 Errata of TMC4671-LA/-ES2/-ES

### 15.1 Errata of TMC4671-LA

# PID\_POSITION\_ACTUAL glitches when calculated from Hall sensor angle and Hall Interpolation is activated

Hall interpolation is not intended for positioning applications, especially not with changes of direction. In the following register configuration glitches on PID\_POSITION\_ACTUAL 0x6B can occur:

| Register                | Value (descr.)                         | Note                          |
|-------------------------|----------------------------------------|-------------------------------|
|                         | 5 (PHI_E_HALL selected)                |                               |
| 0x51 POSITION_SELECTION | 6 (PHI_M_HALL selected)                | Here PID_POSITION_ACTUAL      |
|                         | 0 (Use selection in register 0x52)     | is calculated from PHI_E_HALL |
| 0x52 PHI_E_SELECTION    | 5 (PHI_E_HALL selected)                | or PHI_M_HALL.                |
| 0x33 HALL_MODE          | bit 8 = 1 (Hall interpolation enabled) |                               |

Table 40: Registersettings susceptible to glitches

In this configuration PID\_POSITION\_ACTUAL might not be able to count full revolutions correctly as the interpolated PHI\_E\_HALL might glitch when motor stops. As a result a full revolution is counted where there was not one completed. If the user does not rely on correct position information in register PID\_POSITION\_ACTUAL the silicon error does not affect the application.

#### Workaround

The hall sensor interpolation needs to be switched off.

#### 15.2 Fixes of TMC4671-LA/-ES2 vs. Errata of TMC4671-ES

| # | TMC4671-ES Erratum             | TMC4671-LA Fix                                      | Description                                                                                                                           |
|---|--------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 1 | SPI slave MSB read error       | SPI slave correction                                | read via SPI slave now works correct                                                                                                  |
| 2 | RTMI critical timing           | RTMI enhanced                                       | RTMI works with isolated RTMI-USB IF                                                                                                  |
| 3 | PI advanced controller         | PI scaling updated                                  | scaling selectable available                                                                                                          |
| 4 | ADC group clock cross talk     | ADC clocks corrected                                | crosstalk eliminated                                                                                                                  |
| 5 | PWM_IDLE_L/_H un-used          | PWM outputs are at high impedance until ENI is high | User can configure PWM signal polarity and afterwards enable PWM signals. Idle state can be set with PD or PU resistor on PWM outputs |
| 6 | Space Vector PWM               | SVPWM scaling cor-<br>rected                        | SVPWM gives +12% effective voltage.<br>With Space Vector PWM enabled voltage scaling is modified.                                     |
| 7 | step direction target position | processing corrected                                | step direction as target position                                                                                                     |
| 8 | ABN encoder register access    | access corrected                                    | ABN counter over-writeable                                                                                                            |



| 9  | ENI and ENO                   | function updated                             | ENI and ENO act as enable signals                                     |
|----|-------------------------------|----------------------------------------------|-----------------------------------------------------------------------|
| 10 | -                             | Hall sync PWM sample                         | optional Hall sampling at PWM center                                  |
| 11 | -                             | PWM_POLARITIES register initialized to 0x0   | Active high PWM signal polarity is pre-<br>ferred                     |
| 12 | -                             | Registers PHI_M_EXT and POSITION_EXT removed | Registers were not used                                               |
| 13 | Watchdog not properly working | Watchdog removed                             | Watchdog was intended to monitor CLK. Watchdog flag can not be reset. |

Table 41: TMC4671-ES Errata vs. TMC4671-ES2/-LA Fixes

# 15.3 Errata of TMC4671-ES Engineering Samples as Reference

- 1. SPI Slave Interface The SPI Slave Interface in the TMC4671-ES might show corrupted MSB of read data.
- 2. Realtime Monitoring Interface
  The RTMI of TMC4671-ES could not be used with galvanic isolation due to timing issue.
- 3. PI Controllers

The P Factor of the TMC4671-ES in the advanced position controller was not properly scaled and the integrator in the advanced PI controller was not reset when P or I parameters are set to zero.

- 4. Integrated ADCs
  The Delta Sigma ADCs of TMC4671-ES showed signal cross talk caused by ADC clock cross talk.
- 5. Pins PWM\_IDLE\_H and PWM\_IDLE\_L without function
  Pins PWM\_IDLE H and PWM\_IDLE L of TMC4671-ES were proposed to set gate driver control polarity.
- 6. Space Vector PWM does not allow higher voltage utilization The Space vector PWM of the TMC4671-ES does not allow higher voltage utilization.
- 7. Step Direction Counter not used as Target Position
  The step direction counter of the TMC4671-ES correctly counts but is not available as target position.
- 8. Register write access to ABN encoder count register and N pulse status bits Write access to count registers of TMC4671-ES cleared theses to zero and encoder N pulse input signals were not available within the status register.
- 9. ENO and ENI ENI (ENable Input) and ENO (ENable Output) of TMC4671-ES did partially work as intended (incomplete reset assignment, missing error sum clear on disable).



#### 15.4 Actions to Avoid Trouble

What should be taken into account when moving from TMC4671-ES to TMC4671-LA?

- update P and I parameter for the advanced PI controller in case of switching numerical representation from Q8.8 to Q4.12 (classical PI controller is un-changed)
- mount pull-up resistors if required for gate driver control signals during power-on reset
- check setting of SVPWM control bit to avoid un-wanted speed-up by SVPWM in torque mode (poweron default is disable without speed-up)
- check setting of additional hall\_sync\_pwm\_enable bit for high speed application with usage of Hall signals (power-on default is disable)

### 15.5 Recommendations

• TMC4671-LA (TMC4671-ES2) is drop-in compatible to the TMC4671-ES. Nevertheless, the TMC4671-LA needs to be functional qualified as replacement to avoid un-wanted behavior caused by corrections of errata of TMC4671-ES.

For example: The space vector PWM /SVPWM) control bit does not have an effect for the TMC4671-ES in torque mode. The space vector PWM is corrected for the TMC4671-LA. So, if the SVPWM control bit is un-wanted enabled for the TMC4671-ES, the TMC4671-LA would run approximately +12% faster in torque mode with the same settings.



# 16 Figures Index

| 1  | FOC Basic Principle                             | 9  | 24 | Outline of noisy Hall signals (left) due     |      |
|----|-------------------------------------------------|----|----|----------------------------------------------|------|
| 2  | PID Architectures and Motion Modes              | 10 |    | to electromagnetic interference with         |      |
| 3  | Orientations UVW (FOC3) and XY (FOC2            | 15 |    | PWM switching and noise cleaned              |      |
| 4  | Compass Motor Model w/ 3 Phases                 |    |    | Hall signals (right) by PWM center           |      |
|    | UVW (FOC3) and Compass Motor                    |    |    | synced sampling of Hall signal vector        |      |
|    | Model w/ 2 Phases (FOC2)                        | 15 |    | (H1 H2 H3)                                   | 47   |
| 5  | Hardware FOC Application Diagram .              | 16 | 25 | Hall Signal PWM Center Sampling on           |      |
| 6  | Hardware FOC Block Diagram                      | 16 |    | PWM_CENTER                                   | 47   |
| 7  | SPI Datagram Structure                          | 17 | 26 | Hall Signal Blanking                         | 48   |
| 8  | SPI Timing                                      | 18 | 27 | Analog Encoder (AENC) signal wave-           |      |
| 9  | SPI Timing of Write Access without              |    |    | forms                                        | 48   |
|    | pause with fSCK up to 8MHz                      | 19 | 28 | Analog Encoder (AENC) Selector &             |      |
| 10 | SPI Timing of Read Access with pause            |    |    | Scaler w/ Offset Correction                  | 49   |
|    | (tPAUSE) of 500 ns with fSCK up to              |    | 29 | Classic PI Controller Structure              | 54   |
|    | 8MHz                                            | 19 | 30 | Advanced PI Controller Structure             | 55   |
| 11 | Connector for Real-Time Monitoring              |    | 31 | PI Controllers for position, velocity        |      |
|    | Interface (Connector Type: Hirose               |    |    | and current                                  | 56   |
|    | DF20F-10DP-1V)                                  | 20 | 32 | Inner FOC Control Loop                       | 57   |
| 12 | UART Read Datagram (TMC4671 reg-                |    | 33 | FOC Transformations                          | 58   |
|    | ister read via UART)                            | 22 | 34 | Motion Modes                                 | 58   |
| 13 | UART Write Datagram (TMC4671 reg-               |    | 35 | Biquad Filters in Control Structure          | 61   |
|    | ister write via UART)                           | 22 | 36 | PWM Gate Driver Control Polarities .         | 62   |
| 14 | N_POLE_PAIRS - Number of Pole Pairs             |    | 37 | FOC3 (three phase motor), FOC2 (two          |      |
|    | (Number of Poles)                               | 26 |    | phase stepper motor), FOC1 (single           |      |
| 15 | Integer Representation of Angles as             |    |    | phase DC motor)                              | 63   |
|    | 16 bit signed (s16) resp. 16 bit un-            |    | 38 | BBM Timing                                   | 64   |
|    | signed (u16)                                    | 27 | 39 | TMC4671 Pinout with 3 phase Power            |      |
| 16 | Input Voltage Ranges of internagl               |    |    | stage and BLDC Motor                         | 128  |
|    | Delta Sigma ADC Channels                        | 31 | 40 | TMC4671 Pinout with Stepper Motor            | 128  |
| 17 | Delta Sigma ADC Configurations                  |    | 41 | TMC4671 Pinout with DC Motor or              |      |
|    | dsADC_CONFIG (ANALOG (internal),                |    |    | Voice Coil                                   | 129  |
|    | MCLKO, MCLKI, MDAC)                             | 33 | 42 | Sample Circuit for Interfacing of an En-     |      |
| 18 | $\Delta\Sigma$ ADC Configurations - MDAC        |    |    | coder Signal                                 | 136  |
|    | (Comparator-R-C-R as $\Delta\Sigma$ -Modulator) | 37 | 43 | Sample Circuit for Interfacing of a sin-     |      |
| 19 | ADC Selector and Scaler with Offset             |    |    | gle ended analog signal                      | 137  |
|    | Correction                                      | 41 | 44 | Phase current measurement: Current           |      |
| 20 | Number of Pole Pairs npp vs. mechan-            |    |    | directions for 2 and 3 phase motors .        | 138  |
|    | ical angle phi_m and electrical angle           |    | 45 | Phase current measurement: Current           |      |
|    | phi_e                                           | 43 |    | direction for DC or Voice Coil Motor .       | 138  |
| 21 | ABN Incremental Encoder N Pulse                 | 44 | 46 | <b>Current Shunt Amplifier Sample Circui</b> | t139 |
| 22 | Encoder ABN Timing                              | 45 | 47 | QFN76 Package Outline                        |      |
| 23 | Hall Sensor Angles                              | 46 | 48 | Pinout of TMC4671 (Top View)                 |      |



# 17 Tables Index

| 1  | Order codes                                     | 6  | 19 | Example Parameters for ADC_GAIN .        | 39  |
|----|-------------------------------------------------|----|----|------------------------------------------|-----|
| 2  | SPI Timing Parameter                            | 18 | 20 | Scalings and Change Rate Timings of      |     |
| 3  | Possible baudrates and correspond-              |    |    | classical PID controllers for currents,  |     |
|    | ing values for register 0x79                    | 21 |    | velocity, and position                   | 53  |
| 4  | Single Pin Interface Motion Modes               | 23 | 21 | Motion Modes                             | 53  |
| 5  | GPIO Configuration Overview with 'x'            |    | 22 | Motion Modes                             | 59  |
|    | as don't care                                   | 24 | 23 | TABSTatusFlags                           | 62  |
| 6  | Numerical Representations                       | 24 | 24 | FOC321 Gate Control Signal Configu-      |     |
| 7  | Examples of u16, s16, q8.8, q4.12               | 25 |    | rations                                  | 63  |
| 8  | Examples of u16, s16, q8.8                      | 27 | 25 | Factors for integer to real conversion   | 65  |
| 9  | Delta Sigma $\Delta\Sigma$ ADC Input Stage Con- |    | 26 | Factors for real to integer conversion   | 66  |
|    | figurations                                     | 30 | 27 | TABSTatusFlags                           | 67  |
| 10 | Delta Sigma $\Delta\Sigma$ ADC Input Stage Con- |    | 28 | TMC4671 Registers                        | 75  |
|    | figurations                                     | 31 | 31 |                                          | 129 |
| 11 | $\Delta\Sigma$ ADC Configurations               | 33 | 32 |                                          | 132 |
| 12 | Registers for Delta Sigma Configuration         | 34 | 33 |                                          | 133 |
| 13 | Delta Sigma MCLK Configurations                 | 34 | 34 | Absolute Maximum Ratings                 | 134 |
| 14 | Recommended Decimation Parame-                  |    | 35 |                                          | 134 |
|    | ter MDEC                                        | 35 | 36 |                                          | 135 |
| 15 | Recommended input voltage range                 |    | 37 | Additional decoupling capacitors for     |     |
|    | from V_MIN25%[V] to V_MAX75%[V]                 |    |    |                                          | 136 |
|    | for internal Delta Sigma Modulators;            |    | 38 | Reference Values for circuitry compo-    |     |
|    | $V_SUPPLY[V] = 5V$ is recommended               |    |    | nents                                    | 137 |
|    | for the analog part of the TMC4671              | 36 | 39 |                                          | 142 |
| 16 | Delta Sigma input voltage mapping of            |    | 40 | Registersettings susceptible to glitches | 146 |
|    | internal Delta Sigma Modulators                 | 36 | 41 | TMC4671-ES Errata vs. TMC4671-           |     |
| 17 | Delta Sigma R-C-R-CMP Configurations            | 37 |    |                                          | 147 |
| 18 | Delta Sigma input voltage mapping of            |    | 42 |                                          | 151 |
|    | external comparator (CMP)                       | 38 | 43 |                                          | 152 |



# **18 Revision History**

# **18.1 IC Revision**

| Version | Date        | Author | Description                                           |
|---------|-------------|--------|-------------------------------------------------------|
| V1.0    | 2017-JUL-03 | LL, OM | Engineering samples TMC4671-ES (1v0 2017-07-03-19:43) |
| V1.3    | 2019-APR-30 | LL, OM | Release version TMC4671-LA (1v3 2019-04-30-12:55)     |

Table 42: IC Revision

# **18.2 Document Revision**

| Version | Date        | Author | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V0.9    | 2017-SEP-29 | LL, OM | Pre-liminary TMC4671-ES datasheet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V0.91   | 2018-JAN-30 | ОМ     | Changed some typos and added some notes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| V0.92   | 2018-FEB-28 | ОМ     | Changed register descriptions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| V0.93   | 2018-MAR-07 | ОМ     | Changed some typos and bugs in graphics.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| V0.94   | 2018-MAR-14 | ОМ     | Added Errata Section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| V0.95   | 2018-MAY-08 | ОМ     | Preparations for launch.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| V1.00   | 2018-JUN-28 | LL     | Errata Section updated concerning Step/Dir.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V1.01   | 2018-JUL-19 | ОМ     | Added Description for Status Flags                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V1.02   | 2018-JUL-31 | ОМ     | Added Description for Feed Forward Control Structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V1.03   | 2018-SEP-06 | ОМ     | Description of single pin interface and motion modes added                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| V1.04   | 2018-DEC-11 | ОМ     | Register map and pictures of PI controllers corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| V1.05   | 2019-JAN-02 | ОМ     | Figure 9 corrected, order codes for eval kits added.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V1.06   | 2019-FEB-06 | ОМ     | Reference switch processing explained.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| V1.07   | 2019-MAR-22 | LL     | errata updated concerning encoder N pulse, ENI and ENO; figure illustrating PPR, NPP, phi_m, phi_e added; PWM polarities and Hall signal blanking expained in more detail together with drawings.                                                                                                                                                                                                                                                                                                                                                                                                           |
| V1.99   | 2019-SEP-12 | LL     | register map structure with enhanced readability, minimal move PI controller section of TMC4671-ES removed for TMC4671-LA; SPI timing with tPAUSE added; figure of Hall signal PWM synced sampling option added; section ADC Gain Factors added; section ADC engine updated; sense amplifier type corrected to AD8418; LM319 removed as dsMOD example; ADC engine section updated; PWM Engine FOC321 with associated motor connectors added; PID T_N (Nachstellzeit = Reset Time) dsADC input stage configuration, ADC real world scaling (IgainADC[A/LSB], UgainADC[V/LSB]) added, errata section updated; |



| Version | Date        | Author | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V1.99   | 2019-DEC-06 | LL     | functional summary updated for TMC4671-LA, FOC basics updated, functional description updated, SPI read write access timing updated for TMC4671-LA, ADC Engine section updated w/ voltage scalings, step direction interface correction updated, order codes updated, section 'Calculative PI Controller Setup - Classic Structure' added; TMC4671-ES Erratum vs. TMC4671-LA fixes added, PWM center Hall vector sampling added; section watchdog updated; section fixes vs. errata updated concerning actions to avoid trouble with recommendations; section How to Turn a Motor updated; entry (signal of max. of q4.12) in table (6) corrected, |
| V1.99   | 2019-DEC-20 | LL     | watchdog section updated, order codes updated, 1st page block diagram updated, DS_ANALOG_INPUT_STAGE_CFG updated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| V1.99   | 2020-FEB-10 | LL     | Encoder Engine section: mechanical position (phi_m) corrected, section Safety Functions: hint according to status bit write added,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V2.00   | 2020-APR-16 | ОМ     | feedforward control and PI control section updated; ENO/ENI pin functionality added; Register map updated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V2.01   | 2020-JUL-13 | KK     | Register map updated (added missing registers, removed unused registers), added section for controller sampling rates, added table for real2int and int2real conversions, added section for GPIOusage, updated controller q8.8 and q4.12 representation, fixed num_representation for angles                                                                                                                                                                                                                                                                                                                                                       |
| V2.02   | 2020-SEP-22 | OM     | Register map updated (removed feed forward control registers), added descriptions for register usage and register function, fixed exponents in tables for real/integer pwm conversion, updated feed-foward, updated AENC_DECODER_MODE register info and infobox in Analog Hall and Analog Encoder Interface                                                                                                                                                                                                                                                                                                                                        |
| V2.03   | 2020-OCT-08 | KK     | Fixed several typos, added missing information about UART baudrate in 4.2.3, fixed default values for UART_BPS register and added hint in registermap about baudrate settings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| V2.04   | 2021-JAN-06 | KK     | Removed obsolete register AENC_DECODER_N_MASK from register 0x3C in 7.2 and 7.3, added errata on hall interpolation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V2.05   | 2021-JAN-06 | KK     | updated errata section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Table 43: Document Revision

