ret = read(fd, buf, len)에서 반환하는 값인 ret은 다음과 같이 4가지 경우가 있을 수 있습니다.
(1) ret == len 인 경우: len 크기의 모든 바이트를 읽어서 buf에 저장함.
(2) 0 < ret < len 인 경우: 읽는 도중에 중단된 경우 혹은 len 크기를 모두 읽기전에 EOF에 도달한 경우.
(3) ret == 0 인 경우: EOF 이거나 읽을 데이터가 없는 경우.
(4) ret == -1 인 경우: 오류 발생.
참고로, 아래는 read()를 좀더 완벽하게 하는 코드 입니다.
ssize_t ret;
while (len != 0 && (ret = read (fd, buf, len)) != 0) {
if (ret == -1) {
if (errno == EINTR) continue;
perror ("read(): error");
break;
}
len -= ret;
buf += ret;
}
From:
*알지비 (메일: rgbi3307(at)nate.com)
*커널연구회(http://www.kernel.bz/) 내용물들을 만들고 있음.
*((공부해서 남을 주려면 남보다 더많이 연구해야함.))
read(g_rx_socket,...) 하기 전에,
아래 함수 사용이 해답이 될수 있을듯...
sync()
fsync()
fdatasync()
fflush()
From:
*알지비 (메일: rgbi3307(at)nate.com)
*커널연구회(http://www.kernel.bz/) 내용물들을 만들고 있음.
*((공부해서 남을 주려면 남보다 더많이 연구해야함.))
관련 설명 읽어보니..
위에 명령어들은 buffer를 flush 하는것은 맞는데
buffer 내용을 disk에 쓴다고 하네요...
제가 원하는것은 그냥 flush만 하면될것같고
참고로 V210 개발보드에서 작업하여 disk는 따로 존재하지 않습니다.
혹시나 해서 fflush()를 한번 사용해보니
에러가 발생하네요...
SEGV
read()에서 반환되는 값을 통해서 오류를 점검해 보세요.
ret = read(fd, buf, len)에서 반환하는 값인 ret은 다음과 같이 4가지 경우가 있을 수 있습니다.
(1) ret == len 인 경우: len 크기의 모든 바이트를 읽어서 buf에 저장함.
(2) 0 < ret < len 인 경우: 읽는 도중에 중단된 경우 혹은 len 크기를 모두 읽기전에 EOF에 도달한 경우.
(3) ret == 0 인 경우: EOF 이거나 읽을 데이터가 없는 경우.
(4) ret == -1 인 경우: 오류 발생.
참고로, 아래는 read()를 좀더 완벽하게 하는 코드 입니다.
From:
*알지비 (메일: rgbi3307(at)nate.com)
*커널연구회(http://www.kernel.bz/) 내용물들을 만들고 있음.
*((공부해서 남을 주려면 남보다 더많이 연구해야함.))
특정 시점에 Rx 을 했다고 하셨는데, 무슨
특정 시점에 Rx 을 했다고 하셨는데, 무슨 말씀이신지? WIFI 의 rx interrupt 을 enable 하셨다는 말씀이세요 아니면 read(2) 을 호출하였다는 말씀이신지..?
rx -> read라고 가정하고, socket이든
rx -> read라고 가정하고, socket이든 아니든, input buffer를 flush?하는 것은 불가능합니다. 좀 더 정확히 말하면, flush란 말은 output buffer에만 적용될 수 있는 용어입니다.
input buffer를 지우고 싶다면 읽어서 지우는 방법밖에 없습니다.
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
댓글 달기