22.01.09, 19:11, "Jan Engelhardt" <jengelh@xxxxxxxxxx>: > Very well. But there still is another case I can think of - > non-linear skb. > struct tcphdr tcpbuf; > const struct tcphdr *th; > > th = skb_header_pointer(skb, ip_hdrlen(skb), sizeof(tcpbuf), &tcpbuf); > if (th->psh && ntohs(tcp->dest) == 80) { > char n[4]; > if (skb_copy_bits(skb, ip_hdrlen(skb) + 4*tcp->doff, > n, sizeof(n)) >= 0) > printk("data: %02x %02x %02x %02x\n", n[0], n[1], > n[2], n[3]); > } Yes! It is non-linear skb! All works! THANK YOU VERY MUCH! I try to fix this bug for about 2 weeks. And You fix it for 15 minutes! Non of my books tell me about non-linear skb. Google was useless! Man, You are the best! :) I want to give You a little present - bottle of Russian vodka (old Russian tradition :) ). How can I pass it to You? Give me your address please! -- To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html