SD 카드의 여유 kByte 수 반환
이 FP 명령은 SD 카드에서 사용 가능한 여유 용량(kByte)을 계산하고 d_kBytes에 결과를 저장합니다.
출력
여유 kByte 수
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 카드의 여유 kByte 수를 계산하고 값을 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;