[PATCH v2 06/15] cxl/region: Use endpoint's HPA range to find the port's decoder
From: Robert Richter
Date: Tue Feb 18 2025 - 08:30:46 EST
For the implementation of address translation it might not be possible
to determine the root decoder in the early enumeration state since the
SPA range is still unknown. Instead, the endpoint's HPA range is known
and from there the topology can be traversed up to the root port while
the memory range is adjusted from one memory domain to the next up to
the root port.
In a first step, use endpoint's HPA range to find the port's decoder.
Without address translation HPA == SPA, so the endpoint's HPA range
can be used since it is the same as the root decoder's.
Signed-off-by: Robert Richter <rrichter@xxxxxxx>
Reviewed-by: Gregory Price <gourry@xxxxxxxxxx>
---
drivers/cxl/core/region.c | 7 +++----
1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/drivers/cxl/core/region.c b/drivers/cxl/core/region.c
index d898c9f51113..5048511f9de5 100644
--- a/drivers/cxl/core/region.c
+++ b/drivers/cxl/core/region.c
@@ -872,9 +872,8 @@ static int cxl_port_calc_hpa(struct cxl_port *port, struct cxl_decoder *cxld,
static int match_auto_decoder(struct device *dev, const void *data)
{
- const struct cxl_region_params *p = data;
+ const struct range *r, *hpa = data;
struct cxl_decoder *cxld;
- struct range *r;
if (!is_switch_decoder(dev))
return 0;
@@ -882,7 +881,7 @@ static int match_auto_decoder(struct device *dev, const void *data)
cxld = to_cxl_decoder(dev);
r = &cxld->hpa_range;
- if (p->res && p->res->start == r->start && p->res->end == r->end)
+ if (hpa && hpa->start == r->start && hpa->end == r->end)
return 1;
return 0;
@@ -906,7 +905,7 @@ cxl_find_decoder_early(struct cxl_port *port,
return &cxled->cxld;
if (test_bit(CXL_REGION_F_AUTO, &cxlr->flags))
- dev = device_find_child(&port->dev, &cxlr->params,
+ dev = device_find_child(&port->dev, &cxled->cxld.hpa_range,
match_auto_decoder);
else
dev = device_find_child(&port->dev, NULL, match_free_decoder);
--
2.39.5