sctp: reset ret in again path in sctp_for_each_transport
Commit97a6ec4ac0
("rhashtable: Change rhashtable_walk_start to return void") only initialized ret for the first time, when going to again path, the next tsp could be NULL. Without resetting ret, cb_done would be called with tsp as NULL. A kernel crash was caused by this when running sctpdiag testcase in sctp-tests. Note that this issue doesn't affect net.git yet. Fixes:97a6ec4ac0
("rhashtable: Change rhashtable_walk_start to return void") Signed-off-by: Xin Long <lucien.xin@gmail.com> Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com> Acked-by: Neil Horman <nhorman@tuxdriver.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
196709f494
commit
f53d77e19b
|
@ -4860,9 +4860,10 @@ int sctp_for_each_transport(int (*cb)(struct sctp_transport *, void *),
|
|||
struct net *net, int *pos, void *p) {
|
||||
struct rhashtable_iter hti;
|
||||
struct sctp_transport *tsp;
|
||||
int ret = 0;
|
||||
int ret;
|
||||
|
||||
again:
|
||||
ret = 0;
|
||||
sctp_transport_walk_start(&hti);
|
||||
|
||||
tsp = sctp_transport_get_idx(net, &hti, *pos + 1);
|
||||
|
|
Loading…
Reference in New Issue