qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: "Philippe Mathieu-Daudé" <philmd@linaro.org>
To: Paolo Bonzini <pbonzini@redhat.com>, qemu-devel@nongnu.org
Subject: Re: [PATCH] KVM: remove support for kernel-irqchip=off
Date: Sun, 18 Dec 2022 14:38:44 +0100	[thread overview]
Message-ID: <d7b6874d-a825-f2d3-5cf2-1817d288138d@linaro.org> (raw)
In-Reply-To: <20221218000649.686882-2-pbonzini@redhat.com>

On 18/12/22 01:06, Paolo Bonzini wrote:
> -machine kernel-irqchip=off is broken for many guest OSes; kernel-irqchip=split
> is the replacement that works, so remove the deprecated support for the former.
> 
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
> ---
>   docs/about/deprecated.rst       |  7 -------
>   docs/about/removed-features.rst |  7 +++++++
>   hw/i386/amd_iommu.c             |  2 +-
>   hw/i386/intel_iommu.c           |  4 ++--
>   include/hw/i386/apic_internal.h |  2 +-
>   target/i386/cpu-sysemu.c        | 15 +++++++++++----
>   6 files changed, 22 insertions(+), 15 deletions(-)


> diff --git a/hw/i386/amd_iommu.c b/hw/i386/amd_iommu.c
> index 725f69095b9e..bcd016f5c5a5 100644
> --- a/hw/i386/amd_iommu.c
> +++ b/hw/i386/amd_iommu.c
> @@ -1368,7 +1368,7 @@ static MemTxResult amdvi_mem_ir_write(void *opaque, hwaddr addr,
>           return MEMTX_ERROR;
>       }
>   
> -    apic_get_class()->send_msi(&to);
> +    apic_get_class(NULL)->send_msi(&to);

&error_fatal?

> diff --git a/hw/i386/intel_iommu.c b/hw/i386/intel_iommu.c
> index a08ee85edf2a..98a5c304a7d7 100644
> --- a/hw/i386/intel_iommu.c
> +++ b/hw/i386/intel_iommu.c
> @@ -396,7 +396,7 @@ static void vtd_generate_interrupt(IntelIOMMUState *s, hwaddr mesg_addr_reg,
>   
>       trace_vtd_irq_generate(msi.address, msi.data);
>   
> -    apic_get_class()->send_msi(&msi);
> +    apic_get_class(NULL)->send_msi(&msi);
>   }
>   
>   /* Generate a fault event to software via MSI if conditions are met.
> @@ -3529,7 +3529,7 @@ static MemTxResult vtd_mem_ir_write(void *opaque, hwaddr addr,
>           return MEMTX_ERROR;
>       }
>   
> -    apic_get_class()->send_msi(&to);
> +    apic_get_class(NULL)->send_msi(&to);
>   
>       return MEMTX_OK;
>   }

>   #endif /* QEMU_APIC_INTERNAL_H */
> diff --git a/target/i386/cpu-sysemu.c b/target/i386/cpu-sysemu.c
> index fc97213a73cf..28115edf44f7 100644
> --- a/target/i386/cpu-sysemu.c
> +++ b/target/i386/cpu-sysemu.c
> @@ -247,12 +247,16 @@ void x86_cpu_machine_reset_cb(void *opaque)
>       cpu_reset(CPU(cpu));
>   }
>   
> -APICCommonClass *apic_get_class(void)
> +APICCommonClass *apic_get_class(Error **errp)
>   {
>       const char *apic_type = "apic";
>   
>       /* TODO: in-kernel irqchip for hvf */
> -    if (kvm_apic_in_kernel()) {
> +    if (kvm_enabled()) {
> +        if (!kvm_apic_in_kernel()) {
> +            error_setg(errp, "KVM does not support userspace APIC");
> +            return NULL;
> +        }



  reply	other threads:[~2022-12-18 13:39 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-12-18  0:06 [PATCH] KVM: remove support for kernel-irqchip=off Paolo Bonzini
2022-12-18 13:38 ` Philippe Mathieu-Daudé [this message]
2022-12-18 13:39   ` Philippe Mathieu-Daudé

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=d7b6874d-a825-f2d3-5cf2-1817d288138d@linaro.org \
    --to=philmd@linaro.org \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).