sk_buff 와 ipv6확장헤더에 대한 질문입니다..
struct sk_buff {
.......
	union
	{
		struct tcphdr	*th;
		struct udphdr	*uh;
		struct icmphdr	*icmph;
		struct igmphdr	*igmph;
		struct iphdr	*ipiph;
		struct spxhdr	*spxh;
		unsigned char	*raw;
	} h;
	/* Network layer header */
	union
	{
		struct iphdr	*iph;
		struct ipv6hdr	*ipv6h;
		struct arphdr	*arph;
		struct ipxhdr	*ipxh;
		unsigned char	*raw;
	} nh;
	/* Link layer header */
	union 
	{	
	  	struct ethhdr	*ethernet;
	  	unsigned char 	*raw;
	} mac;
	......
};
ipv6의 확장헤더 목록에 여러가지가 있던데 ipv6소스에서 보니 어떠한 확장헤더들은 ipv6_parse_exthdrs
함수가 호출되어 해당 코드들을 처리하며, 몇몇 확장헤더들은 확장헤더 처리 핸들러가 등록되어서 그 부분에서
처리가 되던데 이렇게 나누어서 처리하는 이유가 있는 것입니까?
그리고 ipv6_parse_exthdrs에서 처리되는 확장헤더는 시작 포인터를 알기위하여 앞헤더의 길이 정보등을 이
용하여 시작포인트를 알아내는데, 핸들러를 이용하여 처리하는 메세지는 transeport layer의 raw값을 이용하
여 바로 시작포인트를 알아내고 있었습니다. 그래서 raw값이 이용하는 것이 무엇인지 알아보려고 했는데, 잘 모
르겠습니다. 제가 여러 정확상 유추해 보건데 해당 계층의 시작 포인터 값을 가지고 있는 것 같습니다. 이것이 맞
는 것인지 모르겠고, 그렇다면 왜 다음 계층의 raw값을 가지고 확장헤더의 시작위치를 알게하도록 되어 있는
것인지 이유나 원인을 알려주시면 매우 감사하겠습니다.^^;


ㅎㅎㅎ. 어렵네요.
ㅎㅎㅎ. 어렵네요.
답변이 될지
답변이 될지 모르겠습니다만...(질문을 정확하게 이해하지 못하겠습니다.)
제가 아는것만 말씀을 드리면 ipv6 extension header 처리는 hop-by-hop option 헤더는 ip6_rcv()에서 처리하고 나머지 extension 헤더에 대한 내용은(다음헤더가 tcp혹은 udp가 아닐경우에는..) ipv6_input_finish()함수에서 님께서 말씀하신것 같이 ipv6_parse_exthdrs() 함수를 호출하여 처리합니다.
ipv6_parse_exthdrs()함수에서는 존재하는 extension 헤더의 갯수만큼 for 루프를 돌면서 확장헤더 마다 등록되어 핸들러들을 호출하여 처리를 하고 있고요, 마지막 처리가 다 끝이 나면 nh의 오프셋 값을 넘겨 줍니다. 나중에 이값은 tcp/udp 헤더를 처리하는데 사용하겠죠...
도움이 될런지 모르겠지만 어려움을 겪고 있는 부분에 대해서 명확히 질문을 주시면 답변을 드리도록 노력 하겠습니다.
댓글 달기