From: Dan Carpenter Date: Mon, 1 Aug 2022 10:20:58 +0000 (+0300) Subject: cxl/region: decrement ->nr_targets on error in cxl_region_attach() X-Git-Tag: v6.0-rc1~42^2~17 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5e42bcbc3fef;p=thirdparty%2Flinux.git cxl/region: decrement ->nr_targets on error in cxl_region_attach() The ++ needs a match -- on the clean up path. If the p->nr_targets value gets to be more than 16 it leads to uninitialized data in cxl_port_setup_targets(). drivers/cxl/core/region.c:995 cxl_port_setup_targets() error: uninitialized symbol 'eiw'. Fixes: 27b3f8d13830 ("cxl/region: Program target lists") Signed-off-by: Dan Carpenter Link: https://lore.kernel.org/r/YuepCvUAoCtdpcoO@kili Signed-off-by: Dan Williams --- diff --git a/drivers/cxl/core/region.c b/drivers/cxl/core/region.c index 516ba7e2de81a..55691f6e97d68 100644 --- a/drivers/cxl/core/region.c +++ b/drivers/cxl/core/region.c @@ -1218,12 +1218,14 @@ static int cxl_region_attach(struct cxl_region *cxlr, if (p->nr_targets == p->interleave_ways) { rc = cxl_region_setup_targets(cxlr); if (rc) - goto err; + goto err_decrement; p->state = CXL_CONFIG_ACTIVE; } return 0; +err_decrement: + p->nr_targets--; err: for (iter = ep_port; !is_cxl_root(iter); iter = to_cxl_port(iter->dev.parent))