From patchwork Wed Apr 21 15:08:30 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kenta Ishiguro X-Patchwork-Id: 12216355 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id DD8AEC43461 for ; Wed, 21 Apr 2021 15:10:19 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id A6CCC61426 for ; Wed, 21 Apr 2021 15:10:19 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243856AbhDUPKs (ORCPT ); Wed, 21 Apr 2021 11:10:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38254 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243869AbhDUPJQ (ORCPT ); Wed, 21 Apr 2021 11:09:16 -0400 Received: from mail-pl1-x62b.google.com (mail-pl1-x62b.google.com [IPv6:2607:f8b0:4864:20::62b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CC5AFC06174A for ; Wed, 21 Apr 2021 08:08:43 -0700 (PDT) Received: by mail-pl1-x62b.google.com with SMTP id y1so6160396plg.11 for ; Wed, 21 Apr 2021 08:08:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sslab.ics.keio.ac.jp; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Po+qU5dt1Yy0qa7l0uLxYfVEa6vaR5MZXziHwyuHotE=; b=PjBH4jQpqFomkLLvOghdtR74zlVVWCzB2L0YShXJND9ZnlX8hieIAcB+2yTU3uQivD kQLlukUypPVt0QqJcSXSvMMHHLPjc96l/C18P0yw6q2L4jgDBdDDpMzmEzGxYtVNniTr /6Npjz1b5YyeGLTBqOVPNxLtW2VoUWjEHE0I0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Po+qU5dt1Yy0qa7l0uLxYfVEa6vaR5MZXziHwyuHotE=; b=fAFdzg1jL/VojmYQldHvyea0IH/DG8WPGHvruyKkepsBQE4Ixd3Y38XjCnMSRNd0XH nDtE6enJEmL3wCjD6umcqaVzkmP8nGmi+BT63S3KKZCCg0ZxL96IJtnQiLzJjHto0QXL yP7x78jn3PCVBqBBgISCv6V9EFUWf2L4eyrbkElgMTGY2/t8xtdrAOgi5jelC7352U9g 8i1Px4ErPntl+Ayx25NY6jdyCkbQmPggZQ5VEhH4Bbfz1M7U5t/fUvyp79OIWQ7Q9QsK pkl2FQyc4CFtnPo4Z0+NvJq8YxpAbU/x35E/jVjJwwB/VO5hXTu2X7IfzSPV5DjbK4m2 LxUw== X-Gm-Message-State: AOAM532/Q7az98rAHZXrh5hlcwtfKPpIKEkGA4voC9Kc/wNuPQD0Uwy9 zzCFzn22IitGNmFMQGmtUyj2qA== X-Google-Smtp-Source: ABdhPJxO2nklRU+cnCq7i+1CU3Nv+qx5VABYKq49QlAFdEnVK8MK/+u8WDfFC8K14cmZdzkD5yGiLQ== X-Received: by 2002:a17:902:9685:b029:e9:abc1:7226 with SMTP id n5-20020a1709029685b02900e9abc17226mr34832987plp.64.1619017723394; Wed, 21 Apr 2021 08:08:43 -0700 (PDT) Received: from haraichi.dnlocal (113x36x239x145.ap113.ftth.ucom.ne.jp. [113.36.239.145]) by smtp.googlemail.com with ESMTPSA id f3sm5432553pjo.3.2021.04.21.08.08.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 21 Apr 2021 08:08:42 -0700 (PDT) From: Kenta Ishiguro To: Paolo Bonzini Cc: Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , David Hildenbrand , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, pl@sslab.ics.keio.ac.jp, kono@sslab.ics.keio.ac.jp, Kenta Ishiguro Subject: [RFC PATCH 1/2] Prevent CFS from ignoring boost requests from KVM Date: Thu, 22 Apr 2021 00:08:30 +0900 Message-Id: <20210421150831.60133-2-kentaishiguro@sslab.ics.keio.ac.jp> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210421150831.60133-1-kentaishiguro@sslab.ics.keio.ac.jp> References: <20210421150831.60133-1-kentaishiguro@sslab.ics.keio.ac.jp> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org This commit increases the vruntime of yielded vCPU to boost a vCPU instead of the yielded vCPU when two vCPUs are in the same VM. This change avoids the situation where scheduling the boosted vCPU is too unfair. Cc: David Hildenbrand Signed-off-by: Kenta Ishiguro --- kernel/sched/fair.c | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index 794c2cb945f8..2908da3f4c77 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -7204,9 +7204,36 @@ static void yield_task_fair(struct rq *rq) set_skip_buddy(se); } +static void deboost_yield_task_vruntime(struct sched_entity *next_se, struct sched_entity *yield_se) +{ + if (wakeup_preempt_entity(next_se, yield_se) < 1) + return; + yield_se->vruntime = next_se->vruntime - wakeup_gran(yield_se); +} + +static void deboost_yield_task(struct sched_entity *next_se, struct sched_entity *yield_se) +{ + struct sched_entity *next_se_base = next_se; + + if (rq_of(cfs_rq_of(yield_se)) != rq_of(cfs_rq_of(next_se))) + return; + + for_each_sched_entity(yield_se) { + next_se = next_se_base; + for_each_sched_entity(next_se) { + if (cfs_rq_of(yield_se) == cfs_rq_of(next_se)) { + deboost_yield_task_vruntime(next_se, yield_se); + return; + } + } + } +} + static bool yield_to_task_fair(struct rq *rq, struct task_struct *p) { struct sched_entity *se = &p->se; + struct task_struct *curr; + struct sched_entity *yield_se; /* throttled hierarchies are not runnable */ if (!se->on_rq || throttled_hierarchy(cfs_rq_of(se))) @@ -7215,6 +7242,10 @@ static bool yield_to_task_fair(struct rq *rq, struct task_struct *p) /* Tell the scheduler that we'd really like pse to run next. */ set_next_buddy(se); + curr = rq->curr; + yield_se = &curr->se; + deboost_yield_task(se, yield_se); + yield_task_fair(rq); return true; From patchwork Wed Apr 21 15:08:31 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kenta Ishiguro X-Patchwork-Id: 12216357 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 9CFC1C433ED for ; Wed, 21 Apr 2021 15:10:21 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 7179C61457 for ; Wed, 21 Apr 2021 15:10:21 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243861AbhDUPKw (ORCPT ); Wed, 21 Apr 2021 11:10:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38272 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243972AbhDUPJW (ORCPT ); Wed, 21 Apr 2021 11:09:22 -0400 Received: from mail-pg1-x536.google.com (mail-pg1-x536.google.com [IPv6:2607:f8b0:4864:20::536]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9B1F8C06174A for ; Wed, 21 Apr 2021 08:08:47 -0700 (PDT) Received: by mail-pg1-x536.google.com with SMTP id t22so30165374pgu.0 for ; Wed, 21 Apr 2021 08:08:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sslab.ics.keio.ac.jp; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=af+kuX5IM9/ZKYVjVnI7LjXEfOZ4xyP6ZjkXRID/xIA=; b=SvXM4Lb0TVCmO/z6VC48S00IVLOXPoYoaCKvGS7g9jhmB8/9IsUhriuHSRj0x/NtAe +pkF+/OCSJaTEvGkvlF7AzREkFqINzx365lUQEXCK9gQ5Iv+81GafrOGQFAf4b0FdA0v yhGMpvEIfgom6cAdCfDEbTzwcnciNV6lT4ado= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=af+kuX5IM9/ZKYVjVnI7LjXEfOZ4xyP6ZjkXRID/xIA=; b=QqUE1HPhWllQnLzieemNQhdoPNe8iLyEK4ue2JSNSseI9f86a+OpE7SdpAknUfnJ3P jpC5l5ZdImqZtgGZNyX+wmqA6z9oUnL1kyfhCzE2MF5NruV4i8mjtMjXlN4lXO5prkWF WMefiA2J8cSggjXYDJtWZyi0SQBFaGDUdxCG4RWwbcP73cV/TckOQAcRKOzO0lE5vhhd qeiBXKnWxDKty0fwSgmpmt3OYAwocTAvff5eYRQTzCnMVIVCTveaxUvSGhOm03Cl1mbU UD9F7FQWAOhU4+QGc/O22mbVf8zqKgOs0zq1Fmw9AyUyk1UK4a6n+K1zYBbmY+SsBIPr bK1Q== X-Gm-Message-State: AOAM5324RBIIdb94XUzonS3nZ75k01pOthsVL9KnMfY7ooOPlgIf1e5k NWrGB1w2Vgs2sXU6O9Rd96tgbQ== X-Google-Smtp-Source: ABdhPJwGgVGZL8yWSsfnrmEEVfVeiBPBSiLz/US1pP2NhReKJ4SUxGmkcSXZXpCx1z87zyFacFsmkQ== X-Received: by 2002:a63:5a55:: with SMTP id k21mr21989045pgm.312.1619017727203; Wed, 21 Apr 2021 08:08:47 -0700 (PDT) Received: from haraichi.dnlocal (113x36x239x145.ap113.ftth.ucom.ne.jp. [113.36.239.145]) by smtp.googlemail.com with ESMTPSA id f3sm5432553pjo.3.2021.04.21.08.08.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 21 Apr 2021 08:08:46 -0700 (PDT) From: Kenta Ishiguro To: Paolo Bonzini Cc: Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , David Hildenbrand , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, pl@sslab.ics.keio.ac.jp, kono@sslab.ics.keio.ac.jp, Kenta Ishiguro Subject: [RFC PATCH 2/2] Boost vCPUs based on IPI-sender and receiver information Date: Thu, 22 Apr 2021 00:08:31 +0900 Message-Id: <20210421150831.60133-3-kentaishiguro@sslab.ics.keio.ac.jp> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210421150831.60133-1-kentaishiguro@sslab.ics.keio.ac.jp> References: <20210421150831.60133-1-kentaishiguro@sslab.ics.keio.ac.jp> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org This commit monitors IPI communication between vCPUs and leverages the relationship between vCPUs to select boost candidates. Cc: David Hildenbrand Signed-off-by: Kenta Ishiguro --- arch/x86/kvm/lapic.c | 14 ++++++++++++++ arch/x86/kvm/vmx/vmx.c | 2 ++ include/linux/kvm_host.h | 5 +++++ virt/kvm/kvm_main.c | 26 ++++++++++++++++++++++++-- 4 files changed, 45 insertions(+), 2 deletions(-) diff --git a/arch/x86/kvm/lapic.c b/arch/x86/kvm/lapic.c index cc369b9ad8f1..c8d967ddecf9 100644 --- a/arch/x86/kvm/lapic.c +++ b/arch/x86/kvm/lapic.c @@ -1269,6 +1269,18 @@ void kvm_apic_set_eoi_accelerated(struct kvm_vcpu *vcpu, int vector) } EXPORT_SYMBOL_GPL(kvm_apic_set_eoi_accelerated); +static void mark_ipi_receiver(struct kvm_lapic *apic, struct kvm_lapic_irq *irq) +{ + struct kvm_vcpu *dest_vcpu; + u64 prev_ipi_received; + + dest_vcpu = kvm_get_vcpu_by_id(apic->vcpu->kvm, irq->dest_id); + if (READ_ONCE(dest_vcpu->sched_outed)) { + prev_ipi_received = READ_ONCE(dest_vcpu->ipi_received); + WRITE_ONCE(dest_vcpu->ipi_received, prev_ipi_received | (1 << apic->vcpu->vcpu_id)); + } +} + void kvm_apic_send_ipi(struct kvm_lapic *apic, u32 icr_low, u32 icr_high) { struct kvm_lapic_irq irq; @@ -1287,6 +1299,8 @@ void kvm_apic_send_ipi(struct kvm_lapic *apic, u32 icr_low, u32 icr_high) trace_kvm_apic_ipi(icr_low, irq.dest_id); + mark_ipi_receiver(apic, &irq); + kvm_irq_delivery_to_apic(apic->vcpu->kvm, apic, &irq, NULL); } diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index 29b40e092d13..ced50935a38b 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -6718,6 +6718,8 @@ static fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu) vmcs_write32(PLE_WINDOW, vmx->ple_window); } + WRITE_ONCE(vcpu->ipi_received, 0); + /* * We did this in prepare_switch_to_guest, because it needs to * be within srcu_read_lock. diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 1b65e7204344..6726aeec03e7 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h @@ -320,6 +320,11 @@ struct kvm_vcpu { #endif bool preempted; bool ready; + bool sched_outed; + /* + * The current implementation of strict boost supports up to 64 vCPUs + */ + u64 ipi_received; struct kvm_vcpu_arch arch; struct kvm_dirty_ring dirty_ring; }; diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 383df23514b9..08e629957e7e 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c @@ -413,6 +413,10 @@ static void kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id) kvm_vcpu_set_dy_eligible(vcpu, false); vcpu->preempted = false; vcpu->ready = false; + + vcpu->sched_outed = false; + vcpu->ipi_received = 0; + preempt_notifier_init(&vcpu->preempt_notifier, &kvm_preempt_ops); } @@ -3011,6 +3015,7 @@ void kvm_vcpu_on_spin(struct kvm_vcpu *me, bool yield_to_kernel_mode) int try = 3; int pass; int i; + u64 prev_ipi_received; kvm_vcpu_set_in_spin_loop(me, true); /* @@ -3031,12 +3036,25 @@ void kvm_vcpu_on_spin(struct kvm_vcpu *me, bool yield_to_kernel_mode) continue; if (vcpu == me) continue; + prev_ipi_received = READ_ONCE(vcpu->ipi_received); + if (!READ_ONCE(vcpu->preempted) && + !(prev_ipi_received & (1 << me->vcpu_id))) { + WRITE_ONCE(vcpu->ipi_received, + prev_ipi_received | (1 << me->vcpu_id)); + continue; + } if (rcuwait_active(&vcpu->wait) && !vcpu_dy_runnable(vcpu)) continue; if (READ_ONCE(vcpu->preempted) && yield_to_kernel_mode && - !kvm_arch_vcpu_in_kernel(vcpu)) - continue; + !kvm_arch_vcpu_in_kernel(vcpu)) { + prev_ipi_received = READ_ONCE(vcpu->ipi_received); + if (!(prev_ipi_received & (1 << me->vcpu_id))) { + WRITE_ONCE(vcpu->ipi_received, + prev_ipi_received | (1 << me->vcpu_id)); + continue; + } + } if (!kvm_vcpu_eligible_for_directed_yield(vcpu)) continue; @@ -4859,6 +4877,9 @@ static void kvm_sched_in(struct preempt_notifier *pn, int cpu) WRITE_ONCE(vcpu->preempted, false); WRITE_ONCE(vcpu->ready, false); + WRITE_ONCE(vcpu->sched_outed, false); + WRITE_ONCE(vcpu->ipi_received, 0); + __this_cpu_write(kvm_running_vcpu, vcpu); kvm_arch_sched_in(vcpu, cpu); kvm_arch_vcpu_load(vcpu, cpu); @@ -4873,6 +4894,7 @@ static void kvm_sched_out(struct preempt_notifier *pn, WRITE_ONCE(vcpu->preempted, true); WRITE_ONCE(vcpu->ready, true); } + WRITE_ONCE(vcpu->sched_outed, true); kvm_arch_vcpu_put(vcpu); __this_cpu_write(kvm_running_vcpu, NULL); }