From: Thomas Gleixner <tglx@linutronix.de>
To: David Woodhouse <dwmw2@infradead.org>,
Usama Arif <usama.arif@bytedance.com>,
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
Subject: Re: [PATCH v12 06/11] x86/smpboot: Remove initial_stack on 64-bit
Date: Tue, 28 Feb 2023 21:17:19 +0100 [thread overview]
Message-ID: <87edq9mto0.ffs@tglx> (raw)
In-Reply-To: <c6863590f5fbf139f6aec50d0f3bc8e8b00cfcaf.camel@infradead.org>
On Tue, Feb 28 2023 at 17:09, David Woodhouse wrote:
> On Tue, 2023-02-28 at 17:13 +0100, Thomas Gleixner wrote:
>> As this patch is now part of the parallel boot series and actually
>> introduces smpboot_control, the above is neither accurate nor useful.
>
> Better commit message, add a comment where we abuse current->thread.sp
> in the sleep path. Didn't remove the {} which would be added back in
> the very next patch. Pushed to my tree for Usama's next round.
Ok.
> However, we start by introducing one more: smpboot_control. For now this
s/we// :)
> merely holds the CPU# of the CPU which is coming up. That CPU can then
> find its own per-cpu data, and everything else it needs can be found from
> there, allowing the other global variables to be removed.
>
> First to be removed is initial_stack. Each CPU can load %rsp from its
> current_task->thread.sp instead. That is already set up with the correct
> idle thread for APs. Set up the .sp field in INIT_THREAD on x86 so that
> the BSP also finds a suitable stack pointer in the static per-cpu data
> when coming up on first boot.
>
> On resume from S3, the CPU needs a temporary stack because its idle task
> is already active. Instead of setting initial_stack, the sleep code can
> simply set its own current->thread.sp to point to the temporary stack.
> The true stack pointer will get restored with the rest of the CPU
> context in do_suspend_lowlevel().
Thanks for writing this up!
> + /*
> + * As each CPU starts up, it will find its own stack pointer
> + * from its current_task->thread.sp. Typically that will be
> + * the idle thread for a newly-started AP, or even the boot
> + * CPU which will find it set to &init_task in the static
> + * per-cpu data.
> + *
> + * Make the resuming CPU use the temporary stack at startup
> + * by setting current->thread.sp to point to that. The true
> + * %rsp will be restored with the rest of the CPU context,
> + * by do_suspend_lowlevel().
Right, but what restores current->thread.sp? thread.sp is used by
unwinders...
Thanks,
tglx
next prev parent reply other threads:[~2023-02-28 20:17 UTC|newest]
Thread overview: 49+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-02-26 11:07 [PATCH v12 00/11] Parallel CPU bringup for x86_64 Usama Arif
2023-02-26 11:07 ` [PATCH v12 01/11] x86/apic/x2apic: Allow CPU cluster_mask to be populated in parallel Usama Arif
2023-02-26 11:07 ` [PATCH v12 02/11] cpu/hotplug: Move idle_thread_get() to <linux/smpboot.h> Usama Arif
2023-02-26 11:07 ` [PATCH v12 03/11] cpu/hotplug: Add dynamic parallel bringup states before CPUHP_BRINGUP_CPU Usama Arif
2023-02-26 11:07 ` [PATCH v12 04/11] x86/smpboot: Reference count on smpboot_setup_warm_reset_vector() Usama Arif
2023-02-26 11:07 ` [PATCH v12 05/11] x86/smpboot: Split up native_cpu_up into separate phases and document them Usama Arif
2023-02-26 11:07 ` [PATCH v12 06/11] x86/smpboot: Remove initial_stack on 64-bit Usama Arif
2023-02-28 16:13 ` Thomas Gleixner
2023-02-28 16:25 ` David Woodhouse
2023-02-28 20:32 ` Thomas Gleixner
2023-02-28 17:09 ` David Woodhouse
2023-02-28 20:17 ` Thomas Gleixner [this message]
2023-02-28 20:43 ` David Woodhouse
2023-03-01 10:18 ` Thomas Gleixner
2023-03-01 10:42 ` David Woodhouse
2023-02-28 22:22 ` Brian Gerst
2023-02-26 11:07 ` [PATCH v12 07/11] x86/smpboot: Remove early_gdt_descr " Usama Arif
2023-02-28 21:01 ` Thomas Gleixner
2023-02-28 21:02 ` Arjan van de Ven
2023-03-01 20:32 ` Josh Triplett
2023-03-01 22:16 ` Paul E. McKenney
2023-03-01 22:25 ` Josh Triplett
2023-03-02 0:28 ` Paul E. McKenney
2023-03-02 1:05 ` Randy Dunlap
2023-03-02 1:37 ` Paul E. McKenney
2023-02-28 21:57 ` David Woodhouse
2023-02-28 22:41 ` David Woodhouse
2023-02-28 22:48 ` Brian Gerst
2023-02-28 23:42 ` David Woodhouse
2023-03-01 0:02 ` H. Peter Anvin
2023-03-01 7:39 ` David Woodhouse
2023-03-01 0:03 ` Brian Gerst
2023-03-01 10:27 ` Thomas Gleixner
2023-02-28 22:09 ` Brian Gerst
2023-02-26 11:07 ` [PATCH v12 08/11] x86/smpboot: Remove initial_gs Usama Arif
2023-02-26 11:08 ` [PATCH v12 09/11] x86/smpboot: Support parallel startup of secondary CPUs Usama Arif
2023-02-26 11:08 ` [PATCH v12 10/11] x86/smpboot: Send INIT/SIPI/SIPI to secondary CPUs in parallel Usama Arif
2023-02-26 11:08 ` [PATCH v12 11/11] x86/smpboot: Serialize topology updates for secondary bringup Usama Arif
2023-02-26 18:31 ` [PATCH v12 00/11] Parallel CPU bringup for x86_64 Oleksandr Natalenko
2023-02-26 20:59 ` [External] " Usama Arif
2023-02-27 6:13 ` David Woodhouse
2023-02-27 6:25 ` Usama Arif
2023-02-27 6:14 ` Usama Arif
2023-02-27 15:29 ` David Woodhouse
2023-02-27 16:32 ` Usama Arif
2023-02-27 21:39 ` Guilherme G. Piccoli
2023-02-28 9:07 ` David Woodhouse
2023-02-28 10:13 ` Paul Menzel
2023-02-28 12:04 ` Guilherme G. Piccoli
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87edq9mto0.ffs@tglx \
--to=tglx@linutronix.de \
--cc=arjan@linux.intel.com \
--cc=bp@alien8.de \
--cc=brgerst@gmail.com \
--cc=dave.hansen@linux.intel.com \
--cc=dwmw2@infradead.org \
--cc=fam.zheng@bytedance.com \
--cc=hewenliang4@huawei.com \
--cc=hpa@zytor.com \
--cc=kim.phillips@amd.com \
--cc=kvm@vger.kernel.org \
--cc=liangma@liangbit.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mimoja@mimoja.de \
--cc=mingo@redhat.com \
--cc=oleksandr@natalenko.name \
--cc=paulmck@kernel.org \
--cc=pbonzini@redhat.com \
--cc=piotrgorski@cachyos.org \
--cc=pmenzel@molgen.mpg.de \
--cc=punit.agrawal@bytedance.com \
--cc=rcu@vger.kernel.org \
--cc=seanjc@google.com \
--cc=simon.evans@bytedance.com \
--cc=thomas.lendacky@amd.com \
--cc=usama.arif@bytedance.com \
--cc=x86@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.