Skip to content
  • Balazs Nemeth's avatar
    tunnel: Fix deletion of datapath tunnel ports in case of reconfiguration · c8025aee
    Balazs Nemeth authored
    
    
    There is an issue in OVS with tunnel deletion during the
    reconfiguration of OF tunnels. If the dst_port value is changed, the
    old tunnel map entry will not be deleted, because the tp_port
    argument of tnl_port_map_delete() has the new dst_port setting, hence
    the tunnel cannot be found in the list of tnl_port structures.
    
    The patch corrects this mechanism by adding a new argument,
    'old_odp_port' to tnl_port_reconfigure(). This value is used to
    identify the datapath tunnel port which is being reconfigured. In
    connection with this fix, to unify the tunnel port map handling,
    odp_port value is used to search the proper port to insert and delete
    tunnel map entries as well. This variable can be used instead of
    tp_port, as it is unique for all datapath tunnel ports, and there is
    no need to reach dst_port from netdev_tunnel_config structure.
    
    This patch also adds a printout to check the reference counter of
    a tnl_port structure in tnl-port.c. Extending OVS unit test cases to
    have ref_cnt values in the expected dump. Adding new test cases to
    check if packet receiving is still working in the case of OF tunnel
    port deletion. Adding new test cases to check the reference counter
    in case of OF tunnel deletion or reconfiguration.
    
    Signed-off-by: default avatarBalazs Nemeth <balazs.nemeth@ericsson.com>
    Signed-off-by: default avatarJan Scheurich <jan.scheurich@ericsson.com>
    Co-authored-by: default avatarJan Scheurich <jan.scheurich@ericsson.com>
    Signed-off-by: default avatarBen Pfaff <blp@ovn.org>
    c8025aee