Jan Kiszka
e5ad936b0f
kvmvapic: Introduce TPR access optimization for Windows guests
...
This enables acceleration for MMIO-based TPR registers accesses of
32-bit Windows guest systems. It is mostly useful with KVM enabled,
either on older Intel CPUs (without flexpriority feature, can also be
manually disabled for testing) or any current AMD processor.
The approach introduced here is derived from the original version of
qemu-kvm. It was refactored, documented, and extended by support for
user space APIC emulation, both with and without KVM acceleration. The
VMState format was kept compatible, so was the ABI to the option ROM
that implements the guest-side para-virtualized driver service. This
enables seamless migration from qemu-kvm to upstream or, one day,
between KVM and TCG mode.
The basic concept goes like this:
- VAPIC PV interface consisting of I/O port 0x7e and (for KVM in-kernel
irqchip) a vmcall hypercall is registered
- VAPIC option ROM is loaded into guest
- option ROM activates TPR MMIO access reporting via port 0x7e
- TPR accesses are trapped and patched in the guest to call into option
ROM instead, VAPIC support is enabled
- option ROM TPR helpers track state in memory and invoke hypercall to
poll for pending IRQs if required
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
2012-02-18 12:15:59 +02:00
..
2012-02-15 09:39:21 -06:00
2012-02-15 17:18:04 -06:00
2012-02-18 12:15:59 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2011-10-06 09:48:07 +02:00
2011-10-06 09:48:07 +02:00
2012-02-07 22:11:04 +04:00
2012-02-15 09:39:21 -06:00
2011-12-20 15:44:30 -06:00
2012-01-22 07:27:06 +00:00
2011-12-20 15:44:30 -06:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2012-02-18 12:15:59 +02:00
2012-02-18 12:15:59 +02:00
2012-02-18 12:15:59 +02:00
2012-02-18 12:15:55 +02:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-26 11:49:09 +00:00
2012-01-17 10:54:07 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-16 11:11:55 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-26 11:43:48 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-12-20 15:44:31 -06:00
2012-01-04 13:34:48 +02:00
2011-08-22 10:17:44 -05:00
2011-07-24 14:48:57 +00:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2012-01-22 07:27:06 +00:00
2012-02-15 09:39:21 -06:00
2011-12-06 09:56:41 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-09-03 10:45:59 +00:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-04 12:45:10 +00:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2011-10-16 11:11:55 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-06 09:48:07 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-04 02:48:14 +01:00
2011-10-17 15:59:18 +02:00
2011-11-04 14:23:58 +01:00
2011-12-05 08:44:33 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:34:48 +02:00
2011-12-06 09:56:41 +00:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2012-01-10 18:40:09 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-08 10:22:29 -05:00
2012-02-15 09:39:21 -06:00
2012-01-12 13:54:17 +01:00
2012-01-12 13:54:17 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-16 11:11:55 +00:00
2012-02-15 09:39:21 -06:00
2011-12-20 15:44:30 -06:00
2011-09-04 17:46:51 +03:00
2011-12-14 11:08:20 +00:00
2011-12-14 11:08:20 +00:00
2012-02-11 10:39:13 +00:00
2011-12-20 14:14:07 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2011-12-06 09:56:41 +00:00
2011-12-14 11:09:12 +00:00
2012-02-15 09:39:21 -06:00
2011-10-06 09:48:07 +02:00
2011-09-10 14:49:51 +00:00
2012-01-13 10:20:51 -06:00
2012-02-15 09:39:21 -06:00
2011-09-03 10:45:59 +00:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:20:51 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-12-20 15:44:30 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2011-10-16 11:10:48 +00:00
2012-02-15 09:39:21 -06:00
2011-09-23 11:51:05 -05:00
2011-09-23 11:51:05 -05:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2011-12-06 09:59:05 +00:00
2012-02-18 12:15:59 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:20:50 -06:00
2012-01-04 13:34:48 +02:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-16 11:11:55 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-12-14 11:08:23 +00:00
2011-12-14 11:08:23 +00:00
2012-01-21 05:17:01 +01:00
2011-11-19 11:23:42 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-21 18:14:29 +02:00
2011-10-21 18:14:29 +02:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-18 12:15:55 +02:00
2011-12-20 15:44:30 -06:00
2012-01-13 10:20:50 -06:00
2012-01-13 10:20:50 -06:00
2011-11-28 15:38:42 +02:00
2011-11-28 15:38:42 +02:00
2011-11-28 15:38:42 +02:00
2011-11-28 15:38:42 +02:00
2011-10-16 11:11:55 +00:00
2011-08-22 23:29:37 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-03 12:44:22 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-19 08:16:41 +00:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:34:48 +02:00
2012-01-13 10:55:56 -06:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:34:48 +02:00
2012-01-04 13:34:48 +02:00
2011-11-24 18:31:59 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-19 12:14:39 +01:00
2012-01-19 12:14:39 +01:00
2012-01-19 12:14:39 +01:00
2012-01-19 12:14:39 +01:00
2011-08-22 10:17:16 -05:00
2011-07-23 11:18:57 -05:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-08 10:22:29 -05:00
2011-11-28 15:38:39 +02:00
2011-12-20 15:44:30 -06:00
2012-01-04 10:06:25 -06:00
2012-01-04 13:34:48 +02:00
2011-08-20 23:01:08 -05:00
2011-11-28 15:38:41 +02:00
2012-01-13 10:36:59 +00:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:41:42 +00:00
2011-11-28 15:40:49 +02:00
2011-11-28 15:40:49 +02:00
2012-02-15 09:39:21 -06:00
2011-11-28 15:40:49 +02:00
2011-12-20 14:14:07 +02:00
2011-11-28 15:40:49 +02:00
2011-11-28 15:38:41 +02:00
2011-11-28 15:40:49 +02:00
2012-01-04 13:34:48 +02:00
2011-11-28 15:40:49 +02:00
2011-11-28 15:40:49 +02:00
2011-11-28 15:40:49 +02:00
2012-01-04 13:41:42 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-27 10:28:30 -06:00
2012-01-27 10:28:30 -06:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2012-02-08 15:57:50 -02:00
2012-02-15 18:41:28 -06:00
2012-01-23 11:00:26 -06:00
2012-01-27 10:50:50 -06:00
2011-09-04 17:46:50 +03:00
2011-11-24 18:32:03 +02:00
2012-01-20 00:27:12 +01:00
2011-09-20 17:46:12 +03:00
2011-09-21 14:32:20 +02:00
2012-01-04 02:48:14 +01:00
2011-12-06 09:56:41 +00:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2011-12-06 09:56:41 +00:00
2011-08-22 10:22:03 -05:00
2011-08-22 10:22:03 -05:00
2011-08-20 23:01:08 -05:00
2012-01-27 10:50:50 -06:00
2012-01-13 10:20:51 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-27 10:50:39 -06:00
2011-11-01 16:52:09 -05:00
2011-12-20 15:44:31 -06:00
2012-01-04 13:34:48 +02:00
2012-01-04 13:34:48 +02:00
2012-01-04 13:34:48 +02:00
2012-02-11 10:58:09 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-12-14 11:08:23 +00:00
2011-12-14 11:08:23 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-17 23:01:11 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2011-08-22 10:47:42 -05:00
2012-01-04 13:34:48 +02:00
2012-01-04 13:34:48 +02:00
2011-10-02 16:14:02 +02:00
2012-01-21 05:17:01 +01:00
2011-10-06 09:48:09 +02:00
2011-10-06 09:48:07 +02:00
2012-01-27 10:28:30 -06:00
2012-01-04 13:34:48 +02:00
2012-02-03 10:41:08 -06:00
2011-12-06 09:56:41 +00:00
2011-10-06 09:48:09 +02:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-11-01 16:52:05 -05:00
2012-01-13 10:20:50 -06:00
2012-01-13 10:20:51 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-17 02:14:42 +01:00
2012-01-17 01:40:18 +01:00
2012-01-13 10:55:56 -06:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-11-24 18:31:59 +02:00
2012-02-07 13:52:42 +01:00
2012-02-15 09:39:21 -06:00
2012-02-14 18:57:33 +00:00
2012-02-15 09:39:21 -06:00
2012-02-07 13:52:42 +01:00
2011-09-07 09:20:09 +02:00
2011-12-02 10:50:56 +00:00
2012-02-15 09:39:21 -06:00
2011-11-01 12:11:53 +01:00
2012-01-04 13:34:48 +02:00
2011-11-24 18:31:59 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-01-22 07:27:06 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-11-18 13:57:16 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2011-12-21 05:04:21 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-12-06 09:56:41 +00:00
2011-11-24 18:32:03 +02:00
2011-11-24 18:32:03 +02:00
2011-11-24 18:32:03 +02:00
2012-02-15 09:39:21 -06:00
2011-11-24 18:32:03 +02:00
2012-01-13 10:20:50 -06:00
2011-11-24 18:32:03 +02:00
2012-01-04 13:34:48 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-11 10:39:13 +00:00
2012-01-13 10:55:56 -06:00
2011-09-03 10:45:59 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2011-09-21 11:14:42 +03:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-31 04:53:01 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-22 07:27:06 +00:00
2012-01-03 15:49:11 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-09-03 10:45:59 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-17 15:59:18 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-10-16 11:11:55 +00:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2011-12-06 09:59:05 +00:00
2012-01-13 10:55:56 -06:00
2011-11-11 12:49:53 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-01-27 10:50:47 -06:00
2012-01-13 10:25:44 +01:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2011-08-04 15:51:22 +02:00
2012-02-15 17:25:25 -06:00
2012-02-10 11:31:57 +01:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-15 17:25:25 -06:00
2012-02-10 12:16:30 +01:00
2012-02-10 12:16:30 +01:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-09 12:10:35 +00:00
2012-02-04 12:45:10 +00:00
2012-02-04 12:45:10 +00:00
2011-08-22 10:47:49 -05:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-11 10:39:57 +00:00
2012-02-04 12:45:10 +00:00
2012-01-13 10:55:56 -06:00
2012-01-25 18:32:47 +00:00
2012-01-03 19:19:28 +02:00
2012-01-21 05:17:01 +01:00
2012-01-03 19:19:28 +02:00
2011-09-03 10:45:59 +00:00
2012-01-26 14:49:18 +01:00
2011-09-03 10:45:59 +00:00
2012-02-15 09:39:21 -06:00
2012-01-27 10:50:39 -06:00
2011-09-03 10:45:59 +00:00
2012-02-15 09:39:21 -06:00
2011-12-04 22:35:28 +05:30
2012-02-15 09:39:21 -06:00
2012-02-03 10:41:06 -06:00
2012-01-21 05:17:01 +01:00
2011-11-28 11:36:28 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-22 07:27:06 +00:00
2012-02-15 09:39:21 -06:00
2011-12-20 15:44:30 -06:00
2011-10-04 11:02:57 -03:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-01-13 10:55:56 -06:00
2011-09-09 13:13:16 +00:00
2011-07-17 01:54:25 +02:00
2011-09-09 13:13:16 +00:00
2011-08-20 23:01:08 -05:00
2012-01-13 10:55:56 -06:00
2012-01-13 10:55:56 -06:00
2012-02-15 09:39:21 -06:00
2011-12-20 14:14:08 +02:00
2011-09-09 13:13:16 +00:00
2012-02-15 09:39:21 -06:00
2011-10-06 09:48:02 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-08-22 23:29:37 +02:00
2012-02-15 09:39:21 -06:00
2012-02-15 09:39:21 -06:00
2011-11-02 05:05:52 +04:00
2012-01-04 13:34:48 +02:00
2011-10-16 11:11:55 +00:00
2012-01-04 13:34:48 +02:00
2012-02-03 10:41:06 -06:00
2012-02-15 09:39:21 -06:00