mirror of
https://github.com/torvalds/linux.git
synced 2026-01-12 00:42:35 +08:00
cxl/test: Adjust the mock version of devm_cxl_switch_port_decoders_setup()
With devm_cxl_switch_port_decoders_setup() being called within cxl_core instead of by the port driver probe, adjustments are needed to deal with circular symbol dependency when this function is being mock'd. Add the appropriate changes to get around the circular dependency. Reviewed-by: Alison Schofield <alison.schofield@intel.com> Reviewed-by: Jonathan Cameron <jonathan.cameron@huawei.com> Signed-off-by: Dave Jiang <dave.jiang@intel.com>
This commit is contained in:
@@ -1216,12 +1216,12 @@ static int devm_cxl_enumerate_decoders(struct cxl_hdm *cxlhdm,
|
||||
}
|
||||
|
||||
/**
|
||||
* devm_cxl_switch_port_decoders_setup - allocate and setup switch decoders
|
||||
* __devm_cxl_switch_port_decoders_setup - allocate and setup switch decoders
|
||||
* @port: CXL port context
|
||||
*
|
||||
* Return 0 or -errno on error
|
||||
*/
|
||||
int devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
int __devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
{
|
||||
struct cxl_hdm *cxlhdm;
|
||||
|
||||
@@ -1245,7 +1245,7 @@ int devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
dev_err(&port->dev, "HDM decoder capability not found\n");
|
||||
return -ENXIO;
|
||||
}
|
||||
EXPORT_SYMBOL_NS_GPL(devm_cxl_switch_port_decoders_setup, "CXL");
|
||||
EXPORT_SYMBOL_NS_GPL(__devm_cxl_switch_port_decoders_setup, "CXL");
|
||||
|
||||
/**
|
||||
* devm_cxl_endpoint_decoders_setup - allocate and setup endpoint decoders
|
||||
|
||||
@@ -811,6 +811,7 @@ struct cxl_endpoint_dvsec_info {
|
||||
};
|
||||
|
||||
int devm_cxl_switch_port_decoders_setup(struct cxl_port *port);
|
||||
int __devm_cxl_switch_port_decoders_setup(struct cxl_port *port);
|
||||
int devm_cxl_endpoint_decoders_setup(struct cxl_port *port);
|
||||
|
||||
struct cxl_dev_state;
|
||||
@@ -934,6 +935,7 @@ u16 cxl_gpf_get_dvsec(struct device *dev);
|
||||
#ifndef CXL_TEST_ENABLE
|
||||
#define DECLARE_TESTABLE(x) __##x
|
||||
#define devm_cxl_add_dport_by_dev DECLARE_TESTABLE(devm_cxl_add_dport_by_dev)
|
||||
#define devm_cxl_switch_port_decoders_setup DECLARE_TESTABLE(devm_cxl_switch_port_decoders_setup)
|
||||
#endif
|
||||
|
||||
#endif /* __CXL_H__ */
|
||||
|
||||
@@ -10,7 +10,6 @@ ldflags-y += --wrap=devm_cxl_add_rch_dport
|
||||
ldflags-y += --wrap=cxl_rcd_component_reg_phys
|
||||
ldflags-y += --wrap=cxl_endpoint_parse_cdat
|
||||
ldflags-y += --wrap=cxl_dport_init_ras_reporting
|
||||
ldflags-y += --wrap=devm_cxl_switch_port_decoders_setup
|
||||
ldflags-y += --wrap=devm_cxl_endpoint_decoders_setup
|
||||
|
||||
DRIVERS := ../../../drivers
|
||||
|
||||
@@ -17,3 +17,13 @@ struct cxl_dport *devm_cxl_add_dport_by_dev(struct cxl_port *port,
|
||||
return _devm_cxl_add_dport_by_dev(port, dport_dev);
|
||||
}
|
||||
EXPORT_SYMBOL_NS_GPL(devm_cxl_add_dport_by_dev, "CXL");
|
||||
|
||||
cxl_switch_decoders_setup_fn _devm_cxl_switch_port_decoders_setup =
|
||||
__devm_cxl_switch_port_decoders_setup;
|
||||
EXPORT_SYMBOL_NS_GPL(_devm_cxl_switch_port_decoders_setup, "CXL");
|
||||
|
||||
int devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
{
|
||||
return _devm_cxl_switch_port_decoders_setup(port);
|
||||
}
|
||||
EXPORT_SYMBOL_NS_GPL(devm_cxl_switch_port_decoders_setup, "CXL");
|
||||
|
||||
@@ -7,4 +7,7 @@ typedef struct cxl_dport *(*cxl_add_dport_by_dev_fn)(struct cxl_port *port,
|
||||
struct device *dport_dev);
|
||||
extern cxl_add_dport_by_dev_fn _devm_cxl_add_dport_by_dev;
|
||||
|
||||
typedef int(*cxl_switch_decoders_setup_fn)(struct cxl_port *port);
|
||||
extern cxl_switch_decoders_setup_fn _devm_cxl_switch_port_decoders_setup;
|
||||
|
||||
#endif
|
||||
|
||||
@@ -17,11 +17,14 @@ static LIST_HEAD(mock);
|
||||
static struct cxl_dport *
|
||||
redirect_devm_cxl_add_dport_by_dev(struct cxl_port *port,
|
||||
struct device *dport_dev);
|
||||
static int redirect_devm_cxl_switch_port_decoders_setup(struct cxl_port *port);
|
||||
|
||||
void register_cxl_mock_ops(struct cxl_mock_ops *ops)
|
||||
{
|
||||
list_add_rcu(&ops->list, &mock);
|
||||
_devm_cxl_add_dport_by_dev = redirect_devm_cxl_add_dport_by_dev;
|
||||
_devm_cxl_switch_port_decoders_setup =
|
||||
redirect_devm_cxl_switch_port_decoders_setup;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(register_cxl_mock_ops);
|
||||
|
||||
@@ -29,6 +32,8 @@ DEFINE_STATIC_SRCU(cxl_mock_srcu);
|
||||
|
||||
void unregister_cxl_mock_ops(struct cxl_mock_ops *ops)
|
||||
{
|
||||
_devm_cxl_switch_port_decoders_setup =
|
||||
__devm_cxl_switch_port_decoders_setup;
|
||||
_devm_cxl_add_dport_by_dev = __devm_cxl_add_dport_by_dev;
|
||||
list_del_rcu(&ops->list);
|
||||
synchronize_srcu(&cxl_mock_srcu);
|
||||
@@ -138,7 +143,7 @@ __wrap_nvdimm_bus_register(struct device *dev,
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(__wrap_nvdimm_bus_register);
|
||||
|
||||
int __wrap_devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
int redirect_devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
{
|
||||
int rc, index;
|
||||
struct cxl_mock_ops *ops = get_cxl_mock_ops(&index);
|
||||
@@ -146,12 +151,11 @@ int __wrap_devm_cxl_switch_port_decoders_setup(struct cxl_port *port)
|
||||
if (ops && ops->is_mock_port(port->uport_dev))
|
||||
rc = ops->devm_cxl_switch_port_decoders_setup(port);
|
||||
else
|
||||
rc = devm_cxl_switch_port_decoders_setup(port);
|
||||
rc = __devm_cxl_switch_port_decoders_setup(port);
|
||||
put_cxl_mock_ops(index);
|
||||
|
||||
return rc;
|
||||
}
|
||||
EXPORT_SYMBOL_NS_GPL(__wrap_devm_cxl_switch_port_decoders_setup, "CXL");
|
||||
|
||||
int __wrap_devm_cxl_endpoint_decoders_setup(struct cxl_port *port)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user