[PATCH 6/7] arm64/kexec: Add core kexec support
Vivek Goyal
vgoyal at redhat.com
Tue Oct 7 06:44:50 PDT 2014
On Fri, Oct 03, 2014 at 11:35:03AM -0700, Geoff Levand wrote:
> Hi Vivek,
>
> On Wed, 2014-10-01 at 10:56 -0400, Vivek Goyal wrote:
> > On Tue, Sep 30, 2014 at 12:54:37PM -0700, Geoff Levand wrote:
> >
> > [..]
> > > > > +{
> > > > > + switch (flag) {
> > > > > + case IND_INDIRECTION:
> > > > > + case IND_SOURCE:
> > > > > + __flush_dcache_area(addr, PAGE_SIZE);
> > > > > + break;
> > > >
> > > > So what does __flush_dcache_area() do? Flush data caches. IIUC, addr
> > > > is virtual address at this point of time. While copying pages and
> > > > walking through the list, I am assuming you have switched off page
> > > > tables and you are in some kind of 1:1 physical mode. So how did
> > > > flushing data caches related to a virtual address help. I guess we
> > > > are not even accessing that virtual address now.
> > >
> > > __flush_dcache_area(), and the underling aarch64 civac instruction
> > > operate on virtual addresses. Here we are still running with the
> > > MMU on and the identity mapping has not yet been enabled. This is
> > > the sequence:
> > >
> > > flush dcache -> turn off MMU, dcache -> access memory (PoC) directly
> >
> > Sorry, I don't understand that why do we need to flush dcache for source
> > and indirection page addresses. Some information here will help.
>
> I think Mark answered this. The architecture requires us to flush to
> the point of coherency (PoC) anything that will be used after the
> dcache is disabled.
>
> For more info you can look at the section'D4.4.7 Cache maintenance
> operations' in the ARMv8 Reference Manual you can get from here (after
> registering):
>
> http://infocenter.arm.com/help/topic/com.arm.doc.subset.architecture.reference/index.html
Geoff,
So as Mark and I discussed need of purgatory code in other mails, are you
plannign to enable purgatory on arm64.
Thanks
Vivek
More information about the kexec
mailing list