Écrire des données vers l’esclave
Utilisez cette instruction pour écrire les données d’un maître vers un esclave via le port de communication avec le protocole MEWTOCOL ou Modbus RTU, selon les paramètres définis dans les registres système du port utilisé. Le maître et l’esclave doivent être définis avec le même protocole. Le maître et l’esclave doivent avoir des zones de mémoire correspondantes. Si les données de l’esclave ne sont pas disponibles dans la zone utilisateur du maître, utilisez FP_WRITE_TO_SLAVE_AREA_OFFS ou FP_MODBUS_MASTER.
Pour les transferts de données à l’aide du protocole Modbus, le compilateur génère des commandes Modbus basées sur les adresses Modbus.Entrée
Indique les ports de communication (selon le type d’API) :
Port COM, par ex. SYS_COM0_PORT
Port Ethernet, par ex. SYS_ETHERNET_USER_CONNECTION_1
MCU/SCU, par ex. 16#xx01 (xx = numéro du connecteur) dans COM01
Numéro de station de l’esclave (MEWTOCOL : 1-99, MODBUS : 1-247)
Défini sur 1, si SYS_ETHERNET_USER_CONNECTION_xx est appliquée à l’entrée Port
Zone de mots ou registre sur le maître pour les données à écrire vers l’esclave.
Sortie
Adresse de destination de l’esclave vers laquelle les données sont écrites.
Pour FP7 uniquement : Vous trouverez une description de tous les codes d’erreur dans le tableau des codes d’erreur de communication Modbus/MEWTOCOL.
Pour les autres automates : défini sur 0
Envoi en cours : Drapeau d’envoi de la communication maître est TRUE
Envoi terminé : Drapeau d’envoi de la communication maître est FALSE
Exécution terminée normalement : FALSE
Exécution terminée anormalement : TRUE
Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.
Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.
Si le port COM sélectionné requiert une cassette de communication qui n’a pas été installée.
Dans la liste des variables globales, vous définissez des variables qui sont accessibles par tous les POU dans le projet.
Toutes les variables d’entrée et de sortie utilisées pour programmer cette fonction ont été déclarées dans l’en-tête du POU. Le même en-tête de POU est utilisé pour tous les langages de programmation.
VAR
wWriteToSlaveResult: WORD:=0;
(*result of write to slave instruction*)
iSlaveStationNumber: INT:=0;
(*slave station number*)
arrParameters: ARRAY [0..15] OF DINT;
(*Array of parameters to be send to slave station*)
bSetParameters: BOOL:=FALSE;
END_VAR
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
B(B_F,FP_WRITE_TO_SLAVE!,,19,0,30,6,,?DEN?DnPort?DStationNumber?DSource?AENO?CSlaveAddress?CResult);
B(B_VARIN,,SYS_COM2_PORT,17,2,19,4,);
B(B_VARIN,,iSlaveStationNumber,17,3,19,5,);
B(B_VARIN,,arrParameters,17,4,19,6,);
B(B_VAROUT,,g_Peripherie_SlaveParameter_Address,30,2,32,4,);
B(B_VAROUT,,wWriteToSlaveResult,30,3,32,5,);
B(B_CONTACT,,bSetParameters,4,1,6,3,);
L(1,2,4,2);
L(6,2,19,2);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
if bSetParameters then
FP_WRITE_TO_SLAVE(Port := SYS_COM2_PORT,
StationNumber := iSlaveStationNumber,
Source := arrParameters,
SlaveAddress => g_Peripherie_SlaveParameter_Address,
Result => wWriteToSlaveResult);
end_if;