Commit 57f1d186 authored by Ying Xue's avatar Ying Xue Committed by David S. Miller

tipc: rename functions defined in subscr.c

When a topology server accepts a connection request from its client,
it allocates a connection instance and a tipc_subscriber structure
object. The former is used to communicate with client, and the latter
is often treated as a subscriber which manages all subscription events
requested from a same client. When a topology server receives a request
of subscribing name services from a client through the connection, it
creates a tipc_subscription structure instance which is seen as a
subscription recording what name services are subscribed. In order to
manage all subscriptions from a same client, topology server links
them into the subscrp_list of the subscriber. So subscriber and
subscription completely represents different meanings respectively,
but function names associated with them make us so confused that we
are unable to easily tell which function is against subscriber and
which is to subscription. So we want to eliminate the confusion by
renaming them.
Signed-off-by: default avatarYing Xue <ying.xue@windriver.com>
Reviewed-by: default avatarJon Maloy <jon.maloy@ericson.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 29a1ff65
...@@ -68,7 +68,7 @@ static int __net_init tipc_init_net(struct net *net) ...@@ -68,7 +68,7 @@ static int __net_init tipc_init_net(struct net *net)
if (err) if (err)
goto out_nametbl; goto out_nametbl;
err = tipc_subscr_start(net); err = tipc_topsrv_start(net);
if (err) if (err)
goto out_subscr; goto out_subscr;
return 0; return 0;
...@@ -83,7 +83,7 @@ static int __net_init tipc_init_net(struct net *net) ...@@ -83,7 +83,7 @@ static int __net_init tipc_init_net(struct net *net)
static void __net_exit tipc_exit_net(struct net *net) static void __net_exit tipc_exit_net(struct net *net)
{ {
tipc_subscr_stop(net); tipc_topsrv_stop(net);
tipc_net_stop(net); tipc_net_stop(net);
tipc_nametbl_stop(net); tipc_nametbl_stop(net);
tipc_sk_rht_destroy(net); tipc_sk_rht_destroy(net);
......
...@@ -330,13 +330,9 @@ static struct publication *tipc_nameseq_insert_publ(struct net *net, ...@@ -330,13 +330,9 @@ static struct publication *tipc_nameseq_insert_publ(struct net *net,
/* Any subscriptions waiting for notification? */ /* Any subscriptions waiting for notification? */
list_for_each_entry_safe(s, st, &nseq->subscriptions, nameseq_list) { list_for_each_entry_safe(s, st, &nseq->subscriptions, nameseq_list) {
tipc_subscr_report_overlap(s, tipc_subscrp_report_overlap(s, publ->lower, publ->upper,
publ->lower, TIPC_PUBLISHED, publ->ref,
publ->upper, publ->node, created_subseq);
TIPC_PUBLISHED,
publ->ref,
publ->node,
created_subseq);
} }
return publ; return publ;
} }
...@@ -404,13 +400,9 @@ static struct publication *tipc_nameseq_remove_publ(struct net *net, ...@@ -404,13 +400,9 @@ static struct publication *tipc_nameseq_remove_publ(struct net *net,
/* Notify any waiting subscriptions */ /* Notify any waiting subscriptions */
list_for_each_entry_safe(s, st, &nseq->subscriptions, nameseq_list) { list_for_each_entry_safe(s, st, &nseq->subscriptions, nameseq_list) {
tipc_subscr_report_overlap(s, tipc_subscrp_report_overlap(s, publ->lower, publ->upper,
publ->lower, TIPC_WITHDRAWN, publ->ref,
publ->upper, publ->node, removed_subseq);
TIPC_WITHDRAWN,
publ->ref,
publ->node,
removed_subseq);
} }
return publ; return publ;
...@@ -432,18 +424,16 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq, ...@@ -432,18 +424,16 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq,
return; return;
while (sseq != &nseq->sseqs[nseq->first_free]) { while (sseq != &nseq->sseqs[nseq->first_free]) {
if (tipc_subscr_overlap(s, sseq->lower, sseq->upper)) { if (tipc_subscrp_check_overlap(s, sseq->lower, sseq->upper)) {
struct publication *crs; struct publication *crs;
struct name_info *info = sseq->info; struct name_info *info = sseq->info;
int must_report = 1; int must_report = 1;
list_for_each_entry(crs, &info->zone_list, zone_list) { list_for_each_entry(crs, &info->zone_list, zone_list) {
tipc_subscr_report_overlap(s, tipc_subscrp_report_overlap(s, sseq->lower,
sseq->lower,
sseq->upper, sseq->upper,
TIPC_PUBLISHED, TIPC_PUBLISHED,
crs->ref, crs->ref, crs->node,
crs->node,
must_report); must_report);
must_report = 0; must_report = 0;
} }
......
...@@ -42,12 +42,12 @@ ...@@ -42,12 +42,12 @@
* struct tipc_subscriber - TIPC network topology subscriber * struct tipc_subscriber - TIPC network topology subscriber
* @conid: connection identifier to server connecting to subscriber * @conid: connection identifier to server connecting to subscriber
* @lock: control access to subscriber * @lock: control access to subscriber
* @subscription_list: list of subscription objects for this subscriber * @subscrp_list: list of subscription objects for this subscriber
*/ */
struct tipc_subscriber { struct tipc_subscriber {
int conid; int conid;
spinlock_t lock; spinlock_t lock;
struct list_head subscription_list; struct list_head subscrp_list;
}; };
/** /**
...@@ -62,9 +62,9 @@ static u32 htohl(u32 in, int swap) ...@@ -62,9 +62,9 @@ static u32 htohl(u32 in, int swap)
return swap ? swab32(in) : in; return swap ? swab32(in) : in;
} }
static void subscr_send_event(struct tipc_subscription *sub, u32 found_lower, static void tipc_subscrp_send_event(struct tipc_subscription *sub,
u32 found_upper, u32 event, u32 port_ref, u32 found_lower, u32 found_upper,
u32 node) u32 event, u32 port_ref, u32 node)
{ {
struct tipc_net *tn = net_generic(sub->net, tipc_net_id); struct tipc_net *tn = net_generic(sub->net, tipc_net_id);
struct tipc_subscriber *subscriber = sub->subscriber; struct tipc_subscriber *subscriber = sub->subscriber;
...@@ -82,11 +82,12 @@ static void subscr_send_event(struct tipc_subscription *sub, u32 found_lower, ...@@ -82,11 +82,12 @@ static void subscr_send_event(struct tipc_subscription *sub, u32 found_lower,
} }
/** /**
* tipc_subscr_overlap - test for subscription overlap with the given values * tipc_subscrp_check_overlap - test for subscription overlap with the
* given values
* *
* Returns 1 if there is overlap, otherwise 0. * Returns 1 if there is overlap, otherwise 0.
*/ */
int tipc_subscr_overlap(struct tipc_subscription *sub, u32 found_lower, int tipc_subscrp_check_overlap(struct tipc_subscription *sub, u32 found_lower,
u32 found_upper) u32 found_upper)
{ {
if (found_lower < sub->seq.lower) if (found_lower < sub->seq.lower)
...@@ -98,24 +99,20 @@ int tipc_subscr_overlap(struct tipc_subscription *sub, u32 found_lower, ...@@ -98,24 +99,20 @@ int tipc_subscr_overlap(struct tipc_subscription *sub, u32 found_lower,
return 1; return 1;
} }
/** void tipc_subscrp_report_overlap(struct tipc_subscription *sub, u32 found_lower,
* tipc_subscr_report_overlap - issue event if there is subscription overlap
*
* Protected by nameseq.lock in name_table.c
*/
void tipc_subscr_report_overlap(struct tipc_subscription *sub, u32 found_lower,
u32 found_upper, u32 event, u32 port_ref, u32 found_upper, u32 event, u32 port_ref,
u32 node, int must) u32 node, int must)
{ {
if (!tipc_subscr_overlap(sub, found_lower, found_upper)) if (!tipc_subscrp_check_overlap(sub, found_lower, found_upper))
return; return;
if (!must && !(sub->filter & TIPC_SUB_PORTS)) if (!must && !(sub->filter & TIPC_SUB_PORTS))
return; return;
subscr_send_event(sub, found_lower, found_upper, event, port_ref, node); tipc_subscrp_send_event(sub, found_lower, found_upper, event, port_ref,
node);
} }
static void subscr_timeout(unsigned long data) static void tipc_subscrp_timeout(unsigned long data)
{ {
struct tipc_subscription *sub = (struct tipc_subscription *)data; struct tipc_subscription *sub = (struct tipc_subscription *)data;
struct tipc_subscriber *subscriber = sub->subscriber; struct tipc_subscriber *subscriber = sub->subscriber;
...@@ -134,12 +131,12 @@ static void subscr_timeout(unsigned long data) ...@@ -134,12 +131,12 @@ static void subscr_timeout(unsigned long data)
tipc_nametbl_unsubscribe(sub); tipc_nametbl_unsubscribe(sub);
/* Unlink subscription from subscriber */ /* Unlink subscription from subscriber */
list_del(&sub->subscription_list); list_del(&sub->subscrp_list);
spin_unlock_bh(&subscriber->lock); spin_unlock_bh(&subscriber->lock);
/* Notify subscriber of timeout */ /* Notify subscriber of timeout */
subscr_send_event(sub, sub->evt.s.seq.lower, sub->evt.s.seq.upper, tipc_subscrp_send_event(sub, sub->evt.s.seq.lower, sub->evt.s.seq.upper,
TIPC_SUBSCR_TIMEOUT, 0, 0); TIPC_SUBSCR_TIMEOUT, 0, 0);
/* Now destroy subscription */ /* Now destroy subscription */
...@@ -147,22 +144,17 @@ static void subscr_timeout(unsigned long data) ...@@ -147,22 +144,17 @@ static void subscr_timeout(unsigned long data)
atomic_dec(&tn->subscription_count); atomic_dec(&tn->subscription_count);
} }
/** static void tipc_subscrp_delete(struct tipc_subscription *sub)
* subscr_del - delete a subscription within a subscription list
*
* Called with subscriber lock held.
*/
static void subscr_del(struct tipc_subscription *sub)
{ {
struct tipc_net *tn = net_generic(sub->net, tipc_net_id); struct tipc_net *tn = net_generic(sub->net, tipc_net_id);
tipc_nametbl_unsubscribe(sub); tipc_nametbl_unsubscribe(sub);
list_del(&sub->subscription_list); list_del(&sub->subscrp_list);
kfree(sub); kfree(sub);
atomic_dec(&tn->subscription_count); atomic_dec(&tn->subscription_count);
} }
static void subscr_release(struct tipc_subscriber *subscriber) static void tipc_subscrb_delete(struct tipc_subscriber *subscriber)
{ {
struct tipc_subscription *sub; struct tipc_subscription *sub;
struct tipc_subscription *sub_temp; struct tipc_subscription *sub_temp;
...@@ -170,14 +162,14 @@ static void subscr_release(struct tipc_subscriber *subscriber) ...@@ -170,14 +162,14 @@ static void subscr_release(struct tipc_subscriber *subscriber)
spin_lock_bh(&subscriber->lock); spin_lock_bh(&subscriber->lock);
/* Destroy any existing subscriptions for subscriber */ /* Destroy any existing subscriptions for subscriber */
list_for_each_entry_safe(sub, sub_temp, &subscriber->subscription_list, list_for_each_entry_safe(sub, sub_temp, &subscriber->subscrp_list,
subscription_list) { subscrp_list) {
if (sub->timeout != TIPC_WAIT_FOREVER) { if (sub->timeout != TIPC_WAIT_FOREVER) {
spin_unlock_bh(&subscriber->lock); spin_unlock_bh(&subscriber->lock);
del_timer_sync(&sub->timer); del_timer_sync(&sub->timer);
spin_lock_bh(&subscriber->lock); spin_lock_bh(&subscriber->lock);
} }
subscr_del(sub); tipc_subscrp_delete(sub);
} }
spin_unlock_bh(&subscriber->lock); spin_unlock_bh(&subscriber->lock);
...@@ -186,7 +178,7 @@ static void subscr_release(struct tipc_subscriber *subscriber) ...@@ -186,7 +178,7 @@ static void subscr_release(struct tipc_subscriber *subscriber)
} }
/** /**
* subscr_cancel - handle subscription cancellation request * tipc_subscrp_cancel - handle subscription cancellation request
* *
* Called with subscriber lock held. Routine must temporarily release lock * Called with subscriber lock held. Routine must temporarily release lock
* to enable the subscription timeout routine to finish without deadlocking; * to enable the subscription timeout routine to finish without deadlocking;
...@@ -194,7 +186,7 @@ static void subscr_release(struct tipc_subscriber *subscriber) ...@@ -194,7 +186,7 @@ static void subscr_release(struct tipc_subscriber *subscriber)
* *
* Note that fields of 's' use subscriber's endianness! * Note that fields of 's' use subscriber's endianness!
*/ */
static void subscr_cancel(struct tipc_subscr *s, static void tipc_subscrp_cancel(struct tipc_subscr *s,
struct tipc_subscriber *subscriber) struct tipc_subscriber *subscriber)
{ {
struct tipc_subscription *sub; struct tipc_subscription *sub;
...@@ -202,8 +194,8 @@ static void subscr_cancel(struct tipc_subscr *s, ...@@ -202,8 +194,8 @@ static void subscr_cancel(struct tipc_subscr *s,
int found = 0; int found = 0;
/* Find first matching subscription, exit if not found */ /* Find first matching subscription, exit if not found */
list_for_each_entry_safe(sub, sub_temp, &subscriber->subscription_list, list_for_each_entry_safe(sub, sub_temp, &subscriber->subscrp_list,
subscription_list) { subscrp_list) {
if (!memcmp(s, &sub->evt.s, sizeof(struct tipc_subscr))) { if (!memcmp(s, &sub->evt.s, sizeof(struct tipc_subscr))) {
found = 1; found = 1;
break; break;
...@@ -219,15 +211,10 @@ static void subscr_cancel(struct tipc_subscr *s, ...@@ -219,15 +211,10 @@ static void subscr_cancel(struct tipc_subscr *s,
del_timer_sync(&sub->timer); del_timer_sync(&sub->timer);
spin_lock_bh(&subscriber->lock); spin_lock_bh(&subscriber->lock);
} }
subscr_del(sub); tipc_subscrp_delete(sub);
} }
/** static int tipc_subscrp_create(struct net *net, struct tipc_subscr *s,
* subscr_subscribe - create subscription for subscriber
*
* Called with subscriber lock held.
*/
static int subscr_subscribe(struct net *net, struct tipc_subscr *s,
struct tipc_subscriber *subscriber, struct tipc_subscriber *subscriber,
struct tipc_subscription **sub_p) struct tipc_subscription **sub_p)
{ {
...@@ -241,7 +228,7 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s, ...@@ -241,7 +228,7 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s,
/* Detect & process a subscription cancellation request */ /* Detect & process a subscription cancellation request */
if (s->filter & htohl(TIPC_SUB_CANCEL, swap)) { if (s->filter & htohl(TIPC_SUB_CANCEL, swap)) {
s->filter &= ~htohl(TIPC_SUB_CANCEL, swap); s->filter &= ~htohl(TIPC_SUB_CANCEL, swap);
subscr_cancel(s, subscriber); tipc_subscrp_cancel(s, subscriber);
return 0; return 0;
} }
...@@ -273,13 +260,14 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s, ...@@ -273,13 +260,14 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s,
kfree(sub); kfree(sub);
return -EINVAL; return -EINVAL;
} }
list_add(&sub->subscription_list, &subscriber->subscription_list); list_add(&sub->subscrp_list, &subscriber->subscrp_list);
sub->subscriber = subscriber; sub->subscriber = subscriber;
sub->swap = swap; sub->swap = swap;
memcpy(&sub->evt.s, s, sizeof(struct tipc_subscr)); memcpy(&sub->evt.s, s, sizeof(*s));
atomic_inc(&tn->subscription_count); atomic_inc(&tn->subscription_count);
if (sub->timeout != TIPC_WAIT_FOREVER) { if (sub->timeout != TIPC_WAIT_FOREVER) {
setup_timer(&sub->timer, subscr_timeout, (unsigned long)sub); setup_timer(&sub->timer, tipc_subscrp_timeout,
(unsigned long)sub);
mod_timer(&sub->timer, jiffies + sub->timeout); mod_timer(&sub->timer, jiffies + sub->timeout);
} }
*sub_p = sub; *sub_p = sub;
...@@ -287,13 +275,13 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s, ...@@ -287,13 +275,13 @@ static int subscr_subscribe(struct net *net, struct tipc_subscr *s,
} }
/* Handle one termination request for the subscriber */ /* Handle one termination request for the subscriber */
static void subscr_conn_shutdown_event(int conid, void *usr_data) static void tipc_subscrb_shutdown_cb(int conid, void *usr_data)
{ {
subscr_release((struct tipc_subscriber *)usr_data); tipc_subscrb_delete((struct tipc_subscriber *)usr_data);
} }
/* Handle one request to create a new subscription for the subscriber */ /* Handle one request to create a new subscription for the subscriber */
static void subscr_conn_msg_event(struct net *net, int conid, static void tipc_subscrb_rcv_cb(struct net *net, int conid,
struct sockaddr_tipc *addr, void *usr_data, struct sockaddr_tipc *addr, void *usr_data,
void *buf, size_t len) void *buf, size_t len)
{ {
...@@ -302,7 +290,7 @@ static void subscr_conn_msg_event(struct net *net, int conid, ...@@ -302,7 +290,7 @@ static void subscr_conn_msg_event(struct net *net, int conid,
struct tipc_net *tn = net_generic(net, tipc_net_id); struct tipc_net *tn = net_generic(net, tipc_net_id);
spin_lock_bh(&subscriber->lock); spin_lock_bh(&subscriber->lock);
subscr_subscribe(net, (struct tipc_subscr *)buf, subscriber, &sub); tipc_subscrp_create(net, (struct tipc_subscr *)buf, subscriber, &sub);
if (sub) if (sub)
tipc_nametbl_subscribe(sub); tipc_nametbl_subscribe(sub);
else else
...@@ -311,7 +299,7 @@ static void subscr_conn_msg_event(struct net *net, int conid, ...@@ -311,7 +299,7 @@ static void subscr_conn_msg_event(struct net *net, int conid,
} }
/* Handle one request to establish a new subscriber */ /* Handle one request to establish a new subscriber */
static void *subscr_named_msg_event(int conid) static void *tipc_subscrb_connect_cb(int conid)
{ {
struct tipc_subscriber *subscriber; struct tipc_subscriber *subscriber;
...@@ -321,14 +309,14 @@ static void *subscr_named_msg_event(int conid) ...@@ -321,14 +309,14 @@ static void *subscr_named_msg_event(int conid)
pr_warn("Subscriber rejected, no memory\n"); pr_warn("Subscriber rejected, no memory\n");
return NULL; return NULL;
} }
INIT_LIST_HEAD(&subscriber->subscription_list); INIT_LIST_HEAD(&subscriber->subscrp_list);
subscriber->conid = conid; subscriber->conid = conid;
spin_lock_init(&subscriber->lock); spin_lock_init(&subscriber->lock);
return (void *)subscriber; return (void *)subscriber;
} }
int tipc_subscr_start(struct net *net) int tipc_topsrv_start(struct net *net)
{ {
struct tipc_net *tn = net_generic(net, tipc_net_id); struct tipc_net *tn = net_generic(net, tipc_net_id);
const char name[] = "topology_server"; const char name[] = "topology_server";
...@@ -355,9 +343,9 @@ int tipc_subscr_start(struct net *net) ...@@ -355,9 +343,9 @@ int tipc_subscr_start(struct net *net)
topsrv->imp = TIPC_CRITICAL_IMPORTANCE; topsrv->imp = TIPC_CRITICAL_IMPORTANCE;
topsrv->type = SOCK_SEQPACKET; topsrv->type = SOCK_SEQPACKET;
topsrv->max_rcvbuf_size = sizeof(struct tipc_subscr); topsrv->max_rcvbuf_size = sizeof(struct tipc_subscr);
topsrv->tipc_conn_recvmsg = subscr_conn_msg_event; topsrv->tipc_conn_recvmsg = tipc_subscrb_rcv_cb;
topsrv->tipc_conn_new = subscr_named_msg_event; topsrv->tipc_conn_new = tipc_subscrb_connect_cb;
topsrv->tipc_conn_shutdown = subscr_conn_shutdown_event; topsrv->tipc_conn_shutdown = tipc_subscrb_shutdown_cb;
strncpy(topsrv->name, name, strlen(name) + 1); strncpy(topsrv->name, name, strlen(name) + 1);
tn->topsrv = topsrv; tn->topsrv = topsrv;
...@@ -366,7 +354,7 @@ int tipc_subscr_start(struct net *net) ...@@ -366,7 +354,7 @@ int tipc_subscr_start(struct net *net)
return tipc_server_start(topsrv); return tipc_server_start(topsrv);
} }
void tipc_subscr_stop(struct net *net) void tipc_topsrv_stop(struct net *net)
{ {
struct tipc_net *tn = net_generic(net, tipc_net_id); struct tipc_net *tn = net_generic(net, tipc_net_id);
struct tipc_server *topsrv = tn->topsrv; struct tipc_server *topsrv = tn->topsrv;
......
...@@ -54,7 +54,7 @@ struct tipc_subscriber; ...@@ -54,7 +54,7 @@ struct tipc_subscriber;
* @filter: event filtering to be done for subscription * @filter: event filtering to be done for subscription
* @timer: timer governing subscription duration (optional) * @timer: timer governing subscription duration (optional)
* @nameseq_list: adjacent subscriptions in name sequence's subscription list * @nameseq_list: adjacent subscriptions in name sequence's subscription list
* @subscription_list: adjacent subscriptions in subscriber's subscription list * @subscrp_list: adjacent subscriptions in subscriber's subscription list
* @server_ref: object reference of server port associated with subscription * @server_ref: object reference of server port associated with subscription
* @swap: indicates if subscriber uses opposite endianness in its messages * @swap: indicates if subscriber uses opposite endianness in its messages
* @evt: template for events generated by subscription * @evt: template for events generated by subscription
...@@ -67,17 +67,17 @@ struct tipc_subscription { ...@@ -67,17 +67,17 @@ struct tipc_subscription {
u32 filter; u32 filter;
struct timer_list timer; struct timer_list timer;
struct list_head nameseq_list; struct list_head nameseq_list;
struct list_head subscription_list; struct list_head subscrp_list;
int swap; int swap;
struct tipc_event evt; struct tipc_event evt;
}; };
int tipc_subscr_overlap(struct tipc_subscription *sub, u32 found_lower, int tipc_subscrp_check_overlap(struct tipc_subscription *sub, u32 found_lower,
u32 found_upper); u32 found_upper);
void tipc_subscr_report_overlap(struct tipc_subscription *sub, u32 found_lower, void tipc_subscrp_report_overlap(struct tipc_subscription *sub,
u32 found_upper, u32 event, u32 port_ref, u32 found_lower, u32 found_upper, u32 event,
u32 node, int must); u32 port_ref, u32 node, int must);
int tipc_subscr_start(struct net *net); int tipc_topsrv_start(struct net *net);
void tipc_subscr_stop(struct net *net); void tipc_topsrv_stop(struct net *net);
#endif #endif
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