1
1
openmpi/ompi/message/message.h
Nathan Hjelm ed78553512 Update opal_free_list_t usage to reflect new class interface.
Please verify your components have been updated correctly. Keep in
mind that in terms of threading:

OPAL_FREE_LIST_GET -> opal_free_list_get_st
OPAL_FREE_LIST_RETURN -> opal_free_list_return_st

I used the opal_using_threads() variant anytime it appeared multiple
threads could be operating on the free list. If this is not the case
update to _st. If multiple threads are always in use change to _mt.
2015-02-24 10:05:44 -07:00

83 строки
2.4 KiB
C

/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
/*
* Copyright (c) 2011-2012 Sandia National Laboratories. All rights reserved.
* Copyright (c) 2012 Cisco Systems, Inc. All rights reserved.
* Copyright (c) 2015 Los Alamos National Security, LLC. All rights
* reserved.
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
#ifndef OMPI_MESSAGE_H
#define OMPI_MESSAGE_H
#include "mpi.h"
#include "opal/class/opal_free_list.h"
#include "opal/class/opal_pointer_array.h"
BEGIN_C_DECLS
struct ompi_communicator_t;
struct ompi_message_t {
opal_free_list_item_t super; /**< Base type */
int m_f_to_c_index; /**< Fortran handle for this message */
struct ompi_communicator_t *comm; /**< communicator used in probe */
void* req_ptr; /**< PML data */
int peer; /**< peer, same as status.MPI_SOURCE */
size_t count; /**< same value as status._ucount */
};
typedef struct ompi_message_t ompi_message_t;
OMPI_DECLSPEC OBJ_CLASS_DECLARATION(ompi_message_t);
/**
* Padded struct to maintain back compatibiltiy.
* See ompi/communicator/communicator.h comments with struct ompi_communicator_t
* for full explanation why we chose the following padding construct for predefines.
*/
#define PREDEFINED_MESSAGE_PAD (sizeof(void*) * 32)
struct ompi_predefined_message_t {
struct ompi_message_t message;
char padding[PREDEFINED_MESSAGE_PAD - sizeof(ompi_message_t)];
};
typedef struct ompi_predefined_message_t ompi_predefined_message_t;
int ompi_message_init(void);
int ompi_message_finalize(void);
OMPI_DECLSPEC extern opal_free_list_t ompi_message_free_list;
OMPI_DECLSPEC extern opal_pointer_array_t ompi_message_f_to_c_table;
OMPI_DECLSPEC extern ompi_predefined_message_t ompi_message_no_proc;
static inline
ompi_message_t*
ompi_message_alloc(void)
{
return (ompi_message_t *) opal_free_list_get (&ompi_message_free_list);
}
static inline
void
ompi_message_return(ompi_message_t* msg)
{
if (MPI_UNDEFINED != msg->m_f_to_c_index) {
opal_pointer_array_set_item(&ompi_message_f_to_c_table,
msg->m_f_to_c_index, NULL);
msg->m_f_to_c_index = MPI_UNDEFINED;
}
opal_free_list_return (&ompi_message_free_list,
&msg->super);
}
END_C_DECLS
#endif