FB_EcReadBIC

FB_EcReadBIC 1:

Mit dem Funktionsbaustein FB_EcReadBIC kann per ADS die BIC aus dem EEPROM eines EtherCAT-Slaves ausgelesen werden. Dazu muss der Slave die BIC im EEPROM enthalten.

FB_EcReadBIC 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_EcReadBIC 3: Ausgänge

VAR_OUTPUT
    bBusy     : BOOL;
    bError    : BOOL;
    nErrId    : UDINT;
    sBICValue : STRING(1023)
    stMSID    : ST_SplittedBIC
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.

sBICValue

STRING(1023)

Dieser Ausgang enthält bei fehlerfreiem Durchlauf die BIC des EtherCAT Slaves, nachdem der bBusy-Ausgang zurückgesetzt wurde, z.B. „1P193995SBTN0002agdw1KEL7411                        Q1    2P112104020018“.

stMSID

ST_SplittedBIC

Dieser Ausgang enthält bei fehlerfreiem Durchlauf die Teilstrings der BIC des EtherCAT Slaves, nachdem der bBusy-Ausgang zurückgesetzt wurde.

Für die oben angeführte BIC sind folgende Teilstrings belegt:
sItemNo = „193995“
sBTN = „0002agdw“
sDescription = „EL7411“
sQuantity = „1“
sBatchNo = „112104020018“

Beispiel für eine Implementierung in ST

PROGRAM TEST_EcReadBIC 
VAR
    fbEcBIC    : FB_EcReadBIC;
    sNetId     : T_AmsNetId := '172.16.2.131.2.1';
    bExecute   : BOOL := TRUE;
    nSlaveAddr : UINT := 1006;
    sECBIC     : STRING(1023);
    stEcBIC    : ST_SplittedBIC;
    bError     : BOOL;
    nErrId     : UDINT;
END_VAR

fbEcBIC(sNetId:= sNetID, nSlaveAddr:= nPort, bExecute:= bExecute, tTimeout:= T#5s);;
IF NOT fbEcBIC.bBusy THEN
     bExecute := FALSE;
     IF NOT fbEcBIC.bError THEN
          stEcBIC   := fbEcBIC.stMSID;
          sECBIC    := fbEcBIC.sBICValue;
     END_IF
     fbEcBIC (bExecute:= bExecute);
END_IF

Voraussetzungen

Entwicklungsumgebung

Zielplattform

Einzubindende SPS- Bibliotheken

TwinCAT v3.1.0

PC oder CX (x86, x64, Arm®)

Tc2_EtherCAT