220 строки
6.7 KiB
C
220 строки
6.7 KiB
C
|
/*
|
||
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
||
|
* University Research and Technology
|
||
|
* Corporation. All rights reserved.
|
||
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
||
|
* of Tennessee Research Foundation. All rights
|
||
|
* reserved.
|
||
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
||
|
* University of Stuttgart. All rights reserved.
|
||
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
||
|
* All rights reserved.
|
||
|
* Copyright (c) 2006-2007 Los Alamos National Security, LLC. All rights
|
||
|
* reserved.
|
||
|
* Copyright (c) 2006-2007 Voltaire All rights reserved.
|
||
|
* $COPYRIGHT$
|
||
|
*
|
||
|
* Additional copyrights may follow
|
||
|
*
|
||
|
* $HEADER$
|
||
|
*/
|
||
|
|
||
|
#include "btl_wv.h"
|
||
|
#include "btl_wv_frag.h"
|
||
|
#include "btl_wv_eager_rdma.h"
|
||
|
|
||
|
void mca_btl_wv_frag_init(ompi_free_list_item_t* item, void* ctx)
|
||
|
{
|
||
|
mca_btl_wv_frag_init_data_t* init_data = (mca_btl_wv_frag_init_data_t *) ctx;
|
||
|
mca_btl_wv_frag_t *frag = to_base_frag(item);
|
||
|
|
||
|
if(MCA_BTL_WV_FRAG_RECV == frag->type) {
|
||
|
to_recv_frag(frag)->qp_idx = init_data->order;
|
||
|
to_com_frag(frag)->sg_entry.Length =
|
||
|
mca_btl_wv_component.qp_infos[init_data->order].size +
|
||
|
sizeof(mca_btl_wv_header_t) +
|
||
|
sizeof(mca_btl_wv_header_coalesced_t) +
|
||
|
sizeof(mca_btl_wv_control_header_t);
|
||
|
}
|
||
|
|
||
|
if(MCA_BTL_WV_FRAG_SEND == frag->type)
|
||
|
to_send_frag(frag)->qp_idx = init_data->order;
|
||
|
|
||
|
frag->list = init_data->list;
|
||
|
}
|
||
|
|
||
|
static void base_constructor(mca_btl_wv_frag_t *frag)
|
||
|
{
|
||
|
frag->base.order = MCA_BTL_NO_ORDER;
|
||
|
}
|
||
|
|
||
|
static void com_constructor(mca_btl_wv_com_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
mca_btl_wv_reg_t* reg =
|
||
|
(mca_btl_wv_reg_t*)base_frag->base.super.registration;
|
||
|
|
||
|
frag->registration = reg;
|
||
|
|
||
|
if(reg) {
|
||
|
frag->sg_entry.Lkey = reg->mr->lkey;
|
||
|
base_frag->segment.seg_key.key32[0] = reg->mr->lkey;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void out_constructor(mca_btl_wv_out_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
|
||
|
base_frag->base.des_src = &base_frag->segment;
|
||
|
base_frag->base.des_src_cnt = 1;
|
||
|
base_frag->base.des_dst = NULL;
|
||
|
base_frag->base.des_dst_cnt = 0;
|
||
|
|
||
|
frag->sr_desc.WrId = (uint64_t)(uintptr_t)frag;
|
||
|
frag->sr_desc.pSgl = (WV_SGE*)&to_com_frag(frag)->sg_entry;
|
||
|
frag->sr_desc.nSge = 1;
|
||
|
frag->sr_desc.Opcode = WvSend;
|
||
|
frag->sr_desc.Flags = WV_SEND_SIGNALED;
|
||
|
frag->sr_desc.pNext = NULL;
|
||
|
}
|
||
|
|
||
|
static void in_constructor(mca_btl_wv_in_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
|
||
|
base_frag->base.des_dst = &base_frag->segment;
|
||
|
base_frag->base.des_dst_cnt = 1;
|
||
|
base_frag->base.des_src = NULL;
|
||
|
base_frag->base.des_src_cnt = 0;
|
||
|
}
|
||
|
|
||
|
static void send_constructor(mca_btl_wv_send_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
|
||
|
base_frag->type = MCA_BTL_WV_FRAG_SEND;
|
||
|
|
||
|
frag->chdr = (mca_btl_wv_header_t*)base_frag->base.super.ptr;
|
||
|
frag->hdr = (mca_btl_wv_header_t*)
|
||
|
(((unsigned char*)base_frag->base.super.ptr) +
|
||
|
sizeof(mca_btl_wv_header_coalesced_t) +
|
||
|
sizeof(mca_btl_wv_control_header_t));
|
||
|
base_frag->segment.seg_addr.pval = frag->hdr + 1;
|
||
|
to_com_frag(frag)->sg_entry.pAddress = (void*)(uintptr_t)frag->hdr;
|
||
|
frag->coalesced_length = 0;
|
||
|
OBJ_CONSTRUCT(&frag->coalesced_frags, opal_list_t);
|
||
|
}
|
||
|
|
||
|
static void recv_constructor(mca_btl_wv_recv_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
|
||
|
base_frag->type = MCA_BTL_WV_FRAG_RECV;
|
||
|
|
||
|
frag->hdr = (mca_btl_wv_header_t*)base_frag->base.super.ptr;
|
||
|
base_frag->segment.seg_addr.pval =
|
||
|
((unsigned char* )frag->hdr) + sizeof(mca_btl_wv_header_t);
|
||
|
to_com_frag(frag)->sg_entry.pAddress = (void*)(uintptr_t)frag->hdr;
|
||
|
|
||
|
frag->rd_desc.wr_id = (uint64_t)(uintptr_t)frag;
|
||
|
frag->rd_desc.sg_list = (WV_SGE*)&to_com_frag(frag)->sg_entry;
|
||
|
frag->rd_desc.num_sge = 1;
|
||
|
frag->rd_desc.next = NULL;
|
||
|
}
|
||
|
|
||
|
static void send_control_constructor(mca_btl_wv_send_control_frag_t *frag)
|
||
|
{
|
||
|
to_base_frag(frag)->type = MCA_BTL_WV_FRAG_CONTROL;
|
||
|
}
|
||
|
|
||
|
static void put_constructor(mca_btl_wv_put_frag_t *frag)
|
||
|
{
|
||
|
to_base_frag(frag)->type = MCA_BTL_WV_FRAG_SEND_USER;
|
||
|
to_out_frag(frag)->sr_desc.Opcode = WvRdmaWrite;
|
||
|
}
|
||
|
|
||
|
static void get_constructor(mca_btl_wv_get_frag_t *frag)
|
||
|
{
|
||
|
to_base_frag(frag)->type = MCA_BTL_WV_FRAG_RECV_USER;
|
||
|
|
||
|
frag->sr_desc.WrId = (uint64_t)(uintptr_t)frag;
|
||
|
frag->sr_desc.pSgl = (WV_SGE*)&to_com_frag(frag)->sg_entry;
|
||
|
frag->sr_desc.nSge = 1;
|
||
|
frag->sr_desc.Opcode = WvRdmaRead;
|
||
|
frag->sr_desc.Flags = WV_SEND_SIGNALED;
|
||
|
frag->sr_desc.pNext = NULL;
|
||
|
}
|
||
|
|
||
|
static void coalesced_constructor(mca_btl_wv_coalesced_frag_t *frag)
|
||
|
{
|
||
|
mca_btl_wv_frag_t *base_frag = to_base_frag(frag);
|
||
|
|
||
|
base_frag->type = MCA_BTL_WV_FRAG_COALESCED;
|
||
|
|
||
|
base_frag->base.des_src = &base_frag->segment;
|
||
|
base_frag->base.des_src_cnt = 1;
|
||
|
base_frag->base.des_dst = NULL;
|
||
|
base_frag->base.des_dst_cnt = 0;
|
||
|
}
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_frag_t,
|
||
|
mca_btl_base_descriptor_t,
|
||
|
base_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_com_frag_t,
|
||
|
mca_btl_wv_frag_t,
|
||
|
com_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_out_frag_t,
|
||
|
mca_btl_wv_com_frag_t,
|
||
|
out_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_in_frag_t,
|
||
|
mca_btl_wv_com_frag_t,
|
||
|
in_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_send_frag_t,
|
||
|
mca_btl_wv_out_frag_t,
|
||
|
send_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_recv_frag_t,
|
||
|
mca_btl_wv_in_frag_t,
|
||
|
recv_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_send_control_frag_t,
|
||
|
mca_btl_wv_send_frag_t,
|
||
|
send_control_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_put_frag_t,
|
||
|
mca_btl_wv_out_frag_t,
|
||
|
put_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_get_frag_t,
|
||
|
mca_btl_wv_in_frag_t,
|
||
|
get_constructor,
|
||
|
NULL);
|
||
|
|
||
|
OBJ_CLASS_INSTANCE(
|
||
|
mca_btl_wv_coalesced_frag_t,
|
||
|
mca_btl_wv_frag_t,
|
||
|
coalesced_constructor,
|
||
|
NULL);
|