实验环境:Ubuntu 18.04 Linux:5.4.1
ipip实验环境设定:
ipip.sh
ip netns add ns1
ip netns add ns2
ip link add v1 type veth peer name v1_r
ip link add v2 type veth peer name v2_r
ip link set v1 netns ns1
ip link set v2 netns ns2
ip a a 10.10.10.1/24 dev v1_r
ip l s v1_r up
ip a a 10.10.20.1/24 dev v2_r
ip l s v2_r up
ip netns exec ns1 ip a a 10.10.10.2/24 dev v1
ip netns exec ns1 ip l s v1 up
ip netns exec ns2 ip a a 10.10.20.2/24 dev v2
ip netns exec ns2 ip l s v2 up
ip netns exec ns1 route add -net 10.10.20.0 netmask 255.255.255.0 gw 10.10.10.1
ip netns exec ns2 route add -net 10.10.10.0 netmask 255.255.255.0 gw 10.10.20.1
ip netns exec ns1 ip tunnel add tun1 mode ipip remote 10.10.20.2 local 10.10.10.2
ip netns exec ns1 ip l s tun1 up
ip netns exec ns1 ip a a 10.10.100.10 peer 10.10.200.10 dev tun1
ip netns exec ns2 ip tunnel add tun2 mode ipip remote 10.10.10.2 local 10.10.20.2
ip netns exec ns2 ip l s tun2 up
ip netns exec ns2 ip a a 10.10.200.10 peer 10.10.100.10 dev tun2
ip netns exec ns1 ping 10.10.200.10 -c 4
ipip xmit:
static const struct net_device_ops ipip_netdev_ops = {
.ndo_start_xmit = ipip_tunnel_xmit,
};
/*
* This function assumes it is being called from dev_queue_xmit()
* and that skb is filled properly by that function.
*/
static netdev_tx_t ipip_tunnel_xmit(struct sk_buff *skb,
struct net_device *dev)
{
struct ip_tunnel *tunnel = netdev_priv(dev);
const struct iphdr *tiph = &tunnel->parms.iph;
u8 ipproto;
......
if (tunnel->collect_md)
ip_md_tunnel_xmit(skb, dev, ipproto, 0);
else
ip_tunnel_xmit(skb, dev, tiph, ipproto);
return NETDEV_TX_OK;
}
void ip_tunnel_xmit(struct sk_buff *skb, struct net_device *dev,
const struct iphdr *tnl_params, u8 protocol)
{
dst = tnl_params->daddr;
ip_tunnel_init_flow(&fl4, protocol, dst, tnl_params->saddr,
tunnel->parms.o_key, RT_TOS(tos), tunnel->parms.link,
tunnel->fwmark, skb_get_hash(skb));
......
if (!rt) {
rt = ip_route_output_key(tunnel->net, &fl4);
......
}
......
iptunnel_xmit(NULL, rt, skb, fl4.saddr, fl4.daddr, protocol, tos, ttl,
df, !net_eq(tunnel->net, dev_net(dev)));
return;
}
void iptunnel_xmit(struct sock *sk, struct rtable *rt, struct sk_buff *skb,
__be32 src, __be32 dst, __u8 proto,
__u8 tos, __u8 ttl, __be16 df, bool xnet)
{
......
iph->daddr = dst;
iph->saddr = src;
......
err = ip_local_out(net, sk, skb);
......
}
Jul 5 15:22:12 chro kernel: [ 60.166102] CPU: 14 PID: 4703 Comm: ping Not tainted 5.4.1+ #92
Jul 5 15:22:12 chro kernel: [ 60.166104] Hardware name: MACHENIKE F117-X/X15CN, BIOS 008.T14 01/26/2021
Jul 5 15:22:12 chro kernel: [ 60.166105] Call Trace:
Jul 5 15:22:12 chro kernel: [ 60.166108] dump_stack+0x6d/0x95
Jul 5 15:22:12 chro kernel: [ 60.166115] ipip_tunnel_xmit+0x47/0x160 [ipip]
Jul 5 15:22:12 chro kernel: [ 60.166120] dev_hard_start_xmit+0x96/0x200
Jul 5 15:22:12 chro kernel: [ 60.166124] ? vprintk_emit+0x80/0x2d0
Jul 5 15:22:12 chro kernel: [ 60.166128] __dev_queue_xmit+0x775/0xa10
Jul 5 15:22:12 chro kernel: [ 60.166130] ? vprintk_default+0x29/0x50
Jul 5 15:22:12 chro kernel: [ 60.166133] ? vprintk_func+0x47/0xc0
Jul 5 15:22:12 chro kernel: [ 60.166137] dev_queue_xmit+0x10/0x20
Jul 5 15:22:12 chro kernel: [ 60.166140] ? dev_queue_xmit+0x10/0x20
Jul 5 15:22:12 chro kernel: [ 60.166144] neigh_direct_output+0x11/0x20
Jul 5 15:22:12 chro kernel: [ 60.166147] ip_finish_output2+0x1fe/0x8a0
Jul 5 15:22:12 chro kernel: [ 60.166150] __ip_finish_output+0xfa/0x1c0
Jul 5 15:22:12 chro kernel: [ 60.166152] ? __ip_finish_output+0xfa/0x1c0
Jul 5 15:22:12 chro kernel: [ 60.166155] ip_finish_output+0x2c/0xa0
Jul 5 15:22:12 chro kernel: [ 60.166158] ip_output+0x6d/0xe0
Jul 5 15:22:12 chro kernel: [ 60.166161] ? __ip_finish_output+0x1c0/0x1c0
Jul 5 15:22:12 chro kernel: [ 60.166164] ip_local_out+0x3b/0x50
Jul 5 15:22:12 chro kernel: [ 60.166167] ip_send_skb+0x19/0x40
Jul 5 15:22:12 chro kernel: [ 60.166170] ip_push_pending_frames+0x33/0x40
Jul 5 15:22:12 chro kernel: [ 60.166175] raw_sendmsg+0x9e5/0xcc0
Jul 5 15:22:12 chro kernel: [ 60.166179] ? ttwu_do_wakeup+0x1e/0x150
Jul 5 15:22:12 chro kernel: [ 60.166185] ? regulator_unregister+0x78/0xe0
Jul 5 15:22:12 chro kernel: [ 60.166189] ? _cond_resched+0x19/0x40
Jul 5 15:22:12 chro kernel: [ 60.166192] ? aa_sk_perm+0x43/0x190
Jul 5 15:22:12 chro kernel: [ 60.166197] inet_sendmsg+0x64/0x70
Jul 5 15:22:12 chro kernel: [ 60.166201] ? inet_sendmsg+0x64/0x70
Jul 5 15:22:12 chro kernel: [ 60.166205] sock_sendmsg+0x5c/0x70
Jul 5 15:22:12 chro kernel: [ 60.166210] __sys_sendto+0x13f/0x180
Jul 5 15:22:12 chro kernel: [ 60.166215] ? ktime_get_ts64+0x51/0xf0
Jul 5 15:22:12 chro kernel: [ 60.166221] __x64_sys_sendto+0x28/0x30
Jul 5 15:22:12 chro kernel: [ 60.166226] do_syscall_64+0x57/0x190
Jul 5 15:22:12 chro kernel: [ 60.166231] entry_SYSCALL_64_after_hwframe+0x44/0xa9
阅读(674) | 评论(0) | 转发(0) |