Commit ab4ca4cb authored by Brenden Blanco's avatar Brenden Blanco

Merge pull request #168 from iovisor/weichunc_dev

Add gretap support for full mesh tunnel
parents ef3b5d9d 3fe56c3c
......@@ -9,12 +9,22 @@ from simulation import Simulation
from subprocess import PIPE, call, Popen
import re
dhcp = 0
multicast = 1
if len(argv) > 1 and argv[1] == "mesh":
dhcp = 0
gretap = 0
if "mesh" in argv:
multicast = 0
if len(argv) > 2 and argv[2] == "dhcp":
if "dhcp" in argv:
dhcp = 1
multicast = 0
if "gretap" in argv:
gretap = 1
multicast = 0
print("multicast %d dhcp %d gretap %d" % (multicast, dhcp, gretap))
ipr = IPRoute()
ipdb = IPDB(nl=ipr)
......@@ -37,7 +47,7 @@ class TunnelSimulation(Simulation):
if multicast:
cmd = ["python", "tunnel.py", str(i)]
else:
cmd = ["python", "tunnel_mesh.py", str(num_hosts), str(i), str(dhcp)]
cmd = ["python", "tunnel_mesh.py", str(num_hosts), str(i), str(dhcp), str(gretap)]
p = NSPopen(host_info[i][0].nl.netns, cmd, stdin=PIPE)
self.processes.append(p)
with self.ipdb.create(ifname="br-fabric", kind="bridge") as br:
......
......@@ -17,6 +17,7 @@ from subprocess import call, Popen, PIPE
num_hosts = int(argv[1])
host_id = int(argv[2])
dhcp = int(argv[3])
gretap = int(argv[4])
b = BPF(src_file="tunnel_mesh.c")
ingress_fn = b.load_func("handle_ingress", BPF.SCHED_CLS)
......@@ -38,9 +39,15 @@ d_serv = []
d_client = []
def run():
if gretap:
with ipdb.create(ifname="gretap1", kind="gretap", gre_ikey=0, gre_okey=0,
gre_local='172.16.1.%d' % (100 + host_id),
gre_ttl=16, gre_collect_metadata=1) as vx:
vx.up()
ifc_gc.append(vx.ifname)
else:
with ipdb.create(ifname="vxlan0", kind="vxlan", vxlan_id=0,
vxlan_link=ifc, vxlan_port=htons(4789),
vxlan_flowbased=True,
vxlan_collect_metadata=True,
vxlan_learning=False) as vx:
vx.up()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment