Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1934661ybl; Tue, 3 Dec 2019 15:15:53 -0800 (PST) X-Google-Smtp-Source: APXvYqyBOIh+TJtZQWb0Q77fbjBxoxnJPyqAaALlwyb/m/MogNqSSYlVZV63xBKy/dYqHsf58Ibm X-Received: by 2002:aca:3c86:: with SMTP id j128mr90088oia.153.1575414952964; Tue, 03 Dec 2019 15:15:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575414952; cv=none; d=google.com; s=arc-20160816; b=LT9sXxE0lA7xmv/E3wSIkfPOpAslgiIyVImR6A+pVpd5luYYZc0g+0Lufvkw44cCXF +PAMXT0RCmnLxQoKuDOIDMixw4DttR0Reh0UFrYQip4ZAbnDjsZG/tVWenxZz75vfPXb xXnrIcm/1E0XBwwDqZGsr1oaPw7133J2ZsP2WbmtbrAMB+8EFOQ0RsoZuf0Mu0gAm9q7 EKkLy/ywgbXPggO9U8hS0iOzND+SmHV5MsqVMXSoKQR0cHc21vIsoDPk9d0vsyW+b7YD 1dtmm8vVYzrDXdYKwaRfp7YA1DtQHnL2N9XhPOZWGFO6qllrq1g1TEoA3IPJJqef32S1 uezw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Q3XIQA0QD7ex/jsKO8efAQuI7eWLNk5TbkouoZxJx8k=; b=bHJ9Ot+TJR6dN31W0tbMQmlNkRwgLgpsmLyK5P6U2rBqBjXyp3biVZLveJWVKmM4ks j8QEy8uUmOFqavBMptXzyevfRnymvQPdJ6jt6LqA4RmLdO0jE6li1anPZpCQ10Cv1gjp u+Y/8bIAHxxx4BO4GYBJte42nJu14JDPe5MUPO0y3ju8zgSig7otUIYnQLqJVVFwmFWe P/EskUJt7C0ONThmA8nY10//liL+0pS0Cehbdce3MRO2RFE1zeaj4vUu2Z+/qaqiP24N QTYHipFAgSKty0Y7+IkVGZ+fNaTeFh4sFrUCrNwxroquUAtnwNnTxnqw4ekYw37TMur8 C83g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=XCW92UYK; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l21si2365445oic.126.2019.12.03.15.15.40; Tue, 03 Dec 2019 15:15:52 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=XCW92UYK; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727537AbfLCWiL (ORCPT + 99 others); Tue, 3 Dec 2019 17:38:11 -0500 Received: from mail.kernel.org ([198.145.29.99]:46892 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727918AbfLCWiI (ORCPT ); Tue, 3 Dec 2019 17:38:08 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 49459207DD; Tue, 3 Dec 2019 22:38:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1575412687; bh=e9yjRnJKV9W1ivXe5wncOt2qkr8STGqIWm9mh4K+73M=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XCW92UYKwCkeVNZj3RLbIPtlIwReE0dNVP0vj7Fc4OyFjQedU+6M2hVLde9YBYgG+ 9DBxI5JFOCXGB7Q4AtPsv0yXlx7WEN0k++vL+r486beNPDth1YaUZNnNc/7dRKSxVj DZv1lIZCSp5SsmKw243wNmI/ySG6wM54IwGy44Zw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, syzbot+e3b35fe7918ff0ee474e@syzkaller.appspotmail.com, Xin Long , Marcelo Ricardo Leitner , Jakub Kicinski Subject: [PATCH 5.4 26/46] sctp: cache netns in sctp_ep_common Date: Tue, 3 Dec 2019 23:35:46 +0100 Message-Id: <20191203212740.545504674@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191203212705.175425505@linuxfoundation.org> References: <20191203212705.175425505@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Xin Long [ Upstream commit 312434617cb16be5166316cf9d08ba760b1042a1 ] This patch is to fix a data-race reported by syzbot: BUG: KCSAN: data-race in sctp_assoc_migrate / sctp_hash_obj write to 0xffff8880b67c0020 of 8 bytes by task 18908 on cpu 1: sctp_assoc_migrate+0x1a6/0x290 net/sctp/associola.c:1091 sctp_sock_migrate+0x8aa/0x9b0 net/sctp/socket.c:9465 sctp_accept+0x3c8/0x470 net/sctp/socket.c:4916 inet_accept+0x7f/0x360 net/ipv4/af_inet.c:734 __sys_accept4+0x224/0x430 net/socket.c:1754 __do_sys_accept net/socket.c:1795 [inline] __se_sys_accept net/socket.c:1792 [inline] __x64_sys_accept+0x4e/0x60 net/socket.c:1792 do_syscall_64+0xcc/0x370 arch/x86/entry/common.c:290 entry_SYSCALL_64_after_hwframe+0x44/0xa9 read to 0xffff8880b67c0020 of 8 bytes by task 12003 on cpu 0: sctp_hash_obj+0x4f/0x2d0 net/sctp/input.c:894 rht_key_get_hash include/linux/rhashtable.h:133 [inline] rht_key_hashfn include/linux/rhashtable.h:159 [inline] rht_head_hashfn include/linux/rhashtable.h:174 [inline] head_hashfn lib/rhashtable.c:41 [inline] rhashtable_rehash_one lib/rhashtable.c:245 [inline] rhashtable_rehash_chain lib/rhashtable.c:276 [inline] rhashtable_rehash_table lib/rhashtable.c:316 [inline] rht_deferred_worker+0x468/0xab0 lib/rhashtable.c:420 process_one_work+0x3d4/0x890 kernel/workqueue.c:2269 worker_thread+0xa0/0x800 kernel/workqueue.c:2415 kthread+0x1d4/0x200 drivers/block/aoe/aoecmd.c:1253 ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:352 It was caused by rhashtable access asoc->base.sk when sctp_assoc_migrate is changing its value. However, what rhashtable wants is netns from asoc base.sk, and for an asoc, its netns won't change once set. So we can simply fix it by caching netns since created. Fixes: d6c0256a60e6 ("sctp: add the rhashtable apis for sctp global transport hashtable") Reported-by: syzbot+e3b35fe7918ff0ee474e@syzkaller.appspotmail.com Signed-off-by: Xin Long Acked-by: Marcelo Ricardo Leitner Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- include/net/sctp/structs.h | 3 +++ net/sctp/associola.c | 1 + net/sctp/endpointola.c | 1 + net/sctp/input.c | 4 ++-- 4 files changed, 7 insertions(+), 2 deletions(-) --- a/include/net/sctp/structs.h +++ b/include/net/sctp/structs.h @@ -1239,6 +1239,9 @@ struct sctp_ep_common { /* What socket does this endpoint belong to? */ struct sock *sk; + /* Cache netns and it won't change once set */ + struct net *net; + /* This is where we receive inbound chunks. */ struct sctp_inq inqueue; --- a/net/sctp/associola.c +++ b/net/sctp/associola.c @@ -64,6 +64,7 @@ static struct sctp_association *sctp_ass /* Discarding const is appropriate here. */ asoc->ep = (struct sctp_endpoint *)ep; asoc->base.sk = (struct sock *)sk; + asoc->base.net = sock_net(sk); sctp_endpoint_hold(asoc->ep); sock_hold(asoc->base.sk); --- a/net/sctp/endpointola.c +++ b/net/sctp/endpointola.c @@ -110,6 +110,7 @@ static struct sctp_endpoint *sctp_endpoi /* Remember who we are attached to. */ ep->base.sk = sk; + ep->base.net = sock_net(sk); sock_hold(ep->base.sk); return ep; --- a/net/sctp/input.c +++ b/net/sctp/input.c @@ -882,7 +882,7 @@ static inline int sctp_hash_cmp(struct r if (!sctp_transport_hold(t)) return err; - if (!net_eq(sock_net(t->asoc->base.sk), x->net)) + if (!net_eq(t->asoc->base.net, x->net)) goto out; if (x->lport != htons(t->asoc->base.bind_addr.port)) goto out; @@ -897,7 +897,7 @@ static inline __u32 sctp_hash_obj(const { const struct sctp_transport *t = data; - return sctp_hashfn(sock_net(t->asoc->base.sk), + return sctp_hashfn(t->asoc->base.net, htons(t->asoc->base.bind_addr.port), &t->ipaddr, seed); }