返回SD卡上的空闲千字节数
此FP指令以千字节计算SD卡上可用的空闲容量,并将结果存储在d_kBytes中。
输出
千字节数
也请参阅有关SD卡访问的注意事项。
在SD存储卡指令的触发器EN变为TRUE后,SD存储访问活动标志(sys_bIsSDMemoryAccessActive)变为TRUE,并保持为TRUE直到执行完成。在此期间,无法执行其他SD存储卡指令。
执行指令时,SD存储访问完成标志(sys_blsSDMemoryAccessDone)为FALSE,指令完成后变为TRUE并保持TRUE。
FALSE:指令完成且没有错误时
TRUE:指令完成但有错误时
使用sys_iSDMemoryAccessErrorCode评估错误代码。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*activates the instrution*)
udiFreeSdSpace: UDINT:=0;
END_VAR
当变量bStart从FALSE变为TRUE时,执行此函数。它计算SD卡上的空闲千字节数,并将值存储在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;