Received: by 2002:a05:7412:98c1:b0:fa:551:50a7 with SMTP id kc1csp1594321rdb; Mon, 8 Jan 2024 04:34:56 -0800 (PST) X-Google-Smtp-Source: AGHT+IH/rifvkGSZFQS+EWqB9VqGsMChZlm1+HZmWUKaknjYqomcxXBFAAvwPJMkThck4sdf+Rdo X-Received: by 2002:a05:6512:138f:b0:50e:60eb:255e with SMTP id fc15-20020a056512138f00b0050e60eb255emr1668068lfb.23.1704717296505; Mon, 08 Jan 2024 04:34:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704717296; cv=none; d=google.com; s=arc-20160816; b=fW2lTlHVQCbGka1xWE27wdPFCIlZcPBMtIa6YKYkt8RSaM9TADiDvq5bYhsw28pJQp /10ShnjOY8S3aHDXuM90DBJA5YiRUeIqcjyiMwjNIv6OqCFjfZEcQyrdHes1dNNQfmz9 +o5Cp4nG9uvD/elSyPfIiiFA2N4oAI7a1EF/ZTfw/yKnVYELtMYuk8FUMfNNVU+c7EMF OMnA9iws0Fxc0PaV4Yz0hmgWyqZVA0wLeccIZgeX38EwpsyiOVj2bG8YoFJp27zRULAl xaEsv7DDnqmD7ZRQ70M5BRyTwg3O7Zgbqwv6L4VBcxtVc7+WwtlREar+StGzAk+zrc/W roTA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:user-agent:date:message-id:from :references:to:subject:cc; bh=/VstZ6lhtAtMPJjHMOU/YbZS/agkoaXywAOt52ZICz8=; fh=TfIdIOYagrSd8m48HiNgjb+kGAdmpkD+LEH6i49gaws=; b=pQYawnNx2HYjzrB9tKDOb4eSRzxB0VaEwD1V7EcYe2kwekYV3/I0yNiDJt7ccGS9KZ cvrTAmFFT3a5QsUqKOCTBIu//kaA/Bgh6+xm5ThShqCOd3B6k1LFoc5unnKCMvORXQx2 4eKh8oiirOZNw58Oqa0mSGI1j3oI5Mgcs/LtZWJicmYuMRpyZhmwwYIL/N0ksL37sa8Z k+t+rhIRMMuFjhau53qMZC0mA1jlADLg5pQW3xZ4nT15lwcwcZZpxgebcTEShE0wx1n3 nyBhHInwKhbmej0ETJx/B/RELVeuUtN2cKlTnrW8p5sxwc3wnXphgMdzpqn57thyAN2q GBvg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-19515-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-19515-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id s15-20020a05640217cf00b005559a32fb08si3051037edy.103.2024.01.08.04.34.56 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 08 Jan 2024 04:34:56 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-19515-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-19515-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-19515-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 3FD331F22C0A for ; Mon, 8 Jan 2024 12:34:56 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 055A446454; Mon, 8 Jan 2024 12:29:15 +0000 (UTC) X-Original-To: linux-kernel@vger.kernel.org Received: from szxga07-in.huawei.com (szxga07-in.huawei.com [45.249.212.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 326E146431 for ; Mon, 8 Jan 2024 12:29:11 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=huawei.com Received: from mail.maildlp.com (unknown [172.19.88.234]) by szxga07-in.huawei.com (SkyGuard) with ESMTP id 4T7tcV6nPzz1Q7vJ; Mon, 8 Jan 2024 20:27:38 +0800 (CST) Received: from canpemm500009.china.huawei.com (unknown [7.192.105.203]) by mail.maildlp.com (Postfix) with ESMTPS id 8E1A41404D8; Mon, 8 Jan 2024 20:29:09 +0800 (CST) Received: from [10.67.121.177] (10.67.121.177) by canpemm500009.china.huawei.com (7.192.105.203) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.35; Mon, 8 Jan 2024 20:29:09 +0800 CC: , , , , , , , Subject: Re: [PATCH v2] hwtracing: hisi_ptt: Move type check to the beginning of hisi_ptt_pmu_event_init() To: Yang Jihong References: <20240108121906.3514820-1-yangjihong1@huawei.com> From: Yicong Yang Message-ID: Date: Mon, 8 Jan 2024 20:29:09 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.5.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 In-Reply-To: <20240108121906.3514820-1-yangjihong1@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To canpemm500009.china.huawei.com (7.192.105.203) Hi Jihong, On 2024/1/8 20:19, Yang Jihong wrote: > When perf_init_event() calls perf_try_init_event() to init pmu driver, > searches for the next pmu driver only when the return value is -ENOENT. > Therefore, hisi_ptt_pmu_event_init() needs to check the type at the > beginning of the function. > Otherwise, in the case of perf-task mode, perf_try_init_event() returns > -EOPNOTSUPP and skips subsequent pmu drivers, causes perf_init_event() to > fail. > > Fixes: ff0de066b463 ("hwtracing: hisi_ptt: Add trace function support for HiSilicon PCIe Tune and Trace device") > Signed-off-by: Yang Jihong Thanks for fixing this: Reviewed-by: Yicong Yang > --- > > Changes since v1: > - Add fixes tag. > > drivers/hwtracing/ptt/hisi_ptt.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/drivers/hwtracing/ptt/hisi_ptt.c b/drivers/hwtracing/ptt/hisi_ptt.c > index a991ecb7515a..24a1f7797aeb 100644 > --- a/drivers/hwtracing/ptt/hisi_ptt.c > +++ b/drivers/hwtracing/ptt/hisi_ptt.c > @@ -995,6 +995,9 @@ static int hisi_ptt_pmu_event_init(struct perf_event *event) > int ret; > u32 val; > > + if (event->attr.type != hisi_ptt->hisi_ptt_pmu.type) > + return -ENOENT; > + > if (event->cpu < 0) { > dev_dbg(event->pmu->dev, "Per-task mode not supported\n"); > return -EOPNOTSUPP; > @@ -1003,9 +1006,6 @@ static int hisi_ptt_pmu_event_init(struct perf_event *event) > if (event->attach_state & PERF_ATTACH_TASK) > return -EOPNOTSUPP; > > - if (event->attr.type != hisi_ptt->hisi_ptt_pmu.type) > - return -ENOENT; > - > ret = hisi_ptt_trace_valid_filter(hisi_ptt, event->attr.config); > if (ret < 0) > return ret; >