ST_IEC870_5_104ProtocolParams
TYPE ST_IEC870_5_104ProtocolParams :
STRUCT
t0 : TIME := T#30s; (* MASTER only: Connection establishment *)
t1 : TIME := T#15s; (* Response Timeout (STARTDTAct, STOPDTAct, TESTFRAct only ) *)
t2 : TIME := T#10s; (* Send ACK in case of no data frames *)
t3 : TIME := T#20s; (* Time for sending test frames *)
iK : INT := 12; (* Max. difference RSN to send ACK *)
iW : INT := 8; (* Latest ACK after receiving I-frames *)
bSFrameACK : BOOL := TRUE; (* Send S-Frame ACK *)
bTESTFRAct : BOOL := TRUE; (* Send TESTFR *)
bDTControlled : BOOL := TRUE; (* STARTDT, STOPDT controlled (wait for STARTDT, STOPDT) *)
bControlDT : BOOL := FALSE; (* Send START, STOPDT frames *)
bSTARTDTCon : BOOL := TRUE; (* Send STARTDT confirmations *)
bSTOPDTCon : BOOL := TRUE; (* Send STOPDT confirmations *)
bTESTFRCon : BOOL := TRUE; (* Send TESTFR confirmations *)
eAcceptMode : E_SocketAcceptMode := eACCEPT_ALL; (* Connection accept flags *)
sRemoteHost : STRING(15) := ''; (* Remote (server) address. String containing an (Ipv4) Internet Protocol dotted address. *)
nRemotePort : UDINT := 0; (* Remote (server) Internet Protocol (IP) port. *)
APDULength : BYTE(MIN_IEC870_5_104_APDULEN..MAX_IEC870_5_104_APDULEN) := MAX_IEC870_5_104_APDULEN;(* Defaults:
Max. length of APDU = 255 bytes - 1 start octet - 1 length octet = 253 octets,
Max. length of ASDU = 253 - 4 control octets = 249 octets*)
bThrottleMode : BOOL := FALSE; (* If set reduces the number of polling socket read requests *)
bPackFrames : BOOL := FALSE; (* Binds more than one APDU frame to one big TCP/IP frame *)
bRetainBuffer : BOOL := FALSE; (* TRUE => Don't reset the tx/rx buffer in offline mode, FALSE => reset tx/rx buffer in offline mode *)
bCOTFilter : BOOL := TRUE; (* Only used if bRetainBuffer = TRUE. If TRUE = filter asdu by COT and session ID, FALSE = don't filter the asdu's *)
cotFilter : T_IEC870_5_101COTBits := 2#10001111, 7(16#FF);(* COT (cause of transfer) filter, default: eIEC870_COT_CYCLIC or eIEC870_COT_BACKGROUND or eIEC870_COT_SPONTAN *)
END_STRUCT
END_TYPE
t0 : Nicht benutzt, reserviert.
t1 : Max. Timeout-Zeit für eine Antwort auf ein STARTDTAct-, STOPDTAct- oder TESTFRAct-Frame.
t2 : Spätestens nach dieser Zeit wird ein S-Frame versendet.
t3 : Spätestens nach dieser Zeit wird ein Test-Frame versendet.
iK : Spätestens nach diesem gesendeten APDUs im I-Format, welches nicht quittiert wurde, wird die Verbindung geschlossen.
iW : Spätestens nach dem Empfang von w APDUs im I-Format quittiert der Empfänger den Empfang.
bSFrameACK : Sende S-Frames.
bTESTFRAct : Sende Test-Frames.
bDTControlled : Warte auf STARTDT-, STOPDT-Frame vom Master.
bControlDT : Nur bei der Masterkonfiguration: Sende STARTDT zum Slave.
bSTARTDTCon : Sende STARTDT Bestätigung
bSTOPDTCon : Sende STOPDT Bestätigung.
bTESTFRCon : Sende TESTFR Bestätigung.
eAcceptMode : Legt fest ob Verbindungen zu allen Remote-Clients, oder nur zu Clients mit bestimmter Host- und Port-Adresse zugelassen werden sollen. Default: Akzeptiere alle ankommenden Verbindungen.
sRemoteHost : Host-Adresse des Remote-Clients. Bei eAcceptMode = eACCEPT_ALL wird dieser Parameter ignoriert.
nRemotePort : Port-Adresse des Remote-Clients. Bei eAcceptMode = eACCEPT_ALL wird dieser Parameter ignoriert.
APDULength : Maximale Länge der APDU.
bThrottleMode: Implementiert ab IEC870-5-104 slave library v2.0.0 und höher. Die TCP/IP sockets werden pollend aus der SPS abgefragt. Mit diesem Parameter kann die Anzahl der pollenden Lesezugriffe und damit auch die Systemauslastung reduziert werden, besonders dann wenn nur selten Daten empfangen werden (z.B. Generalabfrage oder Uhrzeitsynchronisationsbefehle).
- FALSE: Nach jedem Lesezugriff folgt der nächste auch wenn keine neuen Daten empfangen wurden (höhere Systemauslastung);
- TRUE: Nach jedem Lesezugriff ,der keine neuen Daten liefert wird eine Verzögerung eingefügt. Der nächste Lesezugriff wird danach verzögert ausgeführt (kleinere Systemauslastung). Nach jedem Lesezugriff, der neue Daten liefert, wird der nächste ohne Verzögerung ausgeführt. Die max. Verzögerungszeit <= 2 Sekunden.
bPackFrames: Implementiert ab IEC870-5-104 slave library v2.0.4 und höher. Per Default wird mit einem TCP/IP-Send-Aufruf nur eine einzelne APDU verschickt. Wenn Sie diesen Parameter auf TRUE setzen, können Sie die Sende-Performance wesentlich erhöhen und so die Sende-Buffer-Überläufe verringern.
- FALSE: Für eine APDU wird ein TCP/IP-Send-Aufruf benötigt. Ca. alle 3 SPS-Zyklen kann max. eine APDU verschickt werden;
- TRUE: Mehrere APDUs werden zu einem größeren TCP/IP-Block (maximal aber iK-Frames) zusammengefasst und mit einem TCP/IP-Send-Aufruf verschickt;
bRetainBuffer: Implementiert ab IEC870-5-104 slave library v3.0.14 und höher. In der Standardeinstellung (FALSE) werden die internen Tc/Rx-Puffer beim Verbindungsabbruch gelöscht. Wenn dieses Flag auf TRUE gesetzt ist dann werden die noch nicht gesendeten ASDU's im internen Sendepuffer nicht gelöscht. Somit ist eine Offline-Pufferung von von ca. 100-200 Messwerten (abhängig von der ASDU-Größe) im RAM-Speicher möglich. Die Station entfernt immer dann die ASDUs aus dem Sendepuffer wenn deren Empfang bestätigt wurde. Bitte beachten Sie, dass die bereits gesendeten aber noch nicht bestätigten ASDUs auch im Puffer verbleiben und nächstes mal erneut gesendet werden. Möglicherweise empfängt die andere Station dann die Werte zwei Mal. Sie können dieses Verhalten über zwei weitere Parameter: bCOTFilter und cotFilter konfigurieren.
bCOTFilter: Implementiert ab IEC870-5-104 slave library v3.0.14 und höher. Aktiviert/deaktiviert die Filtermaske mit den Übertragungsursachen. Dieser Parameter ist nur dann gültig wenn auch der bRetainBuffer-Parameter auf TRUE gesetzt wurde. Bei jedem neuen Verbindungsaufbau wird intern eine SessionID hochgezählt. Diese SessionID wird immer an die empfangenen und gesendeten ASDUs angehängt. Dadurch können die ASDUs die noch nicht gesendet wurden und im Offline-Puffer verbleiben der alten Verbindung zugeordnet werden. Diese ASDUs können dann mit Hilfe der COT-Maske (cotFilter) gefiltert und verworfen werden (COT = cause of transfer). Dies ist manchmal notwendig wenn der andere Kommunikationspartner die wiederholten ASDUs nicht akzeptiert.
cotFilter: Implementiert ab IEC870-5-104 slave library v3.0.14 und höher. Filtermaske mit Übertragungsursachen (COT = Cause of transfer). Dieser Parameter ist nur dann gültig wenn auch der bRetainBuffer-Parameter und bCOTFilter-Parameter gesetzt wurde. Die Übertragungsursache der zu sendenden ASDUs wird nur dann geprüft wenn deren SessionID nicht zu der aktuellen SessionID passt (d.h. die ASDUs die aus der vorherigen Verbindung stammen). Jedes Bit entspricht einer Übertragungsursache. Die Übertragungsursache wird nur dann überprüft wenn das entsprechende Bit gesetzt wurde.
Die Übertragungsursachen sind auf folgende Weise in den Bits kodiert:
cotFilter[0].7 = eIEC870_COT_UNUSED
cotFilter[0].6 = eIEC870_COT_CYCLIC
cotFilter[0].5 = eIEC870_COT_BACKGROUND
cotFilter[0].4 = eIEC870_COT_SPONTAN
cotFilter[0].3 = eIEC870_COT_INIT
cotFilter[0].2 = eIEC870_COT_REQ
cotFilter[0].1 = eIEC870_COT_ACT
cotFilter[0].0 = eIEC870_COT_ACT_CON
cotFilter[1].7 = eIEC870_COT_DEACT
cotFilter[1].6 = eIEC870_COT_DEACT_CON
cotFilter[1].5 = eIEC870_COT_ACT_TERM
... usw.
Voraussetzungen
Entwicklungsumgebung | Zielplattform | Einzubindende SPS Bibliotheken |
---|---|---|
TwinCAT v2.9.0 Build >= 1030 | PC oder CX (x86) | TcIEC870_5_104.Lib ( Standard.Lib; TcBase.Lib; TcSystem.Lib; TcpIp.Lib; TcUtilities.Lib; TcSocketHelper.Lib; TcIEC870_5_101.Lib werden automatisch eingebunden ) |
TwinCAT v2.10.0 Build >= 1301 | CX (ARM) |