xref: /linux/drivers/cxl/Kconfig (revision 29e9359005dd1ac5f9683608891718e6a32a20a3)
14cdadfd5SDan Williams# SPDX-License-Identifier: GPL-2.0-only
24cdadfd5SDan Williamsmenuconfig CXL_BUS
34cdadfd5SDan Williams	tristate "CXL (Compute Express Link) Devices Support"
44cdadfd5SDan Williams	depends on PCI
59171dfcdSArnd Bergmann	select FW_LOADER
69171dfcdSArnd Bergmann	select FW_UPLOAD
73eddcc93SIra Weiny	select PCI_DOE
8ad6f04c0SDave Jiang	select FIRMWARE_TABLE
91b5695b0SMike Rapoport (Microsoft)	select NUMA_KEEP_MEMINFO if NUMA_MEMBLKS
10858ce2f5SDave Jiang	select FWCTL if CXL_FEATURES
114cdadfd5SDan Williams	help
124cdadfd5SDan Williams	  CXL is a bus that is electrically compatible with PCI Express, but
134cdadfd5SDan Williams	  layers three protocols on that signalling (CXL.io, CXL.cache, and
144cdadfd5SDan Williams	  CXL.mem). The CXL.cache protocol allows devices to hold cachelines
154cdadfd5SDan Williams	  locally, the CXL.mem protocol allows devices to be fully coherent
164cdadfd5SDan Williams	  memory targets, the CXL.io protocol is equivalent to PCI Express.
174cdadfd5SDan Williams	  Say 'y' to enable support for the configuration and management of
184cdadfd5SDan Williams	  devices supporting these protocols.
194cdadfd5SDan Williams
204cdadfd5SDan Williamsif CXL_BUS
214cdadfd5SDan Williams
2268cdd3d2SBen Widawskyconfig CXL_PCI
2368cdd3d2SBen Widawsky	tristate "PCI manageability"
243feaa2d3SDan Williams	default CXL_BUS
254cdadfd5SDan Williams	help
2668cdd3d2SBen Widawsky	  The CXL specification defines a "CXL memory device" sub-class in the
2768cdd3d2SBen Widawsky	  PCI "memory controller" base class of devices. Device's identified by
2868cdd3d2SBen Widawsky	  this class code provide support for volatile and / or persistent
2968cdd3d2SBen Widawsky	  memory to be mapped into the system address map (Host-managed Device
3068cdd3d2SBen Widawsky	  Memory (HDM)).
314cdadfd5SDan Williams
3268cdd3d2SBen Widawsky	  Say 'y/m' to enable a driver that will attach to CXL memory expander
3368cdd3d2SBen Widawsky	  devices enumerated by the memory device class code for configuration
3468cdd3d2SBen Widawsky	  and management primarily via the mailbox interface. See Chapter 2.3
3568cdd3d2SBen Widawsky	  Type 3 CXL Device in the CXL 2.0 specification for more details.
364cdadfd5SDan Williams
374cdadfd5SDan Williams	  If unsure say 'm'.
3813237183SBen Widawsky
3913237183SBen Widawskyconfig CXL_MEM_RAW_COMMANDS
4013237183SBen Widawsky	bool "RAW Command Interface for Memory Devices"
4168cdd3d2SBen Widawsky	depends on CXL_PCI
4213237183SBen Widawsky	help
4313237183SBen Widawsky	  Enable CXL RAW command interface.
4413237183SBen Widawsky
4513237183SBen Widawsky	  The CXL driver ioctl interface may assign a kernel ioctl command
4613237183SBen Widawsky	  number for each specification defined opcode. At any given point in
4713237183SBen Widawsky	  time the number of opcodes that the specification defines and a device
4813237183SBen Widawsky	  may implement may exceed the kernel's set of associated ioctl function
4913237183SBen Widawsky	  numbers. The mismatch is either by omission, specification is too new,
5013237183SBen Widawsky	  or by design. When prototyping new hardware, or developing / debugging
5113237183SBen Widawsky	  the driver it is useful to be able to submit any possible command to
5213237183SBen Widawsky	  the hardware, even commands that may crash the kernel due to their
5313237183SBen Widawsky	  potential impact to memory currently in use by the kernel.
5413237183SBen Widawsky
5513237183SBen Widawsky	  If developing CXL hardware or the driver say Y, otherwise say N.
564812be97SDan Williams
574812be97SDan Williamsconfig CXL_ACPI
584812be97SDan Williams	tristate "CXL ACPI: Platform Support"
594812be97SDan Williams	depends on ACPI
60ad6f04c0SDave Jiang	depends on ACPI_NUMA
613feaa2d3SDan Williams	default CXL_BUS
62f4ce1f76SDan Williams	select ACPI_TABLE_LIB
63ad6f04c0SDave Jiang	select ACPI_HMAT
646575b268SDan Williams	select CXL_PORT
654812be97SDan Williams	help
664812be97SDan Williams	  Enable support for host managed device memory (HDM) resources
674812be97SDan Williams	  published by a platform's ACPI CXL memory layout description.  See
684812be97SDan Williams	  Chapter 9.14.1 CXL Early Discovery Table (CEDT) in the CXL 2.0
694812be97SDan Williams	  specification, and CXL Fixed Memory Window Structures (CEDT.CFMWS)
704812be97SDan Williams	  (https://www.computeexpresslink.org/spec-landing). The CXL core
714812be97SDan Williams	  consumes these resource to publish the root of a cxl_port decode
724812be97SDan Williams	  hierarchy to map regions that represent System RAM, or Persistent
734812be97SDan Williams	  Memory regions to be managed by LIBNVDIMM.
744812be97SDan Williams
754812be97SDan Williams	  If unsure say 'm'.
768fdcb170SDan Williams
778fdcb170SDan Williamsconfig CXL_PMEM
788fdcb170SDan Williams	tristate "CXL PMEM: Persistent Memory Support"
798fdcb170SDan Williams	depends on LIBNVDIMM
808fdcb170SDan Williams	default CXL_BUS
818fdcb170SDan Williams	help
828fdcb170SDan Williams	  In addition to typical memory resources a platform may also advertise
838fdcb170SDan Williams	  support for persistent memory attached via CXL. This support is
848fdcb170SDan Williams	  managed via a bridge driver from CXL to the LIBNVDIMM system
858fdcb170SDan Williams	  subsystem. Say 'y/m' to enable support for enumerating and
868fdcb170SDan Williams	  provisioning the persistent memory capacity of CXL memory expanders.
878fdcb170SDan Williams
888fdcb170SDan Williams	  If unsure say 'm'.
8954cdbf84SBen Widawsky
908dd2bc0fSBen Widawskyconfig CXL_MEM
918dd2bc0fSBen Widawsky	tristate "CXL: Memory Expansion"
928dd2bc0fSBen Widawsky	depends on CXL_PCI
938dd2bc0fSBen Widawsky	default CXL_BUS
948dd2bc0fSBen Widawsky	help
958dd2bc0fSBen Widawsky	  The CXL.mem protocol allows a device to act as a provider of "System
968dd2bc0fSBen Widawsky	  RAM" and/or "Persistent Memory" that is fully coherent as if the
978dd2bc0fSBen Widawsky	  memory were attached to the typical CPU memory controller. This is
988dd2bc0fSBen Widawsky	  known as HDM "Host-managed Device Memory".
998dd2bc0fSBen Widawsky
1008dd2bc0fSBen Widawsky	  Say 'y/m' to enable a driver that will attach to CXL.mem devices for
1018dd2bc0fSBen Widawsky	  memory expansion and control of HDM. See Chapter 9.13 in the CXL 2.0
1028dd2bc0fSBen Widawsky	  specification for a detailed description of HDM.
1038dd2bc0fSBen Widawsky
1048dd2bc0fSBen Widawsky	  If unsure say 'm'.
1058dd2bc0fSBen Widawsky
106f0e6a232SDave Jiangconfig CXL_FEATURES
107f0e6a232SDave Jiang	bool "CXL: Features"
108f0e6a232SDave Jiang	depends on CXL_PCI
109f0e6a232SDave Jiang	help
110f0e6a232SDave Jiang	  Enable support for CXL Features. A CXL device that includes a mailbox
111f0e6a232SDave Jiang	  supports commands that allows listing, getting, and setting of
112f0e6a232SDave Jiang	  optionally defined features such as memory sparing or post package
113f0e6a232SDave Jiang	  sparing. Vendors may define custom features for the device.
114f0e6a232SDave Jiang
115f0e6a232SDave Jiang	  If unsure say 'n'
116f0e6a232SDave Jiang
1170c6e6f13SShiju Joseconfig CXL_EDAC_MEM_FEATURES
1180c6e6f13SShiju Jose	bool "CXL: EDAC Memory Features"
1190c6e6f13SShiju Jose	depends on EXPERT
1200c6e6f13SShiju Jose	depends on CXL_MEM
1210c6e6f13SShiju Jose	depends on CXL_FEATURES
1220c6e6f13SShiju Jose	depends on EDAC >= CXL_BUS
1230c6e6f13SShiju Jose	help
1240c6e6f13SShiju Jose	  The CXL EDAC memory feature is optional and allows host to
1250c6e6f13SShiju Jose	  control the EDAC memory features configurations of CXL memory
1260c6e6f13SShiju Jose	  expander devices.
1270c6e6f13SShiju Jose
1280c6e6f13SShiju Jose	  Say 'y' if you have an expert need to change default settings
1290c6e6f13SShiju Jose	  of a memory RAS feature established by the platform/device.
1300c6e6f13SShiju Jose	  Otherwise say 'n'.
1310c6e6f13SShiju Jose
1320c6e6f13SShiju Joseconfig CXL_EDAC_SCRUB
1330c6e6f13SShiju Jose	bool "Enable CXL Patrol Scrub Control (Patrol Read)"
1340c6e6f13SShiju Jose	depends on CXL_EDAC_MEM_FEATURES
1350c6e6f13SShiju Jose	depends on EDAC_SCRUB
1360c6e6f13SShiju Jose	help
1370c6e6f13SShiju Jose	  The CXL EDAC scrub control is optional and allows host to
1380c6e6f13SShiju Jose	  control the scrub feature configurations of CXL memory expander
1390c6e6f13SShiju Jose	  devices.
1400c6e6f13SShiju Jose
1410c6e6f13SShiju Jose	  When enabled 'cxl_mem' and 'cxl_region' EDAC devices are
1420c6e6f13SShiju Jose	  published with memory scrub control attributes as described by
1430c6e6f13SShiju Jose	  Documentation/ABI/testing/sysfs-edac-scrub.
1440c6e6f13SShiju Jose
1450c6e6f13SShiju Jose	  Say 'y' if you have an expert need to change default settings
1460c6e6f13SShiju Jose	  of a memory scrub feature established by the platform/device
1470c6e6f13SShiju Jose	  (e.g. scrub rates for the patrol scrub feature).
1480c6e6f13SShiju Jose	  Otherwise say 'n'.
1490c6e6f13SShiju Jose
15085fb6a16SShiju Joseconfig CXL_EDAC_ECS
15185fb6a16SShiju Jose	bool "Enable CXL Error Check Scrub (Repair)"
15285fb6a16SShiju Jose	depends on CXL_EDAC_MEM_FEATURES
15385fb6a16SShiju Jose	depends on EDAC_ECS
15485fb6a16SShiju Jose	help
15585fb6a16SShiju Jose	  The CXL EDAC ECS control is optional and allows host to
15685fb6a16SShiju Jose	  control the ECS feature configurations of CXL memory expander
15785fb6a16SShiju Jose	  devices.
15885fb6a16SShiju Jose
15985fb6a16SShiju Jose	  When enabled 'cxl_mem' EDAC devices are published with memory
16085fb6a16SShiju Jose	  ECS control attributes as described by
16185fb6a16SShiju Jose	  Documentation/ABI/testing/sysfs-edac-ecs.
16285fb6a16SShiju Jose
16385fb6a16SShiju Jose	  Say 'y' if you have an expert need to change default settings
16485fb6a16SShiju Jose	  of a memory ECS feature established by the platform/device.
16585fb6a16SShiju Jose	  Otherwise say 'n'.
16685fb6a16SShiju Jose
167*0b5ccb0dSShiju Joseconfig CXL_EDAC_MEM_REPAIR
168*0b5ccb0dSShiju Jose	bool "Enable CXL Memory Repair"
169*0b5ccb0dSShiju Jose	depends on CXL_EDAC_MEM_FEATURES
170*0b5ccb0dSShiju Jose	depends on EDAC_MEM_REPAIR
171*0b5ccb0dSShiju Jose	help
172*0b5ccb0dSShiju Jose	  The CXL EDAC memory repair control is optional and allows host
173*0b5ccb0dSShiju Jose	  to control the memory repair features (e.g. sparing, PPR)
174*0b5ccb0dSShiju Jose	  configurations of CXL memory expander devices.
175*0b5ccb0dSShiju Jose
176*0b5ccb0dSShiju Jose	  When enabled, the memory repair feature requires an additional
177*0b5ccb0dSShiju Jose	  memory of approximately 43KB to store CXL DRAM and CXL general
178*0b5ccb0dSShiju Jose	  media event records.
179*0b5ccb0dSShiju Jose
180*0b5ccb0dSShiju Jose	  When enabled 'cxl_mem' EDAC devices are published with memory
181*0b5ccb0dSShiju Jose	  repair control attributes as described by
182*0b5ccb0dSShiju Jose	  Documentation/ABI/testing/sysfs-edac-memory-repair.
183*0b5ccb0dSShiju Jose
184*0b5ccb0dSShiju Jose	  Say 'y' if you have an expert need to change default settings
185*0b5ccb0dSShiju Jose	  of a memory repair feature established by the platform/device.
186*0b5ccb0dSShiju Jose	  Otherwise say 'n'.
187*0b5ccb0dSShiju Jose
18854cdbf84SBen Widawskyconfig CXL_PORT
18954cdbf84SBen Widawsky	default CXL_BUS
19054cdbf84SBen Widawsky	tristate
19154cdbf84SBen Widawsky
1929ea4dcf4SDan Williamsconfig CXL_SUSPEND
1939ea4dcf4SDan Williams	def_bool y
1949ea4dcf4SDan Williams	depends on SUSPEND && CXL_MEM
1959ea4dcf4SDan Williams
196779dd20cSBen Widawskyconfig CXL_REGION
19745d235c5SDan Williams	bool "CXL: Region Support"
198779dd20cSBen Widawsky	default CXL_BUS
19923a22cd1SDan Williams	# For MAX_PHYSMEM_BITS
20023a22cd1SDan Williams	depends on SPARSEMEM
201779dd20cSBen Widawsky	select MEMREGION
20223a22cd1SDan Williams	select GET_FREE_REGION
20345d235c5SDan Williams	help
20445d235c5SDan Williams	  Enable the CXL core to enumerate and provision CXL regions. A CXL
20545d235c5SDan Williams	  region is defined by one or more CXL expanders that decode a given
20645d235c5SDan Williams	  system-physical address range. For CXL regions established by
20745d235c5SDan Williams	  platform-firmware this option enables memory error handling to
20845d235c5SDan Williams	  identify the devices participating in a given interleaved memory
20945d235c5SDan Williams	  range. Otherwise, platform-firmware managed CXL is enabled by being
21045d235c5SDan Williams	  placed in the system address map and does not need a driver.
21145d235c5SDan Williams
21245d235c5SDan Williams	  If unsure say 'y'
213779dd20cSBen Widawsky
214d18bc74aSDan Williamsconfig CXL_REGION_INVALIDATION_TEST
215d18bc74aSDan Williams	bool "CXL: Region Cache Management Bypass (TEST)"
216d18bc74aSDan Williams	depends on CXL_REGION
217d18bc74aSDan Williams	help
218d18bc74aSDan Williams	  CXL Region management and security operations potentially invalidate
219cbbd05d0SRandy Dunlap	  the content of CPU caches without notifying those caches to
220d18bc74aSDan Williams	  invalidate the affected cachelines. The CXL Region driver attempts
221d18bc74aSDan Williams	  to invalidate caches when those events occur.  If that invalidation
222d18bc74aSDan Williams	  fails the region will fail to enable.  Reasons for cache
223d18bc74aSDan Williams	  invalidation failure are due to the CPU not providing a cache
224d18bc74aSDan Williams	  invalidation mechanism. For example usage of wbinvd is restricted to
225d18bc74aSDan Williams	  bare metal x86. However, for testing purposes toggling this option
226d18bc74aSDan Williams	  can disable that data integrity safety and proceed with enabling
227d18bc74aSDan Williams	  regions when there might be conflicting contents in the CPU cache.
228d18bc74aSDan Williams
229d18bc74aSDan Williams	  If unsure, or if this kernel is meant for production environments,
230d18bc74aSDan Williams	  say N.
231d18bc74aSDan Williams
232516e5bd0SDave Jiangconfig CXL_MCE
233516e5bd0SDave Jiang	def_bool y
234516e5bd0SDave Jiang	depends on X86_MCE && MEMORY_FAILURE
235516e5bd0SDave Jiang
2364cdadfd5SDan Williamsendif
237