read system call을 썼는 데 count보다 많이 받았을 때는 어떻게
글쓴이: 익명 사용자 / 작성시간: 화, 2002/06/25 - 10:19오전
ssize_t read(int fd, void *buf, size_t count);
어셈으로 작업중입니다만은 세번째 시스템콜이나 read함수나 같은 것일 테
니 read함수로 질문을 합니다. ^^;;
어셈은 보기가 않좋아서....
Standard input으로 read함수를 썼는 데 count보다 많이 받으면 count많큼
은 buf에 저장이 되고 나머지는 리눅스가 키보드 버퍼에 저장을 하는 것
같은 데요.
문제는 다음 번에 또 read함수를 호출하면 새로 입력을 받는 게 아니라 아
까 키보드 버퍼에 저장된 내용을 받게 되더라구요.
키보드 버퍼의 내용을 다 지울수 있는 방법은 없나요?
Forums:
man fflush (내용없음).
.
질문
yootiong wrote..
ssize_t read(int fd, void *buf, size_t count);
어셈으로 작업중입니다만은 세번째 시스템콜이나 read함수나 같은 것 일 테
니 read함수로 질문을 합니다. ^^;;
커널 드라이버를 만드시는 건가요?
아니면 user app 를 어셈으로 만드시면서 int 80 을 이용하시는
것인가요?
만약 user app 를 만드시는 것이라면, 아래에 답변해 주신분과
답이 같습니다.
커널 드라이버라면,
tty_driver.flush_buffer() 나
tty_driver.flush_char() 를 이용하시면 되겠군요
fflush는 C Library군요....
커널 드라이버를 만드시는 건가요?
아니면 user app 를 어셈으로 만드시면서 int 80 을 이용하시는
것인가요?
user app를 만드는 겁니다.
만약 user app 를 만드시는 것이라면, 아래에 답변해 주신분과
답이 같습니다.
fflush는 C Library던데...
glibc를 분석해봐야 할 것 같군요.
순수하게 assembly로 만들고 싶어 서요 ^^;;
순수한 어셈블리도 좋은 경험이 되겠지만
Assembly-HOWTO 를 한번 읽어보세요.
제 생각은 그 문서의 저자의 생각과 같습니다.
물론, 매우 작은 시스템, 혹은,
프로세서에 매우 의존적인 부분
(context switch, processor mode change등등)은
어셈으로 구현할 수 밖에 없지만,
C 라이브러리를 호출하여 사용해야 하는 상황에서까지
어셈을 고집한다는 것은... 한번쯤은 좋은 경험이 되겠지만,
언제나 그렇게 한다는것은 시간과 정력의 낭비라고 봅니다 D
화이팅입니다.
열심히 하세요
glibc 의 라이브러리를 호출하려면,
라이브러리 내부의 심볼도 알아야 하고,
gcc 의 linking 규칙, object 생성 규칙,
ELF 파일 구조같은거 까지 상세하게 꿰고 있어야 하겠군요.
도전하려는 정신이 보기 좋습니다. 저에게는 없는 걸 가지고 계시네요
D
Re^4: 순수한 어셈블리도 좋은 경험이 되겠지만
Assembly-HOWTO 를 한번 읽어보세요.
제 생각은 그 문서의 저자의 생각과 같습니다.
물론, 매우 작은 시스템, 혹은,
프로세서에 매우 의존적인 부분
(context switch, processor mode change등등)은
어셈으로 구현할 수 밖에 없지만,
C 라이브러리를 호출하여 사용해야 하는 상황에서까지
어셈을 고집한다는 것은... 한번쯤은 좋은 경험이 되겠지만,
언제나 그렇게 한다는것은 시간과 정력의 낭비라고 봅니다 D
화이팅입니다.
열심히 하세요
제가 프로그램을 만드는 이유, 컴퓨터를 만지고 있는 그 이유는 돈을 많
이 벌고 싶어서도 남들에게 인정받고 싶어서도 아닙니다.
컴퓨터라는 것이 어떻게 움직이는 건지 알고 싶고 사실 지금은 "해커, 그
광기와 비밀의 기록"이라는 책을 보고... )
컴퓨터를 직접 컨트롤하는 데 어셈보다 좋은 언어가 어디있겠습니까 )
OS도 빨리 만들어 봐야 되는 데...실력이 없어서... ^^;;
glibc 의 라이브러리를 호출하려면,
라이브러리 내부의 심볼도 알아야 하고,
gcc 의 linking 규칙, object 생성 규칙,
ELF 파일 구조같은거 까지 상세하게 꿰고 있어야 하겠군요.
도전하려는 정신이 보기 좋습니다. 저에게는 없는 걸 가지고 계시네요
D
흠...그냥 어셈으로 만들고 gcc로 컴파일하면 그냥 되던데요. ^^;;;
전에 XLib 프로그램도 어셈으로 만들수 있나 시험만 해봤는 데 그냥 gcc
로 컴파일할 때 -lX11 옵션만 주면 잘 되더군요. )
Re^3: fflush는 C Library군요....
yootiong님은 커널내의 키보드 버퍼를 싹 비우는 것을 원하시는 것같은데
그런다면 fflush는 아무런 관계가 없습니다.
fflush는 단지 user space에서의 버퍼를 flush하는 라이브러리 함수일
뿐입니다..커널내의 버퍼와는 상관이 없죠..
그렇다면 커널내의 버퍼를 비우는 일은?
단순한 제 생각으론 keyboard를 Nonblocking모드로 열어서
read가 더이상 1바이트도 읽어들이지 않을때까지 루프를 돌면
해결될 것 같은데요...정확히는 잘 모르겠네요..^^;
Re^4: fflush는 C Library군요....
단순한 제 생각으론 keyboard를 Nonblocking모드로 열어서
read가 더이상 1바이트도 읽어들이지 않을때까지 루프를 돌면
해결될 것 같은데요...정확히는 잘 모르겠네요..^^;
이런 방법도 있었군요 )
근데 어떻게 nonblocking 모드로 하죠????
Re^5: fflush는 C Library군요....
찾아보니 그렇게 복잡하게 안해도 되는군요..^^;
tcflush(fd,TCIFLUSH);
이렇게 하면 fd파일디스크립터가 가르키는 tty device의 input buffer를
비워줍니다..
혹시 어셈블리로 직접 짜고 싶으시면 저 위의 라이브러리함수 대신에
ioctl systemcall을 이용해서 하세요..(저 라이브러리 함수가 결국
ioctl(fd,TCFLSH,0);을 호출하거든요..여기서 0은 input buffer를 뜻합니
다)
아, 그리고 nonblocking모드로 바꾸시려면,
http//kldp.org/HOWTO/html/Serial-Programming/Serial-Programming-
HOWTO-3.html
여길 참조 하세요..(TIME,MIN 관련된 부분 읽어보세요)
댓글 달기