Escribir datos binarios a una tarjeta SD
Estas instrucciones FP leen datos binarios de un área de memoria especificada por s_Start y n_Words y los escriben en un archivo de formato binario especificado por d_FIleNumber en la tarjeta SD. El nombre de directorio \data, y el nombre de archivo es dtxxx.bin donde "xxx" es el número de archivo.
Entrada
Dirección de inicio
Número de palabras
Salida
Número de archivo (0–999)
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.
Verificar que sys_bIsSDMemoryAccessDone es FALSE.
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.
Si la carpeta especificada no existe, se crea una carpeta nueva.
Si el archivo ya existe, se sobrescribirá.
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.
si el área especificada utilizando el modificador índice supera el límite.
si el área especificada utilizando el modificador índice supera el límite.
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.
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*)
dutValuesWrite: DUT_VALUES:=iValue := -32768,uiValue := 65535,diValue := -2157492,udiValue := 2333422234,rValue := 27.02,arrValue := [16#0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15],sStringValue := 'Test String 25 characters';
iFileNumberDut: INT:=2;
END_VAR
Cuando la variable bStart pasa de FALSE a TRUE, y la variable del sistema sys_bIsSDMemoryAccessActive no es TRUE, se ejecuta la función.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 11 ;
NETWORK_BODY
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,2,12,4,N);
B(B_CONTACT,,bStart,2,2,4,4,R);
B(B_F,FP_SD_WRITE_BIN!,,16,3,27,8,,?DEN?Ds_Start?Dn_Words?AENO?Cd_FileNumber);
B(B_VAROUT,,iFileNumberDut,27,5,29,7,);
B(B_F,Adr_Of_Var_I!,,9,5,16,7,,?D?C);
B(B_VARIN,,dutValuesWrite,7,5,9,7,);
B(B_F,Size_Of_Var!,,9,6,16,8,,?D?C);
L(9,6,9,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,11);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
FP_SD_WRITE_BIN(s_Start := Adr_Of_Var(dutValuesWrite),
n_Words := Size_Of_Var(dutValuesWrite),
d_FileNumber => iFileNumberDut);
END_IF;