bd9265c560
A few changes were required to support this move: 1. the PMI component used to identify rte-related data (e.g., host name, bind level) and package them as a unit to reduce the number of PMI keys. This code was moved up to the ORTE layer as the OPAL layer has no understanding of these concepts. In addition, the component locally stored data based on process jobid/vpid - this could no longer be supported (see below for the solution). 2. the hash component was updated to use the new opal_identifier_t instead of orte_process_name_t as its index for storing data in the hash tables. Previously, we did a hash on the vpid and stored the data in a 32-bit hash table. In the revised system, we don't see a separate "vpid" field - we only have a 64-bit opaque value. The orte_process_name_t hash turned out to do nothing useful, so we now store the data in a 64-bit hash table. Preliminary tests didn't show any identifiable change in behavior or performance, but we'll have to see if a move back to the 32-bit table is required at some later time. 3. the db framework was a "select one" system. However, since the PMI component could no longer use its internal storage system, the framework has now been changed to a "select many" mode of operation. This allows the hash component to handle all internal storage, while the PMI component only handles pushing/pulling things from the PMI system. This was something we had planned for some time - when fetching data, we first check internal storage to see if we already have it, and then automatically go to the global system to look for it if we don't. Accordingly, the framework was provided with a custom query function used during "select" that lets you seperately specify the "store" and "fetch" ordering. 4. the ORTE grpcomm and ess/pmi components, and the nidmap code, were updated to work with the new db framework and to specify internal/global storage options. No changes were made to the MPI layer, except for modifying the ORTE component of the OMPI/rte framework to support the new db framework. This commit was SVN r28112.
85 строки
2.4 KiB
C
85 строки
2.4 KiB
C
/*
|
|
* Copyright (c) 2010 Cisco Systems, Inc. All rights reserved.
|
|
* Copyright (c) 2012-2013 Los Alamos National Security, Inc. All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
/** @file:
|
|
*/
|
|
|
|
#ifndef MCA_DB_BASE_H
|
|
#define MCA_DB_BASE_H
|
|
|
|
#include "opal_config.h"
|
|
#include "opal/types.h"
|
|
|
|
#include "opal/mca/mca.h"
|
|
#include "opal/class/opal_list.h"
|
|
#include "opal/dss/dss.h"
|
|
|
|
#include "opal/mca/db/db.h"
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
/**
|
|
* Open the db framework
|
|
*/
|
|
OPAL_DECLSPEC int opal_db_base_open(void);
|
|
|
|
/**
|
|
* Select a db module
|
|
*/
|
|
OPAL_DECLSPEC int opal_db_base_select(void);
|
|
|
|
/**
|
|
* Close the db framework
|
|
*/
|
|
OPAL_DECLSPEC int opal_db_base_close(void);
|
|
|
|
typedef struct {
|
|
opal_list_item_t super;
|
|
int pri;
|
|
opal_db_base_module_t *module;
|
|
opal_db_base_component_t *component;
|
|
} opal_db_active_module_t;
|
|
OBJ_CLASS_DECLARATION(opal_db_active_module_t);
|
|
|
|
typedef struct {
|
|
int output;
|
|
opal_list_t available_components;
|
|
opal_list_t store_order;
|
|
opal_list_t fetch_order;
|
|
} opal_db_base_t;
|
|
|
|
OPAL_DECLSPEC extern opal_db_base_t opal_db_base;
|
|
|
|
OPAL_DECLSPEC int opal_db_base_store(opal_identifier_t proc,
|
|
opal_db_locality_t locality,
|
|
const char *key, const void *object,
|
|
opal_data_type_t type);
|
|
OPAL_DECLSPEC int opal_db_base_store_pointer(opal_identifier_t proc,
|
|
opal_db_locality_t locality,
|
|
opal_value_t *kv);
|
|
OPAL_DECLSPEC int opal_db_base_fetch(opal_identifier_t proc,
|
|
const char *key, void **data,
|
|
opal_data_type_t type);
|
|
OPAL_DECLSPEC int opal_db_base_fetch_pointer(opal_identifier_t proc,
|
|
const char *key,
|
|
void **data, opal_data_type_t type);
|
|
OPAL_DECLSPEC int opal_db_base_fetch_multiple(opal_identifier_t proc,
|
|
const char *key,
|
|
opal_list_t *kvs);
|
|
OPAL_DECLSPEC int opal_db_base_remove_data(opal_identifier_t proc,
|
|
const char *key);
|
|
|
|
OPAL_DECLSPEC int opal_db_base_add_log(const char *table,
|
|
const opal_value_t *kvs, int nkvs);
|
|
|
|
|
|
END_C_DECLS
|
|
|
|
#endif
|