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 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
/*
* Copyright (c) 2004-2007 High Performance Computing Center Stuttgart,
* University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2008 The Trustees of Indiana University.
* All rights reserved.
* Copyright (c) 2013 Cisco Systems, Inc. All rights reserved.
* Copyright (c) 2015 Los Alamos National Security, LLC. All rights
* reserved.
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
/**
* These symbols are in a file by themselves to provide nice linker
* semantics. Since linkers generally pull in symbols by object
* files, keeping these symbols as the only symbols in this file
* prevents utility programs such as "ompi_info" from having to import
* entire components just to query their version and parameters.
*/
#include "opal_config.h"
#include "memchecker_valgrind.h"
#include "opal/constants.h"
#include "opal/mca/memchecker/memchecker.h"
int opal_memchecker_component_priority = 0;
/*
* Public string showing the memchecker ompi_linux component version number
*/
const char *opal_memchecker_valgrind_component_version_string
= "OPAL valgrind memchecker MCA component version " OPAL_VERSION;
/*
* Local function
*/
static int valgrind_register(void);
static int valgrind_open(void);
static int valgrind_close(void);
/*
* Instantiate the public struct with all of our public information
* and pointers to our public functions in it
*/
const opal_memchecker_base_component_2_0_0_t mca_memchecker_valgrind_component = {
/* First, the mca_component_t struct containing meta information
about the component itself */
.base_version = {OPAL_MEMCHECKER_BASE_VERSION_2_0_0,
/* Component name and version */
.mca_component_name = "valgrind",
MCA_BASE_MAKE_VERSION(component, OPAL_MAJOR_VERSION, OPAL_MINOR_VERSION,
OPAL_RELEASE_VERSION),
/* Component open and close functions */
.mca_open_component = valgrind_open, .mca_close_component = valgrind_close,
.mca_query_component = opal_memchecker_valgrind_component_query,
.mca_register_component_params = valgrind_register},
.base_data = {/* Valgrind does not offer functionality to save the state */
MCA_BASE_METADATA_PARAM_CHECKPOINT}};
static int valgrind_register(void)
{
opal_memchecker_component_priority = 0;
(void) mca_base_component_var_register(&mca_memchecker_valgrind_component.base_version,
"priority",
"Priority for the memchecker valgrind "
"component (default: 0)",
MCA_BASE_VAR_TYPE_INT, NULL, 0,
MCA_BASE_VAR_FLAG_SETTABLE, OPAL_INFO_LVL_3,
MCA_BASE_VAR_SCOPE_ALL_EQ,
&opal_memchecker_component_priority);
return OPAL_SUCCESS;
}
static int valgrind_open(void)
{
/*
* Any initialization of valgrind upon starting of the component
* should be done here.
*
* Possibilities are, that we need to set special stuff, when
* valgrind is not being run / actually is being run.
*/
return OPAL_SUCCESS;
}
static int valgrind_close(void)
{
/*
* Any closing of valgrind upon starting of the component
* should be done here.
*
* Possibilities are, that we need to set special stuff, when
* valgrind is not being run / actually is being run.
*/
return OPAL_SUCCESS;
}
|