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:
parent
bd6da4ab37
commit
db54e96720
@ -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
57
lib/if-notifier-manual.c
Normal 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);
|
||||
}
|
@ -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 */
|
||||
|
@ -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);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user