mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	batman-adv: mcast: fix memory leak on deleting a batman-adv interface
The batman-adv multicast tracker TVLV handler is registered for the
new batman-adv multicast packet type upon creating a batman-adv interface,
but not unregistered again upon the interface's deletion, leading to a
memory leak.
Fix this memory leak by calling the according TVLV handler unregister
routine for the multicast tracker TVLV upon batman-adv interface
deletion.
Fixes: 07afe1ba28 ("batman-adv: mcast: implement multicast packet reception and forwarding")
Reported-and-tested-by: syzbot+ebe64cc5950868e77358@syzkaller.appspotmail.com
Closes: https://lore.kernel.org/all/000000000000beadc4060f0cbc23@google.com/
Signed-off-by: Linus Lüssing <linus.luessing@c0d3.blue>
Signed-off-by: Sven Eckelmann <sven@narfation.org>
Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de>
			
			
This commit is contained in:
		
							parent
							
								
									59f7ea703c
								
							
						
					
					
						commit
						0a186b49bb
					
				
					 1 changed files with 1 additions and 0 deletions
				
			
		|  | @ -2175,6 +2175,7 @@ void batadv_mcast_free(struct batadv_priv *bat_priv) | |||
| 	cancel_delayed_work_sync(&bat_priv->mcast.work); | ||||
| 
 | ||||
| 	batadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_MCAST, 2); | ||||
| 	batadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_MCAST_TRACKER, 1); | ||||
| 	batadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_MCAST, 2); | ||||
| 
 | ||||
| 	/* safely calling outside of worker, as worker was canceled above */ | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Linus Lüssing
						Linus Lüssing