From: Salah Triki <salah.triki@gmail.com>
To: "Rafał Miłecki" <zajec5@gmail.com>,
linux-wireless@vger.kernel.org, linux-kernel@vger.kernel.org
Cc: salah.triki@gmail.com
Subject: [PATCH] bcma: Use managed APIs
Date: Sat, 19 Jul 2025 15:43:22 +0100 [thread overview]
Message-ID: <aHuvCpFcC2DwBU1P@pc> (raw)
Replace pci_* with pcim_* and kzalloc() with devm_kzalloc() so that no
need to worry about freeing resources and disabling the device.
Signed-off-by: Salah Triki <salah.triki@gmail.com>
---
drivers/bcma/host_pci.c | 39 ++++++++++++++-------------------------
1 file changed, 14 insertions(+), 25 deletions(-)
diff --git a/drivers/bcma/host_pci.c b/drivers/bcma/host_pci.c
index 960632197b05..665990b8afb5 100644
--- a/drivers/bcma/host_pci.c
+++ b/drivers/bcma/host_pci.c
@@ -10,6 +10,7 @@
#include <linux/bcma/bcma.h>
#include <linux/pci.h>
#include <linux/module.h>
+#include <linux/serdev.h>
static void bcma_host_pci_switch_core(struct bcma_device *core)
{
@@ -161,22 +162,23 @@ static int bcma_host_pci_probe(struct pci_dev *dev,
const struct pci_device_id *id)
{
struct bcma_bus *bus;
- int err = -ENOMEM;
+ int err;
u32 val;
/* Alloc */
- bus = kzalloc(sizeof(*bus), GFP_KERNEL);
+ bus = devm_kzalloc(&dev->dev, sizeof(*bus), GFP_KERNEL);
if (!bus)
- goto out;
+ return -ENOMEM;
/* Basic PCI configuration */
- err = pci_enable_device(dev);
+ err = pcim_enable_device(dev);
if (err)
- goto err_kfree_bus;
+ return err;
- err = pci_request_regions(dev, "bcma-pci-bridge");
+ err = pcim_request_all_regions(dev, "bcma-pci-bridge");
if (err)
- goto err_pci_disable;
+ return err;
+
pci_set_master(dev);
/* Disable the RETRY_TIMEOUT register (0x41) to keep
@@ -188,17 +190,16 @@ static int bcma_host_pci_probe(struct pci_dev *dev,
/* SSB needed additional powering up, do we have any AMBA PCI cards? */
if (!pci_is_pcie(dev)) {
bcma_err(bus, "PCI card detected, they are not supported.\n");
- err = -ENXIO;
- goto err_pci_release_regions;
+ return -ENXIO;
}
bus->dev = &dev->dev;
/* Map MMIO */
err = -ENOMEM;
- bus->mmio = pci_iomap(dev, 0, ~0UL);
+ bus->mmio = pcim_iomap(dev, 0, ~0UL);
if (!bus->mmio)
- goto err_pci_release_regions;
+ return err;
/* Host specific */
bus->host_pci = dev;
@@ -214,7 +215,7 @@ static int bcma_host_pci_probe(struct pci_dev *dev,
/* Scan bus to find out generation of PCIe core */
err = bcma_bus_scan(bus);
if (err)
- goto err_pci_unmap_mmio;
+ return err;
if (bcma_find_core(bus, BCMA_CORE_PCIE2))
bus->host_is_pcie2 = true;
@@ -226,19 +227,11 @@ static int bcma_host_pci_probe(struct pci_dev *dev,
pci_set_drvdata(dev, bus);
-out:
return err;
err_unregister_cores:
bcma_unregister_cores(bus);
-err_pci_unmap_mmio:
- pci_iounmap(dev, bus->mmio);
-err_pci_release_regions:
- pci_release_regions(dev);
-err_pci_disable:
- pci_disable_device(dev);
-err_kfree_bus:
- kfree(bus);
+
return err;
}
@@ -247,10 +240,6 @@ static void bcma_host_pci_remove(struct pci_dev *dev)
struct bcma_bus *bus = pci_get_drvdata(dev);
bcma_bus_unregister(bus);
- pci_iounmap(dev, bus->mmio);
- pci_release_regions(dev);
- pci_disable_device(dev);
- kfree(bus);
}
#ifdef CONFIG_PM_SLEEP
--
2.43.0
next reply other threads:[~2025-07-19 14:43 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-19 14:43 Salah Triki [this message]
2025-07-19 15:52 ` [PATCH v2] bcma: Use managed APIs Salah Triki
2025-07-19 15:54 ` Johannes Berg
2025-07-19 16:19 ` [PATCH v3] " Salah Triki
2025-07-19 17:21 ` Jeff Johnson
2025-07-19 18:38 ` Salah Triki
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aHuvCpFcC2DwBU1P@pc \
--to=salah.triki@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-wireless@vger.kernel.org \
--cc=zajec5@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.