FP_READ_FROM_SLAVE

Lire les données de l’esclave

Utilisez cette instruction pour lire les données d’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_READ_FROM_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.

Paramètres

Entrée

Port (WORD, INT, UINT)

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

StationNumber (WORD, INT, UINT)

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

SlaveAddress (WORD, INT, UINT)

Adresse source de l’esclave à partir de laquelle les données sont lues.

Sortie

Destination (ANY)

Zone de mots ou registre du maître vers lequel les données lues sont écrites.

Result (ANY)

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

Chronogramme

  1.  (1) Drapeau "Effacer pour envoi" de la communication maître, par ex. sys_bIsEthernetUserConnection1MasterCommunication
  2.  (2) Vérifier que le drapeau "Effacer pour envoi" de la communication maître est TRUE et que le drapeau d’envoi de la communication maître est FALSE
  3.  (3) Drapeau d’envoi de la communication maître, par ex. sys_bIsEthernetUserConnection1MasterCommunicationActive

    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

  4.  (4) Exécuter cette instruction
  5.  (5) Drapeau "Envoi terminé" de la communication maître, par ex. sys_bIsEthernetUserConnection1CommunicationError

    Exécution terminée normalement : FALSE

    Exécution terminée anormalement : TRUE

  6.  (6) Envoyer les données
  7.  (7) Traitement de la réponse reçue

Drapeaux d’erreur

sys_bIsOperationErrorHold (passe à TRUE et reste TRUE)
  • Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.

  • Si les données de l’esclave ou du maître sont en dehors de la plage d’adresses disponible.

  • Si le mode de communication n’est pas défini sur MEWTOCOL-COM Maître/Esclave ou Modbus RTU Maître/Esclave.

  • Si le port COM sélectionné requiert une cassette de communication qui n’a pas été installée.

sys_bIsOperationErrorNonHold (passe à TRUE pendant un cycle)
  • Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.

  • Si les données de l’esclave ou du maître sont en dehors de la plage d’adresses disponible.

  • Si le mode de communication n’est pas défini sur MEWTOCOL-COM Maître/Esclave ou Modbus RTU Maître/Esclave.

  • Si le port COM sélectionné requiert une cassette de communication qui n’a pas été installée.

Exemple

GVL

Dans la liste des variables globales, vous définissez des variables qui sont accessibles par tous les POU dans le projet.

En-tête du POU

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_EXTERNAL
		g_Peripherie_SlaveResult_Address: ARRAY[0..9] OF REAL:=[10(0)];
	END_VAR
	VAR
		bReadResult: BOOL:=FALSE;
		wReadFromSlaveResult: WORD:=0;
			(*result of write to slave instruction*)
		iSlaveStationNumber: INT:=0;
			(*slave station number*)
		arrResults: ARRAY [0..9] OF REAL:=[10(0.0)];
			(*Array of results to be read from slave station*)
		iSlaveMemoryArea: INT:=5;
			(*memory Area in slave station*)
		iSlaveMemoryOffset: INT:=100;
		iSlaveMemorySize: INT:=1;
	END_VAR

Corps en LD

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 8 ;
        NETWORK_BODY
B(B_VARIN,,SYS_COM1_PORT,19,2,21,4,);
B(B_VARIN,,iSlaveStationNumber,19,3,21,5,);
B(B_CONTACT,,bReadResult,8,1,10,3,);
B(B_VAROUT,,wReadFromSlaveResult,38,3,40,5,);
B(B_VAROUT,,arrResults,38,2,40,4,);
B(B_F,FP_READ_FROM_SLAVE!,,21,0,33,6,,?DEN?DnPort?DStationNumber?DSlaveAddress?AENO?CDestination?CResult);
B(B_VARIN,,g_Peripherie_SlaveResult_Address,19,4,21,6,);
L(1,2,8,2);
L(10,2,21,2);
L(33,3,38,3);
L(33,4,38,4);
L(1,0,1,8);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Corps en ST

if (bReadResult) then
    FP_READ_FROM_SLAVE(Port := SYS_COM1_PORT, StationNumber := iSlaveStationNumber,
                       SlaveAddress := g_Peripherie_SlaveResult_Address, Destination => arrResults[0], 
                       Result => wReadFromSlaveResult);
end_if;

Modifié le : 2024-10-23Commentaires sur cette pageAssistance téléphonique