Commit b26b5aa9 authored by Jon Maloy's avatar Jon Maloy Committed by David S. Miller

tipc: move creation of publication item one level up in call chain

We instantiate struct publication in tipc_nametbl_insert_publ()
instead of as currently in tipc_service_insert_publ(). This has the
advantage that we can pass a pointer to the publication struct to
the next call levels, instead of the numerous individual parameters
we pass on now. It also gives us a location to keep the contents of
the additional fields we will introduce in a later commit.
Signed-off-by: default avatarJon Maloy <jmaloy@redhat.com>
Acked-by: default avatarYing Xue <ying.xue@windriver.com>
Acked-by: default avatarHoang Le <hoang.h.le@dektech.com.au>
Acked-by: default avatarTung Nguyen <tung.q.nguyen@dektech.com.au>
Acked-by: default avatarXin Long <lucien.xin@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 998d3907
...@@ -327,49 +327,48 @@ static struct service_range *tipc_service_create_range(struct tipc_service *sc, ...@@ -327,49 +327,48 @@ static struct service_range *tipc_service_create_range(struct tipc_service *sc,
return sr; return sr;
} }
static struct publication *tipc_service_insert_publ(struct net *net, static bool tipc_service_insert_publ(struct net *net,
struct tipc_service *sc, struct tipc_service *sc,
u32 type, u32 lower, struct publication *p)
u32 upper, u32 scope,
u32 node, u32 port,
u32 key)
{ {
struct tipc_subscription *sub, *tmp; struct tipc_subscription *sub, *tmp;
struct service_range *sr; struct service_range *sr;
struct publication *p; struct publication *_p;
u32 node = p->sk.node;
bool first = false; bool first = false;
bool res = false;
sr = tipc_service_create_range(sc, lower, upper); spin_lock_bh(&sc->lock);
sr = tipc_service_create_range(sc, p->sr.lower, p->sr.upper);
if (!sr) if (!sr)
goto err; goto exit;
first = list_empty(&sr->all_publ); first = list_empty(&sr->all_publ);
/* Return if the publication already exists */ /* Return if the publication already exists */
list_for_each_entry(p, &sr->all_publ, all_publ) { list_for_each_entry(_p, &sr->all_publ, all_publ) {
if (p->key == key && (!p->sk.node || p->sk.node == node)) if (_p->key == p->key && (!_p->sk.node || _p->sk.node == node))
return NULL; goto exit;
} }
/* Create and insert publication */ if (in_own_node(net, p->sk.node))
p = tipc_publ_create(type, lower, upper, scope, node, port, key);
if (!p)
goto err;
/* Suppose there shouldn't be a huge gap btw publs i.e. >INT_MAX */
p->id = sc->publ_cnt++;
if (in_own_node(net, node))
list_add(&p->local_publ, &sr->local_publ); list_add(&p->local_publ, &sr->local_publ);
list_add(&p->all_publ, &sr->all_publ); list_add(&p->all_publ, &sr->all_publ);
p->id = sc->publ_cnt++;
/* Any subscriptions waiting for notification? */ /* Any subscriptions waiting for notification? */
list_for_each_entry_safe(sub, tmp, &sc->subscriptions, service_list) { list_for_each_entry_safe(sub, tmp, &sc->subscriptions, service_list) {
tipc_sub_report_overlap(sub, p->sr.lower, p->sr.upper, TIPC_PUBLISHED, tipc_sub_report_overlap(sub, p->sr.lower, p->sr.upper,
p->sk.ref, p->sk.node, p->scope, first); TIPC_PUBLISHED, p->sk.ref, p->sk.node,
p->scope, first);
} }
return p; res = true;
err: exit:
pr_warn("Failed to bind to %u,%u,%u, no memory\n", type, lower, upper); if (!res)
return NULL; pr_warn("Failed to bind to %u,%u,%u\n",
p->sr.type, p->sr.lower, p->sr.upper);
spin_unlock_bh(&sc->lock);
return res;
} }
/** /**
...@@ -482,6 +481,10 @@ struct publication *tipc_nametbl_insert_publ(struct net *net, u32 type, ...@@ -482,6 +481,10 @@ struct publication *tipc_nametbl_insert_publ(struct net *net, u32 type,
struct tipc_service *sc; struct tipc_service *sc;
struct publication *p; struct publication *p;
p = tipc_publ_create(type, lower, upper, scope, node, port, key);
if (!p)
return NULL;
if (scope > TIPC_NODE_SCOPE || lower > upper) { if (scope > TIPC_NODE_SCOPE || lower > upper) {
pr_debug("Failed to bind illegal {%u,%u,%u} with scope %u\n", pr_debug("Failed to bind illegal {%u,%u,%u} with scope %u\n",
type, lower, upper, scope); type, lower, upper, scope);
...@@ -490,14 +493,10 @@ struct publication *tipc_nametbl_insert_publ(struct net *net, u32 type, ...@@ -490,14 +493,10 @@ struct publication *tipc_nametbl_insert_publ(struct net *net, u32 type,
sc = tipc_service_find(net, type); sc = tipc_service_find(net, type);
if (!sc) if (!sc)
sc = tipc_service_create(type, &nt->services[hash(type)]); sc = tipc_service_create(type, &nt->services[hash(type)]);
if (!sc) if (sc && tipc_service_insert_publ(net, sc, p))
return NULL; return p;
kfree(p);
spin_lock_bh(&sc->lock); return NULL;
p = tipc_service_insert_publ(net, sc, type, lower, upper,
scope, node, port, key);
spin_unlock_bh(&sc->lock);
return p;
} }
struct publication *tipc_nametbl_remove_publ(struct net *net, u32 type, struct publication *tipc_nametbl_remove_publ(struct net *net, u32 type,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment