Vitaly Kuznetsov
ad7dc69aeb
x86/kvm/mmu: fix switch between root and guest MMUs
...
Commit 14c07ad89f
("x86/kvm/mmu: introduce guest_mmu") brought one subtle
change: previously, when switching back from L2 to L1, we were resetting
MMU hooks (like mmu->get_cr3()) in kvm_init_mmu() called from
nested_vmx_load_cr3() and now we do that in nested_ept_uninit_mmu_context()
when we re-target vcpu->arch.mmu pointer.
The change itself looks logical: if nested_ept_init_mmu_context() changes
something than nested_ept_uninit_mmu_context() restores it back. There is,
however, one thing: the following call chain:
nested_vmx_load_cr3()
kvm_mmu_new_cr3()
__kvm_mmu_new_cr3()
fast_cr3_switch()
cached_root_available()
now happens with MMU hooks pointing to the new MMU (root MMU in our case)
while previously it was happening with the old one. cached_root_available()
tries to stash current root but it is incorrect to read current CR3 with
mmu->get_cr3(), we need to use old_mmu->get_cr3() which in case we're
switching from L2 to L1 is guest_mmu. (BTW, in shadow page tables case this
is a non-issue because we don't switch MMU).
While we could've tried to guess that we're switching between MMUs and call
the right ->get_cr3() from cached_root_available() this seems to be overly
complicated. Instead, just stash the corresponding CR3 when setting
root_hpa and make cached_root_available() use the stashed value.
Fixes: 14c07ad89f
("x86/kvm/mmu: introduce guest_mmu")
Signed-off-by: Vitaly Kuznetsov <vkuznets@redhat.com >
Cc: stable@vger.kernel.org
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com >
2019-02-22 19:24:48 +01:00
..
2018-03-03 00:03:35 +08:00
2017-11-02 11:10:55 +01:00
2018-12-04 12:37:28 +01:00
2018-12-26 17:03:51 -08:00
2019-02-15 15:19:56 +01:00
2018-11-09 08:16:55 +01:00
2017-03-02 08:42:37 +01:00
2018-10-10 10:44:22 +02:00
2017-11-02 11:10:55 +01:00
2018-12-19 12:00:04 +01:00
2018-12-26 17:03:51 -08:00
2018-09-27 18:28:58 +02:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2018-07-16 17:59:57 +02:00
2018-11-05 10:42:32 +01:00
2017-09-24 11:19:01 +02:00
2018-02-20 09:38:26 +01:00
2018-12-19 11:59:47 +01:00
2018-09-03 12:41:41 +02:00
2018-10-16 17:33:54 +02:00
2018-10-16 17:33:54 +02:00
2018-06-21 16:00:21 +02:00
2017-11-02 11:10:55 +01:00
2019-01-04 13:13:46 -08:00
2017-11-02 11:10:55 +01:00
2018-12-03 11:56:37 +01:00
2018-12-19 12:00:00 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-09-27 18:28:57 +02:00
2017-11-02 11:10:55 +01:00
2019-01-03 18:57:57 -08:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-12 12:15:35 +01:00
2018-07-25 11:53:58 +02:00
2018-12-03 10:49:13 +01:00
2018-11-01 12:59:25 +01:00
2017-11-02 11:10:55 +01:00
2018-09-12 21:33:53 +02:00
2017-11-02 11:10:55 +01:00
2019-01-06 09:46:51 +09:00
2018-12-26 11:46:28 -08:00
2017-11-02 11:10:55 +01:00
2018-11-23 07:59:59 +01:00
2017-11-02 11:10:55 +01:00
2018-09-03 16:50:36 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-09-03 16:50:36 +02:00
2018-03-20 10:01:57 +01:00
2018-11-20 08:44:28 +01:00
2017-11-02 11:10:55 +01:00
2018-03-20 10:01:59 +01:00
2018-05-28 12:48:25 +02:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-12-26 17:37:51 -08:00
2018-10-23 15:24:22 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-12 17:33:38 -08:00
2017-12-22 20:13:05 +01:00
2018-09-03 15:12:09 +02:00
2017-11-02 11:10:55 +01:00
2018-10-23 17:54:58 +01:00
2016-12-18 09:25:38 +01:00
2017-11-02 11:10:55 +01:00
2018-12-18 14:26:09 +01:00
2018-11-01 12:59:25 +01:00
2018-09-03 15:12:09 +02:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-10-26 16:26:34 -07:00
2018-06-26 09:07:58 +02:00
2018-03-28 10:40:55 +02:00
2018-12-21 11:28:39 +01:00
2018-01-14 21:11:54 +01:00
2018-08-15 13:44:10 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-01 21:50:11 +01:00
2017-11-02 11:10:55 +01:00
2017-11-23 20:17:59 +01:00
2018-05-13 19:52:55 +02:00
2017-11-02 11:10:55 +01:00
2018-07-25 11:50:50 +02:00
2018-05-19 14:03:14 +02:00
2018-03-12 12:10:54 +01:00
2017-11-27 13:39:11 +02:00
2018-12-21 11:28:33 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-14 13:18:30 +01:00
2018-07-03 13:08:21 +02:00
2017-12-22 20:13:04 +01:00
2018-02-17 11:47:45 +01:00
2019-01-04 18:15:33 -08:00
2017-11-02 11:10:55 +01:00
2018-03-20 10:01:56 +01:00
2018-10-25 16:59:08 +02:00
2017-11-02 11:10:55 +01:00
2018-09-25 14:33:43 +02:00
2018-04-26 11:57:57 +02:00
2018-11-23 07:59:59 +01:00
2018-11-23 07:59:59 +01:00
2017-12-29 21:13:04 +01:00
2018-09-03 16:50:36 +02:00
2018-04-23 10:17:28 +02:00
2019-01-06 09:46:51 +09:00
2018-02-06 18:32:43 -08:00
2018-02-14 13:11:13 +01:00
2017-11-02 11:10:55 +01:00
2018-08-22 10:52:47 -07:00
2018-09-06 14:33:12 +02:00
2018-04-13 17:10:27 -07:00
2018-10-31 08:54:12 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-21 12:33:13 +02:00
2018-09-27 18:28:59 +02:00
2019-02-22 19:24:48 +01:00
2017-11-02 11:10:55 +01:00
2018-11-23 07:59:59 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-10-16 17:33:54 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-05-19 14:03:14 +02:00
2018-11-06 19:13:26 +01:00
2018-05-22 23:18:31 -07:00
2018-09-15 20:48:45 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-04-02 15:16:43 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-01-15 10:33:45 +01:00
2017-12-22 20:13:01 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-17 12:58:53 +01:00
2018-01-14 21:11:54 +01:00
2017-11-02 11:10:55 +01:00
2018-09-19 15:53:11 +02:00
2018-12-21 11:28:39 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-12-26 11:46:28 -08:00
2017-11-02 11:10:55 +01:00
2018-09-03 16:50:36 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-12-18 14:13:33 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-07-26 13:18:20 +02:00
2018-06-21 16:34:56 +02:00
2018-06-20 19:09:59 +02:00
2017-11-02 11:10:55 +01:00
2019-02-01 15:46:23 -08:00
2018-04-02 15:45:30 -07:00
2018-06-06 13:38:01 +02:00
2017-11-02 11:10:55 +01:00
2018-12-19 11:59:55 +01:00
2018-11-23 07:59:59 +01:00
2017-11-02 11:10:55 +01:00
2018-01-16 16:40:09 +01:00
2017-11-02 11:10:55 +01:00
2018-12-20 10:19:49 +01:00
2018-06-29 20:06:07 -05:00
2017-11-02 11:10:55 +01:00
2018-05-07 07:15:41 +02:00
2018-10-14 11:11:22 +02:00
2017-11-02 11:10:55 +01:00
2018-10-09 08:50:10 +02:00
2019-01-04 13:13:47 -08:00
2018-07-20 01:11:47 +02:00
2019-01-03 18:57:57 -08:00
2018-12-11 11:19:24 +01:00
2018-09-20 23:17:22 +02:00
2018-11-30 09:10:30 +01:00
2018-07-20 01:11:42 +02:00
2018-09-14 17:08:45 +02:00
2018-09-03 16:50:36 +02:00
2018-08-27 14:20:49 -04:00
2018-08-17 10:27:36 -07:00
2019-02-10 08:47:12 +01:00
2018-06-07 10:23:33 -07:00
2018-03-01 16:22:48 +00:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-12-07 12:35:46 +00:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:44 +02:00
2018-12-28 12:11:48 -08:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:45 +02:00
2018-10-30 09:49:56 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-05-19 14:03:14 +02:00
2017-11-02 11:10:55 +01:00
2018-07-25 11:22:20 +02:00
2018-11-04 00:54:34 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-11-23 07:59:59 +01:00
2018-12-19 12:00:09 +01:00
2018-02-16 10:48:49 +01:00
2019-02-02 10:34:52 +01:00
2017-11-02 11:10:55 +01:00
2019-01-06 09:46:51 +09:00
2017-11-07 10:32:44 +01:00
2017-11-02 11:10:55 +01:00
2018-09-12 21:33:53 +02:00
2018-10-23 17:54:58 +01:00
2017-11-02 11:10:55 +01:00
2018-08-25 18:43:59 -07:00
2018-12-08 12:24:35 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-11-23 07:59:59 +01:00
2018-08-30 13:02:31 +02:00
2017-11-02 11:10:55 +01:00
2018-11-23 07:59:59 +01:00
2018-05-19 11:56:57 +02:00
2018-11-28 11:57:12 +01:00
2018-09-03 16:50:37 +02:00
2017-11-02 11:10:55 +01:00
2017-11-07 10:32:44 +01:00
2017-11-02 11:10:55 +01:00
2018-06-14 12:21:18 +09:00
2018-08-31 17:08:22 +02:00
2017-11-15 18:21:05 -08:00
2019-01-04 18:15:33 -08:00
2017-11-02 11:10:55 +01:00
2018-10-03 11:56:33 +02:00
2017-12-15 12:21:38 +01:00
2018-10-03 11:56:34 +02:00
2018-12-21 11:28:44 +01:00
2018-03-20 10:01:57 +01:00
2018-11-28 11:57:11 +01:00
2017-11-02 11:10:55 +01:00
2018-02-05 21:34:57 +01:00
2018-04-09 16:47:28 +02:00
2018-04-05 16:59:38 +02:00
2018-04-09 16:47:28 +02:00
2018-07-20 00:02:38 +02:00
2018-12-03 19:00:28 +01:00
2017-11-02 11:10:55 +01:00
2017-11-13 19:07:38 -08:00
2017-11-02 11:10:55 +01:00
2018-10-09 16:51:12 +02:00
2017-11-02 11:10:55 +01:00
2018-11-28 11:57:11 +01:00
2018-06-21 14:20:57 +02:00
2017-11-02 11:10:55 +01:00
2018-12-08 12:24:35 +01:00
2018-11-23 07:59:59 +01:00
2018-01-30 21:54:31 +01:00
2018-07-16 00:05:05 +02:00
2019-01-20 15:33:22 +12:00
2017-11-08 11:16:22 +01:00
2017-11-02 11:10:55 +01:00
2018-08-29 15:42:23 +02:00
2018-06-21 16:34:56 +02:00
2018-01-03 16:14:46 +01:00
2017-12-11 18:42:11 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-10-23 19:07:25 +01:00
2018-10-25 17:57:35 -07:00
2017-11-02 11:10:55 +01:00
2018-12-21 11:28:34 +01:00
2017-12-23 21:13:00 +01:00
2017-11-02 11:10:55 +01:00
2018-11-20 09:43:10 +01:00
2017-11-02 11:10:55 +01:00
2017-11-15 18:21:04 -08:00