2007-04-16 13:28:29 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2007, Haiku, Inc. All Rights Reserved.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
|
|
|
* Documentation by:
|
|
|
|
* Niels Sascha Reedijk <niels.reedijk@gmail.com>
|
|
|
|
* Corresponds to:
|
|
|
|
* /trunk/headers/os/support/SupportDefs.h rev 19972
|
|
|
|
*/
|
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\file SupportDefs.h
|
|
|
|
\ingroup support
|
|
|
|
\brief Defines basic types and definitions for the Haiku API.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Short byte long Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef signed char int8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned char uint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile signed char vint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned char vuint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Short 2-byte long Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef short int16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned short uint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile short vint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned short vuint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Short 4-byte long Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef long int32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned long uint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile long vint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned long vuint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Short 8-byte long Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef long long int64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned long long uint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile long long vint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned long long vuint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Short volatile Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile long vlong
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile int vint
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile short vshort
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile char vchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned long vulong
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned int vuint
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned short vushort
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef volatile unsigned char vuchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Character Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned char uchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef unsigned short unichar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\name Descriptive Type Formats
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef int32 status_t
|
|
|
|
\brief Represents one of the status codes defined in Error.h
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef int64 bigtime_t
|
|
|
|
\brief Represents time. The unit depends on the context of the function.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef uint32 type_code
|
|
|
|
\brief Represents a certain type of data. See TypeConstants.h for possible
|
|
|
|
values.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\typedef typedef uint32 perform_code
|
|
|
|
\brief Unused. Defined by Be to support 'hidden' commands or
|
|
|
|
extensions to classes. The Haiku API has none of these.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
//////////////// Odds and ends
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\var const char *B_EMPTY_STRING
|
|
|
|
\brief Defines an empty string. Currently defined as the C-string "".
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\def min_c(a,b)
|
|
|
|
\brief Returns the minimum of the values a and b.
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2007-04-02 15:39:10 +04:00
|
|
|
\note When including this header in a C file, use the C equivalent called
|
|
|
|
\c min(a,b).
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\def max_c(a,b)
|
|
|
|
\brief Returns the maximum of values a and b.
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2007-04-02 15:39:10 +04:00
|
|
|
\note When including this header in a C file, use the C equivalent called
|
|
|
|
\c max(a,b).
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\def NULL
|
|
|
|
\brief Defines the constant \c NULL if it hasn't been defined anywhere before.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\addtogroup support_globals
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_set(vint32 *value, int32 newValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_set64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_test_and_set(), atomic_add(), atomic_and(),
|
|
|
|
atomic_or(), atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_test_and_set(vint32 *value, int32 newValue, int32 testAgainst)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_test_and_set64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_set(), atomic_add(), atomic_and(),
|
|
|
|
atomic_or(), atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_add(vint32 *value, int32 addValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_add64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_set(), atomic_test_and_set(), atomic_and(),
|
|
|
|
atomic_or(), atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_and(vint32 *value, int32 andValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_and64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_set(), atomic_test_and_set(), atomic_add(),
|
|
|
|
atomic_or(), atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_or(vint32 *value, int32 orValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_or64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_set(), atomic_test_and_set(), atomic_add(), atomic_and(),
|
|
|
|
atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int32 atomic_get(vint32 *value)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_get64() for a version that works on \c long \c long
|
|
|
|
\sa atomic_set(), atomic_test_and_set(), atomic_add(), atomic_and(),
|
|
|
|
atomic_or()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_set64(vint64 *value, int64 newValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_set() for a version that works on an \c int32
|
|
|
|
\sa atomic_test_and_set64(), atomic_add64(), atomic_and64(),
|
|
|
|
atomic_or64(), atomic_get64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_test_and_set64(vint64 *value, int64 newValue, int64 testAgainst)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_test_and_set() for a version that works on an \c int32
|
|
|
|
\sa atomic_set64(), atomic_add64(), atomic_and64(),
|
|
|
|
atomic_or64(), atomic_get64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_add64(vint64 *value, int64 addValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_add() for a version that works on an \c int32
|
|
|
|
\sa atomic_set64(), atomic_test_and_set64(), atomic_and64(),
|
|
|
|
atomic_or64(), atomic_get64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_and64(vint64 *value, int64 andValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_and() for a version that works on an \c int32
|
|
|
|
\sa atomic_set64(), atomic_test_and_set64(), atomic_add64(),
|
|
|
|
atomic_or64(), atomic_get64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_or64(vint64 *value, int64 orValue)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_or() for a version that works on an \c int32
|
|
|
|
\sa atomic_set64(), atomic_test_and_set64(), atomic_add64(), atomic_and64(),
|
|
|
|
atomic_get64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn int64 atomic_get64(vint64 *value)
|
|
|
|
\brief Undocumented.
|
|
|
|
\sa atomic_get() for a version that works on an \c int32
|
|
|
|
\sa atomic_set64(), atomic_test_and_set64(), atomic_add64(), atomic_and64(),
|
|
|
|
atomic_or64()
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\fn void* get_stack_frame(void)
|
|
|
|
\brief This is internal, I guess. Else this needs to be documented.
|
|
|
|
\internal
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\def FALSE
|
|
|
|
\brief Obsolete. Use \c false.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2007-04-02 15:39:10 +04:00
|
|
|
\def TRUE
|
|
|
|
\brief Obsolete. Use \c true.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|