187 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			187 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			C
		
	
	
	
/****************************************************************************
 | 
						|
 ****************************************************************************
 | 
						|
 ***
 | 
						|
 ***   This header was automatically generated from a Linux kernel header
 | 
						|
 ***   of the same name, to make information necessary for userspace to
 | 
						|
 ***   call into the kernel available to libc.  It contains only constants,
 | 
						|
 ***   structures, and macros generated from the original header, and thus,
 | 
						|
 ***   contains no copyrightable information.
 | 
						|
 ***
 | 
						|
 ***   To edit the content of this header, modify the corresponding
 | 
						|
 ***   source file (e.g. under external/kernel-headers/original/) then
 | 
						|
 ***   run bionic/libc/kernel/tools/update_all.py
 | 
						|
 ***
 | 
						|
 ***   Any manual change here will be lost the next time this script will
 | 
						|
 ***   be run. You've been warned!
 | 
						|
 ***
 | 
						|
 ****************************************************************************
 | 
						|
 ****************************************************************************/
 | 
						|
#ifndef _CXLFLASH_IOCTL_H
 | 
						|
#define _CXLFLASH_IOCTL_H
 | 
						|
#include <linux/types.h>
 | 
						|
#define CXLFLASH_WWID_LEN 16
 | 
						|
#define DK_CXLFLASH_VERSION_0 0
 | 
						|
struct dk_cxlflash_hdr {
 | 
						|
  __u16 version;
 | 
						|
  __u16 rsvd[3];
 | 
						|
  __u64 flags;
 | 
						|
  __u64 return_flags;
 | 
						|
};
 | 
						|
#define DK_CXLFLASH_ALL_PORTS_ACTIVE 0x0000000000000001ULL
 | 
						|
#define DK_CXLFLASH_APP_CLOSE_ADAP_FD 0x0000000000000002ULL
 | 
						|
#define DK_CXLFLASH_CONTEXT_SQ_CMD_MODE 0x0000000000000004ULL
 | 
						|
#define DK_CXLFLASH_ATTACH_REUSE_CONTEXT 0x8000000000000000ULL
 | 
						|
struct dk_cxlflash_attach {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 num_interrupts;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 mmio_size;
 | 
						|
  __u64 block_size;
 | 
						|
  __u64 adap_fd;
 | 
						|
  __u64 last_lba;
 | 
						|
  __u64 max_xfer;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
struct dk_cxlflash_detach {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
struct dk_cxlflash_udirect {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 rsrc_handle;
 | 
						|
  __u64 last_lba;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
#define DK_CXLFLASH_UVIRTUAL_NEED_WRITE_SAME 0x8000000000000000ULL
 | 
						|
struct dk_cxlflash_uvirtual {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 lun_size;
 | 
						|
  __u64 rsrc_handle;
 | 
						|
  __u64 last_lba;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
struct dk_cxlflash_release {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 rsrc_handle;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
struct dk_cxlflash_resize {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 rsrc_handle;
 | 
						|
  __u64 req_size;
 | 
						|
  __u64 last_lba;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
struct dk_cxlflash_clone {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id_src;
 | 
						|
  __u64 context_id_dst;
 | 
						|
  __u64 adap_fd_src;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
#define DK_CXLFLASH_VERIFY_SENSE_LEN 18
 | 
						|
#define DK_CXLFLASH_VERIFY_HINT_SENSE 0x8000000000000000ULL
 | 
						|
struct dk_cxlflash_verify {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 rsrc_handle;
 | 
						|
  __u64 hint;
 | 
						|
  __u64 last_lba;
 | 
						|
  __u8 sense_data[DK_CXLFLASH_VERIFY_SENSE_LEN];
 | 
						|
  __u8 pad[6];
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
#define DK_CXLFLASH_RECOVER_AFU_CONTEXT_RESET 0x8000000000000000ULL
 | 
						|
struct dk_cxlflash_recover_afu {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u64 reason;
 | 
						|
  __u64 context_id;
 | 
						|
  __u64 mmio_size;
 | 
						|
  __u64 adap_fd;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
#define DK_CXLFLASH_MANAGE_LUN_WWID_LEN CXLFLASH_WWID_LEN
 | 
						|
#define DK_CXLFLASH_MANAGE_LUN_ENABLE_SUPERPIPE 0x8000000000000000ULL
 | 
						|
#define DK_CXLFLASH_MANAGE_LUN_DISABLE_SUPERPIPE 0x4000000000000000ULL
 | 
						|
#define DK_CXLFLASH_MANAGE_LUN_ALL_PORTS_ACCESSIBLE 0x2000000000000000ULL
 | 
						|
struct dk_cxlflash_manage_lun {
 | 
						|
  struct dk_cxlflash_hdr hdr;
 | 
						|
  __u8 wwid[DK_CXLFLASH_MANAGE_LUN_WWID_LEN];
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
union cxlflash_ioctls {
 | 
						|
  struct dk_cxlflash_attach attach;
 | 
						|
  struct dk_cxlflash_detach detach;
 | 
						|
  struct dk_cxlflash_udirect udirect;
 | 
						|
  struct dk_cxlflash_uvirtual uvirtual;
 | 
						|
  struct dk_cxlflash_release release;
 | 
						|
  struct dk_cxlflash_resize resize;
 | 
						|
  struct dk_cxlflash_clone clone;
 | 
						|
  struct dk_cxlflash_verify verify;
 | 
						|
  struct dk_cxlflash_recover_afu recover_afu;
 | 
						|
  struct dk_cxlflash_manage_lun manage_lun;
 | 
						|
};
 | 
						|
#define MAX_CXLFLASH_IOCTL_SZ (sizeof(union cxlflash_ioctls))
 | 
						|
#define CXL_MAGIC 0xCA
 | 
						|
#define CXL_IOWR(_n,_s) _IOWR(CXL_MAGIC, _n, struct _s)
 | 
						|
#define DK_CXLFLASH_ATTACH CXL_IOWR(0x80, dk_cxlflash_attach)
 | 
						|
#define DK_CXLFLASH_USER_DIRECT CXL_IOWR(0x81, dk_cxlflash_udirect)
 | 
						|
#define DK_CXLFLASH_RELEASE CXL_IOWR(0x82, dk_cxlflash_release)
 | 
						|
#define DK_CXLFLASH_DETACH CXL_IOWR(0x83, dk_cxlflash_detach)
 | 
						|
#define DK_CXLFLASH_VERIFY CXL_IOWR(0x84, dk_cxlflash_verify)
 | 
						|
#define DK_CXLFLASH_RECOVER_AFU CXL_IOWR(0x85, dk_cxlflash_recover_afu)
 | 
						|
#define DK_CXLFLASH_MANAGE_LUN CXL_IOWR(0x86, dk_cxlflash_manage_lun)
 | 
						|
#define DK_CXLFLASH_USER_VIRTUAL CXL_IOWR(0x87, dk_cxlflash_uvirtual)
 | 
						|
#define DK_CXLFLASH_VLUN_RESIZE CXL_IOWR(0x88, dk_cxlflash_resize)
 | 
						|
#define DK_CXLFLASH_VLUN_CLONE CXL_IOWR(0x89, dk_cxlflash_clone)
 | 
						|
#define HT_CXLFLASH_VERSION_0 0
 | 
						|
struct ht_cxlflash_hdr {
 | 
						|
  __u16 version;
 | 
						|
  __u16 subcmd;
 | 
						|
  __u16 rsvd[2];
 | 
						|
  __u64 flags;
 | 
						|
  __u64 return_flags;
 | 
						|
};
 | 
						|
#define HT_CXLFLASH_HOST_READ 0x0000000000000000ULL
 | 
						|
#define HT_CXLFLASH_HOST_WRITE 0x0000000000000001ULL
 | 
						|
#define HT_CXLFLASH_LUN_PROVISION_SUBCMD_CREATE_LUN 0x0001
 | 
						|
#define HT_CXLFLASH_LUN_PROVISION_SUBCMD_DELETE_LUN 0x0002
 | 
						|
#define HT_CXLFLASH_LUN_PROVISION_SUBCMD_QUERY_PORT 0x0003
 | 
						|
struct ht_cxlflash_lun_provision {
 | 
						|
  struct ht_cxlflash_hdr hdr;
 | 
						|
  __u16 port;
 | 
						|
  __u16 reserved16[3];
 | 
						|
  __u64 size;
 | 
						|
  __u64 lun_id;
 | 
						|
  __u8 wwid[CXLFLASH_WWID_LEN];
 | 
						|
  __u64 max_num_luns;
 | 
						|
  __u64 cur_num_luns;
 | 
						|
  __u64 max_cap_port;
 | 
						|
  __u64 cur_cap_port;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
#define HT_CXLFLASH_AFU_DEBUG_MAX_DATA_LEN 262144
 | 
						|
#define HT_CXLFLASH_AFU_DEBUG_SUBCMD_LEN 12
 | 
						|
struct ht_cxlflash_afu_debug {
 | 
						|
  struct ht_cxlflash_hdr hdr;
 | 
						|
  __u8 reserved8[4];
 | 
						|
  __u8 afu_subcmd[HT_CXLFLASH_AFU_DEBUG_SUBCMD_LEN];
 | 
						|
  __u64 data_ea;
 | 
						|
  __u32 data_len;
 | 
						|
  __u32 reserved32;
 | 
						|
  __u64 reserved[8];
 | 
						|
};
 | 
						|
union cxlflash_ht_ioctls {
 | 
						|
  struct ht_cxlflash_lun_provision lun_provision;
 | 
						|
  struct ht_cxlflash_afu_debug afu_debug;
 | 
						|
};
 | 
						|
#define MAX_HT_CXLFLASH_IOCTL_SZ (sizeof(union cxlflash_ht_ioctls))
 | 
						|
#define HT_CXLFLASH_LUN_PROVISION CXL_IOWR(0xBF, ht_cxlflash_lun_provision)
 | 
						|
#define HT_CXLFLASH_AFU_DEBUG CXL_IOWR(0xBE, ht_cxlflash_afu_debug)
 | 
						|
#endif
 |