blob: 91ffe62394f20dcacd7d4989ef01d51f2ecea6dd [file] [log] [blame]
Christopher Ferris05d08e92016-02-04 13:16:38 -08001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _CXLFLASH_IOCTL_H
20#define _CXLFLASH_IOCTL_H
21#include <linux/types.h>
22#define DK_CXLFLASH_VERSION_0 0
Christopher Ferris05d08e92016-02-04 13:16:38 -080023struct dk_cxlflash_hdr {
24 __u16 version;
25 __u16 rsvd[3];
26 __u64 flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -080027 __u64 return_flags;
28};
Christopher Ferris106b3a82016-08-24 12:15:38 -070029#define DK_CXLFLASH_ALL_PORTS_ACTIVE 0x0000000000000001ULL
Christopher Ferris6a9755d2017-01-13 14:09:31 -080030#define DK_CXLFLASH_APP_CLOSE_ADAP_FD 0x0000000000000002ULL
Christopher Ferris525ce912017-07-26 13:12:53 -070031#define DK_CXLFLASH_CONTEXT_SQ_CMD_MODE 0x0000000000000004ULL
Christopher Ferris6a9755d2017-01-13 14:09:31 -080032#define DK_CXLFLASH_ATTACH_REUSE_CONTEXT 0x8000000000000000ULL
Christopher Ferris106b3a82016-08-24 12:15:38 -070033struct dk_cxlflash_attach {
Christopher Ferris05d08e92016-02-04 13:16:38 -080034 struct dk_cxlflash_hdr hdr;
35 __u64 num_interrupts;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080036 __u64 context_id;
Christopher Ferris106b3a82016-08-24 12:15:38 -070037 __u64 mmio_size;
Christopher Ferris05d08e92016-02-04 13:16:38 -080038 __u64 block_size;
39 __u64 adap_fd;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080040 __u64 last_lba;
Christopher Ferris106b3a82016-08-24 12:15:38 -070041 __u64 max_xfer;
Christopher Ferris05d08e92016-02-04 13:16:38 -080042 __u64 reserved[8];
43};
Christopher Ferris6a9755d2017-01-13 14:09:31 -080044struct dk_cxlflash_detach {
Christopher Ferris106b3a82016-08-24 12:15:38 -070045 struct dk_cxlflash_hdr hdr;
Christopher Ferris05d08e92016-02-04 13:16:38 -080046 __u64 context_id;
47 __u64 reserved[8];
Christopher Ferris6a9755d2017-01-13 14:09:31 -080048};
Christopher Ferris106b3a82016-08-24 12:15:38 -070049struct dk_cxlflash_udirect {
Christopher Ferris05d08e92016-02-04 13:16:38 -080050 struct dk_cxlflash_hdr hdr;
51 __u64 context_id;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080052 __u64 rsrc_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -070053 __u64 last_lba;
Christopher Ferris05d08e92016-02-04 13:16:38 -080054 __u64 reserved[8];
55};
Christopher Ferris6a9755d2017-01-13 14:09:31 -080056#define DK_CXLFLASH_UVIRTUAL_NEED_WRITE_SAME 0x8000000000000000ULL
Christopher Ferris106b3a82016-08-24 12:15:38 -070057struct dk_cxlflash_uvirtual {
Christopher Ferris05d08e92016-02-04 13:16:38 -080058 struct dk_cxlflash_hdr hdr;
59 __u64 context_id;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080060 __u64 lun_size;
Christopher Ferris106b3a82016-08-24 12:15:38 -070061 __u64 rsrc_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -080062 __u64 last_lba;
63 __u64 reserved[8];
Christopher Ferris6a9755d2017-01-13 14:09:31 -080064};
Christopher Ferris106b3a82016-08-24 12:15:38 -070065struct dk_cxlflash_release {
Christopher Ferris05d08e92016-02-04 13:16:38 -080066 struct dk_cxlflash_hdr hdr;
67 __u64 context_id;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080068 __u64 rsrc_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -070069 __u64 reserved[8];
Christopher Ferris05d08e92016-02-04 13:16:38 -080070};
71struct dk_cxlflash_resize {
Christopher Ferris6a9755d2017-01-13 14:09:31 -080072 struct dk_cxlflash_hdr hdr;
Christopher Ferris106b3a82016-08-24 12:15:38 -070073 __u64 context_id;
Christopher Ferris05d08e92016-02-04 13:16:38 -080074 __u64 rsrc_handle;
75 __u64 req_size;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080076 __u64 last_lba;
Christopher Ferris106b3a82016-08-24 12:15:38 -070077 __u64 reserved[8];
Christopher Ferris05d08e92016-02-04 13:16:38 -080078};
79struct dk_cxlflash_clone {
Christopher Ferris6a9755d2017-01-13 14:09:31 -080080 struct dk_cxlflash_hdr hdr;
Christopher Ferris106b3a82016-08-24 12:15:38 -070081 __u64 context_id_src;
Christopher Ferris05d08e92016-02-04 13:16:38 -080082 __u64 context_id_dst;
83 __u64 adap_fd_src;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080084 __u64 reserved[8];
Christopher Ferris106b3a82016-08-24 12:15:38 -070085};
Christopher Ferris05d08e92016-02-04 13:16:38 -080086#define DK_CXLFLASH_VERIFY_SENSE_LEN 18
87#define DK_CXLFLASH_VERIFY_HINT_SENSE 0x8000000000000000ULL
Christopher Ferris6a9755d2017-01-13 14:09:31 -080088struct dk_cxlflash_verify {
Christopher Ferris106b3a82016-08-24 12:15:38 -070089 struct dk_cxlflash_hdr hdr;
Christopher Ferris05d08e92016-02-04 13:16:38 -080090 __u64 context_id;
91 __u64 rsrc_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -080092 __u64 hint;
Christopher Ferris106b3a82016-08-24 12:15:38 -070093 __u64 last_lba;
Christopher Ferris05d08e92016-02-04 13:16:38 -080094 __u8 sense_data[DK_CXLFLASH_VERIFY_SENSE_LEN];
95 __u8 pad[6];
Christopher Ferris6a9755d2017-01-13 14:09:31 -080096 __u64 reserved[8];
Christopher Ferris106b3a82016-08-24 12:15:38 -070097};
Christopher Ferris05d08e92016-02-04 13:16:38 -080098#define DK_CXLFLASH_RECOVER_AFU_CONTEXT_RESET 0x8000000000000000ULL
99struct dk_cxlflash_recover_afu {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800100 struct dk_cxlflash_hdr hdr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700101 __u64 reason;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800102 __u64 context_id;
103 __u64 mmio_size;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800104 __u64 adap_fd;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700105 __u64 reserved[8];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800106};
107#define DK_CXLFLASH_MANAGE_LUN_WWID_LEN 16
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800108#define DK_CXLFLASH_MANAGE_LUN_ENABLE_SUPERPIPE 0x8000000000000000ULL
Christopher Ferris106b3a82016-08-24 12:15:38 -0700109#define DK_CXLFLASH_MANAGE_LUN_DISABLE_SUPERPIPE 0x4000000000000000ULL
Christopher Ferris05d08e92016-02-04 13:16:38 -0800110#define DK_CXLFLASH_MANAGE_LUN_ALL_PORTS_ACCESSIBLE 0x2000000000000000ULL
111struct dk_cxlflash_manage_lun {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800112 struct dk_cxlflash_hdr hdr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700113 __u8 wwid[DK_CXLFLASH_MANAGE_LUN_WWID_LEN];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800114 __u64 reserved[8];
115};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800116union cxlflash_ioctls {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700117 struct dk_cxlflash_attach attach;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800118 struct dk_cxlflash_detach detach;
119 struct dk_cxlflash_udirect udirect;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800120 struct dk_cxlflash_uvirtual uvirtual;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700121 struct dk_cxlflash_release release;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800122 struct dk_cxlflash_resize resize;
123 struct dk_cxlflash_clone clone;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800124 struct dk_cxlflash_verify verify;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700125 struct dk_cxlflash_recover_afu recover_afu;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800126 struct dk_cxlflash_manage_lun manage_lun;
127};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800128#define MAX_CXLFLASH_IOCTL_SZ (sizeof(union cxlflash_ioctls))
Christopher Ferris106b3a82016-08-24 12:15:38 -0700129#define CXL_MAGIC 0xCA
Christopher Ferris05d08e92016-02-04 13:16:38 -0800130#define CXL_IOWR(_n,_s) _IOWR(CXL_MAGIC, _n, struct _s)
131#define DK_CXLFLASH_ATTACH CXL_IOWR(0x80, dk_cxlflash_attach)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800132#define DK_CXLFLASH_USER_DIRECT CXL_IOWR(0x81, dk_cxlflash_udirect)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700133#define DK_CXLFLASH_RELEASE CXL_IOWR(0x82, dk_cxlflash_release)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800134#define DK_CXLFLASH_DETACH CXL_IOWR(0x83, dk_cxlflash_detach)
135#define DK_CXLFLASH_VERIFY CXL_IOWR(0x84, dk_cxlflash_verify)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800136#define DK_CXLFLASH_RECOVER_AFU CXL_IOWR(0x85, dk_cxlflash_recover_afu)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700137#define DK_CXLFLASH_MANAGE_LUN CXL_IOWR(0x86, dk_cxlflash_manage_lun)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800138#define DK_CXLFLASH_USER_VIRTUAL CXL_IOWR(0x87, dk_cxlflash_uvirtual)
139#define DK_CXLFLASH_VLUN_RESIZE CXL_IOWR(0x88, dk_cxlflash_resize)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800140#define DK_CXLFLASH_VLUN_CLONE CXL_IOWR(0x89, dk_cxlflash_clone)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700141#endif