diff options
| author | Dave Jiang <dave.jiang@intel.com> | 2025-10-10 13:57:53 -0700 | 
|---|---|---|
| committer | Dave Jiang <dave.jiang@intel.com> | 2025-10-14 12:59:13 -0700 | 
| commit | 2e41e5a91a37202ff6743c3ae5329e106aeb1c6c (patch) | |
| tree | c8cba7a3b7af977a4497c8a015a20dc3e4f99070 /drivers/cxl/acpi.c | |
| parent | a375246fcf2bbdaeb1df7fa7ee5a8b884a89085e (diff) | |
cxl/acpi: Fix setup of memory resource in cxl_acpi_set_cache_size()
In order to compare the resource against the HMAT memory target,
the resource needs to be memory type. Change the DEFINE_RES()
macro to DEFINE_RES_MEM() in order to set the correct resource type.
hmat_get_extended_linear_cache_size() uses resource_contains()
internally. This causes a regression for platforms with the
extended linear cache enabled as the comparison always fails and the
cache size is not set. User visible impact is that when 'cxl list' is
issued, a CXL region with extended linear cache support will only
report half the size of the actual size. And this also breaks MCE
reporting of the memory region due to incorrect offset calculation
for the memory.
[dj: Fixup commit log suggested by djbw]
[dj: Fixup stable address for cc]
Fixes: 12b3d697c812 ("cxl: Remove core/acpi.c and cxl core dependency on ACPI")
Cc: stable@vger.kernel.org
Reviewed-by: Gregory Price <gourry@gourry.net>
Reviewed-by: Alison Schofield <alison.schofield@intel.com>
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Dave Jiang <dave.jiang@intel.com>
Diffstat (limited to 'drivers/cxl/acpi.c')
| -rw-r--r-- | drivers/cxl/acpi.c | 2 | 
1 files changed, 1 insertions, 1 deletions
| diff --git a/drivers/cxl/acpi.c b/drivers/cxl/acpi.c index d7a5539d07d4..bd2e282ca93a 100644 --- a/drivers/cxl/acpi.c +++ b/drivers/cxl/acpi.c @@ -348,7 +348,7 @@ static int cxl_acpi_set_cache_size(struct cxl_root_decoder *cxlrd)  	struct resource res;  	int nid, rc; -	res = DEFINE_RES(start, size, 0); +	res = DEFINE_RES_MEM(start, size);  	nid = phys_to_target_node(start);  	rc = hmat_get_extended_linear_cache_size(&res, nid, &cache_size); | 
