Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp130535yba; Tue, 14 May 2019 21:12:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqxG+DGC8qqEsHuo5dvaep/RiLq2EDIN8uL3UfLiLrU+KtxXz3oCs22DW+SVa9fnllrueRgS X-Received: by 2002:a63:8449:: with SMTP id k70mr41307729pgd.53.1557893577451; Tue, 14 May 2019 21:12:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557893577; cv=none; d=google.com; s=arc-20160816; b=O3skIEO2Z+hEWwse7ZaIaUPuToe4DWv8m2Wl2g6qwilcVBgWw20OxQc5dlq3zv8XEK 0aWZNLotyOwAorwM+dZjuu1KctTW0jG1bsUUv6IOHDXLQxIjMAiHZEe6SjXlzzVUGs0p VrdwwVZQJcY/f2wivtOj+K7FY+Lab0qdjl5T9y2vNs6u7dGY6wgzBMvGBU17EZlA9gRB HXldZm35IPPyco7CMQvNrLwe2jE5dBIN2SxHEnqZpMpaOdqFaXCM9uo90snHan1dF/HM 53FEjnU72dslZmUiE+pTs1zXkcdef3qUNW4dkmkxZgXmpX6s2iXR6+x2FI9LFWBOwXgD r9uA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=p98OlGu9SV+BFYem5XMwnXe15at0yFGCsMrG4alRIQ4=; b=XE/L2dLqiTyWfR1EyV4vGRiK26iqYwnZ6H6vFvWWYsrz2ifQN+zNE/YXVGyktTQzF6 +LS7dmP7+g3u0tymKD+AjBTK7HL8EFDW4QLL9iZHeCD4ean6e7ZMe5m4HZll76WjFyar 9eZuC0mJdvsUJ1z33IG8PVJy5e5qadLGK/sr8YOCNuR2yU20PkYAU6YBTbeXW3JpNdsl HGg/TFlJ52yaD6zpMLdae3yRSbcQm144T9cYK0G30E5AZg7qtdCjDnksiR+y1vVFpxGU mySozQwDMrGHLVNQqpSOP0yDPGzHaUYZt/9BdSt31qwcGP3njS8zVaOJk4QDsaQzcfia ofyA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pIx3SabZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t1si747370pgh.406.2019.05.14.21.12.42; Tue, 14 May 2019 21:12:57 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pIx3SabZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726653AbfEOELh (ORCPT + 99 others); Wed, 15 May 2019 00:11:37 -0400 Received: from mail-pf1-f195.google.com ([209.85.210.195]:34615 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725876AbfEOELg (ORCPT ); Wed, 15 May 2019 00:11:36 -0400 Received: by mail-pf1-f195.google.com with SMTP id n19so653900pfa.1; Tue, 14 May 2019 21:11:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=p98OlGu9SV+BFYem5XMwnXe15at0yFGCsMrG4alRIQ4=; b=pIx3SabZFC0lSb9tUT09jqGksi9P3BLToB76wJHDVOisRhsqmEV/xiMeHyns3sFVCE XBYXFz/ZylP7at2Pa9TH8ZQsR/swbRfyFrlaEgFDSuQ2Y0gDs5BQw/Rpgx2t9Pp92el3 8Dnc1QURoR5TWf0cV6su6+loENMwgf1iznkIlQZb168kWKraLSTFz4ael8IruXQaBjnv 1xFR+O4/2ygV2mqQvD6/BjQkidtyfgvoWTWv7LneCSZ3xiDo7pRcBuU+SQGBZ7Tid1vq 7jHJEOophbHiKdCXA85NjmRionhnef0D5IzDmGw5XpFWTQj3MTxZaXZ5f/pugQE+WRbI KyQA== 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; bh=p98OlGu9SV+BFYem5XMwnXe15at0yFGCsMrG4alRIQ4=; b=jyvcV7U2ekc8I8CEs2QYDzQTGQiJsKAJvCux/GImXCPZEkJZSHmEnuulIRcfJmYoZ0 IVaW3/ITvvzH1lovIh564eRnNPZ/1xcTuWfNv9HapplcRdMKtlsRhfZ6RpjOaQZzdHQY Y8ZYKesw+U+Rml6oo30ZIfGgpV2Q8nI/S7ZrR3tim9YLlMkXMw41LdZuxakqM2NFp6O3 Q4XHUIl/oLaIOJYut1M+TjbjZ5AwXbYAgHuF6/M0C4Q55nbgDsyT3Hm2KyFI+XiRy8EJ X7eSr/rLWGTlH9p6R5gzitszguPCUsL8VoPdMPL7IWiDaIN9svFNV5CTzzwCeaghyHcA H4GA== X-Gm-Message-State: APjAAAXCNyqJCo4jgCAeDHpC/jds9pckKaQXpdb2aMuMe2yopnLznu1k JkYVUD4pozJ7FDLeVjKJnZVkfZ7U X-Received: by 2002:a62:7513:: with SMTP id q19mr44835622pfc.108.1557893495865; Tue, 14 May 2019 21:11:35 -0700 (PDT) Received: from localhost.localdomain ([203.205.141.123]) by smtp.googlemail.com with ESMTPSA id i12sm808026pfd.33.2019.05.14.21.11.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 14 May 2019 21:11:35 -0700 (PDT) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , =?UTF-8?q?Radim=20Kr=C4=8Dm=C3=A1=C5=99?= Subject: [PATCH v2 0/4] KVM: LAPIC: Optimize timer latency further Date: Wed, 15 May 2019 12:11:30 +0800 Message-Id: <1557893490-5715-1-git-send-email-wanpengli@tencent.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Advance lapic timer tries to hidden the hypervisor overhead between the host emulated timer fires and the guest awares the timer is fired. However, it just hidden the time between apic_timer_fn/handle_preemption_timer -> wait_lapic_expire, instead of the real position of vmentry which is mentioned in the orignial commit d0659d946be0 ("KVM: x86: add option to advance tscdeadline hrtimer expiration"). There is 700+ cpu cycles between the end of wait_lapic_expire and before world switch on my haswell desktop, it will be 2400+ cycles if vmentry_l1d_flush is tuned to always. This patchset tries to narrow the last gap(wait_lapic_expire -> world switch), it takes the real overhead time between apic_timer_fn/handle_preemption_timer and before world switch into consideration when adaptively tuning timer advancement. The patchset can reduce 40% latency (~1600+ cycles to ~1000+ cycles on a haswell desktop) for kvm-unit-tests/tscdeadline_latency when testing busy waits. v1 -> v2: * fix indent in patch 1/4 * remove the wait_lapic_expire() tracepoint and expose by debugfs * move the call to wait_lapic_expire() into vmx.c and svm.c Wanpeng Li (4): KVM: LAPIC: Extract adaptive tune timer advancement logic KVM: LAPIC: Fix lapic_timer_advance_ns parameter overflow KVM: LAPIC: Expose per-vCPU timer adavance information to userspace KVM: LAPIC: Optimize timer latency further arch/x86/kvm/debugfs.c | 16 +++++++++++++ arch/x86/kvm/lapic.c | 62 +++++++++++++++++++++++++++++--------------------- arch/x86/kvm/lapic.h | 3 ++- arch/x86/kvm/svm.c | 4 ++++ arch/x86/kvm/trace.h | 20 ---------------- arch/x86/kvm/vmx/vmx.c | 4 ++++ arch/x86/kvm/x86.c | 5 +--- 7 files changed, 63 insertions(+), 51 deletions(-) -- 2.7.4