"Jun Wang" <junwan...@cestc.cn> writes:

>>Mike Pattrick <m...@redhat.com> writes:
>> 
>>> On Tue, Mar 4, 2025 at 10:51 AM Aaron Conole <acon...@redhat.com> wrote:
>>>>
>>>> Jun Wang via discuss <ovs-discuss@openvswitch.org> writes:
>>>>
>>>> >> Hello,
>>>> >
>>>> >> Yes, this will result in better ovs-tcpdump performance. The reason
>>>> >> why it hasn't been added so far is because we can't guarantee or even
>>>> >> check for the existence of any given DPDK driver at runtime in a
>>>> >> generic fashion.
>>>> >>
>>>> >> One option would be to select this type of interface with a
>>>> >> non-default command line flag.
>>>> >
>>>> > Hi, I also believe that choosing a non-default command line flag
>>>> > to support this is a good option, allowing customers to decide
>>>> > whether or not
>>>> > to use this flag.
>>>> > However, there are still some details to consider, such as whether to 
>>>> > allow users to configure the virtio-user port queue,
>>>> > and whether virtio-user usage requires affinity configuration, etc.
>>>>
>>>> ovs-tcpdump will already support using `--mirror-to` as a destination.
>>>> Wouldn't that be an appropriate flag?  There's a lot involved with setup
>>>> for a successful DPDK environment, and as you note lots of user required
>>>> input.
>>>
>>> Unfortunately, mirror-to only lets you set the interface name. It will
>>> still try to create a tap device and add it to OVS. If the interface
>>> already exists, ovs-tcpdump will quit with an error.
>> 
>>Hrrm... I thought it shouldn't:
>> 
>>    if sys.platform in _make_taps and \
>>       mirror_interface not in interfaces():
>>        _make_taps[sys.platform](mirror_interface,
>>                                 ovsdb.interface_mtu(interface))
>>        tap_created = True
>>    else:
>>        tap_created = False
>> 
>>But I guess interfaces() might not match because the DPDK devices won't
>>appear in /dev/net (or likely be dumped from netifaces function).
>> 
>>Maybe the fix there could be to make mirror-to aware of these other
>>devices (for instance, maybe searching the interfaces in OVSDB).
>
> Yes, I have actually tried using mirror-to, and it does result in an error. 
>
> The error message and the corresponding code are as follows:
>
> [root@compute0-dpdk /]# ovs-tcpdump -i vh-userclient-e5281ddf-c8 --mirror-to 
> veth1
>
> ERROR: Mirror port (veth1) exists for port vh-userclient-e5281ddf-c8.
>
>     if ovsdb.port_exists(mirror_interface):
>
>         print("ERROR: Mirror port (%s) exists for port %s." %
>
>               (mirror_interface, interface))
>
>         sys.exit(1)

Probably need a bit of rework around the use case - can you try the
following (I didn't really test it well, just trying to see if the idea
is good)

---
diff --git a/utilities/ovs-tcpdump.in b/utilities/ovs-tcpdump.in
index 187eafdf25..2070678b3a 100755
--- a/utilities/ovs-tcpdump.in
+++ b/utilities/ovs-tcpdump.in
@@ -421,13 +421,16 @@ def py_which(executable):
                for path in os.environ["PATH"].split(os.pathsep))
 
 
-def teardown(db_sock, interface, mirror_interface, tap_created):
+def teardown(db_sock, interface, mirror_interface, tap_created,
+             created_mirror):
     def cleanup_mirror():
         try:
             ovsdb = OVSDB(db_sock)
             ovsdb.destroy_mirror(interface, ovsdb.port_bridge(interface))
-            ovsdb.destroy_port(mirror_interface, ovsdb.port_bridge(interface))
-            if tap_created is True:
+            if created_mirror:
+                ovsdb.destroy_port(mirror_interface,
+                                   ovsdb.port_bridge(interface))
+            if tap_created:
                 _del_taps[sys.platform](mirror_interface)
         except Exception:
             print("Unable to tear down the ports and mirrors.")
@@ -505,15 +508,21 @@ def main():
         if sys.platform in _make_mirror_name:
             mirror_interface = _make_mirror_name[sys.platform](interface)
 
+    created_mirror = True
     if sys.platform in _make_taps and \
-       mirror_interface not in interfaces():
+       mirror_interface not in interfaces() and \
+       not ovsdb.port_exists(mirror_interface):
         _make_taps[sys.platform](mirror_interface,
                                  ovsdb.interface_mtu(interface))
         tap_created = True
     else:
+        if mirror_interface in interfaces() or \
+           ovsdb.port_exists(mirror_interface):
+            created_mirror = False
         tap_created = False
 
-    if mirror_interface not in interfaces():
+    if mirror_interface not in interfaces() and \
+       not ovsdb.port_exists(mirror_interface):
         print("ERROR: Please create an interface called `%s`" %
               mirror_interface)
         print("See your OS guide for how to do this.")
@@ -524,15 +533,12 @@ def main():
     if not ovsdb.port_exists(interface):
         print("ERROR: Port %s does not exist." % interface)
         sys.exit(1)
-    if ovsdb.port_exists(mirror_interface):
-        print("ERROR: Mirror port (%s) exists for port %s." %
-              (mirror_interface, interface))
-        sys.exit(1)
 
-    teardown(db_sock, interface, mirror_interface, tap_created)
+    teardown(db_sock, interface, mirror_interface, tap_created, created_mirror)
 
     try:
-        ovsdb.make_port(mirror_interface, ovsdb.port_bridge(interface))
+        if created_mirror:
+            ovsdb.make_port(mirror_interface, ovsdb.port_bridge(interface))
         ovsdb.bridge_mirror(interface, mirror_interface,
                             ovsdb.port_bridge(interface),
                             mirror_select_all, mirror_filter=mirror_filter)
---
2.47.1

_______________________________________________
discuss mailing list
disc...@openvswitch.org
https://mail.openvswitch.org/mailman/listinfo/ovs-discuss

Reply via email to