mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	mptcp: only send RM_ADDR in nl_cmd_remove
The specifications from [1] about the "REMOVE" command say:
    Announce that an address has been lost to the peer
It was then only supposed to send a RM_ADDR and not trying to delete
associated subflows.
A new helper mptcp_pm_remove_addrs() is then introduced to do just
that, compared to mptcp_pm_remove_addrs_and_subflows() also removing
subflows.
To delete a subflow, the userspace daemon can use the "SUB_DESTROY"
command, see mptcp_nl_cmd_sf_destroy().
Fixes: d9a4594eda ("mptcp: netlink: Add MPTCP_PM_CMD_REMOVE")
Link: https://github.com/multipath-tcp/mptcp/blob/mptcp_v0.96/include/uapi/linux/mptcp.h [1]
Cc: stable@vger.kernel.org
Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
Signed-off-by: Mat Martineau <martineau@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
			
			
This commit is contained in:
		
							parent
							
								
									9bc0097347
								
							
						
					
					
						commit
						8b1c94da1e
					
				
					 3 changed files with 20 additions and 1 deletions
				
			
		| 
						 | 
					@ -1558,6 +1558,24 @@ static int mptcp_nl_cmd_del_addr(struct sk_buff *skb, struct genl_info *info)
 | 
				
			||||||
	return ret;
 | 
						return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void mptcp_pm_remove_addrs(struct mptcp_sock *msk, struct list_head *rm_list)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct mptcp_rm_list alist = { .nr = 0 };
 | 
				
			||||||
 | 
						struct mptcp_pm_addr_entry *entry;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						list_for_each_entry(entry, rm_list, list) {
 | 
				
			||||||
 | 
							remove_anno_list_by_saddr(msk, &entry->addr);
 | 
				
			||||||
 | 
							if (alist.nr < MPTCP_RM_IDS_MAX)
 | 
				
			||||||
 | 
								alist.ids[alist.nr++] = entry->addr.id;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (alist.nr) {
 | 
				
			||||||
 | 
							spin_lock_bh(&msk->pm.lock);
 | 
				
			||||||
 | 
							mptcp_pm_remove_addr(msk, &alist);
 | 
				
			||||||
 | 
							spin_unlock_bh(&msk->pm.lock);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void mptcp_pm_remove_addrs_and_subflows(struct mptcp_sock *msk,
 | 
					void mptcp_pm_remove_addrs_and_subflows(struct mptcp_sock *msk,
 | 
				
			||||||
					struct list_head *rm_list)
 | 
										struct list_head *rm_list)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -232,7 +232,7 @@ int mptcp_nl_cmd_remove(struct sk_buff *skb, struct genl_info *info)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	list_move(&match->list, &free_list);
 | 
						list_move(&match->list, &free_list);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	mptcp_pm_remove_addrs_and_subflows(msk, &free_list);
 | 
						mptcp_pm_remove_addrs(msk, &free_list);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	release_sock((struct sock *)msk);
 | 
						release_sock((struct sock *)msk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -832,6 +832,7 @@ int mptcp_pm_announce_addr(struct mptcp_sock *msk,
 | 
				
			||||||
			   bool echo);
 | 
								   bool echo);
 | 
				
			||||||
int mptcp_pm_remove_addr(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
 | 
					int mptcp_pm_remove_addr(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
 | 
				
			||||||
int mptcp_pm_remove_subflow(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
 | 
					int mptcp_pm_remove_subflow(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
 | 
				
			||||||
 | 
					void mptcp_pm_remove_addrs(struct mptcp_sock *msk, struct list_head *rm_list);
 | 
				
			||||||
void mptcp_pm_remove_addrs_and_subflows(struct mptcp_sock *msk,
 | 
					void mptcp_pm_remove_addrs_and_subflows(struct mptcp_sock *msk,
 | 
				
			||||||
					struct list_head *rm_list);
 | 
										struct list_head *rm_list);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue