From patchwork Wed Oct 18 20:10:06 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Tom Herbert X-Patchwork-Id: 827801 Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Authentication-Results: ozlabs.org; spf=none (mailfrom) smtp.mailfrom=vger.kernel.org (client-ip=209.132.180.67; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=quantonium-net.20150623.gappssmtp.com header.i=@quantonium-net.20150623.gappssmtp.com header.b="fvl52ZM6"; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 3yHNVM6z1Qz9t48 for ; Thu, 19 Oct 2017 07:11:07 +1100 (AEDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751276AbdJRULF (ORCPT ); Wed, 18 Oct 2017 16:11:05 -0400 Received: from mail-pg0-f65.google.com ([74.125.83.65]:47467 "EHLO mail-pg0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751465AbdJRUKy (ORCPT ); Wed, 18 Oct 2017 16:10:54 -0400 Received: by mail-pg0-f65.google.com with SMTP id r25so5161837pgn.4 for ; Wed, 18 Oct 2017 13:10:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quantonium-net.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=7mr2WGO4n9rxzSGyWaKxc0bCJtfL26UNxk3oUUBr8zk=; b=fvl52ZM6EHNJZHlXMTH/wt3G/T4bc3jzK9ZdzNgR5aQf/iZKy3mxtLurRDy/uo/PFn Kxl1lw54ttPL6WE1fWiEifM6TPW09N3sKU3JWNxHlpgEd4X6UD0BbYKOP1T0m2cM0Ngc PgaLo8wJhf7KoV5qx+8HlEUsXJXsNs/XWOQjUEhnmA9J27VaNBm7ygkSp5SoErcWw2gU zXgR9wTfAXl52wojEwpZk6Lmg/1dQOIxZ6ZnGS+pJ5kU8IcZ5G5l80Kas3A4AJGkigda oJ8iA7xJbBzXarY28FJTh1Tq9EM0uGBPT0TN8Chi24KLSaGQi9/vIdBJX2zkbxOW5XAa 1dUQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=7mr2WGO4n9rxzSGyWaKxc0bCJtfL26UNxk3oUUBr8zk=; b=Cs8oLj2H8CXRqrg3S2Idq5ql4ryDCyJnvAiuMB5YEDadWBuUsg1AVRSFmodPFLKXke 1DqAiW5/KCr1hkSMRYifHoa9SEnltIlXnSeaXq3OiS7gEu9MVFoDstaI1Topc/RRzH/v JImQ9hBTr0Zj50x3GTTgxNUYTrR4ecQvU6jxzMBxMh0aJ0ydAJ1zthAR91Fm1Fc5DSzf m51i38LT9y+XDGm5NX/nZNJ1FEATDEcXfbmgw0sMWZs088orhZrxRQIeylcHg17sC+kq W54Yg554bfwfIWcbuGljquYQbny1hpQ+8hvEtmcMq53mXiWPO6bMxafxW+NCL+Hmh2ev h3mw== X-Gm-Message-State: AMCzsaUwjAHRrY0wBwhITIQQkN054CF3/7l3kNXVvMEv0+hxknXDOr7k YS4jZjG8Ub2dlJ3ySHhkegmzFA== X-Google-Smtp-Source: AOwi7QA/eu7LjlkqYTB4B/aIIf8uNn1WvCLz09KcX8/F+Q5mL2fu+k0I/a8o+F4OfUyKia+lZe2mOg== X-Received: by 10.99.143.29 with SMTP id n29mr14893595pgd.121.1508357453179; Wed, 18 Oct 2017 13:10:53 -0700 (PDT) Received: from localhost.localdomain (c-73-162-13-107.hsd1.ca.comcast.net. [73.162.13.107]) by smtp.gmail.com with ESMTPSA id l79sm26424108pfb.33.2017.10.18.13.10.51 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 18 Oct 2017 13:10:52 -0700 (PDT) From: Tom Herbert To: davem@davemloft.net Cc: pablo@netfilter.org, laforge@gnumonks.org, aschultz@tpip.net, netdev@vger.kernel.org, rohit@quantonium.net, Tom Herbert Subject: [PATCH v5 net-next 00/12] gtp: Additional feature support - Part I Date: Wed, 18 Oct 2017 13:10:06 -0700 Message-Id: <20171018201018.5692-1-tom@quantonium.net> X-Mailer: git-send-email 2.11.0 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org This patch set builds upon the initial GTP implementation to make support closer to that enjoyed by other encapsulation protocols. The major items are: - Experimental IPv6 support - Configurable networking interfaces so that GTP kernel can be used and tested without needing GSN network emulation (i.e. no user space daemon needed). - Addition of a dst_cache in the GTP structure and other cleanup Additionally, this patch set also includes: - Common functions to get a route fo for an IP tunnel For IPv6 support, the mobile subscriber needs to allow IPv6 addresses, and the remote endpoint can be IPv6. For configurable interfaces, configuration is added to allow an alternate means to configure a GTP and device. This follows the typical UDP encapsulation model of specifying a listener port for receive, and a remote address and port for transmit. Configuration is performed by iproute2/ip. I will post that in a subsequent patch set. Tested: Configured the matrix of IPv4/IPv6 mobile subscriber, IPv4/IPv6 remote peer, and GTP version 0 and 1 (eight combinations). Observed connectivity and functional netperf. Also, tested VXLAN for regression. Test using openggs with ggsn and kernel module on one side and emulated sgsn on the other. Observed connectivity and functional netperf. v2: - Split the original patch to post in parts in order to make review more manageable - Make IPv6 support experimental with a configuration option for it - Prepend hash functions with gtp - Generalize iptunnel update path MTU function and call it from gtp instead using custom code - Split original patch cleaning up udp_recv into several for easier review v3: Properly include netdev on cc v4: - Move __ip6_tnl_get_route to ipv6/route.c to avoid creting dependency on ip6_tunnel - Add "select GRO_CELLS" fo Kconfig for GTP v5: - Rebase to current next-net and repost Tom Herbert (12): iptunnel: Add common functions to get a tunnel route vxlan: Call common functions to get tunnel routes gtp: Call common functions to get tunnel routes and add dst_cache iptunnel: Generalize tunnel update pmtu gtp: Change to use gro_cells gtp: Use goto for exceptions in gtp_udp_encap_recv funcs gtp: udp recv clean up gtp: Call function to update path mtu gtp: Eliminate pktinfo and add port configuration gtp: Experimental encapsulation of IPv6 packets gtp: Experimental support encpasulating over IPv6 gtp: Allow configuring GTP interface as standalone drivers/net/Kconfig | 13 +- drivers/net/gtp.c | 1043 ++++++++++++++++++++++++++++++------------ drivers/net/vxlan.c | 84 +--- include/net/ip6_tunnel.h | 33 ++ include/net/ip_tunnels.h | 36 ++ include/uapi/linux/gtp.h | 8 + include/uapi/linux/if_link.h | 3 + net/ipv4/ip_tunnel.c | 70 ++- net/ipv6/route.c | 42 ++ 9 files changed, 945 insertions(+), 387 deletions(-)