[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <8705a0b0-47ca-96d7-cf8c-b9c9fed6026c@oracle.com>
Date: Fri, 22 Dec 2017 10:15:23 -0800
From: Santosh Shilimkar <santosh.shilimkar@...cle.com>
To: Sowmini Varadhan <sowmini.varadhan@...cle.com>,
netdev@...r.kernel.org
Cc: davem@...emloft.net, rds-devel@....oracle.com
Subject: Re: [PATCH V2 net-next 1/3] rds; Reset rs->rs_bound_addr in
rds_add_bound() failure path
On 12/22/2017 9:38 AM, Sowmini Varadhan wrote:
> If the rds_sock is not added to the bind_hash_table, we must
> reset rs_bound_addr so that rds_remove_bound will not trip on
> this rds_sock.
>
> rds_add_bound() does a rds_sock_put() in this failure path, so
> failing to reset rs_bound_addr will result in a socket refcount
> bug, and will trigger a WARN_ON with the stack shown below when
> the application subsequently tries to close the PF_RDS socket.
>
> WARNING: CPU: 20 PID: 19499 at net/rds/af_rds.c:496 \
> rds_sock_destruct+0x15/0x30 [rds]
> :
> __sk_destruct+0x21/0x190
> rds_remove_bound.part.13+0xb6/0x140 [rds]
> rds_release+0x71/0x120 [rds]
> sock_release+0x1a/0x70
> sock_close+0xe/0x20
> __fput+0xd5/0x210
> task_work_run+0x82/0xa0
> do_exit+0x2ce/0xb30
> ? syscall_trace_enter+0x1cc/0x2b0
> do_group_exit+0x39/0xa0
> SyS_exit_group+0x10/0x10
> do_syscall_64+0x61/0x1a0
>
> Signed-off-by: Sowmini Varadhan <sowmini.varadhan@...cle.com>
> ---
> v2: target net-next, not net
>
Acked-by: Santosh Shilimkar <santosh.shilimkar@...cle.com>
Powered by blists - more mailing lists