[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250715191143.1023512-5-rrichter@amd.com>
Date: Tue, 15 Jul 2025 21:11:27 +0200
From: Robert Richter <rrichter@....com>
To: Alison Schofield <alison.schofield@...el.com>, Vishal Verma
<vishal.l.verma@...el.com>, Ira Weiny <ira.weiny@...el.com>, Dan Williams
<dan.j.williams@...el.com>, Jonathan Cameron <Jonathan.Cameron@...wei.com>,
Dave Jiang <dave.jiang@...el.com>, Davidlohr Bueso <dave@...olabs.net>
CC: <linux-cxl@...r.kernel.org>, <linux-kernel@...r.kernel.org>, Gregory Price
<gourry@...rry.net>, "Fabio M. De Francesco"
<fabio.m.de.francesco@...ux.intel.com>, Terry Bowman <terry.bowman@....com>,
Robert Richter <rrichter@....com>
Subject: [PATCH v1 04/20] cxl/region: Add region registration code to new function register_region()
Separate code to register a region from its creation. This splits the
region setup into a creation and registration part. This helps
grouping the code, adds a counterpart to unregister_region() and esp.
simplifies the error handling paths as there is a single exit for a
put_device() on errors.
Signed-off-by: Robert Richter <rrichter@....com>
---
drivers/cxl/core/region.c | 66 +++++++++++++++++++++------------------
1 file changed, 36 insertions(+), 30 deletions(-)
diff --git a/drivers/cxl/core/region.c b/drivers/cxl/core/region.c
index b968050ad3d7..8e2521c6c845 100644
--- a/drivers/cxl/core/region.c
+++ b/drivers/cxl/core/region.c
@@ -2326,6 +2326,9 @@ static void cxl_region_release(struct device *dev)
struct cxl_root_decoder *cxlrd = cxlr->cxlrd;
int id = atomic_read(&cxlrd->region_id);
+ if (cxlr->id < 0)
+ goto out;
+
/*
* Try to reuse the recently idled id rather than the cached
* next id to prevent the region id space from increasing
@@ -2468,6 +2471,7 @@ static struct cxl_region *cxl_region_alloc(struct cxl_root_decoder *cxlrd)
*/
get_device(dev->parent);
cxlr->cxlrd = cxlrd;
+ cxlr->id = -1;
device_set_pm_not_required(dev);
dev->bus = &cxl_bus_type;
@@ -2496,6 +2500,30 @@ static void unregister_region(void *_cxlr)
put_device(&cxlr->dev);
}
+static int register_region(struct cxl_region *cxlr, int id)
+{
+ struct cxl_root_decoder *cxlrd = cxlr->cxlrd;
+ struct device *dev = &cxlr->dev;
+ int rc;
+
+ rc = memregion_alloc(GFP_KERNEL);
+ if (rc < 0)
+ return rc;
+
+ if (atomic_cmpxchg(&cxlrd->region_id, id, rc) != id) {
+ memregion_free(rc);
+ return -EBUSY;
+ }
+
+ cxlr->id = id;
+
+ rc = dev_set_name(dev, "region%d", cxlr->id);
+ if (rc)
+ return rc;
+
+ return device_add(dev);
+}
+
/**
* devm_cxl_add_region - Adds a region to a decoder
* @cxlrd: root decoder
@@ -2516,40 +2544,29 @@ static struct cxl_region *devm_cxl_add_region(struct cxl_root_decoder *cxlrd,
{
struct cxl_port *port = to_cxl_port(cxlrd->cxlsd.cxld.dev.parent);
struct cxl_region *cxlr;
- struct device *dev;
int rc;
cxlr = cxl_region_alloc(cxlrd);
- if (IS_ERR(cxlr)) {
- memregion_free(id);
+ if (IS_ERR(cxlr))
return cxlr;
- }
cxlr->mode = mode;
cxlr->type = type;
- dev = &cxlr->dev;
- cxlr->id = id;
-
- rc = dev_set_name(dev, "region%d", id);
- if (rc)
- goto err;
-
- rc = device_add(dev);
- if (rc)
- goto err;
+ rc = register_region(cxlr, id);
+ if (rc) {
+ put_device(&cxlr->dev);
+ return ERR_PTR(rc);
+ }
rc = devm_add_action_or_reset(port->uport_dev, unregister_region, cxlr);
if (rc)
return ERR_PTR(rc);
dev_dbg(port->uport_dev, "%s: created %s\n",
- dev_name(&cxlrd->cxlsd.cxld.dev), dev_name(dev));
- return cxlr;
+ dev_name(cxlr->dev.parent), dev_name(&cxlr->dev));
-err:
- put_device(dev);
- return ERR_PTR(rc);
+ return cxlr;
}
static ssize_t __create_region_show(struct cxl_root_decoder *cxlrd, char *buf)
@@ -2572,8 +2589,6 @@ static ssize_t create_ram_region_show(struct device *dev,
static struct cxl_region *__create_region(struct cxl_root_decoder *cxlrd,
enum cxl_partition_mode mode, int id)
{
- int rc;
-
switch (mode) {
case CXL_PARTMODE_RAM:
case CXL_PARTMODE_PMEM:
@@ -2583,15 +2598,6 @@ static struct cxl_region *__create_region(struct cxl_root_decoder *cxlrd,
return ERR_PTR(-EINVAL);
}
- rc = memregion_alloc(GFP_KERNEL);
- if (rc < 0)
- return ERR_PTR(rc);
-
- if (atomic_cmpxchg(&cxlrd->region_id, id, rc) != id) {
- memregion_free(rc);
- return ERR_PTR(-EBUSY);
- }
-
return devm_cxl_add_region(cxlrd, id, mode, CXL_DECODER_HOSTONLYMEM);
}
--
2.39.5
Powered by blists - more mailing lists