forked from luck/tmp_suning_uos_patched
l2tp: hold session while sending creation notifications
l2tp_session_find() doesn't take any reference on the returned session.
Therefore, the session may disappear while sending the notification.
Use l2tp_session_get() instead and decrement session's refcount once
the notification is sent.
Fixes: 33f72e6f0c
("l2tp : multicast notification to the registered listeners")
Signed-off-by: Guillaume Nault <g.nault@alphalink.fr>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
dbdbc73b44
commit
5e6a9e5a35
|
@ -642,10 +642,12 @@ static int l2tp_nl_cmd_session_create(struct sk_buff *skb, struct genl_info *inf
|
|||
session_id, peer_session_id, &cfg);
|
||||
|
||||
if (ret >= 0) {
|
||||
session = l2tp_session_find(net, tunnel, session_id);
|
||||
if (session)
|
||||
session = l2tp_session_get(net, tunnel, session_id, false);
|
||||
if (session) {
|
||||
ret = l2tp_session_notify(&l2tp_nl_family, info, session,
|
||||
L2TP_CMD_SESSION_CREATE);
|
||||
l2tp_session_dec_refcount(session);
|
||||
}
|
||||
}
|
||||
|
||||
out:
|
||||
|
|
Loading…
Reference in New Issue
Block a user