1
1
openmpi/ompi/mca/rcache/rb/rcache_rb_mru.c
Galen Shipman 2314919b73 Initial checkin of rcache
This commit was SVN r7174.
2005-09-04 04:17:00 +00:00

92 строки
2.7 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$
*/
/**
* @file
* Description of the Registration Cache framework
*/
#include "mca/mca.h"
#include "rcache_rb_mru.h"
#include "mca/mpool/mpool.h"
/*
* insert an item in the rb mru
*/
int mca_rcache_base_mru_insert(
mca_rcache_rb_module_t* rcache,
mca_mpool_base_registration_t* reg
) {
OPAL_THREAD_LOCK(&rcache->rb_lock);
if(rcache->reg_mru_len <= rcache->mru_list.opal_list_length) {
mca_mpool_base_registration_t* old_reg =
(mca_mpool_base_registration_t*)
opal_list_remove_last(&rcache->mru_list);
/* need to pull out of rb tree here */
}
opal_list_append(&rcache->mru_list,(opal_list_item_t*) reg);
OPAL_THREAD_UNLOCK(&rcache->rb_lock);
return OMPI_SUCCESS;
}
/*
* remove an item from
the rb mru
*/
int mca_rcache_base_mru_delete(
mca_rcache_rb_module_t* rcache,
mca_mpool_base_registration_t *reg
){
int rc;
OPAL_THREAD_LOCK(&rcache->rb_lock);
if(NULL == opal_list_remove_item(
&rcache->mru_list,
(opal_list_item_t*) reg
)) {
rc = OMPI_ERROR;
} else {
rc = OMPI_SUCCESS;
}
OPAL_THREAD_UNLOCK(&rcache->rb_lock);
return rc;
}
/*
* touch an item in the mru list
*/
int mca_rcache_base_mru_touch(
mca_rcache_rb_module_t* rcache,
mca_mpool_base_registration_t* reg
){
int rc;
OPAL_THREAD_LOCK(rcache->rb_lock);
if(NULL == opal_list_remove_item(
&rcache->mru_list,
(opal_list_item_t*) reg
)) {
rc = OMPI_ERROR;
} else {
opal_list_append(&rcache->mru_list, (opal_list_item_t*) reg);
rc = OMPI_SUCCESS;
}
OPAL_THREAD_UNLOCK(rcache->rb_lock);
return rc;
}