projects
/
openvswitch
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
sflow_agent: Use snprintf() in place of sprintf().
[openvswitch]
/
lib
/
route-table.c
diff --git
a/lib/route-table.c
b/lib/route-table.c
index de335f57b3efef3edefeb4b235dfd65ed8f6e8e0..58c1b60159c90ca404815fef30511ee0f14d2ec1 100644
(file)
--- a/
lib/route-table.c
+++ b/
lib/route-table.c
@@
-69,8
+69,8
@@
static struct vlog_rate_limit rl = VLOG_RATE_LIMIT_INIT(5, 20);
static unsigned int register_count = 0;
static struct nln *nln = NULL;
static struct route_table_msg rtmsg;
static unsigned int register_count = 0;
static struct nln *nln = NULL;
static struct route_table_msg rtmsg;
-static struct nln_notifier
route_notifier
;
-static struct nln_notifier
name_notifier
;
+static struct nln_notifier
*route_notifier = NULL
;
+static struct nln_notifier
*name_notifier = NULL
;
static bool route_table_valid = false;
static bool name_table_valid = false;
static bool route_table_valid = false;
static bool name_table_valid = false;
@@
-162,11
+162,14
@@
route_table_register(void)
{
if (!register_count) {
assert(!nln);
{
if (!register_count) {
assert(!nln);
+ assert(!route_notifier);
nln = nln_create(NETLINK_ROUTE, RTNLGRP_IPV4_ROUTE,
(nln_parse_func *) route_table_parse, &rtmsg);
nln = nln_create(NETLINK_ROUTE, RTNLGRP_IPV4_ROUTE,
(nln_parse_func *) route_table_parse, &rtmsg);
- nln_notifier_register(nln, &route_notifier,
- (nln_notify_func *) route_table_change, NULL);
+
+ route_notifier =
+ nln_notifier_create(nln, (nln_notify_func *) route_table_change,
+ NULL);
hmap_init(&route_map);
route_table_reset();
hmap_init(&route_map);
route_table_reset();
@@
-185,6
+188,8
@@
route_table_unregister(void)
register_count--;
if (!register_count) {
register_count--;
if (!register_count) {
+ nln_notifier_destroy(route_notifier);
+ route_notifier = NULL;
nln_destroy(nln);
nln = NULL;
nln_destroy(nln);
nln = NULL;
@@
-199,8
+204,8
@@
void
route_table_run(void)
{
if (nln) {
route_table_run(void)
{
if (nln) {
- rtnetlink_link_
notifier_
run();
- nln_
notifier_
run(nln);
+ rtnetlink_link_run();
+ nln_run(nln);
}
}
}
}
@@
-209,8
+214,8
@@
void
route_table_wait(void)
{
if (nln) {
route_table_wait(void)
{
if (nln) {
- rtnetlink_link_
notifier_
wait();
- nln_
notifier_
wait(nln);
+ rtnetlink_link_wait();
+ nln_wait(nln);
}
}
}
}
@@
-396,14
+401,15
@@
static void
name_table_init(void)
{
hmap_init(&name_map);
name_table_init(void)
{
hmap_init(&name_map);
-
rtnetlink_link_notifier_register(&name_notifier,
name_table_change, NULL);
+
name_notifier = rtnetlink_link_notifier_create(
name_table_change, NULL);
name_table_valid = false;
}
static void
name_table_uninit(void)
{
name_table_valid = false;
}
static void
name_table_uninit(void)
{
- rtnetlink_link_notifier_unregister(&name_notifier);
+ rtnetlink_link_notifier_destroy(name_notifier);
+ name_notifier = NULL;
name_map_clear();
hmap_destroy(&name_map);
}
name_map_clear();
hmap_destroy(&name_map);
}