From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.8 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 5677EC433F5 for ; Tue, 14 Sep 2021 10:43:12 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id E774A6113E for ; Tue, 14 Sep 2021 10:43:11 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org E774A6113E Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=linux.intel.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=kvack.org Received: by kanga.kvack.org (Postfix) id 037C26B006C; Tue, 14 Sep 2021 06:43:11 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id F2A1D6B0071; Tue, 14 Sep 2021 06:43:10 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id E195F900002; Tue, 14 Sep 2021 06:43:10 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0073.hostedemail.com [216.40.44.73]) by kanga.kvack.org (Postfix) with ESMTP id CFF066B006C for ; Tue, 14 Sep 2021 06:43:10 -0400 (EDT) Received: from smtpin01.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay04.hostedemail.com (Postfix) with ESMTP id 7A1F72DD8D for ; Tue, 14 Sep 2021 10:43:10 +0000 (UTC) X-FDA: 78585841740.01.5561213 Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by imf09.hostedemail.com (Postfix) with ESMTP id 97D0A3000100 for ; Tue, 14 Sep 2021 10:43:09 +0000 (UTC) X-IronPort-AV: E=McAfee;i="6200,9189,10106"; a="307506248" X-IronPort-AV: E=Sophos;i="5.85,292,1624345200"; d="scan'208";a="307506248" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Sep 2021 03:43:06 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.85,292,1624345200"; d="scan'208";a="528733499" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga004.fm.intel.com with ESMTP; 14 Sep 2021 03:43:04 -0700 Received: by black.fi.intel.com (Postfix, from userid 1000) id 948D9FF; Tue, 14 Sep 2021 13:43:08 +0300 (EEST) Date: Tue, 14 Sep 2021 13:43:08 +0300 From: "Kirill A. Shutemov" To: Marco Elver Cc: Andrew Morton , linux-mm@kvack.org, Will Deacon , linux-kernel@vger.kernel.org, kasan-dev@googlegroups.com, kernel test robot Subject: Re: [PATCH] mm: fix data race in PagePoisoned() Message-ID: <20210914104308.hi55o2f4jfxpmswg@black.fi.intel.com> References: <20210913113542.2658064-1-elver@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210913113542.2658064-1-elver@google.com> X-Rspamd-Server: rspam01 X-Rspamd-Queue-Id: 97D0A3000100 Authentication-Results: imf09.hostedemail.com; dkim=none; dmarc=fail reason="No valid SPF, No valid DKIM" header.from=intel.com (policy=none); spf=none (imf09.hostedemail.com: domain of kirill.shutemov@linux.intel.com has no SPF policy when checking 192.55.52.43) smtp.mailfrom=kirill.shutemov@linux.intel.com X-Stat-Signature: rntcuhodo5m664h9ycupymdb1te5ibmm X-HE-Tag: 1631616189-532717 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Mon, Sep 13, 2021 at 01:35:43PM +0200, Marco Elver wrote: > PagePoisoned() accesses page->flags which can be updated concurrently: > > | BUG: KCSAN: data-race in next_uptodate_page / unlock_page > | > | write (marked) to 0xffffea00050f37c0 of 8 bytes by task 1872 on cpu 1: > | instrument_atomic_write include/linux/instrumented.h:87 [inline] > | clear_bit_unlock_is_negative_byte include/asm-generic/bitops/instrumented-lock.h:74 [inline] > | unlock_page+0x102/0x1b0 mm/filemap.c:1465 > | filemap_map_pages+0x6c6/0x890 mm/filemap.c:3057 > | ... > | read to 0xffffea00050f37c0 of 8 bytes by task 1873 on cpu 0: > | PagePoisoned include/linux/page-flags.h:204 [inline] > | PageReadahead include/linux/page-flags.h:382 [inline] > | next_uptodate_page+0x456/0x830 mm/filemap.c:2975 > | ... > | CPU: 0 PID: 1873 Comm: systemd-udevd Not tainted 5.11.0-rc4-00001-gf9ce0be71d1f #1 > > To avoid the compiler tearing or otherwise optimizing the access, use > READ_ONCE() to access flags. > > Link: https://lore.kernel.org/all/20210826144157.GA26950@xsang-OptiPlex-9020/ > Reported-by: kernel test robot > Signed-off-by: Marco Elver > Cc: Will Deacon Acked-by: Kirill A. Shutemov -- Kirill A. Shutemov