netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net-next v2 00/10] vrf: allow simultaneous service instances in default and other VRFs
@ 2018-10-01  8:43 Mike Manning
  2018-10-01  8:43 ` [PATCH net-next v2 01/10] net: allow binding socket in a VRF when there's an unbound socket Mike Manning
                   ` (10 more replies)
  0 siblings, 11 replies; 15+ messages in thread
From: Mike Manning @ 2018-10-01  8:43 UTC (permalink / raw)
  To: netdev

Services currently have to be VRF-aware if they are using an unbound
socket. One cannot have multiple service instances running in the
default and other VRFs for services that are not VRF-aware and listen
on an unbound socket. This is because there is no way of isolating
packets received in the default VRF from those arriving in other VRFs.

This series provides this isolation subject to the existing kernel
parameter net.ipv4.tcp_l3mdev_accept not being set, given that this is
documented as allowing a single service instance to work across all
VRF domains. The functionality applies to UDP & TCP services, for IPv4
and IPv6, in particular adding VRF table handling for IPv6 multicast.

Example of running ssh instances in default and blue VRF:

$ /usr/sbin/sshd -D
$ ip vrf exec vrf-blue /usr/sbin/sshd
$ ss -ta | egrep 'State|ssh'
State   Recv-Q   Send-Q           Local Address:Port       Peer Address:Port
LISTEN  0        128           0.0.0.0%vrf-blue:ssh             0.0.0.0:*
LISTEN  0        128                    0.0.0.0:ssh             0.0.0.0:*
ESTAB   0        0              192.168.122.220:ssh       192.168.122.1:50282
LISTEN  0        128              [::]%vrf-blue:ssh                [::]:*
LISTEN  0        128                       [::]:ssh                [::]:*
ESTAB   0        0           [3000::2]%vrf-blue:ssh           [3000::9]:45896
ESTAB   0        0                    [2000::2]:ssh           [2000::9]:46398

v1:
   - Address Paolo Abeni's comments (patch 4/5)
   - Fix build when CONFIG_NET_L3_MASTER_DEV not defined (patch 1/5)
v2:
   - Address David Aherns' comments (patches 4/5 and 5/5)
   - Remove patches 3/5 and 5/5 from series for individual submissions
   - Include a sysctl for raw sockets as recommended by David Ahern
   - Expand series into 10 patches and provide improved descriptions

Dewi Morgan (1):
  ipv6: do not drop vrf udp multicast packets

Duncan Eastoe (2):
  net: fix raw socket lookup device bind matching with VRFs
  net: IP[V6]_MULTICAST_IF constraint on unbound socket if VRFs present

Mike Manning (6):
  net: ensure unbound stream socket to be chosen when not in a VRF
  net: ensure unbound datagram socket to be chosen when not in a VRF
  net: provide a sysctl raw_l3mdev_accept for raw socket lookup with
    VRFs
  vrf: mark skb for multicast or link-local as enslaved to VRF
  ipv6: allow ping to link-local address in VRF
  ipv6: handling of multicast packets received in VRF

Robert Shearman (1):
  net: allow binding socket in a VRF when there's an unbound socket

 Documentation/networking/ip-sysctl.txt |  9 +++++++++
 Documentation/networking/vrf.txt       | 17 ++++++++++-------
 drivers/net/vrf.c                      | 19 +++++++++---------
 include/net/inet6_hashtables.h         |  5 ++---
 include/net/inet_hashtables.h          | 24 ++++++++++++++++-------
 include/net/inet_sock.h                | 21 ++++++++++++++++++++
 include/net/netns/ipv4.h               |  3 +++
 include/net/raw.h                      | 12 ++++++++++++
 include/net/udp.h                      | 11 +++++++++++
 net/core/sock.c                        |  2 ++
 net/ipv4/inet_connection_sock.c        | 13 ++++++++++---
 net/ipv4/inet_hashtables.c             | 34 ++++++++++++++++++++-------------
 net/ipv4/ip_sockglue.c                 |  3 +++
 net/ipv4/raw.c                         |  4 ++--
 net/ipv4/sysctl_net_ipv4.c             | 11 +++++++++++
 net/ipv4/udp.c                         | 15 ++++++---------
 net/ipv6/datagram.c                    |  5 ++++-
 net/ipv6/inet6_hashtables.c            | 14 ++++++--------
 net/ipv6/ip6_input.c                   | 35 +++++++++++++++++++++++++++++++---
 net/ipv6/ipv6_sockglue.c               |  5 ++++-
 net/ipv6/raw.c                         |  6 +++---
 net/ipv6/udp.c                         | 22 ++++++++++-----------
 22 files changed, 208 insertions(+), 82 deletions(-)

-- 
2.11.0

^ permalink raw reply	[flat|nested] 15+ messages in thread

end of thread, other threads:[~2018-10-03  3:01 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-10-01  8:43 [PATCH net-next v2 00/10] vrf: allow simultaneous service instances in default and other VRFs Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 01/10] net: allow binding socket in a VRF when there's an unbound socket Mike Manning
2018-10-02 19:39   ` David Ahern
2018-10-01  8:43 ` [PATCH net-next v2 02/10] net: ensure unbound stream socket to be chosen when not in a VRF Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 03/10] net: ensure unbound datagram " Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 04/10] net: provide a sysctl raw_l3mdev_accept for raw socket lookup with VRFs Mike Manning
2018-10-02 19:39   ` David Ahern
2018-10-01  8:43 ` [PATCH net-next v2 05/10] net: fix raw socket lookup device bind matching " Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 06/10] net: IP[V6]_MULTICAST_IF constraint on unbound socket if VRFs present Mike Manning
2018-10-02 19:59   ` David Ahern
2018-10-01  8:43 ` [PATCH net-next v2 07/10] vrf: mark skb for multicast or link-local as enslaved to VRF Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 08/10] ipv6: allow ping to link-local address in VRF Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 09/10] ipv6: handling of multicast packets received " Mike Manning
2018-10-01  8:43 ` [PATCH net-next v2 10/10] ipv6: do not drop vrf udp multicast packets Mike Manning
2018-10-02 20:16 ` [PATCH net-next v2 00/10] vrf: allow simultaneous service instances in default and other VRFs David Ahern

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).