107 строки
3.0 KiB
C
107 строки
3.0 KiB
C
|
/*
|
||
|
* Copyright (c) 2004-2005 The Trustees of Indiana University.
|
||
|
* All rights reserved.
|
||
|
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
||
|
* 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$
|
||
|
*
|
||
|
* Additional copyrights may follow
|
||
|
*
|
||
|
* $HEADER$
|
||
|
*/
|
||
|
|
||
|
#include "mca/rcache/rcache.h"
|
||
|
#include "rcache_rb.h"
|
||
|
#include "rcache_rb_tree.h"
|
||
|
#include "rcache_rb_mru.h"
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Initialize the rcache
|
||
|
*/
|
||
|
|
||
|
void mca_rcache_rb_module_init( mca_rcache_rb_module_t* rcache ) {
|
||
|
|
||
|
rcache->base.rcache_find = mca_rcache_rb_find;
|
||
|
rcache->base.rcache_insert = mca_rcache_rb_insert;
|
||
|
rcache->base.rcache_delete = mca_rcache_rb_delete;
|
||
|
rcache->base.rcache_finalize = mca_rcache_rb_finalize;
|
||
|
|
||
|
}
|
||
|
int mca_rcache_rb_find (
|
||
|
struct mca_rcache_base_module_t* rcache,
|
||
|
void* addr,
|
||
|
size_t size,
|
||
|
ompi_pointer_array_t* regs
|
||
|
){
|
||
|
|
||
|
int rc;
|
||
|
mca_rcache_rb_tree_item_t* tree_item;
|
||
|
tree_item = mca_rcache_rb_tree_find( (mca_rcache_rb_module_t*) rcache, addr );
|
||
|
if(NULL == tree_item) {
|
||
|
return OMPI_ERROR;
|
||
|
}
|
||
|
|
||
|
rc = ompi_pointer_array_add(regs, (void*) tree_item->reg);
|
||
|
if(OMPI_SUCCESS != rc) {
|
||
|
return rc;
|
||
|
}
|
||
|
|
||
|
if( !(tree_item->reg->flags & MCA_MPOOL_FLAGS_PERSIST) ) {
|
||
|
rc = mca_rcache_base_mru_touch(rcache, tree_item->reg);
|
||
|
}
|
||
|
OPAL_THREAD_ADD32(&tree_item->reg->ref_count, 1);
|
||
|
return rc;
|
||
|
}
|
||
|
|
||
|
int mca_rcache_rb_insert (
|
||
|
struct mca_rcache_base_module_t* rcache,
|
||
|
mca_mpool_base_registration_t* reg,
|
||
|
uint32_t flags
|
||
|
) {
|
||
|
int rc;
|
||
|
if(!(flags & MCA_MPOOL_FLAGS_PERSIST)) {
|
||
|
rc = mca_rcache_rb_mru_insert( (mca_rcache_rb_module_t*) rcache, reg);
|
||
|
}
|
||
|
if(OMPI_SUCCESS != rc) {
|
||
|
return rc;
|
||
|
}
|
||
|
mca_rcache_rb_tree_insert((mca_rcache_rb_module_t*)rcache, reg );
|
||
|
OPAL_THREAD_ADD32(®->ref_count, 1);
|
||
|
}
|
||
|
|
||
|
int mca_rcache_rb_delete (
|
||
|
struct mca_rcache_base_module_t* rcache,
|
||
|
mca_mpool_base_registration_t* reg,
|
||
|
uint32_t flags
|
||
|
) {
|
||
|
int rc;
|
||
|
if(!(flags & MCA_MPOOL_FLAGS_PERSIST)) {
|
||
|
rc = mca_rcache_rb_mru_delete( (mca_rcache_rb_module_t*) rcache, reg);
|
||
|
}
|
||
|
if(OMPI_SUCCESS != rc) {
|
||
|
return rc;
|
||
|
}
|
||
|
return mca_rcache_rb_tree_delete((mca_rcache_rb_module_t*)rcache, reg );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/**
|
||
|
* finalize
|
||
|
*/
|
||
|
void mca_rcache_rb_finalize(
|
||
|
struct mca_rcache_base_module_t* rcache
|
||
|
) {
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|