Thread (30 messages) 30 messages, 5 authors, 2017-01-24
STALE3424d

[PATCH v29 3/9] arm64: kdump: reserve memory for crash dump kernel

From: mark.rutland@arm.com (Mark Rutland)
Date: 2017-01-23 10:23:15
Also in: kexec

On Mon, Jan 23, 2017 at 06:51:46PM +0900, AKASHI Takahiro wrote:
Mark,

On Thu, Jan 19, 2017 at 11:28:50AM +0000, Mark Rutland wrote:
quoted
On Thu, Jan 19, 2017 at 06:49:42PM +0900, AKASHI Takahiro wrote:
quoted
On Tue, Jan 17, 2017 at 11:54:42AM +0000, Mark Rutland wrote:
quoted
On Tue, Jan 17, 2017 at 05:20:44PM +0900, AKASHI Takahiro wrote:
quoted
On Fri, Jan 13, 2017 at 11:39:15AM +0000, Mark Rutland wrote:
quoted
quoted
quoted
I don't think we have much code useful for unmapping. We could re-use 
create_mapping_late for this, passing a set of prot bits that means the
entries are invalid (e.g. have a PAGE_KERNEL_INVALID).
Do you really think that we should totally invalidate mmu entries?
I guess that, given proper cache & TLB flush operations, RO attribute is
good enough for memory consistency, no?
(None accesses the region, as I said, except in the case of re-loading
crash dump kernel though.)
My worry is that the first kernel and kdump kernel may map (portions of)
the region with potentially confliciting memory attributes. So it would
be necessary to completely unmap the region.
I think that this can happen only if the second kernel boots up,
leaving non-crashed cpus still running for some reason.
Yes. I was considering a kdump case where a secondary was stuck in the
first kernel.
quoted
You raise a good point that this would also mean we need to perform some
cache maintenance, which makes that a little more painful. We'd need a
sequence like:

* Unmap the region
* TLB invalidation
* Remap the region with non-cacheable attributes
* Cache maintenance
* Unmap the region
* TLB invalidation
I don't get why we need to remap the region and do cache
maintenance here. Please elaborate a bit more?
I think I was wrong, and we don't need to. Sorry about that.

My thought was that to ensure that there aren't stale lines with
differing attributes, we'd need to do a clean+invalidate while the
caches are guaranteed to not allocate anything furthe. Hence, we'd need
to use a non-cacheable mapping to perform the clean+invalidate.

However, I now think that so long as we unmap the range, this shouldn't
matter. The new kernel can perform the maintenance if it wishes to use
different attributes, similarly to what the first kernel must do per the
boot protocol.
My current implementation of arch_kexec_protect_crashkres() is:

        kexec_segment_flush(kexec_crash_image);
        create_mapping_late(crashk_res.start, ..., __pgprot(0));
                                                or PAGE_KERNEL_INVALID
        flush_tlb_all();

kexec_segment_flush() will eventually do dcache-flush for all the modified
data in crash dump kernel memory.
I now think this should be fine, per the above.

Thanks,
Mark.
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help