[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [for-5.0 PATCH v2 4/4] spapr/xive: Configure number of servers in KV
From: |
Cédric Le Goater |
Subject: |
Re: [for-5.0 PATCH v2 4/4] spapr/xive: Configure number of servers in KVM |
Date: |
Tue, 26 Nov 2019 18:02:13 +0100 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.1.1 |
On 26/11/2019 17:46, Greg Kurz wrote:
> The XIVE KVM devices now has an attribute to configure the number of
> interrupt servers. This allows to greatly optimize the usage of the VP
> space in the XIVE HW, and thus to start a lot more VMs.
>
> Only set this attribute if available in order to support older POWER9
> KVM.
>
> The XIVE KVM device now reports the exhaustion of VPs upon the
> connection of the first VCPU. Check that in order to have a chance
> to provide a hint to the user.
>
> Signed-off-by: Greg Kurz <address@hidden>
Reviewed-by: Cédric Le Goater <address@hidden>
> ---
> hw/intc/spapr_xive_kvm.c | 23 +++++++++++++++++++++--
> 1 file changed, 21 insertions(+), 2 deletions(-)
>
> diff --git a/hw/intc/spapr_xive_kvm.c b/hw/intc/spapr_xive_kvm.c
> index 46c7609bd8d0..32b2809210a0 100644
> --- a/hw/intc/spapr_xive_kvm.c
> +++ b/hw/intc/spapr_xive_kvm.c
> @@ -152,7 +152,8 @@ void kvmppc_xive_cpu_synchronize_state(XiveTCTX *tctx,
> Error **errp)
>
> void kvmppc_xive_cpu_connect(XiveTCTX *tctx, Error **errp)
> {
> - SpaprXive *xive = SPAPR_MACHINE(qdev_get_machine())->xive;
> + MachineState *ms = MACHINE(qdev_get_machine());
> + SpaprXive *xive = SPAPR_MACHINE(ms)->xive;
> unsigned long vcpu_id;
> int ret;
>
> @@ -171,8 +172,16 @@ void kvmppc_xive_cpu_connect(XiveTCTX *tctx, Error
> **errp)
> ret = kvm_vcpu_enable_cap(tctx->cs, KVM_CAP_PPC_IRQ_XIVE, 0, xive->fd,
> vcpu_id, 0);
> if (ret < 0) {
> - error_setg(errp, "XIVE: unable to connect CPU%ld to KVM device: %s",
> + Error *local_err = NULL;
> +
> + error_setg(&local_err,
> + "XIVE: unable to connect CPU%ld to KVM device: %s",
> vcpu_id, strerror(errno));
> + if (errno == ENOSPC) {
> + error_append_hint(&local_err, "Try -smp maxcpus=N with N < %u\n",
> + ms->smp.max_cpus);
> + }
> + error_propagate(errp, local_err);
> return;
> }
>
> @@ -758,6 +767,16 @@ int kvmppc_xive_connect(SpaprInterruptController *intc,
> uint32_t nr_servers,
> return -1;
> }
>
> + /* Tell KVM about the # of VCPUs we may have */
> + if (kvm_device_check_attr(xive->fd, KVM_DEV_XIVE_GRP_CTRL,
> + KVM_DEV_XIVE_NR_SERVERS)) {
> + if (kvm_device_access(xive->fd, KVM_DEV_XIVE_GRP_CTRL,
> + KVM_DEV_XIVE_NR_SERVERS, &nr_servers, true,
> + &local_err)) {
> + goto fail;
> + }
> + }
> +
> /*
> * 1. Source ESB pages - KVM mapping
> */
>
- [for-5.0 PATCH v2 0/4] spapr: Use less XIVE HW resources in KVM, Greg Kurz, 2019/11/26
- [for-5.0 PATCH v2 1/4] linux-headers: Update, Greg Kurz, 2019/11/26
- [for-5.0 PATCH v2 2/4] spapr: Pass the maximum number of vCPUs to the KVM interrupt controller, Greg Kurz, 2019/11/26
- [for-5.0 PATCH v2 3/4] spapr/xics: Configure number of servers in KVM, Greg Kurz, 2019/11/26
- [for-5.0 PATCH v2 4/4] spapr/xive: Configure number of servers in KVM, Greg Kurz, 2019/11/26
- Re: [for-5.0 PATCH v2 4/4] spapr/xive: Configure number of servers in KVM,
Cédric Le Goater <=
- Re: [for-5.0 PATCH v2 0/4] spapr: Use less XIVE HW resources in KVM, David Gibson, 2019/11/27