From: will.deacon@arm.com (Will Deacon)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH] arm64: kvm: Fix kvm teardown for systems using the extended idmap
Date: Tue, 3 May 2016 09:57:59 +0100 [thread overview]
Message-ID: <20160503085758.GA2604@arm.com> (raw)
In-Reply-To: <57286432.2000606@arm.com>
Hi all,
On Tue, May 03, 2016 at 09:41:22AM +0100, Marc Zyngier wrote:
> On 03/05/16 09:36, Christoffer Dall wrote:
> > On Mon, May 02, 2016 at 01:05:35PM +0100, Marc Zyngier wrote:
> >> On Fri, 29 Apr 2016 18:27:03 +0100
> >> James Morse <james.morse@arm.com> wrote:
> >>> If memory is located above 1<<VA_BITS, kvm adds an extra level to its page
> >>> tables, merging the runtime tables and boot tables that contain the idmap.
> >>> This lets us avoid the trampoline dance during initialisation.
> >>>
> >>> This also means there is no trampoline page mapped, so
> >>> __cpu_reset_hyp_mode() can't call __kvm_hyp_reset() in this page. The good
> >>> news is the idmap is still mapped, so we don't need the trampoline page.
> >>> The bad news is we can't call it directly as the idmap is above
> >>> HYP_PAGE_OFFSET, so its address is masked by kvm_call_hyp.
> >>>
> >>> Add a function __extended_idmap_trampoline which will branch into
> >>> __kvm_hyp_reset in the idmap, change kvm_hyp_reset_entry() to return
> >>> this address if __kvm_cpu_uses_extended_idmap(). In this case
> >>> __kvm_hyp_reset() will still switch to the boot tables (which are the
> >>> merged tables that were already in use), and branch into the idmap (where
> >>> it already was).
> >>>
> >>> This fixes boot failures on these systems, where we fail to execute the
> >>> missing trampoline page when tearing down kvm in init_subsystems():
> >>> [ 2.508922] kvm [1]: 8-bit VMID
> >>> [ 2.512057] kvm [1]: Hyp mode initialized successfully
> >>> [ 2.517242] kvm [1]: interrupt-controller at e1140000 IRQ13
> >>> [ 2.522622] kvm [1]: timer IRQ3
> >>> [ 2.525783] Kernel panic - not syncing: HYP panic:
> >>> [ 2.525783] PS:200003c9 PC:0000007ffffff820 ESR:86000005
> >>> [ 2.525783] FAR:0000007ffffff820 HPFAR:00000000003ffff0 PAR:0000000000000000
> >>> [ 2.525783] VCPU: (null)
> >>> [ 2.525783]
> >>> [ 2.547667] CPU: 0 PID: 0 Comm: swapper/0 Tainted: G W 4.6.0-rc5+ #1
> >>> [ 2.555137] Hardware name: Default string Default string/Default string, BIOS ROD0084E 09/03/2015
> >>> [ 2.563994] Call trace:
> >>> [ 2.566432] [<ffffff80080888d0>] dump_backtrace+0x0/0x240
> >>> [ 2.571818] [<ffffff8008088b24>] show_stack+0x14/0x20
> >>> [ 2.576858] [<ffffff80083423ac>] dump_stack+0x94/0xb8
> >>> [ 2.581899] [<ffffff8008152130>] panic+0x10c/0x250
> >>> [ 2.586677] [<ffffff8008152024>] panic+0x0/0x250
> >>> [ 2.591281] SMP: stopping secondary CPUs
> >>> [ 3.649692] SMP: failed to stop secondary CPUs 0-2,4-7
> >>> [ 3.654818] Kernel Offset: disabled
> >>> [ 3.658293] Memory Limit: none
> >>> [ 3.661337] ---[ end Kernel panic - not syncing: HYP panic:
> >>> [ 3.661337] PS:200003c9 PC:0000007ffffff820 ESR:86000005
> >>> [ 3.661337] FAR:0000007ffffff820 HPFAR:00000000003ffff0 PAR:0000000000000000
> >>> [ 3.661337] VCPU: (null)
> >>> [ 3.661337]
> >>>
> >>>
> >>> Reported-by: Will Deacon <will.deacon@arm.com>
> >>> Signed-off-by: James Morse <james.morse@arm.com>
[...]
> >> Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
> >>
> > thanks! Will, should this go via the kvmarm tree or the arm64 tree?
>
> I believe this issue only exists with the hibernation patches, so I
> suggest we let Will handle this though the arm64 tree together with the
> rest of this series.
Appplied and pushed to for-next/core. Sorry for the delay (bank holiday
here) and thanks for the comments.
Will
prev parent reply other threads:[~2016-05-03 8:57 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-04-27 16:46 [PATCH v9 00/14] arm64: kernel: Add support for hibernate/suspend-to-disk James Morse
2016-04-27 16:47 ` [PATCH v9 01/14] arm64: Fold proc-macros.S into assembler.h James Morse
2016-04-27 16:47 ` [PATCH v9 02/14] arm64: Cleanup SCTLR flags James Morse
2016-04-27 16:47 ` [PATCH v9 03/14] arm64: kvm: Move lr save/restore from do_el2_call into EL1 James Morse
2016-04-27 16:47 ` [PATCH v9 04/14] arm64: hyp/kvm: Make hyp-stub extensible James Morse
2016-04-27 16:47 ` [PATCH v9 05/14] arm64: hyp/kvm: Make hyp-stub reject kvm_call_hyp() James Morse
2016-04-27 16:47 ` [PATCH v9 06/14] arm64: kvm: allows kvm cpu hotplug James Morse
2016-04-27 16:47 ` [PATCH v9 07/14] arm64: kernel: Rework finisher callback out of __cpu_suspend_enter() James Morse
2016-04-27 16:47 ` [PATCH v9 08/14] arm64: Change cpu_resume() to enable mmu early then access sleep_sp by va James Morse
2016-04-27 16:47 ` [PATCH v9 09/14] arm64: kernel: Include _AC definition in page.h James Morse
2016-04-27 16:47 ` [PATCH v9 10/14] arm64: Promote KERNEL_START/KERNEL_END definitions to a header file James Morse
2016-04-27 16:47 ` [PATCH v9 11/14] arm64: Add new asm macro copy_page James Morse
2016-04-27 16:47 ` [PATCH v9 12/14] PM / Hibernate: Call flush_icache_range() on pages restored in-place James Morse
2016-04-28 12:15 ` Will Deacon
2016-04-28 12:23 ` James Morse
2016-04-28 12:27 ` Will Deacon
2016-04-27 16:47 ` [PATCH v9 13/14] arm64: kernel: Add support for hibernate/suspend-to-disk James Morse
2016-04-28 9:26 ` Catalin Marinas
2016-04-27 16:47 ` [PATCH v9 14/14] arm64: hibernate: Refuse to hibernate if the boot cpu is offline James Morse
2016-04-28 12:40 ` [PATCH v9 00/14] arm64: kernel: Add support for hibernate/suspend-to-disk Will Deacon
2016-04-28 17:31 ` James Morse
2016-04-28 18:37 ` Will Deacon
2016-04-29 17:27 ` [PATCH] arm64: kvm: Fix kvm teardown for systems using the extended idmap James Morse
2016-05-02 12:05 ` Marc Zyngier
2016-05-03 8:36 ` Christoffer Dall
2016-05-03 8:41 ` Marc Zyngier
2016-05-03 8:57 ` Will Deacon [this message]
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=20160503085758.GA2604@arm.com \
--to=will.deacon@arm.com \
--cc=linux-arm-kernel@lists.infradead.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.