1225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier/* 2225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * Copyright (c) 2007 Cisco Systems, Inc. All rights reserved. 351a379d0c8f7a6db7c9e3c9c770d90a6d2d1ef9bJack Morgenstein * Copyright (c) 2007, 2008 Mellanox Technologies. All rights reserved. 4225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * 5225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * This software is available to you under a choice of one of two 6225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * licenses. You may choose to be licensed under the terms of the GNU 7225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * General Public License (GPL) Version 2, available from the file 8225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * COPYING in the main directory of this source tree, or the 9225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * OpenIB.org BSD license below: 10225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * 11225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * Redistribution and use in source and binary forms, with or 12225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * without modification, are permitted provided that the following 13225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * conditions are met: 14225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * 15225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * - Redistributions of source code must retain the above 16225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * copyright notice, this list of conditions and the following 17225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * disclaimer. 18225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * 19225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * - Redistributions in binary form must reproduce the above 20225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * copyright notice, this list of conditions and the following 21225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * disclaimer in the documentation and/or other materials 22225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * provided with the distribution. 23225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * 24225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 25225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 26225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 27225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 28225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 29225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 30225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 31225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * SOFTWARE. 32225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier */ 33225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 34225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier#ifndef MLX4_IB_USER_H 35225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier#define MLX4_IB_USER_H 36225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 37225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier#include <linux/types.h> 38225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 39225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier/* 40225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * Increment this value if any changes that break userspace ABI 41225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * compatibility are made. 42225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier */ 4308ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz 4408ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz#define MLX4_IB_UVERBS_NO_DEV_CAPS_ABI_VERSION 3 4508ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz#define MLX4_IB_UVERBS_ABI_VERSION 4 46225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 47225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier/* 48225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * Make sure that all structs defined in this file remain laid out so 49225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * that they pack the same way on 32-bit and 64-bit architectures (to 50225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * avoid incompatibility between 32-bit userspace and 64-bit kernels). 51225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * In particular do not use pointer types -- pass pointers in __u64 52225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier * instead. 53225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier */ 54225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 5508ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitzstruct mlx4_ib_alloc_ucontext_resp_v3 { 5608ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz __u32 qp_tab_size; 5708ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz __u16 bf_reg_size; 5808ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz __u16 bf_regs_per_page; 5908ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz}; 6008ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz 61225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_alloc_ucontext_resp { 6208ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz __u32 dev_caps; 63225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 qp_tab_size; 64225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u16 bf_reg_size; 65225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u16 bf_regs_per_page; 6608ff32352d6ff7083533dc1c25618d42f92ec28eOr Gerlitz __u32 cqe_size; 67225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 68225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 69225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_alloc_pd_resp { 70225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 pdn; 71225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 reserved; 72225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 73225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 74225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_create_cq { 75225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 buf_addr; 76225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 db_addr; 77225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 78225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 79225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_create_cq_resp { 80225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 cqn; 81225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 reserved; 82225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 83225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 84225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_resize_cq { 85225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 buf_addr; 86225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 87225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 88225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_create_srq { 89225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 buf_addr; 90225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 db_addr; 91225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 92225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 93225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_create_srq_resp { 94225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 srqn; 95225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u32 reserved; 96225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 97225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 98225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreierstruct mlx4_ib_create_qp { 99225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 buf_addr; 100225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier __u64 db_addr; 1010e6e74162164d908edf7889ac66dca09e7505745Roland Dreier __u8 log_sq_bb_count; 1020e6e74162164d908edf7889ac66dca09e7505745Roland Dreier __u8 log_sq_stride; 1030e6e74162164d908edf7889ac66dca09e7505745Roland Dreier __u8 sq_no_prefetch; 1040e6e74162164d908edf7889ac66dca09e7505745Roland Dreier __u8 reserved[5]; 105225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier}; 106225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier 107225c7b1feef1b41170f7037a5b10a65cd8a42c54Roland Dreier#endif /* MLX4_IB_USER_H */ 108