Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp445372rwl; Wed, 29 Mar 2023 04:19:24 -0700 (PDT) X-Google-Smtp-Source: AKy350Z8oR5ZzDyT2py7fKpuy0Ss/kYSKzS7Fhzj/EqGNSTu7TAI06LrHhRkxs+H+0R3L+3Mq8JY X-Received: by 2002:a17:907:c087:b0:8b1:779c:a8b1 with SMTP id st7-20020a170907c08700b008b1779ca8b1mr20262247ejc.5.1680088764418; Wed, 29 Mar 2023 04:19:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680088764; cv=none; d=google.com; s=arc-20160816; b=dzERYLEy/HN39dgtjBIgqhsQDSq9G+WDAzglI3iNIHHYNQsDGFAg5whKqTU5Rb+ug6 lJ1Z5VfWGFDgdPAiwio8fVpGHH9Yy+uJFZdc4cIJs32rlrASq4JZvdl0H1fkbpSWj/dr kQsyw7tu1xRHuaW8X8fLjMGwd7CrnwARtcxHA+hKwl6w5zcxD0cJlDR4ihjIYBcmDwfS 4XCFPAwIhgg7abYFB3lD5cErO69iaCCC46pq6jFAwC+M/AEuA0Acatz7kE/HmIJcJBti Xh16G6gbORAWYFNh1AwhI4/optrlHgX4917ADlFr3AADs2lM4MEPBqY7U5wXF7XC1VHX TbpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:references :cc:to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature; bh=6fMyRoI+gDBMSQ1ASPAj5GDfjiLEoGxH9G7/ldjpWq0=; b=huft87buYfS98HmpSjIUIKLgrGAcqXiXSq1doaASlzv7BGQX5Q7gpy/AY0Ai4GY9De RTY7Ha9WnhFmEgpC6rrgrXeY166j+Mj5/cxNIM2zTXRGU2++9TecEpRVEpjNQaPaMaAt 3O9M481ynMSQvNrv8t6NFdzoGI7aKuKlDRpIRzz0iV1pqN1etJ6iEXeQi6Qa7vqb5ikX uZ9/zMRpBh9nc5JT8mi+0Est0dMK7zD0ALW12vM8JuCPJrc9l8L5kUEWfPhVW4pK6+1s uAzfJh9EXekLBE6mTSLGNN2woi6nYRZS9lC1kDNhE01P/A1Fu4WqhDyT17qyIoyPIDL9 vKQA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance.com header.s=google header.b=Q1JX6+bz; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=bytedance.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s1-20020a170906a18100b00935086a660csi21781034ejy.17.2023.03.29.04.18.59; Wed, 29 Mar 2023 04:19:24 -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=@bytedance.com header.s=google header.b=Q1JX6+bz; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229661AbjC2LKb (ORCPT + 99 others); Wed, 29 Mar 2023 07:10:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40926 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229530AbjC2LK3 (ORCPT ); Wed, 29 Mar 2023 07:10:29 -0400 Received: from mail-wr1-x430.google.com (mail-wr1-x430.google.com [IPv6:2a00:1450:4864:20::430]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B32BE3C3A for ; Wed, 29 Mar 2023 04:10:02 -0700 (PDT) Received: by mail-wr1-x430.google.com with SMTP id l27so15246507wrb.2 for ; Wed, 29 Mar 2023 04:10:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1680088201; h=content-transfer-encoding:in-reply-to:references:cc:to:from :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=6fMyRoI+gDBMSQ1ASPAj5GDfjiLEoGxH9G7/ldjpWq0=; b=Q1JX6+bz61+vh+Vzi+sUwW3yMZkzm75oKFpftOGczVAhMrRDKm0YR/bBqfuht4I4G0 yvMwrHoq81CHuHyybcV/HPEQWF0NIdOH7bDzS37+Gr2coehioxNJ8a59CKMBA2XsZp6h 8wtpVuc69EPsfRMeKaNWH2Fvmbl9ev5l1PbaHocbOfQ/X0Uwteton/ZLxjXcoCbnErLl w1T0tHaZo9yPx2R7aeax5iKD+dsN1rQq98OVSuy14aEp3lvRsjwMj40Oyit5R9o+8gGr d28N78YHVgGHJNYCrpiy462211GYs3XiGa2aj2RbW3aqBF24wOZBfKJWhajVPZIj/McR iPiQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; t=1680088201; h=content-transfer-encoding:in-reply-to:references:cc:to:from :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=6fMyRoI+gDBMSQ1ASPAj5GDfjiLEoGxH9G7/ldjpWq0=; b=h4aAFx31zI7iUvY7W4drn3O5PDHe827jnyizo7AIIV/BilaorGTVkCRrMNKJoWBfbG cZMvm/bXXc0ZxWRFkvCZo6YNBhyXI2heQVHjeo+i5TK4RLgs1/eU9JfBehIa5FE4rzZY CIe20IZaoVgRU1+vGZlWISOQ4GQwtv+SrVgtsSW2dGVNUfiuMPlT2PHIRFvC6B8HDDHc Ij+/29nKftwaD1+VDc4f6ALPfmKH/1eWZd0oNgZWHK/agmsd7OQKpWMabbCuSYh+GSSx AMq7o1qvd8EqSxsdelN4pCDe2HWVftthLNfMsBPlhz21Aen6rvt5rKwPAIbAJrapmkRX Y19Q== X-Gm-Message-State: AAQBX9dZxHmOUECJZI+USpSZkXQ70JBzSY/SRdBG6D/F+3Gcnd0f8/l1 Xs90hrl3lcrsMn7+HBW9Q/8DAw== X-Received: by 2002:adf:dd4f:0:b0:2cf:ec75:8090 with SMTP id u15-20020adfdd4f000000b002cfec758090mr14969737wrm.14.1680088201184; Wed, 29 Mar 2023 04:10:01 -0700 (PDT) Received: from ?IPV6:2a02:6b6a:b566:0:4aac:c45d:f15a:d179? ([2a02:6b6a:b566:0:4aac:c45d:f15a:d179]) by smtp.gmail.com with ESMTPSA id i7-20020adffc07000000b002c5706f7c6dsm29908071wrr.94.2023.03.29.04.10.00 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 29 Mar 2023 04:10:00 -0700 (PDT) Message-ID: <8b6eeca2-bc35-6e17-e1e9-27d77565db67@bytedance.com> Date: Wed, 29 Mar 2023 12:09:59 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.4.2 Subject: Re: [PATCH v17 2/8] cpu/hotplug: Reset task stack state in _cpu_up() Content-Language: en-US From: Usama Arif To: dwmw2@infradead.org, tglx@linutronix.de, kim.phillips@amd.com, brgerst@gmail.com Cc: piotrgorski@cachyos.org, oleksandr@natalenko.name, arjan@linux.intel.com, mingo@redhat.com, bp@alien8.de, dave.hansen@linux.intel.com, hpa@zytor.com, x86@kernel.org, pbonzini@redhat.com, paulmck@kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, rcu@vger.kernel.org, mimoja@mimoja.de, hewenliang4@huawei.com, thomas.lendacky@amd.com, seanjc@google.com, pmenzel@molgen.mpg.de, fam.zheng@bytedance.com, punit.agrawal@bytedance.com, simon.evans@bytedance.com, liangma@liangbit.com, gpiccoli@igalia.com, David Woodhouse , Mark Rutland References: <20230328195758.1049469-1-usama.arif@bytedance.com> <20230328195758.1049469-3-usama.arif@bytedance.com> In-Reply-To: <20230328195758.1049469-3-usama.arif@bytedance.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.2 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=unavailable 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 28/03/2023 20:57, Usama Arif wrote: > From: David Woodhouse > > Commit dce1ca0525bf ("sched/scs: Reset task stack state in bringup_cpu()") > ensured that the shadow call stack was reset and KASAN poisoning removed > from a CPU's stack each time that CPU is brought up, not just once. > > This is not incorrect. However, with parallel bringup, an architecture > may obtain the idle thread for a new CPU from a pre-bringup stage, by > calling idle_thread_get() for itself. This would mean that the cleanup > in bringup_cpu() would be too late. > > Move the SCS/KASAN cleanup to the generic _cpu_up() function instead, > which already ensures that the new CPU's stack is available, purely to > allow for early failure. This occurs when the CPU to be brought up is > in the CPUHP_OFFLINE state, which should correctly do the cleanup any > time the CPU has been taken down to the point where such is needed. > > Signed-off-by: David Woodhouse > Reviewed-by: Mark Rutland > Tested-by: Mark Rutland [arm64] Forgot to include my sign-off. Thanks David for pointing it out. Signed-off-by: Usama Arif > --- > kernel/cpu.c | 12 ++++++------ > 1 file changed, 6 insertions(+), 6 deletions(-) > > diff --git a/kernel/cpu.c b/kernel/cpu.c > index 6c0a92ca6bb5..43e0a77f21e8 100644 > --- a/kernel/cpu.c > +++ b/kernel/cpu.c > @@ -591,12 +591,6 @@ static int bringup_cpu(unsigned int cpu) > struct task_struct *idle = idle_thread_get(cpu); > int ret; > > - /* > - * Reset stale stack state from the last time this CPU was online. > - */ > - scs_task_reset(idle); > - kasan_unpoison_task_stack(idle); > - > /* > * Some architectures have to walk the irq descriptors to > * setup the vector space for the cpu which comes online. > @@ -1383,6 +1377,12 @@ static int _cpu_up(unsigned int cpu, int tasks_frozen, enum cpuhp_state target) > ret = PTR_ERR(idle); > goto out; > } > + > + /* > + * Reset stale stack state from the last time this CPU was online. > + */ > + scs_task_reset(idle); > + kasan_unpoison_task_stack(idle); > } > > cpuhp_tasks_frozen = tasks_frozen;