CANopen Implementation Guide
CANopen Implementation Guide
Guide V1.0
CANOpen Implementation Guide Manual Pag. 2
1 Index
1 Index................................................................................................................. 2
2 Introduction ........................................................................................................ 7
2.1 Scope ........................................................................................................... 7
2.2 CANopen....................................................................................................... 7
2.3 Cabling and pin assignment ............................................................................. 8
2.4 Cabling Hints ................................................................................................. 8
3 CANopen Basics................................................................................................... 9
3.1 Physical Layer ................................................................................................ 9
3.2 Client - Server relations ................................................................................ 10
3.3 Object Dictionary ......................................................................................... 11
3.4 Communication Objects ................................................................................. 11
3.5 Object Dictionary data types .......................................................................... 12
3.6 The Object Dictionary ................................................................................... 13
3.7 Service data Objects SDO .............................................................................. 15
3.8 Initiate SDO Download Protocol ...................................................................... 15
3.9 Download SDO Segment Protocol .................................................................... 17
3.10 Initiate SDO Upload Protocol ....................................................................... 18
3.11 Upload SDO Segment Protocol ..................................................................... 19
3.12 Abort SDO Transfer Protocol ........................................................................ 20
3.13 Example using SDO expedited Transfer ......................................................... 22
3.14 Process data Objects PDO ........................................................................... 24
3.15 Emergency Object (EMCY) .......................................................................... 25
3.16 Emergency object data ............................................................................... 25
3.17 Synchronization Object (SYNC) .................................................................... 26
3.18 Network Management (NMT) ....................................................................... 26
3.19 The Bootup protocol ................................................................................... 28
4 Communication Profile ........................................................................................ 28
4.1 Object 1000h – Device Type .......................................................................... 28
4.2 Object 1001h – Error Register ........................................................................ 29
CANOpen Implementation Guide Manual Pag. 3
Notice:
• This guide is delivered subject to the following conditions and restrictions: This guide contains
proprietary information belonging to Motor power Company Srl. Such information is supplied solely
for the purpose of assisting users of the MPC Devices and Servo drive in its installation and
configuration.
• The text and graphics included in this manual are for the purpose of illustration and reference only.
The specifications on which they are based are subject to change without notice.
• Motor power Company and the Motor power Company logo are trademarks of Motor power
Company Srl.
• Information in this document is subject to change without notice.
2 Introduction
2.1 Scope
This manual describes, in detail, the CANOpen implementation of Motor Power Company
Devices.
2.2 CANopen
CiA Draft Standard 201...207: In these standards the general network administration and
the transfer of objects are determined. This book is rather comprehensive. The relevant aspects
are treated in the CANopen manual in hand so that it is not necessary in general to acquire the
DS201..207.
CiA Draft Standard 301: In this standard the basic structure of the object dictionary of a
CANopen device and the access to this directory are described. Besides this the statements
made in the DS201..207 are described in detail. The elements needed for the the object
directory and the access methods which belong to them are described in the present manual.
It is advisable to acquire the DS301 but not necessary.
CiA Draft Standard 402: This standard describes the concrete implementation of CANopen in
servo controllers. Though all implemented objects are also briefly documented and described
in this CANopen manual the user should own this book.
CANOpen Implementation Guide Manual Pag. 8
Follow the installation Guide of each device to find out the correct pinout
configuration.
Please carefully respect the following information and notes for the
cabling of the controller to get a stable and undisturbed communication
system. A non-professional cabling can cause malfunctions of the CAN
bus which hence the controller to shut down with an error.
The CAN bus offers an easy and safe way to connect all parts of a plant. As condition all
following instructions must be respected carefully.
✗ All nodes of a network are principally connected in series, so that the CAN cable is looped
through all controllers.
✗ The two ends of the CAN cable must be terminated by a resistor of 120Ω +/- 5%. Please
note that such a resistor is often already installed in CAN cards or the PLC.
✗ For cabling shielded cable with exactly two twisted pairs must be used.
➔ One twisted pair is used for CAN-H and CAN-L.
CANOpen Implementation Guide Manual Pag. 9
3 CANopen Basics
This chapter describes — in general — the CANopen communication features most relevant to
Motor Power Company Devices. More detailed information is available in the specific CANopen
documentation.
CAN is a serial communication standard in which the transferred data is coded as electrical
pulses on a two-wire communication line. The device that handles the CAN physical layer is
CANOpen Implementation Guide Manual Pag. 10
called the CAN controller. The device that transmits data over the CAN lines is called the CAN
transceiver.
For all the information regarding the connection, please check the Device Installation Guide
Manual.
A CAN master (or client) is a controller that makes requests to nodes to respond to its
commands. A CAN slave (or server) responds to the commands issued by the CAN master. The
CAN protocol permits both single-master and multiple-master networks.
The Device assume a single-master network arrangement, in which the devices are the slaves
and the machine controller or PLC is the master.
Every servo drive has a unique ID in the range [1…127]. The network master does not require
an ID. As slave, the device never sends an unrequested message, other than emergencies. The
drive responds only to messages addressed to its ID or to broadcast messages, which have an
ID of 0. All messages sent by a servo drive are marked with its own ID.
If two servo drives have been assigned the same ID, the CAN network
may crash.
CANOpen Implementation Guide Manual Pag. 11
An object dictionary (OD) is a naming system that gives a unique identifier to each data item
— or “object” —that is communicated over the CAN bus. An object is identified by an index
and, if it is a complex object, also by a sub-index. A CANopen client can manipulate an object
of a CANopen server by referring to its identifier, according to the access permission of the
object. (An object’s access permission may be read-only, write-only, or read-write.)
CiA DS 301 requires a set of mandatory objects for all CANopen devices. Other OD items are
predefined by CiA DS 301 to have fixed identifiers, if supported. The OD also accommodates
manufacturer-specific objects.
The data-byte units transported through a CAN network are called communication objects
(COBs). The Device uses the following COB types:
The type of COB transmitted is indicated in the arbitration field of the message, and thereby
determines its priority. The relation between bits 8 to 11 of the arbitration field (COB-ID) and
the COB type is presented in the following table:
Data Objects 0002 to 0004 are used as map able “dummy” entries.
The most important part of a device profile is the Object Dictionary description. The Object
Dictionary is essentially a grouping of objects accessible via the network in an ordered pre-
defined fashion. Each object within the dictionary is addressed using a 16-bit index.
The overall layout of the standard Object Dictionary is shown below. This layout closely
conforms with other industrial serial bus system concepts:
The Object Dictionary may contain a maximum of 65536 entries which are addressed through
a 16-bit index.
CANOpen Implementation Guide Manual Pag. 15
Motor Power Company Devices use a single transmit server SDO (COB 581h-6ffh) and a single
receive server SDO (COB601h-67fh). This is according to CiA definitions and priority allocations
for 11-bit addressing.
For example, if an SDO is used to change a PDO mapping, the SDO should be issued only after
the last session in which the PDO is completed, and the newly-mapped PDO should not be used
until the SDO mapping change is confirmed.
This protocol is used to implement the Initiate SDO Download service for SDOs.
Client to server:
Server to client:
Where:
CANOpen Implementation Guide Manual Pag. 16
e Transfer type
0: Normal transfer
1: Expedited transfer
s Size indicator
d Data
Client to server:
Byte 0 Byte 1 – 7
7..5 4 3..1 0 -
css=0 t n c Segment - data
Server to client:
Byte 0 Byte 1 – 7
7..5 4 3..0 -
css=1 t x reserved
Where:
t: toggle bit. This bit must alternate for each subsequent segment that is
downloaded. The firstnsegment will have the toggle-bit set to 0. The
toggle bit will be equal for the request and the response message.
x: not used, always 0
CANOpen Implementation Guide Manual Pag. 18
Client to server:
Server to client:
Where:
e: transfer type
0: normal transfer
1: expedited transfer
s: size indicator
0: data set size is not indicated
1: data set size is indicated
d: data
e = 0, s = 0: d is reserved for further use.
e = 0, s = 1: d contains the number of bytes to be uploaded.
Byte 4 contains the lsb and byte 7 contains the msb.
e = 1, s = 1: d contains the data of length 4-n to be uploaded,
the encoding depends on the type of the data referenced by index and
sub-index e = 1, s = 0: d contains unspecified number of bytes to be
uploaded.
x: not used, always 0
Client to server:
Byte 0 Byte 1 – 7
7..5 4 3..0 -
css=2 t x reserved
Server to client:
Byte 0 Byte 1 – 7
7..5 4 3..1 0 -
css=0 t n c Segment - data
Where:
t: toggle bit. This bit must alternate for each subsequent segment that is
uploaded. The first segment will have the toggle-bit set to 0. The toggle
bit will be equal for the request and the response message.
Client to server:
Where:
d: contains a 4 byte abort code about the reason for the abort.
CANOpen Implementation Guide Manual Pag. 21
Here below some sample for reading and writing different objects:
UINT8/INT8
UINT16/INT16
UINT32/INT32
Process Data Objects (PDOs) are suitable to transmit data event-controlled, whereat
the PDO contains one or more predefined parameters. In contrast to SDOs no hand-
shake is used. So the receiver has to be able to handle an arriving PDO at any time. In
most cases this requires a great deal of software in the host computer. This
disadvantage is in contrast to the advantage that the host computer does not need
cyclically inquiry of the objects embedded in a PDO, which means a strong reduction of
bus load.
Emergency objects are triggered by the occurrence of a device internal error situation
and are transmitted from an emergency producer on the device. Emergency objects
are suitable for interrupt type error alerts. An emergency object is transmitted only
once per 'error event'. As long as no new errors occur on a device no further emergency
objects must be transmitted.
The emergency object may be received by zero or more emergency consumers. The
reaction on the emergency consumer(s) is not specified and does not fall in the scope
of this document.
By means of this specification emergency error codes and the error register are
specified.
The Emergency Telegram consists of 8 bytes with the data as shown below.
CANOpen Implementation Guide Manual Pag. 26
COB-ID=0080h NO DATA
NMT commands are used to control the communication state of the servo drive and to
broadcast manufacturer messages to all other connected servo drives.
The NMT message contains only 2 data byte, with the following format:
The following network communication states are supported, with the following
communication type.
Here below we can find the NMT state machine with all the allowed transitions.
The transition (2) from Initialization state to Pre-Operational state is done automatically
by the servo.
This protocol is used to signal that an NMT slave has entered the pre-operational node
state after the initializing state. The protocol uses the same identifier as the error
control protocols.
COB-ID=1792+node-id 0
4 Communication Profile
This chapter define all the Device object available in the communication profile area of
the Object Dictionary.
This object contains information about the device type and functionality. It is comprised
of a 16-bit field that describes the device profile used, and a second 16-bit field that
gives additional information about optional functionality of the device.
MSB LSB
BYTE 4 BYTE 3 BYTE 2 BYTE 1
Additional Information Device profile Number
Object Description:
CANOpen Implementation Guide Manual Pag. 29
Index 1000h
Name Device type
Object code VAR
Data Type UNSIGNED32
Category Mandatory
Entry Description:
Object Description:
Index 1001h
Name Error Register
Object code VAR
Data Type UNSIGNED8
Category Mandatory
Entry Description:
Data description:
CANOpen Implementation Guide Manual Pag. 30
bit Meaning
0 Generic Error
1 Current
2 Voltage
3 Temperature
4 Communication Error
5 Device Profile Specific
6 Reserved
7 Manufacturer Specific
The object at index 1003h holds the errors that have occurred on the device and have
been signaled via the Emergency Object. In doing so it provides an error history.
1. The entry at sub-index 0 contains the number of actual errors that are recorded
in the array starting at sub-index 1.
2. Every new error is stored at sub-index 1, the older ones move down the list.
3. Writing a „0“ to sub-index 0 deletes the entire error history (empties the array).
4. The error numbers are of type UNSIGNED32 and are composed of a 16 bit error
code and a 16 bit additional error information field which is manufacturer specific.
The error code is contained in the lower 2 bytes (LSB) and the additional
information is included in the upper 2 bytes (MSB). The Error list contain 8
elements.
MSB LSB
BYTE 4 BYTE 3 BYTE 2 BYTE 1
Additional Information Error Code
Object Description:
Index 1003h
Name Pre-defined error field
Object code ARRAY
CANOpen Implementation Guide Manual Pag. 31
Entry Description:
Sub-Index 0
Description Number of actual error
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x0
Sub-Index 01 - 08
Description Standard Error Field
Entry Category Mandatory
Access Read
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x0
MSB LSB
31 30 29 28-11 10-0
x 0 0 0 11-bit identifier
Object Description:
Index 1005h
Name COB-ID SYNC message
CANOpen Implementation Guide Manual Pag. 32
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x80
This object defines the communication cycle period in µs. This period defines the SYNC
interval. It is 0 if not used. If the communication cycle period on sync producer is
changed to a new value unequal 0 the transmission of sync object resumes within 1
sync cycle of the new value.
Object Description:
Index 1006h
Name Communication Cycle Period
Object code VAR
Data Type UNSIGNED32
Category Conditional; Mandatory for sync
producers
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x0
CANOpen Implementation Guide Manual Pag. 33
Contains the length of the time window for synchronous PDOs in ms. It is 0 if not used.
Object Description:
Index 1007h
Name Communication Cycle Period
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x0
Object Description:
Index 1008h
Name Manufacturer Device Name
Object code VAR
Data Type Visible String
Category Optional
Entry Description:
Default Value -
Object Description:
Index 1009h
Name Manufacturer Hardware Version
Object code VAR
Data Type Visible String
Category Optional
Entry Description:
Object Description:
Index 1008h
Name Manufacturer Software Version
Object code VAR
Data Type Visible String
Category Optional
Entry Description:
CANOpen Implementation Guide Manual Pag. 35
This object is used to save parameters in non-volatile memory. Through read access,
the drive provides information about its save capabilities, using:
(a) ƒSub-index 0: Largest supported sub-index
(b) Sub-index 1: Save all parameters
In order to avoid accidental storage, storage is only executed when a specific signature
“save” is written to the appropriate sub-index.
MSB LSB
BYTE 4 BYTE 3 BYTE 2 BYTE 1
“e” “v” “a” “s”
65h 76h 61h 73h
Object Description:
Index 1010h
Name Save parameters
Object code ARRAY
Data Type UNSIGNED32
Category Optional
Entry Description:
Sub-Index 0
Description largest sub-index supported
Entry Category Mandatory
Access Read Only
CANOpen Implementation Guide Manual Pag. 36
PDO Mapping NO
Value Range UNSIGNED32
Default Value 1
Sub-Index 1
Description Save all parameters
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value -
This object is used to restore parameters from non-volatile memory. Through read
access, the drive provides information about its restore capabilities, using:
(a) ƒSub-index 0: Largest supported sub-index
(b) ƒSub-index 1: Restore all parameters
In order to avoid accidental storage, restore is only executed when a specific signature
“load” is written to the appropriate sub-index.
MSB LSB
BYTE 4 BYTE 3 BYTE 2 BYTE 1
“d” “a” “o” “l”
64h 61h 6Fh 6Ch
UNSIGNED32
CANOpen Implementation Guide Manual Pag. 37
MSB LSB
31 30 29 28-11 10-0
Reserved (=0) 0 0 11-bit identifier
Object Description:
Index 1014h
Name COB-ID Emergency Object
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x08+Node-ID
The inhibit time for the EMCY message can be adjusted via this entry. The time has to
be a multiple of 100µs.
Object Description:
Index 1014h
Name Inhibit Time EMCY
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
CANOpen Implementation Guide Manual Pag. 38
PDO Mapping NO
Value Range UNSIGNED16
Default Value 0x00
The consumer heartbeat time defines the expected heartbeat cycle time and thus has
to be higher than the corresponding producer heartbeat time configured on the device
producing this heartbeat.
Monitoring starts after the reception of the first heartbeat. If the consumer heartbeat
time is 0 the corresponding entry is not used. The time has to be a multiple of 1ms.
UNSIGNED32
MSB
LSB
bits 31-24 23-16 15-0
value reserved (value: 00h) Node-ID heartbeat time
encoded as - UNSIGNED8 UNSIGNED16
Object Description:
Index 1016h
Name Consumer Heartbeat Time
Object code ARRAY
Data Type UNSIGNED32
Category Optional
Entry Description:
Sub-Index 0
Description number entries
Entry Category Mandatory
CANOpen Implementation Guide Manual Pag. 39
Sub-Index 1
Description Consumer Heartbeat Time
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0
The producer hartbeat time defines the cycle time of the heartbeat. The producer
heartbeat time is 0 if it not used. The time has to be a multiple of 1ms.
Object Description:
Index 1017h
Name Producer Heartbeat Time
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED16
Default Value 0x00
The object at index 1018h contains general information about the device.
The Vendor ID (sub-index 1h) contains a unique value allocated to each manufacturer.
The manufacturer-specific Product code (sub-index 2h) identifies a specific device
version.
The manufacturer-specific Revision number (sub-index 3h) consists of a major revision
number and a minor revision number. The major revision number identifies a specific
CANopen behavior. If the CANopen functionality is expanded, the major revision has to
be incremented. The minor revision number identifies different versions with the same
CANopen behavior.
Object Description:
Index 1018h
Name Identity Object
Object code ARRAY
Data Type Identity
Category Optional
Entry Description:
Sub-Index 0
Description number entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0x4
Sub-Index 1
Description Vendor ID
Entry Category Mandatory
Access Read Only
CANOpen Implementation Guide Manual Pag. 41
PDO Mapping NO
Value Range UNSIGNED32
Default Value -
Sub-Index 2
Description Product code
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED32
Default Value -
Sub-Index 3
Description Revision Number
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED32
Default Value -
Sub-Index 4
Description Serial Number
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED32
Default Value -
This object reports the CAN communication state after a heartbeat failure. The value of
the object asserts that after such a failure, the CAN communication state is:
CANOpen Implementation Guide Manual Pag. 42
Object Description:
Index 1029h
Name Error behavior
Object code ARRAY
Data Type UNSIGNED8
Category Optional
Entry Description:
Sub-Index 0
Description Number of error classes
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0x1
Sub-Index 1
Description Communication error
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED8
Default Value 1
This object is used to describe the SDO used on a device. The data type has the index
22h in the object dictionary. The number of supported entries in the SDO object record
is specified by sub-index 0h. The values at 1h and 2h specify the COB-ID for this SDO.
Sub-index 3 gives the server of the SDO if the record describes an SDO for which the
device is a client, and it gives the client of the SDO if the record describes an SDO for
which the device is the server. The structure of the SDO COB-ID entry is as follows:
MSB LSB
bits 31 30 29 28-11 10-0
11-bit ID 0/1 0 0 0 11-bit identifier
Object Description:
Index 1200h
Name Server SDO Parameter
Object code RECORD
Data Type SDO Parameter
Category Optional
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED8
CANOpen Implementation Guide Manual Pag. 44
Sub-Index 1
Description COB-ID Client->Server (rx)
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 601h…67Fh
Default Value 600h+Node-ID
Sub-Index 2
Description COB-ID Server -> Client (tx)
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 581h … 5FFh
Default Value 580h+Node-ID
Contains the communication parameters for the PDOs the device is able to receive.
MSB LSB
bits 31 30 29 28-11 10-0
11-bit ID 0/1 0 0 0 11-bit identifier
Synchronous (transmission types 0-240 and 252) means that the transmission of the
PDO shall be related to the SYNC object as described in 9.3. Preferably the devices use
the SYNC as a trigger to output or actuate based on the previous synchronous Receive
PDO respectively to update the data transmitted at the following synchronous Transmit
PDO. Details of this mechanism depend on the device type and are defined in the device
profile if applicable.
Asynchronous means that the transmission of the PDO is not related to the SYNC object.
A transmission type of zero means that the message shall be transmitted synchronously
with the SYNC object but not periodically.
A value between 1 and 240 means that the PDO is transferred synchronously and
cyclically, the transmission type indicating the number of SYNC which are necessary to
trigger PDO transmissions/receptions.
Object Description:
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0x2
Sub-Index 1
Description COB-ID used by PDO
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value Index 1400h: 200h+NODE-ID
Index 1401h: 300h+NODE-ID
Index 1402h: 400h+NODE-ID
Index 1403h: 500h+NODE-ID
Sub-Index 2
Description transmission type
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0
CANOpen Implementation Guide Manual Pag. 47
Contains the mapping for the PDOs the device is able to receive. The sub-index 0h
contains the number of valid entries within the mapping record. This number of entries
is also the number of the application variables which shall be transmitted/received with
the corresponding PDO. The sub-indices from 1h to number of entries contain the
information about the mapped application variables. These entries describe the PDO
contents by their index, sub-index and length. All three values are hexadecimal coded.
The length entry contains the length of the object in bit (1..8h). This parameter can be
used to verify the overall mapping length. It is mandatory.
If the change of the PDO mapping cannot be executed (e.g. the PDO length is exceeded
or the SDO client attempts to map an object that cannot be mapped) the device
responds with an Abort SDO Transfer Service.
Sub-index 0 determines the valid number of objects that have been mapped. For
changing the PDO mapping first sub-index 0 must be set to 0 (mapping is deactivated).
Then the objects can be remapped. When a new object is mapped by writing a sub-
index between 1 and 8, the device may check whether the object specified by index
/sub-index exists. If the object does not exist or the object cannot be mapped, the SDO
transfer must be aborted with the Abort SDO Transfer Service with one of the abort
codes 0602 0000h or 0604 0041h.
After all objects are mapped sub-index 0 is set to the valid number of mapped objects.
When sub-index 0 is set to a value >0 the device may validate the new PDO mapping
before transmitting the response of the SDO service. If an error is detected the device
has to transmit the Abort SDO Transfer Service with one of the abort codes 0602 0000h,
0604 0041h or 0604 0042h.
A device that supports dynamic mapping of PDOs must support this during the state
PRE-OPERATIONAL state. If dynamic mapping during the state OPERATIONAL is
supported, the SDO client is responsible for data consistency.
Object Description:
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range 0 deactivated ; 1-8 activated
Default Value 0
Sub-Index N (1-8)
Description PDO mapping for the nth
Entry Category Conditional
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0
Contains the communication parameters for the PDOs the device is able to transmit.
The type of the PDO communication parameter (20h). A detailed description of the
entries is done in the section for the Receive PDO Communication Parameter (1400h –
1403h).
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0x2
Sub-Index 1
Description COB-ID used by PDO
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value Index 1800h: 180h+NODE-ID
Index 1801h: 280h+NODE-ID
Index 1802h: 380h+NODE-ID
Index 1803h: 480h+NODE-ID
Sub-Index 2
Description transmission type
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0
Sub-Index 3
Description inhibit time
Entry Category Optional
Access Read/Write
CANOpen Implementation Guide Manual Pag. 50
PDO Mapping NO
Value Range UNSIGNED16
Default Value 0
Sub-Index 4
Description reserved
Entry Category optional
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED8
Default Value 0
Sub-Index 5
Description Event timer
Entry Category Optional
Access Read/Write
PDO Mapping NO
Value Range 0 not used - UNSIGNED16
Default Value 0
Contains the mapping for the PDOs the device is able to transmit. The type of the PDO
mapping parameter (21h). A detailed description of the entries is done in the section
for the Receive PDO Mapping Parameter (1600h – 1603h).
Object Description:
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range 0 deactivated ; 1-8 activated
Default Value 0
Sub-Index N (1-8)
Description PDO mapping for the nth
Entry Category Conditional
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED32
Default Value 0
CANOpen Implementation Guide Manual Pag. 52
5 Manufacturer-specific Objects
Object Description:
Index 2100h
Name Manufacturer specific error register
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Object Description:
Index 2F80h
Name Boot NMT Status
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping NO
Value Range -
Default Value 0
Value Description
0x00 Pre-operational
0x04 Operational
For compatibility reasons it is possible to use this mask to hide the Manufacturer specific
bit of the Status word. The mask affects all status word, please change only the 2 most
significative bits if needed.
Object Description:
Index 2F81h
Name Status word masking
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
CANOpen Implementation Guide Manual Pag. 54
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED16
Default Value 65535
CANOpen Implementation Guide Manual Pag. 55
6 Device Control
The device control function block controls all functions of the drive (drive function and
power section).
It is divided into:
● device control of the state machine
● operation mode function
The Device is always in remote mode, thus the relative bit in the status word is always
set to 1.
The state machine describes the device status and the possible control sequence of the
drive. A single state represents a special internal or external behavior. The state of the
drive also determines which commands are accepted. E.g. it is only possible to start a
point-to-point move when the drive is in state OPERATION ENABLE.
States may be changed using the controlword and/or according to internal events. The
current state can be read using the statusword.
CANOpen Implementation Guide Manual Pag. 57
The state machine describes the state machine of the device with respect to control of
the power electronics because of user commands and internal drive faults.
CANOpen Implementation Guide Manual Pag. 58
State transitions are caused by internal events in the drive or by commands from the
host via the controlword.
Object Description:
Index 6040h
CANOpen Implementation Guide Manual Pag. 62
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value -
O – Optional
M – Mandatory
Device control commands are triggered by the following bit patterns in the controlword:
Operation mode
Bit Velocity Profile Profile Profile Homing Interpolation
mode position mode velocity mode torque mode mode position mode
Homing
4 rfg enable New set-point Reserved Reserved operation Enable ip mode
start
Change set
5 rfg unlock Reserved Reserved Reserved Reserved
immediately
6 rfg use ref abs/rel Reserved Reserved Reserved Reserved
8 Halt Halt Halt Halt Halt Halt
Bits: 9,10:
These bits are reserved for further use. They are inactive by setting to zero. If they
have no special function, they must be set to zero.
The statusword indicates the current state of the drive. No bits are latched. The
statusword consist of bits for:
• the current state of the drive,
CANOpen Implementation Guide Manual Pag. 64
Object Description:
Index 6041h
Name Status word
Object code VAR
Data Type UNSIGNED16
Category Mandatory
Entry Description:
14 MS – not used O
15 MS – Homing reached O
Bit 7: WARNING
A drive warning is present if bit 7 is set. The cause means no error but a state that has
to be mentioned, e.g. temperature limit, job refused. The status of the drive does not
change. The cause of this warning may be found by reading the fault code parameter.
The bit is set and reset by the device.
Bit 9: REMOTE
Always set to 1.
CANOpen Implementation Guide Manual Pag. 66
Operation mode
Bit
vl pp pv tq hm ip
Set point Homing Ip mode
12 reserved Speed reserved
acknowledge attained active
Following Following Homing
13 reserved reserved reserved
error error error
The parameter modes of operation switches the actually chosen operation mode.
Object Description:
Index 6060h
Name Modes of operation
Object code VAR
CANOpen Implementation Guide Manual Pag. 67
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER8
Default Value -
Value Description
-4 Tuning Current Mode
0 Reserved
1 Profile Position Mode
3 Profile Velocity Mode
4 Torque Profile Mode
5 Reserved
6 Homing Mode
7 Interpolated Position Mode
Note:
A read of modes of operation shows only the value of modes of operation. The actual
mode of the drive is reflected in the object modes of operation display. It may be
changed by writing to modes of operation.
The modes of operation display show the current mode of operation. The meaning of
the returned value corresponds to that of the modes of operation option code (index
6060h).
Object Description:
CANOpen Implementation Guide Manual Pag. 68
Index 6061h
Name Modes of operation display
Object code VAR
Data Type INTEGER8
Category Mandatory
Entry Description:
This chapter describes how to set a point-to-point (PTP) movement under a profiled
position where a target position is applied to the trajectory generator. It generates a
position demand value to the control loop. The trajectory generator input includes
profiled velocity, acceleration, deceleration, and selection of motion type, motion
polarity and stopping option. The inputs to the trajectory are given in user units and
are limited before being normalized to internal increments.
7.2 Objects
The target position is the position that the drive should move to in position profile mode
using the current settings of motion control parameters such as velocity, acceleration,
deceleration, motion profile type etc. The target position is given in user defined
position units. It is converted to position increments using the position factor. The target
position will be interpreted as absolute or relative depending on the ‘abs / rel' flag in
the control word.
Object Description:
Index 607Ah
Name Target position
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
CANOpen Implementation Guide Manual Pag. 70
Position range limit contains two sub-parameters, min position range limit and max
position range limit. These limit the numerical range of the input value. On reaching or
exceeding these limits, the input value automatically wraps to the other end of the
range. Wrap-around of the input value can be prevented by setting software position
limits.
Object Description:
Index 607Bh
Name Position range limit
Object code ARRAY
Data Type INTEGER32
Category Mandatory
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 2
Default Value 2
Sub-Index 1
Description Min position range limit
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range INTEGER32
Default Value -231
CANOpen Implementation Guide Manual Pag. 71
Sub-Index 2
Description Max position range limit
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range INTEGER32
Default Value 231-1
Software position limit contains the sub-parameters min position limit and max position
limit. These parameters define the absolute position limits for the position demand
value and the position actual value. Every new target position must be checked against
these limits. The limit positions are specified in position units (same as target position)
and are always relative to the machine home position.
Object Description:
Index 607Dh
Name Software position limit
Object code ARRAY
Data Type INTEGER32
Category Mandatory
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 2
Default Value 2
Sub-Index 1
CANOpen Implementation Guide Manual Pag. 72
Sub-Index 2
Description Max position limit
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range INTEGER32
Default Value 231-1
The profile velocity is the velocity normally attained at the end of the acceleration ramp
during a profiled move and is valid for both directions of motion. The profile velocity is
given in user defined speed units. It is converted to position increments per second
using the velocity encoder factor.
Object Description:
Index 6081h
Name Profile velocity
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
CANOpen Implementation Guide Manual Pag. 73
Object Description:
Index 6083h
Name Profile acceleration
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
The profile deceleration is given in the same units as profile acceleration. If this
parameter is not supported, then the profile acceleration value is also used for
deceleration.
Object Description:
Index 6084h
Name Profile deceleration
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
CANOpen Implementation Guide Manual Pag. 74
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
The quick stop deceleration is the deceleration used to stop the motor if the ‘Quick Stop’
command is given. The quick stop deceleration is given in the same units as the profile
acceleration.
Object Description:
Index 6085h
Name Quick stop deceleration
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
The motion profile type is used to select the type of motion profile used to perform a
profiled move.
Object Description:
CANOpen Implementation Guide Manual Pag. 75
Index 6086h
Name Motion profile type
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
Value Description
-32768 -1 Manufacturer specific
0 Linear ramp (trapezoidal profile)
1 Not used
2 Not used
3 Not used
4 .. 32767 reserved
• Functional Description
Two different ways to apply target positions to a drive, are supported by this device
profile.
➢ Set of set-points:
After reaching the target position the drive unit immediately processes the next target
position which results in a move where the velocity of the drive normally is not reduced
to zero after achieving a set-point.
➢ Single set-point:
After reaching the target position the drive unit signals this status to a host computer
and then receives a new set-point. After reaching a target position the velocity normally
is reduced to zero before starting a move to the next set-point.
CANOpen Implementation Guide Manual Pag. 76
The two modes are controlled by the timing of the bits ‘new set-point’ and ‘change set
immediately’ in the controlword and ‘set-point acknowledge’ in the statusword. These
bits allow to set up a request-response mechanism in order to prepare a set of set-
points while another set still is processed in the drive unit. This minimizes reaction
times within a control program on a host computer.
CANOpen Implementation Guide Manual Pag. 77
8 Homing Mode
This chapter describes the method by which a drive seeks the home position (also called,
the datum, reference point or zero point). There are various methods of achieving this
using limit switches at the ends of travel or a home switch (zero point switch) in mid-
travel, most of the methods also use the index (zero) pulse train from an incremental
encoder.
The home offset object is the difference between the zero position for the application
and the machine home position (found during homing), it is measured in position units.
During homing the machine home position is found and once the homing is completed
the zero position is offset from the home position by adding the home offset to the
home position. All subsequent absolute moves shall be taken relative to this new zero
position. This is illustrated in the following diagram.
CANOpen Implementation Guide Manual Pag. 78
Object Description:
Index 607Ch
Name Home offset
Object code VAR
Data Type INTEGER32
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
The homing method object determines the method that will be used during homing.
Object Description:
Index 6098h
Name Homing method
Object code VAR
Data Type INTEGER8
CANOpen Implementation Guide Manual Pag. 79
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER8
Default Value 0
Value Description
-17 See the functional description
-18 See the functional description
0 No homing operation required
1 - 35 See the functional description
36 - 127 reserved
This entry in the object dictionary defines the speeds used during homing and is given
velocity units.
Object Description:
Index 6099h
Name Homing speeds
Object code ARRAY
Data Type UNSIGNED32
Category Mandatory
Entry Description:
Sub-Index 0
CANOpen Implementation Guide Manual Pag. 80
Sub-Index 1
Description Speed during search for switch
Entry Category Mandatory
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED32
Default Value 0
Sub-Index 2
Description Speed during search for zero
Entry Category Mandatory
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED32
Default Value 0
The homing acceleration establishes the acceleration to be used for all accelerations
and decelerations with the standard homing modes and is given in acceleration units.
Object Description:
Index 609Ah
Name Homing acceleration
Object code VAR
Data Type UNSIGNED32
CANOpen Implementation Guide Manual Pag. 81
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED32
Default Value 0
✔ the homing signal (positive limit switch, negative limit switch, home switch)
✔ the direction of actuation and where appropriate
✔ the position of the index pulse.
The home position and the zero position are offset by the home offset, see the definition
of home offset for how this offset is used. Various homing positions are illustrated in
the following diagrams. An encircled number indicates the code for selection of this
homing position. The direction of movement is also indicated.
There are five sources of homing signal available, these are the negative and positive
limit switches, the home switch and the index pulse from an encoder and the hard-
home.
In the diagrams of homing sequences shown below, the encoder count increases as the
axis position moves to the right, in other words the left is the minimum position and
the right is the maximum position. For the operation of positioning drives, an exact
knowledge of the absolute position is normally required. Since for cost reasons, drives
often do not have an absolute encoder, a homing operation is necessary. There are
several, application-specific methods. The homing method is used for selection.
The exact sequence of the homing operation is clearly described by the method. In
some circumstances, a device has several methods to choose from, using the homing
method.
The following sub-sections describe the details of how each of the homing modes shall
function.
8.4.1 Method 1: Homing on the negative limit switch and index pulse
Using this method the initial direction of movement is leftward if the negative limit
switch is inactive (here shown as low). The home position is at the first index pulse to
the right of the position where the negative limit switch becomes inactive.
8.4.2 Method 2: Homing on the positive limit switch and index pulse
Using this method the initial direction of movement is rightward if the positive limit
switch is inactive (here shown as low). The position of home is at the first index pulse
to the left of the position where the positive limit switch becomes inactive.
CANOpen Implementation Guide Manual Pag. 83
8.4.3 Methods 3 and 4: Homing on the positive home switch and index pulse
Using methods 3 or 4 the initial direction of movement is dependent on the state of the
home switch. The home position is at the index pulse to either to the left or the right
of the point where the home switch changes state. If the initial position is sited so that
the direction of movement must reverse during homing, the point at which the reversal
takes place is anywhere after a change of state of the home switch.
CANOpen Implementation Guide Manual Pag. 84
8.4.4 Methods 5 and 6: Homing on the negative home switch and index pulse
Using methods 5 or 6 the initial direction of movement is dependent on the state of the
home switch. The home position is at the index pulse to either to the left or the right
of the point where the home switch changes state. If the initial position is sited so that
the direction of movement must reverse during homing, the point at which the reversal
takes place is anywhere after a change of state of the home switch.
CANOpen Implementation Guide Manual Pag. 85
8.4.5 Methods 7 to 14: Homing on the home switch and index pulse
These methods use a home switch which is active over only portion of the travel, in
effect the switch has a ‘momentary’ action as the axle's position sweeps past the switch.
Using methods 7 to 10 the initial direction of movement is to the right, and using
methods 11 to 14 the initial direction of movement is to the left except if the home
switch is active at the start of the motion.
In this case the initial direction of motion is Dependent on the edge being sought. The
home position is at the index pulse on either side of the rising or falling edges of the
home switch, as shown in the following two diagrams. If the initial direction of
movement leads away from the home switch, the drive must reverse on encountering
the relevant limit switch.
CANOpen Implementation Guide Manual Pag. 86
Image 13: Homing on the home switch and index pulse - positive initial move
CANOpen Implementation Guide Manual Pag. 87
Image 14: Homing on the home switch and index pulse - negative initial move
These methods are similar to methods 1 to 14 except that the home position is not
dependent on the index pulse but only dependent on the relevant home or limit switch
transitions. For example methods 19 and 20 are similar to methods 3 and 4 as shown
in the following diagram.
CANOpen Implementation Guide Manual Pag. 88
In this chapter, all parameters are described which are necessary for a closed loop
position control. The control loop is fed with the position demand value as one of the
outputs of the trajectory generator and with the output of the position detection unit
(position actual value) of encoder as input parameters. The behavior of the control may
be influenced by control parameters which are externally applicable. To keep stable the
loop, a relative limitation of the output using the previous control effort is possible. In
order not to exceed physical limits of a drive, an absolute limit function is
implemented for the control effort. The control effort may be a velocity demand value,
a position demand value or any other output value, depending on the modes of
operation implemented by a manufacturer. Especially in cascaded control structures,
where a position control is followed by a torque control, e.g. the control effort of the
position control loop is used as an input for a further calculation.
Object Description:
Index 6062h
Name Position demand value
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
The actual value of the position measurement device is one of the two input values of
the closed loop position control. The data unit is defined as increments.
Object Description:
Index 6063h
Name Position actual value
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
Object Description:
Index 6064h
Name Position actual value
Object code VAR
Data Type UNSIGNED32
Category Mandatory
Entry Description:
CANOpen Implementation Guide Manual Pag. 92
The following error window defines a range of tolerated position values symmetrically
to the position demand value. As it is in most cases used with user defined units, a
transformation into increments with the position factor is necessary. If the position
actual value is out of the following error window, an error occur.
Object Description:
Index 6065h
Name Following error window
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED32
Default Value 0
When a following error occurs longer than the defined value of the time-out given in
multiples of milliseconds, the corresponding bit 13 following error in the status word
will be set to one. The reaction of the drive when a following error occurs, is
manufacturer specific.
Object Description:
CANOpen Implementation Guide Manual Pag. 93
Index 6066h
Name Following error time out
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
The position window defines a symmetrical range of accepted positions relatively to the
target position. If the actual value of the position encoder is within the position window,
this target position is regarded as reached. As the user mostly prefers to specify the
position window in his application in user defined units, the position factor must be
used to transform this value into increments. The target position has to be handled in
the same manner as in the Trajectory Generator concerning limiting functions and
transformation into internal machine units before it can be used with this function.
Object Description:
Index 6067h
Name Position window
Object code VAR
Data Type UNSIGNED32
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED32
CANOpen Implementation Guide Manual Pag. 94
Default Value 0
When the actual position is within the position window during the defined position
window time which is given in multiples of milliseconds, the corresponding bit 10 target
reached in the statusword will be set to one.
Object Description:
Index 6068h
Name Position window time
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
This object represents the actual value of the following error, it is given in user defined
position units.
Object Description:
Index 60F4h
Name Following error actual value
Object code VAR
CANOpen Implementation Guide Manual Pag. 95
Entry Description:
The output of the position control loop is the control effort. It is particular to the Position
control function that the notation of the control effort is mode dependent and therefore
not specified in the object description.
Object Description:
Index 60FAh
Name Control effort
Object code VAR
Data Type INTEGER32
Category Optional
Entry Description:
The object define the manufacturer-specific object for the position control loop
CANOpen Implementation Guide Manual Pag. 96
Object Description:
Index 60FBh
Name Position control parameter set
Object code ARRAY
Data Type UNSIGNED16
Category Optional
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 2
Default Value 2
Sub-Index 1
Description KP Position loop
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED16
Default Value 0
CANOpen Implementation Guide Manual Pag. 97
The interpolated position mode is used to control multiple coordinated axis or a single
axis with the need for time-interpolation of set-point data. The interpolated position
mode use time synchronization mechanisms for a time coordination of the related drive
units.
This object reflects or changes the actual chosen interpolation mode, selected by the
user. The interpolation sub-modes can be changed only when the interpolated mode is
inactive.
Object Description
Index 60C0h
Name Interpolated Sub Mode Select
Object code VAR
Data Type INTEGER16
Category Optional
Entry Description
Access Read/Write
PDO Mapping NO
Value Range 0
Default Value 0 (Linear Interpolation)
Data Description
Value Description
CANOpen Implementation Guide Manual Pag. 98
-3,...,-32768 Reserved
-2 Linear Interpolation no Buffering
-1 Reserved
0 Linear Interpolation
This object is the data words, which are necessary for performing the interpolation
algorithm. The interpretation of the data words may vary with the different possible
interpolation modes as set by 60C0h.
Object Description
Index 60C0h
Name Interpolation data record
Object code 60C0h = 0 : INTEGER32
60C0h > 0 : not defined
Data Type INTEGER16
Category Optional
Entry Description
Sub-Index 0
Description Number of Entries
Entry Category mandatory
Access Read/Write
PDO Mapping YES
Value Range 1
Default Value 1
Sub-Index 1
Description Parameter of IP Function
Entry Category mandatory
Access Read/Write
PDO Mapping YES
CANOpen Implementation Guide Manual Pag. 99
10.2
This object is used to define the relative time taken between two set points for the
interpolation position modes. The interpolation time unit is given in 10 interpolation time index
seconds.
The interpolation time period can be changed only when the interpolated mode is
inactive.
Object Description
Index 60C2h
Name Interpolation time period
Object code RECORD
Data Type Interpolation time period record (0080h)
Category Optional
Entry Description
Sub-Index 0
Description Number of Entries
Entry Category mandatory
Access Read Only
PDO Mapping YES
Value Range 2
Default Value 2
Sub-Index 1
Description Interpolation time units
Entry Category mandatory
CANOpen Implementation Guide Manual Pag. 100
Access Read/Write
PDO Mapping YES
Value Range 0,26
Default Value 1
Sub-Index 2
Description Interpolation time index
Entry Category mandatory
Access Read/Write
PDO Mapping YES
Value Range -128,63 (-3 ONLY)
Default Value -3
Devices in the interpolation position mode often interact with other devices. Therefore
it is necessary to define a communication object which is used to synchronize these
interactions.
This can be done by the general Sync, or a specific group-sync-signal. Each reception
of this trigger-signal or a specified number of occurrences of the trigger-signal can
synchronize the devices; a second opportunity is to use fixed time slices for
synchronization.
Object Description
Index 60C3h
Name Interpolation sync definition
Object code ARRAY
Data Type UNSIGNED8
Category Optional
Entry Description
Sub-Index 0
CANOpen Implementation Guide Manual Pag. 101
Sub-Index 1
Description Synchronize on Group
Entry Category mandatory
Access Read Only
PDO Mapping NO
Value Range 0 .. 255
Default Value 0
Sub-Index 2
Description IP Sync every n event
Entry Category mandatory
Access Read/Write
PDO Mapping NO
Value Range 0 .. 255
Default Value 1
Value Description
0 General Sync is Used
1 .. 255 Reserved
the device to receive the needed data in advance a data space is used to store the
positions and further data send by the host.
Object Description
Index 60C4h
Name Interpolation data configuration
Object code RECORD
Data Type Interpolation data configuration record
(0081h)
Category Optional
Entry Description
Sub-Index 0
Description Number of Entries
Entry Category mandatory
Access Read Only
PDO Mapping NO
Value Range 6
Default Value 6
Sub-Index 1
Description Maximum buffer size
Entry Category mandatory
Access Read Only
PDO Mapping NO
Value Range UNSIGNED32
Default Value 1
Sub-Index 2
Description Actual buffer size
Entry Category mandatory
Access Read/Write
CANOpen Implementation Guide Manual Pag. 103
Sub-Index 3
Description Buffer organization
Entry Category mandatory
Access Read/Write
PDO Mapping YES
Value Range 0 .. 255
Default Value 0
Sub-Index 4
Description Buffer position
Entry Category mandatory
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
Sub-Index 5
Description Size of data record
Entry Category mandatory
Access Write Only
PDO Mapping YES
Value Range 1 .. 254
Default Value 1
CANOpen Implementation Guide Manual Pag. 104
Sub-Index 6
Description Buffer clear
Entry Category mandatory
Access Write Only
PDO Mapping YES
Value Range UNSIGNED8
Default Value 0
Value Description
0 Clear Input Buffer
Access disabled
Clear all ip data records
1 Enable access to the input buffer for the
drive functions
2 .. 255 Reserved
CANOpen Implementation Guide Manual Pag. 105
The profile velocity mode allow the user to run the motor with a controlled speed profile.
The velocity sensor actual value describes the value read from a velocity encoder.
Object Description:
Index 6069h
Name Velocity sensor actual value
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
The output value of the trajectory generator may be corrected by the output value of
the position control function. It is then provided as a demand value for the velocity
controller and given in the velocity units.
Object Description:
CANOpen Implementation Guide Manual Pag. 106
Index 606Bh
Name Velocity demand value
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
The velocity actual value is also represented in velocity units and is coupled to the
velocity used as input to the velocity controller.
Object Description:
Index 606Ch
Name Velocity actual value
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
The velocity window monitors whether the required process velocity has been achieved
after an eventual acceleration or deceleration (braking) phase. It is given in velocity
units.
Object Description:
Index 606Dh
Name Velocity window
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
The corresponding bit 10 target reached is set in the statusword when the difference
between the target velocity and the velocity actual value is within the velocity window
longer than the velocity window time. The value of the velocity window time is given in
multiples of milliseconds.
Object Description:
Index 606Eh
Name Velocity window time
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
CANOpen Implementation Guide Manual Pag. 108
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
As soon as the velocity actual value exceeds the velocity threshold longer than the
velocity threshold time bit 12 velocity = 0 is reset in the statusword. Below this
threshold the bit is set and indicates that the axle is stationary. The value is given in
velocity units.
Object Description:
Index 606Fh
Name Velocity threshold
Object code VAR
Data Type UNSIGNED16
Category Optional
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
Object Description:
Index 606Fh
CANOpen Implementation Guide Manual Pag. 109
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range UNSIGNED16
Default Value 0
The target velocity is the input for the trajectory generator and the value is given in
velocity units.
Object Description:
Index 60FFh
Name Target velocity
Object code VAR
Data Type INTEGER32
Category Mandatory
Entry Description:
Access Read/Write
PDO Mapping YES
Value Range INTEGER32
Default Value 0
In order to control the behavior of the velocity control loop, one or more parameters
are necessary.
This object defines a rudimentary set of three parameters for a PI-control which may
be enlarged by the manufacturer up to 255 parameters.
Object Description:
Index 60F9h
Name Velocity control parameter set
Object code ARRAY
Data Type UNSIGNED16
Category Optional
Entry Description:
Sub-Index 0
Description Number of entries
Entry Category Mandatory
Access Read Only
PDO Mapping NO
Value Range 2
Default Value 2
Sub-Index 1
Description KP Velocity loop
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
Value Range UNSIGNED16
Default Value 0
Sub-Index 2
Description KI Velocity loop
Entry Category Mandatory
Access Read/Write
PDO Mapping NO
CANOpen Implementation Guide Manual Pag. 111