2007-04-16 13:28:29 +04:00
|
|
|
/*
|
2014-06-25 03:25:43 +04:00
|
|
|
* Copyright 2007-2014 Haiku, Inc. All rights reserved.
|
2007-04-16 13:28:29 +04:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
2013-02-07 06:05:00 +04:00
|
|
|
* Authors:
|
|
|
|
* Niels Sascha Reedijk, niels.reedijk@gmail.com
|
2014-06-25 03:25:43 +04:00
|
|
|
* John Scipione, jscipione@gmail.com
|
2013-02-07 06:05:00 +04:00
|
|
|
*
|
2007-04-16 13:28:29 +04:00
|
|
|
* Corresponds to:
|
2013-02-07 06:05:00 +04:00
|
|
|
* headers/os/support/SupportDefs.h rev 35018
|
2007-04-16 13:28:29 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\file SupportDefs.h
|
|
|
|
\ingroup support
|
2013-02-08 00:04:05 +04:00
|
|
|
\ingroup libbe
|
2013-02-07 06:05:00 +04:00
|
|
|
\brief Defines basic types and definitions for the Haiku API.
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\name Fixed-Size Integer Types
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_int8 int8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_uint8 uint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_int16 int16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_uint16 uint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_int32 int32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_uint32 uint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_int64 int64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef __haiku_uint64 uint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2010-01-19 02:14:46 +03:00
|
|
|
\name Fixed-size Volatile Types
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
//! @{
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile int8 vint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile uint8 vuint8
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile int16 vint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile uint16 vuint16
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile int32 vint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile uint32 vuint32
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile int64 vint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile uint64 vuint64
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2010-01-19 02:14:46 +03:00
|
|
|
\name Short-hand Volatile Type Names
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile long vlong
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile int vint
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile short vshort
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile char vchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile unsigned long vulong
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile unsigned int vuint
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile unsigned short vushort
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef volatile unsigned char vuchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
/*!
|
|
|
|
\name Character Type Formats
|
|
|
|
*/
|
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef unsigned char uchar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef unsigned short unichar
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\name Descriptive Type Formats
|
|
|
|
*/
|
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef int32 status_t
|
2014-06-25 03:25:43 +04:00
|
|
|
\brief Represents one of the status codes defined in Error.h.
|
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef int64 bigtime_t
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Represents time. The unit depends on the context of the function.
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef int64 nanotime_t
|
2010-01-19 02:14:46 +03:00
|
|
|
\brief Represents time in nanoseconds.
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef uint32 type_code
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Represents a certain type of data. See TypeConstants.h for
|
2014-06-25 03:25:43 +04:00
|
|
|
possible values.
|
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
/*!
|
2013-02-07 06:05:00 +04:00
|
|
|
\typedef typedef uint32 perform_code
|
|
|
|
\brief Defined to support 'hidden' commands or extensions to classes.
|
|
|
|
|
|
|
|
The Haiku API has none of these.
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
2014-06-25 03:25:43 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
/*!
|
|
|
|
\name Format strings for printf() and scanf()
|
|
|
|
*/
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRId8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIi8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRId16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIi16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRId32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIi32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRId64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIi64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIu8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIo8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIx8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIX8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIu16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIo16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIx16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIX16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIu32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIo32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIx32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIX32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIu64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIo64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIx64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIX64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNd8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNi8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNd16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNi16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNd32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNi32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNd64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNi64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNu8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNo8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNx8
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNu16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNo16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNx16
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNu32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNo32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNx32
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNu64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNo64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_SCNx64
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
//! @}
|
|
|
|
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
/*!
|
|
|
|
\name Format strings for several standard types
|
|
|
|
*/
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIuSIZE
|
|
|
|
\brief size_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIoSIZE
|
|
|
|
\brief size_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIxSIZE
|
|
|
|
\brief size_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIXSIZE
|
|
|
|
\brief size_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIdSSIZE
|
|
|
|
\brief ssize_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIiSSIZE
|
|
|
|
\brief ssize_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIuADDR
|
|
|
|
\brief addr_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIoADDR
|
|
|
|
\brief addr_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIxADDR
|
|
|
|
\brief addr_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIXADDR
|
|
|
|
\brief addr_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIdOFF
|
|
|
|
\brief off_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIiOFF
|
|
|
|
\brief off_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
/*!
|
2010-01-19 02:14:46 +03:00
|
|
|
\def B_PRIdDEV
|
|
|
|
\brief dev_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIiDEV
|
|
|
|
\brief dev_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIdINO
|
|
|
|
\brief ino_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIiINO
|
|
|
|
\brief ino_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
/*!
|
2010-01-19 02:14:46 +03:00
|
|
|
\def B_PRIdTIME
|
|
|
|
\brief time_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
/*!
|
|
|
|
\def B_PRIiTIME
|
|
|
|
\brief time_t
|
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
//! @}
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//////////////// Odds and ends
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
/*!
|
2014-06-25 03:25:43 +04:00
|
|
|
\var const char* B_EMPTY_STRING
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Defines an empty string. Currently defined as the string "".
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\def min_c(a,b)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Returns the minimum of the values a and b.
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
\note When including this header in a C file, use the C equivalent called
|
|
|
|
\c min(a,b).
|
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\def max_c(a,b)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Returns the maximum of values a and b.
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
\note When including this header in a C file, use the C equivalent called
|
|
|
|
\c max(a,b).
|
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\def NULL
|
|
|
|
\brief Defines the constant \c NULL if it hasn't already been defined.
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2013-02-07 06:05:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\addtogroup support_globals
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
/*!
|
|
|
|
\fn void atomic_set(int32* value, int32 newValue)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically set the variable \a value to \a newvalue.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
This is a thread-safe way of performing the \c *value \c = \c newValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
|
|
|
mutex in this case. The variable must be naturally aligned.
|
|
|
|
|
|
|
|
\sa atomic_set64() for a version that works on \c long \c long.
|
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_or(),
|
|
|
|
\sa atomic_get()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2013-07-24 00:24:15 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*! \fn int32 atomic_get_and_set(int32* value, int32 newValue)
|
|
|
|
\brief Atomically set the variable \a value to \a newvalue and return the
|
2014-06-25 03:25:43 +04:00
|
|
|
old value.
|
2013-07-24 00:24:15 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
This is a thread-safe way of performing the \c *value \c = \c newValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64() for a version that works on \c long \c long.
|
|
|
|
\sa atomic_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_or(),
|
|
|
|
\sa atomic_get()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
/*! \fn int32 atomic_test_and_set(int32* value, int32 newValue,
|
2011-08-10 01:46:13 +04:00
|
|
|
int32 testAgainst)
|
|
|
|
\brief Atomically set the variable \a value to \a newValue if the current
|
2014-06-25 03:25:43 +04:00
|
|
|
value is \a testAgainst.
|
|
|
|
|
|
|
|
This is a thread-safe way of conditionally performing the \c *value \c +=
|
2011-08-10 01:46:13 +04:00
|
|
|
\c newValue operation. You should use these function when two or more
|
|
|
|
threads might access the variable simultaneously. You don't have to use
|
2014-06-25 03:25:43 +04:00
|
|
|
a semaphore or a mutex in this case.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_test_and_set64() for a version that works on \c long \c long.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_or()
|
|
|
|
\sa atomic_get()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int32 atomic_add(int32* value, int32 addValue)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically add the value of \a addValue to \a value.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
This is a thread-safe way of performing the \c *value \c += \c addValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_add64() for a version that works on \c long \c long.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set()
|
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_or()
|
|
|
|
\sa atomic_get()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
/*! \fn int32 atomic_and(int32* value, int32 andValue)
|
2014-06-25 03:25:43 +04:00
|
|
|
\brief Atomically perform a bitwise AND operation of \a andValue to the
|
2010-01-19 02:14:46 +03:00
|
|
|
variable \a andValue.
|
|
|
|
|
|
|
|
This is a thread-safe way of performing the \c *value \c &= \c andValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_and64() for a version that works on \c long \c long.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set()
|
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_or()
|
|
|
|
\sa atomic_get()
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
\since BeOS R3
|
|
|
|
*/
|
2007-03-30 17:50:00 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int32 atomic_or(int32* value, int32 orValue)
|
2014-06-25 03:25:43 +04:00
|
|
|
\brief Atomically perform a bitwise OR operation of \a orValue to the
|
|
|
|
variable \a andValue.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
This is a thread-safe way of performing the \c *value \c |= \c orValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_or64() for a version that works on \c long \c long.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set()
|
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_get()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int32 atomic_get(int32* value)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically return the value of \c value.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
This is a thread-safe way of reading the contents of the \c value
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2013-07-24 00:24:15 +04:00
|
|
|
mutex in this case. The variable must be naturally aligned.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_get64() for a version that works on \c long \c long.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set()
|
|
|
|
\sa atomic_test_and_set()
|
|
|
|
\sa atomic_add()
|
|
|
|
\sa atomic_and()
|
|
|
|
\sa atomic_or()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn void atomic_set64(int64* value, int64 newValue)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically set the variable \a value to \a newvalue.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
This is a thread-safe way of performing the \c *value \c = \c newValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
|
|
|
mutex in this case. The variable must be naturally aligned.
|
|
|
|
|
|
|
|
\sa atomic_set() for a version that works on an \c int32.
|
|
|
|
\sa atomic_get_and_set64()
|
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_or64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2013-07-24 00:24:15 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn int64 atomic_get_and_set64(int64* value, int64 newValue)
|
|
|
|
\brief Atomically set the variable \a value to \a newvalue and return
|
2014-06-25 03:25:43 +04:00
|
|
|
the old value.
|
2013-07-24 00:24:15 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
This is a thread-safe way of performing the \c *value \c = \c newValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
|
|
|
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set() for a version that works on an \c int32.
|
|
|
|
\sa atomic_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_or64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int64 atomic_test_and_set64(int64* value, int64 newValue,
|
2011-08-10 01:46:13 +04:00
|
|
|
int64 testAgainst)
|
|
|
|
\brief Atomically set the variable \a value to \a newValue if the current
|
2014-06-25 03:25:43 +04:00
|
|
|
value is \a testAgainst.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2011-08-10 01:46:13 +04:00
|
|
|
This is a thread-safe way of conditionally performing the \c *value
|
|
|
|
\c += \c newValue operation. You should use these function when two
|
|
|
|
or more threads might access the variable simultaneously. You don't
|
2014-06-25 03:25:43 +04:00
|
|
|
have to use a semaphore or a mutex in this case.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_test_and_set() for a version that works on an \c int32.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_or64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int64 atomic_add64(int64* value, int64 addValue)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically add the value of \a addValue to \a value.
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
This is a thread-safe way of performing the \c *value \c += \c addValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_add() for a version that works on an \c int32.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set64()
|
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_or64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int64 atomic_and64(int64* value, int64 andValue)
|
2013-02-07 06:05:00 +04:00
|
|
|
\brief Atomically perform a bitwise AND operation of \a andValue to the
|
2014-06-25 03:25:43 +04:00
|
|
|
variable \a andValue.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
This is a thread-safe way of performing the \c *value \c &= \c andValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2013-02-07 06:05:00 +04:00
|
|
|
mutex in this case.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_and() for a version that works on an \c int32.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set64()
|
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_or64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2014-06-25 03:25:43 +04:00
|
|
|
/*!
|
|
|
|
\fn int64 atomic_or64(int64* value, int64 orValue)
|
2013-02-07 06:05:00 +04:00
|
|
|
\brief Atomically perform a bitwise OR operation of \a orValue to the
|
2014-06-25 03:25:43 +04:00
|
|
|
variable \a andValue.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
This is a thread-safe way of performing the \c *value \c |= \c orValue
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2014-06-25 03:25:43 +04:00
|
|
|
mutex in this case.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_or() for a version that works on an \c int32.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set64()
|
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_get64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
2013-07-24 00:24:15 +04:00
|
|
|
\fn int64 atomic_get64(int64* value)
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Atomically return the value of \c value.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
This is a thread-safe way of reading the contents of the \c value
|
|
|
|
operation. You should use these function when two or more threads might
|
|
|
|
access the variable simultaneously. You don't have to use a semaphore or a
|
2013-07-24 00:24:15 +04:00
|
|
|
mutex in this case. The variable must be naturally aligned.
|
2010-01-19 02:14:46 +03:00
|
|
|
|
|
|
|
\return The original value of \c value.
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_get() for a version that works on an \c int32.
|
2013-07-24 00:24:15 +04:00
|
|
|
\sa atomic_get_and_set64()
|
2013-02-07 06:05:00 +04:00
|
|
|
\sa atomic_set64()
|
|
|
|
\sa atomic_test_and_set64()
|
|
|
|
\sa atomic_add64()
|
|
|
|
\sa atomic_and64()
|
|
|
|
\sa atomic_or64()
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @}
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void* get_stack_frame(void)
|
|
|
|
\brief Internal function.
|
|
|
|
\internal
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\name Deprecated defines
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2010-01-19 02:14:46 +03:00
|
|
|
|
2007-03-30 17:50:00 +04:00
|
|
|
//! @{
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\def FALSE
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Obsolete. Use \c false.
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\def TRUE
|
2011-08-10 01:46:13 +04:00
|
|
|
\brief Obsolete. Use \c true.
|
2014-06-25 03:25:43 +04:00
|
|
|
|
|
|
|
\since BeOS R3
|
2007-03-30 17:50:00 +04:00
|
|
|
*/
|
|
|
|
|
2011-08-10 01:46:13 +04:00
|
|
|
|
2013-02-07 06:05:00 +04:00
|
|
|
//! @}
|