Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933218AbdDGL2n (ORCPT ); Fri, 7 Apr 2017 07:28:43 -0400 Received: from mx1.redhat.com ([209.132.183.28]:33548 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755725AbdDGL1L (ORCPT ); Fri, 7 Apr 2017 07:27:11 -0400 DMARC-Filter: OpenDMARC Filter v1.3.2 mx1.redhat.com E1FA46584C Authentication-Results: ext-mx09.extmail.prod.ext.phx2.redhat.com; dmarc=none (p=none dis=none) header.from=redhat.com Authentication-Results: ext-mx09.extmail.prod.ext.phx2.redhat.com; spf=pass smtp.mailfrom=vkuznets@redhat.com DKIM-Filter: OpenDKIM Filter v2.11.0 mx1.redhat.com E1FA46584C From: Vitaly Kuznetsov To: devel@linuxdriverproject.org, x86@kernel.org Cc: linux-kernel@vger.kernel.org, "K. Y. Srinivasan" , Haiyang Zhang , Stephen Hemminger , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Steven Rostedt , Jork Loeser Subject: [PATCH 0/7] Hyper-V: praravirtualized remote TLB flushing and hypercall improvements Date: Fri, 7 Apr 2017 13:26:54 +0200 Message-Id: <20170407112701.17157-1-vkuznets@redhat.com> X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.38]); Fri, 07 Apr 2017 11:27:06 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2172 Lines: 58 Hi, Hyper-V supports hypercalls for doing local and remote TLB flushing and gives its guests hints when using hypercall is preferred. While doing hypercalls for local TLB flushes is probably not practical (and is not being suggested by modern Hyper-V versions) remote TLB flush with a hypercall brings significant improvement. To test the series I wrote a special 'TLB trasher': on a 16 vCPU guest I was creating 32 threads which were doing 100000 mmap/munmaps each on some big file. Here are the results: Before: # time ./pthread_mmap ./randfile real 3m44.994s user 0m3.829s sys 3m36.323s After: # time ./pthread_mmap ./randfile real 2m57.145s user 0m3.797s sys 2m34.812s This series brings a number of small improvements along the way: fast hypercall implementation and using it for event signaling, rep hypercalls implementation, hyperv tracing subsystem (which only traces the newly added remote TLB flush for now). Vitaly Kuznetsov (7): x86/hyperv: make hv_do_hypercall() inline x86/hyper-v: fast hypercall implementation hyper-v: use fast hypercall for HVCALL_SIGNAL_EVENT x86/hyperv: implement rep hypercalls hyper-v: globalize vp_index x86/hyper-v: use hypercall for remove TLB flush tracing/hyper-v: trace hyperv_mmu_flush_tlb_others() MAINTAINERS | 1 + arch/x86/hyperv/Makefile | 2 +- arch/x86/hyperv/hv_init.c | 90 +++++++++++-------------- arch/x86/hyperv/mmu.c | 134 +++++++++++++++++++++++++++++++++++++ arch/x86/include/asm/mshyperv.h | 131 ++++++++++++++++++++++++++++++++++++ arch/x86/include/uapi/asm/hyperv.h | 26 +++++++ arch/x86/kernel/cpu/mshyperv.c | 1 + drivers/hv/channel_mgmt.c | 22 +++--- drivers/hv/connection.c | 8 ++- drivers/hv/hv.c | 9 --- drivers/hv/hyperv_vmbus.h | 11 --- drivers/hv/vmbus_drv.c | 17 ----- include/linux/hyperv.h | 21 +++--- include/trace/events/hyperv.h | 30 +++++++++ 14 files changed, 386 insertions(+), 117 deletions(-) create mode 100644 arch/x86/hyperv/mmu.c create mode 100644 include/trace/events/hyperv.h -- 2.9.3