[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20131225030901.GA6333@dhcp-16-126.nay.redhat.com>
Date: Wed, 25 Dec 2013 11:09:01 +0800
From: Dave Young <dyoung@...hat.com>
To: Matt Fleming <matt@...sole-pimps.org>
Cc: Toshi Kani <toshi.kani@...com>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
"linux-efi@...r.kernel.org" <linux-efi@...r.kernel.org>,
"x86@...nel.org" <x86@...nel.org>,
"mjg59@...f.ucam.org" <mjg59@...f.ucam.org>,
"hpa@...or.com" <hpa@...or.com>,
"James.Bottomley@...senPartnership.com"
<James.Bottomley@...senPartnership.com>,
"vgoyal@...hat.com" <vgoyal@...hat.com>,
"ebiederm@...ssion.com" <ebiederm@...ssion.com>,
"horms@...ge.net.au" <horms@...ge.net.au>,
"kexec@...ts.infradead.org" <kexec@...ts.infradead.org>,
"bp@...en8.de" <bp@...en8.de>, "greg@...ah.com" <greg@...ah.com>,
"akpm@...ux-foundation.org" <akpm@...ux-foundation.org>,
"mingo@...nel.org" <mingo@...nel.org>,
"msalter@...hat.com" <msalter@...hat.com>,
"leif.lindholm@...aro.org" <leif.lindholm@...aro.org>
Subject: Re: [PATCH v7 00/12] kexec kernel efi runtime support
On 12/23/13 at 07:36am, Matt Fleming wrote:
> On Sun, 22 Dec, at 02:27:01PM, Toshi Kani wrote:
> >
> > The kexec branch is missing the following change, which is required for
> > fast reboot with multi-cpus.
> >
> > commit 279f1df915c3a6ed3075d98a849705bf53851f99
> > Author: Vivek Goyal <vgoyal@...hat.com>
> > Date: Tue Nov 26 10:25:28 2013 +0800
> >
> > kexec: migrate to reboot cpu
> >
> > With this change added, I confirmed that the branch kernel works fine.
>
> I can't find that commit in Linus' tree. Where is it from?
Previously it was in Andrew's mm tree, currently it's below commit in linus tree:
commit c97102ba96324da330078ad8619ba4dfe840dbe3
Author: Vivek Goyal <vgoyal@...hat.com>
Date: Wed Dec 18 17:08:31 2013 -0800
kexec: migrate to reboot cpu
Commit 1b3a5d02ee07 ("reboot: move arch/x86 reboot= handling to generic
kernel") moved reboot= handling to generic code. In the process it also
removed the code in native_machine_shutdown() which are moving reboot
process to reboot_cpu/cpu0.
I guess that thought must have been that all reboot paths are calling
migrate_to_reboot_cpu(), so we don't need this special handling. But
kexec reboot path (kernel_kexec()) is not calling
migrate_to_reboot_cpu() so above change broke kexec. Now reboot can
happen on non-boot cpu and when INIT is sent in second kerneo to bring
up BP, it brings down the machine.
So start calling migrate_to_reboot_cpu() in kexec reboot path to avoid
this problem.
Bisected by WANG Chao.
Reported-by: Matthew Whitehead <mwhitehe@...hat.com>
Reported-by: Dave Young <dyoung@...hat.com>
Signed-off-by: Vivek Goyal <vgoyal@...hat.com>
Tested-by: Baoquan He <bhe@...hat.com>
Tested-by: WANG Chao <chaowang@...hat.com>
Acked-by: H. Peter Anvin <hpa@...ux.intel.com>
Cc: <stable@...r.kernel.org>
Signed-off-by: Andrew Morton <akpm@...ux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@...ux-foundation.org>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists