FB_DMXDiscUniqueBranch
Dieser Funktionsbaustein fragt ab, ob sich innerhalb eines bestimmten Adressbereichs DMX-Geräte befinden. Dieser Befehl findet Verwendung beim Ermitteln (Discovery) der angeschlossenen DMX-Geräte.
Durch eine positive Flanke am Eingang bStart wird der Baustein gestartet und der Ausgang bBusy geht auf TRUE. Die Eingänge wLowerBoundManufacturerId, dwLowerBoundDeviceId, wUpperBoundManufacturerId und dwUpperBoundDeviceId definieren den Adressbereich, in dem DMX-Geräte gesucht werden. Der Eingang byPortId definiert den Kanal innerhalb des adressierten DMX-Gerätes. Ist die Ausführung des Befehls abgeschlossen, geht der Ausgang bBusy wieder auf FALSE. Die Ausgänge bError, udiErrorId, wReceivedManufacturerId und dwReceivedDeviceId können jetzt ausgewertet werden. Solange der Baustein aktiv ist (bBusy ist TRUE) werden weitere positive Flanken am Eingang bStart ignoriert.
Liegt im definierten Adressbereich nur ein DMX-Gerät, so werden über die Ausgänge wReceivedManufacturerId und dwReceivedDeviceId die 48-Bit UID des DMX-Gerätes zurückgegeben. Liegen in diesem Bereich keine DMX-Geräte, so ist der Ausgang bError auf TRUE und udiErrorId ist auf 0x8002 (keine Antwort vom DMX-Gerät). Befinden sich in dem Adressbereich zwei oder mehr DMX-Geräte, so ist bError auf TRUE und udiErrorId enthält eine 0x8006 (Checksummenfehler).
VAR_INPUT
bStart : BOOL;
byPortId : BYTE;
wLowerBoundManufacturerId : WORD;
dwLowerBoundDeviceId : DWORD;
wUpperBoundManufacturerId : WORD;
dwUpperBoundDeviceId : DWORD;
dwOptions : DWORD := 0;
bStart: Über eine positive Flanke an diesem Eingang wird der Befehl gestartet.
byPortId: Kanal innerhalb des adressierten DMX-Gerätes. Untergeräte (Sub-Devices) werden durch die Port-Id adressiert. Das Hauptgerät (Root-Device) hat immer die Port-Id 0.
wLowerBoundManufacturerId: Eindeutige Hersteller-Id vom unteren Adressbereichs.
dwLowerBoundDeviceId: Eindeutige Geräte-Id vom unteren Adressbereichs.
wUpperBoundManufacturerId: Eindeutige Hersteller-Id vom oberen Adressbereichs.
dwUpperBoundDeviceId: Eindeutige Geräte-Id vom oberen Adressbereichs.
dwOptions: Optionen (wird derzeit nicht benutzt).
VAR_OUTPUT
bBusy : BOOL;
bError : BOOL;
udiErrorId : UDINT;
wReceivedManufacturerId : WORD;
dwReceivedDeviceId : DWORD;
bBusy: Bei der Aktivierung des Bausteins wird der Ausgang gesetzt und bleibt so lange aktiv, bis der Befehl abgearbeitet wurde.
bError: Dieser Ausgang wird auf TRUE geschaltet, wenn bei der Ausführung eines Befehls ein Fehler aufgetreten ist. Der befehlsspezifische Fehlercode ist in udiErrorId enthalten. Nur gültig, wenn bBusy auf FALSE ist.
udiErrorId: Enthält den befehlsspezifischen Fehlercode des zuletzt ausgeführten Befehls. Nur gültig, wenn bBusy auf FALSE ist. Siehe Fehlercodes.
wReceivedManufacturerId: Ist die Abarbeitung des Befehls abgeschlossen (bBusy ist FALSE), so wird an diesem Ausgang der Zustand der Identifizierung von dem DMX-Gerät angezeigt.
dwReceivedDeviceId: Ist die Abarbeitung des Befehls abgeschlossen (bBusy ist FALSE), so wird an diesem Ausgang der Zustand der Identifizierung von dem DMX-Gerät angezeigt.
VAR_IN_OUT
stCommandBuffer : ST_DMXCommandBuffer;
stCommandBuffer: Verweis auf die Struktur zur Kommunikation (Puffer) mit dem FB_EL6851CommunicationEx()-Baustein.