[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250114203136.31704-1-fabio.m.de.francesco@linux.intel.com>
Date: Tue, 14 Jan 2025 21:31:00 +0100
From: "Fabio M. De Francesco" <fabio.m.de.francesco@...ux.intel.com>
To: Davidlohr Bueso <dave@...olabs.net>,
Jonathan Cameron <jonathan.cameron@...wei.com>,
Dave Jiang <dave.jiang@...el.com>,
Alison Schofield <alison.schofield@...el.com>,
Vishal Verma <vishal.l.verma@...el.com>,
Ira Weiny <ira.weiny@...el.com>,
Dan Williams <dan.j.williams@...el.com>
Cc: Robert Richter <rrichter@....com>,
ming.li@...omail.com,
linux-kernel@...r.kernel.org,
linux-cxl@...r.kernel.org,
"Fabio M. De Francesco" <fabio.m.de.francesco@...ux.intel.com>
Subject: [PATCH 0/4] cxl/core: Enable Region creation on x86 with Low Mem Hole
The CXL Fixed Memory Window Structure (CFMWS) describes zero or more Host
Physical Address (HPA) windows that are associated with each CXL Host
Bridge. Each window represents a contiguous HPA that may be interleaved
with one or more targets (CXL v3.1 - 9.18.1.3).
The Low Memory Hole (LMH) of x86 is a range of addresses of physical low
memory to which systems cannot send transactions. On those systems, BIOS
publishes CFMWS which communicate the active System Physical Address (SPA)
ranges that map to a subset of the Host Physical Address (HPA) ranges. The
SPA range trims out the hole, and capacity in the endpoint is lost with no
SPA to map to CXL HPA in that hole.
In the early stages of CXL Regions construction and attach on platforms
with Low Memory Holes, the driver fails and returns an error because it
expects that the CXL Endpoint Decoder range is a subset of the Root
Decoder's (SPA >= HPA). On x86 with LMH's, it happens that SPA < HPA.
Therefore, detect x86 Low Memory Holes, match CXL Root and Endpoint
Decoders or already made CXL Regions and Decoders to allow the
construction of new CXL Regions and the attachment of Endpoint Decoders,
even if SPA < HPA. If needed because of LMH's, adjust the Endpoint Decoder
range end to match Root Decoder's.
- Patch 1/4 changes the calling conventions of three match_*_by_range()
helpers in preparation of 3/4.
- Patch 2/4 Introduces helpers to detect LMH's and also one to adjust
the HPA range end for CXL Regions construction.
- Patch 3/4 enables CXL Regions construction and Endpoint Decoders
attachment by matching Root Decoders or Regions with Endpoint
Decoders, adjusting Endpoint Decoders HPA range end, and relaxing
constraints while Endpoints decoders' attachment.
- Patch 4/4 simulates a LMH for the CXL tests on patched CXL driver.
Many thanks to Alison, Dan, and Ira for their help and for their reviews
of my RFC on Intel's internal ML.
Commenting on v1, Alison wrote a couple of observations on what users
will see. I suggest anyone interested to see how this series affect
users to take a look at her observations.[0] Thank you!
Changes for v2:
Cover:
Extend and elaborate more on how the series works.
1/4:
Add Reviewed-by tags (Alison, Ira).
2/4:
Make a separate patch for LMH helpers. (Alison)
Add spaces before final returns. (Alison)
Change trim_by_spa() to arch_adjust_region_resource(). (Alison)
Check that SPA is below CFMWS range start + 4GB. (Ming)
Change storage class of default helpers to "static".[1] (KTR)
3/4:
Add dev_dbg() logs before and after adjusting resource for Region
construction to match the Root Decoder range. (Alison)
4/4:
Conditionally create a LMH simulation only if
CXL_ARCH_LOW_MEMORY_HOLE is set. (Jonathan)
Make the start address of the CFMWS range dependent either on
real hardware (0x0) or on mock_cfmws[0] for tests. (Alison)
Extend the commit message to confirm successful creation of
a Region with a LMH on loading of the cxl-test module. (Alison)
Define the CFMWS range start on real hardware as
LMH_CFMWS_RANGE_START (Alison)
v1 - https://lore.kernel.org/all/20241122155226.2068287-1-fabio.m.de.francesco@linux.intel.com/
[0] - https://lore.kernel.org/all/Z0Tzif55CcHuujJ-@aschofie-mobl2.lan/
[1] - https://lore.kernel.org/oe-kbuild-all/202411252126.T7xKY88q-lkp@intel.com/
Fabio M. De Francesco (4):
cxl/core: Change match_*_by_range() calling convention
cxl/core: Add helpers to detect Low memory Holes on x86
cxl/core: Enable Region creation on x86 with Low Memory Hole
cxl/test: Simulate an x86 Low Memory Hole for tests
drivers/cxl/Kconfig | 5 ++
drivers/cxl/core/Makefile | 1 +
drivers/cxl/core/lmh.c | 81 ++++++++++++++++++++++++++++
drivers/cxl/core/lmh.h | 30 +++++++++++
drivers/cxl/core/region.c | 81 +++++++++++++++++++++-------
tools/testing/cxl/Kbuild | 1 +
tools/testing/cxl/cxl_core_exports.c | 2 +
tools/testing/cxl/test/cxl.c | 10 ++++
8 files changed, 193 insertions(+), 18 deletions(-)
create mode 100644 drivers/cxl/core/lmh.c
create mode 100644 drivers/cxl/core/lmh.h
--
2.47.1
Powered by blists - more mailing lists