diff options
Diffstat (limited to 'net/ipv4/inet_connection_sock.c')
| -rw-r--r-- | net/ipv4/inet_connection_sock.c | 27 | 
1 files changed, 14 insertions, 13 deletions
| diff --git a/net/ipv4/inet_connection_sock.c b/net/ipv4/inet_connection_sock.c index 134957159c27..61b45a17fc73 100644 --- a/net/ipv4/inet_connection_sock.c +++ b/net/ipv4/inet_connection_sock.c @@ -577,21 +577,22 @@ EXPORT_SYMBOL(inet_rtx_syn_ack);  static bool reqsk_queue_unlink(struct request_sock_queue *queue,  			       struct request_sock *req)  { -	struct listen_sock *lopt = queue->listen_opt;  	struct request_sock **prev; +	struct listen_sock *lopt;  	bool found = false;  	spin_lock(&queue->syn_wait_lock); - -	for (prev = &lopt->syn_table[req->rsk_hash]; *prev != NULL; -	     prev = &(*prev)->dl_next) { -		if (*prev == req) { -			*prev = req->dl_next; -			found = true; -			break; +	lopt = queue->listen_opt; +	if (lopt) { +		for (prev = &lopt->syn_table[req->rsk_hash]; *prev != NULL; +		     prev = &(*prev)->dl_next) { +			if (*prev == req) { +				*prev = req->dl_next; +				found = true; +				break; +			}  		}  	} -  	spin_unlock(&queue->syn_wait_lock);  	if (timer_pending(&req->rsk_timer) && del_timer_sync(&req->rsk_timer))  		reqsk_put(req); @@ -685,20 +686,20 @@ void reqsk_queue_hash_req(struct request_sock_queue *queue,  	req->num_timeout = 0;  	req->sk = NULL; +	setup_timer(&req->rsk_timer, reqsk_timer_handler, (unsigned long)req); +	mod_timer_pinned(&req->rsk_timer, jiffies + timeout); +	req->rsk_hash = hash; +  	/* before letting lookups find us, make sure all req fields  	 * are committed to memory and refcnt initialized.  	 */  	smp_wmb();  	atomic_set(&req->rsk_refcnt, 2); -	setup_timer(&req->rsk_timer, reqsk_timer_handler, (unsigned long)req); -	req->rsk_hash = hash;  	spin_lock(&queue->syn_wait_lock);  	req->dl_next = lopt->syn_table[hash];  	lopt->syn_table[hash] = req;  	spin_unlock(&queue->syn_wait_lock); - -	mod_timer_pinned(&req->rsk_timer, jiffies + timeout);  }  EXPORT_SYMBOL(reqsk_queue_hash_req); | 

