Received: by 2002:a05:7412:f690:b0:e2:908c:2ebd with SMTP id ej16csp68653rdb; Wed, 18 Oct 2023 18:53:13 -0700 (PDT) X-Google-Smtp-Source: AGHT+IG/6kNyPPgiqhQDeX0eOoja9IRneWSOCdLo2AzfJ43cyW52ecuK5kz7+p6+rMMc3+6+DBYp X-Received: by 2002:a17:90a:cf18:b0:27d:166b:40f6 with SMTP id h24-20020a17090acf1800b0027d166b40f6mr933620pju.41.1697680393276; Wed, 18 Oct 2023 18:53:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697680393; cv=none; d=google.com; s=arc-20160816; b=ccmb5z1k2krh94QEdKB12rQTG57Zk/7ag3LwnLEK86ucgoXAcRnyj+/jUQRGaHsTPi J7Rp/jsz+23LW4XjiqObMDJ0UOAhDzjjZ2s7WNYNIg6a6RFRxZugJlnjcfqAQQBJkiMr /v9s+RWP2NPa1tCH/8dW0oYO91mM5fI3iFbJnnRbvfDqQtYRRdfQoOHAB5i7k4lJKx4q qBL5x1rrnBOJ2062pMS1S7vtsmz42xa137k+bY/2WoVtz9K5LQgFgIhy2m7nW0TjE1Im KbJVI5AswNPZL5C2KKoczcPGP/xXniWkaJFjGtnGKz1UFfC73aFvi4beucvl2VdRFycD C93w== 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 :mime-version:user-agent:date:message-id:from:references:to:subject :cc; bh=PFsNX/ldfqUCSd6B7T4rNQGIlUsGA3uJKkZTbvQ2L60=; fh=gp/aV49FLMWPTHMd1b4qW7C/yVuF2Yygx6DOiR9Q5L0=; b=BXAVy5ozjSa6N78ghw8dRRUARy0F5MgDyAMt0ItwRvRRLTObjmn97tu4MR+cnJm1n7 XW5E2sE/5ex0VnHDEOUZD8xQwIRNdW2jIVXbBlihvLsBf8A7FH9GuAKoiETIMDd344kI mcHzTUtnvETb+k01sniEK9gb6FDLWV48xEwOS5oOkKYRFHXiES1ihZ4Mrm8k5vSohPMj H7tRMpkwRCkO/OoVhjDR1h7T90fo2oxrLv1wXyWf4wCAeGTcVZhImUnZy1BECvqF/v4+ UEppICyali4bTVI7m2DTTCFK09nVRf0Wx6e3058lmKUTn5GReSCRP/iRPMNj92Efwr8V p8Uw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 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 pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id e24-20020a17090a9a9800b00278ff770796si1121929pjp.88.2023.10.18.18.53.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 Oct 2023 18:53:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 8FE648028436; Wed, 18 Oct 2023 18:53:06 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232241AbjJSBwq (ORCPT + 99 others); Wed, 18 Oct 2023 21:52:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34670 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231470AbjJSBwp (ORCPT ); Wed, 18 Oct 2023 21:52:45 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0057A9F for ; Wed, 18 Oct 2023 18:52:42 -0700 (PDT) Received: from canpemm500009.china.huawei.com (unknown [172.30.72.53]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4S9rGV1vk3zLpKZ; Thu, 19 Oct 2023 09:48:34 +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.31; Thu, 19 Oct 2023 09:52:27 +0800 CC: , , , , , Subject: Re: [PATCH V2 drivers/perf: hisi:] drivers/perf: hisi: use cpuhp_state_remove_instance_nocalls() for hns3 pmu uninit process To: Jijie Shao , , , , References: <20231016105139.1436425-1-shaojijie@huawei.com> From: Yicong Yang Message-ID: <46461fdf-575d-fa32-28b8-420bf0e54210@huawei.com> Date: Thu, 19 Oct 2023 09:52:27 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.5.1 MIME-Version: 1.0 In-Reply-To: <20231016105139.1436425-1-shaojijie@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.67.121.177] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To canpemm500009.china.huawei.com (7.192.105.203) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.1 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.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 (pete.vger.email [0.0.0.0]); Wed, 18 Oct 2023 18:53:06 -0700 (PDT) On 2023/10/16 18:51, Jijie Shao wrote: > From: Hao Chen > > For pmu uninit process, we unregister pmu and then call cpuhp_state_remove_instance() > to call callback function to migrate pmu context. the logic is unreasonable and > may result in NULL pointer call trace. > > Found NULL pointer call trace for kernel-5.13 at the first time, log shows as below: > Unable to handle kernel NULL pointer dereference at virtual address 0000000000000000 > [27169.471153] Mem abort info: > [27169.478859] ESR = 0x96000006 > [27169.485117] EC = 0x25: DABT (current EL), IL = 32 bits > [27169.501386] SET = 0, FnV = 0 > [27169.508038] EA = 0, S1PTW = 0 > [27169.559839] Data abort info: > [27169.567296] ISV = 0, ISS = 0x00000006 > [27169.585332] CM = 0, WnR = 0 > [27169.592627] user pgtable: 4k pages, 48-bit VAs, pgdp=00000820ac0c2000 > [27169.615618] [0000000000000000] pgd=00000820af2bf003, p4d=00000820af2bf003, pud=00000820af2bd003, pmd=0000000000000000 > [27169.641348] Internal error: Oops: 96000006 [#1] PREEMPT SMP > [27169.649879] Modules linked in: hisi_hns3_pmu(-) hns3 hclge hclgevf hnae3 hns3_cae(O) vfio_iommu_type1 vfio_pci vfio_virqfd vfio pv680_mii(O) [last unloaded: hisi_hns3_pmu] > [27169.675150] CPU: 0 PID: 15 Comm: cpuhp/0 Tainted: G W O 5.12.0-rc4+ #1 > [27169.686538] Hardware name: , BIOS KpxxxFPGA 1P B600 V143 04/22/2021 > [27169.694884] pstate: 80400009 (Nzcv daif +PAN -UAO -TCO BTYPE=--) > [27169.704199] pc : perf_pmu_migrate_context+0x98/0x38c > [27169.713848] lr : perf_pmu_migrate_context+0x94/0x38c > [27169.723069] sp : ffff80001020bc80 > [27169.727938] x29: ffff80001020bc80 x28: 0000000000000000 > [27169.737236] x27: 0000000000000001 x26: fffffbffeff951d8 > [27169.745245] x25: ffffb7ae1ce36fd0 x24: fffffbffeff95178 > [27169.753116] x23: ffff0821f6f82668 x22: 0000000000000001 > [27169.760949] x21: ffff80001020bd08 x20: fffffbffeffb5188 > [27169.768467] x19: fffffbffeffb5178 x18: 0000000000000020 > [27169.776699] x17: 0000000000000000 x16: 0000000000000000 > [27169.785042] x15: 0000000000000004 x14: ffff08208093d290 > [27169.793254] x13: 0000000000000000 x12: 0000497f0149bafe > [27169.801390] x11: 01262d2f8bbfdccc x10: 3dc70ddec1e5f4f9 > [27169.808896] x9 : ffffb7ae1a7eb108 x8 : 0000000000000002 > [27169.817000] x7 : 0000000000000000 x6 : 000000000000000e > [27169.824726] x5 : 0000000000000001 x4 : 0000000000000000 > [27169.832924] x3 : 0000000000000000 x2 : ffff082080a30e80 > [27169.841135] x1 : 0000000000000000 x0 : fffffbffeffb5188 > [27169.849059] Call trace: > [27169.853177] perf_pmu_migrate_context+0x98/0x38c > [27169.862256] hisi_hns3_pmu_offline_cpu+0x104/0x12c [hisi_hns3_pmu] > [27169.873943] cpuhp_invoke_callback+0x118/0x634 > [27169.882775] cpuhp_thread_fun+0xe8/0x190 > [27169.890345] smpboot_thread_fn+0x25c/0x290 > [27169.898241] kthread+0x168/0x16c > [27169.904178] ret_from_fork+0x10/0x18 > [27169.911943] Code: 944beda1 aa1403e0 944bed9f f8460f5c (f9400394) > > And tested some other uncore pmu driver such as hisi pcie pmu and hisi uncore i3c pmu, It's l3c pmu, not i3c pmu. Please just use the driver name like hisi_pcie_pmu or hisi_uncore_l3c_pmu in the commit. So is below. Others looks good to me. With this fixed, Reviewed-by: Yicong Yang > hisi pcie pmu driver can reproduce it also, and change hisi uncore i3c pmu hotplug > function from cpuhp_state_remove_instance_nocalls() to cpuhp_state_remove_instance(), > it has the same call trace. > > This patch change cpuhp_state_remove_instance() to cpuhp_state_remove_instance_nocalls() > after pmu unregistered to fix the problem. > > This problem is fixed by commit bd2756811766 ("perf: Rewrite core context handling") > for kernel-6.2. > > Hisi hns3 pmu driver is supported for kernel-5.19, so, use this patch as bugfix for > stable 6.0 and 6.1 tag, and use this patch as cleanup for newest kernel version. > > Fixes: 66637ab137b4 ("drivers/perf: hisi: add driver for HNS3 PMU") > Signed-off-by: Hao Chen > Signed-off-by: Jijie Shao > --- > ChangeLog: > 1. Add more details for NULL pointer call trace suggested by Yicong > V1: https://lore.kernel.org/all/20231009105038.126040-1-shaojijie@huawei.com/ > --- > drivers/perf/hisilicon/hns3_pmu.c | 8 ++++---- > 1 file changed, 4 insertions(+), 4 deletions(-) > > diff --git a/drivers/perf/hisilicon/hns3_pmu.c b/drivers/perf/hisilicon/hns3_pmu.c > index e0457d84af6b..16869bf5bf4c 100644 > --- a/drivers/perf/hisilicon/hns3_pmu.c > +++ b/drivers/perf/hisilicon/hns3_pmu.c > @@ -1556,8 +1556,8 @@ static int hns3_pmu_init_pmu(struct pci_dev *pdev, struct hns3_pmu *hns3_pmu) > ret = perf_pmu_register(&hns3_pmu->pmu, hns3_pmu->pmu.name, -1); > if (ret) { > pci_err(pdev, "failed to register perf PMU, ret = %d.\n", ret); > - cpuhp_state_remove_instance(CPUHP_AP_PERF_ARM_HNS3_PMU_ONLINE, > - &hns3_pmu->node); > + cpuhp_state_remove_instance_nocalls(CPUHP_AP_PERF_ARM_HNS3_PMU_ONLINE, > + &hns3_pmu->node); > } > > return ret; > @@ -1568,8 +1568,8 @@ static void hns3_pmu_uninit_pmu(struct pci_dev *pdev) > struct hns3_pmu *hns3_pmu = pci_get_drvdata(pdev); > > perf_pmu_unregister(&hns3_pmu->pmu); > - cpuhp_state_remove_instance(CPUHP_AP_PERF_ARM_HNS3_PMU_ONLINE, > - &hns3_pmu->node); > + cpuhp_state_remove_instance_nocalls(CPUHP_AP_PERF_ARM_HNS3_PMU_ONLINE, > + &hns3_pmu->node); > } > > static int hns3_pmu_init_dev(struct pci_dev *pdev) >