[SK_BUFF]: Introduce skb_transport_header(skb)
For the places where we need a pointer to the transport header, it is still legal to touch skb->h.raw directly if just adding to, subtracting from or setting it to another layer header. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		 Arnaldo Carvalho de Melo
					Arnaldo Carvalho de Melo
				
			
				
					committed by
					
						 David S. Miller
						David S. Miller
					
				
			
			
				
	
			
			
			 David S. Miller
						David S. Miller
					
				
			
						parent
						
							a27ef749e7
						
					
				
				
					commit
					9c70220b73
				
			| @@ -917,6 +917,7 @@ static int ltpc_xmit(struct sk_buff *skb, struct net_device *dev) | ||||
|  | ||||
| 	int i; | ||||
| 	struct lt_sendlap cbuf; | ||||
| 	unsigned char *hdr; | ||||
|  | ||||
| 	cbuf.command = LT_SENDLAP; | ||||
| 	cbuf.dnode = skb->data[0]; | ||||
| @@ -932,11 +933,13 @@ static int ltpc_xmit(struct sk_buff *skb, struct net_device *dev) | ||||
| 		printk("\n"); | ||||
| 	} | ||||
|  | ||||
| 	do_write(dev,&cbuf,sizeof(cbuf),skb->h.raw,skb->len); | ||||
| 	hdr = skb_transport_header(skb); | ||||
| 	do_write(dev, &cbuf, sizeof(cbuf), hdr, skb->len); | ||||
|  | ||||
| 	if(debug & DEBUG_UPPER) { | ||||
| 		printk("sent %d ddp bytes\n",skb->len); | ||||
| 		for(i=0;i<skb->len;i++) printk("%02x ",skb->h.raw[i]); | ||||
| 		for (i = 0; i < skb->len; i++) | ||||
| 			printk("%02x ", hdr[i]); | ||||
| 		printk("\n"); | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -1324,12 +1324,14 @@ static void write_ofld_wr(struct adapter *adap, struct sk_buff *skb, | ||||
|  | ||||
| 	flits = skb_transport_offset(skb) / 8; | ||||
| 	sgp = ndesc == 1 ? (struct sg_ent *)&d->flit[flits] : sgl; | ||||
| 	sgl_flits = make_sgl(skb, sgp, skb->h.raw, skb->tail - skb->h.raw, | ||||
| 	sgl_flits = make_sgl(skb, sgp, skb_transport_header(skb), | ||||
| 			     skb->tail - skb_transport_header(skb), | ||||
| 			     adap->pdev); | ||||
| 	if (need_skb_unmap()) { | ||||
| 		setup_deferred_unmapping(skb, adap->pdev, sgp, sgl_flits); | ||||
| 		skb->destructor = deferred_unmap_destructor; | ||||
| 		((struct unmap_info *)skb->cb)->len = skb->tail - skb->h.raw; | ||||
| 		((struct unmap_info *)skb->cb)->len = (skb->tail - | ||||
| 						       skb_transport_header(skb)); | ||||
| 	} | ||||
|  | ||||
| 	write_wr_hdr_sgl(ndesc, skb, d, pidx, q, sgl, flits, sgl_flits, | ||||
| @@ -1351,7 +1353,7 @@ static inline unsigned int calc_tx_descs_ofld(const struct sk_buff *skb) | ||||
| 		return 1;	/* packet fits as immediate data */ | ||||
|  | ||||
| 	flits = skb_transport_offset(skb) / 8;	/* headers */ | ||||
| 	if (skb->tail != skb->h.raw) | ||||
| 	if (skb->tail != skb_transport_header(skb)) | ||||
| 		cnt++; | ||||
| 	return flits_to_desc(flits + sgl_len(cnt)); | ||||
| } | ||||
|   | ||||
| @@ -476,13 +476,13 @@ qeth_eddp_fill_context_tcp(struct qeth_eddp_context *ctx, | ||||
| 		eddp = qeth_eddp_create_eddp_data(qhdr, | ||||
| 						  skb_network_header(skb), | ||||
| 						  ip_hdrlen(skb), | ||||
| 						  skb->h.raw, | ||||
| 						  skb_transport_header(skb), | ||||
| 						  tcp_hdrlen(skb)); | ||||
| 	else | ||||
| 		eddp = qeth_eddp_create_eddp_data(qhdr, | ||||
| 						  skb_network_header(skb), | ||||
| 						  sizeof(struct ipv6hdr), | ||||
| 						  skb->h.raw, | ||||
| 						  skb_transport_header(skb), | ||||
| 						  tcp_hdrlen(skb)); | ||||
|  | ||||
| 	if (eddp == NULL) { | ||||
|   | ||||
| @@ -101,7 +101,7 @@ struct ddpehdr { | ||||
|  | ||||
| static __inline__ struct ddpehdr *ddp_hdr(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct ddpehdr *)skb->h.raw; | ||||
| 	return (struct ddpehdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| /* AppleTalk AARP headers */ | ||||
| @@ -129,7 +129,7 @@ struct elapaarp { | ||||
|  | ||||
| static __inline__ struct elapaarp *aarp_hdr(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct elapaarp *)skb->h.raw; | ||||
| 	return (struct elapaarp *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| /* Not specified - how long till we drop a resolved entry */ | ||||
|   | ||||
| @@ -260,19 +260,20 @@ enum { | ||||
|  | ||||
| static inline struct dccp_hdr *dccp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr *)skb->h.raw; | ||||
| 	return (struct dccp_hdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| static inline struct dccp_hdr *dccp_zeroed_hdr(struct sk_buff *skb, int headlen) | ||||
| { | ||||
| 	skb_push(skb, headlen); | ||||
| 	skb_reset_transport_header(skb); | ||||
| 	return memset(skb->h.raw, 0, headlen); | ||||
| 	return memset(skb_transport_header(skb), 0, headlen); | ||||
| } | ||||
|  | ||||
| static inline struct dccp_hdr_ext *dccp_hdrx(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr_ext *)(skb->h.raw + sizeof(struct dccp_hdr)); | ||||
| 	return (struct dccp_hdr_ext *)(skb_transport_header(skb) + | ||||
| 				       sizeof(struct dccp_hdr)); | ||||
| } | ||||
|  | ||||
| static inline unsigned int __dccp_basic_hdr_len(const struct dccp_hdr *dh) | ||||
| @@ -301,12 +302,14 @@ static inline __u64 dccp_hdr_seq(const struct sk_buff *skb) | ||||
|  | ||||
| static inline struct dccp_hdr_request *dccp_hdr_request(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr_request *)(skb->h.raw + dccp_basic_hdr_len(skb)); | ||||
| 	return (struct dccp_hdr_request *)(skb_transport_header(skb) + | ||||
| 					   dccp_basic_hdr_len(skb)); | ||||
| } | ||||
|  | ||||
| static inline struct dccp_hdr_ack_bits *dccp_hdr_ack_bits(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr_ack_bits *)(skb->h.raw + dccp_basic_hdr_len(skb)); | ||||
| 	return (struct dccp_hdr_ack_bits *)(skb_transport_header(skb) + | ||||
| 					    dccp_basic_hdr_len(skb)); | ||||
| } | ||||
|  | ||||
| static inline u64 dccp_hdr_ack_seq(const struct sk_buff *skb) | ||||
| @@ -317,12 +320,14 @@ static inline u64 dccp_hdr_ack_seq(const struct sk_buff *skb) | ||||
|  | ||||
| static inline struct dccp_hdr_response *dccp_hdr_response(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr_response *)(skb->h.raw + dccp_basic_hdr_len(skb)); | ||||
| 	return (struct dccp_hdr_response *)(skb_transport_header(skb) + | ||||
| 					    dccp_basic_hdr_len(skb)); | ||||
| } | ||||
|  | ||||
| static inline struct dccp_hdr_reset *dccp_hdr_reset(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct dccp_hdr_reset *)(skb->h.raw + dccp_basic_hdr_len(skb)); | ||||
| 	return (struct dccp_hdr_reset *)(skb_transport_header(skb) + | ||||
| 					 dccp_basic_hdr_len(skb)); | ||||
| } | ||||
|  | ||||
| static inline unsigned int __dccp_hdr_len(const struct dccp_hdr *dh) | ||||
|   | ||||
| @@ -87,7 +87,7 @@ struct icmphdr { | ||||
|  | ||||
| static inline struct icmphdr *icmp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct icmphdr *)skb->h.raw; | ||||
| 	return (struct icmphdr *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -80,7 +80,7 @@ struct icmp6hdr { | ||||
|  | ||||
| static inline struct icmp6hdr *icmp6_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct icmp6hdr *)skb->h.raw; | ||||
| 	return (struct icmp6hdr *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -85,19 +85,19 @@ struct igmpv3_query { | ||||
|  | ||||
| static inline struct igmphdr *igmp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct igmphdr *)skb->h.raw; | ||||
| 	return (struct igmphdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| static inline struct igmpv3_report * | ||||
| 			igmpv3_report_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct igmpv3_report *)skb->h.raw; | ||||
| 	return (struct igmpv3_report *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| static inline struct igmpv3_query * | ||||
| 			igmpv3_query_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct igmpv3_query *)skb->h.raw; | ||||
| 	return (struct igmpv3_query *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -114,7 +114,7 @@ static inline struct iphdr *ip_hdr(const struct sk_buff *skb) | ||||
|  | ||||
| static inline struct iphdr *ipip_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct iphdr *)skb->h.raw; | ||||
| 	return (struct iphdr *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -230,7 +230,7 @@ static inline struct ipv6hdr *ipv6_hdr(const struct sk_buff *skb) | ||||
|  | ||||
| static inline struct ipv6hdr *ipipv6_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct ipv6hdr *)skb->h.raw; | ||||
| 	return (struct ipv6hdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| /*  | ||||
|   | ||||
| @@ -68,7 +68,7 @@ typedef struct sctphdr { | ||||
|  | ||||
| static inline struct sctphdr *sctp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct sctphdr *)skb->h.raw; | ||||
| 	return (struct sctphdr *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -951,6 +951,11 @@ static inline void skb_reserve(struct sk_buff *skb, int len) | ||||
| 	skb->tail += len; | ||||
| } | ||||
|  | ||||
| static inline unsigned char *skb_transport_header(const struct sk_buff *skb) | ||||
| { | ||||
| 	return skb->h.raw; | ||||
| } | ||||
|  | ||||
| static inline void skb_reset_transport_header(struct sk_buff *skb) | ||||
| { | ||||
| 	skb->h.raw = skb->data; | ||||
|   | ||||
| @@ -180,7 +180,7 @@ struct tcp_md5sig { | ||||
|  | ||||
| static inline struct tcphdr *tcp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct tcphdr *)skb->h.raw; | ||||
| 	return (struct tcphdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| static inline unsigned int tcp_hdrlen(const struct sk_buff *skb) | ||||
|   | ||||
| @@ -31,7 +31,7 @@ struct udphdr { | ||||
|  | ||||
| static inline struct udphdr *udp_hdr(const struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct udphdr *)skb->h.raw; | ||||
| 	return (struct udphdr *)skb_transport_header(skb); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -43,7 +43,7 @@ struct ipxhdr { | ||||
|  | ||||
| static __inline__ struct ipxhdr *ipx_hdr(struct sk_buff *skb) | ||||
| { | ||||
| 	return (struct ipxhdr *)skb->h.raw; | ||||
| 	return (struct ipxhdr *)skb_transport_header(skb); | ||||
| } | ||||
|  | ||||
| struct ipx_interface { | ||||
|   | ||||
| @@ -328,7 +328,7 @@ static inline unsigned char * tcf_get_base_ptr(struct sk_buff *skb, int layer) | ||||
| 		case TCF_LAYER_NETWORK: | ||||
| 			return skb_network_header(skb); | ||||
| 		case TCF_LAYER_TRANSPORT: | ||||
| 			return skb->h.raw; | ||||
| 			return skb_transport_header(skb); | ||||
| 	} | ||||
|  | ||||
| 	return NULL; | ||||
|   | ||||
| @@ -89,8 +89,8 @@ static inline int udp_lib_checksum_complete(struct sk_buff *skb) | ||||
|  */ | ||||
| static inline __wsum udp_csum_outgoing(struct sock *sk, struct sk_buff *skb) | ||||
| { | ||||
| 	__wsum csum = csum_partial(skb->h.raw, sizeof(struct udphdr), 0); | ||||
|  | ||||
| 	__wsum csum = csum_partial(skb_transport_header(skb), | ||||
| 				   sizeof(struct udphdr), 0); | ||||
| 	skb_queue_walk(&sk->sk_write_queue, skb) { | ||||
| 		csum = csum_add(csum, skb->csum); | ||||
| 	} | ||||
|   | ||||
| @@ -56,7 +56,7 @@ static int snap_rcv(struct sk_buff *skb, struct net_device *dev, | ||||
| 	}; | ||||
|  | ||||
| 	rcu_read_lock(); | ||||
| 	proto = find_snap_client(skb->h.raw); | ||||
| 	proto = find_snap_client(skb_transport_header(skb)); | ||||
| 	if (proto) { | ||||
| 		/* Pass the frame on. */ | ||||
| 		skb->h.raw  += 5; | ||||
|   | ||||
| @@ -1585,9 +1585,10 @@ static int ax25_sendmsg(struct kiocb *iocb, struct socket *sock, | ||||
|  | ||||
| 	skb_set_transport_header(skb, lv); | ||||
|  | ||||
| 	SOCK_DEBUG(sk, "base=%p pos=%p\n", skb->data, skb->h.raw); | ||||
| 	SOCK_DEBUG(sk, "base=%p pos=%p\n", | ||||
| 		   skb->data, skb_transport_header(skb)); | ||||
|  | ||||
| 	*skb->h.raw = AX25_UI; | ||||
| 	*skb_transport_header(skb) = AX25_UI; | ||||
|  | ||||
| 	/* Datagram frames go straight out of the door as UI */ | ||||
| 	ax25_queue_xmit(skb, ax25->ax25_dev->dev); | ||||
|   | ||||
| @@ -1076,7 +1076,7 @@ static void hci_add_acl_hdr(struct sk_buff *skb, __u16 handle, __u16 flags) | ||||
|  | ||||
| 	skb_push(skb, HCI_ACL_HDR_SIZE); | ||||
| 	skb_reset_transport_header(skb); | ||||
| 	hdr = (struct hci_acl_hdr *)skb->h.raw; | ||||
| 	hdr = (struct hci_acl_hdr *)skb_transport_header(skb); | ||||
| 	hdr->handle = cpu_to_le16(hci_handle_pack(handle, flags)); | ||||
| 	hdr->dlen   = cpu_to_le16(len); | ||||
| } | ||||
| @@ -1145,7 +1145,7 @@ int hci_send_sco(struct hci_conn *conn, struct sk_buff *skb) | ||||
|  | ||||
| 	skb_push(skb, HCI_SCO_HDR_SIZE); | ||||
| 	skb_reset_transport_header(skb); | ||||
| 	memcpy(skb->h.raw, &hdr, HCI_SCO_HDR_SIZE); | ||||
| 	memcpy(skb_transport_header(skb), &hdr, HCI_SCO_HDR_SIZE); | ||||
|  | ||||
| 	skb->dev = (void *) hdev; | ||||
| 	bt_cb(skb)->pkt_type = HCI_SCODATA_PKT; | ||||
|   | ||||
| @@ -1175,12 +1175,12 @@ int skb_checksum_help(struct sk_buff *skb) | ||||
| 	BUG_ON(offset > (int)skb->len); | ||||
| 	csum = skb_checksum(skb, offset, skb->len-offset, 0); | ||||
|  | ||||
| 	offset = skb->tail - skb->h.raw; | ||||
| 	offset = skb->tail - skb_transport_header(skb); | ||||
| 	BUG_ON(offset <= 0); | ||||
| 	BUG_ON(skb->csum_offset + 2 > offset); | ||||
|  | ||||
| 	*(__sum16*)(skb->h.raw + skb->csum_offset) = csum_fold(csum); | ||||
|  | ||||
| 	*(__sum16 *)(skb_transport_header(skb) + | ||||
| 		     skb->csum_offset) = csum_fold(csum); | ||||
| out_set_summed: | ||||
| 	skb->ip_summed = CHECKSUM_NONE; | ||||
| out: | ||||
|   | ||||
| @@ -943,7 +943,7 @@ static void aun_data_available(struct sock *sk, int slen) | ||||
| 		printk(KERN_DEBUG "AUN: recvfrom() error %d\n", -err); | ||||
| 	} | ||||
|  | ||||
| 	data = skb->h.raw + sizeof(struct udphdr); | ||||
| 	data = skb_transport_header(skb) + sizeof(struct udphdr); | ||||
| 	ah = (struct aunhdr *)data; | ||||
| 	len = skb->len - sizeof(struct udphdr); | ||||
| 	ip = ip_hdr(skb); | ||||
|   | ||||
| @@ -348,7 +348,7 @@ static int igmpv3_sendpack(struct sk_buff *skb) | ||||
| 	struct iphdr *pip = ip_hdr(skb); | ||||
| 	struct igmphdr *pig = igmp_hdr(skb); | ||||
| 	const int iplen = skb->tail - skb->nh.raw; | ||||
| 	const int igmplen = skb->tail - skb->h.raw; | ||||
| 	const int igmplen = skb->tail - skb_transport_header(skb); | ||||
|  | ||||
| 	pip->tot_len = htons(iplen); | ||||
| 	ip_send_check(pip); | ||||
|   | ||||
| @@ -619,7 +619,7 @@ static int ipgre_rcv(struct sk_buff *skb) | ||||
| 		skb_reset_mac_header(skb); | ||||
| 		__pskb_pull(skb, offset); | ||||
| 		skb_reset_network_header(skb); | ||||
| 		skb_postpull_rcsum(skb, skb->h.raw, offset); | ||||
| 		skb_postpull_rcsum(skb, skb_transport_header(skb), offset); | ||||
| 		skb->pkt_type = PACKET_HOST; | ||||
| #ifdef CONFIG_NET_IPGRE_BROADCAST | ||||
| 		if (MULTICAST(iph->daddr)) { | ||||
|   | ||||
| @@ -1128,7 +1128,7 @@ ssize_t	ip_append_page(struct sock *sk, struct page *page, | ||||
| 			if (fraggap) { | ||||
| 				skb->csum = skb_copy_and_csum_bits(skb_prev, | ||||
| 								   maxfraglen, | ||||
| 								   skb->h.raw, | ||||
| 						    skb_transport_header(skb), | ||||
| 								   fraggap, 0); | ||||
| 				skb_prev->csum = csum_sub(skb_prev->csum, | ||||
| 							  skb->csum); | ||||
| @@ -1374,7 +1374,9 @@ void ip_send_reply(struct sock *sk, struct sk_buff *skb, struct ip_reply_arg *ar | ||||
| 		       &ipc, rt, MSG_DONTWAIT); | ||||
| 	if ((skb = skb_peek(&sk->sk_write_queue)) != NULL) { | ||||
| 		if (arg->csumoffset >= 0) | ||||
| 			*((__sum16 *)skb->h.raw + arg->csumoffset) = csum_fold(csum_add(skb->csum, arg->csum)); | ||||
| 			*((__sum16 *)skb_transport_header(skb) + | ||||
| 			  arg->csumoffset) = csum_fold(csum_add(skb->csum, | ||||
| 								arg->csum)); | ||||
| 		skb->ip_summed = CHECKSUM_NONE; | ||||
| 		ip_push_pending_frames(sk); | ||||
| 	} | ||||
|   | ||||
| @@ -432,7 +432,7 @@ ic_rarp_recv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt | ||||
| 		goto drop; | ||||
|  | ||||
| 	/* Basic sanity checks can be done without the lock.  */ | ||||
| 	rarp = (struct arphdr *)skb->h.raw; | ||||
| 	rarp = (struct arphdr *)skb_transport_header(skb); | ||||
|  | ||||
| 	/* If this test doesn't pass, it's not IP, or we should | ||||
| 	 * ignore it anyway. | ||||
| @@ -455,7 +455,7 @@ ic_rarp_recv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt | ||||
| 		goto drop; | ||||
|  | ||||
| 	/* OK, it is all there and looks valid, process... */ | ||||
| 	rarp = (struct arphdr *)skb->h.raw; | ||||
| 	rarp = (struct arphdr *)skb_transport_header(skb); | ||||
| 	rarp_ptr = (unsigned char *) (rarp + 1); | ||||
|  | ||||
| 	/* One reply at a time, please. */ | ||||
|   | ||||
| @@ -1437,7 +1437,8 @@ int pim_rcv_v1(struct sk_buff * skb) | ||||
| 	    pim->group != PIM_V1_VERSION || pim->code != PIM_V1_REGISTER) | ||||
| 		goto drop; | ||||
|  | ||||
| 	encap = (struct iphdr*)(skb->h.raw + sizeof(struct igmphdr)); | ||||
| 	encap = (struct iphdr *)(skb_transport_header(skb) + | ||||
| 				 sizeof(struct igmphdr)); | ||||
| 	/* | ||||
| 	   Check that: | ||||
| 	   a. packet is really destinted to a multicast group | ||||
| @@ -1490,7 +1491,7 @@ static int pim_rcv(struct sk_buff * skb) | ||||
| 	if (!pskb_may_pull(skb, sizeof(*pim) + sizeof(*encap))) | ||||
| 		goto drop; | ||||
|  | ||||
| 	pim = (struct pimreghdr*)skb->h.raw; | ||||
| 	pim = (struct pimreghdr *)skb_transport_header(skb); | ||||
| 	if (pim->type != ((PIM_VERSION<<4)|(PIM_REGISTER)) || | ||||
| 	    (pim->flags&PIM_NULL_REGISTER) || | ||||
| 	    (ip_compute_csum((void *)pim, sizeof(*pim)) != 0 && | ||||
| @@ -1498,7 +1499,8 @@ static int pim_rcv(struct sk_buff * skb) | ||||
| 		goto drop; | ||||
|  | ||||
| 	/* check if the inner packet is destined to mcast group */ | ||||
| 	encap = (struct iphdr*)(skb->h.raw + sizeof(struct pimreghdr)); | ||||
| 	encap = (struct iphdr *)(skb_transport_header(skb) + | ||||
| 				 sizeof(struct pimreghdr)); | ||||
| 	if (!MULTICAST(encap->daddr) || | ||||
| 	    encap->tot_len == 0 || | ||||
| 	    ntohs(encap->tot_len) + sizeof(*pim) > skb->len) | ||||
|   | ||||
| @@ -2219,8 +2219,9 @@ struct sk_buff *tcp_tso_segment(struct sk_buff *skb, int features) | ||||
| 		th->check = ~csum_fold((__force __wsum)((__force u32)th->check + | ||||
| 				       (__force u32)delta)); | ||||
| 		if (skb->ip_summed != CHECKSUM_PARTIAL) | ||||
| 			th->check = csum_fold(csum_partial(skb->h.raw, thlen, | ||||
| 							   skb->csum)); | ||||
| 			th->check = | ||||
| 			     csum_fold(csum_partial(skb_transport_header(skb), | ||||
| 						    thlen, skb->csum)); | ||||
|  | ||||
| 		seq += len; | ||||
| 		skb = skb->next; | ||||
| @@ -2230,12 +2231,13 @@ struct sk_buff *tcp_tso_segment(struct sk_buff *skb, int features) | ||||
| 		th->cwr = 0; | ||||
| 	} while (skb->next); | ||||
|  | ||||
| 	delta = htonl(oldlen + (skb->tail - skb->h.raw) + skb->data_len); | ||||
| 	delta = htonl(oldlen + (skb->tail - skb_transport_header(skb)) + | ||||
| 		      skb->data_len); | ||||
| 	th->check = ~csum_fold((__force __wsum)((__force u32)th->check + | ||||
| 				(__force u32)delta)); | ||||
| 	if (skb->ip_summed != CHECKSUM_PARTIAL) | ||||
| 		th->check = csum_fold(csum_partial(skb->h.raw, thlen, | ||||
| 						   skb->csum)); | ||||
| 		th->check = csum_fold(csum_partial(skb_transport_header(skb), | ||||
| 						   thlen, skb->csum)); | ||||
|  | ||||
| out: | ||||
| 	return segs; | ||||
|   | ||||
| @@ -140,7 +140,7 @@ static void tcp_measure_rcv_mss(struct sock *sk, | ||||
| 		 * | ||||
| 		 * "len" is invariant segment length, including TCP header. | ||||
| 		 */ | ||||
| 		len += skb->data - skb->h.raw; | ||||
| 		len += skb->data - skb_transport_header(skb); | ||||
| 		if (len >= TCP_MIN_RCVMSS + sizeof(struct tcphdr) || | ||||
| 		    /* If PSH is not set, packet should be | ||||
| 		     * full sized, provided peer TCP is not badly broken. | ||||
| @@ -940,7 +940,8 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_ | ||||
| { | ||||
| 	const struct inet_connection_sock *icsk = inet_csk(sk); | ||||
| 	struct tcp_sock *tp = tcp_sk(sk); | ||||
| 	unsigned char *ptr = ack_skb->h.raw + TCP_SKB_CB(ack_skb)->sacked; | ||||
| 	unsigned char *ptr = (skb_transport_header(ack_skb) + | ||||
| 			      TCP_SKB_CB(ack_skb)->sacked); | ||||
| 	struct tcp_sack_block_wire *sp = (struct tcp_sack_block_wire *)(ptr+2); | ||||
| 	struct sk_buff *cached_skb; | ||||
| 	int num_sacks = (ptr[1] - TCPOLEN_SACK_BASE)>>3; | ||||
| @@ -3634,10 +3635,10 @@ tcp_collapse(struct sock *sk, struct sk_buff_head *list, | ||||
| 			return; | ||||
|  | ||||
| 		skb_set_mac_header(nskb, skb_mac_header(skb) - skb->head); | ||||
| 		skb_set_network_header(nskb, | ||||
| 				       skb_network_header(skb) - skb->head); | ||||
| 		skb_set_transport_header(nskb, skb->h.raw - skb->head); | ||||
|  | ||||
| 		skb_set_network_header(nskb, (skb_network_header(skb) - | ||||
| 					      skb->head)); | ||||
| 		skb_set_transport_header(nskb, (skb_transport_header(skb) - | ||||
| 						skb->head)); | ||||
| 		skb_reserve(nskb, header); | ||||
| 		memcpy(nskb->head, skb->head, header); | ||||
| 		memcpy(nskb->cb, skb->cb, sizeof(skb->cb)); | ||||
|   | ||||
| @@ -51,7 +51,7 @@ static int xfrm4_beet_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
|  | ||||
| 		BUG_ON(optlen < 0); | ||||
|  | ||||
| 		ph = (struct ip_beet_phdr *)skb->h.raw; | ||||
| 		ph = (struct ip_beet_phdr *)skb_transport_header(skb); | ||||
| 		ph->padlen = 4 - (optlen & 4); | ||||
| 		ph->hdrlen = optlen / 8; | ||||
| 		ph->nexthdr = top_iph->protocol; | ||||
|   | ||||
| @@ -45,10 +45,11 @@ static int xfrm4_transport_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
|  */ | ||||
| static int xfrm4_transport_input(struct xfrm_state *x, struct sk_buff *skb) | ||||
| { | ||||
| 	int ihl = skb->data - skb->h.raw; | ||||
| 	int ihl = skb->data - skb_transport_header(skb); | ||||
|  | ||||
| 	if (skb->h.raw != skb->nh.raw) { | ||||
| 		memmove(skb->h.raw, skb_network_header(skb), ihl); | ||||
| 		memmove(skb_transport_header(skb), | ||||
| 			skb_network_header(skb), ihl); | ||||
| 		skb->nh.raw = skb->h.raw; | ||||
| 	} | ||||
| 	ip_hdr(skb)->tot_len = htons(skb->len + ihl); | ||||
|   | ||||
| @@ -268,7 +268,7 @@ static int ah6_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
| 			goto error_free_iph; | ||||
| 	} | ||||
|  | ||||
| 	ah = (struct ip_auth_hdr *)skb->h.raw; | ||||
| 	ah = (struct ip_auth_hdr *)skb_transport_header(skb); | ||||
| 	ah->nexthdr = nexthdr; | ||||
|  | ||||
| 	top_iph->priority    = 0; | ||||
|   | ||||
| @@ -87,7 +87,7 @@ static int esp6_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
| 	pskb_put(skb, trailer, clen - skb->len); | ||||
|  | ||||
| 	top_iph = (struct ipv6hdr *)__skb_push(skb, hdr_len); | ||||
| 	esph = (struct ipv6_esp_hdr *)skb->h.raw; | ||||
| 	esph = (struct ipv6_esp_hdr *)skb_transport_header(skb); | ||||
| 	top_iph->payload_len = htons(skb->len + alen - sizeof(*top_iph)); | ||||
| 	*(u8 *)(trailer->tail - 1) = *skb_network_header(skb); | ||||
| 	*skb_network_header(skb) = IPPROTO_ESP; | ||||
|   | ||||
| @@ -144,7 +144,7 @@ static int ip6_parse_tlv(struct tlvtype_proc *procs, struct sk_buff **skbp) | ||||
| 	struct tlvtype_proc *curr; | ||||
| 	const unsigned char *nh = skb_network_header(skb); | ||||
| 	int off = skb->h.raw - skb->nh.raw; | ||||
| 	int len = ((skb->h.raw[1]+1)<<3); | ||||
| 	int len = (skb_transport_header(skb)[1] + 1) << 3; | ||||
|  | ||||
| 	if (skb_transport_offset(skb) + len > skb_headlen(skb)) | ||||
| 		goto bad; | ||||
| @@ -290,15 +290,14 @@ static int ipv6_destopt_rcv(struct sk_buff **skbp) | ||||
|  | ||||
| 	if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) || | ||||
| 	    !pskb_may_pull(skb, (skb_transport_offset(skb) + | ||||
| 				 ((skb->h.raw[1] + 1) << 3)))) { | ||||
| 				 ((skb_transport_header(skb)[1] + 1) << 3)))) { | ||||
| 		IP6_INC_STATS_BH(ip6_dst_idev(skb->dst), | ||||
| 				 IPSTATS_MIB_INHDRERRORS); | ||||
| 		kfree_skb(skb); | ||||
| 		return -1; | ||||
| 	} | ||||
|  | ||||
| 	opt->lastopt = skb->h.raw - skb->nh.raw; | ||||
| 	opt->dst1 = skb->h.raw - skb->nh.raw; | ||||
| 	opt->lastopt = opt->dst1 = skb->h.raw - skb->nh.raw; | ||||
| #ifdef CONFIG_IPV6_MIP6 | ||||
| 	dstbuf = opt->dst1; | ||||
| #endif | ||||
| @@ -307,7 +306,7 @@ static int ipv6_destopt_rcv(struct sk_buff **skbp) | ||||
| 	if (ip6_parse_tlv(tlvprocdestopt_lst, skbp)) { | ||||
| 		dst_release(dst); | ||||
| 		skb = *skbp; | ||||
| 		skb->h.raw += ((skb->h.raw[1]+1)<<3); | ||||
| 		skb->h.raw += (skb_transport_header(skb)[1] + 1) << 3; | ||||
| 		opt = IP6CB(skb); | ||||
| #ifdef CONFIG_IPV6_MIP6 | ||||
| 		opt->nhoff = dstbuf; | ||||
| @@ -390,14 +389,14 @@ static int ipv6_rthdr_rcv(struct sk_buff **skbp) | ||||
|  | ||||
| 	if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) || | ||||
| 	    !pskb_may_pull(skb, (skb_transport_offset(skb) + | ||||
| 				 ((skb->h.raw[1] + 1) << 3)))) { | ||||
| 				 ((skb_transport_header(skb)[1] + 1) << 3)))) { | ||||
| 		IP6_INC_STATS_BH(ip6_dst_idev(skb->dst), | ||||
| 				 IPSTATS_MIB_INHDRERRORS); | ||||
| 		kfree_skb(skb); | ||||
| 		return -1; | ||||
| 	} | ||||
|  | ||||
| 	hdr = (struct ipv6_rt_hdr *) skb->h.raw; | ||||
| 	hdr = (struct ipv6_rt_hdr *)skb_transport_header(skb); | ||||
|  | ||||
| 	switch (hdr->type) { | ||||
| #ifdef CONFIG_IPV6_MIP6 | ||||
| @@ -444,8 +443,7 @@ looped_back: | ||||
| 			break; | ||||
| 		} | ||||
|  | ||||
| 		opt->lastopt = skb->h.raw - skb->nh.raw; | ||||
| 		opt->srcrt = skb->h.raw - skb->nh.raw; | ||||
| 		opt->lastopt = opt->srcrt = skb->h.raw - skb->nh.raw; | ||||
| 		skb->h.raw += (hdr->hdrlen + 1) << 3; | ||||
| 		opt->dst0 = opt->dst1; | ||||
| 		opt->dst1 = 0; | ||||
| @@ -745,7 +743,8 @@ int ipv6_parse_hopopts(struct sk_buff **skbp) | ||||
| 	 * hop-by-hop options. | ||||
| 	 */ | ||||
| 	if (!pskb_may_pull(skb, sizeof(struct ipv6hdr) + 8) || | ||||
| 	    !pskb_may_pull(skb, sizeof(struct ipv6hdr) + ((skb->h.raw[1] + 1) << 3))) { | ||||
| 	    !pskb_may_pull(skb, (sizeof(struct ipv6hdr) + | ||||
| 				 ((skb_transport_header(skb)[1] + 1) << 3)))) { | ||||
| 		kfree_skb(skb); | ||||
| 		return -1; | ||||
| 	} | ||||
| @@ -753,7 +752,7 @@ int ipv6_parse_hopopts(struct sk_buff **skbp) | ||||
| 	opt->hop = sizeof(struct ipv6hdr); | ||||
| 	if (ip6_parse_tlv(tlvprochopopt_lst, skbp)) { | ||||
| 		skb = *skbp; | ||||
| 		skb->h.raw += (skb->h.raw[1]+1)<<3; | ||||
| 		skb->h.raw += (skb_transport_header(skb)[1] + 1) << 3; | ||||
| 		opt = IP6CB(skb); | ||||
| 		opt->nhoff = sizeof(struct ipv6hdr); | ||||
| 		return 1; | ||||
|   | ||||
| @@ -143,7 +143,7 @@ static int ipcomp6_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
| 	/* compression */ | ||||
| 	plen = skb->len - hdr_len; | ||||
| 	dlen = IPCOMP_SCRATCH_SIZE; | ||||
| 	start = skb->h.raw; | ||||
| 	start = skb_transport_header(skb); | ||||
|  | ||||
| 	cpu = get_cpu(); | ||||
| 	scratch = *per_cpu_ptr(ipcomp6_scratches, cpu); | ||||
|   | ||||
| @@ -1212,7 +1212,7 @@ int igmp6_event_query(struct sk_buff *skb) | ||||
| 			in6_dev_put(idev); | ||||
| 			return -EINVAL; | ||||
| 		} | ||||
| 		mlh2 = (struct mld2_query *) skb->h.raw; | ||||
| 		mlh2 = (struct mld2_query *)skb_transport_header(skb); | ||||
| 		max_delay = (MLDV2_MRC(ntohs(mlh2->mrc))*HZ)/1000; | ||||
| 		if (!max_delay) | ||||
| 			max_delay = 1; | ||||
| @@ -1235,7 +1235,7 @@ int igmp6_event_query(struct sk_buff *skb) | ||||
| 				in6_dev_put(idev); | ||||
| 				return -EINVAL; | ||||
| 			} | ||||
| 			mlh2 = (struct mld2_query *) skb->h.raw; | ||||
| 			mlh2 = (struct mld2_query *)skb_transport_header(skb); | ||||
| 			mark = 1; | ||||
| 		} | ||||
| 	} else { | ||||
| @@ -1460,18 +1460,20 @@ static inline int mld_dev_queue_xmit(struct sk_buff *skb) | ||||
| static void mld_sendpack(struct sk_buff *skb) | ||||
| { | ||||
| 	struct ipv6hdr *pip6 = ipv6_hdr(skb); | ||||
| 	struct mld2_report *pmr = (struct mld2_report *)skb->h.raw; | ||||
| 	struct mld2_report *pmr = | ||||
| 			      (struct mld2_report *)skb_transport_header(skb); | ||||
| 	int payload_len, mldlen; | ||||
| 	struct inet6_dev *idev = in6_dev_get(skb->dev); | ||||
| 	int err; | ||||
|  | ||||
| 	IP6_INC_STATS(idev, IPSTATS_MIB_OUTREQUESTS); | ||||
| 	payload_len = skb->tail - skb_network_header(skb) - sizeof(*pip6); | ||||
| 	mldlen = skb->tail - skb->h.raw; | ||||
| 	mldlen = skb->tail - skb_transport_header(skb); | ||||
| 	pip6->payload_len = htons(payload_len); | ||||
|  | ||||
| 	pmr->csum = csum_ipv6_magic(&pip6->saddr, &pip6->daddr, mldlen, | ||||
| 		IPPROTO_ICMPV6, csum_partial(skb->h.raw, mldlen, 0)); | ||||
| 		IPPROTO_ICMPV6, csum_partial(skb_transport_header(skb), | ||||
| 					     mldlen, 0)); | ||||
| 	err = NF_HOOK(PF_INET6, NF_IP6_LOCAL_OUT, skb, NULL, skb->dev, | ||||
| 		mld_dev_queue_xmit); | ||||
| 	if (!err) { | ||||
| @@ -1505,7 +1507,7 @@ static struct sk_buff *add_grhead(struct sk_buff *skb, struct ifmcaddr6 *pmc, | ||||
| 	pgr->grec_auxwords = 0; | ||||
| 	pgr->grec_nsrcs = 0; | ||||
| 	pgr->grec_mca = pmc->mca_addr;	/* structure copy */ | ||||
| 	pmr = (struct mld2_report *)skb->h.raw; | ||||
| 	pmr = (struct mld2_report *)skb_transport_header(skb); | ||||
| 	pmr->ngrec = htons(ntohs(pmr->ngrec)+1); | ||||
| 	*ppgr = pgr; | ||||
| 	return skb; | ||||
| @@ -1538,7 +1540,7 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc, | ||||
| 	if (!*psf_list) | ||||
| 		goto empty_source; | ||||
|  | ||||
| 	pmr = skb ? (struct mld2_report *)skb->h.raw : NULL; | ||||
| 	pmr = skb ? (struct mld2_report *)skb_transport_header(skb) : NULL; | ||||
|  | ||||
| 	/* EX and TO_EX get a fresh packet, if needed */ | ||||
| 	if (truncate) { | ||||
|   | ||||
| @@ -92,10 +92,10 @@ int mip6_mh_filter(struct sock *sk, struct sk_buff *skb) | ||||
|  | ||||
| 	if (!pskb_may_pull(skb, (skb_transport_offset(skb)) + 8) || | ||||
| 	    !pskb_may_pull(skb, (skb_transport_offset(skb) + | ||||
| 				 ((skb->h.raw[1] + 1) << 3)))) | ||||
| 				 ((skb_transport_header(skb)[1] + 1) << 3)))) | ||||
| 		return -1; | ||||
|  | ||||
| 	mh = (struct ip6_mh *)skb->h.raw; | ||||
| 	mh = (struct ip6_mh *)skb_transport_header(skb); | ||||
|  | ||||
| 	if (mh->ip6mh_hdrlen < mip6_mh_len(mh->ip6mh_type)) { | ||||
| 		LIMIT_NETDEBUG(KERN_DEBUG "mip6: MH message too short: %d vs >=%d\n", | ||||
| @@ -158,7 +158,7 @@ static int mip6_destopt_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
| 	nexthdr = *skb_network_header(skb); | ||||
| 	*skb_network_header(skb) = IPPROTO_DSTOPTS; | ||||
|  | ||||
| 	dstopt = (struct ipv6_destopt_hdr *)skb->h.raw; | ||||
| 	dstopt = (struct ipv6_destopt_hdr *)skb_transport_header(skb); | ||||
| 	dstopt->nexthdr = nexthdr; | ||||
|  | ||||
| 	hao = mip6_padn((char *)(dstopt + 1), | ||||
| @@ -370,7 +370,7 @@ static int mip6_rthdr_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
| 	nexthdr = *skb_network_header(skb); | ||||
| 	*skb_network_header(skb) = IPPROTO_ROUTING; | ||||
|  | ||||
| 	rt2 = (struct rt2_hdr *)skb->h.raw; | ||||
| 	rt2 = (struct rt2_hdr *)skb_transport_header(skb); | ||||
| 	rt2->rt_hdr.nexthdr = nexthdr; | ||||
| 	rt2->rt_hdr.hdrlen = (x->props.header_len >> 3) - 1; | ||||
| 	rt2->rt_hdr.type = IPV6_SRCRT_TYPE_2; | ||||
|   | ||||
| @@ -760,7 +760,7 @@ static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb) | ||||
|  | ||||
| static void ndisc_recv_ns(struct sk_buff *skb) | ||||
| { | ||||
| 	struct nd_msg *msg = (struct nd_msg *)skb->h.raw; | ||||
| 	struct nd_msg *msg = (struct nd_msg *)skb_transport_header(skb); | ||||
| 	struct in6_addr *saddr = &ipv6_hdr(skb)->saddr; | ||||
| 	struct in6_addr *daddr = &ipv6_hdr(skb)->daddr; | ||||
| 	u8 *lladdr = NULL; | ||||
| @@ -938,7 +938,7 @@ out: | ||||
|  | ||||
| static void ndisc_recv_na(struct sk_buff *skb) | ||||
| { | ||||
| 	struct nd_msg *msg = (struct nd_msg *)skb->h.raw; | ||||
| 	struct nd_msg *msg = (struct nd_msg *)skb_transport_header(skb); | ||||
| 	struct in6_addr *saddr = &ipv6_hdr(skb)->saddr; | ||||
| 	struct in6_addr *daddr = &ipv6_hdr(skb)->daddr; | ||||
| 	u8 *lladdr = NULL; | ||||
| @@ -1040,7 +1040,7 @@ out: | ||||
|  | ||||
| static void ndisc_recv_rs(struct sk_buff *skb) | ||||
| { | ||||
| 	struct rs_msg *rs_msg = (struct rs_msg *) skb->h.raw; | ||||
| 	struct rs_msg *rs_msg = (struct rs_msg *)skb_transport_header(skb); | ||||
| 	unsigned long ndoptlen = skb->len - sizeof(*rs_msg); | ||||
| 	struct neighbour *neigh; | ||||
| 	struct inet6_dev *idev; | ||||
| @@ -1097,7 +1097,7 @@ out: | ||||
|  | ||||
| static void ndisc_router_discovery(struct sk_buff *skb) | ||||
| { | ||||
| 	struct ra_msg *ra_msg = (struct ra_msg *) skb->h.raw; | ||||
| 	struct ra_msg *ra_msg = (struct ra_msg *)skb_transport_header(skb); | ||||
| 	struct neighbour *neigh = NULL; | ||||
| 	struct inet6_dev *in6_dev; | ||||
| 	struct rt6_info *rt = NULL; | ||||
| @@ -1108,7 +1108,8 @@ static void ndisc_router_discovery(struct sk_buff *skb) | ||||
|  | ||||
| 	__u8 * opt = (__u8 *)(ra_msg + 1); | ||||
|  | ||||
| 	optlen = (skb->tail - skb->h.raw) - sizeof(struct ra_msg); | ||||
| 	optlen = (skb->tail - skb_transport_header(skb)) - | ||||
| 		  sizeof(struct ra_msg); | ||||
|  | ||||
| 	if (!(ipv6_addr_type(&ipv6_hdr(skb)->saddr) & IPV6_ADDR_LINKLOCAL)) { | ||||
| 		ND_PRINTK2(KERN_WARNING | ||||
| @@ -1357,7 +1358,7 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	optlen = skb->tail - skb->h.raw; | ||||
| 	optlen = skb->tail - skb_transport_header(skb); | ||||
| 	optlen -= sizeof(struct icmp6hdr) + 2 * sizeof(struct in6_addr); | ||||
|  | ||||
| 	if (optlen < 0) { | ||||
| @@ -1584,9 +1585,9 @@ int ndisc_rcv(struct sk_buff *skb) | ||||
| 	if (!pskb_may_pull(skb, skb->len)) | ||||
| 		return 0; | ||||
|  | ||||
| 	msg = (struct nd_msg *) skb->h.raw; | ||||
| 	msg = (struct nd_msg *)skb_transport_header(skb); | ||||
|  | ||||
| 	__skb_push(skb, skb->data-skb->h.raw); | ||||
| 	__skb_push(skb, skb->data - skb_transport_header(skb)); | ||||
|  | ||||
| 	if (ipv6_hdr(skb)->hop_limit != 255) { | ||||
| 		ND_PRINTK2(KERN_WARNING | ||||
|   | ||||
| @@ -1077,7 +1077,7 @@ static int rawv6_ioctl(struct sock *sk, int cmd, unsigned long arg) | ||||
| 			spin_lock_bh(&sk->sk_receive_queue.lock); | ||||
| 			skb = skb_peek(&sk->sk_receive_queue); | ||||
| 			if (skb != NULL) | ||||
| 				amount = skb->tail - skb->h.raw; | ||||
| 				amount = skb->tail - skb_transport_header(skb); | ||||
| 			spin_unlock_bh(&sk->sk_receive_queue.lock); | ||||
| 			return put_user(amount, (int __user *)arg); | ||||
| 		} | ||||
|   | ||||
| @@ -726,7 +726,7 @@ static int ipv6_frag_rcv(struct sk_buff **skbp) | ||||
| 	} | ||||
|  | ||||
| 	hdr = ipv6_hdr(skb); | ||||
| 	fhdr = (struct frag_hdr *)skb->h.raw; | ||||
| 	fhdr = (struct frag_hdr *)skb_transport_header(skb); | ||||
|  | ||||
| 	if (!(fhdr->frag_off & htons(0xFFF9))) { | ||||
| 		/* It is not a fragmented frame */ | ||||
|   | ||||
| @@ -51,10 +51,11 @@ static int xfrm6_transport_output(struct xfrm_state *x, struct sk_buff *skb) | ||||
|  */ | ||||
| static int xfrm6_transport_input(struct xfrm_state *x, struct sk_buff *skb) | ||||
| { | ||||
| 	int ihl = skb->data - skb->h.raw; | ||||
| 	int ihl = skb->data - skb_transport_header(skb); | ||||
|  | ||||
| 	if (skb->h.raw != skb->nh.raw) { | ||||
| 		memmove(skb->h.raw, skb_network_header(skb), ihl); | ||||
| 		memmove(skb_transport_header(skb), | ||||
| 			skb_network_header(skb), ihl); | ||||
| 		skb->nh.raw = skb->h.raw; | ||||
| 	} | ||||
| 	ipv6_hdr(skb)->payload_len = htons(skb->len + ihl - | ||||
|   | ||||
| @@ -62,7 +62,7 @@ int xfrm_parse_spi(struct sk_buff *skb, u8 nexthdr, __be32 *spi, __be32 *seq) | ||||
| 	case IPPROTO_COMP: | ||||
| 		if (!pskb_may_pull(skb, sizeof(struct ip_comp_hdr))) | ||||
| 			return -EINVAL; | ||||
| 		*spi = htonl(ntohs(*(__be16*)(skb->h.raw + 2))); | ||||
| 		*spi = htonl(ntohs(*(__be16*)(skb_transport_header(skb) + 2))); | ||||
| 		*seq = 0; | ||||
| 		return 0; | ||||
| 	default: | ||||
| @@ -72,8 +72,8 @@ int xfrm_parse_spi(struct sk_buff *skb, u8 nexthdr, __be32 *spi, __be32 *seq) | ||||
| 	if (!pskb_may_pull(skb, 16)) | ||||
| 		return -EINVAL; | ||||
|  | ||||
| 	*spi = *(__be32*)(skb->h.raw + offset); | ||||
| 	*seq = *(__be32*)(skb->h.raw + offset_seq); | ||||
| 	*spi = *(__be32*)(skb_transport_header(skb) + offset); | ||||
| 	*seq = *(__be32*)(skb_transport_header(skb) + offset_seq); | ||||
| 	return 0; | ||||
| } | ||||
| EXPORT_SYMBOL(xfrm_parse_spi); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user