Message ID | 166931492718.2104015.1866183528350401708.stgit@dwillia2-xfh.jf.intel.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | cxl: Add support for Restricted CXL hosts (RCD mode) | expand |
On 24.11.22 10:35:27, Dan Williams wrote: > In preparation for devm_cxl_add_endpoint() to call out to > cxl_rcrb_to_component() to map the upstream port component registers, > move devm_cxl_add_endpoint() from the cxl_core to the cxl_mem driver. > This is due to the organization of cxl_test that mandates that the > cxl_core not call out to any mocked symbols. It also cleans up the > export of devm_cxl_add_endpoint() which is just a wrapper around > devm_cxl_add_port(). The last sentense is unclear to me? I see you just make it static as there is only a single user, do you mean that here? The change itself looks good. > > Signed-off-by: Dan Williams <dan.j.williams@intel.com> Reviewed-by: Robert Richter <rrichter@amd.com> > --- > drivers/cxl/core/core.h | 8 -------- > drivers/cxl/core/port.c | 39 --------------------------------------- > drivers/cxl/cxl.h | 2 -- > drivers/cxl/cxlmem.h | 9 +++++++++ > drivers/cxl/mem.c | 38 ++++++++++++++++++++++++++++++++++++++ > 5 files changed, 47 insertions(+), 49 deletions(-)
On 28.11.22 20:50:16, Robert Richter wrote: > On 24.11.22 10:35:27, Dan Williams wrote: > > In preparation for devm_cxl_add_endpoint() to call out to > > cxl_rcrb_to_component() to map the upstream port component registers, > > move devm_cxl_add_endpoint() from the cxl_core to the cxl_mem driver. > > This is due to the organization of cxl_test that mandates that the > > cxl_core not call out to any mocked symbols. It also cleans up the > > export of devm_cxl_add_endpoint() which is just a wrapper around > > devm_cxl_add_port(). > > The last sentense is unclear to me? I see you just make it static as > there is only a single user, do you mean that here? The change itself > looks good. Looking at the next patch I think you mean the change of the function i/f of devm_cxl_add_endpoint() here. Please update description. > > > > > Signed-off-by: Dan Williams <dan.j.williams@intel.com> > > Reviewed-by: Robert Richter <rrichter@amd.com> > > > --- > > drivers/cxl/core/core.h | 8 -------- > > drivers/cxl/core/port.c | 39 --------------------------------------- > > drivers/cxl/cxl.h | 2 -- > > drivers/cxl/cxlmem.h | 9 +++++++++ > > drivers/cxl/mem.c | 38 ++++++++++++++++++++++++++++++++++++++ > > 5 files changed, 47 insertions(+), 49 deletions(-)
Robert Richter wrote: > On 24.11.22 10:35:27, Dan Williams wrote: > > In preparation for devm_cxl_add_endpoint() to call out to > > cxl_rcrb_to_component() to map the upstream port component registers, > > move devm_cxl_add_endpoint() from the cxl_core to the cxl_mem driver. > > This is due to the organization of cxl_test that mandates that the > > cxl_core not call out to any mocked symbols. It also cleans up the > > export of devm_cxl_add_endpoint() which is just a wrapper around > > devm_cxl_add_port(). > > The last sentense is unclear to me? I see you just make it static as > there is only a single user, do you mean that here? The change itself > looks good. Yeah, it does read strangely. I changed it to: cxl/mem: Move devm_cxl_add_endpoint() from cxl_core to cxl_mem tl;dr: Clean up an unnecessary export and enable cxl_test. An RCD (Restricted CXL Device), in contrast to a typical CXL device in a VH topology, obtains its component registers from the bottom half of the associated CXL host bridge RCRB (Root Complex Register Block). In turn this means that cxl_rcrb_to_component() needs to be called from devm_cxl_add_endpoint(). Presently devm_cxl_add_endpoint() is part of the CXL core, but the only user is the CXL mem module. Move it from cxl_core to cxl_mem to not only get rid of an unnecessary export, but to also enable its call out to cxl_rcrb_to_component(), in a subsequent patch, to be mocked by cxl_test. Recall that cxl_test can only mock exported symbols, and since cxl_rcrb_to_component() is itself inside the core, all callers must be outside of cxl_core to allow cxl_test to mock it. > Reviewed-by: Robert Richter <rrichter@amd.com>
On 28.11.22 15:42:38, Dan Williams wrote: > Robert Richter wrote: > > On 24.11.22 10:35:27, Dan Williams wrote: > > > In preparation for devm_cxl_add_endpoint() to call out to > > > cxl_rcrb_to_component() to map the upstream port component registers, > > > move devm_cxl_add_endpoint() from the cxl_core to the cxl_mem driver. > > > This is due to the organization of cxl_test that mandates that the > > > cxl_core not call out to any mocked symbols. It also cleans up the > > > export of devm_cxl_add_endpoint() which is just a wrapper around > > > devm_cxl_add_port(). > > > > The last sentense is unclear to me? I see you just make it static as > > there is only a single user, do you mean that here? The change itself > > looks good. > > Yeah, it does read strangely. I changed it to: > > cxl/mem: Move devm_cxl_add_endpoint() from cxl_core to cxl_mem > > tl;dr: Clean up an unnecessary export and enable cxl_test. > > An RCD (Restricted CXL Device), in contrast to a typical CXL device in > a VH topology, obtains its component registers from the bottom half of > the associated CXL host bridge RCRB (Root Complex Register Block). In > turn this means that cxl_rcrb_to_component() needs to be called from > devm_cxl_add_endpoint(). > > Presently devm_cxl_add_endpoint() is part of the CXL core, but the only > user is the CXL mem module. Move it from cxl_core to cxl_mem to not only > get rid of an unnecessary export, but to also enable its call out to > cxl_rcrb_to_component(), in a subsequent patch, to be mocked by > cxl_test. Recall that cxl_test can only mock exported symbols, and since > cxl_rcrb_to_component() is itself inside the core, all callers must be > outside of cxl_core to allow cxl_test to mock it. > > > Reviewed-by: Robert Richter <rrichter@amd.com> Yep, thanks for changing. -Robert
diff --git a/drivers/cxl/core/core.h b/drivers/cxl/core/core.h index 1d8f87be283f..8c04672dca56 100644 --- a/drivers/cxl/core/core.h +++ b/drivers/cxl/core/core.h @@ -58,14 +58,6 @@ extern struct rw_semaphore cxl_dpa_rwsem; bool is_switch_decoder(struct device *dev); struct cxl_switch_decoder *to_cxl_switch_decoder(struct device *dev); -static inline struct cxl_ep *cxl_ep_load(struct cxl_port *port, - struct cxl_memdev *cxlmd) -{ - if (!port) - return NULL; - - return xa_load(&port->endpoints, (unsigned long)&cxlmd->dev); -} int cxl_memdev_init(void); void cxl_memdev_exit(void); diff --git a/drivers/cxl/core/port.c b/drivers/cxl/core/port.c index d9fe06e1462f..c7f58282b2c1 100644 --- a/drivers/cxl/core/port.c +++ b/drivers/cxl/core/port.c @@ -1203,45 +1203,6 @@ static void reap_dports(struct cxl_port *port) } } -int devm_cxl_add_endpoint(struct cxl_memdev *cxlmd, - struct cxl_dport *parent_dport) -{ - struct cxl_port *parent_port = parent_dport->port; - struct cxl_dev_state *cxlds = cxlmd->cxlds; - struct cxl_port *endpoint, *iter, *down; - int rc; - - /* - * Now that the path to the root is established record all the - * intervening ports in the chain. - */ - for (iter = parent_port, down = NULL; !is_cxl_root(iter); - down = iter, iter = to_cxl_port(iter->dev.parent)) { - struct cxl_ep *ep; - - ep = cxl_ep_load(iter, cxlmd); - ep->next = down; - } - - endpoint = devm_cxl_add_port(&parent_port->dev, &cxlmd->dev, - cxlds->component_reg_phys, parent_dport); - if (IS_ERR(endpoint)) - return PTR_ERR(endpoint); - - rc = cxl_endpoint_autoremove(cxlmd, endpoint); - if (rc) - return rc; - - if (!endpoint->dev.driver) { - dev_err(&cxlmd->dev, "%s failed probe\n", - dev_name(&endpoint->dev)); - return -ENXIO; - } - - return 0; -} -EXPORT_SYMBOL_NS_GPL(devm_cxl_add_endpoint, CXL); - static void cxl_detach_ep(void *data) { struct cxl_memdev *cxlmd = data; diff --git a/drivers/cxl/cxl.h b/drivers/cxl/cxl.h index 43c43d1ec069..d94635e43a50 100644 --- a/drivers/cxl/cxl.h +++ b/drivers/cxl/cxl.h @@ -560,8 +560,6 @@ struct pci_bus *cxl_port_to_pci_bus(struct cxl_port *port); struct cxl_port *devm_cxl_add_port(struct device *host, struct device *uport, resource_size_t component_reg_phys, struct cxl_dport *parent_dport); -int devm_cxl_add_endpoint(struct cxl_memdev *cxlmd, - struct cxl_dport *parent_dport); struct cxl_port *find_cxl_root(struct device *dev); int devm_cxl_enumerate_ports(struct cxl_memdev *cxlmd); void cxl_bus_rescan(void); diff --git a/drivers/cxl/cxlmem.h b/drivers/cxl/cxlmem.h index c1c9960ab05f..e082991bc58c 100644 --- a/drivers/cxl/cxlmem.h +++ b/drivers/cxl/cxlmem.h @@ -80,6 +80,15 @@ static inline bool is_cxl_endpoint(struct cxl_port *port) struct cxl_memdev *devm_cxl_add_memdev(struct cxl_dev_state *cxlds); +static inline struct cxl_ep *cxl_ep_load(struct cxl_port *port, + struct cxl_memdev *cxlmd) +{ + if (!port) + return NULL; + + return xa_load(&port->endpoints, (unsigned long)&cxlmd->dev); +} + /** * struct cxl_mbox_cmd - A command to be submitted to hardware. * @opcode: (input) The command set and command submitted to hardware. diff --git a/drivers/cxl/mem.c b/drivers/cxl/mem.c index 549b6b499bae..aa63ce8c7ca6 100644 --- a/drivers/cxl/mem.c +++ b/drivers/cxl/mem.c @@ -45,6 +45,44 @@ static int cxl_mem_dpa_show(struct seq_file *file, void *data) return 0; } +static int devm_cxl_add_endpoint(struct cxl_memdev *cxlmd, + struct cxl_dport *parent_dport) +{ + struct cxl_port *parent_port = parent_dport->port; + struct cxl_dev_state *cxlds = cxlmd->cxlds; + struct cxl_port *endpoint, *iter, *down; + int rc; + + /* + * Now that the path to the root is established record all the + * intervening ports in the chain. + */ + for (iter = parent_port, down = NULL; !is_cxl_root(iter); + down = iter, iter = to_cxl_port(iter->dev.parent)) { + struct cxl_ep *ep; + + ep = cxl_ep_load(iter, cxlmd); + ep->next = down; + } + + endpoint = devm_cxl_add_port(&parent_port->dev, &cxlmd->dev, + cxlds->component_reg_phys, parent_dport); + if (IS_ERR(endpoint)) + return PTR_ERR(endpoint); + + rc = cxl_endpoint_autoremove(cxlmd, endpoint); + if (rc) + return rc; + + if (!endpoint->dev.driver) { + dev_err(&cxlmd->dev, "%s failed probe\n", + dev_name(&endpoint->dev)); + return -ENXIO; + } + + return 0; +} + static int cxl_mem_probe(struct device *dev) { struct cxl_memdev *cxlmd = to_cxl_memdev(dev);
In preparation for devm_cxl_add_endpoint() to call out to cxl_rcrb_to_component() to map the upstream port component registers, move devm_cxl_add_endpoint() from the cxl_core to the cxl_mem driver. This is due to the organization of cxl_test that mandates that the cxl_core not call out to any mocked symbols. It also cleans up the export of devm_cxl_add_endpoint() which is just a wrapper around devm_cxl_add_port(). Signed-off-by: Dan Williams <dan.j.williams@intel.com> --- drivers/cxl/core/core.h | 8 -------- drivers/cxl/core/port.c | 39 --------------------------------------- drivers/cxl/cxl.h | 2 -- drivers/cxl/cxlmem.h | 9 +++++++++ drivers/cxl/mem.c | 38 ++++++++++++++++++++++++++++++++++++++ 5 files changed, 47 insertions(+), 49 deletions(-)