Devolver el número de kBytes libres en la tarjeta SD
Estas instrucciones FP calculan la capacidad libre en kilobytes disponible en la tarjeta SD y guardan el resultado en d_kBytes.
Salida
Número de kBytes libres
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.
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.
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 instrution*)
udiFreeSdSpace: UDINT:=0;
END_VAR
Cuando la variable bStart pasa de FALSE a TRUE, se ejecuta la función. Calcula el número de kBytes libres en la tarjeta y guarda el valor en d_kBytes.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 7 ;
NETWORK_BODY
B(B_F,FP_SD_GET_FREE_KBYTES!,,18,0,31,4,,?DEN?AENO?Cd_kBytes);
B(B_VAROUT,,udiFreeSdSpace,31,2,33,4,);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,1,12,3,N);
B(B_CONTACT,,bStart,2,1,4,3,);
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
IF bStart AND not sys_bIsSDMemoryAccessActive then
FP_SD_GET_FREE_KBYTES(udiFreeSdSpace);
END_IF;