2014-09-21 19:33:12 +02:00

237 lines
7.5 KiB
C++

/* os.h -*-C++-*-
*
*************************************************************************
*
* @copyright
* Copyright (C) 2009-2013, Intel Corporation
* All rights reserved.
*
* @copyright
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Intel Corporation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* @copyright
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
**************************************************************************/
/**
* @file os.h
*
* @brief Low-level operating-system dependent facilities, not dependent on
* any Cilk facilities.
*/
#ifndef INCLUDED_OS_DOT_H
#define INCLUDED_OS_DOT_H
#include "rts-common.h"
#include "cilk/common.h"
#include "cilk-tbb-interop.h"
#ifdef __cplusplus
# include <cstddef>
#else
# include <stddef.h>
#endif
__CILKRTS_BEGIN_EXTERN_C
// /* Thread-local storage */
// #ifdef _WIN32
// typedef unsigned cilkos_tls_key_t;
// #else
// typedef pthread_key_t cilkos_tls_key_t;
// #endif
// cilkos_tls_key_t cilkos_allocate_tls_key();
// void cilkos_set_tls_pointer(cilkos_tls_key_t key, void* ptr);
// void* cilkos_get_tls_pointer(cilkos_tls_key_t key);
/* The RTS assumes that some thread-local state exists that stores the
worker and reducer map currently associated with a thread. These routines
manipulate this state. */
/** @brief Thread-local state for cilk fibers. */
typedef struct cilk_fiber_sysdep cilk_fiber_sysdep;
/** @brief Initialize all TLS variables for Cilk. */
COMMON_SYSDEP void __cilkrts_init_tls_variables(void);
/** @brief Set worker struct in TLS. */
COMMON_SYSDEP
void __cilkrts_set_tls_worker(__cilkrts_worker *w) cilk_nothrow;
/** @brief Get stack_op for TBB-interop structures from TLS. */
COMMON_SYSDEP
__cilk_tbb_stack_op_thunk *__cilkrts_get_tls_tbb_interop(void);
/** @brief Set stack_op for TBB-interop structures in TLS. */
COMMON_SYSDEP
void __cilkrts_set_tls_tbb_interop(__cilk_tbb_stack_op_thunk *t);
/**
* @brief Get the pointer to the pedigree leaf node from TLS.
*
* Function to get a pointer to the thread's pedigree leaf node. This
* pointer can be NULL.
*/
COMMON_SYSDEP
__cilkrts_pedigree * __cilkrts_get_tls_pedigree_leaf(int create_new);
/**
* @brief Sets the pointer to the pedigree leaf node in TLS.
*
* If the previous pointer value was not NULL, it is the caller's
* responsibility to ensure that previous pointer value is saved and
* freed.
*
* @param pedigree_leaf The leaf node to store into TLS.
*/
COMMON_SYSDEP
void __cilkrts_set_tls_pedigree_leaf(__cilkrts_pedigree* pedigree_leaf);
#if SUPPORT_GET_CURRENT_FIBER > 0
/**
* @brief Get the cilk_fiber from TLS.
*/
COMMON_SYSDEP
cilk_fiber_sysdep* cilkos_get_tls_cilk_fiber(void);
/**
* @brief Set the cilk_fiber in TLS.
*
* @param fiber The fiber to store into TLS.
*/
COMMON_SYSDEP
void cilkos_set_tls_cilk_fiber(cilk_fiber_sysdep* fiber);
#endif
/**
* @brief Function for returning the current thread id.
* @warning This function is useful for debugging purposes only.
*/
COMMON_SYSDEP
void* cilkos_get_current_thread_id(void);
/** @brief Return number of CPUs supported by this hardware, using whatever definition
of CPU is considered appropriate. */
COMMON_SYSDEP int __cilkrts_hardware_cpu_count(void);
/** @brief Get current value of timer */
COMMON_SYSDEP unsigned long long __cilkrts_getticks(void);
/* Machine instructions */
/// Stall execution for a few cycles.
COMMON_SYSDEP void __cilkrts_short_pause(void);
/// Wrapper for xchg instruction
COMMON_SYSDEP int __cilkrts_xchg(volatile int *ptr, int x);
// Defines __cilkrts_fence - A macro for x86, a function call for other
// architectures
#include "os-fence.h"
COMMON_SYSDEP void __cilkrts_sleep(void); ///< Sleep briefly
COMMON_SYSDEP void __cilkrts_yield(void); ///< Yield quantum
/**
* @brief Gets environment variable 'varname' and copy its value into 'value'.
*
* If the entire value, including the null terminator fits into 'vallen'
* bytes, then returns the length of the value excluding the null. Otherwise,
* leaves the contents of 'value' undefined and returns the number of
* characters needed to store the environment variable's value, *including*
* the null terminator.
*
* @param value Buffer to store value.
* @param vallen Length of value buffer
* @param varname Name of the environment variable.
* @return Length of value buffer (excluding the null).
*/
COMMON_SYSDEP __STDNS size_t cilkos_getenv(char* value, __STDNS size_t vallen,
const char* varname);
/**
* @brief Unrecoverable error: Print an error message and abort execution.
*/
COMMON_SYSDEP void cilkos_error(const char *fmt, ...);
/**
* @brief Print a warning message and return.
*/
COMMON_SYSDEP void cilkos_warning(const char *fmt, ...);
/**
* @brief Convert the user's specified stack size into a "reasonable"
* value for the current OS.
*
* @param specified_stack_size User-specified stack size.
* @return New stack size value, modified for the OS.
*/
COMMON_SYSDEP size_t cilkos_validate_stack_size(size_t specified_stack_size);
/**
* @brief Atomic addition: computes *p += x.
*
* @param p Pointer to value to update
* @param x Value of x.
*/
COMMON_SYSDEP long cilkos_atomic_add(volatile long* p, long x);
#ifdef _WIN32
/**
* @brief Windows-only low-level functions for processor groups.
*/
typedef struct _GROUP_AFFINITY GROUP_AFFINITY;
/**
* @brief Probe the executing OS to see if it supports processor
* groups. These functions are expected to be available in Windows 7
* or later.
*/
void win_init_processor_groups(void);
unsigned long win_get_active_processor_count(unsigned short GroupNumber);
unsigned short win_get_active_processor_group_count(void);
int win_set_thread_group_affinity(/*HANDLE*/ void* hThread,
const GROUP_AFFINITY *GroupAffinity,
GROUP_AFFINITY* PreviousGroupAffinity);
/**
* @brief Cleans up any state allocated in TLS.
*
* Only defined for Windows because Linux calls destructors for each
* thread-local variable.
*/
void __cilkrts_per_thread_tls_cleanup(void);
#endif // _WIN32
__CILKRTS_END_EXTERN_C
#endif // ! defined(INCLUDED_OS_DOT_H)