#ifndef _SYS_IB_ADAPTERS_TAVOR_CMD_H
#define _SYS_IB_ADAPTERS_TAVOR_CMD_H
#include <sys/types.h>
#include <sys/conf.h>
#include <sys/ddi.h>
#include <sys/sunddi.h>
#include <sys/ib/mgt/sm_attr.h>
#ifdef __cplusplus
extern "C" {
#endif
#define TAVOR_CMD_POLL_DELAY 1
#define TAVOR_CMD_POLL_MAX 3000000
#define TAVOR_NUM_MAILBOXES_SHIFT 8
#define TAVOR_NUM_INTR_MAILBOXES_SHIFT 0
#define TAVOR_MBOX_SIZE_SHIFT 0x9
#define TAVOR_MBOX_SIZE (1 << TAVOR_MBOX_SIZE_SHIFT)
#define TAVOR_MBOX_ALIGN TAVOR_MBOX_SIZE
#define TAVOR_MBOX_IS_SYNC_REQ(state, type) \
((((((state)->ts_cfg_profile->cp_streaming_consistent) && \
((state)->ts_cfg_profile->cp_consistent_syncoverride))) || \
((&((state)->ts_rsrc_hdl[(type)]))->rsrc_loc == TAVOR_IN_DDR)) \
? 0 : 1)
#define SYS_EN 0x1
#define SYS_DIS 0x2
#define QUERY_DEV_LIM 0x3
#define QUERY_FW 0x4
#define QUERY_DDR 0x5
#define QUERY_ADAPTER 0x6
#define INIT_HCA 0x7
#define CLOSE_HCA 0x8
#define INIT_IB 0x9
#define CLOSE_IB 0xA
#define QUERY_HCA 0xB
#define SET_IB 0xC
#define ACCESS_DDR 0x2E
#define SW2HW_MPT 0xD
#define QUERY_MPT 0xE
#define HW2SW_MPT 0xF
#define READ_MTT 0x10
#define WRITE_MTT 0x11
#define SYNC_TPT 0x2F
#define MAP_EQ 0x12
#define SW2HW_EQ 0x13
#define HW2SW_EQ 0x14
#define QUERY_EQ 0x15
#define SW2HW_CQ 0x16
#define HW2SW_CQ 0x17
#define QUERY_CQ 0x18
#define RESIZE_CQ 0x2C
#define RST2INIT_QP 0x19
#define INIT2INIT_QP 0x2D
#define INIT2RTR_QP 0x1A
#define RTR2RTS_QP 0x1B
#define RTS2RTS_QP 0x1C
#define SQERR2RTS_QP 0x1D
#define TOERR_QP 0x1E
#define RTS2SQD_QP 0x1F
#define SQD2RTS_QP 0x20
#define TORST_QP 0x21
#define QUERY_QP 0x22
#define CONF_SPECIAL_QP 0x23
#define MAD_IFC 0x24
#define READ_MGM 0x25
#define WRITE_MGM 0x26
#define MGID_HASH 0x27
#define CONF_NTU 0x28
#define QUERY_NTU 0x29
#define QUERY_DEBUG_MSG 0x2A
#define SET_DEBUG_MSG 0x2B
#define DIAG_RPRT 0x30
#define MOD_STAT_CFG 0x34
#define SW2HW_SRQ 0x35
#define HW2SW_SRQ 0x36
#define QUERY_SRQ 0x37
#define SQD2SQD_QP 0x38
#define MODIFY_MPT 0x39
#define TAVOR_CMD_INSUFF_RSRC 0xFFFD
#define TAVOR_CMD_TIMEOUT 0xFFFE
#define TAVOR_CMD_INVALID_STATUS 0xFFFF
#define TAVOR_CMD_SUCCESS 0x00
#define TAVOR_CMD_INTERNAL_ERR 0x01
#define TAVOR_CMD_BAD_OP 0x02
#define TAVOR_CMD_BAD_PARAM 0x03
#define TAVOR_CMD_BAD_SYS_STATE 0x04
#define TAVOR_CMD_BAD_RESOURCE 0x05
#define TAVOR_CMD_RESOURCE_BUSY 0x06
#define TAVOR_CMD_DDR_MEM_ERR 0x07
#define TAVOR_CMD_EXCEED_LIM 0x08
#define TAVOR_CMD_BAD_RES_STATE 0x09
#define TAVOR_CMD_BAD_INDEX 0x0A
#define TAVOR_CMD_BAD_NVMEM 0x0B
#define TAVOR_CMD_BAD_QP_STATE 0x10
#define TAVOR_CMD_BAD_SEG_PARAM 0x20
#define TAVOR_CMD_REG_BOUND 0x21
#define TAVOR_CMD_BAD_PKT 0x30
#define TAVOR_CMD_BAD_SIZE 0x40
#define TAVOR_CMD_QP_SMI 0
#define TAVOR_CMD_QP_GSI 1
#define TAVOR_CMD_QP_RAW_IPV6 2
#define TAVOR_CMD_QP_RAW_ETH 3
#define TAVOR_CMD_OP_ALT_PATH (1 << 0)
#define TAVOR_CMD_OP_RRE (1 << 1)
#define TAVOR_CMD_OP_RAE (1 << 2)
#define TAVOR_CMD_OP_RWE (1 << 3)
#define TAVOR_CMD_OP_PKEYINDX (1 << 4)
#define TAVOR_CMD_OP_QKEY (1 << 5)
#define TAVOR_CMD_OP_MINRNRNAK (1 << 6)
#define TAVOR_CMD_OP_PRIM_PATH (1 << 7)
#define TAVOR_CMD_OP_SRA_SET (1 << 8)
#define TAVOR_CMD_OP_RRA_SET (1 << 9)
#define TAVOR_CMD_OP_PM_STATE (1 << 10)
#define TAVOR_CMD_OP_PRIM_PORT (1 << 11)
#define TAVOR_CMD_OP_RETRYCNT (1 << 12)
#define TAVOR_CMD_OP_ALT_RNRRETRY (1 << 13)
#define TAVOR_CMD_OP_ACKTIMEOUT (1 << 14)
#define TAVOR_CMD_OP_PRIM_RNRRETRY (1 << 15)
#define TAVOR_CMD_OP_SCHEDQUEUE (1 << 16)
#define TAVOR_CMD_REQ_SQD_EVENT 0x80000000
#define TAVOR_CMD_DIRECT_TO_RESET (1 << 1)
#define TAVOR_CMD_DO_OUTMBOX (0)
#define TAVOR_CMD_NO_OUTMBOX (1 << 0)
#define TAVOR_CMD_SYS_EN_NORMAL 0
#define TAVOR_CMD_SYS_EN_DDR_MEMCHECK 2
#define TAVOR_CMD_SYS_EN_DDR_PRESERVE 3
#define TAVOR_CMD_MAP_EQ_EVT_MAP 0
#define TAVOR_CMD_MAP_EQ_EVT_UNMAP 1
#define TAVOR_CMD_UNMAP_EQ_MASK 0x80000000
#define TAVOR_CMD_MKEY_CHECK 0
#define TAVOR_CMD_MKEY_DONTCHECK 1
#define TAVOR_CMD_BKEY_DONTCHECK 2
#define TAVOR_CMD_MAD_IFC_SIZE 0x100
#define TAVOR_CMD_MADDATA_OFFSET 0x40
#define TAVOR_CMD_MADHDR0 0x01010101
#define TAVOR_CMD_MADHDR1 0x00000000
#define TAVOR_CMD_MADHDR2 0x00000000
#define TAVOR_CMD_MADHDR3 0x00000000
#define TAVOR_CMD_PORTINFO 0x00150000
#define TAVOR_CMD_NODEINFO 0x00110000
#define TAVOR_CMD_NODEDESC 0x00100000
#define TAVOR_CMD_GUIDINFO 0x00140000
#define TAVOR_CMD_PKEYTBLE 0x00160000
#define TAVOR_CMD_PERF_GET 0x01040101
#define TAVOR_CMD_PERF_SET 0x01040102
#define TAVOR_CMD_PERFCNTRS 0x00120000
#define TAVOR_CMD_PERFATTR 0x00000000
#define TAVOR_CMD_WRITEMTT_RSVD_SZ 0x10
#define TAVOR_CMD_SETIB_SZ 0x8
#define TAVOR_CMD_MGIDHASH_SZ 0x10
#define TAVOR_CMD_RSRC_HW2SW 0
#define TAVOR_CMD_RSRC_SW2HW 1
#ifdef _LITTLE_ENDIAN
#define TAVOR_GETPORTINFO_SWAP(portinfo) \
{ \
(portinfo)->M_Key = ddi_swap64((portinfo)->M_Key); \
(portinfo)->GidPrefix = ddi_swap64((portinfo)->GidPrefix); \
(portinfo)->LID = ddi_swap16((portinfo)->LID); \
(portinfo)->MasterSMLID = ddi_swap16((portinfo)->MasterSMLID); \
(portinfo)->CapabilityMask = \
ddi_swap32((portinfo)->CapabilityMask); \
(portinfo)->DiagCode = ddi_swap16((portinfo)->DiagCode); \
(portinfo)->M_KeyLeasePeriod = \
ddi_swap16((portinfo)->M_KeyLeasePeriod); \
(portinfo)->M_KeyViolations = \
ddi_swap16((portinfo)->M_KeyViolations); \
(portinfo)->P_KeyViolations = \
ddi_swap16((portinfo)->P_KeyViolations); \
(portinfo)->Q_KeyViolations = \
ddi_swap16((portinfo)->Q_KeyViolations); \
}
#else
#define TAVOR_GETPORTINFO_SWAP(portinfo)
#endif
#ifdef _LITTLE_ENDIAN
#define TAVOR_GETNODEINFO_SWAP(nodeinfo) \
{ \
uint32_t tmp; \
\
tmp = ddi_swap32(((uint32_t *)nodeinfo)[9]); \
(nodeinfo)->VendorID = tmp & 0xFFFFFF; \
(nodeinfo)->LocalPortNum = tmp >> 24; \
(nodeinfo)->Revision = \
ddi_swap32(((uint32_t *)nodeinfo)[8]); \
tmp = ddi_swap32(((uint32_t *)nodeinfo)[7]); \
(nodeinfo)->PartitionCap = tmp >> 16; \
(nodeinfo)->DeviceID = tmp & 0xFFFF; \
(nodeinfo)->PortGUID = ddi_swap64((((uint64_t) \
(((uint32_t *)nodeinfo)[6]) << 32) | \
((uint32_t *)nodeinfo)[5])); \
(nodeinfo)->NodeGUID = ddi_swap64((((uint64_t) \
(((uint32_t *)nodeinfo)[4]) << 32) | \
((uint32_t *)nodeinfo)[3])); \
(nodeinfo)->SystemImageGUID = ddi_swap64((((uint64_t) \
(((uint32_t *)nodeinfo)[2]) << 32) | \
((uint32_t *)nodeinfo)[1])); \
}
#else
#define TAVOR_GETNODEINFO_SWAP(nodeinfo) \
{ \
uint32_t tmp; \
\
tmp = ((uint32_t *)nodeinfo)[9]; \
(nodeinfo)->VendorID = tmp & 0xFFFFFF; \
(nodeinfo)->LocalPortNum = tmp >> 24; \
(nodeinfo)->Revision = ((uint32_t *)nodeinfo)[8]; \
tmp = ((uint32_t *)nodeinfo)[7]; \
(nodeinfo)->PartitionCap = tmp >> 16; \
(nodeinfo)->DeviceID = tmp & 0xFFFF; \
(nodeinfo)->PortGUID = (((uint64_t) \
(((uint32_t *)nodeinfo)[5]) << 32) | \
((uint32_t *)nodeinfo)[6]); \
(nodeinfo)->NodeGUID = (((uint64_t) \
(((uint32_t *)nodeinfo)[3]) << 32) | \
((uint32_t *)nodeinfo)[4]); \
(nodeinfo)->SystemImageGUID = (((uint64_t) \
(((uint32_t *)nodeinfo)[1]) << 32) | \
((uint32_t *)nodeinfo)[2]); \
}
#endif
#ifdef _LITTLE_ENDIAN
#define TAVOR_GETGUIDINFO_SWAP(guidinfo) \
{ \
int i; \
\
for (i = 0; i < 8; i++) { \
(guidinfo)->GUIDBlocks[i] = \
ddi_swap64((guidinfo)->GUIDBlocks[i]); \
} \
}
#else
#define TAVOR_GETGUIDINFO_SWAP(guidinfo)
#endif
#ifdef _LITTLE_ENDIAN
#define TAVOR_GETPKEYTABLE_SWAP(pkeytable) \
{ \
int i; \
\
for (i = 0; i < 32; i++) { \
(pkeytable)->P_KeyTableBlocks[i] = \
ddi_swap16((pkeytable)->P_KeyTableBlocks[i]); \
} \
}
#else
#define TAVOR_GETPKEYTABLE_SWAP(pkeytable)
#endif
#define TAVOR_CMD_MODIFY_MPT_RESIZESRQ 3
#define TAVOR_CMD_MODIFY_MPT_SWAPFULL 5
typedef struct tavor_mbox_s {
void *mb_addr;
uint64_t mb_mapaddr;
ddi_acc_handle_t mb_acchdl;
tavor_rsrc_t *mb_rsrcptr;
uint_t mb_sync;
uint_t mb_indx;
uint_t mb_next;
uint_t mb_prev;
} tavor_mbox_t;
typedef struct tavor_mboxlist_s {
kmutex_t mbl_lock;
kcondvar_t mbl_cv;
tavor_mbox_t *mbl_mbox;
uint_t mbl_list_sz;
uint_t mbl_num_alloc;
uint_t mbl_head_indx;
uint_t mbl_tail_indx;
uint_t mbl_entries_free;
uint_t mbl_waiters;
uint_t mbl_pollers;
uint_t mbl_signal;
} tavor_mboxlist_t;
_NOTE(MUTEX_PROTECTS_DATA(tavor_mboxlist_t::mbl_lock,
tavor_mboxlist_t::mbl_mbox
tavor_mboxlist_t::mbl_list_sz
tavor_mboxlist_t::mbl_num_alloc
tavor_mboxlist_t::mbl_cv
tavor_mboxlist_t::mbl_head_indx
tavor_mboxlist_t::mbl_tail_indx
tavor_mboxlist_t::mbl_entries_free
tavor_mboxlist_t::mbl_waiters
tavor_mboxlist_t::mbl_pollers
tavor_mboxlist_t::mbl_signal
tavor_mbox_t::mb_next
tavor_mbox_t::mb_prev))
typedef struct tavor_mbox_info_s {
uint_t mbi_alloc_flags;
uint_t mbi_sleep_context;
tavor_mbox_t *mbi_in;
tavor_mbox_t *mbi_out;
} tavor_mbox_info_t;
#define TAVOR_ALLOC_INMBOX (1 << 0)
#define TAVOR_ALLOC_OUTMBOX (1 << 1)
typedef struct tavor_cmd_s {
kmutex_t cmd_comp_lock;
kcondvar_t cmd_comp_cv;
uint64_t cmd_outparm;
uint_t cmd_status;
uint_t cmd_indx;
uint_t cmd_next;
uint_t cmd_prev;
} tavor_cmd_t;
_NOTE(MUTEX_PROTECTS_DATA(tavor_cmd_t::cmd_comp_lock,
tavor_cmd_t::cmd_comp_cv
tavor_cmd_t::cmd_status))
typedef struct tavor_cmdlist_s {
kmutex_t cml_lock;
kcondvar_t cml_cv;
tavor_cmd_t *cml_cmd;
uint_t cml_list_sz;
uint_t cml_num_alloc;
uint_t cml_head_indx;
uint_t cml_tail_indx;
uint_t cml_entries_free;
uint_t cml_waiters;
} tavor_cmdlist_t;
_NOTE(MUTEX_PROTECTS_DATA(tavor_cmdlist_t::cml_lock,
tavor_cmdlist_t::cml_cv
tavor_cmdlist_t::cml_cmd
tavor_cmdlist_t::cml_list_sz
tavor_cmdlist_t::cml_num_alloc
tavor_cmdlist_t::cml_head_indx
tavor_cmdlist_t::cml_tail_indx
tavor_cmdlist_t::cml_entries_free
tavor_cmdlist_t::cml_waiters
tavor_cmd_t::cmd_next
tavor_cmd_t::cmd_prev))
_NOTE(LOCK_ORDER(tavor_cmdlist_t::cml_lock
tavor_cmd_t::cmd_comp_lock))
typedef struct tavor_cmd_post_s {
uint64_t cp_inparm;
uint64_t cp_outparm;
uint32_t cp_inmod;
uint16_t cp_opcode;
uint16_t cp_opmod;
uint32_t cp_flags;
} tavor_cmd_post_t;
#define TAVOR_CMD_SLEEP_NOSPIN TAVOR_SLEEP
#define TAVOR_CMD_NOSLEEP_SPIN TAVOR_NOSLEEP
int tavor_cmd_post(tavor_state_t *state, tavor_cmd_post_t *cmdpost);
int tavor_mbox_alloc(tavor_state_t *state, tavor_mbox_info_t *mbox_info,
uint_t mbox_wait);
void tavor_mbox_free(tavor_state_t *state, tavor_mbox_info_t *mbox_info);
int tavor_cmd_complete_handler(tavor_state_t *state, tavor_eqhdl_t eq,
tavor_hw_eqe_t *eqe);
int tavor_inmbox_list_init(tavor_state_t *state);
int tavor_intr_inmbox_list_init(tavor_state_t *state);
int tavor_outmbox_list_init(tavor_state_t *state);
int tavor_intr_outmbox_list_init(tavor_state_t *state);
void tavor_inmbox_list_fini(tavor_state_t *state);
void tavor_intr_inmbox_list_fini(tavor_state_t *state);
void tavor_outmbox_list_fini(tavor_state_t *state);
void tavor_intr_outmbox_list_fini(tavor_state_t *state);
int tavor_outstanding_cmdlist_init(tavor_state_t *state);
void tavor_outstanding_cmdlist_fini(tavor_state_t *state);
int tavor_sys_en_cmd_post(tavor_state_t *state, uint_t flags,
uint64_t *errorcode, uint_t sleepflag);
int tavor_sys_dis_cmd_post(tavor_state_t *state, uint_t sleepflag);
int tavor_init_hca_cmd_post(tavor_state_t *state,
tavor_hw_initqueryhca_t *inithca, uint_t sleepflag);
int tavor_close_hca_cmd_post(tavor_state_t *state, uint_t sleepflag);
int tavor_init_ib_cmd_post(tavor_state_t *state,
tavor_hw_initib_t *initib, uint_t port, uint_t sleepflag);
int tavor_close_ib_cmd_post(tavor_state_t *state, uint_t port,
uint_t sleepflag);
int tavor_set_ib_cmd_post(tavor_state_t *state, uint32_t capmask,
uint_t port, uint_t reset_qkey, uint_t sleepflag);
int tavor_cmn_qp_cmd_post(tavor_state_t *state, uint_t opcode,
tavor_hw_qpc_t *qp, uint_t qpindx, uint32_t opmask, uint_t sleepflag);
int tavor_cmn_query_cmd_post(tavor_state_t *state, uint_t opcode,
uint_t queryindx, void *query, uint_t size, uint_t sleepflag);
int tavor_cmn_ownership_cmd_post(tavor_state_t *state, uint_t opcode,
void *hwrsrc, uint_t size, uint_t hwrsrcindx, uint_t sleepflag);
int tavor_mad_ifc_cmd_post(tavor_state_t *state, uint_t port,
uint_t sleepflag, uint32_t *mad, uint32_t *resp);
int tavor_getportinfo_cmd_post(tavor_state_t *state, uint_t port,
uint_t sleepflag, sm_portinfo_t *portinfo);
int tavor_getnodeinfo_cmd_post(tavor_state_t *state, uint_t sleepflag,
sm_nodeinfo_t *nodeinfo);
int tavor_getnodedesc_cmd_post(tavor_state_t *state, uint_t sleepflag,
sm_nodedesc_t *nodedesc);
int tavor_getguidinfo_cmd_post(tavor_state_t *state, uint_t port,
uint_t guidblock, uint_t sleepflag, sm_guidinfo_t *guidinfo);
int tavor_getpkeytable_cmd_post(tavor_state_t *state, uint_t port,
uint_t pkeyblock, uint_t sleepflag, sm_pkey_table_t *pkeytable);
int tavor_getperfcntr_cmd_post(tavor_state_t *state, uint_t port,
uint_t sleepflag, tavor_hw_sm_perfcntr_t *perfinfo, int reset);
int tavor_write_mtt_cmd_post(tavor_state_t *state,
tavor_mbox_info_t *mbox_info, uint_t num_mtt, uint_t sleepflag);
int tavor_sync_tpt_cmd_post(tavor_state_t *state, uint_t sleepflag);
int tavor_map_eq_cmd_post(tavor_state_t *state, uint_t map,
uint_t eqcindx, uint64_t eqmapmask, uint_t sleepflag);
int tavor_resize_cq_cmd_post(tavor_state_t *state, tavor_hw_cqc_t *cqc,
uint_t cqcindx, uint32_t *prod_indx, uint_t sleepflag);
int tavor_conf_special_qp_cmd_post(tavor_state_t *state, uint_t qpindx,
uint_t qptype, uint_t sleepflag);
int tavor_mgid_hash_cmd_post(tavor_state_t *state, uint64_t mgid_h,
uint64_t mgid_l, uint64_t *mgid_hash, uint_t sleepflag);
int tavor_read_mgm_cmd_post(tavor_state_t *state, tavor_hw_mcg_t *mcg,
uint_t mcgindx, uint_t sleepflag);
int tavor_write_mgm_cmd_post(tavor_state_t *state, tavor_hw_mcg_t *mcg,
uint_t mcgindx, uint_t sleepflag);
int tavor_mod_stat_cfg_cmd_post(tavor_state_t *state);
int tavor_modify_mpt_cmd_post(tavor_state_t *state, tavor_hw_mpt_t *mpt,
uint_t mptindx, uint_t flags, uint_t sleepflag);
#ifdef __cplusplus
}
#endif
#endif