Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp1095449rwr; Wed, 3 May 2023 10:05:35 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4w0+d//2jzNBqFDJd2JKq1CbC25B5QszLZRhO7QLusyR0XJuQKZrEDHBV9pkLDMbA5LsJh X-Received: by 2002:a17:90a:ba90:b0:24d:ea7f:9ea2 with SMTP id t16-20020a17090aba9000b0024dea7f9ea2mr14315408pjr.15.1683133534620; Wed, 03 May 2023 10:05:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683133534; cv=none; d=google.com; s=arc-20160816; b=rVHrRuxGbLLhTtfZpc0IhwvVBDBrve9MX3Nlib5oTzDeFjzPiDwqOEpPouVGkdEsva Y2myL20jMkMeMHhPEtqhjuWN8Mzg36+5a6q0odD9s1aa8/f/Ndq1H+Zz3+ZHXGWQqbDA mX1sCi1NYN9E+pXaxhrc6aZ/o6S4906EkGtCcc9eP6gY3iDyYirJR0PDjdkyWGAeBHDD 6TMUAMjvl7UZfSYc9NhVEB0yblCbu+zdIkzgkQLHn+O9sMeAUgtV7P3te/2GGLrxwpH1 QsUZfMjmnfJu5ty42hOOl1fGUkdAxnd9KcXTb2o3chVnUZ8HfUqHjPlafo+Ll2H51tHo ejqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:message-id:references :mime-version:in-reply-to:date:dkim-signature; bh=zhaj39JNTZzzP0OJ4q1Fsmn7E11iG53wyK5Xw6bPaLM=; b=M0OvD4PCo2HwioOu2QCYj5fT5DChRcc++13gcedbreylMRygfPFjK+AyBFvP9AfgUk lLzaSQjSM4zNn0pf05JigvlrPKvm2LMWVAuqlMxJmhzu1WDh8d1Z+Sf7E16cyjV+56K7 pNPuxH/zQR5IEA4qgEE/AgX+Hi7j84SUR/QzIpuJZpRStD2aM+c9L5CovJv6acFQa9V7 AABtBWYZ6H9ZHNCwaUwt5C2vOGiGnH1fKwGGwEmz9zGc8Yg2RIBQiZHreGUgfuPR1AcC 7YBM3rxtavWvPfMU2Nd/eZ67KqvK9A+qjrFqHTiYA/2lOCRXUjwtelhxZNGG7KiD/j8+ U53Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=40UVaor9; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mr20-20020a17090b239400b002336940f887si14070086pjb.61.2023.05.03.10.05.21; Wed, 03 May 2023 10:05:34 -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=@google.com header.s=20221208 header.b=40UVaor9; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229891AbjECREI (ORCPT + 99 others); Wed, 3 May 2023 13:04:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42272 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229894AbjECREE (ORCPT ); Wed, 3 May 2023 13:04:04 -0400 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 48DAF7281 for ; Wed, 3 May 2023 10:03:50 -0700 (PDT) Received: by mail-yb1-xb49.google.com with SMTP id 3f1490d57ef6-b9a792ff423so10840253276.1 for ; Wed, 03 May 2023 10:03:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1683133429; x=1685725429; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=zhaj39JNTZzzP0OJ4q1Fsmn7E11iG53wyK5Xw6bPaLM=; b=40UVaor955aGvd53qm0GFgMypuIN/TDh5/Cj/jhcvxQS4Yv/e/MDzudJeFjocQMl4z toBL0aXdf0tGpY68t5/f3Xd8q1uty1AXWrjuKlkXdxUSy5JJf0g6JX5bHceDViBje8Ae S4DQJAuiQ4DPqxbEfLltixvnWbZE10OBCPPh6IRMMDa3+zwbFH1Vju9/ofezaBO1VD+G 43AtH8T8f2cQsgdkHTRD+KZjDCWhi5KxitNJ9TQ3NsS1v+tf/j9rzn0S66YkQjlPBTr0 tspOJhBqJiPsCSAFK5lm2iw8hqxg6Mm+8sRlkCwipalTTk+0WxoYaygjt0Pwj3bvWEHz l0aQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1683133429; x=1685725429; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=zhaj39JNTZzzP0OJ4q1Fsmn7E11iG53wyK5Xw6bPaLM=; b=HLK7265VquE7fXKJzLPMdh5B98pxGlMfe20Wq77My/H56YPIZutdLG3n89yL7sG8m0 oAEvcBwpmXMBRRBUo42Yq3amtt/+XKISGkpT3XEwyJEXDtfRtYeq5czE/MPnCp3bEo0w CurAk2ScW8ueMrQckrDN5QQLqUlV3OZC8DiYIiWlv7M/wc7XjcHYHsJPFeMHuOoWtd0Y Lr778/jEc2Lh28KUis1vcHtXxsbWohxjjqBrQlveJb3Xj3MmKh87+PH28dl+QytNi+vN sUduIK7H0Ik0cONAn1eHqyKjDB90L/Qxtd2Ui1HGHdbE3vyOaTzkjsWZMtL6XBOFX9m3 Yfcw== X-Gm-Message-State: AC+VfDxDHYU8jfrIlfs2/wN+KWqVB+w3qslR4PitIpuEQIsMdzx3GEoc CX65ckfiqpf6wDyGRBEKc8pT/033IFsnLQ== X-Received: from shakeelb.c.googlers.com ([fda3:e722:ac3:cc00:7f:e700:c0a8:262e]) (user=shakeelb job=sendgmr) by 2002:a05:6902:154a:b0:b9e:1436:990e with SMTP id r10-20020a056902154a00b00b9e1436990emr6476589ybu.3.1683133429450; Wed, 03 May 2023 10:03:49 -0700 (PDT) Date: Wed, 3 May 2023 17:03:47 +0000 In-Reply-To: Mime-Version: 1.0 References: <20230502160839.361544-1-roman.gushchin@linux.dev> Message-ID: <20230503170347.ldrrtenh57trfpdy@google.com> Subject: Re: [PATCH v2 1/2] mm: kmem: fix a NULL pointer dereference in obj_stock_flush_required() From: Shakeel Butt To: Roman Gushchin Cc: Yosry Ahmed , linux-mm@kvack.org, Andrew Morton , Johannes Weiner , Michal Hocko , Muchun Song , linux-kernel@vger.kernel.org, syzbot+774c29891415ab0fd29d@syzkaller.appspotmail.com, Dmitry Vyukov Content-Type: text/plain; charset="us-ascii" X-Spam-Status: No, score=-9.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL 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 On Tue, May 02, 2023 at 02:38:19PM -0700, Roman Gushchin wrote: [...] > > > > I believe all read accesses other than obj_stock_flush_required() are > > done under the lock, so READ_ONCE() wouldn't be needed AFAICT. Having > > READ_ONCE() only around the racy read can be useful to document the > > racy read and differentiate it from others. > > > > With that said, it's also inconvenient to keep track moving forward of > > which reading sites are racy, and it may be simpler to just annotate > > all readers with READ_ONCE(). > > > > I am not sure which approach is better, just thinking out loud. > > Yeah, I wasn't sure either. I believe that all changes except the original > READ_ONCE() are not leading to any meaningful asm changes, so it's a matter > of taste. > > The reason why I went with the "change them all" approach: > reads without READ_ONCE() and subsequent writes with WRITE_ONCE() > inside a single function looked really weird. > Change them all is the right approach. This code will evolve in future and having partial tagging will cause confusion or might be missed altogether. Also the automated tools prefer change them all.