Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752146AbdIMUWY convert rfc822-to-8bit (ORCPT ); Wed, 13 Sep 2017 16:22:24 -0400 Received: from relay2-d.mail.gandi.net ([217.70.183.194]:41900 "EHLO relay2-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751956AbdIMUWU (ORCPT ); Wed, 13 Sep 2017 16:22:20 -0400 X-Originating-IP: 209.85.128.182 X-Google-Smtp-Source: ADKCNb60LMU467qwSoAyT48WEKi7CdLE4flGToSKCcZH/oaQ2ByQMA4Eaiouj9PHAOMUciKZv0LyOtObnCQrTUPENdQ= MIME-Version: 1.0 In-Reply-To: <95A24784-0575-47CE-A485-B2A59911262A@cmss.chinamobile.com> References: <1505199911-21153-1-git-send-email-yanhaishuang@cmss.chinamobile.com> <95A24784-0575-47CE-A485-B2A59911262A@cmss.chinamobile.com> From: Pravin Shelar Date: Wed, 13 Sep 2017 13:22:18 -0700 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v2] geneve: Fix setting ttl value in collect metadata mode To: =?UTF-8?B?5Lil5rW35Y+M?= Cc: "David S. Miller" , Girish Moodalbail , Linux Kernel Network Developers , linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1828 Lines: 44 On Wed, Sep 13, 2017 at 4:15 AM, 严海双 wrote: > > >> On 2017年9月13日, at 上午7:43, Pravin Shelar wrote: >> >> On Tue, Sep 12, 2017 at 12:05 AM, Haishuang Yan >> wrote: >>> Similar to vxlan/ipip tunnel, if key->tos is zero in collect metadata >>> mode, tos should also fallback to ip{4,6}_dst_hoplimit. >>> >>> Signed-off-by: Haishuang Yan >>> >>> --- >>> Changes since v2: >>> * Make the commit message more clearer. >>> --- >>> drivers/net/geneve.c | 6 ++---- >>> 1 file changed, 2 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/net/geneve.c b/drivers/net/geneve.c >>> index f640407..d52a65f 100644 >>> --- a/drivers/net/geneve.c >>> +++ b/drivers/net/geneve.c >>> @@ -834,11 +834,10 @@ static int geneve_xmit_skb(struct sk_buff *skb, struct net_device *dev, >>> sport = udp_flow_src_port(geneve->net, skb, 1, USHRT_MAX, true); >>> if (geneve->collect_md) { >>> tos = ip_tunnel_ecn_encap(key->tos, ip_hdr(skb), skb); >>> - ttl = key->ttl; >>> } else { >>> tos = ip_tunnel_ecn_encap(fl4.flowi4_tos, ip_hdr(skb), skb); >>> - ttl = key->ttl ? : ip4_dst_hoplimit(&rt->dst); >>> } >>> + ttl = key->ttl ? : ip4_dst_hoplimit(&rt->dst); >>> df = key->tun_flags & TUNNEL_DONT_FRAGMENT ? htons(IP_DF) : 0; >>> >> This changes user API of Geneve collect-metadata mode. I do not see >> good reason for this. Why user can not set right TTL for the flow? >> > > For example, I test this case with script samples/bpf/test_tunnel_bpf.sh, > and modify samples/bpf/tcbpf2_kern.c with following patch: > But user is suppose to specify the TTL in collect-md mode for Geneve tunnel. That is the API.