LGF_LIFO (FB / V3.0.1)


Autor: Siemens Industry Support

Kurzbeschreibung

LIFO (Last-In First-Out / Stack / Stapelspeicher)
Die Funktion speichert eingehende Daten und gibt die aktuellsten / letzten noch nicht abgearbeiteten Daten aus.

Baustein Schnittstelle

LGF_LIFO (FB)
Bool  push error  Bool
    
Bool  pop status  Word
    
Bool  peek subFunctionStatus  Word
    
Bool  reset elementCount  DInt
    
Bool  clear isEmpty  Bool
    
Variant  initialItem   
    
Variant  item  Variant
       
Variant  buffer  Variant
       
   

Input Parameter

BezeichnerDatentypDefault WertBeschreibung
pushBoolfalseDaten in den Puffer schieben
popBoolfalseDaten aus dem Puffer holen
peekBoolfalseDaten im Puffer ansehen (Der Puffer wird nicht verändert)
resetBoolFALSEPuffer initialisieren (Index und Zähler zurücksetzen)
clearBoolFALSEPuffer leeren und mit Anfangswert `initialItem` initialisieren (Index und Zähler zurücksetzen).
initialItemVariant---Wert mit dem das Array des Puffer initialisiert wird (meistens: `0` / default wert)

Output Parameter

BezeichnerDatentypBeschreibung
errorBoolFALSE: Kein Fehler
TRUE: Während der Ausführung des FB ist ein Fehler aufgetreten
statusWord16#0000-16#7FFF: Status des FB
16#8000-16#FFFF: Fehleridentifikation (siehe folgende Tabelle)
subFunctionStatusWordStatus oder Rückgabewert von aufgerufenen FB's / FC's und Systemfunktionen
elementCountDIntAnzahl der Elemente im Puffer
isEmptyBoolTRUE: Puffer ist leer

In/Out Parameter

BezeichnerDatentypBeschreibung
itemVariantEintrag der aus dem Puffer zurückgegeben wird oder in den Puffer geschrieben werden soll
bufferVariantDas ARRAY welches als Puffer genutzt wird. (Array of … )

Status & Error Meldungen

Code / WertBezeichner / Beschreibung
16#0000STATUS_NO_ERROR
Status: Abarbeitung ohne Fehler beendet
16#7000STATUS_NO_CURRENT_JOBS
Status: Keine aktuellen Aufträge, Initial State
16#8001ERR_BUFFER_EMPTY
Fehler: Der Puffer ist leer
16#8002ERR_BUFFER_FULL
Fehler: Der Puffer ist voll
16#8200ERR_NO_ARRAY
Fehler: Am Eingang `buffer` liegt kein Array an.
16#8201ERR_WRONG_TYPE_ITEM
Fehler: Der Datentyp des InOut-Parameters `item` entspricht nicht dem Datentyp der Array-Elemente von dem Eingang `buffer`.
16#8202ERR_WRONG_TYPE_INITIAL_ITEM
Fehler: Der Datentyp des Eingangs `initialItem` entspricht nicht dem Datentyp des InOut-Parameters `item`.
16#8610ERR_CLEAR_BUFFER
Fehler: Während des Ablöschen des Puffer in Funktion `MOVE_BLK_VARIANT` - weitere Infos in `subFunctionStatus`
16#8611ERR_RETURN_LAST_ENTRY
Fehler: Während der Rückgabe des letzten Elements aus dem Puffer in Funktion `MOVE_BLK_VARIANT` - weitere Infos in `subFunctionStatus` (POP & PEEK)
16#8612ERR_POP_REPLACE_ITEM_BY_INIT_VALUE
Fehler: Während des Überschreibens des Elements mit dem Initialwert in Funktion `MOVE_BLK_VARIANT` - weitere Infos in `subFunctionStatus (POP)
16#8613ERR_WRITE_ENTRY
Fehler: Während des Schreibens eines Elements in den Puffer in Funktion `MOVE_BLK_VARIANT` - weitere Infos in `subFunctionStatus` (PUSH)

Funktionsbeschreibung

Hinweis
In subFunctionStatus wird der Status von aufgerufenen Anweisungen ausgegeben. Der Ausgangswert in status gibt in diesem Fall an, welche Anweisung den Fehler verursacht hat. Holen Sie sich in diesem Fall die Informationen aus der TIA Portal Online Hilfe zu den jeweiligen Anweisungen.

Hinweis
Der Stack in der Informatik beruht ebenfalls auf dem LIFO-Prinzip.

Mit dem Eingang push wird ein neues Element vom InOut-Parameter item an der nächsten freien Stelle im Puffer gespeichert. Der Ausgang elementCount wird um eins inkrementiert.

Mit dem Eingang pop wird am InOut-Parameter item das aktuellste / letzte Element ausgegeben und dieses Feld im Puffer durch den Wert am Parameter initialItem ersetzt. Der Ausgang elementCount wird um eins dekrementiert.

Der Eingang peek ermöglicht das Auslesen des letzten Eintrags im Puffer. Der Puffer wird dabei nicht verändert.

Mit dem Eingang reset wird der Puffer initialisiert, Index und Zähler werden zurückgesetzt. Der Ausgang elementCount wird auf null und der Ausgang isEmpty wird auf TRUE gesetzt.

Mit dem Eingang clear wird der Puffer geleert und mit Anfangswert initialItem initialisiert. Index und Zähler werden zurückgesetzt. Der Ausgang elementCount wird auf null, der Ausgang isEmpty auf TRUE gesetzt.

Änderungshistorie

Version & DatumÄnderungsbeschreibung
01.00.00Siemens Industry Online Support
10.07.2018First released version
01.00.01Siemens Industry Online Support
17.08.2018Upgrade: TIA V15 Update 2
01.00.02Siemens Industry Online Support
23.11.2018Upgrade: TIA V15.1
02.00.00Siemens Industry Online Support
29.01.2019Output "done" removed (not necessary, because block works synchron)
03.00.00Simatic Systems Support
22.10.2019Code refactoring, comments added
Interface change (push, pop, peek etc.)
Set version to V3.0.0, harmonize the version of the whole library
03.00.01Simatic Systems Support
15.02.2021Insert documentation