Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1946831imm; Thu, 20 Sep 2018 05:33:26 -0700 (PDT) X-Google-Smtp-Source: ANB0Vdaw49QfLVgDyzOlugJrxw1+9gF4Fo0mNQ3Y3OXkDaqB0gYPSekpo1ledPIQ9b8FMk78u0jK X-Received: by 2002:a63:f751:: with SMTP id f17-v6mr37180741pgk.410.1537446806389; Thu, 20 Sep 2018 05:33:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537446806; cv=none; d=google.com; s=arc-20160816; b=eiq74KOR1Ep/J2zjrIm1s52YKWJp2ZQegfKpm5+W2BF60osTfzcowARpXGPcKrQMzq grY/9L6Y6UI7rfeTGCGtnGLC2bHEYRhB+yIZ2yEWbZFOAo+OMtJeAkHynhb0ilIdIzqa FIpuq0+5mgJ19cU69XWsaZwgYe0tJf3My73xPeRRTcPMWdT0QXHRsyczS+ejoDU0gB7W CQmIhy+FYRaBLWL8BlP5vCglsDDQjD5TGfs7zD+eDSGLzB+lashRyk37rWXcThsl1Osy up1c299FjCxoJpvk5LR1i7u2ysoCdBETTrlXKTHGLlqxydz81aIHqlZocsBnCjlIMU/D 7cUg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=QZuZa1meuIZaNWQp6dF92m665G4UHHN63rowi+t00Ss=; b=dnrk+XmJljp2PMkjowZj2MlZnKOFSR3IocqJ0vMGQ6jgkmxdrn7dTtDXx6kcSOk9/D T9DJJ0aq5H+Gav47eufu4UIRQ5xtU4KzQg2LQETU+O3+EX9oR+Mg95fdI39zkOIBkvjY ykW7MqMjd4rw2G32n5z6tdu3WPXNbUQOjzvGsDP5FSJyPa+5CnIHEJKj71q2IgbQX6ep IVjsKyzx2J37Uy8U1yiWR0iDXj9nooCTmlpnR+oD+7jwIydAkKNCEtenN9bIUnmHGUzb NFUVnoYd18VEbnB2pfsGbD38cUHMnOe5nmgyFrIvl1mm6DHqO33AEr1uXcZg1RZMnEmA VzcA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=ivfXClov; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i16-v6si23578526pgi.660.2018.09.20.05.33.10; Thu, 20 Sep 2018 05:33:26 -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=fail header.i=@infradead.org header.s=merlin.20170209 header.b=ivfXClov; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387685AbeITSPz (ORCPT + 99 others); Thu, 20 Sep 2018 14:15:55 -0400 Received: from merlin.infradead.org ([205.233.59.134]:60804 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387570AbeITSPz (ORCPT ); Thu, 20 Sep 2018 14:15:55 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=merlin.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=QZuZa1meuIZaNWQp6dF92m665G4UHHN63rowi+t00Ss=; b=ivfXClovRNRbB2W9BfgT8S602 uNwk0lTwDZAExKiei+pvya496++V7EGSZTtrR0n8OiRc5i8P41EWej31nerH20uC3f1A7MmX0t0ri +8JfcnJ4/t5u6rZDu3vVy2O8J56ncSN5nCCI9qlBwLWzib+Bct4h+A1W3bWfqMWzn5L+Nrzp4n8Ly yRhYlOccXqSs8aDIZXFO4/XZI3xyuBHymY3jc+0KoHXxSQsYslkayyhzrLDJH4CR/YjbW87xhykvh +ro6dyE48TgSTf7yVejDnqVBGAiAzYSLq4RkbmpPPgyhPCHOjJCst5F2VeLl65HcCOYY+6zMkyXqj UHUR65DQA==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by merlin.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1g2y88-0001h9-QD; Thu, 20 Sep 2018 12:32:25 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 547852015F391; Thu, 20 Sep 2018 14:32:23 +0200 (CEST) Date: Thu, 20 Sep 2018 14:32:23 +0200 From: Peter Zijlstra To: Wei Wang Cc: linux-kernel@vger.kernel.org, kvm@vger.kernel.org, pbonzini@redhat.com, ak@linux.intel.com, kan.liang@intel.com, mingo@redhat.com, rkrcmar@redhat.com, like.xu@intel.com, jannh@google.com, arei.gonglei@huawei.com Subject: Re: [PATCH v3 4/5] KVM/x86/vPMU: Add APIs to support host save/restore the guest lbr stack Message-ID: <20180920123223.GS24124@hirez.programming.kicks-ass.net> References: <1537437959-8751-1-git-send-email-wei.w.wang@intel.com> <1537437959-8751-5-git-send-email-wei.w.wang@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1537437959-8751-5-git-send-email-wei.w.wang@intel.com> User-Agent: Mutt/1.10.0 (2018-05-17) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Sep 20, 2018 at 06:05:58PM +0800, Wei Wang wrote: > diff --git a/arch/x86/kvm/pmu_intel.c b/arch/x86/kvm/pmu_intel.c > index 5ab4a36..97a29d7 100644 > --- a/arch/x86/kvm/pmu_intel.c > +++ b/arch/x86/kvm/pmu_intel.c > @@ -342,6 +342,47 @@ static void intel_pmu_reset(struct kvm_vcpu *vcpu) > pmu->global_ovf_ctrl = 0; > } > > +int intel_pmu_enable_save_guest_lbr(struct kvm_vcpu *vcpu) > +{ > + struct kvm_pmu *pmu = vcpu_to_pmu(vcpu); > + struct perf_event *event; > + struct perf_event_attr attr = { > + .type = PERF_TYPE_RAW, > + .size = sizeof(attr), Bit yuck to imply .config = 0, like that. > + .pinned = true, Note that this can still result in failing to schedule the event, you create a pinned task event, but a pinned cpu event takes precedence and can claim the LBR. How do you deal with that situation, where the LBR is in use by a host event? > + .exclude_host = true, Didn't you mean to use .exclude_guest ? You don't want this thing to run when the guest is running, right? But I still don't like this hack much, what happens if userspace sets that bit? You seems to have forgotten to combine it with PF_VCPU or whatever is the appropriate bit to check. Similarly, how does the existing exclude_{gues,host} crud work? > + .sample_type = PERF_SAMPLE_BRANCH_STACK, What's the point of setting .sample_type if !.sample_period ? > + .branch_sample_type = PERF_SAMPLE_BRANCH_CALL_STACK | > + PERF_SAMPLE_BRANCH_USER | > + PERF_SAMPLE_BRANCH_KERNEL, > + }; I think this function wants a comment to explain wth its doing and why, because if someone stumbles over this code in a few months nobody will remember those things. > + > + if (pmu->guest_lbr_event) > + return 0; > + > + event = perf_event_create_kernel_counter(&attr, -1, current, NULL, > + NULL); > + if (IS_ERR(event)) { > + pr_err("%s: failed %ld\n", __func__, PTR_ERR(event)); > + return -ENOENT; > + } > + pmu->guest_lbr_event = event; > + > + return 0; > +}