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 5*9171dfcdSArnd Bergmann select FW_LOADER 6*9171dfcdSArnd Bergmann select FW_UPLOAD 73eddcc93SIra Weiny select PCI_DOE 84cdadfd5SDan Williams help 94cdadfd5SDan Williams CXL is a bus that is electrically compatible with PCI Express, but 104cdadfd5SDan Williams layers three protocols on that signalling (CXL.io, CXL.cache, and 114cdadfd5SDan Williams CXL.mem). The CXL.cache protocol allows devices to hold cachelines 124cdadfd5SDan Williams locally, the CXL.mem protocol allows devices to be fully coherent 134cdadfd5SDan Williams memory targets, the CXL.io protocol is equivalent to PCI Express. 144cdadfd5SDan Williams Say 'y' to enable support for the configuration and management of 154cdadfd5SDan Williams devices supporting these protocols. 164cdadfd5SDan Williams 174cdadfd5SDan Williamsif CXL_BUS 184cdadfd5SDan Williams 1968cdd3d2SBen Widawskyconfig CXL_PCI 2068cdd3d2SBen Widawsky tristate "PCI manageability" 213feaa2d3SDan Williams default CXL_BUS 224cdadfd5SDan Williams help 2368cdd3d2SBen Widawsky The CXL specification defines a "CXL memory device" sub-class in the 2468cdd3d2SBen Widawsky PCI "memory controller" base class of devices. Device's identified by 2568cdd3d2SBen Widawsky this class code provide support for volatile and / or persistent 2668cdd3d2SBen Widawsky memory to be mapped into the system address map (Host-managed Device 2768cdd3d2SBen Widawsky Memory (HDM)). 284cdadfd5SDan Williams 2968cdd3d2SBen Widawsky Say 'y/m' to enable a driver that will attach to CXL memory expander 3068cdd3d2SBen Widawsky devices enumerated by the memory device class code for configuration 3168cdd3d2SBen Widawsky and management primarily via the mailbox interface. See Chapter 2.3 3268cdd3d2SBen Widawsky Type 3 CXL Device in the CXL 2.0 specification for more details. 334cdadfd5SDan Williams 344cdadfd5SDan Williams If unsure say 'm'. 3513237183SBen Widawsky 3613237183SBen Widawskyconfig CXL_MEM_RAW_COMMANDS 3713237183SBen Widawsky bool "RAW Command Interface for Memory Devices" 3868cdd3d2SBen Widawsky depends on CXL_PCI 3913237183SBen Widawsky help 4013237183SBen Widawsky Enable CXL RAW command interface. 4113237183SBen Widawsky 4213237183SBen Widawsky The CXL driver ioctl interface may assign a kernel ioctl command 4313237183SBen Widawsky number for each specification defined opcode. At any given point in 4413237183SBen Widawsky time the number of opcodes that the specification defines and a device 4513237183SBen Widawsky may implement may exceed the kernel's set of associated ioctl function 4613237183SBen Widawsky numbers. The mismatch is either by omission, specification is too new, 4713237183SBen Widawsky or by design. When prototyping new hardware, or developing / debugging 4813237183SBen Widawsky the driver it is useful to be able to submit any possible command to 4913237183SBen Widawsky the hardware, even commands that may crash the kernel due to their 5013237183SBen Widawsky potential impact to memory currently in use by the kernel. 5113237183SBen Widawsky 5213237183SBen Widawsky If developing CXL hardware or the driver say Y, otherwise say N. 534812be97SDan Williams 544812be97SDan Williamsconfig CXL_ACPI 554812be97SDan Williams tristate "CXL ACPI: Platform Support" 564812be97SDan Williams depends on ACPI 573feaa2d3SDan Williams default CXL_BUS 58f4ce1f76SDan Williams select ACPI_TABLE_LIB 594812be97SDan Williams help 604812be97SDan Williams Enable support for host managed device memory (HDM) resources 614812be97SDan Williams published by a platform's ACPI CXL memory layout description. See 624812be97SDan Williams Chapter 9.14.1 CXL Early Discovery Table (CEDT) in the CXL 2.0 634812be97SDan Williams specification, and CXL Fixed Memory Window Structures (CEDT.CFMWS) 644812be97SDan Williams (https://www.computeexpresslink.org/spec-landing). The CXL core 654812be97SDan Williams consumes these resource to publish the root of a cxl_port decode 664812be97SDan Williams hierarchy to map regions that represent System RAM, or Persistent 674812be97SDan Williams Memory regions to be managed by LIBNVDIMM. 684812be97SDan Williams 694812be97SDan Williams If unsure say 'm'. 708fdcb170SDan Williams 718fdcb170SDan Williamsconfig CXL_PMEM 728fdcb170SDan Williams tristate "CXL PMEM: Persistent Memory Support" 738fdcb170SDan Williams depends on LIBNVDIMM 748fdcb170SDan Williams default CXL_BUS 758fdcb170SDan Williams help 768fdcb170SDan Williams In addition to typical memory resources a platform may also advertise 778fdcb170SDan Williams support for persistent memory attached via CXL. This support is 788fdcb170SDan Williams managed via a bridge driver from CXL to the LIBNVDIMM system 798fdcb170SDan Williams subsystem. Say 'y/m' to enable support for enumerating and 808fdcb170SDan Williams provisioning the persistent memory capacity of CXL memory expanders. 818fdcb170SDan Williams 828fdcb170SDan Williams If unsure say 'm'. 8354cdbf84SBen Widawsky 848dd2bc0fSBen Widawskyconfig CXL_MEM 858dd2bc0fSBen Widawsky tristate "CXL: Memory Expansion" 868dd2bc0fSBen Widawsky depends on CXL_PCI 878dd2bc0fSBen Widawsky default CXL_BUS 888dd2bc0fSBen Widawsky help 898dd2bc0fSBen Widawsky The CXL.mem protocol allows a device to act as a provider of "System 908dd2bc0fSBen Widawsky RAM" and/or "Persistent Memory" that is fully coherent as if the 918dd2bc0fSBen Widawsky memory were attached to the typical CPU memory controller. This is 928dd2bc0fSBen Widawsky known as HDM "Host-managed Device Memory". 938dd2bc0fSBen Widawsky 948dd2bc0fSBen Widawsky Say 'y/m' to enable a driver that will attach to CXL.mem devices for 958dd2bc0fSBen Widawsky memory expansion and control of HDM. See Chapter 9.13 in the CXL 2.0 968dd2bc0fSBen Widawsky specification for a detailed description of HDM. 978dd2bc0fSBen Widawsky 988dd2bc0fSBen Widawsky If unsure say 'm'. 998dd2bc0fSBen Widawsky 10054cdbf84SBen Widawskyconfig CXL_PORT 10154cdbf84SBen Widawsky default CXL_BUS 10254cdbf84SBen Widawsky tristate 10354cdbf84SBen Widawsky 1049ea4dcf4SDan Williamsconfig CXL_SUSPEND 1059ea4dcf4SDan Williams def_bool y 1069ea4dcf4SDan Williams depends on SUSPEND && CXL_MEM 1079ea4dcf4SDan Williams 108779dd20cSBen Widawskyconfig CXL_REGION 10945d235c5SDan Williams bool "CXL: Region Support" 110779dd20cSBen Widawsky default CXL_BUS 11123a22cd1SDan Williams # For MAX_PHYSMEM_BITS 11223a22cd1SDan Williams depends on SPARSEMEM 113779dd20cSBen Widawsky select MEMREGION 11423a22cd1SDan Williams select GET_FREE_REGION 11545d235c5SDan Williams help 11645d235c5SDan Williams Enable the CXL core to enumerate and provision CXL regions. A CXL 11745d235c5SDan Williams region is defined by one or more CXL expanders that decode a given 11845d235c5SDan Williams system-physical address range. For CXL regions established by 11945d235c5SDan Williams platform-firmware this option enables memory error handling to 12045d235c5SDan Williams identify the devices participating in a given interleaved memory 12145d235c5SDan Williams range. Otherwise, platform-firmware managed CXL is enabled by being 12245d235c5SDan Williams placed in the system address map and does not need a driver. 12345d235c5SDan Williams 12445d235c5SDan Williams If unsure say 'y' 125779dd20cSBen Widawsky 126d18bc74aSDan Williamsconfig CXL_REGION_INVALIDATION_TEST 127d18bc74aSDan Williams bool "CXL: Region Cache Management Bypass (TEST)" 128d18bc74aSDan Williams depends on CXL_REGION 129d18bc74aSDan Williams help 130d18bc74aSDan Williams CXL Region management and security operations potentially invalidate 131cbbd05d0SRandy Dunlap the content of CPU caches without notifying those caches to 132d18bc74aSDan Williams invalidate the affected cachelines. The CXL Region driver attempts 133d18bc74aSDan Williams to invalidate caches when those events occur. If that invalidation 134d18bc74aSDan Williams fails the region will fail to enable. Reasons for cache 135d18bc74aSDan Williams invalidation failure are due to the CPU not providing a cache 136d18bc74aSDan Williams invalidation mechanism. For example usage of wbinvd is restricted to 137d18bc74aSDan Williams bare metal x86. However, for testing purposes toggling this option 138d18bc74aSDan Williams can disable that data integrity safety and proceed with enabling 139d18bc74aSDan Williams regions when there might be conflicting contents in the CPU cache. 140d18bc74aSDan Williams 141d18bc74aSDan Williams If unsure, or if this kernel is meant for production environments, 142d18bc74aSDan Williams say N. 143d18bc74aSDan Williams 1445d7107c7SJonathan Cameronconfig CXL_PMU 1455d7107c7SJonathan Cameron tristate "CXL Performance Monitoring Unit" 1465d7107c7SJonathan Cameron default CXL_BUS 1475d7107c7SJonathan Cameron depends on PERF_EVENTS 1485d7107c7SJonathan Cameron help 1495d7107c7SJonathan Cameron Support performance monitoring as defined in CXL rev 3.0 1505d7107c7SJonathan Cameron section 13.2: Performance Monitoring. CXL components may have 1515d7107c7SJonathan Cameron one or more CXL Performance Monitoring Units (CPMUs). 1525d7107c7SJonathan Cameron 1535d7107c7SJonathan Cameron Say 'y/m' to enable a driver that will attach to performance 1545d7107c7SJonathan Cameron monitoring units and provide standard perf based interfaces. 1555d7107c7SJonathan Cameron 1565d7107c7SJonathan Cameron If unsure say 'm'. 1574cdadfd5SDan Williamsendif 158