File: btl_elan_frag.h

package info (click to toggle)
openmpi 1.6.5-9.1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 91,652 kB
  • sloc: ansic: 408,966; cpp: 44,454; sh: 27,828; makefile: 10,486; asm: 3,882; python: 1,239; lex: 805; perl: 549; csh: 253; fortran: 232; f90: 126; tcl: 12
file content (85 lines) | stat: -rw-r--r-- 2,541 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
 * Copyright (c) 2004-2008 The University of Tennessee and The University
 *                         of Tennessee Research Foundation.  All rights
 *                         reserved.
 * $COPYRIGHT$
 * 
 * Additional copyrights may follow
 * 
 * $HEADER$
 */

#ifndef MCA_BTL_ELAN_FRAG_H
#define MCA_BTL_ELAN_FRAG_H

#include "ompi_config.h"
#include "btl_elan.h" 

BEGIN_C_DECLS

#define MCA_BTL_ELAN_HDR_TYPE_SEND     1
#define MCA_BTL_ELAN_HDR_TYPE_PUT      2
#define MCA_BTL_ELAN_HDR_TYPE_GET      3
#define MCA_BTL_ELAN_HDR_TYPE_RECV     4


/**
 * Elan send fragment derived type.
 */
struct mca_btl_elan_frag_t {
    mca_btl_base_descriptor_t base; 
    mca_btl_base_segment_t segment; 
    struct mca_btl_base_endpoint_t *endpoint; 
    struct mca_btl_elan_module_t* btl;
    int type;
    ompi_free_list_t* my_list;
    mca_btl_base_tag_t tag;
    struct ELAN_EVENT* elan_event;
    size_t size;
}; 
typedef struct mca_btl_elan_frag_t mca_btl_elan_frag_t; 
OBJ_CLASS_DECLARATION(mca_btl_elan_frag_t); 

typedef struct mca_btl_elan_frag_t mca_btl_elan_frag_eager_t; 
    
OBJ_CLASS_DECLARATION(mca_btl_elan_frag_eager_t); 

typedef struct mca_btl_elan_frag_t mca_btl_elan_frag_max_t; 
    
OBJ_CLASS_DECLARATION(mca_btl_elan_frag_max_t); 

typedef struct mca_btl_elan_frag_t mca_btl_elan_frag_user_t; 
    
OBJ_CLASS_DECLARATION(mca_btl_elan_frag_user_t); 


/*
 * Macros to allocate/return descriptors from module specific
 * free list(s).
 */
#define MCA_BTL_ELAN_FRAG_ALLOC_LIST( list, frag, rc ) \
{                                                      \
    ompi_free_list_item_t *item;                       \
    OMPI_FREE_LIST_GET(&(list), item, rc);             \
    frag = (mca_btl_elan_frag_t*) item;                \
}

#define MCA_BTL_ELAN_FRAG_ALLOC_EAGER(frag, rc)                         \
    MCA_BTL_ELAN_FRAG_ALLOC_LIST(mca_btl_elan_component.elan_frag_eager, frag, rc)

#define MCA_BTL_ELAN_FRAG_ALLOC_MAX(frag, rc)                           \
    MCA_BTL_ELAN_FRAG_ALLOC_LIST(mca_btl_elan_component.elan_frag_max, frag, rc)

#define MCA_BTL_ELAN_FRAG_ALLOC_USER(frag, rc)                     \
    MCA_BTL_ELAN_FRAG_ALLOC_LIST(mca_btl_elan_component.elan_frag_user, frag, rc)

#define MCA_BTL_ELAN_FRAG_RETURN(frag)                             \
    {                                                              \
        OMPI_FREE_LIST_RETURN(frag->my_list,                       \
                              (ompi_free_list_item_t*)(frag));     \
    }


END_C_DECLS

#endif  /* MCA_BTL_ELAN_FRAG_H */