# 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"
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
"""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
"""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):
: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)
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.
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"])
+ )
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:
: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)
| | ... | 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]
| 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]
| | ... | 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}
-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
-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
-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
--- /dev/null
+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
-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
-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
-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
-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
-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
-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