Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp2473631imn; Tue, 2 Aug 2022 04:19:03 -0700 (PDT) X-Google-Smtp-Source: AGRyM1v4wMVP3VMCTvzWAj0mYmCbnhykQmb2DS+p9Z4g8d5wwIgnPfTG991bQOYBL57pDTfeeB19 X-Received: by 2002:a05:6a00:2185:b0:520:7276:6570 with SMTP id h5-20020a056a00218500b0052072766570mr20725388pfi.84.1659439143627; Tue, 02 Aug 2022 04:19:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659439143; cv=none; d=google.com; s=arc-20160816; b=RC6E/jcUVJPLleuVwpk5GRVvU5r9eovFygfeyvZC8GS1DUYfJHYQw2ksTOyWffygPA K9lFtyVEL0wiZA6nqFo50vMf07NIm+bOqf87mccudm74SPABFHycMN+67TTh2VD+Szg5 QQfToD362/OQFUX2l+Uwgbs7CcKNdbDud2EIybdwGB7Yx0EwWVMJNede9uG43Lwlauxq J87EzsR/jKlUgay11nlLAViDHtu3UrG3+nQbpPSemhqxZvHureogVIPawGJOunUmQSID YM9exFY95bl45uEWdDvA1ljA+O3hjwvJpGJ6x2EfM3KB1ogtIKLdfLRakJEScokHWpOo qZ+Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:references :cc:to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature; bh=s/ZC9n/wInmegiSyRz568Hw+Uv60cUOdQmulw7RvUXE=; b=DrJLlmP5iSJZxl1fJxw5QgNInKUz2d8MGB6H+BD/HC+6zbIe0MjT645xz25hVk+xk6 ckimi6Hz+iB2ESfseUldkPVCYNA5zuS7kdwmp1IF+Yl3k2vtrg4FdYnVHGwSNvMzkXF0 wTHmsewA4jQk6d909Ez/o0AdYY8ClTyfKYduZFV6EeKY3q6edye1ubFrnwZ+tH2gJj9P pdcSWrkTh69kfm6/dAJ1EcTAUqQ24scEiEpBrBoj3GneG8gQcyhCh/Y/ubDy9Yifdq6l rZOcDvq1rQILkZXB3QRjVBX0QUv6mEVxyT0i2xAC0wLVkw3MfA/d/8HdSVzoufS08+NN 4SUQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="JIzh/vuR"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d3-20020a636803000000b0041298bc412asi15854714pgc.862.2022.08.02.04.18.49; Tue, 02 Aug 2022 04:19:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="JIzh/vuR"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231732AbiHBLIG (ORCPT + 99 others); Tue, 2 Aug 2022 07:08:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43954 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236721AbiHBLIE (ORCPT ); Tue, 2 Aug 2022 07:08:04 -0400 Received: from mail-pj1-x1033.google.com (mail-pj1-x1033.google.com [IPv6:2607:f8b0:4864:20::1033]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CE09C41D36; Tue, 2 Aug 2022 04:08:03 -0700 (PDT) Received: by mail-pj1-x1033.google.com with SMTP id b4so3098732pji.4; Tue, 02 Aug 2022 04:08:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language :from:to:cc:references:in-reply-to:content-transfer-encoding; bh=s/ZC9n/wInmegiSyRz568Hw+Uv60cUOdQmulw7RvUXE=; b=JIzh/vuRbxmOjINUOjX0I1ZMchVdtFY+Fa0uO7+l6lAv28fe4USKnm/hgnX2VZWqI7 z1TYiNbGnAaITD+c24m9NSOqV3Ed0pLHcIs0RRBOulmcWYXjlJACO3HR5uF8KHmVQhiy +pR51WuNzFHosggAOBTNN0NLdZpGMKhLvoFnNGz+QwjLcuqq0lnU8vdB2Pf0Qz/jTqqX YYIEnCzUy8MdgMYB+xxWWQF2a2HHNeXQ3wfUVubPZaKG6L65bkGzUrrqcUuPnRTI4OHb X4/ZRy2vwth7I1JLNg42qxUSJ6U18EfoOSSfleSJ+EiIsSvHirpwgALnDG6zWpO24jMH lN7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:from:to:cc:references:in-reply-to :content-transfer-encoding; bh=s/ZC9n/wInmegiSyRz568Hw+Uv60cUOdQmulw7RvUXE=; b=BKlBx4SLkjwjve9yw1jOboPI60p3Q9xhGlZM0zkeMGbd+FgZkCfxqFh9C7L1u4Ctny UlvCZc0o3e7hy51UjdieMAdscK7tX7xks9LWJyCfX4NO/gbdjJY5D1w3XQet0JCd/AkH +/xppOEHeUaPdA2JhS4Hc7z7vg2sQZY5fJGt76ZcDdI3XzbmcplBYOLJ53SL0NO4cAsg vXZRBI6fsXqGLjfCy9vx4vse9D0TX4m8n02bUdscErjYXcFinWgjga3kkvc0owufVJsa nqeFflm30Y03dSTJwZYVH6P9hJGfdx43wc93J/HU40pK8vnolxeFnEYKG5uGGzW583oM K8sw== X-Gm-Message-State: ACgBeo3ytdFd8w3ov4m1w2bAztCaTwxj6uZA1p1SLDEYEiQUC6hauGqm WM3PnR6WQePW1CIFCJh7GkFdEampsSWaPQ== X-Received: by 2002:a17:902:c40e:b0:16e:cdf5:fd95 with SMTP id k14-20020a170902c40e00b0016ecdf5fd95mr14536542plk.86.1659438483228; Tue, 02 Aug 2022 04:08:03 -0700 (PDT) Received: from [192.168.255.10] ([103.7.29.32]) by smtp.gmail.com with ESMTPSA id s9-20020a170902ea0900b0016d12adc282sm11733065plg.147.2022.08.02.04.08.01 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 02 Aug 2022 04:08:02 -0700 (PDT) Message-ID: <5e8f11ef-22ff-ee67-ed39-8e07d4ee9028@gmail.com> Date: Tue, 2 Aug 2022 19:07:54 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:91.0) Gecko/20100101 Thunderbird/91.11.0 Subject: Re: [PATCH v2 0/7] KVM: x86/pmu: Fix some corner cases including Intel PEBS Content-Language: en-US From: Like Xu To: Paolo Bonzini , Sean Christopherson Cc: linux-kernel@vger.kernel.org, kvm@vger.kernel.org References: <20220721103549.49543-1-likexu@tencent.com> In-Reply-To: <20220721103549.49543-1-likexu@tencent.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To catch up on the first -rc, ping beggarly and guiltily. On 21/7/2022 6:35 pm, Like Xu wrote: > Good well-designed tests can help us find more bugs, especially when > the test steps differ from the Linux kernel behaviour in terms of the > timing of access to virtualized hw resources. > > A new guest PEBS kvm-unit-test constructs a number of typical and > corner use cases to demonstrate how fragile the earlier PEBS > enabling patch set is. I prefer to reveal these flaws and fix them > myself before we receive complaints from projects that rely on it. > > In this patch series, there is one small optimization (006), one hardware > surprise (002), and most of these fixes have stepped on my little toes. > > Please feel free to run tests, add more or share comments. > > Previous: > https://lore.kernel.org/kvm/20220713122507.29236-1-likexu@tencent.com/ > > V1 -> V2 Changelog: > - For 3/7, use "hw_idx > -1" and add comment; (Sean) > - For 4/7, refine commit message and add comment; (Sean) > - For 6/7, inline reprogram_counter() and restrict pmc->current_config; > > Like Xu (7): > perf/x86/core: Update x86_pmu.pebs_capable for ICELAKE_{X,D} > perf/x86/core: Completely disable guest PEBS via guest's global_ctrl > KVM: x86/pmu: Avoid setting BIT_ULL(-1) to pmu->host_cross_mapped_mask > KVM: x86/pmu: Don't generate PEBS records for emulated instructions > KVM: x86/pmu: Avoid using PEBS perf_events for normal counters > KVM: x86/pmu: Defer reprogram_counter() to kvm_pmu_handle_event() > KVM: x86/pmu: Defer counter emulated overflow via pmc->stale_counter > > arch/x86/events/intel/core.c | 4 ++- > arch/x86/include/asm/kvm_host.h | 6 +++-- > arch/x86/kvm/pmu.c | 47 +++++++++++++++++++++------------ > arch/x86/kvm/pmu.h | 6 ++++- > arch/x86/kvm/svm/pmu.c | 2 +- > arch/x86/kvm/vmx/pmu_intel.c | 30 ++++++++++----------- > 6 files changed, 58 insertions(+), 37 deletions(-) >