2004-01-29 02:43:58 +00:00
|
|
|
/*
|
2005-11-05 19:57:48 +00:00
|
|
|
* 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.
|
2004-11-28 20:09:25 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-01-29 02:43:58 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#include "ompi_config.h"
|
2004-01-29 02:43:58 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/constants.h"
|
|
|
|
#include "opal/mca/mca.h"
|
|
|
|
#include "opal/mca/base/base.h"
|
|
|
|
#include "ompi/mca/pml/pml.h"
|
|
|
|
#include "ompi/mca/pml/base/base.h"
|
2007-07-10 23:45:23 +00:00
|
|
|
#include "ompi/mca/pml/base/pml_base_request.h"
|
2005-09-12 20:22:59 +00:00
|
|
|
#include "opal/runtime/opal_progress.h"
|
2004-01-29 02:43:58 +00:00
|
|
|
|
2007-10-09 15:28:56 +00:00
|
|
|
|
|
|
|
int mca_pml_base_finalize(void) {
|
|
|
|
if (NULL != mca_pml_base_selected_component.pmlm_finalize) {
|
|
|
|
return mca_pml_base_selected_component.pmlm_finalize();
|
|
|
|
}
|
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-01-29 02:43:58 +00:00
|
|
|
int mca_pml_base_close(void)
|
|
|
|
{
|
2011-03-08 15:21:33 +00:00
|
|
|
int i, j;
|
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
/* turn off the progress code for the pml */
|
2007-10-09 23:28:53 +00:00
|
|
|
if( NULL != mca_pml.pml_progress ) {
|
|
|
|
opal_progress_unregister(mca_pml.pml_progress);
|
|
|
|
}
|
2005-03-18 03:43:59 +00:00
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
/* Blatently ignore the return code (what would we do to recover,
|
|
|
|
anyway? This module is going away, so errors don't matter
|
|
|
|
anymore) */
|
2004-01-30 22:28:32 +00:00
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
/**
|
|
|
|
* Destruct the send and receive queues. The ompi_free_list_t destructor
|
|
|
|
* will return the memory to the mpool, so this has to be done before the
|
|
|
|
* mpool get released by the PML close function.
|
|
|
|
*/
|
|
|
|
OBJ_DESTRUCT(&mca_pml_base_send_requests);
|
|
|
|
OBJ_DESTRUCT(&mca_pml_base_recv_requests);
|
2004-01-30 22:28:32 +00:00
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
mca_pml.pml_progress = mca_pml_base_progress;
|
2007-10-09 15:28:56 +00:00
|
|
|
|
2011-03-08 15:21:33 +00:00
|
|
|
/* Free all the strings in the array */
|
|
|
|
j = opal_pointer_array_get_size(&mca_pml_base_pml);
|
|
|
|
for (i = 0; i < j; ++i) {
|
|
|
|
char *str;
|
|
|
|
str = (char*) opal_pointer_array_get_item(&mca_pml_base_pml, i);
|
|
|
|
free(str);
|
|
|
|
}
|
2007-07-10 23:45:23 +00:00
|
|
|
OBJ_DESTRUCT(&mca_pml_base_pml);
|
2004-01-29 02:43:58 +00:00
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
/* Close all remaining available modules (may be one if this is a
|
|
|
|
OMPI RTE program, or [possibly] multiple if this is ompi_info) */
|
2004-01-29 02:43:58 +00:00
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
mca_base_components_close(mca_pml_base_output,
|
|
|
|
&mca_pml_base_components_available, NULL);
|
2004-01-29 02:43:58 +00:00
|
|
|
|
2012-11-06 19:09:26 +00:00
|
|
|
/* Close the framework output */
|
|
|
|
opal_output_close (mca_pml_base_output);
|
|
|
|
mca_pml_base_output = -1;
|
|
|
|
|
2007-07-10 23:45:23 +00:00
|
|
|
/* All done */
|
|
|
|
|
|
|
|
return OMPI_SUCCESS;
|
2004-01-29 02:43:58 +00:00
|
|
|
}
|
2004-01-29 23:50:31 +00:00
|
|
|
|