[IPV6] IP6TUNNEL: Split out generic routine in ip6ip6_rcv().

This enables to add IPv4/IPv6 specific handling later,

Signed-off-by: Yasuyuki Kozakai <yasuyuki.kozakai@toshiba.co.jp>
Signed-off-by: YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Yasuyuki Kozakai 2006-11-03 09:39:14 +09:00 committed by David S. Miller
parent e490d1d85c
commit 8359925be8
1 changed files with 23 additions and 11 deletions

View File

@ -513,14 +513,17 @@ ip6ip6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
return 0; return 0;
} }
static inline void ip6ip6_ecn_decapsulate(struct ipv6hdr *outer_iph, static void ip6ip6_dscp_ecn_decapsulate(struct ip6_tnl *t,
struct sk_buff *skb) struct ipv6hdr *ipv6h,
struct sk_buff *skb)
{ {
struct ipv6hdr *inner_iph = skb->nh.ipv6h; if (t->parms.flags & IP6_TNL_F_RCV_DSCP_COPY)
ipv6_copy_dscp(ipv6h, skb->nh.ipv6h);
if (INET_ECN_is_ce(ipv6_get_dsfield(outer_iph))) if (INET_ECN_is_ce(ipv6_get_dsfield(ipv6h)))
IP6_ECN_set_ce(inner_iph); IP6_ECN_set_ce(skb->nh.ipv6h);
} }
static inline int ip6_tnl_rcv_ctl(struct ip6_tnl *t) static inline int ip6_tnl_rcv_ctl(struct ip6_tnl *t)
{ {
struct ip6_tnl_parm *p = &t->parms; struct ip6_tnl_parm *p = &t->parms;
@ -546,12 +549,16 @@ static inline int ip6_tnl_rcv_ctl(struct ip6_tnl *t)
/** /**
* ip6ip6_rcv - decapsulate IPv6 packet and retransmit it locally * ip6ip6_rcv - decapsulate IPv6 packet and retransmit it locally
* @skb: received socket buffer * @skb: received socket buffer
* @protocol: ethernet protocol ID
* @dscp_ecn_decapsulate: the function to decapsulate DSCP code and ECN
* *
* Return: 0 * Return: 0
**/ **/
static int static int ip6_tnl_rcv(struct sk_buff *skb, __u16 protocol,
ip6ip6_rcv(struct sk_buff *skb) void (*dscp_ecn_decapsulate)(struct ip6_tnl *t,
struct ipv6hdr *ipv6h,
struct sk_buff *skb))
{ {
struct ipv6hdr *ipv6h; struct ipv6hdr *ipv6h;
struct ip6_tnl *t; struct ip6_tnl *t;
@ -574,16 +581,16 @@ ip6ip6_rcv(struct sk_buff *skb)
secpath_reset(skb); secpath_reset(skb);
skb->mac.raw = skb->nh.raw; skb->mac.raw = skb->nh.raw;
skb->nh.raw = skb->data; skb->nh.raw = skb->data;
skb->protocol = htons(ETH_P_IPV6); skb->protocol = htons(protocol);
skb->pkt_type = PACKET_HOST; skb->pkt_type = PACKET_HOST;
memset(skb->cb, 0, sizeof(struct inet6_skb_parm)); memset(skb->cb, 0, sizeof(struct inet6_skb_parm));
skb->dev = t->dev; skb->dev = t->dev;
dst_release(skb->dst); dst_release(skb->dst);
skb->dst = NULL; skb->dst = NULL;
nf_reset(skb); nf_reset(skb);
if (t->parms.flags & IP6_TNL_F_RCV_DSCP_COPY)
ipv6_copy_dscp(ipv6h, skb->nh.ipv6h); dscp_ecn_decapsulate(t, ipv6h, skb);
ip6ip6_ecn_decapsulate(ipv6h, skb);
t->stat.rx_packets++; t->stat.rx_packets++;
t->stat.rx_bytes += skb->len; t->stat.rx_bytes += skb->len;
netif_rx(skb); netif_rx(skb);
@ -598,6 +605,11 @@ discard:
return 0; return 0;
} }
static int ip6ip6_rcv(struct sk_buff *skb)
{
return ip6_tnl_rcv(skb, ETH_P_IPV6, ip6ip6_dscp_ecn_decapsulate);
}
struct ipv6_tel_txoption { struct ipv6_tel_txoption {
struct ipv6_txoptions ops; struct ipv6_txoptions ops;
__u8 dst_opt[8]; __u8 dst_opt[8];