Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags   |
/* SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause */
/*
* Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All rights reserved.
*/
#ifndef _EFA_ADMIN_CMDS_H_
#define _EFA_ADMIN_CMDS_H_
#define EFA_ADMIN_API_VERSION_MAJOR 0
#define EFA_ADMIN_API_VERSION_MINOR 1
/* EFA admin queue opcodes */
enum efa_admin_aq_opcode {
<------>EFA_ADMIN_CREATE_QP = 1,
<------>EFA_ADMIN_MODIFY_QP = 2,
<------>EFA_ADMIN_QUERY_QP = 3,
<------>EFA_ADMIN_DESTROY_QP = 4,
<------>EFA_ADMIN_CREATE_AH = 5,
<------>EFA_ADMIN_DESTROY_AH = 6,
<------>EFA_ADMIN_REG_MR = 7,
<------>EFA_ADMIN_DEREG_MR = 8,
<------>EFA_ADMIN_CREATE_CQ = 9,
<------>EFA_ADMIN_DESTROY_CQ = 10,
<------>EFA_ADMIN_GET_FEATURE = 11,
<------>EFA_ADMIN_SET_FEATURE = 12,
<------>EFA_ADMIN_GET_STATS = 13,
<------>EFA_ADMIN_ALLOC_PD = 14,
<------>EFA_ADMIN_DEALLOC_PD = 15,
<------>EFA_ADMIN_ALLOC_UAR = 16,
<------>EFA_ADMIN_DEALLOC_UAR = 17,
<------>EFA_ADMIN_MAX_OPCODE = 17,
};
enum efa_admin_aq_feature_id {
<------>EFA_ADMIN_DEVICE_ATTR = 1,
<------>EFA_ADMIN_AENQ_CONFIG = 2,
<------>EFA_ADMIN_NETWORK_ATTR = 3,
<------>EFA_ADMIN_QUEUE_ATTR = 4,
<------>EFA_ADMIN_HW_HINTS = 5,
<------>EFA_ADMIN_HOST_INFO = 6,
};
/* QP transport type */
enum efa_admin_qp_type {
<------>/* Unreliable Datagram */
<------>EFA_ADMIN_QP_TYPE_UD = 1,
<------>/* Scalable Reliable Datagram */
<------>EFA_ADMIN_QP_TYPE_SRD = 2,
};
/* QP state */
enum efa_admin_qp_state {
<------>EFA_ADMIN_QP_STATE_RESET = 0,
<------>EFA_ADMIN_QP_STATE_INIT = 1,
<------>EFA_ADMIN_QP_STATE_RTR = 2,
<------>EFA_ADMIN_QP_STATE_RTS = 3,
<------>EFA_ADMIN_QP_STATE_SQD = 4,
<------>EFA_ADMIN_QP_STATE_SQE = 5,
<------>EFA_ADMIN_QP_STATE_ERR = 6,
};
enum efa_admin_get_stats_type {
<------>EFA_ADMIN_GET_STATS_TYPE_BASIC = 0,
<------>EFA_ADMIN_GET_STATS_TYPE_MESSAGES = 1,
<------>EFA_ADMIN_GET_STATS_TYPE_RDMA_READ = 2,
};
enum efa_admin_get_stats_scope {
<------>EFA_ADMIN_GET_STATS_SCOPE_ALL = 0,
<------>EFA_ADMIN_GET_STATS_SCOPE_QUEUE = 1,
};
/*
* QP allocation sizes, converted by fabric QueuePair (QP) create command
* from QP capabilities.
*/
struct efa_admin_qp_alloc_size {
<------>/* Send descriptor ring size in bytes */
<------>u32 send_queue_ring_size;
<------>/* Max number of WQEs that can be outstanding on send queue. */
<------>u32 send_queue_depth;
<------>/*
<------> * Recv descriptor ring size in bytes, sufficient for user-provided
<------> * number of WQEs
<------> */
<------>u32 recv_queue_ring_size;
<------>/* Max number of WQEs that can be outstanding on recv queue */
<------>u32 recv_queue_depth;
};
struct efa_admin_create_qp_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* Protection Domain associated with this QP */
<------>u16 pd;
<------>/* QP type */
<------>u8 qp_type;
<------>/*
<------> * 0 : sq_virt - If set, SQ ring base address is
<------> * virtual (IOVA returned by MR registration)
<------> * 1 : rq_virt - If set, RQ ring base address is
<------> * virtual (IOVA returned by MR registration)
<------> * 7:2 : reserved - MBZ
<------> */
<------>u8 flags;
<------>/*
<------> * Send queue (SQ) ring base physical address. This field is not
<------> * used if this is a Low Latency Queue(LLQ).
<------> */
<------>u64 sq_base_addr;
<------>/* Receive queue (RQ) ring base address. */
<------>u64 rq_base_addr;
<------>/* Index of CQ to be associated with Send Queue completions */
<------>u32 send_cq_idx;
<------>/* Index of CQ to be associated with Recv Queue completions */
<------>u32 recv_cq_idx;
<------>/*
<------> * Memory registration key for the SQ ring, used only when not in
<------> * LLQ mode and base address is virtual
<------> */
<------>u32 sq_l_key;
<------>/*
<------> * Memory registration key for the RQ ring, used only when base
<------> * address is virtual
<------> */
<------>u32 rq_l_key;
<------>/* Requested QP allocation sizes */
<------>struct efa_admin_qp_alloc_size qp_alloc_size;
<------>/* UAR number */
<------>u16 uar;
<------>/* MBZ */
<------>u16 reserved;
<------>/* MBZ */
<------>u32 reserved2;
};
struct efa_admin_create_qp_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/*
<------> * Opaque handle to be used for consequent admin operations on the
<------> * QP
<------> */
<------>u32 qp_handle;
<------>/*
<------> * QP number in the given EFA virtual device. Least-significant bits
<------> * (as needed according to max_qp) carry unique QP ID
<------> */
<------>u16 qp_num;
<------>/* MBZ */
<------>u16 reserved;
<------>/* Index of sub-CQ for Send Queue completions */
<------>u16 send_sub_cq_idx;
<------>/* Index of sub-CQ for Receive Queue completions */
<------>u16 recv_sub_cq_idx;
<------>/* SQ doorbell address, as offset to PCIe DB BAR */
<------>u32 sq_db_offset;
<------>/* RQ doorbell address, as offset to PCIe DB BAR */
<------>u32 rq_db_offset;
<------>/*
<------> * low latency send queue ring base address as an offset to PCIe
<------> * MMIO LLQ_MEM BAR
<------> */
<------>u32 llq_descriptors_offset;
};
struct efa_admin_modify_qp_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/*
<------> * Mask indicating which fields should be updated
<------> * 0 : qp_state
<------> * 1 : cur_qp_state
<------> * 2 : qkey
<------> * 3 : sq_psn
<------> * 4 : sq_drained_async_notify
<------> * 5 : rnr_retry
<------> * 31:6 : reserved
<------> */
<------>u32 modify_mask;
<------>/* QP handle returned by create_qp command */
<------>u32 qp_handle;
<------>/* QP state */
<------>u32 qp_state;
<------>/* Override current QP state (before applying the transition) */
<------>u32 cur_qp_state;
<------>/* QKey */
<------>u32 qkey;
<------>/* SQ PSN */
<------>u32 sq_psn;
<------>/* Enable async notification when SQ is drained */
<------>u8 sq_drained_async_notify;
<------>/* Number of RNR retries (valid only for SRD QPs) */
<------>u8 rnr_retry;
<------>/* MBZ */
<------>u16 reserved2;
};
struct efa_admin_modify_qp_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
struct efa_admin_query_qp_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* QP handle returned by create_qp command */
<------>u32 qp_handle;
};
struct efa_admin_query_qp_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/* QP state */
<------>u32 qp_state;
<------>/* QKey */
<------>u32 qkey;
<------>/* SQ PSN */
<------>u32 sq_psn;
<------>/* Indicates that draining is in progress */
<------>u8 sq_draining;
<------>/* Number of RNR retries (valid only for SRD QPs) */
<------>u8 rnr_retry;
<------>/* MBZ */
<------>u16 reserved2;
};
struct efa_admin_destroy_qp_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* QP handle returned by create_qp command */
<------>u32 qp_handle;
};
struct efa_admin_destroy_qp_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
/*
* Create Address Handle command parameters. Must not be called more than
* once for the same destination
*/
struct efa_admin_create_ah_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* Destination address in network byte order */
<------>u8 dest_addr[16];
<------>/* PD number */
<------>u16 pd;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_create_ah_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/* Target interface address handle (opaque) */
<------>u16 ah;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_destroy_ah_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* Target interface address handle (opaque) */
<------>u16 ah;
<------>/* PD number */
<------>u16 pd;
};
struct efa_admin_destroy_ah_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
/*
* Registration of MemoryRegion, required for QP working with Virtual
* Addresses. In standard verbs semantics, region length is limited to 2GB
* space, but EFA offers larger MR support for large memory space, to ease
* on users working with very large datasets (i.e. full GPU memory mapping).
*/
struct efa_admin_reg_mr_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* Protection Domain */
<------>u16 pd;
<------>/* MBZ */
<------>u16 reserved16_w1;
<------>/* Physical Buffer List, each element is page-aligned. */
<------>union {
<------><------>/*
<------><------> * Inline array of guest-physical page addresses of user
<------><------> * memory pages (optimization for short region
<------><------> * registrations)
<------><------> */
<------><------>u64 inline_pbl_array[4];
<------><------>/* points to PBL (direct or indirect, chained if needed) */
<------><------>struct efa_admin_ctrl_buff_info pbl;
<------>} pbl;
<------>/* Memory region length, in bytes. */
<------>u64 mr_length;
<------>/*
<------> * flags and page size
<------> * 4:0 : phys_page_size_shift - page size is (1 <<
<------> * phys_page_size_shift). Page size is used for
<------> * building the Virtual to Physical address mapping
<------> * 6:5 : reserved - MBZ
<------> * 7 : mem_addr_phy_mode_en - Enable bit for physical
<------> * memory registration (no translation), can be used
<------> * only by privileged clients. If set, PBL must
<------> * contain a single entry.
<------> */
<------>u8 flags;
<------>/*
<------> * permissions
<------> * 0 : local_write_enable - Local write permissions:
<------> * must be set for RQ buffers and buffers posted for
<------> * RDMA Read requests
<------> * 1 : reserved1 - MBZ
<------> * 2 : remote_read_enable - Remote read permissions:
<------> * must be set to enable RDMA read from the region
<------> * 7:3 : reserved2 - MBZ
<------> */
<------>u8 permissions;
<------>/* MBZ */
<------>u16 reserved16_w5;
<------>/* number of pages in PBL (redundant, could be calculated) */
<------>u32 page_num;
<------>/*
<------> * IO Virtual Address associated with this MR. If
<------> * mem_addr_phy_mode_en is set, contains the physical address of
<------> * the region.
<------> */
<------>u64 iova;
};
struct efa_admin_reg_mr_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/*
<------> * L_Key, to be used in conjunction with local buffer references in
<------> * SQ and RQ WQE, or with virtual RQ/CQ rings
<------> */
<------>u32 l_key;
<------>/*
<------> * R_Key, to be used in RDMA messages to refer to remotely accessed
<------> * memory region
<------> */
<------>u32 r_key;
};
struct efa_admin_dereg_mr_cmd {
<------>/* Common Admin Queue descriptor */
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/* L_Key, memory region's l_key */
<------>u32 l_key;
};
struct efa_admin_dereg_mr_resp {
<------>/* Common Admin Queue completion descriptor */
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
struct efa_admin_create_cq_cmd {
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>/*
<------> * 4:0 : reserved5 - MBZ
<------> * 5 : interrupt_mode_enabled - if set, cq operates
<------> * in interrupt mode (i.e. CQ events and MSI-X are
<------> * generated), otherwise - polling
<------> * 6 : virt - If set, ring base address is virtual
<------> * (IOVA returned by MR registration)
<------> * 7 : reserved6 - MBZ
<------> */
<------>u8 cq_caps_1;
<------>/*
<------> * 4:0 : cq_entry_size_words - size of CQ entry in
<------> * 32-bit words, valid values: 4, 8.
<------> * 7:5 : reserved7 - MBZ
<------> */
<------>u8 cq_caps_2;
<------>/* completion queue depth in # of entries. must be power of 2 */
<------>u16 cq_depth;
<------>/* msix vector assigned to this cq */
<------>u32 msix_vector_idx;
<------>/*
<------> * CQ ring base address, virtual or physical depending on 'virt'
<------> * flag
<------> */
<------>struct efa_common_mem_addr cq_ba;
<------>/*
<------> * Memory registration key for the ring, used only when base
<------> * address is virtual
<------> */
<------>u32 l_key;
<------>/*
<------> * number of sub cqs - must be equal to sub_cqs_per_cq of queue
<------> * attributes.
<------> */
<------>u16 num_sub_cqs;
<------>/* UAR number */
<------>u16 uar;
};
struct efa_admin_create_cq_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>u16 cq_idx;
<------>/* actual cq depth in number of entries */
<------>u16 cq_actual_depth;
};
struct efa_admin_destroy_cq_cmd {
<------>struct efa_admin_aq_common_desc aq_common_desc;
<------>u16 cq_idx;
<------>/* MBZ */
<------>u16 reserved1;
};
struct efa_admin_destroy_cq_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
/*
* EFA AQ Get Statistics command. Extended statistics are placed in control
* buffer pointed by AQ entry
*/
struct efa_admin_aq_get_stats_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
<------>union {
<------><------>/* command specific inline data */
<------><------>u32 inline_data_w1[3];
<------><------>struct efa_admin_ctrl_buff_info control_buffer;
<------>} u;
<------>/* stats type as defined in enum efa_admin_get_stats_type */
<------>u8 type;
<------>/* stats scope defined in enum efa_admin_get_stats_scope */
<------>u8 scope;
<------>u16 scope_modifier;
};
struct efa_admin_basic_stats {
<------>u64 tx_bytes;
<------>u64 tx_pkts;
<------>u64 rx_bytes;
<------>u64 rx_pkts;
<------>u64 rx_drops;
};
struct efa_admin_messages_stats {
<------>u64 send_bytes;
<------>u64 send_wrs;
<------>u64 recv_bytes;
<------>u64 recv_wrs;
};
struct efa_admin_rdma_read_stats {
<------>u64 read_wrs;
<------>u64 read_bytes;
<------>u64 read_wr_err;
<------>u64 read_resp_bytes;
};
struct efa_admin_acq_get_stats_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>union {
<------><------>struct efa_admin_basic_stats basic_stats;
<------><------>struct efa_admin_messages_stats messages_stats;
<------><------>struct efa_admin_rdma_read_stats rdma_read_stats;
<------>} u;
};
struct efa_admin_get_set_feature_common_desc {
<------>/*
<------> * 1:0 : select - 0x1 - current value; 0x3 - default
<------> * value
<------> * 7:3 : reserved3 - MBZ
<------> */
<------>u8 flags;
<------>/* as appears in efa_admin_aq_feature_id */
<------>u8 feature_id;
<------>/* MBZ */
<------>u16 reserved16;
};
struct efa_admin_feature_device_attr_desc {
<------>/* Bitmap of efa_admin_aq_feature_id */
<------>u64 supported_features;
<------>/* Bitmap of supported page sizes in MR registrations */
<------>u64 page_size_cap;
<------>u32 fw_version;
<------>u32 admin_api_version;
<------>u32 device_version;
<------>/* Bar used for SQ and RQ doorbells */
<------>u16 db_bar;
<------>/* Indicates how many bits are used on physical address access */
<------>u8 phys_addr_width;
<------>/* Indicates how many bits are used on virtual address access */
<------>u8 virt_addr_width;
<------>/*
<------> * 0 : rdma_read - If set, RDMA Read is supported on
<------> * TX queues
<------> * 1 : rnr_retry - If set, RNR retry is supported on
<------> * modify QP command
<------> * 31:2 : reserved - MBZ
<------> */
<------>u32 device_caps;
<------>/* Max RDMA transfer size in bytes */
<------>u32 max_rdma_size;
};
struct efa_admin_feature_queue_attr_desc {
<------>/* The maximum number of queue pairs supported */
<------>u32 max_qp;
<------>/* Maximum number of WQEs per Send Queue */
<------>u32 max_sq_depth;
<------>/* Maximum size of data that can be sent inline in a Send WQE */
<------>u32 inline_buf_size;
<------>/* Maximum number of buffer descriptors per Recv Queue */
<------>u32 max_rq_depth;
<------>/* The maximum number of completion queues supported per VF */
<------>u32 max_cq;
<------>/* Maximum number of CQEs per Completion Queue */
<------>u32 max_cq_depth;
<------>/* Number of sub-CQs to be created for each CQ */
<------>u16 sub_cqs_per_cq;
<------>/* Minimum number of WQEs per SQ */
<------>u16 min_sq_depth;
<------>/* Maximum number of SGEs (buffers) allowed for a single send WQE */
<------>u16 max_wr_send_sges;
<------>/* Maximum number of SGEs allowed for a single recv WQE */
<------>u16 max_wr_recv_sges;
<------>/* The maximum number of memory regions supported */
<------>u32 max_mr;
<------>/* The maximum number of pages can be registered */
<------>u32 max_mr_pages;
<------>/* The maximum number of protection domains supported */
<------>u32 max_pd;
<------>/* The maximum number of address handles supported */
<------>u32 max_ah;
<------>/* The maximum size of LLQ in bytes */
<------>u32 max_llq_size;
<------>/* Maximum number of SGEs for a single RDMA read WQE */
<------>u16 max_wr_rdma_sges;
<------>/*
<------> * Maximum number of bytes that can be written to SQ between two
<------> * consecutive doorbells (in units of 64B). Driver must ensure that only
<------> * complete WQEs are written to queue before issuing a doorbell.
<------> * Examples: max_tx_batch=16 and WQE size = 64B, means up to 16 WQEs can
<------> * be written to SQ between two consecutive doorbells. max_tx_batch=11
<------> * and WQE size = 128B, means up to 5 WQEs can be written to SQ between
<------> * two consecutive doorbells. Zero means unlimited.
<------> */
<------>u16 max_tx_batch;
};
struct efa_admin_feature_aenq_desc {
<------>/* bitmask for AENQ groups the device can report */
<------>u32 supported_groups;
<------>/* bitmask for AENQ groups to report */
<------>u32 enabled_groups;
};
struct efa_admin_feature_network_attr_desc {
<------>/* Raw address data in network byte order */
<------>u8 addr[16];
<------>/* max packet payload size in bytes */
<------>u32 mtu;
};
/*
* When hint value is 0, hints capabilities are not supported or driver
* should use its own predefined value
*/
struct efa_admin_hw_hints {
<------>/* value in ms */
<------>u16 mmio_read_timeout;
<------>/* value in ms */
<------>u16 driver_watchdog_timeout;
<------>/* value in ms */
<------>u16 admin_completion_timeout;
<------>/* poll interval in ms */
<------>u16 poll_interval;
};
struct efa_admin_get_feature_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
<------>struct efa_admin_ctrl_buff_info control_buffer;
<------>struct efa_admin_get_set_feature_common_desc feature_common;
<------>u32 raw[11];
};
struct efa_admin_get_feature_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>union {
<------><------>u32 raw[14];
<------><------>struct efa_admin_feature_device_attr_desc device_attr;
<------><------>struct efa_admin_feature_aenq_desc aenq;
<------><------>struct efa_admin_feature_network_attr_desc network_attr;
<------><------>struct efa_admin_feature_queue_attr_desc queue_attr;
<------><------>struct efa_admin_hw_hints hw_hints;
<------>} u;
};
struct efa_admin_set_feature_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
<------>struct efa_admin_ctrl_buff_info control_buffer;
<------>struct efa_admin_get_set_feature_common_desc feature_common;
<------>union {
<------><------>u32 raw[11];
<------><------>/* AENQ configuration */
<------><------>struct efa_admin_feature_aenq_desc aenq;
<------>} u;
};
struct efa_admin_set_feature_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>union {
<------><------>u32 raw[14];
<------>} u;
};
struct efa_admin_alloc_pd_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
};
struct efa_admin_alloc_pd_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/* PD number */
<------>u16 pd;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_dealloc_pd_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
<------>/* PD number */
<------>u16 pd;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_dealloc_pd_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
struct efa_admin_alloc_uar_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
};
struct efa_admin_alloc_uar_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
<------>/* UAR number */
<------>u16 uar;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_dealloc_uar_cmd {
<------>struct efa_admin_aq_common_desc aq_common_descriptor;
<------>/* UAR number */
<------>u16 uar;
<------>/* MBZ */
<------>u16 reserved;
};
struct efa_admin_dealloc_uar_resp {
<------>struct efa_admin_acq_common_desc acq_common_desc;
};
/* asynchronous event notification groups */
enum efa_admin_aenq_group {
<------>EFA_ADMIN_FATAL_ERROR = 1,
<------>EFA_ADMIN_WARNING = 2,
<------>EFA_ADMIN_NOTIFICATION = 3,
<------>EFA_ADMIN_KEEP_ALIVE = 4,
<------>EFA_ADMIN_AENQ_GROUPS_NUM = 5,
};
enum efa_admin_aenq_notification_syndrom {
<------>EFA_ADMIN_SUSPEND = 0,
<------>EFA_ADMIN_RESUME = 1,
<------>EFA_ADMIN_UPDATE_HINTS = 2,
};
struct efa_admin_mmio_req_read_less_resp {
<------>u16 req_id;
<------>u16 reg_off;
<------>/* value is valid when poll is cleared */
<------>u32 reg_val;
};
enum efa_admin_os_type {
<------>EFA_ADMIN_OS_LINUX = 0,
};
struct efa_admin_host_info {
<------>/* OS distribution string format */
<------>u8 os_dist_str[128];
<------>/* Defined in enum efa_admin_os_type */
<------>u32 os_type;
<------>/* Kernel version string format */
<------>u8 kernel_ver_str[32];
<------>/* Kernel version numeric format */
<------>u32 kernel_ver;
<------>/*
<------> * 7:0 : driver_module_type
<------> * 15:8 : driver_sub_minor
<------> * 23:16 : driver_minor
<------> * 31:24 : driver_major
<------> */
<------>u32 driver_ver;
<------>/*
<------> * Device's Bus, Device and Function
<------> * 2:0 : function
<------> * 7:3 : device
<------> * 15:8 : bus
<------> */
<------>u16 bdf;
<------>/*
<------> * Spec version
<------> * 7:0 : spec_minor
<------> * 15:8 : spec_major
<------> */
<------>u16 spec_ver;
<------>/*
<------> * 0 : intree - Intree driver
<------> * 1 : gdr - GPUDirect RDMA supported
<------> * 31:2 : reserved2
<------> */
<------>u32 flags;
};
/* create_qp_cmd */
#define EFA_ADMIN_CREATE_QP_CMD_SQ_VIRT_MASK BIT(0)
#define EFA_ADMIN_CREATE_QP_CMD_RQ_VIRT_MASK BIT(1)
/* modify_qp_cmd */
#define EFA_ADMIN_MODIFY_QP_CMD_QP_STATE_MASK BIT(0)
#define EFA_ADMIN_MODIFY_QP_CMD_CUR_QP_STATE_MASK BIT(1)
#define EFA_ADMIN_MODIFY_QP_CMD_QKEY_MASK BIT(2)
#define EFA_ADMIN_MODIFY_QP_CMD_SQ_PSN_MASK BIT(3)
#define EFA_ADMIN_MODIFY_QP_CMD_SQ_DRAINED_ASYNC_NOTIFY_MASK BIT(4)
#define EFA_ADMIN_MODIFY_QP_CMD_RNR_RETRY_MASK BIT(5)
/* reg_mr_cmd */
#define EFA_ADMIN_REG_MR_CMD_PHYS_PAGE_SIZE_SHIFT_MASK GENMASK(4, 0)
#define EFA_ADMIN_REG_MR_CMD_MEM_ADDR_PHY_MODE_EN_MASK BIT(7)
#define EFA_ADMIN_REG_MR_CMD_LOCAL_WRITE_ENABLE_MASK BIT(0)
#define EFA_ADMIN_REG_MR_CMD_REMOTE_READ_ENABLE_MASK BIT(2)
/* create_cq_cmd */
#define EFA_ADMIN_CREATE_CQ_CMD_INTERRUPT_MODE_ENABLED_MASK BIT(5)
#define EFA_ADMIN_CREATE_CQ_CMD_VIRT_MASK BIT(6)
#define EFA_ADMIN_CREATE_CQ_CMD_CQ_ENTRY_SIZE_WORDS_MASK GENMASK(4, 0)
/* get_set_feature_common_desc */
#define EFA_ADMIN_GET_SET_FEATURE_COMMON_DESC_SELECT_MASK GENMASK(1, 0)
/* feature_device_attr_desc */
#define EFA_ADMIN_FEATURE_DEVICE_ATTR_DESC_RDMA_READ_MASK BIT(0)
#define EFA_ADMIN_FEATURE_DEVICE_ATTR_DESC_RNR_RETRY_MASK BIT(1)
/* host_info */
#define EFA_ADMIN_HOST_INFO_DRIVER_MODULE_TYPE_MASK GENMASK(7, 0)
#define EFA_ADMIN_HOST_INFO_DRIVER_SUB_MINOR_MASK GENMASK(15, 8)
#define EFA_ADMIN_HOST_INFO_DRIVER_MINOR_MASK GENMASK(23, 16)
#define EFA_ADMIN_HOST_INFO_DRIVER_MAJOR_MASK GENMASK(31, 24)
#define EFA_ADMIN_HOST_INFO_FUNCTION_MASK GENMASK(2, 0)
#define EFA_ADMIN_HOST_INFO_DEVICE_MASK GENMASK(7, 3)
#define EFA_ADMIN_HOST_INFO_BUS_MASK GENMASK(15, 8)
#define EFA_ADMIN_HOST_INFO_SPEC_MINOR_MASK GENMASK(7, 0)
#define EFA_ADMIN_HOST_INFO_SPEC_MAJOR_MASK GENMASK(15, 8)
#define EFA_ADMIN_HOST_INFO_INTREE_MASK BIT(0)
#define EFA_ADMIN_HOST_INFO_GDR_MASK BIT(1)
#endif /* _EFA_ADMIN_CMDS_H_ */