2
0
mirror of https://github.com/openvswitch/ovs synced 2025-08-22 01:51:26 +00:00

bridge: Allow manual notifications about interfaces' updates.

Sometimes interface updates could happen in a way ifnotifier is not
able to catch.  For example some heavy operations (device reset) in
netdev-dpdk could require re-applying of the bridge configuration.

For this purpose new manual notifier introduced. Its function
'if_notifier_manual_report()' could be called directly by the code
that aware about changes.  This new notifier is thread-safe.

Signed-off-by: Ilya Maximets <i.maximets@ovn.org>
Acked-by: Eelco Chaudron <echaudro@redhat.com>
This commit is contained in:
Ilya Maximets 2019-11-05 18:20:51 +01:00
parent bd6da4ab37
commit db54e96720
4 changed files with 68 additions and 1 deletions

View File

@ -111,6 +111,8 @@ lib_libopenvswitch_la_SOURCES = \
lib/hmapx.h \
lib/id-pool.c \
lib/id-pool.h \
lib/if-notifier-manual.c \
lib/if-notifier.h \
lib/ipf.c \
lib/ipf.h \
lib/jhash.c \
@ -394,7 +396,6 @@ lib_libopenvswitch_la_SOURCES += \
lib/dpif-netlink-rtnl.c \
lib/dpif-netlink-rtnl.h \
lib/if-notifier.c \
lib/if-notifier.h \
lib/netdev-linux.c \
lib/netdev-linux.h \
lib/netdev-linux-private.h \

57
lib/if-notifier-manual.c Normal file
View File

@ -0,0 +1,57 @@
/*
* Copyright (c) 2019 Ilya Maximets <i.maximets@ovn.org>.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <config.h>
#include "openvswitch/compiler.h"
#include "openvswitch/thread.h"
#include "openvswitch/util.h"
#include "if-notifier.h"
/* Implementation of a manual interface notifier.
*
* Intended for catching interface events that could not be tracked by
* OS specific interface notifiers, e.g. iface updates in netdev-dpdk.
* For that purpose 'if_notifier_manual_report()' should be called directly
* by the code that aware of interface changes.
*
* Thread-safety
* =============
* This notifier is thread-safe in terms of calling its functions from
* different thread contexts, however if the callback passed to
* 'if_notifier_manual_set_cb' is used by some other code (i.e. by OS
* specific notifiers) it must be thread-safe itself.
*/
static struct ovs_mutex manual_notifier_mutex = OVS_MUTEX_INITIALIZER;
static if_notify_func *notify OVS_GUARDED_BY(manual_notifier_mutex) = NULL;
void
if_notifier_manual_set_cb(if_notify_func *cb)
{
ovs_mutex_lock(&manual_notifier_mutex);
notify = cb;
ovs_mutex_unlock(&manual_notifier_mutex);
}
void
if_notifier_manual_report(void)
{
ovs_mutex_lock(&manual_notifier_mutex);
if (notify) {
notify(NULL);
}
ovs_mutex_unlock(&manual_notifier_mutex);
}

View File

@ -27,4 +27,11 @@ void if_notifier_destroy(struct if_notifier *);
void if_notifier_run(void);
void if_notifier_wait(void);
/* Below functions are reserved for if-notifier-manual , i.e. for manual
* notifications from the OVS code.
* Must not be implemented by OS specific notifiers. */
void if_notifier_manual_set_cb(if_notify_func *);
void if_notifier_manual_report(void);
#endif /* if-notifier.h */

View File

@ -530,11 +530,13 @@ bridge_init(const char *remote)
ifaces_changed = seq_create();
last_ifaces_changed = seq_read(ifaces_changed);
ifnotifier = if_notifier_create(if_change_cb, NULL);
if_notifier_manual_set_cb(if_change_cb);
}
void
bridge_exit(bool delete_datapath)
{
if_notifier_manual_set_cb(NULL);
if_notifier_destroy(ifnotifier);
seq_destroy(ifaces_changed);