From: Shiju Jose <shiju.jose@xxxxxxxxxx> Add helper function to determine a CXL memory is online. Use case: certain memory operations are permitted when the memory is offline only, for eg. some memory repair operations. Co-developed-by: Jonathan Cameron <Jonathan.Cameron@xxxxxxxxxx> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@xxxxxxxxxx> Signed-off-by: Shiju Jose <shiju.jose@xxxxxxxxxx> --- drivers/cxl/core/core.h | 9 +++++++++ drivers/cxl/core/region.c | 10 ++++++++++ 2 files changed, 19 insertions(+) diff --git a/drivers/cxl/core/core.h b/drivers/cxl/core/core.h index 23761340e65c..fb3b5f1229e7 100644 --- a/drivers/cxl/core/core.h +++ b/drivers/cxl/core/core.h @@ -32,8 +32,17 @@ int cxl_get_poison_by_endpoint(struct cxl_port *port); struct cxl_region *cxl_dpa_to_region(const struct cxl_memdev *cxlmd, u64 dpa); u64 cxl_dpa_to_hpa(struct cxl_region *cxlr, const struct cxl_memdev *cxlmd, u64 dpa); +bool cxl_are_decoders_committed(const struct cxl_memdev *cxlmd); #else +static inline bool cxl_are_decoders_committed(const struct cxl_memdev *cxlmd) +{ + /* + * If no driver, in absence of a way to check, assume decoders are committed. + */ + return true; +} + static inline u64 cxl_dpa_to_hpa(struct cxl_region *cxlr, const struct cxl_memdev *cxlmd, u64 dpa) { diff --git a/drivers/cxl/core/region.c b/drivers/cxl/core/region.c index 5339237ced0f..33a3ef839f6a 100644 --- a/drivers/cxl/core/region.c +++ b/drivers/cxl/core/region.c @@ -2851,6 +2851,16 @@ struct cxl_region *cxl_dpa_to_region(const struct cxl_memdev *cxlmd, u64 dpa) return ctx.cxlr; } +bool cxl_are_decoders_committed(const struct cxl_memdev *cxlmd) +{ + struct cxl_port *port = cxlmd->endpoint; + + if (port && is_cxl_endpoint(port) && cxl_num_decoders_committed(port)) + return true; + + return false; +} + static bool cxl_is_hpa_in_chunk(u64 hpa, struct cxl_region *cxlr, int pos) { struct cxl_region_params *p = &cxlr->params; -- 2.43.0