| /* SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause */ |
| /* |
| * Copyright 2018-2021 Amazon.com, Inc. or its affiliates. All rights reserved. |
| */ |
| |
| #ifndef _EFA_ADMIN_H_ |
| #define _EFA_ADMIN_H_ |
| |
| enum efa_admin_aq_completion_status { |
| EFA_ADMIN_SUCCESS = 0, |
| EFA_ADMIN_RESOURCE_ALLOCATION_FAILURE = 1, |
| EFA_ADMIN_BAD_OPCODE = 2, |
| EFA_ADMIN_UNSUPPORTED_OPCODE = 3, |
| EFA_ADMIN_MALFORMED_REQUEST = 4, |
| /* Additional status is provided in ACQ entry extended_status */ |
| EFA_ADMIN_ILLEGAL_PARAMETER = 5, |
| EFA_ADMIN_UNKNOWN_ERROR = 6, |
| EFA_ADMIN_RESOURCE_BUSY = 7, |
| }; |
| |
| struct efa_admin_aq_common_desc { |
| /* |
| * 11:0 : command_id |
| * 15:12 : reserved12 |
| */ |
| u16 command_id; |
| |
| /* as appears in efa_admin_aq_opcode */ |
| u8 opcode; |
| |
| /* |
| * 0 : phase |
| * 1 : ctrl_data - control buffer address valid |
| * 2 : ctrl_data_indirect - control buffer address |
| * points to list of pages with addresses of control |
| * buffers |
| * 7:3 : reserved3 |
| */ |
| u8 flags; |
| }; |
| |
| /* |
| * used in efa_admin_aq_entry. Can point directly to control data, or to a |
| * page list chunk. Used also at the end of indirect mode page list chunks, |
| * for chaining. |
| */ |
| struct efa_admin_ctrl_buff_info { |
| u32 length; |
| |
| struct efa_common_mem_addr address; |
| }; |
| |
| struct efa_admin_aq_entry { |
| struct efa_admin_aq_common_desc aq_common_descriptor; |
| |
| union { |
| u32 inline_data_w1[3]; |
| |
| struct efa_admin_ctrl_buff_info control_buffer; |
| } u; |
| |
| u32 inline_data_w4[12]; |
| }; |
| |
| struct efa_admin_acq_common_desc { |
| /* |
| * command identifier to associate it with the aq descriptor |
| * 11:0 : command_id |
| * 15:12 : reserved12 |
| */ |
| u16 command; |
| |
| u8 status; |
| |
| /* |
| * 0 : phase |
| * 7:1 : reserved1 |
| */ |
| u8 flags; |
| |
| u16 extended_status; |
| |
| /* |
| * indicates to the driver which AQ entry has been consumed by the |
| * device and could be reused |
| */ |
| u16 sq_head_indx; |
| }; |
| |
| struct efa_admin_acq_entry { |
| struct efa_admin_acq_common_desc acq_common_descriptor; |
| |
| u32 response_specific_data[14]; |
| }; |
| |
| struct efa_admin_aenq_common_desc { |
| u16 group; |
| |
| u16 syndrom; |
| |
| /* |
| * 0 : phase |
| * 7:1 : reserved - MBZ |
| */ |
| u8 flags; |
| |
| u8 reserved1[3]; |
| |
| u32 timestamp_low; |
| |
| u32 timestamp_high; |
| }; |
| |
| struct efa_admin_aenq_entry { |
| struct efa_admin_aenq_common_desc aenq_common_desc; |
| |
| /* command specific inline data */ |
| u32 inline_data_w4[12]; |
| }; |
| |
| enum efa_admin_eqe_event_type { |
| EFA_ADMIN_EQE_EVENT_TYPE_COMPLETION = 0, |
| }; |
| |
| /* Completion event */ |
| struct efa_admin_comp_event { |
| /* CQ number */ |
| u16 cqn; |
| |
| /* MBZ */ |
| u16 reserved; |
| |
| /* MBZ */ |
| u32 reserved2; |
| }; |
| |
| /* Event Queue Element */ |
| struct efa_admin_eqe { |
| /* |
| * 0 : phase |
| * 8:1 : event_type - Event type |
| * 31:9 : reserved - MBZ |
| */ |
| u32 common; |
| |
| /* MBZ */ |
| u32 reserved; |
| |
| union { |
| /* Event data */ |
| u32 event_data[2]; |
| |
| /* Completion Event */ |
| struct efa_admin_comp_event comp_event; |
| } u; |
| }; |
| |
| /* aq_common_desc */ |
| #define EFA_ADMIN_AQ_COMMON_DESC_COMMAND_ID_MASK GENMASK(11, 0) |
| #define EFA_ADMIN_AQ_COMMON_DESC_PHASE_MASK BIT(0) |
| #define EFA_ADMIN_AQ_COMMON_DESC_CTRL_DATA_MASK BIT(1) |
| #define EFA_ADMIN_AQ_COMMON_DESC_CTRL_DATA_INDIRECT_MASK BIT(2) |
| |
| /* acq_common_desc */ |
| #define EFA_ADMIN_ACQ_COMMON_DESC_COMMAND_ID_MASK GENMASK(11, 0) |
| #define EFA_ADMIN_ACQ_COMMON_DESC_PHASE_MASK BIT(0) |
| |
| /* aenq_common_desc */ |
| #define EFA_ADMIN_AENQ_COMMON_DESC_PHASE_MASK BIT(0) |
| |
| /* eqe */ |
| #define EFA_ADMIN_EQE_PHASE_MASK BIT(0) |
| #define EFA_ADMIN_EQE_EVENT_TYPE_MASK GENMASK(8, 1) |
| |
| #endif /* _EFA_ADMIN_H_ */ |