Received: by 2002:a05:7412:1703:b0:e2:908c:2ebd with SMTP id dm3csp4003842rdb; Wed, 30 Aug 2023 12:19:06 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFPPo9VIBOUrkmNunCWn/+XhJfd4j/B1sywvj69/OL4c15A8Jmgp5cEgxy0vOO4HvEiCBtZ X-Received: by 2002:a05:6512:2809:b0:4fb:8c52:611 with SMTP id cf9-20020a056512280900b004fb8c520611mr2746439lfb.38.1693423145820; Wed, 30 Aug 2023 12:19:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1693423145; cv=none; d=google.com; s=arc-20160816; b=mYI2+o2siqr8QK710AqJfQDqcGL9mYk7AuOYXHfR8X4n7fMdOZ4GsTSKc1Ucyzwyzy qYKutyyTu/DyuX2Odd+EyqwHGR1hM8ldBjG7umAGnB294VBwCIrXzkK7F+Qoxu/N28YC sexAvDkJfxYcSyYKypogLOzV3MqL9TucigWwD9ioKNtj5EY0+KplBsGDfp4btXSevYyo /d6IlE4ylBjnD7Nn/jZ/wm9+oxtg9TJ8HQOf9Ma4MGwcSE22UxS3UsYN52D5kxmgEtP+ J+9oFCIwWFw6On2nixK6NMQZbcE7Sywf/ikkbEzauyt+cD1tcY79XC1TgMnOzsj2F6ad Y9yA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=K/7xcEGqxuW/2MvIwYs12jDLkHGL/fL5nMRrv4keDO0=; fh=4K4L0Hz7KrlwpEYCTfK6PRE7nVhNc1a93PK8S78MFKw=; b=zw4w2GoCKwDIDcqkeIlUUDWjlPAlzSxFTJX4XHirFAq9JGpfXFJNqeuWFEBhw10THf fotvXkysc4c4dhgjeEDlg48kNHf/4VQHMUG4BR00dPitIKlay33AY2a1w8Lbn2fszOl7 GcnKfyQQV5TeqrNOVVQCj/15IK/NJ3WEb+nfJi8KDPEb0tddxPuj6EASRn1o3Bb4apUs mDfhcB9jPMVHXxGimnbMY8lSCl7bkSSjynA+2LNxT0NckXDaCQJJ5ZYKARv2R6xspTGq ciMDWP4mxSC0Xz28zgYoQwWrTexw/SGbx19cBfb4+ymsOrHcWG3NXEHeeCFTfobMjz2Y Ln0A== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i8-20020a17090685c800b0099cd74432d6si8251894ejy.439.2023.08.30.12.18.26; Wed, 30 Aug 2023 12:19:05 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243789AbjH3TNe (ORCPT + 99 others); Wed, 30 Aug 2023 15:13:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51010 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243827AbjH3Lu2 (ORCPT ); Wed, 30 Aug 2023 07:50:28 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id E9AB41B0; Wed, 30 Aug 2023 04:50:24 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 118872F4; Wed, 30 Aug 2023 04:50:59 -0700 (PDT) Received: from bogus (unknown [10.57.36.157]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id E29423F738; Wed, 30 Aug 2023 04:50:15 -0700 (PDT) Date: Wed, 30 Aug 2023 12:49:18 +0100 From: Sudeep Holla To: Ricardo Neri Cc: x86@kernel.org, Andreas Herrmann , Catalin Marinas , Sudeep Holla , Chen Yu , Len Brown , Radu Rendec , Pierre Gondois , Pu Wen , "Rafael J. Wysocki" , Srinivas Pandruvada , Will Deacon , Zhang Rui , stable@vger.kernel.org, Ricardo Neri , "Ravi V. Shankar" , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH v3 1/3] cacheinfo: Allocate memory for memory if not done from the primary CPU Message-ID: <20230830114918.be4mvwfogdqmsxk6@bogus> References: <20230805012421.7002-1-ricardo.neri-calderon@linux.intel.com> <20230805012421.7002-2-ricardo.neri-calderon@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230805012421.7002-2-ricardo.neri-calderon@linux.intel.com> X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE 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 Fri, Aug 04, 2023 at 06:24:19PM -0700, Ricardo Neri wrote: > Commit 5944ce092b97 ("arch_topology: Build cacheinfo from primary CPU") > adds functionality that architectures can use to optionally allocate and > build cacheinfo early during boot. Commit 6539cffa9495 ("cacheinfo: Add > arch specific early level initializer") lets secondary CPUs correct (and > reallocate memory) cacheinfo data if needed. > > If the early build functionality is not used and cacheinfo does not need > correction, memory for cacheinfo is never allocated. x86 does not use the > early build functionality. Consequently, during the cacheinfo CPU hotplug > callback, last_level_cache_is_valid() attempts to dereference a NULL > pointer: > > BUG: kernel NULL pointer dereference, address: 0000000000000100 > #PF: supervisor read access in kernel mode > #PF: error_code(0x0000) - not present page > PGD 0 P4D 0 > Oops: 0000 [#1] PREEPMT SMP NOPTI > CPU: 0 PID 19 Comm: cpuhp/0 Not tainted 6.4.0-rc2 #1 > RIP: 0010: last_level_cache_is_valid+0x95/0xe0a > > Allocate memory for cacheinfo during the cacheinfo CPU hotplug callback if > not done earlier. > > Cc: Andreas Herrmann > Cc: Catalin Marinas > Cc: Chen Yu > Cc: Len Brown > Cc: Radu Rendec > Cc: Pierre Gondois > Cc: Pu Wen > Cc: "Rafael J. Wysocki" > Cc: Sudeep Holla > Cc: Srinivas Pandruvada > Cc: Will Deacon > Cc: Zhang Rui > Cc: linux-arm-kernel@lists.infradead.org > Cc: stable@vger.kernel.org > Acked-by: Len Brown > Fixes: 6539cffa9495 ("cacheinfo: Add arch specific early level initializer") Not sure if we strictly need this(details below), but I am fine either way. > Signed-off-by: Ricardo Neri > --- > The motivation for commit 5944ce092b97 was to prevent a BUG splat in > PREEMPT_RT kernels during memory allocation. This splat is not observed on > x86 because the memory allocation for cacheinfo happens in > detect_cache_attributes() from the cacheinfo CPU hotplug callback. > > The dereference of a NULL pointer is not observed today because > cache_leaves(cpu) is zero until after init_cache_level() is called (also > during the CPU hotplug callback). Patch2 will set it earlier and the NULL- > pointer dereference will be observed. Right, this is the information I have been asking in the previous versions. This clarifies a lot. The trigger is in the patch 2/3 which is why it didn't make complete sense to me without it when you posted this patch independently. Thanks for posting it together and sorry for the delay(both reviewing this and in understanding the issue). Given the trigger for NULL pointer dereference is in 2/3, I am not sure if it is really worth applying this to all the stable kernels with the commit 5944ce092b97 ("arch_topology: Build cacheinfo from primary CPU"). That is the reason why I asked to drop fixes tag if you agree with me. It is simple fix, so I am OK if you prefer to see that in the stable kernels as well. Since there are x86 changes and patch 2/3 triggers NULL pointer dereference without this patch, I prefer you route all 3 via x86. So, Reviewed-by: Sudeep Holla -- Regards, Sudeep