Die CRC-Berechnung wird für die Fehlererkennung bei der Datenübertragung verwendet. Das Ergebnis einer Berechnung liefert einen CRC-Wert über die gesendeten Daten. Der Empfänger erkennt eine fehlerhafte Übertragung aufgrund des ungleichen CRC-Werts. Die Funktion LGF_CalcCRC32Advanced verwendet als Generatorpolynom (Maske) 32 Bit sowie die Parameter finalXorValue, reflectInput und reflectResult.
| LGF_CalcCRC32Advanced (FC) | ||||||||
|---|---|---|---|---|---|---|---|---|
| DWord | initValue | Ret_Val | DWord | |||||
| DWord | mask | |||||||
| DWord | finalXorValue | |||||||
| Bool | reflectInput | |||||||
| Bool | reflectResult | |||||||
| Array[*] of Byte | array | Array[*] of Byte | ||||||
| Bezeichner | Datentyp | Beschreibung |
|---|---|---|
| initValue | DWord | Startwert, mit dem die Berechnung durchgeführt wird. Wenn keinen Startwert notwendig ist - 16#00 zuweisen. |
| mask | DWord | Generatorpolynom, mit dem die Berechnung durchgeführt wird. (Maske / CRC Polynom) |
| finalXorValue | DWord | Wert, mit dem am Ende eine weitere XOR-Operation durchgeführt wird |
| reflectInput | Bool | TRUE: wird die Reihenfolge der Bits innerhalb des Eingangsbytes gespiegelt. Aus der Reihenfolge 0…7 wird 7…0. |
| reflectResult | Bool | TRUE: wird die Reihenfolge der Bits innerhalb des Ergebnisses gespiegelt. Aus der Reihenfolge 0…7 wird 7…0. |
| Bezeichner | Datentyp | Beschreibung |
|---|---|---|
| Ret_Val | DWord | Berechneter CRC-Wert (Rückgabewert der Funktion). |
| Bezeichner | Datentyp | Beschreibung |
|---|---|---|
| array | Array[*] of Byte | Datenstrom, für den der CRC-Wert berechnet werden soll. |
Die Funktion berechnet aus einem beliebig großen Datenstrom den CRC-Wert. Der Datenstrom setzt sich aus den einzelnen Elementen des Arrays am Ein- / Ausgangsparameter array zusammen. Der Startwert initValue und das Generatorpolynom mask sind frei wählbar.
Über die booleschen Eingangsparameter reflectInput und reflectResult können Sie optional die Bits der Eingangsdaten bzw. des CRC-Werts spiegeln. Außerdem wird mit dem CRC-Wert am Ende und dem Wert finalXorValue eine XOR-Operation durchgeführt.
mask (Polynom) und initValue (Initial Value) unterstützt:| Version & Datum | Änderungsbeschreibung | |
|---|---|---|
| 01.00.00 | Siemens Industry Online Support | |
| 03.07.2018 | First released version | |
| 01.00.01 | Siemens Industry Online Support | |
| 17.08.2018 | Upgrade: TIA V15 Update 2 | |
| 01.00.02 | Siemens Industry Online Support | |
| 23.11.2018 | Upgrade: TIA V15.1 | |
| 01.00.03 | Simatic Systems Support | |
| 09.10.2019 | Code refactoring, comments added | |
| 03.00.00 | Simatic Systems Support | |
| 23.04.2020 | Set version to V3.0.0, harmonize the version of the whole library | |
| 03.00.01 | Simatic Systems Support | |
| 12.11.2020 | Insert documentation Assign default start values to optional inputs - `initValue`, `mask`, `finalXorValue`, `reflectInput`, `reflectResult` | |