1
1
openmpi/ompi/mca/btl/wv/btl_wv_frag.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);