2007-12-21 06:02:00 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; -*- */
|
2006-08-15 18:40:08 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2007-12-21 06:02:00 +00:00
|
|
|
* Copyright (c) 2004-2007 The University of Tennessee and The University
|
2006-08-15 18:40:08 +00:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2006 Voltaire. All rights reserved.
|
|
|
|
*
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* Description of the Registration Cache framework
|
|
|
|
*/
|
|
|
|
#ifndef MCA_RCACHE_VMA_H
|
|
|
|
#define MCA_RCACHE_VMA_H
|
|
|
|
#include "opal/mca/mca.h"
|
|
|
|
#include "ompi/info/info.h"
|
|
|
|
#include "opal/class/opal_list.h"
|
|
|
|
#include "ompi/class/ompi_rb_tree.h"
|
|
|
|
#include "ompi/mca/rcache/rcache.h"
|
|
|
|
|
|
|
|
struct mca_rcache_vma_module_t {
|
|
|
|
mca_rcache_base_module_t base;
|
|
|
|
ompi_rb_tree_t rb_tree;
|
|
|
|
opal_list_t vma_list;
|
2006-12-17 12:26:41 +00:00
|
|
|
size_t reg_cur_cache_size;
|
2006-08-15 18:40:08 +00:00
|
|
|
};
|
|
|
|
typedef struct mca_rcache_vma_module_t mca_rcache_vma_module_t;
|
|
|
|
|
|
|
|
|
|
|
|
struct mca_rcache_vma_component_t {
|
|
|
|
mca_rcache_base_component_t super;
|
|
|
|
}; typedef struct mca_rcache_vma_component_t mca_rcache_vma_component_t;
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OMPI_DECLSPEC extern mca_rcache_vma_component_t mca_rcache_vma_component;
|
2006-08-15 18:40:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
void mca_rcache_vma_module_init(mca_rcache_vma_module_t* rcache);
|
|
|
|
|
|
|
|
int mca_rcache_vma_find(mca_rcache_base_module_t* rcache, void* addr,
|
|
|
|
size_t size, mca_mpool_base_registration_t **reg);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
int mca_rcache_vma_find_all(mca_rcache_base_module_t* rcache, void* addr,
|
2008-01-08 08:55:42 +00:00
|
|
|
size_t size, mca_mpool_base_registration_t **regs, int reg_cnt);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
int mca_rcache_vma_insert(struct mca_rcache_base_module_t* rcache,
|
|
|
|
mca_mpool_base_registration_t* registration, size_t limit);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
int mca_rcache_vma_delete(struct mca_rcache_base_module_t* rcache,
|
|
|
|
mca_mpool_base_registration_t* registration);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* init/finalize
|
|
|
|
*/
|
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
void mca_rcache_vma_module_init(mca_rcache_vma_module_t *rcache);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
void mca_rcache_vma_finalize(struct mca_rcache_base_module_t*);
|
2006-08-15 18:40:08 +00:00
|
|
|
|
|
|
|
#endif /* MCA_RCACHE_VMA_H */
|
|
|
|
|
|
|
|
|