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