Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp9073376rwd; Wed, 21 Jun 2023 02:38:01 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5MNucuqHyxvzlXL8R/MeffD9H5rF+S6Q9neVrQbuWafx7IRP16o7wj/qCbmCoQzwU35Yx5 X-Received: by 2002:a17:90b:3684:b0:260:b83e:89d4 with SMTP id mj4-20020a17090b368400b00260b83e89d4mr7673945pjb.15.1687340281193; Wed, 21 Jun 2023 02:38:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687340281; cv=none; d=google.com; s=arc-20160816; b=uxKIkNwTCHEfmU/ZydhzDL6UzjoWN06d+wYSPHPNngB0pEvwInCuvHxcvW+xfYk2Sm rVOPTOmwjUCnhmteNomb/jnM478pj60xLLeSDsiwtxmApXALGIZ1pQv6P70LiwIeZRkZ iZJudPLKoqIJsFbRqHijRBlPFFvquoro833VYmYwlmYYLAV3adIa8V0RPTE83B/spq0R TZTJEtxaTfna3E3jQT+EY7+EJ9d6EZo/BicfCakY+2YsvaGnRfLJpDA9lGXhKU4Na22K bq4zTsTwr4BOf8DJfwzKc5NVGmoiVAebDlEOAe4RoB1DfZNgDR0WKjoRAg8SpifalE4T Vv8w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=Q8rv8fO1PSCwp6HikWfgdvczEELBHpVEgIUXCOttzXA=; b=fXb6LHTpVskaLtelJmP+lWNdCCXjZXtuaSEe3xKSLt7y6ho45X5S7Pfr7FpEqhdvZq TJMRYQ5khDV4jd5k+aIEftxYMpUYcsgxyIF3du3n3Qjs/qwl9GmGXbAQwHTkV2v+PPQ6 HkTmJsTBLrHtaAJ1fEv04db8b+DsV3lKLnCfiAFOaOMht1k10hHVx5KiJG1RW9Z4jfPC fkypz4xLfh54hl0kdMGhH0y3kPD41HJrcNFhK8Pk3/nzZ/C6/1j9A6GTd7QghZB1p0Jp t3894zZEAk0k+yiyUkT/jUf/WJIi8938dxP+uqrz1kNP6Jj4ghKLmmAhavoUWeSwZN5+ kang== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 17-20020a17090a01d100b00260fadc24b7si927033pjd.75.2023.06.21.02.37.45; Wed, 21 Jun 2023 02:38:01 -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; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231819AbjFUJbL (ORCPT + 99 others); Wed, 21 Jun 2023 05:31:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34842 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232292AbjFUJao (ORCPT ); Wed, 21 Jun 2023 05:30:44 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 16DB61992; Wed, 21 Jun 2023 02:29:44 -0700 (PDT) Received: from canpemm500009.china.huawei.com (unknown [172.30.72.53]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4QmJ7j0pgszLmlX; Wed, 21 Jun 2023 17:27:45 +0800 (CST) Received: from localhost.localdomain (10.50.163.32) 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.27; Wed, 21 Jun 2023 17:29:42 +0800 From: Yicong Yang To: , , , , , CC: , , , , , , Subject: [PATCH v6 0/5] Improve PTT filter interface and some fixes Date: Wed, 21 Jun 2023 17:27:59 +0800 Message-ID: <20230621092804.15120-1-yangyicong@huawei.com> X-Mailer: git-send-email 2.31.0 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.50.163.32] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To canpemm500009.china.huawei.com (7.192.105.203) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 From: Yicong Yang This series tends to improve the PTT's filter interface in 2 aspects (Patch 2&3): - Support dynamically filter updating to response to hotplug Previous the supported filter list is settled down once the driver probed and it maybe out-of-date if hotplug events happen later. User need to reload the driver to update list. Patch 1/2 enable the driver to update the list by registering a PCI bus notifier and the filter list will always be the latest. - Export the available filters through sysfs Previous user needs to calculate the filters and filter value using device's BDF number, which requires the user to know the hardware well. Patch 3/3 tends to export the available filter information through sysfs attributes, the filter value will be gotten by reading the file. This will be more user friendly. In order to support above function, this series also includes a patch 1/4 to factor out the allocation and release function of PTT filters. Also includes an improvement and a fix. Patch 4 tends to set proper PMU capability to avoid collecting unnecessary data to save the storage. Patch 5 fix an improper use of pci_irq_vector() which have potential problem. Change since v5: - PERF_PMU_CAP_EXCLUSIVE is still needed so keep it as is, thanks Junhao for pointing it Link: https://lore.kernel.org/all/01c39cb9-e56a-862b-2d99-024b7ba5a769@huawei.com/ Change since v4: - Add tags for Patch 2,3,5 and tweak some comments/docs in Patch 3 Link: https://lore.kernel.org/all/20230606142244.10939-1-yangyicong@huawei.com/ Change since v3: - Addressed the comment from Jonathan. Add tags for Patch 1 and 4. Thanks. - Add one bugfix in Patch 5/5 Link: https://lore.kernel.org/linux-pci/20230523093228.48149-1-yangyicong@huawei.com/ Change since v2: - Fix one possible issue for dereferencing a NULL pointer Link: https://lore.kernel.org/linux-pci/20230331070310.5465-1-yangyicong@huawei.com/ Change since v1: - Drop the patch for handling the cpumask since it seems to be redundant - Refine of the codes per Jonathan - Add Patch 1/4 for refactor the filters allocation and release - Thanks the review of Jonathan. Link: https://lore.kernel.org/linux-pci/d496ee4f-641a-a726-ab3f-62b587422b61@huawei.com/T/#m47e4de552d69920035214b3e91080cdc185f61f5 Yicong Yang (5): hwtracing: hisi_ptt: Factor out filter allocation and release operation hwtracing: hisi_ptt: Add support for dynamically updating the filter list hwtracing: hisi_ptt: Export available filters through sysfs hwtracing: hisi_ptt: Advertise PERF_PMU_CAP_NO_EXCLUDE for PTT PMU hwtracing: hisi_ptt: Fix potential sleep in atomic context .../ABI/testing/sysfs-devices-hisi_ptt | 52 ++ Documentation/trace/hisi-ptt.rst | 12 +- drivers/hwtracing/ptt/hisi_ptt.c | 444 ++++++++++++++++-- drivers/hwtracing/ptt/hisi_ptt.h | 56 +++ 4 files changed, 526 insertions(+), 38 deletions(-) -- 2.24.0