1
1
Rainer Keller fd28b392bf - An intrusive commit yet again (sorry): with the separation we
get bitten by header depending on having already included
   the corresponding [opal|orte|ompi]_config.h header.
   When separating, things like [OPAL|ORTE|OMPI]_DECLSPEC
   are missed.

   Script to add the corresponding header in front of all following
   (taking care of possible #ifdef HAVE_...)

 - Including some minor cleanups to
   - ompi/group/group.h -- include _after_ #ifndef OMPI_GROUP_H
   - ompi/mca/btl/btl.h -- nclude _after_ #ifndef MCA_BTL_H
   - ompi/mca/crcp/bkmrk/crcp_bkmrk_btl.c -- still no need for
     orte/util/output.h
   - ompi/mca/pml/dr/pml_dr_recvreq.c -- no need for mpool.h
   - ompi/mca/btl/btl.h -- reorder to fit
   - ompi/mca/bml/bml.h -- reorder to fit
   - ompi/runtime/ompi_mpi_finalize.c -- reorder to fit
   - ompi/request/request.h -- additionally need ompi/constants.h

 - Tested on linux/x86-64

This commit was SVN r20720.
2009-03-04 15:35:54 +00:00

167 строки
6.3 KiB
C

/*
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation. All rights reserved.
* Copyright (c) 2004-2006 The University of Tennessee and The University
* 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$
*
* Additional copyrights may follow
*
* $HEADER$
*/
/**
* @file@
*
* Hooks for receiving callbacks when memory is allocated or deallocated
*
* Hooks for receiving callbacks when memory is allocated or
* deallocated from the current process. Intended to be used with
* RDMA communication devices that require "pinning" of virtual
* memory. The hooks allow for a "lazy unpinning" approach, which
* provides better latency when application buffer reuse is high.
* Most operating systems do not respond well to memory being freed
* from a process while still pinned, so some type of callback to
* unpin is necessary before the memory is returned to the OS.
*
* \note For linking reasons, this is not a component framework (some of
* these require tight coupling into libopal and the wrapper compilers
* and that entire stack).
*/
#ifndef OPAL_MEMORY_MEMORY_H
#define OPAl_MEMORY_MEMORY_H
#include "opal_config.h"
#include "memory_internal.h"
#if defined(c_plusplus) || defined(__cplusplus)
extern "C" {
#endif
/**
* Initialize the memory hooks subsystem
*
* Initialize the memory hooks subsystem. This is generally called
* during opal_init() and should be called before any other function
* in the interface is called.
*
* \note Note that some back-end functionality is activated pre-main,
* so not calling this function does not prevent the memory hooks from
* becoming active.
*
* @retval OPAL_SUCCESS Initialization completed successfully
*/
OPAL_DECLSPEC int opal_mem_hooks_init(void);
/**
* Finalize the memory hooks subsystem
*
* Finalize the memory hooks subsystem. This is generally called
* during opal_finalize() and no other memory hooks functions should
* be called after this function is called. opal_mem_hooks_finalize()
* will automatically deregister any callbacks that have not already
* been deregistered. In a multi-threaded application, it is possible
* that one thread will have a memory hook callback while the other
* thread is in opal_mem_hooks_finalize(), however, no threads will
* receive a callback once the calling thread has exited
* opal_mem_hooks_finalize().
*
* @retval OPAL_SUCCESS Shutdown completed successfully
*/
OPAL_DECLSPEC int opal_mem_hooks_finalize(void);
/**
* Query level of support provided by memory hooks
*
* Query memory hooks subsystem about the level of support provided by
* the current system configuration. The return value is \c 0 if no
* support is provided or a bit-wise OR of the available return values
* if support is provided.
*
* @retval OPAL_MEMORY_FREE_SUPPORT Memory hooks subsytem can trigger
* callback events when memory is going
* to be released by the process, either
* by the user calling an allocator
* function or munmap. Implies
* OPAL_MEMORY_MUNMAP_SUPPORT.
* @retval OPAL_MEMORY_MUNMAP_SUPPORT Subsystem can trigger callback events
* by the user calling munmap directly.
* @retval OPAL_MEMORY_CHUNK_SUPPORT Memory hooks subsystem will only
* trigger callback events when the
* process is giving memory back to the
* operating system, not at ever call
* to realloc/free/etc.
*
* \note This function must be called after opal_mem_hooks_init().
*/
OPAL_DECLSPEC int opal_mem_hooks_support_level(void);
/**
* Memory status change callback
*
* Typedef for callbacks triggered when memory has been allocated or
* is about to be freed. The callback will be triggered according to
* the note in opal_mem_hooks_register_alloc() or
* opal_mem_hooks_register_release().
*
* @param buf Pointer to the start of the allocation
* @param lentgh Length of the allocation
* @param cbdata Data passed to memory hooks when callback
* was registered
* @param from_alloc True if the callback is caused by a call to the
* general allocation routines (malloc, calloc, free,
* etc.) or directly from the user (mmap, munmap, etc.)
*/
typedef void (opal_mem_hooks_callback_fn_t)(void *buf, size_t length,
void *cbdata, bool from_alloc);
/**
* Register callback for when memory is to be released
*
* Register a \c opal_mem_hooks_callback_fn_t function pointer to be called
* whenever the current process is about to release memory.
*
* @param func Function pointer to call when memory is to be released
* @param cbdata A pointer-length field to be passed to func when it is
* invoked.
*
* @retval OPAL_SUCCESS The registration completed successfully.
* @retval OPAL_EXISTS The function is already registered and will not
* be registered again.
* @retval OPAL_ERR_NOT_SUPPORTED There are no hooks available for
* receiving callbacks when memory is to be released
*/
OPAL_DECLSPEC int opal_mem_hooks_register_release(opal_mem_hooks_callback_fn_t *func,
void *cbdata);
/**
* Unregister previously registered release callback
*
* Unregister previously registered release callback.
*
* @param func Function pointer to registered callback to remove
*
* @retval OPAL_SUCCESS The function was successfully deregistered
* @retval OPAL_ERR_NOT_FOUND The function was not previously registered
*/
OPAL_DECLSPEC int opal_mem_hooks_unregister_release(opal_mem_hooks_callback_fn_t *func);
#if defined(c_plusplus) || defined(__cplusplus)
}
#endif
#endif /* OPAL_MEMORY_MEMORY_H */