mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-23 07:12:09 +00:00
tipc: add support for broadcast rcv stats dumping
This commit enables dumping the statistics of a broadcast-receiver link like the traditional 'broadcast-link' one (which is for broadcast- sender). The link dumping can be triggered via netlink (e.g. the iproute2/tipc tool) by the link flag - 'TIPC_NLA_LINK_BROADCAST' as the indicator. The name of a broadcast-receiver link of a specific peer will be in the format: 'broadcast-link:<peer-id>'. For example: Link <broadcast-link:1001002> Window:50 packets RX packets:7841 fragments:2408/440 bundles:0/0 TX packets:0 fragments:0/0 bundles:0/0 RX naks:0 defs:124 dups:0 TX naks:21 acks:0 retrans:0 Congestion link:0 Send queue max:0 avg:0 In addition, the broadcast-receiver link statistics can be reset in the usual way via netlink by specifying that link name in command. Note: the 'tipc_link_name_ext()' is removed because the link name can now be retrieved simply via the 'l->name'. Acked-by: Ying Xue <ying.xue@windriver.com> Acked-by: Jon Maloy <jmaloy@redhat.com> Signed-off-by: Tuong Lien <tuong.t.lien@dektech.com.au> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a91d55d162
commit
03b6fefd9b
9 changed files with 103 additions and 58 deletions
|
@ -825,19 +825,19 @@ bool tipc_msg_pskb_copy(u32 dst, struct sk_buff_head *msg,
|
|||
* @seqno: sequence number of buffer to add
|
||||
* @skb: buffer to add
|
||||
*/
|
||||
void __tipc_skb_queue_sorted(struct sk_buff_head *list, u16 seqno,
|
||||
bool __tipc_skb_queue_sorted(struct sk_buff_head *list, u16 seqno,
|
||||
struct sk_buff *skb)
|
||||
{
|
||||
struct sk_buff *_skb, *tmp;
|
||||
|
||||
if (skb_queue_empty(list) || less(seqno, buf_seqno(skb_peek(list)))) {
|
||||
__skb_queue_head(list, skb);
|
||||
return;
|
||||
return true;
|
||||
}
|
||||
|
||||
if (more(seqno, buf_seqno(skb_peek_tail(list)))) {
|
||||
__skb_queue_tail(list, skb);
|
||||
return;
|
||||
return true;
|
||||
}
|
||||
|
||||
skb_queue_walk_safe(list, _skb, tmp) {
|
||||
|
@ -846,9 +846,10 @@ void __tipc_skb_queue_sorted(struct sk_buff_head *list, u16 seqno,
|
|||
if (seqno == buf_seqno(_skb))
|
||||
break;
|
||||
__skb_queue_before(list, _skb, skb);
|
||||
return;
|
||||
return true;
|
||||
}
|
||||
kfree_skb(skb);
|
||||
return false;
|
||||
}
|
||||
|
||||
void tipc_skb_reject(struct net *net, int err, struct sk_buff *skb,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue