|
@@ -661,6 +661,9 @@ struct sock *inet_csk_clone_lock(const struct sock *sk,
|
|
|
inet_sk(newsk)->inet_sport = htons(inet_rsk(req)->ir_num);
|
|
|
newsk->sk_write_space = sk_stream_write_space;
|
|
|
|
|
|
+ /* listeners have SOCK_RCU_FREE, not the children */
|
|
|
+ sock_reset_flag(newsk, SOCK_RCU_FREE);
|
|
|
+
|
|
|
newsk->sk_mark = inet_rsk(req)->ir_mark;
|
|
|
atomic64_set(&newsk->sk_cookie,
|
|
|
atomic64_read(&inet_rsk(req)->ir_cookie));
|