Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp2933645ybx; Fri, 8 Nov 2019 11:28:38 -0800 (PST) X-Google-Smtp-Source: APXvYqxhtf1cXMz7VyLpvJDKfmIajozfTHr1LJt8JroHrCCnDYplEm4cHTw8YmCvbDJeUIfuQNxD X-Received: by 2002:a50:e68c:: with SMTP id z12mr12696048edm.53.1573241318082; Fri, 08 Nov 2019 11:28:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573241318; cv=none; d=google.com; s=arc-20160816; b=H+F4yaRmQeStdlLSYJi/scJApmjt39YX1myHbKhPCagYBQebC1WEbNQgW/Nm9RJ+UM T0xB9WVO26eUPgGazwygcSp0TP2D99dXLHA7xOxdOdea7xi70Vo/FAqOsrD34rETgynS cnIbsOV03wI6utXWhJUucVkT07QXTXKthjLtTS44TFsU/JGALA/sdmzfZWWD6dMBRE6l 5NO0ixt7qf5nQhJryNxYfdoL2KPht2iiRJJzvi/34LcQY2QrGOwEBQuRLaUiHTRZGMfK YwkldYtMpOPDTs71Sud6+QcodTGlsseTE7T9ksLkGENn9xJYQ4ubnw1qmbE2cW9s9/w2 NBOQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date:dkim-signature; bh=nwZ9xmc++oewXvwmgLhEz7LSTwf0AH6IOBgTZAG+d+Y=; b=RWv7nTraMlSNyF+BjO3kN32EFX5ovivHTvDvrMVlfn9q1jyKcR7HWoLzttdeM63ILE TfGm0kuFqykwcxI9E5cJk/lar2aVC0eq456ZaeEBGgYtcsT/W1OfD8QW9r4gTu0VpMuf RZtoi0/ZupuPabbkphZI+kPWTTldzsBe83ICce6c1sHRCrAj1SCl6vZGaVlBqI0DztWp E7avVnwgfMbtoNsnsMg7gya6bF+LaNzzsFPbj5eiTOi8Tk3QPBrGhvNZJTg7w+mYU3+z VfPgzKxGfi+mroIzKvJqmKsiAZDwfk2DD5s8eWJ9P2f8gRqMYMtqxeZRHTbX6sVZnjCp aiXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BNvudVJ7; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 93si5539680edo.408.2019.11.08.11.28.13; Fri, 08 Nov 2019 11:28:38 -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=BNvudVJ7; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731878AbfKHT1g (ORCPT + 99 others); Fri, 8 Nov 2019 14:27:36 -0500 Received: from mail.kernel.org ([198.145.29.99]:55468 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730416AbfKHT1g (ORCPT ); Fri, 8 Nov 2019 14:27:36 -0500 Received: from paulmck-ThinkPad-P72.home (unknown [213.233.149.27]) (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 6A1F320659; Fri, 8 Nov 2019 19:27:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1573241255; bh=5MuVgvyCLaORD6Q1QL/LqE+iJOwhSsGkPwO+sGRLSxk=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=BNvudVJ7gYMDFWmqv/WHW8fHm7xyInDO1jKuRAGOzHu9CRMPBCzzfsEEdZmdZ+ek9 KXykYo7kM/xTjFDQmbgny697e27THLzHt1FCU8U8h+R6uogpvfC4vtBPQzG7ShrtZ6 UChU6r6r8iIlsW6jt2bO94WZE1tTq2rJDAglW0dA= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id 8455F35204A1; Fri, 8 Nov 2019 11:27:21 -0800 (PST) Date: Fri, 8 Nov 2019 11:27:21 -0800 From: "Paul E. McKenney" To: Eric Dumazet Cc: Thomas Gleixner , linux-kernel , Eric Dumazet Subject: Re: [PATCH 2/2] timer: use hlist_unhashed_lockless() in timer_pending() Message-ID: <20191108192721.GC20975@paulmck-ThinkPad-P72> Reply-To: paulmck@kernel.org References: <20191107193738.195914-1-edumazet@google.com> <20191107193738.195914-2-edumazet@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191107193738.195914-2-edumazet@google.com> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Nov 07, 2019 at 11:37:38AM -0800, Eric Dumazet wrote: > timer_pending() is mostly used in lockless contexts. > > Without proper annotations, KCSAN might detect a data-race [1] > > Using hlist_unhashed_lockless() instead of hand-coding it > seems appropriate (as suggested by Paul E. McKenney). > > [1] > > BUG: KCSAN: data-race in del_timer / detach_if_pending > > write to 0xffff88808697d870 of 8 bytes by task 10 on cpu 0: > __hlist_del include/linux/list.h:764 [inline] > detach_timer kernel/time/timer.c:815 [inline] > detach_if_pending+0xcd/0x2d0 kernel/time/timer.c:832 > try_to_del_timer_sync+0x60/0xb0 kernel/time/timer.c:1226 > del_timer_sync+0x6b/0xa0 kernel/time/timer.c:1365 > schedule_timeout+0x2d2/0x6e0 kernel/time/timer.c:1896 > rcu_gp_fqs_loop+0x37c/0x580 kernel/rcu/tree.c:1639 > rcu_gp_kthread+0x143/0x230 kernel/rcu/tree.c:1799 > kthread+0x1d4/0x200 drivers/block/aoe/aoecmd.c:1253 > ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:352 > > read to 0xffff88808697d870 of 8 bytes by task 12060 on cpu 1: > del_timer+0x3b/0xb0 kernel/time/timer.c:1198 > sk_stop_timer+0x25/0x60 net/core/sock.c:2845 > inet_csk_clear_xmit_timers+0x69/0xa0 net/ipv4/inet_connection_sock.c:523 > tcp_clear_xmit_timers include/net/tcp.h:606 [inline] > tcp_v4_destroy_sock+0xa3/0x3f0 net/ipv4/tcp_ipv4.c:2096 > inet_csk_destroy_sock+0xf4/0x250 net/ipv4/inet_connection_sock.c:836 > tcp_close+0x6f3/0x970 net/ipv4/tcp.c:2497 > inet_release+0x86/0x100 net/ipv4/af_inet.c:427 > __sock_release+0x85/0x160 net/socket.c:590 > sock_close+0x24/0x30 net/socket.c:1268 > __fput+0x1e1/0x520 fs/file_table.c:280 > ____fput+0x1f/0x30 fs/file_table.c:313 > task_work_run+0xf6/0x130 kernel/task_work.c:113 > tracehook_notify_resume include/linux/tracehook.h:188 [inline] > exit_to_usermode_loop+0x2b4/0x2c0 arch/x86/entry/common.c:163 > > Reported by Kernel Concurrency Sanitizer on: > CPU: 1 PID: 12060 Comm: syz-executor.5 Not tainted 5.4.0-rc3+ #0 > Hardware name: Google Google Compute Engine/Google Compute Engine, > > Signed-off-by: Eric Dumazet > Cc: "Paul E. McKenney" > Cc: Thomas Gleixner And I queued this one as well, but again if you would prefer it go up elsewhere, for whatever it is worth: Acked-by: Paul E. McKenney > --- > include/linux/timer.h | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/include/linux/timer.h b/include/linux/timer.h > index 1e6650ed066d5d28251b0bd385fc37ef94c96532..0dc19a8c39c9e49a7cde3d34bfa4be8871cbc1c2 100644 > --- a/include/linux/timer.h > +++ b/include/linux/timer.h > @@ -164,7 +164,7 @@ static inline void destroy_timer_on_stack(struct timer_list *timer) { } > */ > static inline int timer_pending(const struct timer_list * timer) > { > - return timer->entry.pprev != NULL; > + return !hlist_unhashed_lockless(&timer->entry); > } > > extern void add_timer_on(struct timer_list *timer, int cpu); > -- > 2.24.0.432.g9d3f5f5b63-goog >