On 04/26/2018 11:01 PM, William Tu wrote:
> The patch series provide end-to-end eBPF tunnel testsute.  A common topology
> is created below for all types of tunnels:
> 
> Topology:                                                                     
> ---------                                                                     
>      root namespace   |     at_ns0 namespace                                  
>  
>                       |                                                       
>  
>       -----------     |     -----------                                       
>  
>       | tnl dev |     |     | tnl dev |  (overlay network)                    
>  
>       -----------     |     -----------                                       
>  
>       metadata-mode   |     native-mode                                       
>  
>        with bpf       |                                                       
>  
>                       |                                                       
>  
>       ----------      |     ----------                                        
>  
>       |  veth1  | --------- |  veth0  |  (underlay network)                   
>  
>       ----------    peer    ----------                                        
>  
>                                                                               
>       
>                                                                               
>  
> Device Configuration                                                          
> --------------------                                                          
>  Root namespace with metadata-mode tunnel + BPF                               
>  
>  Device names and addresses:                                                  
>  
>        veth1 IP: 172.16.1.200, IPv6: 00::22 (underlay)                        
>  
>        tunnel dev <type>11, ex: gre11, IPv4: 10.1.1.200 (overlay)             
>  
>                                                                               
>  
>  Namespace at_ns0 with native tunnel                                          
>  
>  Device names and addresses:                                                  
>  
>        veth0 IPv4: 172.16.1.100, IPv6: 00::11 (underlay)                      
>  
>        tunnel dev <type>00, ex: gre00, IPv4: 10.1.1.100 (overlay)             
>  
>                                                                               
>  
>                                                                               
>  
> End-to-end ping packet flow                                                   
> ---------------------------                                                   
>  Most of the tests start by namespace creation, device configuration,         
>  
>  then ping the underlay and overlay network.  When doing 'ping 10.1.1.100'    
>  
>  from root namespace, the following operations happen:                        
>  
>  1) Route lookup shows 10.1.1.100/24 belongs to tnl dev, fwd to tnl dev.      
>  
>  2) Tnl device's egress BPF program is triggered and set the tunnel metadata, 
>  
>     with remote_ip=172.16.1.200 and others.                                   
>  
>  3) Outer tunnel header is prepended and route the packet to veth1's egress   
>  
>  4) veth0's ingress queue receive the tunneled packet at namespace at_ns0     
>  
>  5) Tunnel protocol handler, ex: vxlan_rcv, decap the packet                  
>  
>  6) Forward the packet to the overlay tnl dev                                 
>  
> 
> Test Cases
> -----------------------------
>  Tunnel Type |  BPF Programs
> -----------------------------
>  GRE:          gre_set_tunnel, gre_get_tunnel
>  IP6GRE:       ip6gretap_set_tunnel, ip6gretap_get_tunnel
>  ERSPAN:       erspan_set_tunnel, erspan_get_tunnel
>  IP6ERSPAN:    ip4ip6erspan_set_tunnel, ip4ip6erspan_get_tunnel
>  VXLAN:        vxlan_set_tunnel, vxlan_get_tunnel
>  IP6VXLAN:     ip6vxlan_set_tunnel, ip6vxlan_get_tunnel
>  GENEVE:       geneve_set_tunnel, geneve_get_tunnel
>  IP6GENEVE:    ip6geneve_set_tunnel, ip6geneve_get_tunnel
>  IPIP:         ipip_set_tunnel, ipip_get_tunnel
>  IP6IP:        ipip6_set_tunnel, ipip6_get_tunnel,
>                ip6ip6_set_tunnel, ip6ip6_get_tunnel
>  XFRM:         xfrm_get_state

Applied yesterday night to bpf-next (and now in net-next), thanks William!

Reply via email to