Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp3366708iog; Mon, 20 Jun 2022 18:33:04 -0700 (PDT) X-Google-Smtp-Source: AGRyM1swhbYKpgjMAfaL6ikPwy4IP/c0JVOjqnk8cFy6TC7+XzSXBO06npMcssp51yt1HxIJqcpm X-Received: by 2002:a05:6402:42c6:b0:42d:ed84:6fe0 with SMTP id i6-20020a05640242c600b0042ded846fe0mr33064244edc.58.1655775184813; Mon, 20 Jun 2022 18:33:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655775184; cv=none; d=google.com; s=arc-20160816; b=FQIhr14G2FHVcntt72CfggDVzSDf5SnVQ053ig4NG4Du+al2H7QebYq3sOh9Y89LW/ Yc37PNHjJIkrKNWPGoB7w+jGIhkN2caTaF8i3g9y/FKdTLkpW0gpyK0gLCCg/1ukK55V D02P4qQYM6+BnBiC6+k+3s9+uY/ZChUh+eqtZi9OZNz39tAzMzgHQRlRmVViu9SU8rUh adni4Rm2bdYsA7joTkgf3zmYjQsERGIZuFq2IU1ZCV876wM8WNBhzs3P+kYO/MHMdpk3 M2jsNBoNt+5sLRXuJjrrtMeJtJuUibzvQgwpOnw0CLV/P2NgA1X8dninVabHoCG1MhA7 rkxg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:message-id:in-reply-to :date:references:subject:cc:to:from:dkim-signature; bh=HVxF7nN+U1ZSRIaDYa1f8lSYvwGnKolVH6cMzgiBph8=; b=jpzLNE4zxqBI8fDqu/WN7nfXQBFg+biXyLHOnMpCmnt5Ty+G+vTROOjVwZ6wmm97eV j//03yU2ZGnoVEKWBHsSsOpgP4Ktw5nF9JjbsX2dlyqMPc2R1MQ1U2Vwmz+kZ5N5c3Zs 2PCqG67lLhwXDRO5AXfqF/6wlIMGW7Q6HMh8LS4V4MuxQ96jrHEChXhY121Uy5DUJHat 6SMBuSJCBZCjIJP4p5P2wDbAICEij+NT5Hq8QiGXzVHBo2Hh3tGAUEBSMop3NZMrhs2T /PoysgHhVvIP3mlK6J2n0yK3S0pa4p1D0gGG2xvqmUivGqk0IcMau8bvS72esaM1eGXO vOxg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=Lfi8V1zT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id sd10-20020a1709076e0a00b00708de654a3esi17101626ejc.995.2022.06.20.18.32.39; Mon, 20 Jun 2022 18:33:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=Lfi8V1zT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239169AbiFUBOc (ORCPT + 99 others); Mon, 20 Jun 2022 21:14:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40728 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232030AbiFUBO3 (ORCPT ); Mon, 20 Jun 2022 21:14:29 -0400 Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 56822140AB for ; Mon, 20 Jun 2022 18:14:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1655774068; x=1687310068; h=from:to:cc:subject:references:date:in-reply-to: message-id:mime-version; bh=b00p+JPCNLBqBtIBRmsVShSdYPWHF1lrMDDwHIhXKXY=; b=Lfi8V1zTtOGIuPz+Sk19Cmy+glMO9ZFnOkF6Ce42UC8kls8DIJl0Rqtp QlPh39SsPknbvm6XLxIDo/iLrQfAKDd8URqv8cZxsliJDHwFX+TdUAlbI rEwdIIPNbfq8XZCuTPVmlfMEcT0kaEbbznHzBX33JL+6Y0qPOQzJ9IVCx NClcrqh2cAbzhTD5/pMPZzmU+IhABuPb5a+p7CnMh798JuDKgABAIXbY1 Vc6w6DBk2ncQxl7E2lmbe4a77ca3CT90dqeHFLNRne/xvxPCTGc/1nP+M YFF11cGnXOVr3FMMrKwF1EIhnZaj+2JF2kfVSg0pXVamSdUTmVVu8JgAf g==; X-IronPort-AV: E=McAfee;i="6400,9594,10384"; a="366322946" X-IronPort-AV: E=Sophos;i="5.92,207,1650956400"; d="scan'208";a="366322946" Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Jun 2022 18:14:28 -0700 X-IronPort-AV: E=Sophos;i="5.92,207,1650956400"; d="scan'208";a="833333958" Received: from yhuang6-desk2.sh.intel.com (HELO yhuang6-desk2.ccr.corp.intel.com) ([10.239.13.94]) by fmsmga006-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Jun 2022 18:14:26 -0700 From: "Huang, Ying" To: Qian Cai , Miaohe Lin Cc: Muchun Song , , , , Subject: Re: [PATCH v2 2/3] mm/swapfile: fix possible data races of inuse_pages References: <20220608144031.829-1-linmiaohe@huawei.com> <20220608144031.829-3-linmiaohe@huawei.com> <87edzjrcq8.fsf@yhuang6-desk2.ccr.corp.intel.com> <13414d6a-9e72-fb6c-f0a8-8b83ba0455de@huawei.com> <09ffac27-7fe9-0977-cb33-30433e78e662@huawei.com> Date: Tue, 21 Jun 2022 09:14:00 +0800 In-Reply-To: (Qian Cai's message of "Mon, 20 Jun 2022 17:36:47 -0400") Message-ID: <87pmj2q0mf.fsf@yhuang6-desk2.ccr.corp.intel.com> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/27.1 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=ascii X-Spam-Status: No, score=-5.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Qian Cai writes: > On Mon, Jun 20, 2022 at 10:20:07PM +0800, Muchun Song wrote: >> The lock does not protect the read sides. So the write side should be >> fixed by WRITTE_ONCE(). > > https://lwn.net/Articles/816854/ > > "Unmarked writes (aligned and up to word size) can be treated as if they had > used WRITE_ONCE() by building with > CONFIG_KCSAN_ASSUME_PLAIN_WRITES_ATOMIC=y (also selected by default). > Experience has shown that compilers are much less likely to destructively > optimize in-kernel writes than reads. Some developers might therefore > choose to use READ_ONCE() but omit the corresponding WRITE_ONCE(). Other > developers might prefer the documentation benefits and long-term peace of > mind accruing from explicit use of WRITE_ONCE()..." Thanks for pointing me to this great article. So although not required by KCSAN strictly, WRITE_ONCE() is still good for documentation, etc. Just like we have done for swap_info_struct->highest_bit, etc. Best Regards, Huang, Ying