FB_EcCoeReadBTN

FB_EcCoeReadBTN 1:

Mit dem Funktionsbaustein FB_EcCoeReadBTN kann per SDO(Service Daten Objekt)-Zugriff die BTN aus dem Objektverzeichnis eines EtherCAT-Slaves ausgelesen werden. Dazu muss der Slave eine Mailbox besitzen und das "CANopen over EtherCAT (CoE)"-Protokoll unterstützen unterstützen und das Objektverzeichnis muss ein Objekt 0xF083 mit der BTN enthalten.

FB_EcCoeReadBTN 2: Eingänge

VAR_INPUT
    sNetId     : T_AmsNetId; 
    nSlaveAddr : UINT; 
    bExecute   : BOOL;
    tTimeout   : TIME := DEFAULT_ADS_TIMEOUT; 
END_VAR

Name

Typ

Beschreibung

sNetId

T_AmsNetId

String, der die AMS-Netzwerkkennung des EtherCAT-Master-Gerätes enthält. (Typ: T_AmsNetId)

nSlaveAddr

UINT

Feste Adresse des EtherCAT-Slaves, an den das SDO-Upload-Kommando geschickt werden soll.

bExecute

BOOL

Über eine positive Flanke an diesem Eingang wird der Baustein aktiviert.

tTimeout

TIME

Maximale Zeit, die bei der Ausführung des Funktionsbausteins nicht überschritten werden darf.

FB_EcCoeReadBTN 3: Ausgänge

VAR_OUTPUT
    bBusy  : BOOL;
    bError : BOOL;
    nErrId : UDINT;
    sBTN   : STRING(9)
END_VAR

Name

Typ

Beschreibung

bBusy

BOOL

Dieser Ausgang wird bei der Aktivierung des Funktionsbausteins gesetzt und bleibt gesetzt, bis eine Rückmeldung erfolgt.

bError

BOOL

Dieser Ausgang wird gesetzt, nachdem der bBusy-Ausgang zurückgesetzt wurde, wenn bei der Übertragung des Kommandos ein Fehler auftritt.

nErrId

UDINT

Liefert bei einem gesetzten bError-Ausgang den ADS-Fehlercode des zuletzt ausgeführten Befehls.

sBTN

STRING

Dieser Ausgang enthält bei fehlerfreiem Durchlauf die BTN des EtherCAT Slaves, nachdem der bBusy-Ausgang zurückgesetzt wurde, z.B. „0002agdw“.

Beispiel für eine Implementierung in ST

PROGRAM TEST_ EcCoEReadBtn
VAR
    fbCoEBTN   : FB_EcCoEReadBtn;
    sNetId     : T_AmsNetId := '172.16.2.131.2.1';
    bExecute   : BOOL := TRUE;
    nSlaveAddr : UINT := 1006;
    sCoEBTN    : STRING;
    bError     : BOOL;
    nErrId     : UDINT;
END_VAR

fbCoEBTN(sNetId:= sNetID, nSlaveAddr:= nPort, bExecute:= bExecute, tTimeout:= T#5S);
IF NOT fbCoEBTN.bBusy THEN
     bExecute := FALSE;
     IF NOT fbCoEBTN.bError THEN
          sCoEBTN := fbCoEBTN.sBTN;
     END_IF
     fbCoEBTN(bExecute:= bExecute);
END_IF

Voraussetzungen

Entwicklungsumgebung

Zielplattform

Einzubindende SPS- Bibliotheken

TwinCAT v3.1.0

PC oder CX (x86, x64, ARM)

Tc2_EtherCAT