hw/rdma: Definitions for rdma device and rdma resource manager
Definition of various structures and constants used in backend and resource manager modules. Reviewed-by: Dotan Barak <dotanb@mellanox.com> Reviewed-by: Zhu Yanjun <yanjun.zhu@oracle.com> Signed-off-by: Yuval Shaia <yuval.shaia@oracle.com> Signed-off-by: Marcel Apfelbaum <marcel@redhat.com>
This commit is contained in:
parent
dcbf469aef
commit
b3a9227769
62
hw/rdma/rdma_backend_defs.h
Normal file
62
hw/rdma/rdma_backend_defs.h
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* RDMA device: Definitions of Backend Device structures
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018 Oracle
|
||||||
|
* Copyright (C) 2018 Red Hat Inc
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Yuval Shaia <yuval.shaia@oracle.com>
|
||||||
|
* Marcel Apfelbaum <marcel@redhat.com>
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||||
|
* See the COPYING file in the top-level directory.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef RDMA_BACKEND_DEFS_H
|
||||||
|
#define RDMA_BACKEND_DEFS_H
|
||||||
|
|
||||||
|
#include <infiniband/verbs.h>
|
||||||
|
#include <qemu/thread.h>
|
||||||
|
|
||||||
|
typedef struct RdmaDeviceResources RdmaDeviceResources;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendThread {
|
||||||
|
QemuThread thread;
|
||||||
|
QemuMutex mutex;
|
||||||
|
bool run;
|
||||||
|
} RdmaBackendThread;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendDev {
|
||||||
|
struct ibv_device_attr dev_attr;
|
||||||
|
RdmaBackendThread comp_thread;
|
||||||
|
union ibv_gid gid;
|
||||||
|
PCIDevice *dev;
|
||||||
|
RdmaDeviceResources *rdma_dev_res;
|
||||||
|
struct ibv_device *ib_dev;
|
||||||
|
struct ibv_context *context;
|
||||||
|
struct ibv_comp_channel *channel;
|
||||||
|
uint8_t port_num;
|
||||||
|
uint8_t backend_gid_idx;
|
||||||
|
} RdmaBackendDev;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendPD {
|
||||||
|
struct ibv_pd *ibpd;
|
||||||
|
} RdmaBackendPD;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendMR {
|
||||||
|
struct ibv_pd *ibpd;
|
||||||
|
struct ibv_mr *ibmr;
|
||||||
|
} RdmaBackendMR;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendCQ {
|
||||||
|
RdmaBackendDev *backend_dev;
|
||||||
|
struct ibv_cq *ibcq;
|
||||||
|
} RdmaBackendCQ;
|
||||||
|
|
||||||
|
typedef struct RdmaBackendQP {
|
||||||
|
struct ibv_pd *ibpd;
|
||||||
|
struct ibv_qp *ibqp;
|
||||||
|
} RdmaBackendQP;
|
||||||
|
|
||||||
|
#endif
|
104
hw/rdma/rdma_rm_defs.h
Normal file
104
hw/rdma/rdma_rm_defs.h
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
/*
|
||||||
|
* RDMA device: Definitions of Resource Manager structures
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018 Oracle
|
||||||
|
* Copyright (C) 2018 Red Hat Inc
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Yuval Shaia <yuval.shaia@oracle.com>
|
||||||
|
* Marcel Apfelbaum <marcel@redhat.com>
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||||
|
* See the COPYING file in the top-level directory.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef RDMA_RM_DEFS_H
|
||||||
|
#define RDMA_RM_DEFS_H
|
||||||
|
|
||||||
|
#include "rdma_backend_defs.h"
|
||||||
|
|
||||||
|
#define MAX_PORTS 1
|
||||||
|
#define MAX_PORT_GIDS 1
|
||||||
|
#define MAX_PORT_PKEYS 1
|
||||||
|
#define MAX_PKEYS 1
|
||||||
|
#define MAX_GIDS 2048
|
||||||
|
#define MAX_UCS 512
|
||||||
|
#define MAX_MR_SIZE (1UL << 27)
|
||||||
|
#define MAX_QP 1024
|
||||||
|
#define MAX_SGE 4
|
||||||
|
#define MAX_CQ 2048
|
||||||
|
#define MAX_MR 1024
|
||||||
|
#define MAX_PD 1024
|
||||||
|
#define MAX_QP_RD_ATOM 16
|
||||||
|
#define MAX_QP_INIT_RD_ATOM 16
|
||||||
|
#define MAX_AH 64
|
||||||
|
|
||||||
|
#define MAX_RMRESTBL_NAME_SZ 16
|
||||||
|
typedef struct RdmaRmResTbl {
|
||||||
|
char name[MAX_RMRESTBL_NAME_SZ];
|
||||||
|
QemuMutex lock;
|
||||||
|
unsigned long *bitmap;
|
||||||
|
size_t tbl_sz;
|
||||||
|
size_t res_sz;
|
||||||
|
void *tbl;
|
||||||
|
} RdmaRmResTbl;
|
||||||
|
|
||||||
|
typedef struct RdmaRmPD {
|
||||||
|
RdmaBackendPD backend_pd;
|
||||||
|
uint32_t ctx_handle;
|
||||||
|
} RdmaRmPD;
|
||||||
|
|
||||||
|
typedef struct RdmaRmCQ {
|
||||||
|
RdmaBackendCQ backend_cq;
|
||||||
|
void *opaque;
|
||||||
|
bool notify;
|
||||||
|
} RdmaRmCQ;
|
||||||
|
|
||||||
|
typedef struct RdmaRmUserMR {
|
||||||
|
uint64_t host_virt;
|
||||||
|
uint64_t guest_start;
|
||||||
|
size_t length;
|
||||||
|
} RdmaRmUserMR;
|
||||||
|
|
||||||
|
/* MR (DMA region) */
|
||||||
|
typedef struct RdmaRmMR {
|
||||||
|
RdmaBackendMR backend_mr;
|
||||||
|
RdmaRmUserMR user_mr;
|
||||||
|
uint32_t pd_handle;
|
||||||
|
uint32_t lkey;
|
||||||
|
uint32_t rkey;
|
||||||
|
} RdmaRmMR;
|
||||||
|
|
||||||
|
typedef struct RdmaRmUC {
|
||||||
|
uint64_t uc_handle;
|
||||||
|
} RdmaRmUC;
|
||||||
|
|
||||||
|
typedef struct RdmaRmQP {
|
||||||
|
RdmaBackendQP backend_qp;
|
||||||
|
void *opaque;
|
||||||
|
uint32_t qp_type;
|
||||||
|
uint32_t qpn;
|
||||||
|
uint32_t send_cq_handle;
|
||||||
|
uint32_t recv_cq_handle;
|
||||||
|
enum ibv_qp_state qp_state;
|
||||||
|
} RdmaRmQP;
|
||||||
|
|
||||||
|
typedef struct RdmaRmPort {
|
||||||
|
union ibv_gid gid_tbl[MAX_PORT_GIDS];
|
||||||
|
enum ibv_port_state state;
|
||||||
|
int *pkey_tbl; /* TODO: Not yet supported */
|
||||||
|
} RdmaRmPort;
|
||||||
|
|
||||||
|
typedef struct RdmaDeviceResources {
|
||||||
|
RdmaRmPort ports[MAX_PORTS];
|
||||||
|
RdmaRmResTbl pd_tbl;
|
||||||
|
RdmaRmResTbl mr_tbl;
|
||||||
|
RdmaRmResTbl uc_tbl;
|
||||||
|
RdmaRmResTbl qp_tbl;
|
||||||
|
RdmaRmResTbl cq_tbl;
|
||||||
|
RdmaRmResTbl cqe_ctx_tbl;
|
||||||
|
GHashTable *qp_hash; /* Keeps mapping between real and emulated */
|
||||||
|
} RdmaDeviceResources;
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user