Skip to content

Commit 2af5ae3

Browse files
Jon Paul Maloydavem330
authored andcommitted
tipc: clean up unused code and structures
After the previous changes in this series, we can now remove some unused code and structures, both in the broadcast, link aggregation and link code. There are no functional changes in this commit. Signed-off-by: Jon Maloy <[email protected]> Reviewed-by: Ying Xue <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent c49a0a8 commit 2af5ae3

File tree

9 files changed

+30
-1104
lines changed

9 files changed

+30
-1104
lines changed

net/tipc/bcast.c

Lines changed: 17 additions & 798 deletions
Large diffs are not rendered by default.

net/tipc/bcast.h

Lines changed: 1 addition & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -52,28 +52,15 @@ void tipc_bcast_add_peer(struct net *net, struct tipc_link *l,
5252
void tipc_bcast_remove_peer(struct net *net, struct tipc_link *rcv_bcl);
5353
void tipc_bcast_inc_bearer_dst_cnt(struct net *net, int bearer_id);
5454
void tipc_bcast_dec_bearer_dst_cnt(struct net *net, int bearer_id);
55-
struct tipc_node *tipc_bclink_retransmit_to(struct net *tn);
56-
void tipc_bclink_acknowledge(struct tipc_node *n_ptr, u32 acked);
57-
void tipc_bclink_rcv(struct net *net, struct sk_buff *buf);
58-
u32 tipc_bclink_get_last_sent(struct net *net);
59-
u32 tipc_bclink_acks_missing(struct tipc_node *n_ptr);
60-
void tipc_bclink_update_link_state(struct tipc_node *node,
61-
u32 last_sent);
62-
void tipc_bcbearer_sort(struct net *net, struct tipc_node_map *nm_ptr,
63-
u32 node, bool action);
64-
int tipc_bclink_reset_stats(struct net *net);
65-
int tipc_bclink_set_queue_limits(struct net *net, u32 limit);
6655
int tipc_bcast_get_mtu(struct net *net);
6756
int tipc_bcast_xmit(struct net *net, struct sk_buff_head *list);
6857
int tipc_bcast_rcv(struct net *net, struct tipc_link *l, struct sk_buff *skb);
6958
void tipc_bcast_ack_rcv(struct net *net, struct tipc_link *l, u32 acked);
7059
void tipc_bcast_sync_rcv(struct net *net, struct tipc_link *l,
7160
struct tipc_msg *hdr);
72-
void tipc_bclink_wakeup_users(struct net *net);
7361
int tipc_nl_add_bc_link(struct net *net, struct tipc_nl_msg *msg);
7462
int tipc_nl_bc_link_set(struct net *net, struct nlattr *attrs[]);
75-
void tipc_bclink_input(struct net *net);
76-
void tipc_bclink_sync_state(struct tipc_node *n, struct tipc_msg *msg);
63+
int tipc_bclink_reset_stats(struct net *net);
7764

7865
static inline void tipc_bcast_lock(struct net *net)
7966
{

net/tipc/bearer.c

Lines changed: 0 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -440,25 +440,6 @@ int tipc_l2_send_msg(struct net *net, struct sk_buff *skb,
440440
return 0;
441441
}
442442

443-
/* tipc_bearer_send- sends buffer to destination over bearer
444-
*
445-
* IMPORTANT:
446-
* The media send routine must not alter the buffer being passed in
447-
* as it may be needed for later retransmission!
448-
*/
449-
void tipc_bearer_send(struct net *net, u32 bearer_id, struct sk_buff *buf,
450-
struct tipc_media_addr *dest)
451-
{
452-
struct tipc_net *tn = net_generic(net, tipc_net_id);
453-
struct tipc_bearer *b_ptr;
454-
455-
rcu_read_lock();
456-
b_ptr = rcu_dereference_rtnl(tn->bearer_list[bearer_id]);
457-
if (likely(b_ptr))
458-
b_ptr->media->send_msg(net, buf, b_ptr, dest);
459-
rcu_read_unlock();
460-
}
461-
462443
int tipc_bearer_mtu(struct net *net, u32 bearer_id)
463444
{
464445
int mtu = 0;

net/tipc/bearer.h

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -216,8 +216,6 @@ struct tipc_media *tipc_media_find(const char *name);
216216
int tipc_bearer_setup(void);
217217
void tipc_bearer_cleanup(void);
218218
void tipc_bearer_stop(struct net *net);
219-
void tipc_bearer_send(struct net *net, u32 bearer_id, struct sk_buff *buf,
220-
struct tipc_media_addr *dest);
221219
int tipc_bearer_mtu(struct net *net, u32 bearer_id);
222220
void tipc_bearer_xmit_skb(struct net *net, u32 bearer_id,
223221
struct sk_buff *skb,

net/tipc/core.h

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,6 @@
6262

6363
struct tipc_node;
6464
struct tipc_bearer;
65-
struct tipc_bcbearer;
6665
struct tipc_bc_base;
6766
struct tipc_link;
6867
struct tipc_name_table;
@@ -94,7 +93,6 @@ struct tipc_net {
9493

9594
/* Broadcast link */
9695
spinlock_t bclock;
97-
struct tipc_bcbearer *bcbearer;
9896
struct tipc_bc_base *bcbase;
9997
struct tipc_link *bcl;
10098

net/tipc/link.c

Lines changed: 8 additions & 214 deletions
Original file line numberDiff line numberDiff line change
@@ -244,7 +244,6 @@ static u32 link_own_addr(struct tipc_link *l)
244244
* @ownnode: identity of own node
245245
* @peer: node id of peer node
246246
* @peer_caps: bitmap describing peer node capabilities
247-
* @maddr: media address to be used
248247
* @bc_sndlink: the namespace global link used for broadcast sending
249248
* @bc_rcvlink: the peer specific link used for broadcast reception
250249
* @inputq: queue to put messages ready for delivery
@@ -257,7 +256,6 @@ bool tipc_link_create(struct net *net, char *if_name, int bearer_id,
257256
int tolerance, char net_plane, u32 mtu, int priority,
258257
int window, u32 session, u32 ownnode, u32 peer,
259258
u16 peer_caps,
260-
struct tipc_media_addr *maddr,
261259
struct tipc_link *bc_sndlink,
262260
struct tipc_link *bc_rcvlink,
263261
struct sk_buff_head *inputq,
@@ -286,7 +284,6 @@ bool tipc_link_create(struct net *net, char *if_name, int bearer_id,
286284

287285
l->addr = peer;
288286
l->peer_caps = peer_caps;
289-
l->media_addr = maddr;
290287
l->net = net;
291288
l->peer_session = WILDCARD_SESSION;
292289
l->bearer_id = bearer_id;
@@ -331,7 +328,7 @@ bool tipc_link_bc_create(struct net *net, u32 ownnode, u32 peer,
331328
struct tipc_link *l;
332329

333330
if (!tipc_link_create(net, "", MAX_BEARERS, 0, 'Z', mtu, 0, window,
334-
0, ownnode, peer, peer_caps, NULL, bc_sndlink,
331+
0, ownnode, peer, peer_caps, bc_sndlink,
335332
NULL, inputq, namedq, link))
336333
return false;
337334

@@ -662,38 +659,6 @@ void link_prepare_wakeup(struct tipc_link *l)
662659
}
663660
}
664661

665-
/**
666-
* tipc_link_reset_fragments - purge link's inbound message fragments queue
667-
* @l_ptr: pointer to link
668-
*/
669-
void tipc_link_reset_fragments(struct tipc_link *l_ptr)
670-
{
671-
kfree_skb(l_ptr->reasm_buf);
672-
l_ptr->reasm_buf = NULL;
673-
}
674-
675-
void tipc_link_purge_backlog(struct tipc_link *l)
676-
{
677-
__skb_queue_purge(&l->backlogq);
678-
l->backlog[TIPC_LOW_IMPORTANCE].len = 0;
679-
l->backlog[TIPC_MEDIUM_IMPORTANCE].len = 0;
680-
l->backlog[TIPC_HIGH_IMPORTANCE].len = 0;
681-
l->backlog[TIPC_CRITICAL_IMPORTANCE].len = 0;
682-
l->backlog[TIPC_SYSTEM_IMPORTANCE].len = 0;
683-
}
684-
685-
/**
686-
* tipc_link_purge_queues - purge all pkt queues associated with link
687-
* @l_ptr: pointer to link
688-
*/
689-
void tipc_link_purge_queues(struct tipc_link *l_ptr)
690-
{
691-
__skb_queue_purge(&l_ptr->deferdq);
692-
__skb_queue_purge(&l_ptr->transmq);
693-
tipc_link_purge_backlog(l_ptr);
694-
tipc_link_reset_fragments(l_ptr);
695-
}
696-
697662
void tipc_link_reset(struct tipc_link *l)
698663
{
699664
/* Link is down, accept any session */
@@ -705,12 +670,16 @@ void tipc_link_reset(struct tipc_link *l)
705670
/* Prepare for renewed mtu size negotiation */
706671
l->mtu = l->advertised_mtu;
707672

708-
/* Clean up all queues: */
673+
/* Clean up all queues and counters: */
709674
__skb_queue_purge(&l->transmq);
710675
__skb_queue_purge(&l->deferdq);
711676
skb_queue_splice_init(&l->wakeupq, l->inputq);
712-
713-
tipc_link_purge_backlog(l);
677+
__skb_queue_purge(&l->backlogq);
678+
l->backlog[TIPC_LOW_IMPORTANCE].len = 0;
679+
l->backlog[TIPC_MEDIUM_IMPORTANCE].len = 0;
680+
l->backlog[TIPC_HIGH_IMPORTANCE].len = 0;
681+
l->backlog[TIPC_CRITICAL_IMPORTANCE].len = 0;
682+
l->backlog[TIPC_SYSTEM_IMPORTANCE].len = 0;
714683
kfree_skb(l->reasm_buf);
715684
kfree_skb(l->failover_reasm_skb);
716685
l->reasm_buf = NULL;
@@ -726,74 +695,6 @@ void tipc_link_reset(struct tipc_link *l)
726695
link_reset_statistics(l);
727696
}
728697

729-
/**
730-
* __tipc_link_xmit(): same as tipc_link_xmit, but destlink is known & locked
731-
* @link: link to use
732-
* @list: chain of buffers containing message
733-
*
734-
* Consumes the buffer chain, except when returning an error code,
735-
* Returns 0 if success, or errno: -ELINKCONG, -EMSGSIZE or -ENOBUFS
736-
* Messages at TIPC_SYSTEM_IMPORTANCE are always accepted
737-
*/
738-
int __tipc_link_xmit(struct net *net, struct tipc_link *link,
739-
struct sk_buff_head *list)
740-
{
741-
struct tipc_msg *msg = buf_msg(skb_peek(list));
742-
unsigned int maxwin = link->window;
743-
unsigned int i, imp = msg_importance(msg);
744-
uint mtu = link->mtu;
745-
u16 ack = mod(link->rcv_nxt - 1);
746-
u16 seqno = link->snd_nxt;
747-
u16 bc_ack = link->bc_rcvlink->rcv_nxt - 1;
748-
struct tipc_media_addr *addr = link->media_addr;
749-
struct sk_buff_head *transmq = &link->transmq;
750-
struct sk_buff_head *backlogq = &link->backlogq;
751-
struct sk_buff *skb, *bskb;
752-
753-
/* Match msg importance against this and all higher backlog limits: */
754-
for (i = imp; i <= TIPC_SYSTEM_IMPORTANCE; i++) {
755-
if (unlikely(link->backlog[i].len >= link->backlog[i].limit))
756-
return link_schedule_user(link, list);
757-
}
758-
if (unlikely(msg_size(msg) > mtu))
759-
return -EMSGSIZE;
760-
761-
/* Prepare each packet for sending, and add to relevant queue: */
762-
while (skb_queue_len(list)) {
763-
skb = skb_peek(list);
764-
msg = buf_msg(skb);
765-
msg_set_seqno(msg, seqno);
766-
msg_set_ack(msg, ack);
767-
msg_set_bcast_ack(msg, bc_ack);
768-
769-
if (likely(skb_queue_len(transmq) < maxwin)) {
770-
__skb_dequeue(list);
771-
__skb_queue_tail(transmq, skb);
772-
tipc_bearer_send(net, link->bearer_id, skb, addr);
773-
link->rcv_unacked = 0;
774-
seqno++;
775-
continue;
776-
}
777-
if (tipc_msg_bundle(skb_peek_tail(backlogq), msg, mtu)) {
778-
kfree_skb(__skb_dequeue(list));
779-
link->stats.sent_bundled++;
780-
continue;
781-
}
782-
if (tipc_msg_make_bundle(&bskb, msg, mtu, link->addr)) {
783-
kfree_skb(__skb_dequeue(list));
784-
__skb_queue_tail(backlogq, bskb);
785-
link->backlog[msg_importance(buf_msg(bskb))].len++;
786-
link->stats.sent_bundled++;
787-
link->stats.sent_bundles++;
788-
continue;
789-
}
790-
link->backlog[imp].len += skb_queue_len(list);
791-
skb_queue_splice_tail_init(list, backlogq);
792-
}
793-
link->snd_nxt = seqno;
794-
return 0;
795-
}
796-
797698
/**
798699
* tipc_link_xmit(): enqueue buffer list according to queue situation
799700
* @link: link to use
@@ -867,40 +768,6 @@ int tipc_link_xmit(struct tipc_link *l, struct sk_buff_head *list,
867768
return 0;
868769
}
869770

870-
/*
871-
* tipc_link_push_packets - push unsent packets to bearer
872-
*
873-
* Push out the unsent messages of a link where congestion
874-
* has abated. Node is locked.
875-
*
876-
* Called with node locked
877-
*/
878-
void tipc_link_push_packets(struct tipc_link *link)
879-
{
880-
struct sk_buff *skb;
881-
struct tipc_msg *msg;
882-
u16 seqno = link->snd_nxt;
883-
u16 ack = mod(link->rcv_nxt - 1);
884-
885-
while (skb_queue_len(&link->transmq) < link->window) {
886-
skb = __skb_dequeue(&link->backlogq);
887-
if (!skb)
888-
break;
889-
TIPC_SKB_CB(skb)->ackers = link->ackers;
890-
msg = buf_msg(skb);
891-
link->backlog[msg_importance(msg)].len--;
892-
msg_set_ack(msg, ack);
893-
msg_set_seqno(msg, seqno);
894-
seqno = mod(seqno + 1);
895-
/* msg_set_bcast_ack(msg, link->owner->bclink.last_in); */
896-
link->rcv_unacked = 0;
897-
__skb_queue_tail(&link->transmq, skb);
898-
tipc_bearer_send(link->net, link->bearer_id,
899-
skb, link->media_addr);
900-
}
901-
link->snd_nxt = seqno;
902-
}
903-
904771
void tipc_link_advance_backlog(struct tipc_link *l, struct sk_buff_head *xmitq)
905772
{
906773
struct sk_buff *skb, *_skb;
@@ -943,40 +810,6 @@ static void link_retransmit_failure(struct tipc_link *l, struct sk_buff *skb)
943810
msg_seqno(hdr), msg_prevnode(hdr), msg_orignode(hdr));
944811
}
945812

946-
void tipc_link_retransmit(struct tipc_link *l_ptr, struct sk_buff *skb,
947-
u32 retransmits)
948-
{
949-
struct tipc_msg *msg;
950-
951-
if (!skb)
952-
return;
953-
954-
msg = buf_msg(skb);
955-
956-
/* Detect repeated retransmit failures */
957-
if (l_ptr->last_retransm == msg_seqno(msg)) {
958-
if (++l_ptr->stale_count > 100) {
959-
link_retransmit_failure(l_ptr, skb);
960-
return;
961-
}
962-
} else {
963-
l_ptr->last_retransm = msg_seqno(msg);
964-
l_ptr->stale_count = 1;
965-
}
966-
967-
skb_queue_walk_from(&l_ptr->transmq, skb) {
968-
if (!retransmits)
969-
break;
970-
msg = buf_msg(skb);
971-
msg_set_ack(msg, mod(l_ptr->rcv_nxt - 1));
972-
/* msg_set_bcast_ack(msg, l_ptr->owner->bclink.last_in); */
973-
tipc_bearer_send(l_ptr->net, l_ptr->bearer_id, skb,
974-
l_ptr->media_addr);
975-
retransmits--;
976-
l_ptr->stats.retransmitted++;
977-
}
978-
}
979-
980813
int tipc_link_retrans(struct tipc_link *l, u16 from, u16 to,
981814
struct sk_buff_head *xmitq)
982815
{
@@ -1249,45 +1082,6 @@ int tipc_link_rcv(struct tipc_link *l, struct sk_buff *skb,
12491082
return rc;
12501083
}
12511084

1252-
/**
1253-
* tipc_link_defer_pkt - Add out-of-sequence message to deferred reception queue
1254-
*
1255-
* Returns increase in queue length (i.e. 0 or 1)
1256-
*/
1257-
u32 tipc_link_defer_pkt(struct sk_buff_head *list, struct sk_buff *skb)
1258-
{
1259-
struct sk_buff *skb1;
1260-
u16 seq_no = buf_seqno(skb);
1261-
1262-
/* Empty queue ? */
1263-
if (skb_queue_empty(list)) {
1264-
__skb_queue_tail(list, skb);
1265-
return 1;
1266-
}
1267-
1268-
/* Last ? */
1269-
if (less(buf_seqno(skb_peek_tail(list)), seq_no)) {
1270-
__skb_queue_tail(list, skb);
1271-
return 1;
1272-
}
1273-
1274-
/* Locate insertion point in queue, then insert; discard if duplicate */
1275-
skb_queue_walk(list, skb1) {
1276-
u16 curr_seqno = buf_seqno(skb1);
1277-
1278-
if (seq_no == curr_seqno) {
1279-
kfree_skb(skb);
1280-
return 0;
1281-
}
1282-
1283-
if (less(seq_no, curr_seqno))
1284-
break;
1285-
}
1286-
1287-
__skb_queue_before(list, skb1, skb);
1288-
return 1;
1289-
}
1290-
12911085
/*
12921086
* Send protocol message to the other endpoint.
12931087
*/

0 commit comments

Comments
 (0)