0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011 #ifndef _SISLITE_H
0012 #define _SISLITE_H
0013
0014 #include <linux/types.h>
0015
0016 typedef u16 ctx_hndl_t;
0017 typedef u32 res_hndl_t;
0018
0019 #define SIZE_4K 4096
0020 #define SIZE_64K 65536
0021
0022
0023
0024
0025
0026 struct sisl_ioarcb {
0027 u16 ctx_id;
0028 u16 req_flags;
0029 #define SISL_REQ_FLAGS_RES_HNDL 0x8000U
0030 #define SISL_REQ_FLAGS_PORT_LUN_ID 0x0000U
0031
0032 #define SISL_REQ_FLAGS_SUP_UNDERRUN 0x4000U
0033
0034 #define SISL_REQ_FLAGS_TIMEOUT_SECS 0x0000U
0035 #define SISL_REQ_FLAGS_TIMEOUT_MSECS 0x0040U
0036 #define SISL_REQ_FLAGS_TIMEOUT_USECS 0x0080U
0037 #define SISL_REQ_FLAGS_TIMEOUT_CYCLES 0x00C0U
0038
0039 #define SISL_REQ_FLAGS_TMF_CMD 0x0004u
0040
0041 #define SISL_REQ_FLAGS_AFU_CMD 0x0002U
0042
0043 #define SISL_REQ_FLAGS_HOST_WRITE 0x0001U
0044 #define SISL_REQ_FLAGS_HOST_READ 0x0000U
0045
0046 union {
0047 u32 res_hndl;
0048 u32 port_sel;
0049
0050
0051
0052
0053 };
0054 u64 lun_id;
0055 u32 data_len;
0056 u32 ioadl_len;
0057 union {
0058 u64 data_ea;
0059 u64 ioadl_ea;
0060 };
0061 u8 msi;
0062 #define SISL_MSI_CXL_PFAULT 0
0063 #define SISL_MSI_SYNC_ERROR 1
0064 #define SISL_MSI_RRQ_UPDATED 2
0065 #define SISL_MSI_ASYNC_ERROR 3
0066
0067 u8 rrq;
0068 u16 timeout;
0069 u32 rsvd1;
0070 u8 cdb[16];
0071 #define SISL_AFU_CMD_SYNC 0xC0
0072 #define SISL_AFU_CMD_LUN_PROVISION 0xD0
0073 #define SISL_AFU_CMD_DEBUG 0xE0
0074
0075 #define SISL_AFU_LUN_PROVISION_CREATE 0x00
0076 #define SISL_AFU_LUN_PROVISION_DELETE 0x01
0077
0078 union {
0079 u64 reserved;
0080 struct sisl_ioasa *ioasa;
0081 };
0082 } __packed;
0083
0084 struct sisl_rc {
0085 u8 flags;
0086 #define SISL_RC_FLAGS_SENSE_VALID 0x80U
0087 #define SISL_RC_FLAGS_FCP_RSP_CODE_VALID 0x40U
0088 #define SISL_RC_FLAGS_OVERRUN 0x20U
0089 #define SISL_RC_FLAGS_UNDERRUN 0x10U
0090
0091 u8 afu_rc;
0092 #define SISL_AFU_RC_RHT_INVALID 0x01U
0093 #define SISL_AFU_RC_RHT_UNALIGNED 0x02U
0094 #define SISL_AFU_RC_RHT_OUT_OF_BOUNDS 0x03u
0095 #define SISL_AFU_RC_RHT_DMA_ERR 0x04u
0096
0097
0098
0099 #define SISL_AFU_RC_RHT_RW_PERM 0x05u
0100 #define SISL_AFU_RC_LXT_UNALIGNED 0x12U
0101 #define SISL_AFU_RC_LXT_OUT_OF_BOUNDS 0x13u
0102 #define SISL_AFU_RC_LXT_DMA_ERR 0x14u
0103
0104
0105
0106 #define SISL_AFU_RC_LXT_RW_PERM 0x15u
0107
0108 #define SISL_AFU_RC_NOT_XLATE_HOST 0x1au
0109
0110
0111
0112
0113
0114
0115 #define SISL_AFU_RC_NO_CHANNELS 0x20U
0116 #define SISL_AFU_RC_CAP_VIOLATION 0x21U
0117
0118
0119 #define SISL_AFU_RC_OUT_OF_DATA_BUFS 0x30U
0120 #define SISL_AFU_RC_DATA_DMA_ERR 0x31U
0121
0122
0123
0124 u8 scsi_rc;
0125 #define SISL_SCSI_RC_CHECK 0x02U
0126 #define SISL_SCSI_RC_BUSY 0x08u
0127
0128 u8 fc_rc;
0129
0130
0131
0132
0133
0134
0135
0136
0137
0138
0139
0140
0141
0142
0143
0144
0145 #define SISL_FC_RC_ABORTPEND 0x52
0146 #define SISL_FC_RC_WRABORTPEND 0x53
0147 #define SISL_FC_RC_NOLOGI 0x54
0148 #define SISL_FC_RC_NOEXP 0x55
0149 #define SISL_FC_RC_INUSE 0x56
0150 #define SISL_FC_RC_LINKDOWN 0x57
0151 #define SISL_FC_RC_ABORTOK 0x58
0152 #define SISL_FC_RC_ABORTFAIL 0x59
0153 #define SISL_FC_RC_RESID 0x5A
0154 #define SISL_FC_RC_RESIDERR 0x5B
0155
0156
0157
0158 #define SISL_FC_RC_TGTABORT 0x5C
0159 };
0160
0161 #define SISL_SENSE_DATA_LEN 20
0162 #define SISL_WWID_DATA_LEN 16
0163
0164
0165
0166
0167
0168 struct sisl_ioasa {
0169 union {
0170 struct sisl_rc rc;
0171 u32 ioasc;
0172 #define SISL_IOASC_GOOD_COMPLETION 0x00000000U
0173 };
0174
0175 union {
0176 u32 resid;
0177 u32 lunid_hi;
0178 };
0179
0180 u8 port;
0181 u8 afu_extra;
0182
0183
0184
0185 #define SISL_AFU_DMA_ERR_PAGE_IN 0x0A
0186
0187
0188
0189 #define SISL_AFU_DMA_ERR_INVALID_EA 0x0B
0190
0191
0192
0193
0194
0195
0196
0197 #define SISL_AFU_NO_CLANNELS_AMASK(afu_extra) (((afu_extra) & 0x0C) >> 2)
0198 #define SISL_AFU_NO_CLANNELS_RMASK(afu_extra) ((afu_extra) & 0x03)
0199
0200 u8 scsi_extra;
0201 u8 fc_extra;
0202
0203 union {
0204 u8 sense_data[SISL_SENSE_DATA_LEN];
0205 struct {
0206 u32 lunid_lo;
0207 u8 wwid[SISL_WWID_DATA_LEN];
0208 };
0209 };
0210
0211
0212
0213
0214 union {
0215 u64 host_use[4];
0216 u8 host_use_b[32];
0217 };
0218 } __packed;
0219
0220 #define SISL_RESP_HANDLE_T_BIT 0x1ULL
0221
0222
0223
0224
0225
0226
0227
0228
0229
0230
0231
0232
0233
0234
0235
0236 #define SISL_ENDIAN_CTRL_BE 0x8000000000000080ULL
0237 #define SISL_ENDIAN_CTRL_LE 0x0000000000000000ULL
0238
0239 #ifdef __BIG_ENDIAN
0240 #define SISL_ENDIAN_CTRL SISL_ENDIAN_CTRL_BE
0241 #else
0242 #define SISL_ENDIAN_CTRL SISL_ENDIAN_CTRL_LE
0243 #endif
0244
0245
0246 struct sisl_host_map {
0247 __be64 endian_ctrl;
0248
0249
0250
0251
0252 __be64 intr_status;
0253
0254
0255
0256
0257 #define SISL_ISTATUS_PERM_ERR_LISN_3_EA 0x0400ULL
0258 #define SISL_ISTATUS_PERM_ERR_LISN_2_EA 0x0200ULL
0259 #define SISL_ISTATUS_PERM_ERR_LISN_1_EA 0x0100ULL
0260 #define SISL_ISTATUS_PERM_ERR_LISN_3_PASID 0x0080ULL
0261 #define SISL_ISTATUS_PERM_ERR_LISN_2_PASID 0x0040ULL
0262 #define SISL_ISTATUS_PERM_ERR_LISN_1_PASID 0x0020ULL
0263 #define SISL_ISTATUS_PERM_ERR_CMDROOM 0x0010ULL
0264 #define SISL_ISTATUS_PERM_ERR_RCB_READ 0x0008ULL
0265 #define SISL_ISTATUS_PERM_ERR_SA_WRITE 0x0004ULL
0266 #define SISL_ISTATUS_PERM_ERR_RRQ_WRITE 0x0002ULL
0267
0268
0269
0270 #define SISL_ISTATUS_TEMP_ERR_PAGEIN 0x0001ULL
0271
0272
0273
0274
0275
0276
0277
0278
0279 #define SISL_ISTATUS_UNMASK (0x07FFULL)
0280 #define SISL_ISTATUS_MASK ~(SISL_ISTATUS_UNMASK)
0281
0282 __be64 intr_clear;
0283 __be64 intr_mask;
0284 __be64 ioarrin;
0285 __be64 rrq_start;
0286 __be64 rrq_end;
0287 __be64 cmd_room;
0288 __be64 ctx_ctrl;
0289 #define SISL_CTX_CTRL_UNMAP_SECTOR 0x8000000000000000ULL
0290 #define SISL_CTX_CTRL_LISN_MASK (0xFFULL)
0291 __be64 mbox_w;
0292 __be64 sq_start;
0293 __be64 sq_end;
0294 __be64 sq_head;
0295 __be64 sq_tail;
0296 __be64 sq_ctx_reset;
0297 };
0298
0299
0300 struct sisl_ctrl_map {
0301 __be64 rht_start;
0302 __be64 rht_cnt_id;
0303
0304 #define SISL_RHT_CNT_ID(cnt, ctx_id) (((cnt) << 48) | ((ctx_id) << 32))
0305
0306 __be64 ctx_cap;
0307 #define SISL_CTX_CAP_PROXY_ISSUE 0x8000000000000000ULL
0308 #define SISL_CTX_CAP_REAL_MODE 0x4000000000000000ULL
0309 #define SISL_CTX_CAP_HOST_XLATE 0x2000000000000000ULL
0310 #define SISL_CTX_CAP_PROXY_TARGET 0x1000000000000000ULL
0311 #define SISL_CTX_CAP_AFU_CMD 0x0000000000000008ULL
0312 #define SISL_CTX_CAP_GSCSI_CMD 0x0000000000000004ULL
0313 #define SISL_CTX_CAP_WRITE_CMD 0x0000000000000002ULL
0314 #define SISL_CTX_CAP_READ_CMD 0x0000000000000001ULL
0315 __be64 mbox_r;
0316 __be64 lisn_pasid[2];
0317
0318 #define SISL_LISN_PASID(_a, _b) (((_a) << 32) | (_b))
0319 __be64 lisn_ea[3];
0320 };
0321
0322
0323 struct sisl_global_regs {
0324 __be64 aintr_status;
0325
0326
0327
0328
0329
0330
0331
0332
0333
0334
0335
0336
0337
0338 #define SISL_ASTATUS_FC2_OTHER 0x80000000ULL
0339 #define SISL_ASTATUS_FC2_LOGO 0x40000000ULL
0340 #define SISL_ASTATUS_FC2_CRC_T 0x20000000ULL
0341 #define SISL_ASTATUS_FC2_LOGI_R 0x10000000ULL
0342 #define SISL_ASTATUS_FC2_LOGI_F 0x08000000ULL
0343 #define SISL_ASTATUS_FC2_LOGI_S 0x04000000ULL
0344 #define SISL_ASTATUS_FC2_LINK_DN 0x02000000ULL
0345 #define SISL_ASTATUS_FC2_LINK_UP 0x01000000ULL
0346
0347 #define SISL_ASTATUS_FC3_OTHER 0x00800000ULL
0348 #define SISL_ASTATUS_FC3_LOGO 0x00400000ULL
0349 #define SISL_ASTATUS_FC3_CRC_T 0x00200000ULL
0350 #define SISL_ASTATUS_FC3_LOGI_R 0x00100000ULL
0351 #define SISL_ASTATUS_FC3_LOGI_F 0x00080000ULL
0352 #define SISL_ASTATUS_FC3_LOGI_S 0x00040000ULL
0353 #define SISL_ASTATUS_FC3_LINK_DN 0x00020000ULL
0354 #define SISL_ASTATUS_FC3_LINK_UP 0x00010000ULL
0355
0356 #define SISL_ASTATUS_FC0_OTHER 0x00008000ULL
0357 #define SISL_ASTATUS_FC0_LOGO 0x00004000ULL
0358 #define SISL_ASTATUS_FC0_CRC_T 0x00002000ULL
0359 #define SISL_ASTATUS_FC0_LOGI_R 0x00001000ULL
0360 #define SISL_ASTATUS_FC0_LOGI_F 0x00000800ULL
0361 #define SISL_ASTATUS_FC0_LOGI_S 0x00000400ULL
0362 #define SISL_ASTATUS_FC0_LINK_DN 0x00000200ULL
0363 #define SISL_ASTATUS_FC0_LINK_UP 0x00000100ULL
0364
0365 #define SISL_ASTATUS_FC1_OTHER 0x00000080ULL
0366 #define SISL_ASTATUS_FC1_LOGO 0x00000040ULL
0367 #define SISL_ASTATUS_FC1_CRC_T 0x00000020ULL
0368 #define SISL_ASTATUS_FC1_LOGI_R 0x00000010ULL
0369 #define SISL_ASTATUS_FC1_LOGI_F 0x00000008ULL
0370 #define SISL_ASTATUS_FC1_LOGI_S 0x00000004ULL
0371 #define SISL_ASTATUS_FC1_LINK_DN 0x00000002ULL
0372 #define SISL_ASTATUS_FC1_LINK_UP 0x00000001ULL
0373
0374 #define SISL_FC_INTERNAL_UNMASK 0x0000000300000000ULL
0375 #define SISL_FC_INTERNAL_MASK ~(SISL_FC_INTERNAL_UNMASK)
0376 #define SISL_FC_INTERNAL_SHIFT 32
0377
0378 #define SISL_FC_SHUTDOWN_NORMAL 0x0000000000000010ULL
0379 #define SISL_FC_SHUTDOWN_ABRUPT 0x0000000000000020ULL
0380
0381 #define SISL_STATUS_SHUTDOWN_ACTIVE 0x0000000000000010ULL
0382 #define SISL_STATUS_SHUTDOWN_COMPLETE 0x0000000000000020ULL
0383
0384 #define SISL_ASTATUS_UNMASK 0xFFFFFFFFULL
0385 #define SISL_ASTATUS_MASK ~(SISL_ASTATUS_UNMASK)
0386
0387 __be64 aintr_clear;
0388 __be64 aintr_mask;
0389 __be64 afu_ctrl;
0390 __be64 afu_hb;
0391 __be64 afu_scratch_pad;
0392 __be64 afu_port_sel;
0393 #define SISL_AFUCONF_AR_IOARCB 0x4000ULL
0394 #define SISL_AFUCONF_AR_LXT 0x2000ULL
0395 #define SISL_AFUCONF_AR_RHT 0x1000ULL
0396 #define SISL_AFUCONF_AR_DATA 0x0800ULL
0397 #define SISL_AFUCONF_AR_RSRC 0x0400ULL
0398 #define SISL_AFUCONF_AR_IOASA 0x0200ULL
0399 #define SISL_AFUCONF_AR_RRQ 0x0100ULL
0400
0401 #define SISL_AFUCONF_AR_ALL (SISL_AFUCONF_AR_IOARCB|SISL_AFUCONF_AR_LXT| \
0402 SISL_AFUCONF_AR_RHT|SISL_AFUCONF_AR_DATA| \
0403 SISL_AFUCONF_AR_RSRC|SISL_AFUCONF_AR_IOASA| \
0404 SISL_AFUCONF_AR_RRQ)
0405 #ifdef __BIG_ENDIAN
0406 #define SISL_AFUCONF_ENDIAN 0x0000ULL
0407 #else
0408 #define SISL_AFUCONF_ENDIAN 0x0020ULL
0409 #endif
0410 #define SISL_AFUCONF_MBOX_CLR_READ 0x0010ULL
0411 __be64 afu_config;
0412 __be64 rsvd[0xf8];
0413 __le64 afu_version;
0414 __be64 interface_version;
0415 #define SISL_INTVER_CAP_SHIFT 16
0416 #define SISL_INTVER_MAJ_SHIFT 8
0417 #define SISL_INTVER_CAP_MASK 0xFFFFFFFF00000000ULL
0418 #define SISL_INTVER_MAJ_MASK 0x00000000FFFF0000ULL
0419 #define SISL_INTVER_MIN_MASK 0x000000000000FFFFULL
0420 #define SISL_INTVER_CAP_IOARRIN_CMD_MODE 0x800000000000ULL
0421 #define SISL_INTVER_CAP_SQ_CMD_MODE 0x400000000000ULL
0422 #define SISL_INTVER_CAP_RESERVED_CMD_MODE_A 0x200000000000ULL
0423 #define SISL_INTVER_CAP_RESERVED_CMD_MODE_B 0x100000000000ULL
0424 #define SISL_INTVER_CAP_LUN_PROVISION 0x080000000000ULL
0425 #define SISL_INTVER_CAP_AFU_DEBUG 0x040000000000ULL
0426 #define SISL_INTVER_CAP_OCXL_LISN 0x020000000000ULL
0427 };
0428
0429 #define CXLFLASH_NUM_FC_PORTS_PER_BANK 2
0430 #define CXLFLASH_MAX_FC_BANKS 2
0431 #define CXLFLASH_MAX_FC_PORTS (CXLFLASH_NUM_FC_PORTS_PER_BANK * \
0432 CXLFLASH_MAX_FC_BANKS)
0433 #define CXLFLASH_MAX_CONTEXT 512
0434 #define CXLFLASH_NUM_VLUNS 512
0435 #define CXLFLASH_NUM_REGS 512
0436
0437 struct fc_port_bank {
0438 __be64 fc_port_regs[CXLFLASH_NUM_FC_PORTS_PER_BANK][CXLFLASH_NUM_REGS];
0439 __be64 fc_port_luns[CXLFLASH_NUM_FC_PORTS_PER_BANK][CXLFLASH_NUM_VLUNS];
0440 };
0441
0442 struct sisl_global_map {
0443 union {
0444 struct sisl_global_regs regs;
0445 char page0[SIZE_4K];
0446 };
0447
0448 char page1[SIZE_4K];
0449
0450 struct fc_port_bank bank[CXLFLASH_MAX_FC_BANKS];
0451
0452
0453
0454 };
0455
0456
0457
0458
0459
0460
0461
0462
0463
0464
0465
0466
0467
0468
0469
0470
0471
0472 struct cxlflash_afu_map {
0473 union {
0474 struct sisl_host_map host;
0475 char harea[SIZE_64K];
0476 } hosts[CXLFLASH_MAX_CONTEXT];
0477
0478 union {
0479 struct sisl_ctrl_map ctrl;
0480 char carea[cache_line_size()];
0481 } ctrls[CXLFLASH_MAX_CONTEXT];
0482
0483 union {
0484 struct sisl_global_map global;
0485 char garea[SIZE_64K];
0486 };
0487 };
0488
0489
0490
0491
0492
0493 struct sisl_lxt_entry {
0494 u64 rlba_base;
0495
0496
0497
0498
0499
0500 };
0501
0502
0503
0504
0505
0506 struct sisl_rht_entry {
0507 struct sisl_lxt_entry *lxt_start;
0508 u32 lxt_cnt;
0509 u16 rsvd;
0510 u8 fp;
0511
0512
0513 u8 nmask;
0514 } __packed __aligned(16);
0515
0516 struct sisl_rht_entry_f1 {
0517 u64 lun_id;
0518 union {
0519 struct {
0520 u8 valid;
0521 u8 rsvd[5];
0522 u8 fp;
0523 u8 port_sel;
0524 };
0525
0526 u64 dw;
0527 };
0528 } __packed __aligned(16);
0529
0530
0531 #define SISL_RHT_FP(fmt, perm) (((fmt) << 4) | (perm))
0532
0533
0534
0535
0536 #define SISL_RHT_FP_CLONE(src_fp, cln_flags) ((src_fp) & (0xFC | (cln_flags)))
0537
0538 #define RHT_PERM_READ 0x01U
0539 #define RHT_PERM_WRITE 0x02U
0540 #define RHT_PERM_RW (RHT_PERM_READ | RHT_PERM_WRITE)
0541
0542
0543 #define SISL_RHT_PERM(fp) ((fp) & RHT_PERM_RW)
0544
0545 #define PORT0 0x01U
0546 #define PORT1 0x02U
0547 #define PORT2 0x04U
0548 #define PORT3 0x08U
0549 #define PORT_MASK(_n) ((1 << (_n)) - 1)
0550
0551
0552 #define AFU_LW_SYNC 0x0U
0553 #define AFU_HW_SYNC 0x1U
0554 #define AFU_GSYNC 0x2U
0555
0556
0557 #define TMF_LUN_RESET 0x1U
0558 #define TMF_CLEAR_ACA 0x2U
0559
0560 #endif