46
Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Embed Size (px)

Citation preview

Page 1: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Page 2: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

This webinar will be available afterwards at

designworldonline.com & via email

Q&A at the end of the presentation

Hashtag for this webinar: #DWwebinar

Before We Start

Page 3: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Moderator

Leslie Langnau Design World

Presenter

Joey Stubbs EtherCAT Technology Group

Page 4: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Accurate Synchronization of EtherCAT

Systems Using Distributed Clocks

Joseph E Stubbs, PE, PMP

EtherCAT Technology Group

Page 5: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Purpose of this presentation

• Gain a basic understanding of how the Distributed Clocks

(DC) synchronization method of EtherCAT works.

• Understand how devices designed with EtherCAT DCs can

benefit the user.

Page 6: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Agenda

• “Distributed Clocks” definition

• Important EtherCAT functional principles

• Overview of DC functionality

• How it works o Propagation delay measurement

o Setting of Reference Clock

o Setting of Slave Clocks

o Drift compensation

o Master compensation (shift time)

• Practical applications of DCs in slave devices

Page 7: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

DCs definition • In EtherCAT terminology the term “Distributed Clocks”

(DCs) refers to a logical network of synchronized,

distributed local clocks in the EtherCAT fieldbus system.

• By using distributed clocks, EtherCAT, the real-time

Ethernet protocol is able to synchronize the time in all local

bus devices within a very narrow tolerance range, typically

within 100ns.

Page 8: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Why Synchronize a Network? • Common time value in all devices allows synchronous gathering

of input data from devices o Example -- When device 1 was at position X, device 2 was at position Z.

• Cyclic behavior with tight temporal tolerances o Example – position control of a drive. Exact position input for each time slice produces

tighter coordinated motion or speed.

o Example – data acquisition at high data rates

• Response to external event o Example -- Exact time alarm when received can be used to reject bad product

downstream with respect to conveyor speed with little loss of good product

o Example -- “Seeing” events that would be missed in classical scanning of I/O systems

• Response at exact future time o Example -- All drives begin execution of new command at exact time

o Example -- Simultaneous outputs for devices separated by long distances in same network

Page 9: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

• EtherCAT utilizes several important operating principles

allowing DCs to be implemented efficiently and elegantly o Processing “On the Fly”

o Protocol processed in hardware

o Fixed frame path for all frames in network in a given topology

o Latching of receive times in slave ports and logical processing unit

o Instruction set that lends itself to distributing times and offsets easily

o A DC unit built-in to the EtherCAT Slave Controller (ESC), which facilitates many of

the functions in hardware

o External interfaces from the DC unit

Functional Principles

Page 10: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Slave Device

EtherCAT Slave Controller

Slave Device

EtherCAT Slave Controller

Functional Principle: Ethernet “on the Fly”

•Process data is extracted and inserted on the fly

•Compilation of process data can change in each cycle, e.g.

ultra short cycle time for axis, and longer cycles for I/O

update possible

•In addition asynchronous, event triggered communication

Page 11: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

DVI

IPC

.. ..

Frame Processing within each node

EtherCAT Segment (Slaves) Master

To Master

From Master

Page 12: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Topology • Flexible Topology

• Any number of physical layer changes possible

• Up to 65,535 devices within one EtherCAT network possible

Master

Line

Drop Line Star/Tree

Page 13: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Frame Processing Auto Forwarder and Loop Back

1

Port 2

Auto-

Forwarder

Port 1

Aut

o-

Forw

arde

r

1

Port 3

Auto-

Forwarder

Port 0

Aut

o-

Forw

arde

r

Loopback function

Loop

back

func

tion

EtherCAT

Processing Unit

Loopback function

Loop

back

func

tion

ET1100

port 2 closed

port 2 open

port

1 cl

osed

port

1 op

en

port 3 open

port 3 closed

port

0 op

en

or a

ll po

rts

clos

ed

port

0 cl

osed

ESC

Page 14: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Important things to keep in mind

• Only the EtherCAT master (controller) can create a frame

• Slaves can only modify the frame(s)

• The frame is not actively routed to a particular node. The frame travels through the entire network regardless of which node is addressed within the frame.

• One frame can service an entire network. Multiple frames can be sent out back-to-back to service larger networks which exceed 1500 bytes in data length.

Page 15: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Frame Processing Order on the System

EtherCAT Segment

Master

Cable EtherCAT Frame Path

Page 16: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

EtherCAT Commands

• Broadcast Read Actions

o Individual Bits of a Byte will be added with a bitwise OR operation between

incoming data and local data

• Read Write Actions

o Exchange of incoming data and local data

(exception: Broadcast – see broadcast read)

• Read Multiple Write Actions (RMW)

o Addressed Station will read, the others will write

Page 17: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Distributed Clocks Unit

EtherCAT Slave Controller (ESC)

FMMU n

SyncMan

EtherCAT Address Space

EtherCAT Processing Unit and Auto-Forwarder with Loop Back

Port 0 Port 1 Port 2 Port 3

PHY

Mag

RJ4

5

PHY

Mag

RJ45

Distributed Clocks

SPI / µC parallel Digital I/O Sync0 / Latch0

Sync1 / Latch1 IRQ

Process Data Interface (PDI)

Sync / Latch Unit

DC Control

System Time

Offset

Delay

Page 18: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

• The following must be handled by the distributed clock

control in the EtherCAT master:

o Propagation delay measurement: Measurement of the offset times depending on

the number of devices, cable lengths, dynamic changes in the configuration, etc.

o Offset compensation of the reference clock relative to the master clock. This is

taken into account during system start-up.

o Offset compensation of each slave relative to the reference clock. After system

startup the local clocks may start with different start values.

o Drift compensation/drift correction. Each slave clock usually has its own source

(quartz, PLL, ...), which means that offset times do not remain constant over a

prolonged period (minutes, days). Drift correction deals with this irregularity.

Page 19: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Distributed Clocks – Features

• Definition of a System Time

o Beginning on Jan. 1, 2000 at 0:00h on power-up

o Base unit is 1 ns

o 64 bit value (enough for more than 500 years)

o Lower 32 bits spans over 4.2 seconds

• Normally enough for communication and time stamping

• Definition of a Reference Clock

o One EtherCAT Slave will be used as a Reference Clock

o Reference Clock distributes its Clock cyclically

o Reference Clock adjustable from a “global” Reference Clock – IEEE 1588

Page 20: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

• Determine differences between the Ref clock and each DC

slave Port 0 time Ref

IPC S

S

S S S S

S

∆t

Propagation Delay Measurement

Page 21: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

DC – Propagation Delay Measurement

• EtherCAT Node measures time difference between leaving and

returning frame

EtherCAT Frame Processing Direction

EtherCAT Frame Forwarding Direction

Page 22: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Propagation Delay Measurement

• Registers:

o Receive Time Port 0 (ADO: 0x0900:0x0903)

o Receive Time Port 1 (ADO: 0x0904:0x0907)

o Receive Time Port 2 (ADO: 0x0908:0x090B)

o Receive Time Port 3 (ADO: 0x090C:0x090F)

o System Time Delay (ADO: 0x0928:0x092B)

• Write access to Receive Time Port 0 activates latch

o Latch local time of SOF (Start of Frame)

o At EOF (End of Frame) SOF time is copied to Receive Time Port X

• Receive Time Port X in local clock units (controlled)

• SOF time of all frames are latched on all ports internally

• Master reads all time stamps and calculates the delay times with respect to the topology.

• Individual delay time is written to register System Time Delay

Page 23: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

DC – Propagation Delay Measurement • EtherCAT Node measures time difference between leaving and

returning frame

IPC

Page 24: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

The differences between the Reference Clock and each DC slave “In” port

is Propagation Delay, called “System Time Delay”.

Ref

IPC S

S

S S S S

S

This value is

distributed by

the master

stored in the

slave for drift

compensation

calculations

later.

Propagation Delay Measurement

∆t

Page 25: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Binding Reference Clock to RTC

• Registers: o System Time Offset

(ADO: 0x0920:0x927, small systems 0x0920:0x0923)

• Difference between the Master RTC and Reference Clock is

calculated by the master.

• This time is written to register System Time Offset of the

Reference Clock only.

Page 26: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Binding Reference Clock to RTC Master sets Reference clock to RTC (or other source)

Ref

IPC S

S

S S S S

S

RTC

Page 27: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Offset Compensation

• Registers: o System Time Offset

(ADO: 0x0920:0x927, small systems 0x0920:0x0923)

• Difference between the Reference Clock and every slave device's clock is calculated by the master.

• The offset time is written to register System Time Offset

• Each slave calculates its local copy of the System time using its local time and the local offset value:

• tLocal copy of System Time = tLocal time + tOffset

Page 28: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Setting individual slaves to Reference Clock

Master calculates offset between Ref Clock and individual local clocks.

Ref

IPC S

S

S S S S

S

This value is

distributed by

the master

and written to

each slave in

order to bring

all local times

to the same

exact time.

Page 29: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Drift Compensation – DC Control

• RMW command (read – multiple write) allows the master to read System Time of the reference clock and write it to all slave clocks within a single frame using the same frame route and therefore the same propagation delay as the initial measurement.

• DC Control o Write access to System Time compares

received Time with local time

t = (tLocal time + tOffset - tPropagationDelay) – tReceived System Time

o If (t > 0) then decelerate local clock (each tick counts as less time) else if (t < 0) accelerate local clock (each tick counts as more time)

Page 30: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Drift Compensation Master commands the Reference clock to distribute its local

time to all nodes occasionally. Ref

IPC S

S

S S S S

S

The frequency of

issuing the RMW

command

determines the

amount of drift

allowed in the

system clocks

Page 31: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Drift Compensation – DC Control Because the RMW instruction distributes the reference

clock time each time the instruction is called…

…and because the propagation delay of the system does

not change…

…we do not need to have jitter-free frames to have a

jitter free system!

Therefore, no special master card is required, the master

can be a software stack even for the most tightly

synchronized applications.

Page 32: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Long Term Scope View of Two Separated Devices • 300 Nodes in between, 120m Cable Length

Jitter: ~ +/-20ns

Simultaneousness: ~15 ns

Interrupt Node 1

Interrupt Node 300

Page 33: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

M1

M2

M3

Synchronization of multiple networks Via boundary clock

Page 34: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

M S

S

S S S S

Boundary Clock

S

Master

IEEE 1588 Grandmaster

External Synchronization Via 1588 Boundary Clock

Page 35: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Example features of EtherCAT DCs

• Clock synchronization between the EtherCAT slaves and

the master

• Synchronous generation of local output signals (Sync

signals)

• Precise time stamping of input signals (Latch signals)

• Generation of synchronous interrupts to local

microprocessors (IRQ signals)

Page 36: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Action based on specified time: Sync 0/1

• The distributed clock unit in the ESC usually features 2 pins that can be triggered time-controlled. SYNC0 and SYNC1.

• In this case the compare unit in the ESC would be active: If the local distributed clock time matches a user-defined enable time the ESC triggers the associated Sync pin(s).

• This behaviour can be set up to be single shot or cyclic, with or without an acknowledge.

Distributed Clocks

Sync0 Sync1 PDI IRQ

Sync Unit Latch Unit

DC Control

System Time

Offset

Delay

Page 37: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Reaction to an external signal - Latch 0/1

• If an ESC is configured accordingly it can store the current local time if an external event occurs, i.e. it can place it into a buffer without delay using a capture unit.

• Can be configured for rising and/or falling edge, and single event or continuous latch

• Examples for such external events are edge on a dedicated pin of the ESC (Latch 0/1), arrival of the EtherCAT frame, end of the EtherCAT frame, communication with a connected microcontroller, and a wide range of other options.

Distributed Clocks

Latch0 Latch1

Sync Unit Latch Unit

DC Control

System Time

Offset

Delay

Page 38: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Example of Latch and Sync Use

OUT

OUT

Timestamp

IN

Latch

Timestamp

“Classical

Controls”

?

Constant

Constant

1 + T1 1 +T2 1 + T3

1 + Tx 1 +Ty 1 + Tz

Page 39: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Connection to an External Logic - SPI/µC

Parallel/IO/IRQ • An ESC can not only be used as a stand-alone

unit, it also has interfaces for communicating with other electronic units such as a microcontroller or other driver circuitry.

• Communication via these interfaces can also be controlled via distributed clocks in order to ensure synchronous, high-precision sampling of input parameters, or cyclic interrupts based on a multiple of the base scan rate.

• Examples for this use include interfacing to a microprocessor controlling a power drive, electronic shaft encoder analyzer, or data acquisition slaves for condition monitoring.

Distributed Clocks

Sync0 Sync1 PDI IRQ

Sync Unit Latch Unit

DC Control

System Time

Offset

Delay

Page 40: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Example of IRQ Use with a µC -- Oversampling o Fast signal sampling

o Analog value recording (input)

o Analog value generation (output)

23.10.2012 41

Oversampling – fast measurements

Measurement cycle

Base Network cycle Base Network cycle

Page 41: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Distributed Clock shift in Master to Ensure

Frame Arrives Prior to Sync Signal Generation

Application

Frame D U Frame D U

S0

Sync0

S0

Sync0

Master

Slave

User Shift Master

Fixed Shift (precalc.) Frame Delay

Sync0 Shift

DC Base Master Shift

Application

Local Timer Local Timer

Page 42: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Summary

• Tight clock synchronization between the EtherCAT slaves and

the master is possible without the use of a special fieldbus card

• The DC features of devices are enabled by both the unique

communication principles of EtherCAT and built-in features of

the ESCs.

• Some of the common behaviors built in to devices are: o Synchronous reading of input signals

o Precise time stamping of input signals (Latch signals)

o Generation of synchronous interrupts to local microprocessors (IRQ signals)

Page 43: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Please visit

www.ethercat.org for more information

EtherCAT Technology Group Headquarters Ostendstraße 196 90482 Nuremberg, Germany Phone: +49 911 54056 20 Email: [email protected]

EtherCAT Technology Group North America PO Box 1305 Port Orchard, WA 98366 Phone: 1-877-384-3722 Email: [email protected]

Page 44: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Questions?

Design World Leslie Langnau [email protected] Phone: 440.234.4531 Twitter: @DW_RapidMfg

EtherCAT Technology Group Joey Stubbs [email protected] [email protected] Phone: 1-877-384-3722

Page 45: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks

Thank You

This webinar will be available at designworldonline.com & via email

Tweet with hashtag #DWwebinar

Connect with

Twitter: @DesignWorld

Facebook: facebook.com/engineeringexchange

LinkedIn: Design World Group

YouTube: youtube.com/designworldvideo

Discuss this on EngineeringExchange.com

Page 46: Accurate Synchronization of EtherCAT Systems Using Distributed Clocks