FP_SD_READ_BIN

Leer datos binarios de una tarjeta SD

Estas instrucciones FP leen el número de palabras especificado por n_Words de un archivo de formato binario especificado por el número de archivo s_FileNumber en la tarjeta SD. El nombre de directorio es \data, y el nombre de archivo es dtxxx.bin donde "xxx" es el número de archivo. El resultado se guarda en el área especificada por d_Start. El código ASCII necesita 8 bits (1 byte) para representar 1 carácter BCD. Después de la conversión a ASCII, la longitud de los datos será por tanto el doble de la longitud de los datos de origen.

Parámetros

Entrada

s_FileNumber (WORD, INT, UINT)

Número de archivo (0–999)

n_Words (WORD, INT, UINT)

Número de palabras (0–65535)

Salida

d_Start (WORD, INT, UINT)

Dirección de inicio

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.

  • No leer los datos del área de salida hasta que la ejecución de la instrucción no haya concluido.

  • Si no hubiera ningún directorio \data o si en el directorio no existiera ningún archivo con el número de archivo especificado, se produce un error.

  • Si el número de datos en el archivo es inferior al número de de datos a leer, los datos se leen hasta el número de datos del archivo.

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

DUT

Con un Tipo de Datos Estructurados (DUT) se puede definir un tipo de dato compuesto por otros tipos de datos. Una DUT se define primero en el repositorio de DUTs y, seguidamente, se procesa como los tipos de datos estándar (BOOL, INT, etc.) en la lista de variables globales o la cabecera de la POU.

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*)
		dutValuesRead: DUT_VALUES;
		iFileNumberDut: INT:=2;
	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

eneral">BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 9 ;
        NETWORK_BODY
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,2,12,4,N);
B(B_CONTACT,,bStart,2,2,4,4,R);
B(B_VARIN,,iFileNumberDut,14,5,16,7,);
B(B_F,FP_SD_READ_BIN!,,16,3,27,8,,?DEN?Ds_FileNumber?Dn_Words?AENO?Cd_Start);
B(B_F,Size_Of_Var!,,9,6,16,8,,?D?C);
B(B_VARIN,,dutValuesRead,7,6,9,8,);
B(B_F,Adr_Of_Var_O!,,27,5,35,7,,?D?C);
B(B_VAROUT,,dutValuesRead,35,5,37,7,);
L(1,3,2,3);
L(4,3,10,3);
L(12,3,12,5);
L(12,5,16,5);
L(1,0,1,9);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Cuerpo en ST

IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
    FP_SD_READ_BIN(s_FileNumber := iFileNumberDut,
                   n_Words := Size_Of_Var(dutValuesRead),
                   d_Start => Adr_Of_Var(dutValuesRead));
END_IF;

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