Received: by 2002:a05:7412:40d:b0:e2:908c:2ebd with SMTP id 13csp486351rdf; Tue, 21 Nov 2023 07:59:24 -0800 (PST) X-Google-Smtp-Source: AGHT+IG+DZ9dF9lnGXTpQxPp6yvnsrWx12+T2IJZPM+nZnyq7bwNSWSubiFwJwbXbTCKOU9B+JH1 X-Received: by 2002:a05:6a20:6a07:b0:18a:d7a8:5e5e with SMTP id p7-20020a056a206a0700b0018ad7a85e5emr2714617pzk.41.1700582363684; Tue, 21 Nov 2023 07:59:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700582363; cv=none; d=google.com; s=arc-20160816; b=wJgnRwMGI49qsJidEr2dRUTLQ8ukHtN4WdszNaEDEi20PtFwC6CWmXLe3LqVojc+RY 2hzUZBleVK8KQeZWnjSf/JKqusEUpDtv2eU2o131bJAKsbqeklPtCcIUwi2+KNHImjoQ UldTQlOzz6h2ytiIb8C31pKLVNoYclgjlSPOLPRzpPwznhmIOojPi1ZNMBPnpd6SOf7T 2o4tJTe26btSuDZnCNPwnie+IIXwBevdD/eJaSmr2LhdsCWmd9RMikYfGgq1+GUb9vga OtpIJAGoE+fBzsZI2fMUDD5gUlHTNGLF0VZgW0J8VvceLIQaEOFEfqFoNs3es+HWdwMW J2Yw== 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:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=8QlwHYdsESgjzIw3HCFjyaQ7iMd9XXjiF6dgcXNdMdM=; fh=IFOIc08B6+2JaulQgZQZMGYRAf2eC3sle3aBU+yMoqg=; b=xiff9CN9uvLbmo10zUziKnpcVGBiYqHZCkKhgbcWSSfON7bkzv7ypqW45PFOh56dOO 1j9bFhjFd9HB21zxYtCo59mV39ucqr5t82hWjZPV03plT1GC49y4yViZ4flkeisA5HzP rueIPXnXT06O+JiRzh5Ut2WXcPTs7S0RmiZ4NVttxtS8/+PBJEFG31wdZYIS7CcT4WbH Wa1f1F7bJgTS0o/L2iK9rMH3JrqjVIVtqsHylLpb5Ljj9UqYHB1bkGbZh++O2A6JshTP lT4l+xCcThAtGwEuqKx6ijWxi+GefJ8g1hwa2PkR15RTXvqhAP2Ao5rnUPc0ygKmWeIc DYhg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=LbbMfYQv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id q2-20020a635c02000000b005b96e63bc5esi10791214pgb.631.2023.11.21.07.59.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 21 Nov 2023 07:59:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=LbbMfYQv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 2A05A80A054A; Tue, 21 Nov 2023 07:59:21 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234601AbjKUP7N (ORCPT + 99 others); Tue, 21 Nov 2023 10:59:13 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34148 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232517AbjKUP7L (ORCPT ); Tue, 21 Nov 2023 10:59:11 -0500 Received: from mgamail.intel.com (mgamail.intel.com [134.134.136.31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 108D9139 for ; Tue, 21 Nov 2023 07:59:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1700582347; x=1732118347; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=P6HcNX+jdIWSaxjwmIVYFvKSrRGelBv2vGjlF+Zi26g=; b=LbbMfYQv+/nDO71S7boA2sYPZpkWRZGjJVp1nNIboacyGoN36AYjzvrt yhfvxN3s9clYieGkPLdnr1KnWlwN+F+AIxEm4CzYLGrnrJ54BjQT/nARC U/Wx9NyTu8naRJj9EPPTLsRHIy2D459PunrwCQ14m9fonxOPGoCpB5Tsz UOjoyPpbG1k2yxdCMCvPDCLIvGNW//SkOF4r4/PPbmmZOC2xqhLy+G//G 8Cq+G1U7jVDF8CEaAIswffcyXuCELrp/wtSdE3ZTazpFqx3eLM6sXj5BI LqDRmpOd2jb+1DON4F/YgEQQm/SoeX5QqWPN1qfqH21tLcsNTyBKYhPWF Q==; X-IronPort-AV: E=McAfee;i="6600,9927,10901"; a="456202067" X-IronPort-AV: E=Sophos;i="6.04,216,1695711600"; d="scan'208";a="456202067" Received: from orviesa001.jf.intel.com ([10.64.159.141]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Nov 2023 07:59:07 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.04,216,1695711600"; d="scan'208";a="14556196" Received: from linux.intel.com ([10.54.29.200]) by orviesa001.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Nov 2023 07:59:07 -0800 Received: from [10.209.157.143] (kliang2-mobl1.ccr.corp.intel.com [10.209.157.143]) (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 485AF580689; Tue, 21 Nov 2023 07:59:06 -0800 (PST) Message-ID: <66f74af2-21b6-477b-ada1-a8816ee115dc@linux.intel.com> Date: Tue, 21 Nov 2023 10:59:06 -0500 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 3/3] perf/x86: Add CAP_NO_INTERRUPT for uncore PMUs Content-Language: en-US To: Namhyung Kim , Peter Zijlstra , Ingo Molnar Cc: Mark Rutland , Alexander Shishkin , Arnaldo Carvalho de Melo , LKML , Ian Rogers , Mingwei Zhang References: <20231120221932.213710-1-namhyung@kernel.org> <20231120221932.213710-3-namhyung@kernel.org> From: "Liang, Kan" In-Reply-To: <20231120221932.213710-3-namhyung@kernel.org> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Tue, 21 Nov 2023 07:59:21 -0800 (PST) On 2023-11-20 5:19 p.m., Namhyung Kim wrote: > It doesn't support sampling in uncore PMU events. While it's > technically possible to generate interrupts, let's treat it as if it > has no interrupt in order to skip the freq adjust/unthrottling logic > in the timer handler which is only meaningful to sampling events. > > Also remove the sampling event check because it'd be done in the general > code in the perf_event_open syscall. > > Signed-off-by: Namhyung Kim > --- > arch/x86/events/intel/uncore.c | 11 ++++++----- > 1 file changed, 6 insertions(+), 5 deletions(-) > > diff --git a/arch/x86/events/intel/uncore.c b/arch/x86/events/intel/uncore.c > index 69043e02e8a7..f7e6228bd1b1 100644 > --- a/arch/x86/events/intel/uncore.c > +++ b/arch/x86/events/intel/uncore.c > @@ -744,10 +744,6 @@ static int uncore_pmu_event_init(struct perf_event *event) > if (pmu->func_id < 0) > return -ENOENT; > > - /* Sampling not supported yet */ > - if (hwc->sample_period) > - return -EINVAL; > - > /* > * Place all uncore events for a particular physical package > * onto a single cpu > @@ -919,7 +915,12 @@ static int uncore_pmu_register(struct intel_uncore_pmu *pmu) > .stop = uncore_pmu_event_stop, > .read = uncore_pmu_event_read, > .module = THIS_MODULE, > - .capabilities = PERF_PMU_CAP_NO_EXCLUDE, > + /* > + * It doesn't allow sampling for uncore events, let's > + * treat the PMU has no interrupts to skip them in the > + * perf_adjust_freq_unthr_context(). > + */ > + .capabilities = PERF_PMU_CAP_NO_EXCLUDE | PERF_PMU_CAP_NO_INTERRUPT, > .attr_update = pmu->type->attr_update, > }; There is a special customized uncore PMU which needs the flag as well. diff --git a/arch/x86/events/intel/uncore_snb.c b/arch/x86/events/intel/uncore_snb.c index 7fd4334e12a1..46a63e291975 100644 --- a/arch/x86/events/intel/uncore_snb.c +++ b/arch/x86/events/intel/uncore_snb.c @@ -1013,7 +1013,7 @@ static struct pmu snb_uncore_imc_pmu = { .start = uncore_pmu_event_start, .stop = uncore_pmu_event_stop, .read = uncore_pmu_event_read, - .capabilities = PERF_PMU_CAP_NO_EXCLUDE, + .capabilities = PERF_PMU_CAP_NO_EXCLUDE | PERF_PMU_CAP_NO_INTERRUPT, }; static struct intel_uncore_ops snb_uncore_imc_ops = { Thanks, Kan > } else {