TRINAMIC / ANALOG DEVICES TMCM-1636-24V-TMCL Owner's manual

  • Hello! I've analyzed the provided document, which is a Firmware Manual for the TRINAMIC TMCM-1636 servo drive. The manual details the TMCL commands and parameters for controlling the motor drive, including motion commands, parameter settings, and I/O port controls. It covers the various feedback options supported, such as incremental and absolute encoders. I'm ready to answer your questions about the TMCM-1636 and related topics in the manual.
  • What type of motors does the TMCM-1636 support?
    What communication interfaces does the TMCM-1636 have?
    What kind of position feedback options are supported?
    What is the maximum power that the TMCM-1636 can handle?
Module for BLDC MODULE
TMCM-1636 TMCLFirmware Manual
Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09
The TMCM-1636 is a single axis servo drive for 3-phase BLDC motors and DC motors with up to ca.
1000W running at +24V or +48V. It oers a CAN & UART interface with either TMCL or CANopen
protocol for communication. TMCM-1636 supports various positions feedback options: 2x incre-
mental quadrature encoders, analog encoder, digital HALL sensor, absolute SPI- and SSI-based
encoders. Customization of rmware and hardware is possible.
Features
Servo Drive for BLDC and DC Motor
+24V and +48V Supply Version
Up to 1000W continuous
Up to 60A RMS phase current max.
CAN & UART interface
2x incremental encoder
Digital HALL sensor
Analog encoder option
Absolute SPI& SSI-based encoder
support
Various GPIOs
Motor brake control and overvolt-
age protection
Applications
Robotics
Laboratory Automation
Manufacturing
Factory Automation
Servo Drives
Motorized Tables and Chairs
Industrial BLDC & DC Motor
Drives
Simplied Block Diagram
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at: www.trinamic.com
Read entire documentation.
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 2 / 75
Contents
1 First Steps with TMCL 4
1.1 Basic Setup ................................................ 4
1.2 Using the TMCL Direct Mode ...................................... 4
1.3 Testing with a simple TMCL Program ................................. 4
2 TMCL and the TMCL-IDE An Introduction 6
2.1 Binary Command Format ........................................ 6
2.1.1 Checksum Calculation ..................................... 7
2.2 Reply Format ............................................... 8
2.2.1 Status Codes ........................................... 8
2.3 Standalone Applications ........................................ 9
2.4 TMCL Command Overview ....................................... 10
2.5 TMCL Commands by Subject ...................................... 11
2.5.1 Motion Commands ....................................... 11
2.5.2 Parameter Commands ..................................... 11
2.5.3 Branch Commands ....................................... 12
2.5.4 I/O Port Commands ....................................... 12
2.5.5 Calculation Commands ..................................... 13
2.6 Detailed TMCL Command Descriptions ................................ 14
2.6.1 ROR (Rotate Right) ........................................ 14
2.6.2 ROL (Rotate Left) ......................................... 15
2.6.3 MST (Motor Stop) ........................................ 16
2.6.4 MVP (Move to Position) ..................................... 17
2.6.5 SAP (Set Axis Parameter) .................................... 19
2.6.6 GAP (Get Axis Parameter) ................................... 20
2.6.7 STAP (Store Axis Parameter) .................................. 21
2.6.8 RSAP (Restore Axis Parameter) ................................ 22
2.6.9 SGP (Set Global Parameter) .................................. 23
2.6.10 GGP (Get Global Parameter) .................................. 24
2.6.11 STGP (Store Global Parameter) ................................ 25
2.6.12 RSGP (Restore Global Parameter) ............................... 26
2.6.13 SIO (Set Output) ......................................... 27
2.6.14 GIO (Get Input) .......................................... 29
2.6.15 CALC (Calculate) ......................................... 32
2.6.16 COMP (Compare) ........................................ 34
2.6.17 JC (Jump conditional) ...................................... 35
2.6.18 JA (Jump always) ......................................... 37
2.6.19 CSUB (Call Subroutine) ..................................... 38
2.6.20 RSUB (Return from Subroutine) ................................ 39
2.6.21 WAIT (Wait for an Event to occur) ............................... 40
2.6.22 STOP (Stop TMCL Program Execution End of TMCL Program) .............. 42
2.6.23 CALCX (Calculate using the X Register) ............................ 43
2.6.24 AAP (Accu to Axis Parameter) ................................. 45
2.6.25 AGP (Accu to Global Parameter) ................................ 46
2.6.26 CLE (Clear Error Flags) ..................................... 47
2.6.27 Customer specic Command Extensions (UF0. . . UF7 User Functions) ........ 49
2.6.28 TMCL Control Commands ................................... 50
3 Axis Parameters 52
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 3 / 75
4 Global Parameters 59
4.1 Bank 0 ................................................... 59
4.2 Bank 2 ................................................... 61
5 Motor Regulation 62
5.1 Structure of Cascaded Motor Regulation Modes .......................... 62
5.2 Current Regulation ............................................ 62
5.2.1 Timing Control Value ...................................... 62
5.2.2 Structure of the Current Regulator .............................. 62
5.3 Velocity Regulation ............................................ 63
5.3.1 Timing Control Value ...................................... 64
5.3.2 Structure of the Velocity Regulator .............................. 64
5.4 Velocity Ramp Generator ........................................ 65
5.5 Position Regulation ........................................... 65
5.5.1 Timing Control Value ...................................... 65
5.5.2 Structure of the Position Regulator .............................. 65
5.5.3
Correlation of Axis Parameters 10 and 7, the Target Position and the Position End Flag
66
6 TMCL Programming Techniques and Structure 67
6.1 Initialization ................................................ 67
6.2 Main Loop ................................................. 67
6.3 Using Symbolic Constants ....................................... 68
6.4 Using Variables .............................................. 68
6.5 Using Subroutines ............................................ 69
6.6 Combining Direct Mode and Standalone Mode ........................... 69
6.7 Make the TMCL Program start automatically ............................. 70
7 Figures Index 71
8 Tables Index 72
9 Supplemental Directives 73
9.1 Producer Information .......................................... 73
9.2 Copyright ................................................. 73
9.3 Trademark Designations and Symbols ................................ 73
9.4 Target User ................................................ 73
9.5 Disclaimer: Life Support Systems ................................... 73
9.6 Disclaimer: Intended Use ........................................ 73
9.7 Collateral Documents & Tools ..................................... 74
10 Revision History 75
10.1 Firmware Revision ............................................ 75
10.2 Document Revision ........................................... 75
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 4 / 75
1 First Steps with TMCL
In this chapter you can nd some hints for your rst steps with the TMCM-1636 and TMCL. You may skip
this chapter if you are already familiar with TMCL and the TMCL-IDE.
Things that you will need
Your TMCM-1636 Module.
A power supply (24V DC) for your TMCM-1636 Module.
A CAN adapter.
The TMCL-IDE 3.x already installed on your PC
1.1 Basic Setup
First of all, you will need a PC with Windows (at least Windows 7) and the TMCL-IDE 3.x installed on it. If
you do not have the TMCL-IDE installed on your PC then please download it from the TMCL-IDE product
page of Trinamics website (www.trinamic.com/support/software/) and install it on your PC.
Please also ensure that your TMCM-1636 is properly connected to your power supply. Please see the
TMCM-1636 hardware manual for instructions on how to do this.
Do not connect or disconnect the
motor to or from the module while the module is powered!
Then, please start up the TMCL-IDE.
Afterwards you can connect your TMCM-1636. Just connect the module via CAN and switch on the power
supply.
1.2 Using the TMCL Direct Mode
At rst try to use some TMCL commands in direct mode. In the TMCL-IDE a tree view showing the TMCM-
1636 and all tools available for it is displayed. Click on the Direct Mode entry of the tool tree. Now, the
Direct Mode tool will pop up.
In the Direct Mode tool you can choose a TMCL command, enter the necessary parameters and execute
the command. For example, choose the command ROL (rotate left). Then choose the appropriate motor
(motor 0 if your motor is connected to the motor 0 connector). Now, enter the desired speed. Try entering
500 rpm as the value and then click the Execute button. The motor will now run. Choose the MST (motor
stop) command and click Execute again to stop the motor.
Next you can try changing some settings (also called axis parameters) using the SAP command in direct
mode. Choose the SAP command. Then choose the parameter type and the motor number. Last, enter
the desired value and click execute to execute the command which then changes the desired parameter.
Please see chapter 3for a complete list of all axis parameters.
1.3 Testing with a simple TMCL Program
Now, test the TMCL stand alone mode with a simple TMCL program. To type in, assemble and download
the program, you will need the TMCL creator. This is also a tool that can be found in the tool tree of
the TMCL-IDE. Click the TMCL creator entry to open the TMCL creator. In the TMCL creator, type in the
following little TMCL program:
1SAP 5, 0, 33911 // set ADC off sets
SAP 6, 0, 32514
3
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 5 / 75
SA P 53 , 0 , 100 0 // set po sition reached distance
5SA P 54 , 0 , 500 // set posit ion reached velocit y [rpm ]
SA P 74 , 0 , 500 // set position P
7SA P 44 , 0 , 1 0000 // set a cc eler ati on [ rpm / s]
9SA P 15 , 0 , 2 // switch to encoder mode
11 ROR 0, 200 // rotate motor
WAIT TICKS , 0, 300
13
// cle ar p osi tio n c ou nt er on nex t enc oder -N - C han nel e ve nt
15 SA P 67 , 0 , 1 // set clear on null
SA P 68 , 0 , 1 // set clear once
17 WAIT TICKS , 0, 300
19 PositionTest:
MVP ABS , 0 , 0
21 WAIT POS , 0, 0
MVP ABS , 0, 655360
23 WAIT POS , 0, 0
JA PositionTest
After you have done that, take the following steps:
1.
Click the Assemble icon (or choose Assemble from the TMCL menu) in the TMCL creator to assemble
the program.
2.
Click the Download icon (or choose Download from the TMCL menu) in the TMCL creator to donwload
the program to the module.
3.
Click the Run icon (or choose Run from the TMCL menu) in the TMCL creator to run the program on
the module.
Also try out the debugging functions in the TMCL creator:
1. Click on the Bug icon to start the debugger.
2. Click the Animate button to see the single steps of the program.
3. You can at any time pause the program, set or reset breakpoints and resume program execution.
4. To end the debug mode click the Bug icon again.
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 6 / 75
2 TMCL and the TMCL-IDE An Introduction
As with most TRINAMIC modules the software running on the microprocessor of the TMCM-1636 consists
of two parts, a boot loader and the rmware itself. Whereas the boot loader is installed during production
and testing at TRINAMIC and remains untouched throughout the whole lifetime, the rmware can be
updated by the user. New versions can be downloaded free of charge from the TRINAMIC website
(http://www.trinamic.com).
The TMCM-1636 supports TMCL direct mode (binary commands). It also implements standalone TMCL
program execution. This makes it possible to write TMCL programs using the TMCL-IDE and store them in
the memory of the module.
In direct mode the TMCL communication over RS-232, RS-485, CAN, and USB follows a strict master/slave
relationship. That is, a host computer (e.g. PC/PLC) acting as the interface bus master will send a com-
mand to the TMCM-1636. The TMCL interpreter on the module will then interpret this command, do the
initialization of the motion controller, read inputs and write outputs or whatever is necessary according to
the specied command. As soon as this step has been done, the module will send a reply back over the
interface to the bus master. Only then should the master transfer the next command.
Normally, the module will just switch to transmission and occupy the bus for a reply, otherwise it will stay
in receive mode. It will not send any data over the interface without receiving a command rst. This way,
any collision on the bus will be avoided when there are more than two nodes connected to a single bus.
The Trinamic Motion Control Language [TMCL] provides a set of structured motion control commands.
Every motion control command can be given by a host computer or can be stored in an EEPROM on the
TMCM module to form programs that run standalone on the module. For this purpose there are not only
motion control commands but also commands to control the program structure (like conditional jumps,
compare and calculating).
Every command has a binary representation and a mnemonic. The binary format is used to send com-
mands from the host to a module in direct mode, whereas the mnemonic format is used for easy usage of
the commands when developing standalone TMCL applications using the TMCL-IDE (IDE means Integrated
Development Environment).
There is also a set of conguration variables for the axis and for global parameters which allow individual
conguration of nearly every function of a module. This manual gives a detailed description of all TMCL
commands and their usage.
2.1 Binary Command Format
Every command has a mnemonic and a binary representation. When commands are sent from a host
to a module, the binary format has to be used. Every command consists of a one-byte command eld, a
one-byte type eld, a one-byte motor/bank eld and a four-byte value eld. So the binary representation
of a command always has seven bytes. When a command is to be sent via RS-232, RS-485, RS-422 or USB
interface, it has to be enclosed by an address byte at the beginning and a checksum byte at the end. In
these cases it consists of nine bytes.
The binary command format with RS-232, RS-485, RS-422 and USB is as follows:
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 7 / 75
TMCL Command Format
Bytes Meaning
1 Module address
1 Command number
1 Type number
1 Motor or Bank number
4 Value (MSB rst!)
1 Checksum
Table 1: TMCL Command Format
Info
The checksum is calculated by accumulating all the other bytes using an 8-bit
addition.
Note
When using the CAN interface, leave out the address byte and the checksum byte.
With CAN, the CAN-ID is used as the module address and the checksum is not
needed because CAN bus uses hardware CRC checking.
2.1.1 Checksum Calculation
As mentioned above, the checksum is calculated by adding up all bytes (including the module address
byte) using 8-bit addition. Here are two examples which show how to do this:
Checksum calculation in C:
unsigned char i , C hec ksu m ;
2unsigned char Command [9];
4// Set the Com mand array to the des ired command
Checksum = Command [0];
6for (i =1; i <8; i ++)
Chec ksu m += C omm an d [ i ];
8
Command [8]= Ch ecksum ; // insert c hecksum as last byte of the command
10 // Now , send it to the module
Checksum calculation in Delphi:
var
2i , C he cks um : byte;
Command: array [0..8] of byte ;
4
// Set the Command array to the desired command
6
// Calculate the Check sum :
8Checksum := Command [0];
for i :=1 to 7do Checksum := Checksu m + Command [i ];
10 Command [8]:= Ch ecksum ;
// Now , send the Comma nd array (9 bytes ) to the module
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 8 / 75
2.2 Reply Format
Every time a command has been sent to a module, the module sends a reply. The reply format with RS-232,
RS-485, RS-422 and USB is as follows:
TMCL Reply Format
Bytes Meaning
1 Reply address
1 Module address
1 Status (e.g. 100 means no error)
1 Command number
4 Value (MSB rst!)
1 Checksum
Table 2: TMCL Reply Format
Info
The checksum is also calculated by adding up all the other bytes using an 8-bit
addition. Do not send the next command before having received the reply!
Note
When using CAN interface, the reply does not contain an address byte and a
checksum byte. With CAN, the CAN-ID is used as the reply address and the
checksum is not needed because the CAN bus uses hardware CRC checking.
2.2.1 Status Codes
The reply contains a status code. The status code can have one of the following values:
TMCL Status Codes
Code Meaning
100 Successfully executed, no error
101 Command loaded into TMCL program EEPROM
1 Wrong checksum
2Invalid command
3 Wrong type
4Invalid value
5 Conguration EEPROM locked
6 Command not available
Table 3: TMCL Status Codes
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 9 / 75
2.3 Standalone Applications
The module is equipped with a TMCL memory for storing TMCL applications. You can use the TMCL-IDE for
developing standalone TMCL applications. You can download a program into the EEPROM and afterwards
it will run on the module. The TMCL-IDE contains an editor and the TMCL assembler where the commands
can be entered using their mnemonic format. They will be assembled automatically into their binary
representations. Afterwards this code can be downloaded into the module to be executed there.
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 10 / 75
2.4 TMCL Command Overview
This sections gives a short overview of all TMCL commands.
Overview of all TMCL Commands
Command Number Parameter Description
ROR 1 <motor number>, <velocity> Rotate right with specied velocity
ROL 2 <motor number>, <velocity> Rotate left with specied velocity
MST 3 <motor number> Stop motor movement
MVP 4
ABS|REL, <motor number>, <posi-
tion|oset>
Move to position (absolute or relative)
SAP 5
<parameter>, <motor number>,
<value>
Set axis parameter (motion control
specic settings)
GAP 6 <parameter>, <motor number>
Get axis parameter (read out motion
control specic settings)
STAP 7
<parameter>, <motor number>,
<value>
Store axis parameter (store motion
control specic settings)
RSAP 8 <parameter>, <motor number>
Restore axis parameter (restore mo-
tion control specic settings)
SGP 9
<parameter>, <bank number>,
<value>
Set global parameter (module specic
settings e.g. communication settings
or TMCL user variables)
GGP 10 <parameter>, <bank number>
Get global parameter (read out mod-
ule specic settings e.g. communica-
tion settings or TMCL user variables)
STGP 11 <parameter>, <bank number>
Store global parameter (TMCL user
variables only)
RSGP 12 <parameter>, <bank number>
Restore global parameter (TMCL user
variables only)
SIO 14
<port number>, <bank number>,
<value>
Set digital output to specied value
GIO 15 <port number>, <bank number> Get value of analog/digital input
CALC 19 <operation>, <value>
Aithmetical operation between accu-
mulator and direct value
COMP 20 <value> Compare accumulator with value
JC 21 <condition>, <jump address> Jump conditional
JA 22 <jump address> Jump absolute
CSUB 23 <subroutine address> Call subroutine
RSUB 24 Return from subroutine
WAIT 27
<condition>, <motor number>,
<ticks>
Wait with further program execution
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 11 / 75
Command Number Parameter Description
STOP 28 Stop program execution
CALCX 33 <operation>
Arithmetical operation between accu-
mulator and X-register
AAP 34 <parameter>, <motor number> Accumulator to axis parameter
AGP 35 <parameter>, <bank number> Accumulator to global parameter
CLE 36 <ag> Clear an error ag
Table 4: Overview of all TMCL Commands
2.5 TMCL Commands by Subject
2.5.1 Motion Commands
These commands control the motion of the motor. They are the most important commands and can be
used in direct mode or in standalone mode.
Motion Commands
Mnemonic Command number Meaning
ROL 2 Rotate left
ROR 1 Rotate right
MVP 4 Move to position
MST 3 Motor stop
Table 5: Motion Commands
2.5.2 Parameter Commands
These commands are used to set, read and store axis parameters or global parameters. Axis parameters
can be set independently for each axis, whereas global parameters control the behavior of the module
itself. These commands can also be used in direct mode and in standalone mode.
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 12 / 75
Parameter Commands
Mnemonic Command number Meaning
SAP 5 Set axis parameter
GAP 6 Get axis parameter
STAP 7 Store axis parameter
RSAP 8 Restore axis parameter
SGP 9 Set global parameter
GGP 10 Get global parameter
STGP 11 Store global parameter
RSGP 12 Restore global parameter
Table 6: Parameter Commands
2.5.3 Branch Commands
These commands are used to control the program ow (loops, conditions, jumps etc.). Using them in direct
mode does not make sense. They are intended for standalone mode only.
Branch Commands
Mnemonic Command number Meaning
JA 22 Jump always
JC 21 Jump conditional
COMP 20 Compare accumulator with constant value
CSUB 23 Call subroutine
RSUB 24 Return from subroutine
WAIT 27 Wait for a specied event
STOP 28 End of a TMCL program
Table 7: Branch Commands
2.5.4 I/O Port Commands
These commands control the external I/O ports and can be used in direct mode as well as in standalone
mode.
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 13 / 75
I/O Port Commands
Mnemonic Command number Meaning
SIO 14 Set output
GIO 15 Get input
Table 8: I/O Port Commands
2.5.5 Calculation Commands
These commands are intended to be used for calculations within TMCL applications. Although they could
also be used in direct mode it does not make much sense to do so.
Calculation Commands
Mnemonic Command number Meaning
CALC 19 Calculate using the accumulator and a constant value
CALCX 33 Calculate using the accumulator and the X register
AAP 34 Copy accumulator to an axis parameter
AGP 35 Copy accumulator to a global parameter
Table 9: Calculation Commands
For calculating purposes there is an accumulator (also called accu or A register) and an X register. When
executed in a TMCL program (in standalone mode), all TMCL commands that read a value store the result
in the accumulator. The X register can be used as an additional memory when doing calculations. It can be
loaded from the accumulator.
When a command that reads a value is executed in direct mode the accumulator will not be aected.
This means that while a TMCL program is running on the module (standalone mode), a host can still
send commands like GAP and GGP to the module (e.g. to query the actual position of the motor) without
aecting the ow of the TMCL program running on the module.
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 14 / 75
2.6 Detailed TMCL Command Descriptions
The module specic commands are explained in more detail on the following pages. They are listed
according to their command number.
2.6.1 ROR (Rotate Right)
The motor is instructed to rotate with a specied velocity in right direction (increasing the position counter).
The velocity is given in microsteps per second (pulse per second [pps]).
Internal function:
First, velocity mode is selected.
Then, the velocity value is transferred to axis parameter #2 (target velocity).
Related commands: ROL, MST, SAP, GAP.
Mnemonic: ROR <axis>,<velocity>
Binary Representation
Instruction Type Motor/Bank Value
1 0 0 -2147483648. . . 2147583647
Reply in Direct Mode
Status Value
100 - OK dont care
Example
Rotate right motor 0, velocity 500.
Mnemonic: ROR 0, 500.
Binary Form of ROR 0, 51200
Field Value
Target address 01h
Instruction number 01h
Type 00h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 00h
Value (Byte 1) C8h
Value (Byte 0) 00h
Checksum CAh
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 15 / 75
2.6.2 ROL (Rotate Left)
The motor is instructed to rotate with a specied velocity in left direction (decreasing the position counter).
The velocity is given in microsteps per second (pulse per second [pps]).
Internal function:
First, velocity mode is selected.
Then, the velocity value is transferred to axis parameter #2 (target velocity).
Related commands: ROR, MST, SAP, GAP.
Mnemonic: ROL <axis>,<velocity>
Binary Representation
Instruction Type Motor/Bank Value
2 0 0 -2147483648. . . 2147583647
Reply in Direct Mode
Status Value
100 - OK dont care
Example
Rotate left motor 0, velocity 500.
Mnemonic: ROL 0, 500.
Binary Form of ROL 0, 51200
Field Value
Target address 01h
Instruction number 02h
Type 00h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 00h
Value (Byte 1) C8h
Value (Byte 0) 00h
Checksum CBh
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 16 / 75
2.6.3 MST (Motor Stop)
The motor is instructed to stop with a soft stop.
Internal function:
The velocity mode is selected. Then, the target speed (axis parameter #0) is set to zero.
Related commands: ROR, ROL, SAP, GAP.
Mnemonic: MST <axis>
Binary Representation
Instruction Type Motor/Bank Value
3 0 0 0
Reply in Direct Mode
Status Value
100 - OK dont care
Example
Stop motor 0.
Mnemonic: MST 0.
Binary Form of MST 0
Field Value
Target address 01h
Instruction number 03h
Type 00h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 00h
Value (Byte 1) 00h
Value (Byte 0) 00h
Checksum 04h
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 17 / 75
2.6.4 MVP (Move to Position)
With this command the motor will be instructed to move to a specied relative or absolute position. It
will use the acceleration/deceleration ramp and the positioning speed programmed into the unit. This
command is non-blocking - that is, a reply will be sent immediately after command interpretation and
initialization of the motion controller. Further commands may follow without waiting for the motor
reaching its end position. The maximum velocity and acceleration as well as other ramp parameters are
dened by the appropriate axis parameters. For a list of these parameters please refer to section 3.
The range of the MVP command is 32 bit signed (-2147483648. . . 2147483647). Positioning can be inter-
rupted using MST, ROL or ROR commands.
Three operation types are available:
Moving to an absolute position in the range from -2147483648. . . 2147483647 (231...231 1).
Starting a relative movement by means of an oset to the actual position. In this case, the new
resulting position value must not exceed the above mentioned limits, too.
Note
The distance between the actual position and the new position must not be more
than 2147483647 (2
31
1) position steps . Otherwise the motor will run in the
opposite direction in order to take the shorter distance (caused by 32 bit overow).
Internal function: A new position value is transferred to the axis parameter #0 (target position).
Related commands: SAP, GAP, MST.
Mnemonic: MVP <ABS|REL>,<axis>,<position|oset>
Binary Representation
Instruction Type Motor/Bank Value
40ABS absolute 0 <position>
1REL relative 0 <oset>
Reply in Direct Mode
Status Value
100 - OK dont care
Example
Move motor 0 to position 90000.
Mnemonic: MVP ABS, 0, 90000
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 18 / 75
Binary Form of MVP ABS, 0, 90000
Field Value
Target address 01h
Instruction number 04h
Type 00h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 01h
Value (Byte 1) 5Fh
Value (Byte 0) 90h
Checksum F5h
Example
Move motor 0 from current position 10000 steps backward.
Mnemonic: MVP REL, 0, -10000
Binary Form of MVP REL, 0, -10000
Field Value
Target address 01h
Instruction number 04h
Type 01h
Motor/Bank 00h
Value (Byte 3) FFh
Value (Byte 2) FFh
Value (Byte 1) D8h
Value (Byte 0) F0h
Checksum CCh
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 19 / 75
2.6.5 SAP (Set Axis Parameter)
With this command most of the motion control parameters of the module can be specied. The settings
will be stored in SRAM and therefore are volatile. That is, information will be lost after power o.
Info
For a table with parameters and values which can be used together with this
command please refer to section 3.
Internal function:
The specied value is written to the axis parameter specied by the parameter number.
Related commands: GAP, AAP.
Mnemonic: SAP <parameter number>, <axis>, <value>
Binary representation
Binary Representation
Instruction Type Motor/Bank Value
5 see chapter 30 <value>
Reply in Direct Mode
Status Value
100 - OK dont care
Example Set the maximum positioning speed for motor 0 to 51200 pps.
Mnemonic: SAP 4, 0, 51200.
Binary Form of SAP 4, 0, 51200
Field Value
Target address 01h
Instruction number 05h
Type 04h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 00h
Value (Byte 1) C8h
Value (Byte 0) 00h
Checksum D2h
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
TMCM-1636 TMCLFirmware Manual Firmware Version V1.09 | Document Revision V1.01 2020-JUN-09 20 / 75
2.6.6 GAP (Get Axis Parameter)
Most motion / driver related parameters of the TMCM-1636 can be adjusted using e.g. the SAP command.
With the GAP parameter they can be read out. In standalone mode the requested value is also transferred
to the accumulator register for further processing purposes (such as conditional jumps). In direct mode
the value read is only output in the value eld of the reply, without aecting the accumulator.
Info
For a table with parameters and values that can be used together with this
command please refer to section 3.
Internal function: The specied value gets copied to the accumulator.
Related commands: SAP, AAP.
Mnemonic: GAP <parameter number>, <axis>
Binary Representation
Instruction Type Motor/Bank Value
6 see chapter 30 <value>
Reply in Direct Mode
Status Value
100 - OK value read by this command
Example
Get the actual position of motor 0.
Mnemonic: GAP 1, 0.
Binary Form of GAP 1, 0
Field Value
Target address 01h
Instruction number 06h
Type 01h
Motor/Bank 00h
Value (Byte 3) 00h
Value (Byte 2) 00h
Value (Byte 1) 00h
Value (Byte 0) 00h
Checksum 08h
©2020 TRINAMIC Motion Control GmbH & Co. KG, Hamburg, Germany
Terms of delivery and rights to technical change reserved.
Download newest version at www.trinamic.com
/