Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp71372pxb; Wed, 14 Apr 2021 09:39:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwW2q9DJ5h9f1wyQ6pcNMd0tPjI641OfwJHKjidxzhqBFs6uKWDPAo1zyoZBsOaeqTwqhrd X-Received: by 2002:a50:fb84:: with SMTP id e4mr41723737edq.92.1618418356295; Wed, 14 Apr 2021 09:39:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618418356; cv=none; d=google.com; s=arc-20160816; b=LStFTKgjOLdPWSuiKXgouV+dUU3E8X+i4+/fl88Kl8RXJUPxI3QL9Hn9ue9tz6/OM7 dlh2jWL3p+h/pVGnH07h7FQ+szVQ1366jHWKB/0Jqup/PIkLMV74MHw9uu0+TlBq1L91 KJRD5gUEzp+OesliwQ+iO+LJVkoWeYCldA3Vu4AioXlrRa4dRaBEueR2rjysCz1EX9fA dgdhb7byBWIqVxXGixQKZqPcmX8op4cgGEBEl1oZ4Mss5SDHPDSMcSYsaQ07su68uazO 10C8PmPXMwe3lwqmHv3M9zJlWOswsWIi4mEwcmvH+aJ4eN+PAFkYQfKfqsO4oVcUUNzu Wxeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=3dwBrK5lvR3k/9cERLUWaiap5PKCK6Tsv6tf9yQ0cbo=; b=NwDAe7daMpOESVfXkFwW5IxUvYT2ed+EVo/5UIS26Okh+TS1Z8hsRWJ+jg8KSuhn28 49lel5ffadd049vyzbGY07RuvvqiOizxaY2Z15cB7IKlKJt1Pa1unvDshR+CQUZiHVAI nRlVXVWYAVAVwNWObEZ+wioiNuoJPOfpwT6eY0FaowXswAmns8EM7IyQazkVafn5bhqw VIHs43ulXQJ045AbZzdR8DbYY4ieLweM0dN+Q9Pzi89hTv5XK3VIkYe58r+8i5rH/CCI KQQnQwFvQf5uL3f8ivju20nghLcjt1TeYCev6cEMvtZ4N3gBOxn56SyfJRkCv9Mg6tjL aTJA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k19si51862eds.343.2021.04.14.09.38.51; Wed, 14 Apr 2021 09:39:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1349582AbhDNO2J (ORCPT + 99 others); Wed, 14 Apr 2021 10:28:09 -0400 Received: from mga11.intel.com ([192.55.52.93]:61591 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1349630AbhDNO2B (ORCPT ); Wed, 14 Apr 2021 10:28:01 -0400 IronPort-SDR: bwLCcMe302Q5PEUFHp/X6qnB5KOopWuuz3hPhMlp36xzIAafM1zN5uJ4guH1mLTMgfSNqA+/eh MsOArosbjh+Q== X-IronPort-AV: E=McAfee;i="6200,9189,9954"; a="191464138" X-IronPort-AV: E=Sophos;i="5.82,222,1613462400"; d="scan'208";a="191464138" Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Apr 2021 07:27:31 -0700 IronPort-SDR: BjYR8f/isYE2cN+iBRYqXk9T8ZvtCGT0mXREoFxLqfpiogJN/dBNGNX3MPSYzb0Duxw89oRyVu guYiRKZsSjng== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.82,222,1613462400"; d="scan'208";a="383695416" Received: from linux.intel.com ([10.54.29.200]) by orsmga006.jf.intel.com with ESMTP; 14 Apr 2021 07:27:31 -0700 Received: from [10.209.105.172] (kliang2-MOBL.ccr.corp.intel.com [10.209.105.172]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by linux.intel.com (Postfix) with ESMTPS id 1D005580021; Wed, 14 Apr 2021 07:27:30 -0700 (PDT) Subject: Re: [PATCH V3 2/2] perf/x86: Reset the dirty counter to prevent the leak for an RDPMC task To: Namhyung Kim Cc: Peter Zijlstra , Ingo Molnar , linux-kernel , Arnaldo Carvalho de Melo , Andi Kleen , Mark Rutland , luto@amacapital.net, Stephane Eranian References: <1618340250-29027-1-git-send-email-kan.liang@linux.intel.com> <1618340250-29027-2-git-send-email-kan.liang@linux.intel.com> From: "Liang, Kan" Message-ID: <599982b3-321a-9a75-2041-252fc73bbaa4@linux.intel.com> Date: Wed, 14 Apr 2021 10:27:28 -0400 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.9.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/14/2021 9:51 AM, Namhyung Kim wrote: > Hi Kan, > > On Wed, Apr 14, 2021 at 4:04 AM wrote: >> diff --git a/arch/x86/events/core.c b/arch/x86/events/core.c >> index dd9f3c2..0d4a1a3 100644 >> --- a/arch/x86/events/core.c >> +++ b/arch/x86/events/core.c >> @@ -1585,6 +1585,8 @@ static void x86_pmu_del(struct perf_event *event, int flags) >> if (cpuc->txn_flags & PERF_PMU_TXN_ADD) >> goto do_del; >> >> + __set_bit(event->hw.idx, cpuc->dirty); >> + >> /* >> * Not a TXN, therefore cleanup properly. >> */ >> @@ -2304,12 +2306,46 @@ static int x86_pmu_event_init(struct perf_event *event) >> return err; >> } >> >> +void x86_pmu_clear_dirty_counters(void) >> +{ >> + struct cpu_hw_events *cpuc = this_cpu_ptr(&cpu_hw_events); >> + int i; >> + >> + if (bitmap_empty(cpuc->dirty, X86_PMC_IDX_MAX)) >> + return; > > Maybe you can check it after clearing assigned counters. > It should be very likely that the cpuc->dirty is non-empty. Move it after the clearing can skip the for_each_set_bit() and bitmap_zero(). OK. I will change it in V4. Thanks, Kan