Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp237234rwd; Tue, 30 May 2023 19:36:06 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5JGEH3HNyImuZuQgfHIedl2DsF6HCoeC2DraTCdKe+kdEslm11y5iC8GCWLcJ7YKdPn7Fh X-Received: by 2002:a05:6870:50e4:b0:195:c537:14f1 with SMTP id s36-20020a05687050e400b00195c53714f1mr2786739oaf.36.1685500565948; Tue, 30 May 2023 19:36:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685500565; cv=none; d=google.com; s=arc-20160816; b=FAmhAWrt7fIRamlaB45YwcXw+KhOUcBea0SEH/5j+Oj1oynINJUflir3kqVGcCQBBK +7MdNoEtjCcLjue6LPm15cTSK4+XswdbzMmktjOKA8IOYXBvFPeyczWNMDwAl5R962R1 ziFUFeXCHf/NDEcmt3kpqO1MjngJN52JvsbQ0SoSjqfi+W1QJovLmEdpPPUV36RIjCv7 1E6bgDs+gYhIhsOVWmY0UN7hjHcECLjJpvovlaZ8TKRR65uldCEKnXzbz9TJzhRa1DQK 30g/uWXzqEPHqT4qpBh3otV8w751593/m+fN0zaU9KIn0SZFzT4OvUwmYGKNejbO48vE GtTQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=l5wRPWQD5GnNjqzx23QJe7U2HXbCGKl8GmCKAyb1Tvc=; b=Yehay+nBOtpqY6yY9Hht3n4QPx9VOggg2Yj5TcyjwS/4HC4SecSzwsS1YfXUlqoYeI 9aAxy7IdekzPsIQiY8tpu8+4G5ZVnR1pwJjm7ZQqsksLI6LJM3gFiuxf14mkm9XcmJ4w Ap3vFNdS81aFKRh0pMSI/aWoetwjwyj9bMRrsiNNmnTxijcHYqcl8sAJjNzXAwRheOGU 1/Z6BM2qDD/pdJQ1MzMoepihCLINN3xMFFvZmaeZwe6lkMStQDU7X7NkxLQYrjHKtiIj PVf/lNs/KxnWFKUOpg0nLMPuW8guhEp09AqrVqeZ0ugd7M215IXsd2sZE8uuROfrI1Zs w6BQ== 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c136-20020a621c8e000000b0064f50a4a515si2695644pfc.37.2023.05.30.19.35.53; Tue, 30 May 2023 19:36: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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234008AbjEaCT5 (ORCPT + 99 others); Tue, 30 May 2023 22:19:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54580 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234009AbjEaCT4 (ORCPT ); Tue, 30 May 2023 22:19:56 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B071C113 for ; Tue, 30 May 2023 19:19:54 -0700 (PDT) Received: from dggpemm500006.china.huawei.com (unknown [172.30.72.53]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4QWCdV68m0zTkwp; Wed, 31 May 2023 10:19:42 +0800 (CST) Received: from [10.174.178.55] (10.174.178.55) by dggpemm500006.china.huawei.com (7.185.36.236) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.23; Wed, 31 May 2023 10:19:52 +0800 Subject: Re: [PATCH 2/6] kexec: delete a useless check in crash_shrink_memory() To: Baoquan He CC: Eric Biederman , , , Michael Holzheu , Andrew Morton References: <20230527123439.772-1-thunder.leizhen@huawei.com> <20230527123439.772-3-thunder.leizhen@huawei.com> From: "Leizhen (ThunderTown)" Message-ID: <5beb1883-5391-1b75-d8cd-2152478b9e72@huawei.com> Date: Wed, 31 May 2023 10:19:51 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.178.55] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpemm500006.china.huawei.com (7.185.36.236) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS,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 On 2023/5/31 8:17, Baoquan He wrote: > On 05/27/23 at 08:34pm, Zhen Lei wrote: >> The check '(crashk_res.parent != NULL)' is added by >> commit e05bd3367bd3 ("kexec: fix Oops in crash_shrink_memory()"), but it's >> stale now. Because if 'crashk_res' is not reserved, it will be zero in >> size and will be intercepted by the above 'if (new_size >= old_size)'. >> >> Ago: >> if (new_size >= end - start + 1) >> >> Now: >> old_size = (end == 0) ? 0 : end - start + 1; >> if (new_size >= old_size) > > Hmm, I would strongly suggest we keep that check. Even though the > current code like above can do the acutal checking, but its actual usage > is not obvious for checking of crashk_res existence. In the future, > someone may change above calculation and don't notice the hidden > functionality at all behind the calculation. The cost of the check is > almost zero, right? The cost of the check is negligible. The only downside is that it's hard to understand why it's added, and I only found out why by looking at the history log. In my opinion, the above 'Now:' is the right fix. > >> >> Signed-off-by: Zhen Lei >> --- >> kernel/kexec_core.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/kernel/kexec_core.c b/kernel/kexec_core.c >> index 22acee18195a591..d1ab139dd49035e 100644 >> --- a/kernel/kexec_core.c >> +++ b/kernel/kexec_core.c >> @@ -1137,7 +1137,7 @@ int crash_shrink_memory(unsigned long new_size) >> end = start + new_size; >> crash_free_reserved_phys_range(end, crashk_res.end); >> >> - if ((start == end) && (crashk_res.parent != NULL)) >> + if (start == end) >> release_resource(&crashk_res); >> >> ram_res->start = end; >> -- >> 2.25.1 >> > > . > -- Regards, Zhen Lei