FP_SD_WRITE

Escribir datos a una tarjeta SD

Estas instrucciones FP leen el número de datos especificado por n_NumberOfDataToWrite guardado en la dirección de inicio con s_Start y escriben los datos en el archivo especificado por d1_FullFileName en la tarjeta SD. La DUT FP_SD_WRITE_DUT at d2_dutWrite especifica los parámetros de escritura.

Parámetros

Entrada

s_Start (ANY)

Dirección de inicio

n_NumberOfDataToWrite (WORD, INT, UINT)

Número de datos a escribir, especificado por el elemento de la DUT udiNumberOfDataWritten

  • Para wFormat=1–8: Número de datos de 16/32 bits separados por coma

  • Para wFormat=10: Número de caracteres de 8 bits

  • Para wFormat=11: Número de datos de 16 bits

d1_FullFileName (STRING)

Nombre de archivo con extensión, por ejemplo '\Test.csv'

Entrada/salida

d2_dutWrite (FP_SD_WRITE_DUT)

Formato de escritura, modo de escritura, posición del puntero, etc.

Modo de puntero

Si se ha seleccionado un modo de puntero en FP_SD_WRITE_DUT de s2_dutWrite (wMode=2 o wMode=3), la escritura comienza en la posición del puntero. Después de la escritura, el puntero se mueve a la posición donde ha finalizado la escritura. La siguiente operación de escritura comienza desde este punto. La posición del puntero también puede especificarse por udiBytePosition en la DUT. En el ejemplo inferior, se indican posiciones del puntero del archivo para diferentes formatos de datos.

  1.  (1) Datos INT de 16 bits (archivo de formato BIN)
  2.  (2) Datos INT de 16 bits (archivo de formato CSV)
  3.  (3) Datos ASCII (archivo de formato CSV)
  4.  (4) Puntero del archivo

Observaciones

  • Consultar también Introducción a las instrucciones de la tarjeta SD.

  • La bandera "acceso a memoria SD en proceso" (sys_bIsSDMemoryAccessActive) pasa a TRUE después de la que la entrada de trigger EN de las instrucciones de la tarjeta SD haya pasado a TRUE y continúe en TRUE hasta concluir la ejecución. En este intervalo, no se pueden ejecutar otras instrucciones de la tarjeta SD.

  • La bandera "acceso a memoria SD finalizada" (sys_blsSDMemoryAccessDone) es FALSE cuando se ejecuta la instrucción y pasa a TRUE y se mantiene TRUE después de concluir la instrucción.

  • Cuando el atributo del archivo sea de solo lectura, no pueden escribirse datos.

  • Al guardar datos ASCII, las cadenas de caracteres escritas se sitúan entre comillas dobles.

  • Una comilla doble (") en cadenas de caracteres se convierte a dos comillas dobles ("").

Banderas de error

sys_bIsSDMemoryAccessError
  • FALSE: cuando la instrucción ha finalizado sin errores

  • TRUE: cuando la instrucción ha finalizado con un error

  • Utilizar sys_iSDMemoryAccessErrorCode para evaluar el código de error.

sys_bIsOperationErrorHold (pasa a TRUE y permanece TRUE)
  • si el área especificada utilizando el modificador índice supera el límite.

sys_bIsOperationErrorNonHold (pasa a TRUE para un ciclo de scan)
  • si el área especificada utilizando el modificador índice supera el límite.

Ejemplo

Cabecera de la POU

Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU.Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.

	VAR
		bStart: BOOL:=FALSE;
			(*activates the instruction*)
		sStringWrite1: STRING[32]:='Test String1';
	END_VAR

Cuerpo de la POU

Cuando la variable bStart pasa de FALSE a TRUE, y la variable del sistema sys_bIsSDMemoryAccessActive no es TRUE, se ejecuta la función.

Cuerpo LD

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 3 ;
        NETWORK_BODY
B(B_COMMENT,,ø^Write string ASCII data into SD card memory - ASCII value,3,0,58,3,);
L(1,0,1,3);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 4 ;
        NETWORK_BODY
B(B_CONTACT,,bStart,2,1,4,3,R);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,1,12,3,N);
B(B_F,E_MOVE!,,18,0,24,4,,?DEN?D?AENO?C);
B(B_VARIN,,10,16,2,18,4,);
B(B_VAROUT,,dutFpWriteTest_csv.wFormat,24,2,26,4,);
L(1,2,2,2);
L(4,2,10,2);
L(12,2,18,2);
L(1,0,1,4);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 7 ;
        NETWORK_BODY
B(B_VARIN,,sStringWrite,16,2,18,4,);
B(B_CONTACT,,bStart,2,1,4,3,R);
B(B_VARIN,,sFile_Test_Csv,16,4,18,6,);
B(B_VARIN,,dutFpWriteTest_csv,16,5,18,7,);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,1,12,3,N);
B(B_F,FP_SD_WRITE!,,18,0,31,7,,?DEN?Ds_Start?Dn_NumberOfDataToWrite?Dd1_FullFileName?Dd2_dutWrite?Ad2_dutWrite?AENO);
B(B_VARIN,,iStringLength,16,3,18,5,);
L(1,2,2,2);
L(4,2,10,2);
L(12,2,18,2);
L(1,0,1,7);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Cuerpo en ST

IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
    dutFpWriteTest_csv.wFormat:=10;
    FP_SD_WRITE(s_Start := sStringWrite,
                n_NumberOfDataToWrite := iStringLength,
                d1_FullFileName := sFile_Test_Csv,
                d2_dutWrite := dutFpWriteTest_csv);
END_IF;

Modificado el: 2024-03-07Comentarios sobre esta páginaLínea directa de Panasonic