Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751784AbdFIQEV (ORCPT ); Fri, 9 Jun 2017 12:04:21 -0400 Received: from mail-qt0-f193.google.com ([209.85.216.193]:33279 "EHLO mail-qt0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751642AbdFIQET (ORCPT ); Fri, 9 Jun 2017 12:04:19 -0400 MIME-Version: 1.0 In-Reply-To: <20170609132736.13699-1-vkuznets@redhat.com> References: <20170609132736.13699-1-vkuznets@redhat.com> From: Andy Shevchenko Date: Fri, 9 Jun 2017 19:04:18 +0300 Message-ID: Subject: Re: [PATCH v8 00/10] Hyper-V: paravirtualized remote TLB flushing and hypercall improvements To: Vitaly Kuznetsov Cc: devel@linuxdriverproject.org, "x86@kernel.org" , "linux-kernel@vger.kernel.org" , "K. Y. Srinivasan" , Haiyang Zhang , Stephen Hemminger , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Steven Rostedt , Jork Loeser , Simon Xiao , Andy Lutomirski Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2952 Lines: 82 On Fri, Jun 9, 2017 at 4:27 PM, Vitaly Kuznetsov wrote: > Changes since v7: > - Minor code style fixes (drop explicit casting, reformat code a bit) > in PATCH3 and PATCH9 [Andy Shevchenko] > > Original description: > > 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 3m33.118s > user 0m3.698s > sys 3m16.624s > > After: > # time ./pthread_mmap ./randfile > real 2m19.920s > user 0m2.662s > sys 2m9.948s > > 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). > FWIW, Reviewed-by: Andy Shevchenko to the patches that do not have it yet. > Vitaly Kuznetsov (10): > x86/hyper-v: include hyperv/ only when CONFIG_HYPERV is set > x86/hyper-v: stash the max number of virtual/logical processor > x86/hyper-v: make hv_do_hypercall() inline > x86/hyper-v: fast hypercall implementation > hyper-v: use fast hypercall for HVCALL_SIGNAL_EVENT > x86/hyper-v: implement rep hypercalls > hyper-v: globalize vp_index > x86/hyper-v: use hypercall for remote TLB flush > x86/hyper-v: support extended CPU ranges for TLB flush hypercalls > tracing/hyper-v: trace hyperv_mmu_flush_tlb_others() > > MAINTAINERS | 1 + > arch/x86/Kbuild | 2 +- > arch/x86/hyperv/Makefile | 2 +- > arch/x86/hyperv/hv_init.c | 90 ++++++------ > arch/x86/hyperv/mmu.c | 268 ++++++++++++++++++++++++++++++++++++ > arch/x86/include/asm/mshyperv.h | 148 +++++++++++++++++++- > arch/x86/include/asm/trace/hyperv.h | 38 +++++ > arch/x86/include/uapi/asm/hyperv.h | 17 +++ > arch/x86/kernel/cpu/mshyperv.c | 13 +- > drivers/hv/channel_mgmt.c | 20 +-- > drivers/hv/connection.c | 7 +- > drivers/hv/hv.c | 9 -- > drivers/hv/hyperv_vmbus.h | 11 -- > drivers/hv/vmbus_drv.c | 17 --- > drivers/pci/host/pci-hyperv.c | 10 +- > include/linux/hyperv.h | 17 +-- > 16 files changed, 539 insertions(+), 131 deletions(-) > create mode 100644 arch/x86/hyperv/mmu.c > create mode 100644 arch/x86/include/asm/trace/hyperv.h > > -- > 2.9.4 > -- With Best Regards, Andy Shevchenko