Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp1091631imm; Fri, 22 Jun 2018 10:09:54 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLpUQVRd5/NhPefw6dR0UMT9TdDMzSVs3NduhI7Bjk1sSVuphXu+Q8gnS9TQWZI56Lm/VGZ X-Received: by 2002:a62:4255:: with SMTP id p82-v6mr2626366pfa.227.1529687394885; Fri, 22 Jun 2018 10:09:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529687394; cv=none; d=google.com; s=arc-20160816; b=PcOgJJXL69rxrecTS+Cjx7wYDNm/E7vHeEoHXi7NtFTijVUKMzFDP3ZawSpOxFfXpQ ueiebqc65eLOLkwPMPpdvmTBvI+qtqqH7QeEQs7UEzMG/Z1BATo4Off/COuqm+vwm9Jg AuMcXSU9bZScyHdyKXq3jb+t1fqq4+bAEHx+nvDnUHjBfnX+jbKc7E0J/DTN4OZ8qm2o ugn+FR5TlMUXL1LfyeIAL/Y2WDRfhJLhdHLAuM88YtI/nGjSSyY6tJHnInaMqFIZxBJr nCWVFCh2QLuK6AZ5YlPySG/mycGwgjpRSSmjwl0c0Xgu9o/NAOjhXicSpztofT+h2Dhs GKXQ== 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 :arc-authentication-results; bh=hXlppXPauVDe5MqVAfIPqCgalnlIlyjNmdoRv7BhQEg=; b=DQdMw1q0raaQ/qirNWye4TgEz4Ae4CFtBkIkumoTlpM9by2M73XL5vAK3MNu1bfsdQ RbawYX8py8H3alUht3dtLSrkbSZ0ALuLhBN7nh6UzJmrw9RPVZtuQGfHXiE1gJvjBPbV 1OQf7Lx8o9lpTmsJVJVTrAai5j8ORrWFl/NEsWkJUwU0AzKrpnTDCJhykZECrKVf3QlN F40UUqQQR/PkU7LPJo9c6+JPwqnoC0aiv4vXIvkW1ldtyfHkxLFciYmttMeilHJyFkHJ h7AnWuUDb25kzOy5F9yxNci4DhzCV/k++zZVur3RAyL7MQsqX0dGLtQhLME6IbEauqbj E8YA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r20-v6si1379606pga.142.2018.06.22.10.09.40; Fri, 22 Jun 2018 10:09:54 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754533AbeFVRGa (ORCPT + 99 others); Fri, 22 Jun 2018 13:06:30 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:55286 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751370AbeFVRG3 (ORCPT ); Fri, 22 Jun 2018 13:06:29 -0400 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.rdu2.redhat.com [10.11.54.5]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 89DE04023336; Fri, 22 Jun 2018 17:06:28 +0000 (UTC) Received: from vitty.brq.redhat.com (unknown [10.43.2.155]) by smtp.corp.redhat.com (Postfix) with ESMTP id AADD61C59E; Fri, 22 Jun 2018 17:06:26 +0000 (UTC) From: Vitaly Kuznetsov To: x86@kernel.org Cc: devel@linuxdriverproject.org, linux-kernel@vger.kernel.org, "K. Y. Srinivasan" , Haiyang Zhang , Stephen Hemminger , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Tianyu Lan , "Michael Kelley (EOSG)" Subject: [PATCH 0/4] x86/hyper-v: optimize PV IPIs Date: Fri, 22 Jun 2018 19:06:21 +0200 Message-Id: <20180622170625.30688-1-vkuznets@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.11.54.5 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.6]); Fri, 22 Jun 2018 17:06:28 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.6]); Fri, 22 Jun 2018 17:06:28 +0000 (UTC) for IP:'10.11.54.5' DOMAIN:'int-mx05.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'vkuznets@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When reviewing my "x86/hyper-v: use cheaper HVCALL_FLUSH_VIRTUAL_ADDRESS_ {LIST,SPACE} hypercalls when possible" patch Michael suggested to apply the same idea to PV IPIs. Here we go! Despite what Hyper-V TLFS says about HVCALL_SEND_IPI hypercall, it can actually be 'fast' (passing parameters through registers). Use that too. This series can collide with my "KVM: x86: hyperv: PV IPI support for Windows guests" series as I rename ipi_arg_non_ex/ipi_arg_ex structures there. Depending on which one gets in first we may need to do tiny adjustments. Vitaly Kuznetsov (4): x86/hyper-v: implement hv_do_fast_hypercall16 x86/hyper-v: use 'fast' hypercall for HVCALL_SEND_IPI x86/hyper-v: use cheaper HVCALL_SEND_IPI hypercall when possible x86/hyper-v: trace PV IPI send arch/x86/hyperv/hv_apic.c | 57 ++++++++++++++++++++----------------- arch/x86/include/asm/mshyperv.h | 34 ++++++++++++++++++++++ arch/x86/include/asm/trace/hyperv.h | 15 ++++++++++ 3 files changed, 80 insertions(+), 26 deletions(-) -- 2.14.4