blob: bd0bee75c2a8c13234fb402aa3a99abd0fcf639e [file] [log] [blame]
andrew@webrtc.orgb015cbe2012-10-22 18:19:231/*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11// This file contains platform-specific typedefs and defines.
12// Much of it is derived from Chromium's build/build_config.h.
13
14#ifndef WEBRTC_TYPEDEFS_H_
15#define WEBRTC_TYPEDEFS_H_
16
andrew@webrtc.orgb015cbe2012-10-22 18:19:2317// Processor architecture detection. For more info on what's defined, see:
18// http://msdn.microsoft.com/en-us/library/b0084kay.aspx
19// http://www.agner.org/optimize/calling_conventions.pdf
20// or with gcc, run: "echo | gcc -E -dM -"
andrew@webrtc.orgb015cbe2012-10-22 18:19:2321#if defined(_M_X64) || defined(__x86_64__)
22#define WEBRTC_ARCH_X86_FAMILY
23#define WEBRTC_ARCH_X86_64
24#define WEBRTC_ARCH_64_BITS
25#define WEBRTC_ARCH_LITTLE_ENDIAN
andrew@webrtc.org78306892014-04-01 01:19:0826#elif defined(__aarch64__)
kjellander6de37042015-12-18 12:28:4227#define WEBRTC_ARCH_ARM_FAMILY
andrew@webrtc.orgd30a9ea2014-03-27 19:48:5328#define WEBRTC_ARCH_64_BITS
29#define WEBRTC_ARCH_LITTLE_ENDIAN
andrew@webrtc.orgb015cbe2012-10-22 18:19:2330#elif defined(_M_IX86) || defined(__i386__)
31#define WEBRTC_ARCH_X86_FAMILY
32#define WEBRTC_ARCH_X86
33#define WEBRTC_ARCH_32_BITS
34#define WEBRTC_ARCH_LITTLE_ENDIAN
andrew@webrtc.orgb015cbe2012-10-22 18:19:2335#elif defined(__ARMEL__)
kjellander6de37042015-12-18 12:28:4236#define WEBRTC_ARCH_ARM_FAMILY
andrew@webrtc.orgb015cbe2012-10-22 18:19:2337#define WEBRTC_ARCH_32_BITS
38#define WEBRTC_ARCH_LITTLE_ENDIAN
andrew@webrtc.orgb015cbe2012-10-22 18:19:2339#elif defined(__MIPSEL__)
kjellander6de37042015-12-18 12:28:4240#define WEBRTC_ARCH_MIPS_FAMILY
milko.leporis040dd992016-06-23 10:52:2841#if defined(__LP64__)
42#define WEBRTC_ARCH_64_BITS
43#else
andrew@webrtc.orgb015cbe2012-10-22 18:19:2344#define WEBRTC_ARCH_32_BITS
milko.leporis040dd992016-06-23 10:52:2845#endif
andrew@webrtc.orgb015cbe2012-10-22 18:19:2346#define WEBRTC_ARCH_LITTLE_ENDIAN
andresp@webrtc.org1af2c142014-02-19 13:55:0247#elif defined(__pnacl__)
48#define WEBRTC_ARCH_32_BITS
49#define WEBRTC_ARCH_LITTLE_ENDIAN
andrew@webrtc.orgb015cbe2012-10-22 18:19:2350#else
51#error Please add support for your architecture in typedefs.h
52#endif
53
andrew@webrtc.orgd7e90412013-10-22 10:27:2354#if !(defined(WEBRTC_ARCH_LITTLE_ENDIAN) ^ defined(WEBRTC_ARCH_BIG_ENDIAN))
55#error Define either WEBRTC_ARCH_LITTLE_ENDIAN or WEBRTC_ARCH_BIG_ENDIAN
56#endif
57
Andrew MacDonaldab168022015-05-20 05:20:1758// TODO(zhongwei.yao): WEBRTC_CPU_DETECTION is only used in one place; we should
59// probably just remove it.
pasko43b11302016-05-17 17:56:4060#if (defined(WEBRTC_ARCH_X86_FAMILY) && !defined(__SSE2__))
andrew@webrtc.orge9d42e62014-02-27 04:12:3461#define WEBRTC_CPU_DETECTION
andrew@webrtc.orgb015cbe2012-10-22 18:19:2362#endif
63
andrew@webrtc.orgb015cbe2012-10-22 18:19:2364#include <stdint.h>
andrew@webrtc.orgb015cbe2012-10-22 18:19:2365
andrew@webrtc.org221798a2013-10-22 12:50:0066// Annotate a function indicating the caller must examine the return value.
67// Use like:
kwiberg697679a2017-04-06 11:32:2768// int foo() RTC_WARN_UNUSED_RESULT;
69// To explicitly ignore a result, cast to void.
70// TODO(kwiberg): Remove when we can use [[nodiscard]] from C++17.
71#if defined(__clang__)
72#define RTC_WARN_UNUSED_RESULT __attribute__((__warn_unused_result__))
73#elif defined(__GNUC__)
74// gcc has a __warn_unused_result__ attribute, but you can't quiet it by
75// casting to void, so we don't use it.
76#define RTC_WARN_UNUSED_RESULT
andrew@webrtc.org221798a2013-10-22 12:50:0077#else
kwiberg697679a2017-04-06 11:32:2778#define RTC_WARN_UNUSED_RESULT
andrew@webrtc.org221798a2013-10-22 12:50:0079#endif
80
kwiberg@webrtc.org999bcbc2014-08-25 06:26:0481// Put after a variable that might not be used, to prevent compiler warnings:
pbos@webrtc.orgf08b85e2014-11-17 13:47:3882// int result ATTRIBUTE_UNUSED = DoSomething();
kwiberg@webrtc.org999bcbc2014-08-25 06:26:0483// assert(result == 17);
terelius822434d2017-03-17 13:34:4784// Deprecated since it only works with GCC & clang. See RTC_UNUSED below.
85// TODO(terelius): Remove.
pbos@webrtc.orgf08b85e2014-11-17 13:47:3886#ifndef ATTRIBUTE_UNUSED
87#if defined(__GNUC__) || defined(__clang__)
kjellander9587b402016-01-08 12:51:3888#define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
kwiberg@webrtc.org999bcbc2014-08-25 06:26:0489#else
pbos@webrtc.orgf08b85e2014-11-17 13:47:3890#define ATTRIBUTE_UNUSED
kwiberg@webrtc.org999bcbc2014-08-25 06:26:0491#endif
92#endif
93
kjellander@webrtc.org2234f412015-01-28 18:37:5894// Macro to be used for switch-case fallthrough (required for enabling
95// -Wimplicit-fallthrough warning on Clang).
96#ifndef FALLTHROUGH
97#if defined(__clang__)
98#define FALLTHROUGH() [[clang::fallthrough]]
99#else
100#define FALLTHROUGH() do { } while (0)
101#endif
102#endif
103
agouaillard570255a2017-01-30 08:54:19104#ifndef NO_RETURN
andrew@webrtc.org54ade8b2014-08-28 16:28:26105// Annotate a function that will not return control flow to the caller.
106#if defined(_MSC_VER)
107#define NO_RETURN __declspec(noreturn)
108#elif defined(__GNUC__)
kjellander9587b402016-01-08 12:51:38109#define NO_RETURN __attribute__ ((__noreturn__))
andrew@webrtc.org54ade8b2014-08-28 16:28:26110#else
111#define NO_RETURN
112#endif
agouaillard570255a2017-01-30 08:54:19113#endif
andrew@webrtc.org54ade8b2014-08-28 16:28:26114
terelius822434d2017-03-17 13:34:47115// Prevent the compiler from warning about an unused variable. For example:
116// int result = DoSomething();
117// assert(result == 17);
118// RTC_UNUSED(result);
119// Note: In most cases it is better to remove the unused variable rather than
120// suppressing the compiler warning.
121#ifndef RTC_UNUSED
122#define RTC_UNUSED(x) static_cast<void>(x)
123#endif // RTC_UNUSED
124
andrew@webrtc.orgb015cbe2012-10-22 18:19:23125#endif // WEBRTC_TYPEDEFS_H_