* Re: [PATCH v3 2/2] perf/dwc_pcie: fix duplicate pci_dev devices [not found] ` <20250208104002.60332-3-cuiyunhui@bytedance.com> @ 2025-02-11 8:01 ` Shuai Xue 2025-02-18 8:46 ` [External] " yunhui cui 0 siblings, 1 reply; 4+ messages in thread From: Shuai Xue @ 2025-02-11 8:01 UTC (permalink / raw) To: Yunhui Cui, renyu.zj, will, mark.rutland, linux-arm-kernel, linux-perf-users, linux-kernel, Jonathan Cameron, Bjorn Helgaas, linux-pci 在 2025/2/8 18:40, Yunhui Cui 写道: > During platform_device_register, wrongly using struct device > pci_dev as platform_data caused a kmemdup copy of pci_dev. Worse > still, accessing the duplicated device leads to list corruption as its > mutex content (e.g., list, magic) remains the same as the original. > > Signed-off-by: Yunhui Cui <cuiyunhui@bytedance.com> > --- > drivers/perf/dwc_pcie_pmu.c | 20 +++++++++++++------- > 1 file changed, 13 insertions(+), 7 deletions(-) > > diff --git a/drivers/perf/dwc_pcie_pmu.c b/drivers/perf/dwc_pcie_pmu.c > index 19fa2ba8dd67..4f6599e32bba 100644 > --- a/drivers/perf/dwc_pcie_pmu.c > +++ b/drivers/perf/dwc_pcie_pmu.c > @@ -565,9 +565,7 @@ static int dwc_pcie_register_dev(struct pci_dev *pdev) > u32 sbdf; > > sbdf = (pci_domain_nr(pdev->bus) << 16) | PCI_DEVID(pdev->bus->number, pdev->devfn); > - plat_dev = platform_device_register_data(NULL, "dwc_pcie_pmu", sbdf, > - pdev, sizeof(*pdev)); > - > + plat_dev = platform_device_register_simple("platform_dwc_pcie", sbdf, NULL, 0); > if (IS_ERR(plat_dev)) > return PTR_ERR(plat_dev); > > @@ -616,18 +614,26 @@ static struct notifier_block dwc_pcie_pmu_nb = { > > static int dwc_pcie_pmu_probe(struct platform_device *plat_dev) > { > - struct pci_dev *pdev = plat_dev->dev.platform_data; > + struct pci_dev *pdev; > struct dwc_pcie_pmu *pcie_pmu; > char *name; > u32 sbdf; > u16 vsec; > int ret; > > + sbdf = plat_dev->id; > + pdev = pci_get_domain_bus_and_slot(sbdf >> 16, PCI_BUS_NUM(sbdf & 0xffff), > + sbdf & 0xff); > + if (!pdev) { > + pr_err("No pdev found for the sbdf 0x%x\n", sbdf); > + return -ENODEV; > + } > + > vsec = dwc_pcie_des_cap(pdev); > if (!vsec) > return -ENODEV; pci_dev_put(pdev) should move ahead to aovid return here. > > - sbdf = plat_dev->id; > + pci_dev_put(pdev); > name = devm_kasprintf(&plat_dev->dev, GFP_KERNEL, "dwc_rootport_%x", sbdf); > if (!name) > return -ENOMEM; > @@ -642,7 +648,7 @@ static int dwc_pcie_pmu_probe(struct platform_device *plat_dev) > pcie_pmu->on_cpu = -1; > pcie_pmu->pmu = (struct pmu){ > .name = name, > - .parent = &pdev->dev, > + .parent = &plat_dev->dev, > .module = THIS_MODULE, > .attr_groups = dwc_pcie_attr_groups, > .capabilities = PERF_PMU_CAP_NO_EXCLUDE, > @@ -729,7 +735,7 @@ static int dwc_pcie_pmu_offline_cpu(unsigned int cpu, struct hlist_node *cpuhp_n > > static struct platform_driver dwc_pcie_pmu_driver = { > .probe = dwc_pcie_pmu_probe, > - .driver = {.name = "dwc_pcie_pmu",}, > + .driver = {.name = "platform_dwc_pcie",}, Aha, it is very difficult to come up with a name that satisfies everyone. The original name uses the '_pmu' suffix to follow the unwritten convention of other PMU drivers. Personally, I think the original name is more appropriate, but I'll leave the decision to @Will. Thanks. Best Regards. Shuai ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [External] Re: [PATCH v3 2/2] perf/dwc_pcie: fix duplicate pci_dev devices 2025-02-11 8:01 ` [PATCH v3 2/2] perf/dwc_pcie: fix duplicate pci_dev devices Shuai Xue @ 2025-02-18 8:46 ` yunhui cui 0 siblings, 0 replies; 4+ messages in thread From: yunhui cui @ 2025-02-18 8:46 UTC (permalink / raw) To: Shuai Xue Cc: renyu.zj, will, mark.rutland, linux-arm-kernel, linux-perf-users, linux-kernel, Jonathan Cameron, Bjorn Helgaas, linux-pci Hi Shuai, On Tue, Feb 11, 2025 at 4:02 PM Shuai Xue <xueshuai@linux.alibaba.com> wrote: > > > > 在 2025/2/8 18:40, Yunhui Cui 写道: > > During platform_device_register, wrongly using struct device > > pci_dev as platform_data caused a kmemdup copy of pci_dev. Worse > > still, accessing the duplicated device leads to list corruption as its > > mutex content (e.g., list, magic) remains the same as the original. > > > > Signed-off-by: Yunhui Cui <cuiyunhui@bytedance.com> > > --- > > drivers/perf/dwc_pcie_pmu.c | 20 +++++++++++++------- > > 1 file changed, 13 insertions(+), 7 deletions(-) > > > > diff --git a/drivers/perf/dwc_pcie_pmu.c b/drivers/perf/dwc_pcie_pmu.c > > index 19fa2ba8dd67..4f6599e32bba 100644 > > --- a/drivers/perf/dwc_pcie_pmu.c > > +++ b/drivers/perf/dwc_pcie_pmu.c > > @@ -565,9 +565,7 @@ static int dwc_pcie_register_dev(struct pci_dev *pdev) > > u32 sbdf; > > > > sbdf = (pci_domain_nr(pdev->bus) << 16) | PCI_DEVID(pdev->bus->number, pdev->devfn); > > - plat_dev = platform_device_register_data(NULL, "dwc_pcie_pmu", sbdf, > > - pdev, sizeof(*pdev)); > > - > > + plat_dev = platform_device_register_simple("platform_dwc_pcie", sbdf, NULL, 0); > > if (IS_ERR(plat_dev)) > > return PTR_ERR(plat_dev); > > > > @@ -616,18 +614,26 @@ static struct notifier_block dwc_pcie_pmu_nb = { > > > > static int dwc_pcie_pmu_probe(struct platform_device *plat_dev) > > { > > - struct pci_dev *pdev = plat_dev->dev.platform_data; > > + struct pci_dev *pdev; > > struct dwc_pcie_pmu *pcie_pmu; > > char *name; > > u32 sbdf; > > u16 vsec; > > int ret; > > > > + sbdf = plat_dev->id; > > + pdev = pci_get_domain_bus_and_slot(sbdf >> 16, PCI_BUS_NUM(sbdf & 0xffff), > > + sbdf & 0xff); > > + if (!pdev) { > > + pr_err("No pdev found for the sbdf 0x%x\n", sbdf); > > + return -ENODEV; > > + } > > + > > vsec = dwc_pcie_des_cap(pdev); > > if (!vsec) > > return -ENODEV; > > pci_dev_put(pdev) should move ahead to aovid return here. > > > > > - sbdf = plat_dev->id; > > + pci_dev_put(pdev); > > name = devm_kasprintf(&plat_dev->dev, GFP_KERNEL, "dwc_rootport_%x", sbdf); > > if (!name) > > return -ENOMEM; > > @@ -642,7 +648,7 @@ static int dwc_pcie_pmu_probe(struct platform_device *plat_dev) > > pcie_pmu->on_cpu = -1; > > pcie_pmu->pmu = (struct pmu){ > > .name = name, > > - .parent = &pdev->dev, > > + .parent = &plat_dev->dev, > > .module = THIS_MODULE, > > .attr_groups = dwc_pcie_attr_groups, > > .capabilities = PERF_PMU_CAP_NO_EXCLUDE, > > @@ -729,7 +735,7 @@ static int dwc_pcie_pmu_offline_cpu(unsigned int cpu, struct hlist_node *cpuhp_n > > > > static struct platform_driver dwc_pcie_pmu_driver = { > > .probe = dwc_pcie_pmu_probe, > > - .driver = {.name = "dwc_pcie_pmu",}, > > + .driver = {.name = "platform_dwc_pcie",}, > > Aha, it is very difficult to come up with a name that satisfies everyone. The > original name uses the '_pmu' suffix to follow the unwritten convention of > other PMU drivers. > > Personally, I think the original name is more appropriate, but I'll leave the > decision to @Will. Since Will hasn't replied, I'll update to the next version to keep the original name. > > Thanks. > Best Regards. > Shuai Thanks, Yunhui ^ permalink raw reply [flat|nested] 4+ messages in thread
[parent not found: <20250208104002.60332-2-cuiyunhui@bytedance.com>]
* Re: [PATCH v3 1/2] perf/dwc_pcie: fix some unreleased resources [not found] ` <20250208104002.60332-2-cuiyunhui@bytedance.com> @ 2025-02-11 8:05 ` Shuai Xue 2025-02-18 8:31 ` [External] " yunhui cui 0 siblings, 1 reply; 4+ messages in thread From: Shuai Xue @ 2025-02-11 8:05 UTC (permalink / raw) To: Yunhui Cui, renyu.zj, will, mark.rutland, linux-arm-kernel, linux-perf-users, linux-kernel, Bjorn Helgaas, Jonathan Cameron, linux-pci 在 2025/2/8 18:40, Yunhui Cui 写道: > Release leaked resources, such as plat_dev and dev_info. > > Signed-off-by: Yunhui Cui <cuiyunhui@bytedance.com> > --- > drivers/perf/dwc_pcie_pmu.c | 33 ++++++++++++++++++++++----------- > 1 file changed, 22 insertions(+), 11 deletions(-) > > diff --git a/drivers/perf/dwc_pcie_pmu.c b/drivers/perf/dwc_pcie_pmu.c > index cccecae9823f..19fa2ba8dd67 100644 > --- a/drivers/perf/dwc_pcie_pmu.c > +++ b/drivers/perf/dwc_pcie_pmu.c > @@ -572,8 +572,10 @@ static int dwc_pcie_register_dev(struct pci_dev *pdev) > return PTR_ERR(plat_dev); > > dev_info = kzalloc(sizeof(*dev_info), GFP_KERNEL); > - if (!dev_info) > + if (!dev_info) { > + platform_device_unregister(plat_dev); > return -ENOMEM; > + } > > /* Cache platform device to handle pci device hotplug */ > dev_info->plat_dev = plat_dev; > @@ -730,6 +732,15 @@ static struct platform_driver dwc_pcie_pmu_driver = { > .driver = {.name = "dwc_pcie_pmu",}, > }; > > +static void dwc_pcie_cleanup_devices(void) > +{ > + struct dwc_pcie_dev_info *dev_info, *tmp; > + > + list_for_each_entry_safe(dev_info, tmp, &dwc_pcie_dev_info_head, dev_node) { > + dwc_pcie_unregister_dev(dev_info); > + } > +} > + > static int __init dwc_pcie_pmu_init(void) > { > struct pci_dev *pdev = NULL; > @@ -742,7 +753,7 @@ static int __init dwc_pcie_pmu_init(void) > ret = dwc_pcie_register_dev(pdev); > if (ret) { > pci_dev_put(pdev); Should we get a reference count of pdev in dwc_pcie_register_dev and put it in dwc_pcie_unregister_dev? Thanks. Shuai ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [External] Re: [PATCH v3 1/2] perf/dwc_pcie: fix some unreleased resources 2025-02-11 8:05 ` [PATCH v3 1/2] perf/dwc_pcie: fix some unreleased resources Shuai Xue @ 2025-02-18 8:31 ` yunhui cui 0 siblings, 0 replies; 4+ messages in thread From: yunhui cui @ 2025-02-18 8:31 UTC (permalink / raw) To: Shuai Xue Cc: renyu.zj, will, mark.rutland, linux-arm-kernel, linux-perf-users, linux-kernel, Bjorn Helgaas, Jonathan Cameron, linux-pci Hi Shuai, On Tue, Feb 11, 2025 at 4:05 PM Shuai Xue <xueshuai@linux.alibaba.com> wrote: > > > > 在 2025/2/8 18:40, Yunhui Cui 写道: > > Release leaked resources, such as plat_dev and dev_info. > > > > Signed-off-by: Yunhui Cui <cuiyunhui@bytedance.com> > > --- > > drivers/perf/dwc_pcie_pmu.c | 33 ++++++++++++++++++++++----------- > > 1 file changed, 22 insertions(+), 11 deletions(-) > > > > diff --git a/drivers/perf/dwc_pcie_pmu.c b/drivers/perf/dwc_pcie_pmu.c > > index cccecae9823f..19fa2ba8dd67 100644 > > --- a/drivers/perf/dwc_pcie_pmu.c > > +++ b/drivers/perf/dwc_pcie_pmu.c > > @@ -572,8 +572,10 @@ static int dwc_pcie_register_dev(struct pci_dev *pdev) > > return PTR_ERR(plat_dev); > > > > dev_info = kzalloc(sizeof(*dev_info), GFP_KERNEL); > > - if (!dev_info) > > + if (!dev_info) { > > + platform_device_unregister(plat_dev); > > return -ENOMEM; > > + } > > > > /* Cache platform device to handle pci device hotplug */ > > dev_info->plat_dev = plat_dev; > > @@ -730,6 +732,15 @@ static struct platform_driver dwc_pcie_pmu_driver = { > > .driver = {.name = "dwc_pcie_pmu",}, > > }; > > > > +static void dwc_pcie_cleanup_devices(void) > > +{ > > + struct dwc_pcie_dev_info *dev_info, *tmp; > > + > > + list_for_each_entry_safe(dev_info, tmp, &dwc_pcie_dev_info_head, dev_node) { > > + dwc_pcie_unregister_dev(dev_info); > > + } > > +} > > + > > static int __init dwc_pcie_pmu_init(void) > > { > > struct pci_dev *pdev = NULL; > > @@ -742,7 +753,7 @@ static int __init dwc_pcie_pmu_init(void) > > ret = dwc_pcie_register_dev(pdev); > > if (ret) { > > pci_dev_put(pdev); > > Should we get a reference count of pdev in dwc_pcie_register_dev and put it in > dwc_pcie_unregister_dev? Personally, it's not an issue because RP devices are generally not unloaded. > > Thanks. > Shuai > Thanks, Yunhui ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2025-02-18 8:46 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20250208104002.60332-1-cuiyunhui@bytedance.com>
[not found] ` <20250208104002.60332-3-cuiyunhui@bytedance.com>
2025-02-11 8:01 ` [PATCH v3 2/2] perf/dwc_pcie: fix duplicate pci_dev devices Shuai Xue
2025-02-18 8:46 ` [External] " yunhui cui
[not found] ` <20250208104002.60332-2-cuiyunhui@bytedance.com>
2025-02-11 8:05 ` [PATCH v3 1/2] perf/dwc_pcie: fix some unreleased resources Shuai Xue
2025-02-18 8:31 ` [External] " yunhui cui
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox