커널에서 recvfrom 과정에 대해서 질문 드립니다.
글쓴이: kphwan / 작성시간: 토, 2010/06/12 - 1:16오전
안녕하세요
raw_socket 프로그래밍을 짜고 있는데요
잘안돼다가 strace 로 동작과정을 살펴보라는 말씀을 듣고 실험을 해봤습니다.
그런데 굉장히 이상한 부분을 발견햇습니다.
raw_socket 은 IP와 TCP 헤더를 직접 채워준다고 본것 같은데
실상 그부분은 모조리 생략이 되더라구요...
socket = sock(AF_INET, SOCK_RAW, IPPROTO_RAW);
setsockopt( raw_socket, IPPROTO_IP, IP_HDRINCL, (char *)&on, sizeof(on));
TCP 헤더 제작
IP 헤더 제작
sendto(............)
그런데 strace 로 확인해 본 결과 헤더 제작부분이 빠지고 바로 sendto 부분으로 들어가네요
어쩐지 캡쳐 프로그램으로 잡아봤을때
헤더값이 제가 설정한 값과 다르더라니...ㅡ,.ㅡ;;
이 부분은 왜 그런지 이해가 안됩니다.
그리고 두번째로
recvfrom 에서
recvfrom(4(소켓번호), '<'unfinished...'>'
요렇게 나오면서...
recvfrom 에서 계쏙 블락이 걸려 있는데...
이 부분에서 unfinished 라는게 왜 뜨는 건지 해석이 안됩니다.
어디 부분이 잘못되었는지 조언 부탁드립니다..(__)
Forums:
[pid 2812] sendto(3,
[pid 2812] sendto(3, "E\0(\00009\0\0<\6s\276\312\37\311i\312\37\213\356\3\t\0\1\5\211\375\f\0\270\364|P"..., 40, 0, {sa_family=AF_INET, sin_port=htons(1), sin_addr=inet_addr("202.31.139.238")}, 16) = 40
다시 확인을 해보니깐 두번째 인자에 뭔가 들어가긴 하네요....
그런데 왜 중간에 헤더를 채우는 부분이 커널동작 과정에서는 안 나왔을까요?
그리고 왜 제가 넣은 값하고는 다른 값이 들어가는지 ㅡ.,ㅡ
커널이란게 참... ㅠㅠ
조언좀 부탁드리겟습니다.
strace 는 system call 만
strace 는 system call 만 trace 합니다.
system call 포함, 라이브러리 함수 호출까지 전부 보고 싶다면 frysk의 ftrace 를 사용해보세요.
OTL
댓글 달기