Framework: Code aligments 89/28589/5
authorpmikus <pmikus@cisco.com>
Thu, 27 Aug 2020 07:47:31 +0000 (07:47 +0000)
committerPeter Mikus <pmikus@cisco.com>
Thu, 3 Sep 2020 06:41:47 +0000 (06:41 +0000)
+ Unifying code structures
  - To easily plug another DUT
+ New PCI PassThrough templates
+ Improved perf stat on cores allocated in test.

Signed-off-by: pmikus <pmikus@cisco.com>
Change-Id: I325f17b977314f93cb91818feddfddf3e607eb8a

17 files changed:
resources/libraries/python/Constants.py
resources/libraries/python/PerfUtil.py
resources/libraries/python/QemuManager.py
resources/libraries/python/QemuUtils.py
resources/libraries/robot/performance/performance_utils.robot
resources/libraries/robot/shared/default.robot
resources/libraries/robot/shared/vm.robot
resources/templates/vm/vpp_2vfpt_ethip4_nat44ed_h1024_p63_s64512.exec
resources/templates/vm/vpp_2vfpt_ethip4_nat44ed_h16384_p63_s1032192.exec
resources/templates/vm/vpp_2vfpt_ethip4_nat44ed_h4096_p63_s258048.exec
resources/templates/vm/vpp_2vfpt_ethip4ipsec1tnl_nat44ed_s64512.exec [new file with mode: 0644]
resources/templates/vm/vpp_2vfpt_ethip4ipsec1tnl_plen30.exec
resources/templates/vm/vpp_2vfpt_ethip4ipsec40tnl_plen30.exec
resources/templates/vm/vpp_2vfpt_ip4base_plen24.exec
resources/templates/vm/vpp_2vfpt_ip4scale200k_plen30.exec
resources/templates/vm/vpp_2vfpt_ip4scale20k_plen30.exec
resources/templates/vm/vpp_2vfpt_ip4scale2k_plen30.exec

index 6e44d39..437c97f 100644 (file)
@@ -139,8 +139,8 @@ class Constants:
     # Kubernetes templates location
     RESOURCES_TPL_K8S = u"resources/templates/kubernetes"
 
-    # KernelVM templates location
-    RESOURCES_TPL_VM = u"resources/templates/vm"
+    # Templates location
+    RESOURCES_TPL = u"resources/templates"
 
     # Container templates location
     RESOURCES_TPL_CONTAINER = u"resources/templates/container"
@@ -215,7 +215,10 @@ class Constants:
     CORE_DUMP_DIR = u"/tmp"
 
     # Perf stat events (comma separated).
-    PERF_STAT_EVENTS = u"L1-icache-load-misses"
+    PERF_STAT_EVENTS = get_str_from_env(
+        u"PERF_STAT_EVENTS",
+        u"cpu-clock,context-switches,cpu-migrations,page-faults,"
+        u"cycles,instructions,branches,branch-misses,L1-icache-load-misses")
 
     # Equivalent to ~0 used in vpp code
     BITWISE_NON_ZERO = 0xffffffff
index 4c286b4..6444cc5 100644 (file)
@@ -14,6 +14,7 @@
 """Linux perf utility."""
 
 from resources.libraries.python.Constants import Constants
+from resources.libraries.python.OptionString import OptionString
 from resources.libraries.python.ssh import exec_cmd
 from resources.libraries.python.topology import NodeType
 
@@ -28,29 +29,42 @@ class PerfUtil:
         """Get perf stat read for duration.
 
         :param node: Node in the topology.
-        :param cpu_list: CPU List.
+        :param cpu_list: CPU List as a string separated by comma.
         :param duration: Measure time in seconds.
         :type node: dict
         :type cpu_list: str
         :type duration: int
         """
-        cpu = cpu_list if cpu_list else u"0-$(($(nproc) - 1))"
-        if Constants.PERF_STAT_EVENTS:
-            command = (
-                u"perf stat"
-                f" --cpu {cpu} --no-aggr"
-                f" --event '{{{Constants.PERF_STAT_EVENTS}}}'"
-                f" --interval-print 1000 "
-                f" -- sleep {int(duration)}"
-            )
-        else:
-            command = (
-                u"perf stat"
-                f" --cpu {cpu} --no-aggr"
-                f" --interval-print 1000 "
-                f" -- sleep {int(duration)}"
-            )
-        exec_cmd(node, command, sudo=True)
+        if cpu_list:
+            cpu_list = list(dict.fromkeys(cpu_list.split(u",")))
+            cpu_list = ",".join(str(cpu) for cpu in cpu_list)
+
+        cmd_opts = OptionString(prefix=u"--")
+        cmd_opts.add(u"no-aggr")
+        cmd_opts.add_with_value_if(
+            u"cpu", cpu_list, cpu_list
+        )
+        cmd_opts.add_if(
+            u"all-cpus", not(cpu_list)
+        )
+        cmd_opts.add_with_value_if(
+            u"event", f"'{{{Constants.PERF_STAT_EVENTS}}}'",
+            Constants.PERF_STAT_EVENTS
+        )
+        cmd_opts.add_with_value(
+            u"interval-print", 1000
+        )
+        cmd_opts.add_with_value(
+            u"field-separator", u"';'"
+        )
+
+        cmd_base = OptionString()
+        cmd_base.add(f"perf stat")
+        cmd_base.extend(cmd_opts)
+        cmd_base.add(u"--")
+        cmd_base.add_with_value(u"sleep", int(duration))
+
+        exec_cmd(node, cmd_base, sudo=True)
 
     @staticmethod
     def perf_stat_on_all_duts(nodes, cpu_list=None, duration=1):
index 66a21aa..547250e 100644 (file)
@@ -107,6 +107,7 @@ class QemuManager:
         :param pinning: If True, then do also QEMU process pinning.
         :type pinning: bool
         """
+        cpus = []
         for machine, machine_affinity in \
                 zip(self.machines.values(), self.machines_affinity.values()):
             index = list(self.machines.values()).index(machine)
@@ -114,6 +115,8 @@ class QemuManager:
             self.nodes[name] = machine.qemu_start()
             if pinning:
                 machine.qemu_set_affinity(*machine_affinity)
+                cpus.extend(machine_affinity)
+        return ",".join(str(cpu) for cpu in cpus)
 
     def kill_all_vms(self, force=False):
         """Kill all added VMs in manager.
@@ -176,3 +179,243 @@ class QemuManager:
             csum=kwargs[u"enable_csum"],
             gso=kwargs[u"enable_gso"]
         )
+
+    def _c_vpp_2vfpt_ip4base_plen24(self, **kwargs):
+        """Instantiate one VM with vpp_2vfpt_ip4base_plen24 configuration.
+
+        :param kwargs: Named parameters.
+        :type kwargs: dict
+        """
+        qemu_id = kwargs[u"qemu_id"]
+        name = kwargs[u"name"]
+
+        self.machines[name] = QemuUtils(
+            node=self.nodes[kwargs[u"node"]],
+            qemu_id=qemu_id,
+            smp=len(self.machines_affinity[name]),
+            mem=4096,
+            vnf=kwargs[u"vnf"],
+            img=Constants.QEMU_VM_KERNEL
+        )
+        self.machines[name].add_default_params()
+        self.machines[name].add_kernelvm_params()
+        if u"DUT1" in name:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"2.2.2.1/30",
+                ip2=u"1.1.1.2/30",
+                route1=u"20.0.0.0/24",
+                routeif1=u"avf-0/0/6/0",
+                nexthop1=u"2.2.2.2",
+                route2=u"10.0.0.0/24",
+                routeif2=u"avf-0/0/7/0",
+                nexthop2=u"1.1.1.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d8",
+                arpip1=u"1.1.1.1",
+                arpif1=u"avf-0/0/7/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        else:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"3.3.3.2/30",
+                ip2=u"2.2.2.2/30",
+                route1=u"10.0.0.0/24",
+                routeif1=u"avf-0/0/7/0",
+                nexthop1=u"2.2.2.1",
+                route2=u"20.0.0.0/24",
+                routeif2=u"avf-0/0/6/0",
+                nexthop2=u"3.3.3.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d9",
+                arpip1=u"3.3.3.1",
+                arpif1=u"avf-0/0/6/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if2"])
+        )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if1"])
+        )
+
+    def _c_vpp_2vfpt_ip4scale2k_plen30(self, **kwargs):
+        """Instantiate one VM with vpp_2vfpt_ip4scale2k_plen30 configuration.
+
+        :param kwargs: Named parameters.
+        :type kwargs: dict
+        """
+        qemu_id = kwargs[u"qemu_id"]
+        name = kwargs[u"name"]
+
+        self.machines[name] = QemuUtils(
+            node=self.nodes[kwargs[u"node"]],
+            qemu_id=qemu_id,
+            smp=len(self.machines_affinity[name]),
+            mem=4096,
+            vnf=kwargs[u"vnf"],
+            img=Constants.QEMU_VM_KERNEL
+        )
+        self.machines[name].add_default_params()
+        self.machines[name].add_kernelvm_params()
+        if u"DUT1" in name:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"2.2.2.1/30",
+                ip2=u"1.1.1.2/30",
+                route1=u"20.0.0.0/30",
+                routeif1=u"avf-0/0/6/0",
+                nexthop1=u"2.2.2.2",
+                route2=u"10.0.0.0/30",
+                routeif2=u"avf-0/0/7/0",
+                nexthop2=u"1.1.1.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d8",
+                arpip1=u"1.1.1.1",
+                arpif1=u"avf-0/0/7/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        else:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"3.3.3.2/30",
+                ip2=u"2.2.2.2/30",
+                route1=u"10.0.0.0/30",
+                routeif1=u"avf-0/0/7/0",
+                nexthop1=u"2.2.2.1",
+                route2=u"20.0.0.0/30",
+                routeif2=u"avf-0/0/6/0",
+                nexthop2=u"3.3.3.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d9",
+                arpip1=u"3.3.3.1",
+                arpif1=u"avf-0/0/6/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if2"])
+        )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if1"])
+        )
+
+    def _c_vpp_2vfpt_ip4scale20k_plen30(self, **kwargs):
+        """Instantiate one VM with vpp_2vfpt_ip4scale20k_plen30 configuration.
+
+        :param kwargs: Named parameters.
+        :type kwargs: dict
+        """
+        qemu_id = kwargs[u"qemu_id"]
+        name = kwargs[u"name"]
+
+        self.machines[name] = QemuUtils(
+            node=self.nodes[kwargs[u"node"]],
+            qemu_id=qemu_id,
+            smp=len(self.machines_affinity[name]),
+            mem=4096,
+            vnf=kwargs[u"vnf"],
+            img=Constants.QEMU_VM_KERNEL
+        )
+        self.machines[name].add_default_params()
+        self.machines[name].add_kernelvm_params()
+        if u"DUT1" in name:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"2.2.2.1/30",
+                ip2=u"1.1.1.2/30",
+                route1=u"20.0.0.0/30",
+                routeif1=u"avf-0/0/6/0",
+                nexthop1=u"2.2.2.2",
+                route2=u"10.0.0.0/30",
+                routeif2=u"avf-0/0/7/0",
+                nexthop2=u"1.1.1.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d8",
+                arpip1=u"1.1.1.1",
+                arpif1=u"avf-0/0/7/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        else:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"3.3.3.2/30",
+                ip2=u"2.2.2.2/30",
+                route1=u"10.0.0.0/30",
+                routeif1=u"avf-0/0/7/0",
+                nexthop1=u"2.2.2.1",
+                route2=u"20.0.0.0/30",
+                routeif2=u"avf-0/0/6/0",
+                nexthop2=u"3.3.3.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d9",
+                arpip1=u"3.3.3.1",
+                arpif1=u"avf-0/0/6/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if2"])
+        )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if1"])
+        )
+
+    def _c_vpp_2vfpt_ip4scale200k_plen30(self, **kwargs):
+        """Instantiate one VM with vpp_2vfpt_ip4scale200k_plen30 configuration.
+
+        :param kwargs: Named parameters.
+        :type kwargs: dict
+        """
+        qemu_id = kwargs[u"qemu_id"]
+        name = kwargs[u"name"]
+
+        self.machines[name] = QemuUtils(
+            node=self.nodes[kwargs[u"node"]],
+            qemu_id=qemu_id,
+            smp=len(self.machines_affinity[name]),
+            mem=4096,
+            vnf=kwargs[u"vnf"],
+            img=Constants.QEMU_VM_KERNEL
+        )
+        self.machines[name].add_default_params()
+        self.machines[name].add_kernelvm_params()
+        if u"DUT1" in name:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"2.2.2.1/30",
+                ip2=u"1.1.1.2/30",
+                route1=u"20.0.0.0/30",
+                routeif1=u"avf-0/0/6/0",
+                nexthop1=u"2.2.2.2",
+                route2=u"10.0.0.0/30",
+                routeif2=u"avf-0/0/7/0",
+                nexthop2=u"1.1.1.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d8",
+                arpip1=u"1.1.1.1",
+                arpif1=u"avf-0/0/7/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        else:
+            self.machines[name].configure_kernelvm_vnf(
+                ip1=u"3.3.3.2/30",
+                ip2=u"2.2.2.2/30",
+                route1=u"10.0.0.0/30",
+                routeif1=u"avf-0/0/7/0",
+                nexthop1=u"2.2.2.1",
+                route2=u"20.0.0.0/30",
+                routeif2=u"avf-0/0/6/0",
+                nexthop2=u"3.3.3.1",
+                arpmac1=u"3c:fd:fe:d1:5c:d9",
+                arpip1=u"3.3.3.1",
+                arpif1=u"avf-0/0/6/0",
+                queues=kwargs[u"queues"],
+                jumbo_frames=kwargs[u"jumbo"]
+            )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if2"])
+        )
+        self.machines[name].add_vfio_pci_if(
+            pci=Topology.get_interface_pci_addr(
+                self.nodes[kwargs[u"node"]], kwargs[u"if1"])
+        )
index a814763..b29e19c 100644 (file)
@@ -323,12 +323,12 @@ class QemuUtils:
             vpp_config.add_plugin(u"enable", u"crypto_openssl_plugin.so")
         if "nat" in self._opt.get(u'vnf'):
             vpp_config.add_nat(value=u"endpoint-dependent")
-            vpp_config.add_nat_max_translations_per_thread(value=655360)
+            #vpp_config.add_nat_max_translations_per_thread(value=655360)
             vpp_config.add_plugin(u"enable", u"nat_plugin.so")
         vpp_config.write_config(startup)
 
         # Create VPP running configuration.
-        template = f"{Constants.RESOURCES_TPL_VM}/{self._opt.get(u'vnf')}.exec"
+        template = f"{Constants.RESOURCES_TPL}/vm/{self._opt.get(u'vnf')}.exec"
         exec_cmd_no_error(self._node, f"rm -f {running}", sudo=True)
 
         with open(template, u"rt") as src_file:
@@ -400,7 +400,7 @@ class QemuUtils:
         :param kwargs: Key-value pairs to replace content of init startup file.
         :type kwargs: dict
         """
-        template = f"{Constants.RESOURCES_TPL_VM}/init.sh"
+        template = f"{Constants.RESOURCES_TPL}/vm/init.sh"
         init = self._temp.get(u"ini")
         exec_cmd_no_error(self._node, f"rm -f {init}", sudo=True)
 
index 5480448..af58da0 100644 (file)
 | | ... | Additional Statistics Action for bash command "perf stat".
 | |
 | | Run Keyword If | ${extended_debug}==${True}
-| | ... | Perf Stat On All DUTs | ${nodes}
+| | ... | Perf Stat On All DUTs | ${nodes} | cpu_list=${cpu_alloc_str}
 
 | Additional Statistics Action For clear-show-runtime-with-traffic
 | | [Documentation]
index 51ce513..cf6b599 100644 (file)
@@ -70,6 +70,9 @@
 | Resource | resources/libraries/robot/shared/traffic.robot
 | Resource | resources/libraries/robot/shared/vm.robot
 
+*** Variables ***
+| ${cpu_alloc_str}= | ${0}
+
 *** Keywords ***
 | Configure crypto device on all DUTs
 | | [Documentation] | Verify if Crypto QAT device virtual functions are
 | | | ... | Set Tags | MTHREAD | ELSE | Set Tags | STHREAD
 | | | Set Tags | ${thr_count_int}T${cpu_count_int}C
 | | END
+| | ${cpu_alloc_str}= | Catenate | SEPARATOR=, | ${cpu_alloc_str} | ${cpu_main}
+| | ${cpu_alloc_str}= | Catenate | SEPARATOR=, | ${cpu_alloc_str} | ${cpu_wt}
 | | Set Test Variable | ${smt_used}
-| | Set Test Variable | ${thr_count_int}
+| | Set Test Variable | ${cpu_alloc_str}
 | | Set Test Variable | ${cpu_count_int}
-| | Set Test Variable | ${rxq_count_int}
+| | Set Test Variable | ${thr_count_int}
 | | Set Test Variable | ${rxd_count_int}
 | | Set Test Variable | ${txd_count_int}
+| | Set Test Variable | ${rxq_count_int}
 
 | Add DPDK VLAN strip offload switch off between DUTs
 | | [Documentation]
index 2f15853..c33ca5f 100644 (file)
@@ -54,7 +54,9 @@
 | | ... | vs_dtc=${cpu_count_int} | nf_dtc=${nf_dtc} | nf_dtcr=${nf_dtcr}
 | | ... | rxq_count_int=${rxq_count_int} | enable_csum=${False}
 | | ... | enable_gso=${False}
-| | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_wt}= | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_alloc_str}= | Catenate | SEPARATOR=, | ${cpu_alloc_str} | ${cpu_wt}
+| | Set Test Variable | ${cpu_alloc_str}
 | | All VPP Interfaces Ready Wait | ${nodes} | retries=${300}
 | | VPP round robin RX placement on all DUTs | ${nodes} | prefix=Virtual
 
 | | ... | vs_dtc=${cpu_count_int} | nf_dtc=${nf_dtc} | nf_dtcr=${nf_dtcr}
 | | ... | rxq_count_int=${rxq_count_int} | enable_csum=${False}
 | | ... | enable_gso=${False}
-| | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_wt}= | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_alloc_str}= | Catenate | SEPARATOR=, | ${cpu_alloc_str} | ${cpu_wt}
+| | Set Test Variable | ${cpu_alloc_str}
 | | All VPP Interfaces Ready Wait | ${nodes} | retries=${300}
 | | VPP round robin RX placement on all DUTs | ${nodes} | prefix=Virtual
 
 | | ... | rxq_count_int=${rxq_count_int} | enable_csum=${False}
 | | ... | enable_gso=${False}
 | | ... | if1=${DUT1_${int}1}[0] | if2=${DUT1_${int}2}[0]
-| | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_wt}= | Run Keyword | vnf_manager.Start All VMs | pinning=${pinning}
+| | ${cpu_alloc_str}= | Catenate | SEPARATOR=, | ${cpu_alloc_str} | ${cpu_wt}
+| | Set Test Variable | ${cpu_alloc_str}
index 3d00a60..c2da2ec 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 ip route add $route2 via $nexthop2 $routeif2
index 3d00a60..c2da2ec 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 ip route add $route2 via $nexthop2 $routeif2
index 3d00a60..c2da2ec 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 ip route add $route2 via $nexthop2 $routeif2
diff --git a/resources/templates/vm/vpp_2vfpt_ethip4ipsec1tnl_nat44ed_s64512.exec b/resources/templates/vm/vpp_2vfpt_ethip4ipsec1tnl_nat44ed_s64512.exec
new file mode 100644 (file)
index 0000000..1c4e045
--- /dev/null
@@ -0,0 +1,17 @@
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
+
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
+
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
+
+ip route add $route1 via $nexthop1 $routeif1
+set ip neighbor static $arpif1 $arpip1 $arpmac1
+
+$nat_ipsec
+
+show logging
+
+show version
\ No newline at end of file
index 54cf428..b0462e1 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 set ip neighbor static $arpif1 $arpip1 $arpmac1
index 54cf428..b0462e1 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 set ip neighbor static $arpif1 $arpip1 $arpmac1
index 7563309..96727ac 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 via $nexthop1 $routeif1
 ip route add $route2 via $nexthop2 $routeif2
index 1afa8c3..192d2bc 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 count 100000 via $nexthop1 $routeif1
 ip route add $route2 count 100000 via $nexthop2 $routeif2
index 8087fdb..ca8be4a 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 count 10000 via $nexthop1 $routeif1
 ip route add $route2 count 10000 via $nexthop2 $routeif2
index 480abc5..652e24e 100644 (file)
@@ -1,11 +1,11 @@
-create interface avf 0000:00:03.0 num-rx-queues $queues
-create interface avf 0000:00:04.0 num-rx-queues $queues
+create interface avf 0000:00:06.0 num-rx-queues $queues
+create interface avf 0000:00:07.0 num-rx-queues $queues
 
-set interface ip address avf-0/0/3/0 $ip1
-set interface state avf-0/0/3/0 up
+set interface ip address avf-0/0/6/0 $ip1
+set interface state avf-0/0/6/0 up
 
-set interface ip address avf-0/0/4/0 $ip2
-set interface state avf-0/0/4/0 up
+set interface ip address avf-0/0/7/0 $ip2
+set interface state avf-0/0/7/0 up
 
 ip route add $route1 count 1000 via $nexthop1 $routeif1
 ip route add $route2 count 1000 via $nexthop2 $routeif2