__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
/*
 * Copyright(c) 2016 - 2018 Intel Corporation.
 */

#ifndef DEF_RDMAVT_INCCQ_H
#define DEF_RDMAVT_INCCQ_H

#include <linux/kthread.h>
#include <rdma/ib_user_verbs.h>
#include <rdma/ib_verbs.h>

/*
 * Define an ib_cq_notify value that is not valid so we know when CQ
 * notifications are armed.
 */
#define RVT_CQ_NONE      (IB_CQ_NEXT_COMP + 1)

/*
 * Define read macro that apply smp_load_acquire memory barrier
 * when reading indice of circular buffer that mmaped to user space.
 */
#define RDMA_READ_UAPI_ATOMIC(member) smp_load_acquire(&(member).val)

/*
 * Define write macro that uses smp_store_release memory barrier
 * when writing indice of circular buffer that mmaped to user space.
 */
#define RDMA_WRITE_UAPI_ATOMIC(member, x) smp_store_release(&(member).val, x)
#include <rdma/rvt-abi.h>

/*
 * This structure is used to contain the head pointer, tail pointer,
 * and completion queue entries as a single memory allocation so
 * it can be mmap'ed into user space.
 */
struct rvt_k_cq_wc {
	u32 head;               /* index of next entry to fill */
	u32 tail;               /* index of next ib_poll_cq() entry */
	struct ib_wc kqueue[];
};

/*
 * The completion queue structure.
 */
struct rvt_cq {
	struct ib_cq ibcq;
	struct work_struct comptask;
	spinlock_t lock; /* protect changes in this struct */
	u8 notify;
	u8 triggered;
	u8 cq_full;
	int comp_vector_cpu;
	struct rvt_dev_info *rdi;
	struct rvt_cq_wc *queue;
	struct rvt_mmap_info *ip;
	struct rvt_k_cq_wc *kqueue;
};

static inline struct rvt_cq *ibcq_to_rvtcq(struct ib_cq *ibcq)
{
	return container_of(ibcq, struct rvt_cq, ibcq);
}

bool rvt_cq_enter(struct rvt_cq *cq, struct ib_wc *entry, bool solicited);

#endif          /* DEF_RDMAVT_INCCQH */

Filemanager

Name Type Size Permission Actions
ib.h File 2.07 KB 0644
ib_addr.h File 7.16 KB 0644
ib_cache.h File 3.59 KB 0644
ib_cm.h File 16.73 KB 0644
ib_hdrs.h File 6.83 KB 0644
ib_mad.h File 24.58 KB 0644
ib_marshall.h File 685 B 0644
ib_pack.h File 7.81 KB 0644
ib_pma.h File 4.17 KB 0644
ib_sa.h File 19.53 KB 0644
ib_smi.h File 4.49 KB 0644
ib_sysfs.h File 1.23 KB 0644
ib_umem.h File 6.82 KB 0644
ib_umem_odp.h File 3.39 KB 0644
ib_verbs.h File 144.17 KB 0644
iba.h File 5.51 KB 0644
ibta_vol1_c12.h File 12.94 KB 0644
iw_cm.h File 6.49 KB 0644
iw_portmap.h File 2.19 KB 0644
lag.h File 530 B 0644
mr_pool.h File 568 B 0644
opa_addr.h File 2.39 KB 0644
opa_port_info.h File 13.43 KB 0644
opa_smi.h File 3 KB 0644
opa_vnic.h File 1.99 KB 0644
rdma_cm.h File 13.12 KB 0644
rdma_cm_ib.h File 797 B 0644
rdma_counter.h File 1.88 KB 0644
rdma_netlink.h File 4.32 KB 0644
rdma_vt.h File 14.22 KB 0644
rdmavt_cq.h File 1.74 KB 0644
rdmavt_mr.h File 3.94 KB 0644
rdmavt_qp.h File 28.04 KB 0644
restrack.h File 4.35 KB 0644
rw.h File 2.22 KB 0644
signature.h File 2.9 KB 0644
tid_rdma_defs.h File 2.05 KB 0644
uverbs_ioctl.h File 32.83 KB 0644
uverbs_named_ioctl.h File 4.72 KB 0644
uverbs_std_types.h File 5.24 KB 0644
uverbs_types.h File 6.96 KB 0644
Filemanager