Received: by 10.223.164.202 with SMTP id h10csp187433wrb; Mon, 13 Nov 2017 23:03:52 -0800 (PST) X-Google-Smtp-Source: AGs4zMay0GywLJg1U6ElPoBz3sevOCdhLoGtgBdZ5VpicFcUGdBmdLWKJ0PUa7q5A8SgzDKtB6HO X-Received: by 10.99.182.66 with SMTP id v2mr11467690pgt.325.1510643032389; Mon, 13 Nov 2017 23:03:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510643032; cv=none; d=google.com; s=arc-20160816; b=zIkz/Cn0ngZhRMPV//E7NHQKh9ajVlwSmhj1rhrkC+CFahd5XOMzR/O/1yucGzg9A9 oaOpp5/xrotqXWZDrOH/adett2AsLLYhehtpUW6IZ8T406QtvcrZrr6poPH6lUFGxIp3 laFXSVHdMcyWoIKDh0I9A3aLuAKufQHoYKFg1qcm1U5wYVNg98zZPyGSk6KpBmaXQx4a /0VyV/Zf6CyTyrLZM08MoIjHPaISw+0IrJMWzvGc+7VAKlWpf/zxNLL8K/y+S3FiPoMa XxGUbBRZ1DeYylAAnRW6SuIUpqhDZbPEMzy+47TAwp/TigFEuZKJMzZ6yAPe6QqHXkLr KDdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=5jX5gdhlP0ZDOz5Bq1fgLGCpCNsEFwyjtZSm2TgqGEM=; b=Q6YU9rtLFVZzrDvqNvVINe3C+fXxUpRxu2GaI6lnzw0F+QSOk3od5oBeWVaTNvOfrW WcMluS3JDC5riFHIFZsZzWCEMMVi5JKKW/sTDfvbzIoriVk8gust9uXBqOb+vDsfJruE +uMT7zXTrySDLBBzb1SJvlfDrQ8r3mF3UK9bvFcVWQ6fZcKkI6MbSSwwa22cnbqnhcga n70jbGqV+Ha9aRr6GvvIjdoPKrnzj7uJR9K+r8iEb4PRJmQk1drYHiEW091deadvjsqp o5FiGhC/4Y+b54ahk2PFExDZgMgjEs+tJgQ8CqN0ETr9gRi/SkdmgSG1mw4wkq4Bd7NW 9JnA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FuIYyyTq; 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=NONE 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 r63si15940859plb.638.2017.11.13.23.03.40; Mon, 13 Nov 2017 23:03:52 -0800 (PST) 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=FuIYyyTq; 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=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753159AbdKNHC7 (ORCPT + 89 others); Tue, 14 Nov 2017 02:02:59 -0500 Received: from mail-ot0-f194.google.com ([74.125.82.194]:45498 "EHLO mail-ot0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752233AbdKNHCx (ORCPT ); Tue, 14 Nov 2017 02:02:53 -0500 Received: by mail-ot0-f194.google.com with SMTP id b17so3732304oth.2; Mon, 13 Nov 2017 23:02:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=5jX5gdhlP0ZDOz5Bq1fgLGCpCNsEFwyjtZSm2TgqGEM=; b=FuIYyyTqaszVcnG4WXEUo719PEfRe3hxQI1onDL7WOxTJ67iwo8ACe3jgEgpvhu7gv PdtGa/6HAvAkGcJ7UcbI6Goqo7AvlGgq15h0mmG3WtUEY+zcxbIRe/+92ZJV4opM1XUD okiU0gC8JdroKkNAQ9mRbydEHZNbnk4jgqRv/XBAK/cEG1vrJqe3if5QltQYXCSXIvHt A0mmsPLuyR31bHObcTfQhHJ/dsLtmBS20YZA1ciV4strgBl4fUGqPrctE+SDhbj2laq5 pe2CyJa7/QSKNZmbjpcLdSxAUiGGCaGsCSlo4u+3c5mbJot4GXsfyfeKM3q8j+GrLRnU 6v7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=5jX5gdhlP0ZDOz5Bq1fgLGCpCNsEFwyjtZSm2TgqGEM=; b=q9ajDnD+SnmSRETN0zgttTx/tmlCaIua+L6LGY3SCcLNz2GjNuUaQ9RvSvbaEsau1T 5+lOsNQlJerrSmM9p6NygNQBoCDLH8OrpTBWNWI1OOWXOWEoiERL6dRzsKfG6xHvoONS 4I6QLAsGAuLnHgXdRtz7u41q9LWtfFq2xXpilkFMRsneRg1zqpSeVLD/ndUIn0Qbrv+a JvkeWn6du6j1LWHxVDoKLhSkak4+hZenM0jAen7j7JCWT/+V/62GiaKLXBn8n1ThFcDP DHvR4EcApqlJgNruTK/UxBiTFdE36ITwVv8BlnfSg2MHeMkNkt3TctZT5t/x3oxcM0Ri FB0w== X-Gm-Message-State: AJaThX6V30fRRhnwMCzwXRcThTarMushj/BJgobOrdPq0B357uU4Tmgb 8Qc1VNSiKsctzy6OZkGepPE= X-Received: by 10.157.47.137 with SMTP id r9mr6800341otb.108.1510642972699; Mon, 13 Nov 2017 23:02:52 -0800 (PST) Received: from [0.0.0.0] ([47.89.242.186]) by smtp.gmail.com with ESMTPSA id l130sm8027931oia.29.2017.11.13.23.02.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 13 Nov 2017 23:02:52 -0800 (PST) Subject: Re: [PATCH RFC v3 1/6] x86/paravirt: Add pv_idle_ops to paravirt ops To: Juergen Gross , Quan Xu , kvm@vger.kernel.org, linux-doc@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, virtualization@lists.linux-foundation.org, x86@kernel.org, xen-devel@lists.xenproject.org Cc: Yang Zhang , Alok Kataria , Rusty Russell , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" References: <1510567565-5118-1-git-send-email-quan.xu0@gmail.com> <1510567565-5118-2-git-send-email-quan.xu0@gmail.com> <07fac696-e3d4-8f35-8f3d-764d7ab41204@suse.com> From: Quan Xu Message-ID: <902da704-1e4f-583b-91c3-1a62ccd6e73d@gmail.com> Date: Tue, 14 Nov 2017 15:02:41 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: <07fac696-e3d4-8f35-8f3d-764d7ab41204@suse.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2017/11/13 18:53, Juergen Gross wrote: > On 13/11/17 11:06, Quan Xu wrote: >> From: Quan Xu >> >> So far, pv_idle_ops.poll is the only ops for pv_idle. .poll is called >> in idle path which will poll for a while before we enter the real idle >> state. >> >> In virtualization, idle path includes several heavy operations >> includes timer access(LAPIC timer or TSC deadline timer) which will >> hurt performance especially for latency intensive workload like message >> passing task. The cost is mainly from the vmexit which is a hardware >> context switch between virtual machine and hypervisor. Our solution is >> to poll for a while and do not enter real idle path if we can get the >> schedule event during polling. >> >> Poll may cause the CPU waste so we adopt a smart polling mechanism to >> reduce the useless poll. >> >> Signed-off-by: Yang Zhang >> Signed-off-by: Quan Xu >> Cc: Juergen Gross >> Cc: Alok Kataria >> Cc: Rusty Russell >> Cc: Thomas Gleixner >> Cc: Ingo Molnar >> Cc: "H. Peter Anvin" >> Cc: x86@kernel.org >> Cc: virtualization@lists.linux-foundation.org >> Cc: linux-kernel@vger.kernel.org >> Cc: xen-devel@lists.xenproject.org > Hmm, is the idle entry path really so critical to performance that a new > pvops function is necessary? Juergen, Here is the data we get when running benchmark netperf:  1. w/o patch and disable kvm dynamic poll (halt_poll_ns=0):     29031.6 bit/s -- 76.1 %CPU  2. w/ patch and disable kvm dynamic poll (halt_poll_ns=0):     35787.7 bit/s -- 129.4 %CPU  3. w/ kvm dynamic poll:     35735.6 bit/s -- 200.0 %CPU  4. w/patch and w/ kvm dynamic poll:     42225.3 bit/s -- 198.7 %CPU  5. idle=poll     37081.7 bit/s -- 998.1 %CPU  w/ this patch, we will improve performance by 23%.. even we could improve  performance by 45.4%, if we use w/patch and w/ kvm dynamic poll. also the  cost of CPU is much lower than 'idle=poll' case.. > Wouldn't a function pointer, maybe guarded > by a static key, be enough? A further advantage would be that this would > work on other architectures, too. I assume this feature will be ported to other archs.. a new pvops makes code clean and easy to maintain. also I tried to add it into existed pvops, but it doesn't match. Quan Alibaba Cloud > > Juergen > From 1583948919722115757@xxx Mon Nov 13 11:10:03 +0000 2017 X-GM-THRID: 1583947963447418004 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread