Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave

In dieser Übersicht werden in Kurzform einige Aspekte des EtherCAT-Slave Betriebs unter TwinCAT behandelt. Ausführliche Informationen dazu sind entsprechenden Fachkapiteln z.B. in der EtherCAT-Systemdokumentation zu entnehmen.

Diagnose in Echtzeit: WorkingCounter, EtherCAT State und Status

Im Allgemeinen bietet ein EtherCAT-Slave mehrere Diagnoseinformationen zur Verarbeitung in der ansteuernden Task an.

Diese Diagnoseinformationen erfassen unterschiedliche Kommunikationsebenen und damit Quellorte und werden deshalb auch unterschiedlich aktualisiert.

Eine Applikation, die auf die Korrektheit und Aktualität von IO-Daten aus einem Feldbus angewiesen ist, muss die entsprechend ihr unterlagerten Ebenen diagnostisch erfassen.

EtherCAT und der TwinCAT System Manager bieten entsprechend umfassende Diagnoseelemente an. Die Diagnoseelemente, die im laufenden Betrieb (nicht zur Inbetriebnahme) für eine zyklusaktuelle Diagnose aus der steuernden Task hilfreich sind, werden im Folgenden erläutert.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 1:
Auswahl an Diagnoseinformationen eines EtherCAT-Slave

Im Allgemeinen verfügt ein EtherCAT-Slave über

Die Farbgebung in Abb. Auswahl an Diagnoseinformationen eines EtherCAT-Slave entspricht auch den Variablenfarben im System Manager, siehe Abb. Grundlegende EtherCAT-Slave Diagnose in der PLC.

Farbe

Bedeutung

gelb

Eingangsvariablen vom Slave zum EtherCAT-Master, die in jedem Zyklus aktualisiert werden

rot

Ausgangsvariablen vom Slave zum EtherCAT-Master, die in jedem Zyklus aktualisiert werden

grün

Informationsvariabeln des EtherCAT-Masters, die azyklisch aktualisiert werden d. h. in einem Zyklus eventuell nicht den letztmöglichen Stand abbilden. Deshalb ist ein Auslesen solcher Variablen über ADS sinnvoll.

In Abb. Grundlegende EtherCAT Slave Diagnose in der PLC ist eine Beispielimplementation einer grundlegenden EtherCAT-Slave Diagnose zu sehen. Dabei wird eine Beckhoff EL3102 (2 kanalige analoge Eingangsklemme) verwendet, da sie sowohl über slave-typische Kommunikationsdiagnose als auch über kanal-spezifische Funktionsdiagnose verfügt. In der PLC sind Strukturen als Eingangsvariablen angelegt, die jeweils dem Prozessabbild entsprechen.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 2:
Grundlegende EtherCAT-Slave Diagnose in der PLC

Dabei werden folgende Aspekte abgedeckt:

Kennzeichen

Funktion

Ausprägung

Anwendung/Auswertung

A

Diagnoseinformationen des EtherCAT-Master

zyklisch aktualisiert (gelb) oder azyklisch bereitgestellt (grün).

 

Zumindest der DevState ist in der PLC zyklusaktuell auszuwerten.

Die Diagnoseinformationen des EtherCAT-Master bieten noch weitaus mehr Möglichkeiten, die in der EtherCAT-Systemdokumentation behandelt werden. Einige Stichworte:

  • CoE im Master zur Kommunikation mit/über die Slaves
  • Funktionen aus TcEtherCAT.lib
  • OnlineScan durchführen

B

Im gewählten Beispiel (EL3102) umfasst die EL3102 zwei analoge Eingangskanäle, die einen eigenen Funktionsstatus zyklusaktuell übermitteln.

Status

  • die Bitdeutungen sind der Gerätedokumentation zu entnehmen
  • andere Geräte können mehr oder keine slave-typischen Angaben liefern

Damit sich die übergeordnete PLC-Task (oder entsprechende Steueranwendungen) auf korrekte Daten verlassen kann, muss dort der Funktionsstatus ausgewertet werden. Deshalb werden solche Informationen zyklusaktuell mit den Prozessdaten bereitgestellt.

C

Für jeden EtherCAT-Slave mit zyklischen Prozessdaten zeigt der Master durch einen so genannten WorkingCounter an, ob der Slave erfolgreich und störungsfrei am zyklischen Prozessdatenverkehr teilnimmt. Diese elementar wichtige Information wird deshalb im System Manager zyklusaktuell

  1. am EtherCAT-Slave als auch inhaltsidentisch
  2. als Sammelvariable am EtherCAT-Master (siehe Punkt A)

zur Verlinkung bereitgestellt.

WcState (Working Counter)

0: gültige Echtzeitkommunikation im letzten Zyklus

1: ungültige Echtzeitkommunikation

ggf. Auswirkung auf die Prozessdaten anderer Slaves, die in der gleichen SyncUnit liegen

Damit sich die übergeordnete PLC-Task (oder entsprechende Steueranwendungen) auf korrekte Daten verlassen kann, muss dort der Kommunikationsstatus des EtherCAT-Slaves ausgewertet werden. Deshalb werden solche Informationen zyklusaktuell mit den Prozessdaten bereitgestellt.

D

Diagnoseinformationen des EtherCAT-Masters, die zwar am Slave zur Verlinkung dargestellt werden, aber tatsächlich vom Master für den jeweiligen Slave ermittelt und dort dargestellt werden. Diese Informationen haben keinen Echtzeit-Charakter weil sie

  • nur selten/nie verändert werden, außer beim Systemstart
  • selbst auf azyklischem Weg ermittelt werden (z.B. EtherCAT-Status)

State

aktueller Status (INIT..OP) des Slaves. Im normalen Betriebszustand muss der Slave im OP (=8) sein.

AdsAddr

Die ADS-Adresse ist nützlich, um aus der PLC/Task über ADS mit dem EtherCAT-Slave zu kommunizieren, z.B. zum Lesen/Schreiben auf das CoE. Die AMS-NetID eines Slaves entspricht der AMS-NetID des EtherCAT-Masters, über den port (= EtherCAT Adresse) ist der einzelne Slave ansprechbar.

Informationsvariabeln des EtherCAT-Masters, die azyklisch aktualisiert werden, d.h. in einem Zyklus eventuell nicht den letztmöglichen Stand abbilden. Deshalb ist ein Auslesen solcher Variablen über ADS möglich.

Hinweis

Diagnoseinformationen

Es wird dringend empfohlen, die angebotenen Diagnoseinformationen auszuwerten um in der Applikation entsprechend reagieren zu können.

CoE-Parameterverzeichnis

Das CoE-Parameterverzeichnis (CanOpen-over-EtherCAT) dient der Verwaltung von Einstellwerten des jeweiligen Slaves. Bei der Inbetriebnahme eines komplexeren EtherCAT-Slaves sind unter Umständen hier Veränderungen vorzunehmen. Zugänglich ist es über den TwinCAT System Manager, s. Abb. EL3102, CoE-Verzeichnis:

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 3:
EL3102, CoE-Verzeichnis
Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 4:

EtherCAT-Systemdokumentation

Es ist die ausführliche Beschreibung in der EtherCAT-Systemdokumentation (EtherCAT Grundlagen --> CoE Interface) zu beachten!

Einige Hinweise daraus in Kürze:

Inbetriebnahmehilfe im TwinCAT System Manager

In einem fortschreitenden Prozess werden für EL/EP-EtherCAT-Geräte Inbetriebnahmeoberflächen eingeführt. Diese sind in TwinCAT System Managern ab TwinCAT 2.11R2 verfügbar. Sie werden über entsprechend erweiterte ESI-Konfigurationsdateien in den System Manager integriert.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 5:
Beispiel Inbetriebnahmehilfe für eine EL3204

Diese Inbetriebnahme verwaltet zugleich

Die dafür bisher nötigen Karteireiter „Process Data“, „DC“, „Startup“ und „CoE-Online“ werden zwar noch angezeigt, es wird aber empfohlen die automatisch generierten Einstellungen durch die Inbetriebnahmehilfe nicht zu verändern, wenn diese verwendet wird.

Das Inbetriebnahme-Tool deckt nicht alle möglichen Einsatzfälle eines EL/EP-Gerätes ab. Sind die Einstellmöglichkeiten nicht ausreichend, können vom Anwender wie bisher DC-, PDO- und CoE-Einstellungen manuell vorgenommen werden.

EtherCAT State: automatisches Default-Verhalten des TwinCAT System Managers und manuelle Ansteuerung

Ein EtherCAT-Slave hat für den ordnungsgemäßen Betrieb nach der Versorgung mit Betriebsspannung die Stati

zu durchlaufen. Der EtherCAT-Master ordnet diese Zustände an in Abhängigkeit der Initialisierungsroutinen, die zur Inbetriebnahme des Gerätes durch die ES/XML und Anwendereinstellungen (Distributed Clocks (DC), PDO, CoE) definiert sind. Siehe dazu auch Kapitel "Grundlagen der Kommunikation, EtherCAT State Machine. Der Hochlauf kann je nach Konfigurationsaufwand und Gesamtkonfiguration bis zu einigen Sekunden dauern.

Auch der EtherCAT-Master selbst muss beim Start diese Routinen durchlaufen, bis er in jedem Fall den Zielzustand OP erreicht.

Der vom Anwender beabsichtigte, von TwinCAT beim Start automatisch herbeigeführte Ziel-State kann im System Manager eingestellt werden. Sobald TwinCAT in RUN versetzt wird, wird dann der TwinCAT EtherCAT-Master die Zielzustände anfahren.

Standardeinstellung

Standardmäßig ist in den erweiterten Einstellungen des EtherCAT-Masters gesetzt:

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 6:
Default Verhalten System Manager

Zusätzlich kann im Dialog „Erweiterte Einstellung“ beim jeweiligen Slave der Zielzustand eingestellt werden, auch dieser ist standardmäßig OP.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 7:
Default Zielzustand im Slave

Manuelle Führung

Aus bestimmten Gründen kann es angebracht sein, aus der Anwendung/Task/PLC die States kontrolliert zu fahren, z. B.

Dann ist es in der PLC-Anwendung sinnvoll, die PLC-Funktionsblöcke aus der standardmäßig vorhandenen TcEtherCAT.lib zu nutzen und z. B. mit FB_EcSetMasterState die States kontrolliert anzufahren.

Die Einstellungen im EtherCAT-Master sind dann sinnvollerweise für Master und Slave auf INIT zu setzen.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 8:
PLC-Bausteine

Hinweis E-Bus-Strom

EL/ES-Klemmen werden im Klemmenstrang auf der Hutschiene an einen Koppler gesetzt. Ein Buskoppler kann die an ihm angefügten EL-Klemmen mit der E-Bus-Systemspannung von 5 V versorgen, i.d.R. ist ein Koppler dabei bis zu 2 A belastbar. Zu jeder EL-Klemme ist die Information, wie viel Strom sie aus der E-Bus-Versorgung benötigt, online und im Katalog verfügbar. Benötigen die angefügten Klemmen mehr Strom als der Koppler liefern kann, sind an entsprechenden Positionen im Klemmenstrang Einspeiseklemmen (z. B. EL9410) zu setzen.

Im TwinCAT System Manager wird der vorberechnete theoretische maximale E-Bus-Strom als Spaltenwert angezeigt. Eine Unterschreitung wird durch negativen Summenbetrag und Ausrufezeichen markiert, vor einer solchen Stelle ist eine Einspeiseklemme zu setzen.

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 9:
Unzulässige Überschreitung E-Bus Strom

Ab TwinCAT 2.11 wird bei der Aktivierung einer solchen Konfiguration eine Warnmeldung „E-Bus Power of Terminal...“ im Logger-Fenster ausgegeben:

Allgemeine Inbetriebnahmehinweise für einen EtherCAT-Slave 10:
Warnmeldung E-Bus-Überschreitung

Hinweis

Achtung! Fehlfunktion möglich!

Die E-Bus-Versorgung aller EtherCAT-Klemmen eines Klemmenblocks muss aus demselben Massepotential erfolgen!