On Tue, Sep 13, 2016 at 07:08:52AM +0000, Waizel, Ariel wrote:
> When adding a VXLAN tunnel that connects to a VTEP residing in a different IP 
> network, the tunnel source ip needs to be selected by best fit (longest 
> matching netmask), based on the destination VTEP ip, and the specific route's 
> gateway ip.
> 
> A bug in ovs-router.c made the source ip to be decided only based on the 
> destination ip: Thus, if all source ips available to OVS and the destination 
> ip are in different ip networks - no source ip is selected, and an error is 
> returned.
> 
> This error accorded when  using OVS-DPDK and configuring a VXLAN tunnel where 
> source ip and destination ip are in different networks, and a gateway ip was 
> in place for the specific route.
> 
> The fix tries to match a source ip based on the gateway ip, if no matching 
> source ip was found based on the destination ip - This way, the gateway 
> becomes the first hop only if the tunnel crosses between ip networks.
> 
> Signed-off-by: Ariel Waizel <ariel.wai...@hpe.com>
> 
> diff --git a/lib/ovs-router.c b/lib/ovs-router.c
> index e27514a..18d0f8e 100644
> --- a/lib/ovs-router.c
> +++ b/lib/ovs-router.c
> @@ -198,6 +198,9 @@ ovs_router_insert__(uint8_t priority, const struct 
> in6_addr *ip6_dst,
>      p->plen = plen;
>      p->priority = priority;
>      err = get_src_addr(ip6_dst, output_bridge, &p->src_addr);
> +    if (err && ipv6_addr_is_set(gw)) {
> +        err = get_src_addr(gw, output_bridge, &p->src_addr);
> +    }
>      if (err) {
>          free(p);
>          return err;

Hi, Ariel.

Thanks for that. Can you resend wrapping the log text to 72 columns and add a
test? At least one test verifying that adding such routes with ovs/route/add
work as expected.

Acked-by: Thadeu Lima de Souza Cascardo <casca...@redhat.com>

Cascardo.
_______________________________________________
dev mailing list
dev@openvswitch.org
http://openvswitch.org/mailman/listinfo/dev

Reply via email to