/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ /* Copyright (C) 2018-2025, Advanced Micro Devices, Inc */ #ifndef IONIC_ABI_H #define IONIC_ABI_H #include #define IONIC_ABI_VERSION 1 #define IONIC_EXPDB_64 1 #define IONIC_EXPDB_128 2 #define IONIC_EXPDB_256 4 #define IONIC_EXPDB_512 8 #define IONIC_EXPDB_SQ 1 #define IONIC_EXPDB_RQ 2 #define IONIC_CMB_ENABLE 1 #define IONIC_CMB_REQUIRE 2 #define IONIC_CMB_EXPDB 4 #define IONIC_CMB_WC 8 #define IONIC_CMB_UC 16 struct ionic_ctx_req { __u32 rsvd[2]; }; struct ionic_ctx_resp { __u32 rsvd; __u32 page_shift; __aligned_u64 dbell_offset; __u16 version; __u8 qp_opcodes; __u8 admin_opcodes; __u8 sq_qtype; __u8 rq_qtype; __u8 cq_qtype; __u8 admin_qtype; __u8 max_stride; __u8 max_spec; __u8 udma_count; __u8 expdb_mask; __u8 expdb_qtypes; __u8 rsvd2[3]; }; struct ionic_qdesc { __aligned_u64 addr; __u32 size; __u16 mask; __u8 depth_log2; __u8 stride_log2; }; struct ionic_ah_resp { __u32 ahid; __u32 pad; }; struct ionic_cq_req { struct ionic_qdesc cq[2]; __u8 udma_mask; __u8 rsvd[7]; }; struct ionic_cq_resp { __u32 cqid[2]; __u8 udma_mask; __u8 rsvd[7]; }; struct ionic_qp_req { struct ionic_qdesc sq; struct ionic_qdesc rq; __u8 sq_spec; __u8 rq_spec; __u8 sq_cmb; __u8 rq_cmb; __u8 udma_mask; __u8 rsvd[3]; }; struct ionic_qp_resp { __u32 qpid; __u8 sq_cmb; __u8 rq_cmb; __u8 udma_idx; __u8 rsvd[1]; __aligned_u64 sq_cmb_offset; __aligned_u64 rq_cmb_offset; }; struct ionic_srq_req { struct ionic_qdesc rq; __u8 rq_spec; __u8 rq_cmb; __u8 udma_mask; __u8 rsvd[5]; }; struct ionic_srq_resp { __u32 qpid; __u8 rq_cmb; __u8 udma_idx; __u8 rsvd[2]; __aligned_u64 rq_cmb_offset; }; #endif /* IONIC_ABI_H */