diff options
author | Wilson Peng <pweisong@vmware.com> | 2022-04-06 21:18:19 +0800 |
---|---|---|
committer | Alin-Gabriel Serdean <aserdean@ovn.org> | 2022-04-10 05:18:59 +0300 |
commit | edb2335861d629f791467f77729e743378dac15f (patch) | |
tree | 82268b884ee34ba9aa689eec2ea3708649971ee4 /datapath-windows/ovsext/DpInternal.h | |
parent | 9d70f4a7c3df3bb33e64d8866e3aa752d747de70 (diff) | |
download | openvswitch-edb2335861d629f791467f77729e743378dac15f.tar.gz |
datapath-windows: Add IPv6 Geneve tunnel support in Windows
In the first step OVS Windows will support IPv6 tunnel(Geneve IPv6 tunnel).
Implementation on Windows
-------------------------
1. For the IPv6 tunnel support, OvsIPTunnelKey will replace original
OvsIPv4TunnelKey in the related flow context handing.
2. The related src and dst address will be changed to SOCKADDR_INET type from UINT32.
3. For the IPv6 tunnel, one node running OVS-Windows could encapsulate IPv4/IPv6
Packets via IPV6 Geneve Tunnel, and the node could also encapsulate IPv4/IPv6 packet
Via IPv4 Geneve tunnel.
4. Related IPHelper data structure will be adapted to support IPv6 Tunnel. In the IPHelper
part the related Windows API(such as GetUnicastIpAddressTable/GetBestRoute2/GetIpNetEntry2/
ResolveIpNetEntry2) and Windows data structure(MIB_IPFORWARD_ROW2/MIB_IPNET_ROW2/IP_ADDRESS_PREFIX)
Have already supported both IPv4 and IPV6. Now OVS Windows has been adjusted some functions
And data structured to support IPV6 tunnel also.
5. OVS_TUNNEL_KEY_ATTR_IPV6_SRC and OVS_TUNNEL_KEY_ATTR_IPV6_DST filed will be supported in
OVS-Windows kernel for IPV6 tunnel.
Testing done.
-------------------------
Related topo, 1 Windows VM(Win2019) and 2 Ubuntu 16.04 server. Both VMs
Are running on one ESX host.
1. Setup one IPV6 Geneve Tunnel between 1 Windows VM and 1 Ubuntu server.
Windows VM, vif0( 6000::2/40.1.1.10) vif1(5000::2)—— Ubuntu VM Eth2(5000::9), name space ns1
with interface ns1_link_peer(6000::9/40.1.1.2)
Related tunnnel,
ovs-vsctl.exe add-port br-int bms-tun0 -- set interface bms-tun0 type=Geneve options:csum=true
options:key=flow options:local_ip="5000::2" options:remote_ip=flow
In this topo, traffic from Vif0(Win) to ns1_link_peer(Ubuntu) will be gone through the Geneve tunnel
(5000::2—>5000::9) for both IPv4 traffic(40.1.1.10-->40.1.1.2) and IPv6 traffic(6000::2—>6000::9)
2. Setup one IPV4 Geneve Tunnel between Windows VM and 1 Ubuntu server.
Windows VM, vif0( 6000::2/40.1.1.10) vif1(50.1.1.11)—— Ubuntu, Eth2(50.1.1.9), name space ns1
with interface ns1_link_peer(6000::19/40.1.1.9)
Related tunnnel,
ovs-vsctl.exe -- set Interface bms-tun0 type=geneve options:csum=true options:key=flow
options:local_ip="50.1.1.11" options:remote_ip=flow
In this topo, traffic from Vif0(Win) to ns1_link_peer(Ubuntu) will be gone through the Geneve Tunnel
(50.1.1.11—>50.1.1.9) for both IPv4 traffic(40.1.1.10-->40.1.1.9) and IPv6 traffic(6000::2—>6000::19).
3.Regression test for IpV4 in Antrea project (about 60 test case) is PASS
Future Work
-----------
Add other type IPv6 tunnel support for Gre/Vxlan/Stt.
Signed-off-by: Wilson Peng <pweisong@vmware.com>
Signed-off-by: Alin-Gabriel Serdean <aserdean@ovn.org>
Diffstat (limited to 'datapath-windows/ovsext/DpInternal.h')
-rw-r--r-- | datapath-windows/ovsext/DpInternal.h | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/datapath-windows/ovsext/DpInternal.h b/datapath-windows/ovsext/DpInternal.h index 58e7ed8e2..b5027e35e 100644 --- a/datapath-windows/ovsext/DpInternal.h +++ b/datapath-windows/ovsext/DpInternal.h @@ -137,7 +137,7 @@ typedef struct L2Key { #define NUM_PKT_ATTR_REQUIRED 35 #define TUN_OPT_MAX_LEN 255 -typedef union OvsIPv4TunnelKey { +typedef union OvsIPTunnelKey { /* Options should always be the first member of tunnel key. * They are stored at the end of the array if they are less than the * maximum size. This allows us to get the benefits of variable length @@ -146,8 +146,9 @@ typedef union OvsIPv4TunnelKey { struct { UINT8 tunOpts[TUN_OPT_MAX_LEN]; /* Tunnel options. */ UINT8 tunOptLen; /* Tunnel option length in byte. */ - ovs_be32 dst; - ovs_be32 src; + + SOCKADDR_INET dst; /* IPv4/6 destination address. */ + SOCKADDR_INET src; /* IPv4/6 source address. */ ovs_be64 tunnelId; uint16_t flags; uint8_t tos; @@ -161,24 +162,24 @@ typedef union OvsIPv4TunnelKey { }; }; uint64_t attr[NUM_PKT_ATTR_REQUIRED]; -} OvsIPv4TunnelKey; /* Size of 280 byte. */ +} OvsIPTunnelKey; /* Size of 280+40-8= 312 byte. */ static __inline uint8_t -TunnelKeyGetOptionsOffset(const OvsIPv4TunnelKey *key) +IPTunnelKeyGetOptionsOffset(const OvsIPTunnelKey *key) { return TUN_OPT_MAX_LEN - key->tunOptLen; } static __inline uint8_t * -TunnelKeyGetOptions(OvsIPv4TunnelKey *key) +IPTunnelKeyGetOptions(OvsIPTunnelKey *key) { - return key->tunOpts + TunnelKeyGetOptionsOffset(key); + return key->tunOpts + IPTunnelKeyGetOptionsOffset(key); } static __inline uint16_t -TunnelKeyGetRealSize(OvsIPv4TunnelKey *key) +IPTunnelKeyGetRealSize(OvsIPTunnelKey *key) { - return sizeof(OvsIPv4TunnelKey) - TunnelKeyGetOptionsOffset(key); + return sizeof(OvsIPTunnelKey) - IPTunnelKeyGetOptionsOffset(key); } typedef struct MplsKey { @@ -187,7 +188,7 @@ typedef struct MplsKey { } MplsKey; /* Size of 8 bytes. */ typedef __declspec(align(8)) struct OvsFlowKey { - OvsIPv4TunnelKey tunKey; /* 280 bytes */ + OvsIPTunnelKey tunKey; /* 280 bytes? */ L2Key l2; /* 32 bytes */ union { /* These headers are mutually exclusive. */ @@ -209,7 +210,7 @@ typedef __declspec(align(8)) struct OvsFlowKey { } ct; /* Connection Tracking Flags */ } OvsFlowKey; -#define OVS_WIN_TUNNEL_KEY_SIZE (sizeof (OvsIPv4TunnelKey)) +#define OVS_WIN_IP_TUNNEL_KEY_SIZE (sizeof (OvsIPTunnelKey)) #define OVS_L2_KEY_SIZE (sizeof (L2Key)) #define OVS_IP_KEY_SIZE (sizeof (IpKey)) #define OVS_IPV6_KEY_SIZE (sizeof (Ipv6Key)) @@ -295,7 +296,7 @@ typedef struct _OVS_PACKET_INFO { uint32_t queue; uint32_t inPort; uint32_t cmd; - OvsIPv4TunnelKey tunnelKey; + OvsIPTunnelKey tunnelKey; uint8_t *payload; /* Includes user data defined as chain of netlink attributes followed by the * packet data. */ |