mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 583fa5e71c
			
		
	
	
		583fa5e71c
		
	
	
	
	
		
			
			Add a straightforward IOCTL that provides a mechanism for userspace to query the supported memory device commands. CXL commands as they appear to userspace are described as part of the UAPI kerneldoc. The command list returned via this IOCTL will contain the full set of commands that the driver supports, however, some of those commands may not be available for use by userspace. Memory device commands first appear in the CXL 2.0 specification. They are submitted through a mailbox mechanism specified in the CXL 2.0 specification. The send command allows userspace to issue mailbox commands directly to the hardware. The list of available commands to send are the output of the query command. The driver verifies basic properties of the command and possibly inspect the input (or output) payload to determine whether or not the command is allowed (or might taint the kernel). Reported-by: kernel test robot <lkp@intel.com> # bug in earlier revision Reported-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Ben Widawsky <ben.widawsky@intel.com> Reviewed-by: Dan Williams <dan.j.williams@intel.com> (v2) Cc: Al Viro <viro@zeniv.linux.org.uk> Link: https://lore.kernel.org/r/20210217040958.1354670-5-ben.widawsky@intel.com Signed-off-by: Dan Williams <dan.j.williams@intel.com>
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| .. include:: <isonum.txt>
 | |
| 
 | |
| ===================================
 | |
| Compute Express Link Memory Devices
 | |
| ===================================
 | |
| 
 | |
| A Compute Express Link Memory Device is a CXL component that implements the
 | |
| CXL.mem protocol. It contains some amount of volatile memory, persistent memory,
 | |
| or both. It is enumerated as a PCI device for configuration and passing
 | |
| messages over an MMIO mailbox. Its contribution to the System Physical
 | |
| Address space is handled via HDM (Host Managed Device Memory) decoders
 | |
| that optionally define a device's contribution to an interleaved address
 | |
| range across multiple devices underneath a host-bridge or interleaved
 | |
| across host-bridges.
 | |
| 
 | |
| Driver Infrastructure
 | |
| =====================
 | |
| 
 | |
| This section covers the driver infrastructure for a CXL memory device.
 | |
| 
 | |
| CXL Memory Device
 | |
| -----------------
 | |
| 
 | |
| .. kernel-doc:: drivers/cxl/mem.c
 | |
|    :doc: cxl mem
 | |
| 
 | |
| .. kernel-doc:: drivers/cxl/mem.c
 | |
|    :internal:
 | |
| 
 | |
| CXL Bus
 | |
| -------
 | |
| .. kernel-doc:: drivers/cxl/bus.c
 | |
|    :doc: cxl bus
 | |
| 
 | |
| External Interfaces
 | |
| ===================
 | |
| 
 | |
| CXL IOCTL Interface
 | |
| -------------------
 | |
| 
 | |
| .. kernel-doc:: include/uapi/linux/cxl_mem.h
 | |
|    :doc: UAPI
 | |
| 
 | |
| .. kernel-doc:: include/uapi/linux/cxl_mem.h
 | |
|    :internal:
 |