diff options
author | David Woodhouse <dwmw2@infradead.org> | 2022-03-14 14:25:41 +0000 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2022-05-16 04:38:39 -0400 |
commit | dc89f32d92bba795b0665f075b78d8881cf67ab3 (patch) | |
tree | 345f7ba9454b2d8f697a2b14b86a7ff74d24a3be /hw/i386/pc.c | |
parent | 5181db132b587754dda3a520eec923b87a65bbb7 (diff) | |
download | qemu-dc89f32d92bba795b0665f075b78d8881cf67ab3.zip qemu-dc89f32d92bba795b0665f075b78d8881cf67ab3.tar.gz qemu-dc89f32d92bba795b0665f075b78d8881cf67ab3.tar.bz2 |
target/i386: Fix sanity check on max APIC ID / X2APIC enablement
The check on x86ms->apic_id_limit in pc_machine_done() had two problems.
Firstly, we need KVM to support the X2APIC API in order to allow IRQ
delivery to APICs >= 255. So we need to call/check kvm_enable_x2apic(),
which was done elsewhere in *some* cases but not all.
Secondly, microvm needs the same check. So move it from pc_machine_done()
to x86_cpus_init() where it will work for both.
The check in kvm_cpu_instance_init() is now redundant and can be dropped.
Signed-off-by: David Woodhouse <dwmw2@infradead.org>
Acked-by: Claudio Fontana <cfontana@suse.de>
Message-Id: <20220314142544.150555-1-dwmw2@infradead.org>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'hw/i386/pc.c')
-rw-r--r-- | hw/i386/pc.c | 8 |
1 files changed, 0 insertions, 8 deletions
diff --git a/hw/i386/pc.c b/hw/i386/pc.c index 312eb9e..15f37d8 100644 --- a/hw/i386/pc.c +++ b/hw/i386/pc.c @@ -744,14 +744,6 @@ void pc_machine_done(Notifier *notifier, void *data) /* update FW_CFG_NB_CPUS to account for -device added CPUs */ fw_cfg_modify_i16(x86ms->fw_cfg, FW_CFG_NB_CPUS, x86ms->boot_cpus); } - - - if (x86ms->apic_id_limit > 255 && !xen_enabled() && - !kvm_irqchip_in_kernel()) { - error_report("current -smp configuration requires kernel " - "irqchip support."); - exit(EXIT_FAILURE); - } } void pc_guest_info_init(PCMachineState *pcms) |