@@ -3345,7 +3345,7 @@ static struct cxl_region *construct_region(struct cxl_root_decoder *cxlrd,
dev_name(&cxlr->dev), p->res, p->interleave_ways,
p->interleave_granularity);
- /* ...to match put_device() in cxl_add_to_region() */
+ /* ...to match put_device() in cxl_endpoint_decoder_add() */
get_device(&cxlr->dev);
up_write(&cxl_region_rwsem);
@@ -3357,19 +3357,28 @@ static struct cxl_region *construct_region(struct cxl_root_decoder *cxlrd,
return ERR_PTR(rc);
}
-int cxl_add_to_region(struct cxl_endpoint_decoder *cxled)
+static int cxl_endpoint_decoder_initialize(struct cxl_endpoint_decoder *cxled)
{
- struct range *hpa = &cxled->cxld.hpa_range;
struct cxl_root_decoder *cxlrd;
- struct cxl_region_params *p;
- struct cxl_region *cxlr;
- bool attach = false;
- int rc;
cxlrd = cxl_find_root_decoder(cxled);
if (!cxlrd)
return -ENXIO;
+ cxled->cxlrd = cxlrd;
+
+ return 0;
+}
+
+static int cxl_endpoint_decoder_add(struct cxl_endpoint_decoder *cxled)
+{
+ struct range *hpa = &cxled->cxld.hpa_range;
+ struct cxl_root_decoder *cxlrd = cxled->cxlrd;
+ struct cxl_region_params *p;
+ struct cxl_region *cxlr;
+ bool attach = false;
+ int rc;
+
/*
* Ensure that if multiple threads race to construct_region() for @hpa
* one does the construction and the others add to that.
@@ -3406,7 +3415,18 @@ int cxl_add_to_region(struct cxl_endpoint_decoder *cxled)
return rc;
}
-EXPORT_SYMBOL_NS_GPL(cxl_add_to_region, "CXL");
+
+int cxl_endpoint_decoder_register(struct cxl_endpoint_decoder *cxled)
+{
+ int rc;
+
+ rc = cxl_endpoint_decoder_initialize(cxled);
+ if (rc)
+ return rc;
+
+ return cxl_endpoint_decoder_add(cxled);
+}
+EXPORT_SYMBOL_NS_GPL(cxl_endpoint_decoder_register, "CXL");
static int is_system_ram(struct resource *res, void *arg)
{
@@ -392,6 +392,7 @@ enum cxl_decoder_state {
*/
struct cxl_endpoint_decoder {
struct cxl_decoder cxld;
+ struct cxl_root_decoder *cxlrd;
struct resource *dpa_res;
resource_size_t skip;
enum cxl_decoder_state state;
@@ -854,7 +855,7 @@ struct cxl_nvdimm_bridge *cxl_find_nvdimm_bridge(struct cxl_port *port);
#ifdef CONFIG_CXL_REGION
bool is_cxl_pmem_region(struct device *dev);
struct cxl_pmem_region *to_cxl_pmem_region(struct device *dev);
-int cxl_add_to_region(struct cxl_endpoint_decoder *cxled);
+int cxl_endpoint_decoder_register(struct cxl_endpoint_decoder *cxled);
struct cxl_dax_region *to_cxl_dax_region(struct device *dev);
#else
static inline bool is_cxl_pmem_region(struct device *dev)
@@ -865,7 +866,8 @@ static inline struct cxl_pmem_region *to_cxl_pmem_region(struct device *dev)
{
return NULL;
}
-static inline int cxl_add_to_region(struct cxl_endpoint_decoder *cxled)
+static inline int
+cxl_endpoint_decoder_register(struct cxl_endpoint_decoder *cxled)
{
return 0;
}
@@ -46,13 +46,14 @@ static int discover_region(struct device *dev, void *unused)
return 0;
/*
- * Region enumeration is opportunistic, if this add-event fails,
+ * Region enumeration is opportunistic, ignore errors and
* continue to the next endpoint decoder.
*/
- rc = cxl_add_to_region(cxled);
+ rc = cxl_endpoint_decoder_register(cxled);
if (rc)
- dev_dbg(dev, "failed to add to region: %#llx-%#llx\n",
- cxled->cxld.hpa_range.start, cxled->cxld.hpa_range.end);
+ dev_warn(cxled->cxld.dev.parent,
+ "failed to register %s: %d\n",
+ dev_name(&cxled->cxld.dev), rc);
return 0;
}