FB_BACnet_ReadProp

Funktionsbaustein für den Zugriff auf BACnet Properties über ADS. Sämtliche BACnet Properties, die im Online-Reiter des jeweiligen BACnet-Objekts angezeigt werden, von Server und Client Objekten können über ADS gelesen bzw. geschrieben werden. Wird auf einen Client (entfernter BACnet-Server) über ADS zugegriffen, dann werden die ADS Zugriffe in BACnet-Abfragen umgewandelt und an den entfernten Server gesendet.

FB_BACnet_ReadProp 1:

Anwendung

Die Bausteininstanz wird im SPS Programm angelegt und zyklisch aufgerufen. Der Eingang BACnetDevicePort und sNetId muss mit dem entsprechenden AMS Port und NetID belegt werden. Der AMS Port und NetID können für jeden BACnet-Server und -Client über den zugehörigen BACnet-Device Baustein abgefragt werden.

FB_BACnet_ReadProp 2:

Die AMS NetID entspricht nicht der lokalen AMS NetID und muss immer angegeben werden - keine Verwendung von Leerstrings möglich!

Die aktuelle AMS NetID und AMS Port werden vom zugehörigen FB_BACnet_Device bzw. FB_BACnet_RemoteDevice ausgegeben:

FB_BACnet_ReadProp 3:
Bild-1: FB_BACnet_Device → stAdsConn gibt die aktuellen ADS Verbindungsdaten aus.

AMS NetId und AMS Port in der Ausgabe-Struktur stAdsConn des Device Bausteins.

TYPE ST_BACnet_AdsConnection: 
  STRUCT 
    bValid     : BOOL;
    nReload    : USINT;
    sAmsNetId  : T_AmsNetId;
    nAmsPort   : T_AmsPort;
    bServer    : BOOL;
    bClient    : BOOL;
    bNSink     : BOOL;
    nDeviceId  : UDINT;
  END_STRUCT
END_TYPE

Zudem kann der AMS Port und die AMS NetID im TwinCAT System Manager angezeigt werden (siehe Bild-3 und -4). Je nach Konfiguration können Ports für Server und Client variieren.

FB_BACnet_ReadProp 4:
Bild-3: AMS Port des lokalen BACnet Server im System Manager
FB_BACnet_ReadProp 5:
Bild-4: AMS NetId des BACnet Device

VAR_INPUT

BACnetDevicePort  : UINT:=16#FFFF;
bExecute          : BOOL;
sNetId            : T_AmsNetId;
ObjectType        : E_BACNETOBJECTTYPE;
PropertyID        : E_BACNETPROPERTYIDENTIFIER;
DataType          : E_BACNETDATATYPES;
ObjectInstance    : DINT;
ptrValue          : POINTER TO BYTE;
nLenValue         : UDINT;

 

BACnetDevicePort: AMS Port unter dem das gewünschte Objekt angelegt wurde.

bExecute: Steigende Flanke am Eingang startet den Lesevorgang. Fallende Flanke löscht den Ausgang bDone.

sNetId: AMS NetId des BACnet Devices (Adapter) unter dem der Server bzw. Client konfiguriert wurde.

ObjectType: Enumeration des Objekttypes (AnalogValue, BinaryInput...).

PropertyID: Enumeration des Property-Identifiers (Present_Value, Status_Flags...).

DataType: Datentyp der Property (Bool, BinaryPV, Real, Unsigned Integer...).

ObjectInstance: Objekt-Nummer des BACnet Objekts (die unteren 22 Bit des Object_Identifier).

ptrValue: Zeiger auf die Variable in der die gelesenen Daten abgelegt werden sollen (zu ermitteln mit ADR()).

nLenValue: Byte-Länge der Variable in der die gelesenen Daten abgelegt werden sollen (zu ermitteln mit SIZEOF()).

 

VAR_OUPUT

bDone         : BOOL;
bBusy         : BOOL;
bError        : BOOL;
nErrID        : UDINT;
nProcessedLen : UDINT;

 

bDone: Lesen der Daten erfolgreich beendet. bDone bleibt so lange gesetzt bis bExecute zurückgesetzt wird. Wurde bExecute zurück gesetzt bevor bDone aktiv ist, dann wird bDone für einen Zyklus gesetzt.

bBusy: Der Baustein ist beschäftigt.

bError: Fehler während der Abarbeitung.

nErrID: ADS Fehlercode.

nProcessedLen: Byte-Länge der gelesenen Daten. Die Länge kann sich von der Ziellänge nLenValue unterscheiden (kleiner/gleich). Die Lücke zwischen der Eingangsdatenlänge nLenValue und der tatsächlich gelesen Datenlänge nProcessedLen wird im übergebenen Datenbereich mit "Nullen" aufgefüllt.

Beispiel

FB_BACnet_ReadProp 6:
Bild-5: Beispiel für die Verwendung. Lesen der Property Present_Value eines BACnet Binary Input Objekts.