Commit a2e79489 authored by Robert Richter's avatar Robert Richter Committed by Dave Jiang
Browse files

cxl/atl: Lock decoders that need address translation



The current kernel implementation does not support endpoint setup with
Normalized Addressing. It only translates an endpoint's DPA to the SPA
range of the host bridge. Therefore, the endpoint address range cannot
be determined, making a non-auto setup impossible. If a decoder
requires address translation, reprogramming should be disabled and the
decoder locked.

The BIOS, however, provides all the necessary address translation
data, which the kernel can use to reconfigure endpoint decoders with
normalized addresses. Locking the decoders in the BIOS would prevent a
capable kernel (or other operating systems) from shutting down
auto-generated regions and managing resources dynamically.

Reviewed-by: default avatarGregory Price <gourry@gourry.net>
Reviewed-by: default avatarJonathan Cameron <jonathan.cameron@huawei.com>
Reviewed-by: default avatarDave Jiang <dave.jiang@intel.com>
Tested-by: default avatarGregory Price <gourry@gourry.net>
Signed-off-by: default avatarRobert Richter <rrichter@amd.com>
Reviewed-by: Dave Jiang <dave.jiang@intel.com>> ---
Link: https://patch.msgid.link/20260114164837.1076338-12-rrichter@amd.com


Signed-off-by: default avatarDave Jiang <dave.jiang@intel.com>
parent af74daf9
Loading
Loading
Loading
Loading
+18 −0
Original line number Diff line number Diff line
@@ -154,6 +154,24 @@ static int cxl_prm_setup_root(struct cxl_root *cxl_root, void *data)
		return -ENXIO;
	}

	/*
	 * The current kernel implementation does not support endpoint
	 * setup with Normalized Addressing. It only translates an
	 * endpoint's DPA to the SPA range of the host bridge.
	 * Therefore, the endpoint address range cannot be determined,
	 * making a non-auto setup impossible. If a decoder requires
	 * address translation, reprogramming should be disabled and
	 * the decoder locked.
	 *
	 * The BIOS, however, provides all the necessary address
	 * translation data, which the kernel can use to reconfigure
	 * endpoint decoders with normalized addresses. Locking the
	 * decoders in the BIOS would prevent a capable kernel (or
	 * other operating systems) from shutting down auto-generated
	 * regions and managing resources dynamically.
	 */
	cxld->flags |= CXL_DECODER_F_LOCK;

	ctx->hpa_range = hpa_range;
	ctx->interleave_ways = ways;
	ctx->interleave_granularity = gran;