1=========================
2Clang Language Extensions
3=========================
4
5.. contents::
6   :local:
7   :depth: 1
8
9.. toctree::
10   :hidden:
11
12   ObjectiveCLiterals
13   BlockLanguageSpec
14   Block-ABI-Apple
15   AutomaticReferenceCounting
16   MatrixTypes
17
18Introduction
19============
20
21This document describes the language extensions provided by Clang.  In addition
22to the language extensions listed here, Clang aims to support a broad range of
23GCC extensions.  Please see the `GCC manual
24<https://gcc.gnu.org/onlinedocs/gcc/C-Extensions.html>`_ for more information on
25these extensions.
26
27.. _langext-feature_check:
28
29Feature Checking Macros
30=======================
31
32Language extensions can be very useful, but only if you know you can depend on
33them.  In order to allow fine-grain features checks, we support three builtin
34function-like macros.  This allows you to directly test for a feature in your
35code without having to resort to something like autoconf or fragile "compiler
36version checks".
37
38``__has_builtin``
39-----------------
40
41This function-like macro takes a single identifier argument that is the name of
42a builtin function, a builtin pseudo-function (taking one or more type
43arguments), or a builtin template.
44It evaluates to 1 if the builtin is supported or 0 if not.
45It can be used like this:
46
47.. code-block:: c++
48
49  #ifndef __has_builtin         // Optional of course.
50    #define __has_builtin(x) 0  // Compatibility with non-clang compilers.
51  #endif
52
53  ...
54  #if __has_builtin(__builtin_trap)
55    __builtin_trap();
56  #else
57    abort();
58  #endif
59  ...
60
61.. note::
62
63  Prior to Clang 10, ``__has_builtin`` could not be used to detect most builtin
64  pseudo-functions.
65
66  ``__has_builtin`` should not be used to detect support for a builtin macro;
67  use ``#ifdef`` instead.
68
69.. _langext-__has_feature-__has_extension:
70
71``__has_feature`` and ``__has_extension``
72-----------------------------------------
73
74These function-like macros take a single identifier argument that is the name
75of a feature.  ``__has_feature`` evaluates to 1 if the feature is both
76supported by Clang and standardized in the current language standard or 0 if
77not (but see :ref:`below <langext-has-feature-back-compat>`), while
78``__has_extension`` evaluates to 1 if the feature is supported by Clang in the
79current language (either as a language extension or a standard language
80feature) or 0 if not.  They can be used like this:
81
82.. code-block:: c++
83
84  #ifndef __has_feature         // Optional of course.
85    #define __has_feature(x) 0  // Compatibility with non-clang compilers.
86  #endif
87  #ifndef __has_extension
88    #define __has_extension __has_feature // Compatibility with pre-3.0 compilers.
89  #endif
90
91  ...
92  #if __has_feature(cxx_rvalue_references)
93  // This code will only be compiled with the -std=c++11 and -std=gnu++11
94  // options, because rvalue references are only standardized in C++11.
95  #endif
96
97  #if __has_extension(cxx_rvalue_references)
98  // This code will be compiled with the -std=c++11, -std=gnu++11, -std=c++98
99  // and -std=gnu++98 options, because rvalue references are supported as a
100  // language extension in C++98.
101  #endif
102
103.. _langext-has-feature-back-compat:
104
105For backward compatibility, ``__has_feature`` can also be used to test
106for support for non-standardized features, i.e. features not prefixed ``c_``,
107``cxx_`` or ``objc_``.
108
109Another use of ``__has_feature`` is to check for compiler features not related
110to the language standard, such as e.g. :doc:`AddressSanitizer
111<AddressSanitizer>`.
112
113If the ``-pedantic-errors`` option is given, ``__has_extension`` is equivalent
114to ``__has_feature``.
115
116The feature tag is described along with the language feature below.
117
118The feature name or extension name can also be specified with a preceding and
119following ``__`` (double underscore) to avoid interference from a macro with
120the same name.  For instance, ``__cxx_rvalue_references__`` can be used instead
121of ``cxx_rvalue_references``.
122
123``__has_cpp_attribute``
124-----------------------
125
126This function-like macro is available in C++20 by default, and is provided as an
127extension in earlier language standards. It takes a single argument that is the
128name of a double-square-bracket-style attribute. The argument can either be a
129single identifier or a scoped identifier. If the attribute is supported, a
130nonzero value is returned. If the attribute is a standards-based attribute, this
131macro returns a nonzero value based on the year and month in which the attribute
132was voted into the working draft. See `WG21 SD-6
133<https://isocpp.org/std/standing-documents/sd-6-sg10-feature-test-recommendations>`_
134for the list of values returned for standards-based attributes. If the attribute
135is not supported by the current compilation target, this macro evaluates to 0.
136It can be used like this:
137
138.. code-block:: c++
139
140  #ifndef __has_cpp_attribute         // For backwards compatibility
141    #define __has_cpp_attribute(x) 0
142  #endif
143
144  ...
145  #if __has_cpp_attribute(clang::fallthrough)
146  #define FALLTHROUGH [[clang::fallthrough]]
147  #else
148  #define FALLTHROUGH
149  #endif
150  ...
151
152The attribute scope tokens ``clang`` and ``_Clang`` are interchangeable, as are
153the attribute scope tokens ``gnu`` and ``__gnu__``. Attribute tokens in either
154of these namespaces can be specified with a preceding and following ``__``
155(double underscore) to avoid interference from a macro with the same name. For
156instance, ``gnu::__const__`` can be used instead of ``gnu::const``.
157
158``__has_c_attribute``
159---------------------
160
161This function-like macro takes a single argument that is the name of an
162attribute exposed with the double square-bracket syntax in C mode. The argument
163can either be a single identifier or a scoped identifier. If the attribute is
164supported, a nonzero value is returned. If the attribute is not supported by the
165current compilation target, this macro evaluates to 0. It can be used like this:
166
167.. code-block:: c
168
169  #ifndef __has_c_attribute         // Optional of course.
170    #define __has_c_attribute(x) 0  // Compatibility with non-clang compilers.
171  #endif
172
173  ...
174  #if __has_c_attribute(fallthrough)
175    #define FALLTHROUGH [[fallthrough]]
176  #else
177    #define FALLTHROUGH
178  #endif
179  ...
180
181The attribute scope tokens ``clang`` and ``_Clang`` are interchangeable, as are
182the attribute scope tokens ``gnu`` and ``__gnu__``. Attribute tokens in either
183of these namespaces can be specified with a preceding and following ``__``
184(double underscore) to avoid interference from a macro with the same name. For
185instance, ``gnu::__const__`` can be used instead of ``gnu::const``.
186
187``__has_attribute``
188-------------------
189
190This function-like macro takes a single identifier argument that is the name of
191a GNU-style attribute.  It evaluates to 1 if the attribute is supported by the
192current compilation target, or 0 if not.  It can be used like this:
193
194.. code-block:: c++
195
196  #ifndef __has_attribute         // Optional of course.
197    #define __has_attribute(x) 0  // Compatibility with non-clang compilers.
198  #endif
199
200  ...
201  #if __has_attribute(always_inline)
202  #define ALWAYS_INLINE __attribute__((always_inline))
203  #else
204  #define ALWAYS_INLINE
205  #endif
206  ...
207
208The attribute name can also be specified with a preceding and following ``__``
209(double underscore) to avoid interference from a macro with the same name.  For
210instance, ``__always_inline__`` can be used instead of ``always_inline``.
211
212
213``__has_declspec_attribute``
214----------------------------
215
216This function-like macro takes a single identifier argument that is the name of
217an attribute implemented as a Microsoft-style ``__declspec`` attribute.  It
218evaluates to 1 if the attribute is supported by the current compilation target,
219or 0 if not.  It can be used like this:
220
221.. code-block:: c++
222
223  #ifndef __has_declspec_attribute         // Optional of course.
224    #define __has_declspec_attribute(x) 0  // Compatibility with non-clang compilers.
225  #endif
226
227  ...
228  #if __has_declspec_attribute(dllexport)
229  #define DLLEXPORT __declspec(dllexport)
230  #else
231  #define DLLEXPORT
232  #endif
233  ...
234
235The attribute name can also be specified with a preceding and following ``__``
236(double underscore) to avoid interference from a macro with the same name.  For
237instance, ``__dllexport__`` can be used instead of ``dllexport``.
238
239``__is_identifier``
240-------------------
241
242This function-like macro takes a single identifier argument that might be either
243a reserved word or a regular identifier. It evaluates to 1 if the argument is just
244a regular identifier and not a reserved word, in the sense that it can then be
245used as the name of a user-defined function or variable. Otherwise it evaluates
246to 0.  It can be used like this:
247
248.. code-block:: c++
249
250  ...
251  #ifdef __is_identifier          // Compatibility with non-clang compilers.
252    #if __is_identifier(__wchar_t)
253      typedef wchar_t __wchar_t;
254    #endif
255  #endif
256
257  __wchar_t WideCharacter;
258  ...
259
260Include File Checking Macros
261============================
262
263Not all developments systems have the same include files.  The
264:ref:`langext-__has_include` and :ref:`langext-__has_include_next` macros allow
265you to check for the existence of an include file before doing a possibly
266failing ``#include`` directive.  Include file checking macros must be used
267as expressions in ``#if`` or ``#elif`` preprocessing directives.
268
269.. _langext-__has_include:
270
271``__has_include``
272-----------------
273
274This function-like macro takes a single file name string argument that is the
275name of an include file.  It evaluates to 1 if the file can be found using the
276include paths, or 0 otherwise:
277
278.. code-block:: c++
279
280  // Note the two possible file name string formats.
281  #if __has_include("myinclude.h") && __has_include(<stdint.h>)
282  # include "myinclude.h"
283  #endif
284
285To test for this feature, use ``#if defined(__has_include)``:
286
287.. code-block:: c++
288
289  // To avoid problem with non-clang compilers not having this macro.
290  #if defined(__has_include)
291  #if __has_include("myinclude.h")
292  # include "myinclude.h"
293  #endif
294  #endif
295
296.. _langext-__has_include_next:
297
298``__has_include_next``
299----------------------
300
301This function-like macro takes a single file name string argument that is the
302name of an include file.  It is like ``__has_include`` except that it looks for
303the second instance of the given file found in the include paths.  It evaluates
304to 1 if the second instance of the file can be found using the include paths,
305or 0 otherwise:
306
307.. code-block:: c++
308
309  // Note the two possible file name string formats.
310  #if __has_include_next("myinclude.h") && __has_include_next(<stdint.h>)
311  # include_next "myinclude.h"
312  #endif
313
314  // To avoid problem with non-clang compilers not having this macro.
315  #if defined(__has_include_next)
316  #if __has_include_next("myinclude.h")
317  # include_next "myinclude.h"
318  #endif
319  #endif
320
321Note that ``__has_include_next``, like the GNU extension ``#include_next``
322directive, is intended for use in headers only, and will issue a warning if
323used in the top-level compilation file.  A warning will also be issued if an
324absolute path is used in the file argument.
325
326``__has_warning``
327-----------------
328
329This function-like macro takes a string literal that represents a command line
330option for a warning and returns true if that is a valid warning option.
331
332.. code-block:: c++
333
334  #if __has_warning("-Wformat")
335  ...
336  #endif
337
338.. _languageextensions-builtin-macros:
339
340Builtin Macros
341==============
342
343``__BASE_FILE__``
344  Defined to a string that contains the name of the main input file passed to
345  Clang.
346
347``__FILE_NAME__``
348  Clang-specific extension that functions similar to ``__FILE__`` but only
349  renders the last path component (the filename) instead of an invocation
350  dependent full path to that file.
351
352``__COUNTER__``
353  Defined to an integer value that starts at zero and is incremented each time
354  the ``__COUNTER__`` macro is expanded.
355
356``__INCLUDE_LEVEL__``
357  Defined to an integral value that is the include depth of the file currently
358  being translated.  For the main file, this value is zero.
359
360``__TIMESTAMP__``
361  Defined to the date and time of the last modification of the current source
362  file.
363
364``__clang__``
365  Defined when compiling with Clang
366
367``__clang_major__``
368  Defined to the major marketing version number of Clang (e.g., the 2 in
369  2.0.1).  Note that marketing version numbers should not be used to check for
370  language features, as different vendors use different numbering schemes.
371  Instead, use the :ref:`langext-feature_check`.
372
373``__clang_minor__``
374  Defined to the minor version number of Clang (e.g., the 0 in 2.0.1).  Note
375  that marketing version numbers should not be used to check for language
376  features, as different vendors use different numbering schemes.  Instead, use
377  the :ref:`langext-feature_check`.
378
379``__clang_patchlevel__``
380  Defined to the marketing patch level of Clang (e.g., the 1 in 2.0.1).
381
382``__clang_version__``
383  Defined to a string that captures the Clang marketing version, including the
384  Subversion tag or revision number, e.g., "``1.5 (trunk 102332)``".
385
386``__clang_literal_encoding__``
387  Defined to a narrow string literal that represents the current encoding of
388  narrow string literals, e.g., ``"hello"``. This macro typically expands to
389  "UTF-8" (but may change in the future if the
390  ``-fexec-charset="Encoding-Name"`` option is implemented.)
391
392``__clang_wide_literal_encoding__``
393  Defined to a narrow string literal that represents the current encoding of
394  wide string literals, e.g., ``L"hello"``. This macro typically expands to
395  "UTF-16" or "UTF-32" (but may change in the future if the
396  ``-fwide-exec-charset="Encoding-Name"`` option is implemented.)
397
398.. _langext-vectors:
399
400Vectors and Extended Vectors
401============================
402
403Supports the GCC, OpenCL, AltiVec and NEON vector extensions.
404
405OpenCL vector types are created using the ``ext_vector_type`` attribute.  It
406supports the ``V.xyzw`` syntax and other tidbits as seen in OpenCL.  An example
407is:
408
409.. code-block:: c++
410
411  typedef float float4 __attribute__((ext_vector_type(4)));
412  typedef float float2 __attribute__((ext_vector_type(2)));
413
414  float4 foo(float2 a, float2 b) {
415    float4 c;
416    c.xz = a;
417    c.yw = b;
418    return c;
419  }
420
421Query for this feature with ``__has_attribute(ext_vector_type)``.
422
423Giving ``-maltivec`` option to clang enables support for AltiVec vector syntax
424and functions.  For example:
425
426.. code-block:: c++
427
428  vector float foo(vector int a) {
429    vector int b;
430    b = vec_add(a, a) + a;
431    return (vector float)b;
432  }
433
434NEON vector types are created using ``neon_vector_type`` and
435``neon_polyvector_type`` attributes.  For example:
436
437.. code-block:: c++
438
439  typedef __attribute__((neon_vector_type(8))) int8_t int8x8_t;
440  typedef __attribute__((neon_polyvector_type(16))) poly8_t poly8x16_t;
441
442  int8x8_t foo(int8x8_t a) {
443    int8x8_t v;
444    v = a;
445    return v;
446  }
447
448GCC vector types are created using the ``vector_size(N)`` attribute.  The
449argument ``N`` specifies the number of bytes that will be allocated for an
450object of this type.  The size has to be multiple of the size of the vector
451element type. For example:
452
453.. code-block:: c++
454
455  // OK: This declares a vector type with four 'int' elements
456  typedef int int4 __attribute__((vector_size(4 * sizeof(int))));
457
458  // ERROR: '11' is not a multiple of sizeof(int)
459  typedef int int_impossible __attribute__((vector_size(11)));
460
461  int4 foo(int4 a) {
462    int4 v;
463    v = a;
464    return v;
465  }
466
467
468Boolean Vectors
469---------------
470
471Clang also supports the ext_vector_type attribute with boolean element types in
472C and C++.  For example:
473
474.. code-block:: c++
475
476  // legal for Clang, error for GCC:
477  typedef bool bool4 __attribute__((ext_vector_type(4)));
478  // Objects of bool4 type hold 8 bits, sizeof(bool4) == 1
479
480  bool4 foo(bool4 a) {
481    bool4 v;
482    v = a;
483    return v;
484  }
485
486Boolean vectors are a Clang extension of the ext vector type.  Boolean vectors
487are intended, though not guaranteed, to map to vector mask registers.  The size
488parameter of a boolean vector type is the number of bits in the vector.  The
489boolean vector is dense and each bit in the boolean vector is one vector
490element.
491
492The semantics of boolean vectors borrows from C bit-fields with the following
493differences:
494
495* Distinct boolean vectors are always distinct memory objects (there is no
496  packing).
497* Only the operators `?:`, `!`, `~`, `|`, `&`, `^` and comparison are allowed on
498  boolean vectors.
499* Casting a scalar bool value to a boolean vector type means broadcasting the
500  scalar value onto all lanes (same as general ext_vector_type).
501* It is not possible to access or swizzle elements of a boolean vector
502  (different than general ext_vector_type).
503
504The size and alignment are both the number of bits rounded up to the next power
505of two, but the alignment is at most the maximum vector alignment of the
506target.
507
508
509Vector Literals
510---------------
511
512Vector literals can be used to create vectors from a set of scalars, or
513vectors.  Either parentheses or braces form can be used.  In the parentheses
514form the number of literal values specified must be one, i.e. referring to a
515scalar value, or must match the size of the vector type being created.  If a
516single scalar literal value is specified, the scalar literal value will be
517replicated to all the components of the vector type.  In the brackets form any
518number of literals can be specified.  For example:
519
520.. code-block:: c++
521
522  typedef int v4si __attribute__((__vector_size__(16)));
523  typedef float float4 __attribute__((ext_vector_type(4)));
524  typedef float float2 __attribute__((ext_vector_type(2)));
525
526  v4si vsi = (v4si){1, 2, 3, 4};
527  float4 vf = (float4)(1.0f, 2.0f, 3.0f, 4.0f);
528  vector int vi1 = (vector int)(1);    // vi1 will be (1, 1, 1, 1).
529  vector int vi2 = (vector int){1};    // vi2 will be (1, 0, 0, 0).
530  vector int vi3 = (vector int)(1, 2); // error
531  vector int vi4 = (vector int){1, 2}; // vi4 will be (1, 2, 0, 0).
532  vector int vi5 = (vector int)(1, 2, 3, 4);
533  float4 vf = (float4)((float2)(1.0f, 2.0f), (float2)(3.0f, 4.0f));
534
535Vector Operations
536-----------------
537
538The table below shows the support for each operation by vector extension.  A
539dash indicates that an operation is not accepted according to a corresponding
540specification.
541
542============================== ======= ======= ============= =======
543         Operator              OpenCL  AltiVec     GCC        NEON
544============================== ======= ======= ============= =======
545[]                               yes     yes       yes         --
546unary operators +, --            yes     yes       yes         --
547++, -- --                        yes     yes       yes         --
548+,--,*,/,%                       yes     yes       yes         --
549bitwise operators &,|,^,~        yes     yes       yes         --
550>>,<<                            yes     yes       yes         --
551!, &&, ||                        yes     --        yes         --
552==, !=, >, <, >=, <=             yes     yes       yes         --
553=                                yes     yes       yes         yes
554?: [#]_                          yes     --        yes         --
555sizeof                           yes     yes       yes         yes
556C-style cast                     yes     yes       yes         no
557reinterpret_cast                 yes     no        yes         no
558static_cast                      yes     no        yes         no
559const_cast                       no      no        no          no
560address &v[i]                    no      no        no [#]_     no
561============================== ======= ======= ============= =======
562
563See also :ref:`langext-__builtin_shufflevector`, :ref:`langext-__builtin_convertvector`.
564
565.. [#] ternary operator(?:) has different behaviors depending on condition
566  operand's vector type. If the condition is a GNU vector (i.e. __vector_size__),
567  it's only available in C++ and uses normal bool conversions (that is, != 0).
568  If it's an extension (OpenCL) vector, it's only available in C and OpenCL C.
569  And it selects base on signedness of the condition operands (OpenCL v1.1 s6.3.9).
570.. [#] Clang does not allow the address of an element to be taken while GCC
571   allows this. This is intentional for vectors with a boolean element type and
572   not implemented otherwise.
573
574Vector Builtins
575---------------
576
577**Note: The implementation of vector builtins is work-in-progress and incomplete.**
578
579In addition to the operators mentioned above, Clang provides a set of builtins
580to perform additional operations on certain scalar and vector types.
581
582Let ``T`` be one of the following types:
583
584* an integer type (as in C2x 6.2.5p19), but excluding enumerated types and _Bool
585* the standard floating types float or double
586* a half-precision floating point type, if one is supported on the target
587* a vector type.
588
589For scalar types, consider the operation applied to a vector with a single element.
590
591*Elementwise Builtins*
592
593Each builtin returns a vector equivalent to applying the specified operation
594elementwise to the input.
595
596Unless specified otherwise operation(±0) = ±0 and operation(±infinity) = ±infinity
597
598=========================================== ================================================================ =========================================
599         Name                                Operation                                                        Supported element types
600=========================================== ================================================================ =========================================
601 T __builtin_elementwise_abs(T x)            return the absolute value of a number x; the absolute value of   signed integer and floating point types
602                                             the most negative integer remains the most negative integer
603 T __builtin_elementwise_ceil(T x)           return the smallest integral value greater than or equal to x    floating point types
604 T __builtin_elementwise_floor(T x)          return the largest integral value less than or equal to x        floating point types
605 T __builtin_elementwise_roundeven(T x)      round x to the nearest integer value in floating point format,   floating point types
606                                             rounding halfway cases to even (that is, to the nearest value
607                                             that is an even integer), regardless of the current rounding
608                                             direction.
609 T__builtin_elementwise_trunc(T x)           return the integral value nearest to but no larger in            floating point types
610                                             magnitude than x
611 T __builtin_elementwise_max(T x, T y)       return x or y, whichever is larger                               integer and floating point types
612 T __builtin_elementwise_min(T x, T y)       return x or y, whichever is smaller                              integer and floating point types
613 T __builtin_elementwise_add_sat(T x, T y)   return the sum of x and y, clamped to the range of               integer types
614                                             representable values for the signed/unsigned integer type.
615 T __builtin_elementwise_sub_sat(T x, T y)   return the difference of x and y, clamped to the range of        integer types
616                                             representable values for the signed/unsigned integer type.
617=========================================== ================================================================ =========================================
618
619
620*Reduction Builtins*
621
622Each builtin returns a scalar equivalent to applying the specified
623operation(x, y) as recursive even-odd pairwise reduction to all vector
624elements. ``operation(x, y)`` is repeatedly applied to each non-overlapping
625even-odd element pair with indices ``i * 2`` and ``i * 2 + 1`` with
626``i in [0, Number of elements / 2)``. If the numbers of elements is not a
627power of 2, the vector is widened with neutral elements for the reduction
628at the end to the next power of 2.
629
630Example:
631
632.. code-block:: c++
633
634    __builtin_reduce_add([e3, e2, e1, e0]) = __builtin_reduced_add([e3 + e2, e1 + e0])
635                                           = (e3 + e2) + (e1 + e0)
636
637
638Let ``VT`` be a vector type and ``ET`` the element type of ``VT``.
639
640======================================= ================================================================ ==================================
641         Name                            Operation                                                        Supported element types
642======================================= ================================================================ ==================================
643 ET __builtin_reduce_max(VT a)           return x or y, whichever is larger; If exactly one argument is   integer and floating point types
644                                         a NaN, return the other argument. If both arguments are NaNs,
645                                         fmax() return a NaN.
646 ET __builtin_reduce_min(VT a)           return x or y, whichever is smaller; If exactly one argument     integer and floating point types
647                                         is a NaN, return the other argument. If both arguments are
648                                         NaNs, fmax() return a NaN.
649 ET __builtin_reduce_add(VT a)           \+                                                               integer and floating point types
650 ET __builtin_reduce_mul(VT a)           \*                                                               integer and floating point types
651 ET __builtin_reduce_and(VT a)           &                                                                integer types
652 ET __builtin_reduce_or(VT a)            \|                                                               integer types
653 ET __builtin_reduce_xor(VT a)           ^                                                                integer types
654======================================= ================================================================ ==================================
655
656Matrix Types
657============
658
659Clang provides an extension for matrix types, which is currently being
660implemented. See :ref:`the draft specification <matrixtypes>` for more details.
661
662For example, the code below uses the matrix types extension to multiply two 4x4
663float matrices and add the result to a third 4x4 matrix.
664
665.. code-block:: c++
666
667  typedef float m4x4_t __attribute__((matrix_type(4, 4)));
668
669  m4x4_t f(m4x4_t a, m4x4_t b, m4x4_t c) {
670    return a + b * c;
671  }
672
673The matrix type extension also supports operations on a matrix and a scalar.
674
675.. code-block:: c++
676
677  typedef float m4x4_t __attribute__((matrix_type(4, 4)));
678
679  m4x4_t f(m4x4_t a) {
680    return (a + 23) * 12;
681  }
682
683The matrix type extension supports division on a matrix and a scalar but not on a matrix and a matrix.
684
685.. code-block:: c++
686
687  typedef float m4x4_t __attribute__((matrix_type(4, 4)));
688
689  m4x4_t f(m4x4_t a) {
690    a = a / 3.0;
691    return a;
692  }
693
694The matrix type extension supports compound assignments for addition, subtraction, and multiplication on matrices
695and on a matrix and a scalar, provided their types are consistent.
696
697.. code-block:: c++
698
699  typedef float m4x4_t __attribute__((matrix_type(4, 4)));
700
701  m4x4_t f(m4x4_t a, m4x4_t b) {
702    a += b;
703    a -= b;
704    a *= b;
705    a += 23;
706    a -= 12;
707    return a;
708  }
709
710The matrix type extension supports explicit casts. Implicit type conversion between matrix types is not allowed.
711
712.. code-block:: c++
713
714  typedef int ix5x5 __attribute__((matrix_type(5, 5)));
715  typedef float fx5x5 __attribute__((matrix_type(5, 5)));
716
717  fx5x5 f1(ix5x5 i, fx5x5 f) {
718    return (fx5x5) i;
719  }
720
721
722  template <typename X>
723  using matrix_4_4 = X __attribute__((matrix_type(4, 4)));
724
725  void f2() {
726    matrix_5_5<double> d;
727    matrix_5_5<int> i;
728    i = (matrix_5_5<int>)d;
729    i = static_cast<matrix_5_5<int>>(d);
730  }
731
732Half-Precision Floating Point
733=============================
734
735Clang supports three half-precision (16-bit) floating point types: ``__fp16``,
736``_Float16`` and ``__bf16``.  These types are supported in all language modes.
737
738``__fp16`` is supported on every target, as it is purely a storage format; see below.
739``_Float16`` is currently only supported on the following targets, with further
740targets pending ABI standardization:
741
742* 32-bit ARM
743* 64-bit ARM (AArch64)
744* AMDGPU
745* SPIR
746* X86 (see below)
747
748On X86 targets, ``_Float16`` is supported as long as SSE2 is available, which
749includes all 64-bit and all recent 32-bit processors. When the target supports
750AVX512-FP16, ``_Float16`` arithmetic is performed using that native support.
751Otherwise, ``_Float16`` arithmetic is performed by promoting to ``float``,
752performing the operation, and then truncating to ``_Float16``.
753
754``_Float16`` will be supported on more targets as they define ABIs for it.
755
756``__bf16`` is purely a storage format; it is currently only supported on the following targets:
757* 32-bit ARM
758* 64-bit ARM (AArch64)
759
760The ``__bf16`` type is only available when supported in hardware.
761
762``__fp16`` is a storage and interchange format only.  This means that values of
763``__fp16`` are immediately promoted to (at least) ``float`` when used in arithmetic
764operations, so that e.g. the result of adding two ``__fp16`` values has type ``float``.
765The behavior of ``__fp16`` is specified by the ARM C Language Extensions (`ACLE <http://infocenter.arm.com/help/topic/com.arm.doc.ihi0053d/IHI0053D_acle_2_1.pdf>`_).
766Clang uses the ``binary16`` format from IEEE 754-2008 for ``__fp16``, not the ARM
767alternative format.
768
769``_Float16`` is an interchange floating-point type.  This means that, just like arithmetic on
770``float`` or ``double``, arithmetic on ``_Float16`` operands is formally performed in the
771``_Float16`` type, so that e.g. the result of adding two ``_Float16`` values has type
772``_Float16``.  The behavior of ``_Float16`` is specified by ISO/IEC TS 18661-3:2015
773("Floating-point extensions for C").  As with ``__fp16``, Clang uses the ``binary16``
774format from IEEE 754-2008 for ``_Float16``.
775
776``_Float16`` arithmetic will be performed using native half-precision support
777when available on the target (e.g. on ARMv8.2a); otherwise it will be performed
778at a higher precision (currently always ``float``) and then truncated down to
779``_Float16``.  Note that C and C++ allow intermediate floating-point operands
780of an expression to be computed with greater precision than is expressible in
781their type, so Clang may avoid intermediate truncations in certain cases; this may
782lead to results that are inconsistent with native arithmetic.
783
784It is recommended that portable code use ``_Float16`` instead of ``__fp16``,
785as it has been defined by the C standards committee and has behavior that is
786more familiar to most programmers.
787
788Because ``__fp16`` operands are always immediately promoted to ``float``, the
789common real type of ``__fp16`` and ``_Float16`` for the purposes of the usual
790arithmetic conversions is ``float``.
791
792A literal can be given ``_Float16`` type using the suffix ``f16``. For example,
793``3.14f16``.
794
795Because default argument promotion only applies to the standard floating-point
796types, ``_Float16`` values are not promoted to ``double`` when passed as variadic
797or untyped arguments.  As a consequence, some caution must be taken when using
798certain library facilities with ``_Float16``; for example, there is no ``printf`` format
799specifier for ``_Float16``, and (unlike ``float``) it will not be implicitly promoted to
800``double`` when passed to ``printf``, so the programmer must explicitly cast it to
801``double`` before using it with an ``%f`` or similar specifier.
802
803Messages on ``deprecated`` and ``unavailable`` Attributes
804=========================================================
805
806An optional string message can be added to the ``deprecated`` and
807``unavailable`` attributes.  For example:
808
809.. code-block:: c++
810
811  void explode(void) __attribute__((deprecated("extremely unsafe, use 'combust' instead!!!")));
812
813If the deprecated or unavailable declaration is used, the message will be
814incorporated into the appropriate diagnostic:
815
816.. code-block:: none
817
818  harmless.c:4:3: warning: 'explode' is deprecated: extremely unsafe, use 'combust' instead!!!
819        [-Wdeprecated-declarations]
820    explode();
821    ^
822
823Query for this feature with
824``__has_extension(attribute_deprecated_with_message)`` and
825``__has_extension(attribute_unavailable_with_message)``.
826
827Attributes on Enumerators
828=========================
829
830Clang allows attributes to be written on individual enumerators.  This allows
831enumerators to be deprecated, made unavailable, etc.  The attribute must appear
832after the enumerator name and before any initializer, like so:
833
834.. code-block:: c++
835
836  enum OperationMode {
837    OM_Invalid,
838    OM_Normal,
839    OM_Terrified __attribute__((deprecated)),
840    OM_AbortOnError __attribute__((deprecated)) = 4
841  };
842
843Attributes on the ``enum`` declaration do not apply to individual enumerators.
844
845Query for this feature with ``__has_extension(enumerator_attributes)``.
846
847C++11 Attributes on using-declarations
848======================================
849
850Clang allows C++-style ``[[]]`` attributes to be written on using-declarations.
851For instance:
852
853.. code-block:: c++
854
855  [[clang::using_if_exists]] using foo::bar;
856  using foo::baz [[clang::using_if_exists]];
857
858You can test for support for this extension with
859``__has_extension(cxx_attributes_on_using_declarations)``.
860
861'User-Specified' System Frameworks
862==================================
863
864Clang provides a mechanism by which frameworks can be built in such a way that
865they will always be treated as being "system frameworks", even if they are not
866present in a system framework directory.  This can be useful to system
867framework developers who want to be able to test building other applications
868with development builds of their framework, including the manner in which the
869compiler changes warning behavior for system headers.
870
871Framework developers can opt-in to this mechanism by creating a
872"``.system_framework``" file at the top-level of their framework.  That is, the
873framework should have contents like:
874
875.. code-block:: none
876
877  .../TestFramework.framework
878  .../TestFramework.framework/.system_framework
879  .../TestFramework.framework/Headers
880  .../TestFramework.framework/Headers/TestFramework.h
881  ...
882
883Clang will treat the presence of this file as an indicator that the framework
884should be treated as a system framework, regardless of how it was found in the
885framework search path.  For consistency, we recommend that such files never be
886included in installed versions of the framework.
887
888Checks for Standard Language Features
889=====================================
890
891The ``__has_feature`` macro can be used to query if certain standard language
892features are enabled.  The ``__has_extension`` macro can be used to query if
893language features are available as an extension when compiling for a standard
894which does not provide them.  The features which can be tested are listed here.
895
896Since Clang 3.4, the C++ SD-6 feature test macros are also supported.
897These are macros with names of the form ``__cpp_<feature_name>``, and are
898intended to be a portable way to query the supported features of the compiler.
899See `the C++ status page <https://clang.llvm.org/cxx_status.html#ts>`_ for
900information on the version of SD-6 supported by each Clang release, and the
901macros provided by that revision of the recommendations.
902
903C++98
904-----
905
906The features listed below are part of the C++98 standard.  These features are
907enabled by default when compiling C++ code.
908
909C++ exceptions
910^^^^^^^^^^^^^^
911
912Use ``__has_feature(cxx_exceptions)`` to determine if C++ exceptions have been
913enabled.  For example, compiling code with ``-fno-exceptions`` disables C++
914exceptions.
915
916C++ RTTI
917^^^^^^^^
918
919Use ``__has_feature(cxx_rtti)`` to determine if C++ RTTI has been enabled.  For
920example, compiling code with ``-fno-rtti`` disables the use of RTTI.
921
922C++11
923-----
924
925The features listed below are part of the C++11 standard.  As a result, all
926these features are enabled with the ``-std=c++11`` or ``-std=gnu++11`` option
927when compiling C++ code.
928
929C++11 SFINAE includes access control
930^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
931
932Use ``__has_feature(cxx_access_control_sfinae)`` or
933``__has_extension(cxx_access_control_sfinae)`` to determine whether
934access-control errors (e.g., calling a private constructor) are considered to
935be template argument deduction errors (aka SFINAE errors), per `C++ DR1170
936<http://www.open-std.org/jtc1/sc22/wg21/docs/cwg_defects.html#1170>`_.
937
938C++11 alias templates
939^^^^^^^^^^^^^^^^^^^^^
940
941Use ``__has_feature(cxx_alias_templates)`` or
942``__has_extension(cxx_alias_templates)`` to determine if support for C++11's
943alias declarations and alias templates is enabled.
944
945C++11 alignment specifiers
946^^^^^^^^^^^^^^^^^^^^^^^^^^
947
948Use ``__has_feature(cxx_alignas)`` or ``__has_extension(cxx_alignas)`` to
949determine if support for alignment specifiers using ``alignas`` is enabled.
950
951Use ``__has_feature(cxx_alignof)`` or ``__has_extension(cxx_alignof)`` to
952determine if support for the ``alignof`` keyword is enabled.
953
954C++11 attributes
955^^^^^^^^^^^^^^^^
956
957Use ``__has_feature(cxx_attributes)`` or ``__has_extension(cxx_attributes)`` to
958determine if support for attribute parsing with C++11's square bracket notation
959is enabled.
960
961C++11 generalized constant expressions
962^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
963
964Use ``__has_feature(cxx_constexpr)`` to determine if support for generalized
965constant expressions (e.g., ``constexpr``) is enabled.
966
967C++11 ``decltype()``
968^^^^^^^^^^^^^^^^^^^^
969
970Use ``__has_feature(cxx_decltype)`` or ``__has_extension(cxx_decltype)`` to
971determine if support for the ``decltype()`` specifier is enabled.  C++11's
972``decltype`` does not require type-completeness of a function call expression.
973Use ``__has_feature(cxx_decltype_incomplete_return_types)`` or
974``__has_extension(cxx_decltype_incomplete_return_types)`` to determine if
975support for this feature is enabled.
976
977C++11 default template arguments in function templates
978^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
979
980Use ``__has_feature(cxx_default_function_template_args)`` or
981``__has_extension(cxx_default_function_template_args)`` to determine if support
982for default template arguments in function templates is enabled.
983
984C++11 ``default``\ ed functions
985^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
986
987Use ``__has_feature(cxx_defaulted_functions)`` or
988``__has_extension(cxx_defaulted_functions)`` to determine if support for
989defaulted function definitions (with ``= default``) is enabled.
990
991C++11 delegating constructors
992^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
993
994Use ``__has_feature(cxx_delegating_constructors)`` to determine if support for
995delegating constructors is enabled.
996
997C++11 ``deleted`` functions
998^^^^^^^^^^^^^^^^^^^^^^^^^^^
999
1000Use ``__has_feature(cxx_deleted_functions)`` or
1001``__has_extension(cxx_deleted_functions)`` to determine if support for deleted
1002function definitions (with ``= delete``) is enabled.
1003
1004C++11 explicit conversion functions
1005^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1006
1007Use ``__has_feature(cxx_explicit_conversions)`` to determine if support for
1008``explicit`` conversion functions is enabled.
1009
1010C++11 generalized initializers
1011^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1012
1013Use ``__has_feature(cxx_generalized_initializers)`` to determine if support for
1014generalized initializers (using braced lists and ``std::initializer_list``) is
1015enabled.
1016
1017C++11 implicit move constructors/assignment operators
1018^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1019
1020Use ``__has_feature(cxx_implicit_moves)`` to determine if Clang will implicitly
1021generate move constructors and move assignment operators where needed.
1022
1023C++11 inheriting constructors
1024^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1025
1026Use ``__has_feature(cxx_inheriting_constructors)`` to determine if support for
1027inheriting constructors is enabled.
1028
1029C++11 inline namespaces
1030^^^^^^^^^^^^^^^^^^^^^^^
1031
1032Use ``__has_feature(cxx_inline_namespaces)`` or
1033``__has_extension(cxx_inline_namespaces)`` to determine if support for inline
1034namespaces is enabled.
1035
1036C++11 lambdas
1037^^^^^^^^^^^^^
1038
1039Use ``__has_feature(cxx_lambdas)`` or ``__has_extension(cxx_lambdas)`` to
1040determine if support for lambdas is enabled.
1041
1042C++11 local and unnamed types as template arguments
1043^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1044
1045Use ``__has_feature(cxx_local_type_template_args)`` or
1046``__has_extension(cxx_local_type_template_args)`` to determine if support for
1047local and unnamed types as template arguments is enabled.
1048
1049C++11 noexcept
1050^^^^^^^^^^^^^^
1051
1052Use ``__has_feature(cxx_noexcept)`` or ``__has_extension(cxx_noexcept)`` to
1053determine if support for noexcept exception specifications is enabled.
1054
1055C++11 in-class non-static data member initialization
1056^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1057
1058Use ``__has_feature(cxx_nonstatic_member_init)`` to determine whether in-class
1059initialization of non-static data members is enabled.
1060
1061C++11 ``nullptr``
1062^^^^^^^^^^^^^^^^^
1063
1064Use ``__has_feature(cxx_nullptr)`` or ``__has_extension(cxx_nullptr)`` to
1065determine if support for ``nullptr`` is enabled.
1066
1067C++11 ``override control``
1068^^^^^^^^^^^^^^^^^^^^^^^^^^
1069
1070Use ``__has_feature(cxx_override_control)`` or
1071``__has_extension(cxx_override_control)`` to determine if support for the
1072override control keywords is enabled.
1073
1074C++11 reference-qualified functions
1075^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1076
1077Use ``__has_feature(cxx_reference_qualified_functions)`` or
1078``__has_extension(cxx_reference_qualified_functions)`` to determine if support
1079for reference-qualified functions (e.g., member functions with ``&`` or ``&&``
1080applied to ``*this``) is enabled.
1081
1082C++11 range-based ``for`` loop
1083^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1084
1085Use ``__has_feature(cxx_range_for)`` or ``__has_extension(cxx_range_for)`` to
1086determine if support for the range-based for loop is enabled.
1087
1088C++11 raw string literals
1089^^^^^^^^^^^^^^^^^^^^^^^^^
1090
1091Use ``__has_feature(cxx_raw_string_literals)`` to determine if support for raw
1092string literals (e.g., ``R"x(foo\bar)x"``) is enabled.
1093
1094C++11 rvalue references
1095^^^^^^^^^^^^^^^^^^^^^^^
1096
1097Use ``__has_feature(cxx_rvalue_references)`` or
1098``__has_extension(cxx_rvalue_references)`` to determine if support for rvalue
1099references is enabled.
1100
1101C++11 ``static_assert()``
1102^^^^^^^^^^^^^^^^^^^^^^^^^
1103
1104Use ``__has_feature(cxx_static_assert)`` or
1105``__has_extension(cxx_static_assert)`` to determine if support for compile-time
1106assertions using ``static_assert`` is enabled.
1107
1108C++11 ``thread_local``
1109^^^^^^^^^^^^^^^^^^^^^^
1110
1111Use ``__has_feature(cxx_thread_local)`` to determine if support for
1112``thread_local`` variables is enabled.
1113
1114C++11 type inference
1115^^^^^^^^^^^^^^^^^^^^
1116
1117Use ``__has_feature(cxx_auto_type)`` or ``__has_extension(cxx_auto_type)`` to
1118determine C++11 type inference is supported using the ``auto`` specifier.  If
1119this is disabled, ``auto`` will instead be a storage class specifier, as in C
1120or C++98.
1121
1122C++11 strongly typed enumerations
1123^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1124
1125Use ``__has_feature(cxx_strong_enums)`` or
1126``__has_extension(cxx_strong_enums)`` to determine if support for strongly
1127typed, scoped enumerations is enabled.
1128
1129C++11 trailing return type
1130^^^^^^^^^^^^^^^^^^^^^^^^^^
1131
1132Use ``__has_feature(cxx_trailing_return)`` or
1133``__has_extension(cxx_trailing_return)`` to determine if support for the
1134alternate function declaration syntax with trailing return type is enabled.
1135
1136C++11 Unicode string literals
1137^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1138
1139Use ``__has_feature(cxx_unicode_literals)`` to determine if support for Unicode
1140string literals is enabled.
1141
1142C++11 unrestricted unions
1143^^^^^^^^^^^^^^^^^^^^^^^^^
1144
1145Use ``__has_feature(cxx_unrestricted_unions)`` to determine if support for
1146unrestricted unions is enabled.
1147
1148C++11 user-defined literals
1149^^^^^^^^^^^^^^^^^^^^^^^^^^^
1150
1151Use ``__has_feature(cxx_user_literals)`` to determine if support for
1152user-defined literals is enabled.
1153
1154C++11 variadic templates
1155^^^^^^^^^^^^^^^^^^^^^^^^
1156
1157Use ``__has_feature(cxx_variadic_templates)`` or
1158``__has_extension(cxx_variadic_templates)`` to determine if support for
1159variadic templates is enabled.
1160
1161C++14
1162-----
1163
1164The features listed below are part of the C++14 standard.  As a result, all
1165these features are enabled with the ``-std=C++14`` or ``-std=gnu++14`` option
1166when compiling C++ code.
1167
1168C++14 binary literals
1169^^^^^^^^^^^^^^^^^^^^^
1170
1171Use ``__has_feature(cxx_binary_literals)`` or
1172``__has_extension(cxx_binary_literals)`` to determine whether
1173binary literals (for instance, ``0b10010``) are recognized. Clang supports this
1174feature as an extension in all language modes.
1175
1176C++14 contextual conversions
1177^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1178
1179Use ``__has_feature(cxx_contextual_conversions)`` or
1180``__has_extension(cxx_contextual_conversions)`` to determine if the C++14 rules
1181are used when performing an implicit conversion for an array bound in a
1182*new-expression*, the operand of a *delete-expression*, an integral constant
1183expression, or a condition in a ``switch`` statement.
1184
1185C++14 decltype(auto)
1186^^^^^^^^^^^^^^^^^^^^
1187
1188Use ``__has_feature(cxx_decltype_auto)`` or
1189``__has_extension(cxx_decltype_auto)`` to determine if support
1190for the ``decltype(auto)`` placeholder type is enabled.
1191
1192C++14 default initializers for aggregates
1193^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1194
1195Use ``__has_feature(cxx_aggregate_nsdmi)`` or
1196``__has_extension(cxx_aggregate_nsdmi)`` to determine if support
1197for default initializers in aggregate members is enabled.
1198
1199C++14 digit separators
1200^^^^^^^^^^^^^^^^^^^^^^
1201
1202Use ``__cpp_digit_separators`` to determine if support for digit separators
1203using single quotes (for instance, ``10'000``) is enabled. At this time, there
1204is no corresponding ``__has_feature`` name
1205
1206C++14 generalized lambda capture
1207^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1208
1209Use ``__has_feature(cxx_init_captures)`` or
1210``__has_extension(cxx_init_captures)`` to determine if support for
1211lambda captures with explicit initializers is enabled
1212(for instance, ``[n(0)] { return ++n; }``).
1213
1214C++14 generic lambdas
1215^^^^^^^^^^^^^^^^^^^^^
1216
1217Use ``__has_feature(cxx_generic_lambdas)`` or
1218``__has_extension(cxx_generic_lambdas)`` to determine if support for generic
1219(polymorphic) lambdas is enabled
1220(for instance, ``[] (auto x) { return x + 1; }``).
1221
1222C++14 relaxed constexpr
1223^^^^^^^^^^^^^^^^^^^^^^^
1224
1225Use ``__has_feature(cxx_relaxed_constexpr)`` or
1226``__has_extension(cxx_relaxed_constexpr)`` to determine if variable
1227declarations, local variable modification, and control flow constructs
1228are permitted in ``constexpr`` functions.
1229
1230C++14 return type deduction
1231^^^^^^^^^^^^^^^^^^^^^^^^^^^
1232
1233Use ``__has_feature(cxx_return_type_deduction)`` or
1234``__has_extension(cxx_return_type_deduction)`` to determine if support
1235for return type deduction for functions (using ``auto`` as a return type)
1236is enabled.
1237
1238C++14 runtime-sized arrays
1239^^^^^^^^^^^^^^^^^^^^^^^^^^
1240
1241Use ``__has_feature(cxx_runtime_array)`` or
1242``__has_extension(cxx_runtime_array)`` to determine if support
1243for arrays of runtime bound (a restricted form of variable-length arrays)
1244is enabled.
1245Clang's implementation of this feature is incomplete.
1246
1247C++14 variable templates
1248^^^^^^^^^^^^^^^^^^^^^^^^
1249
1250Use ``__has_feature(cxx_variable_templates)`` or
1251``__has_extension(cxx_variable_templates)`` to determine if support for
1252templated variable declarations is enabled.
1253
1254C11
1255---
1256
1257The features listed below are part of the C11 standard.  As a result, all these
1258features are enabled with the ``-std=c11`` or ``-std=gnu11`` option when
1259compiling C code.  Additionally, because these features are all
1260backward-compatible, they are available as extensions in all language modes.
1261
1262C11 alignment specifiers
1263^^^^^^^^^^^^^^^^^^^^^^^^
1264
1265Use ``__has_feature(c_alignas)`` or ``__has_extension(c_alignas)`` to determine
1266if support for alignment specifiers using ``_Alignas`` is enabled.
1267
1268Use ``__has_feature(c_alignof)`` or ``__has_extension(c_alignof)`` to determine
1269if support for the ``_Alignof`` keyword is enabled.
1270
1271C11 atomic operations
1272^^^^^^^^^^^^^^^^^^^^^
1273
1274Use ``__has_feature(c_atomic)`` or ``__has_extension(c_atomic)`` to determine
1275if support for atomic types using ``_Atomic`` is enabled.  Clang also provides
1276:ref:`a set of builtins <langext-__c11_atomic>` which can be used to implement
1277the ``<stdatomic.h>`` operations on ``_Atomic`` types. Use
1278``__has_include(<stdatomic.h>)`` to determine if C11's ``<stdatomic.h>`` header
1279is available.
1280
1281Clang will use the system's ``<stdatomic.h>`` header when one is available, and
1282will otherwise use its own. When using its own, implementations of the atomic
1283operations are provided as macros. In the cases where C11 also requires a real
1284function, this header provides only the declaration of that function (along
1285with a shadowing macro implementation), and you must link to a library which
1286provides a definition of the function if you use it instead of the macro.
1287
1288C11 generic selections
1289^^^^^^^^^^^^^^^^^^^^^^
1290
1291Use ``__has_feature(c_generic_selections)`` or
1292``__has_extension(c_generic_selections)`` to determine if support for generic
1293selections is enabled.
1294
1295As an extension, the C11 generic selection expression is available in all
1296languages supported by Clang.  The syntax is the same as that given in the C11
1297standard.
1298
1299In C, type compatibility is decided according to the rules given in the
1300appropriate standard, but in C++, which lacks the type compatibility rules used
1301in C, types are considered compatible only if they are equivalent.
1302
1303C11 ``_Static_assert()``
1304^^^^^^^^^^^^^^^^^^^^^^^^
1305
1306Use ``__has_feature(c_static_assert)`` or ``__has_extension(c_static_assert)``
1307to determine if support for compile-time assertions using ``_Static_assert`` is
1308enabled.
1309
1310C11 ``_Thread_local``
1311^^^^^^^^^^^^^^^^^^^^^
1312
1313Use ``__has_feature(c_thread_local)`` or ``__has_extension(c_thread_local)``
1314to determine if support for ``_Thread_local`` variables is enabled.
1315
1316Modules
1317-------
1318
1319Use ``__has_feature(modules)`` to determine if Modules have been enabled.
1320For example, compiling code with ``-fmodules`` enables the use of Modules.
1321
1322More information could be found `here <https://clang.llvm.org/docs/Modules.html>`_.
1323
1324Type Trait Primitives
1325=====================
1326
1327Type trait primitives are special builtin constant expressions that can be used
1328by the standard C++ library to facilitate or simplify the implementation of
1329user-facing type traits in the <type_traits> header.
1330
1331They are not intended to be used directly by user code because they are
1332implementation-defined and subject to change -- as such they're tied closely to
1333the supported set of system headers, currently:
1334
1335* LLVM's own libc++
1336* GNU libstdc++
1337* The Microsoft standard C++ library
1338
1339Clang supports the `GNU C++ type traits
1340<https://gcc.gnu.org/onlinedocs/gcc/Type-Traits.html>`_ and a subset of the
1341`Microsoft Visual C++ type traits
1342<https://msdn.microsoft.com/en-us/library/ms177194(v=VS.100).aspx>`_,
1343as well as nearly all of the
1344`Embarcadero C++ type traits
1345<http://docwiki.embarcadero.com/RADStudio/Rio/en/Type_Trait_Functions_(C%2B%2B11)_Index>`_.
1346
1347The following type trait primitives are supported by Clang. Those traits marked
1348(C++) provide implementations for type traits specified by the C++ standard;
1349``__X(...)`` has the same semantics and constraints as the corresponding
1350``std::X_t<...>`` or ``std::X_v<...>`` type trait.
1351
1352* ``__array_rank(type)`` (Embarcadero):
1353  Returns the number of levels of array in the type ``type``:
1354  ``0`` if ``type`` is not an array type, and
1355  ``__array_rank(element) + 1`` if ``type`` is an array of ``element``.
1356* ``__array_extent(type, dim)`` (Embarcadero):
1357  The ``dim``'th array bound in the type ``type``, or ``0`` if
1358  ``dim >= __array_rank(type)``.
1359* ``__has_nothrow_assign`` (GNU, Microsoft, Embarcadero):
1360  Deprecated, use ``__is_nothrow_assignable`` instead.
1361* ``__has_nothrow_move_assign`` (GNU, Microsoft):
1362  Deprecated, use ``__is_nothrow_assignable`` instead.
1363* ``__has_nothrow_copy`` (GNU, Microsoft):
1364  Deprecated, use ``__is_nothrow_constructible`` instead.
1365* ``__has_nothrow_constructor`` (GNU, Microsoft):
1366  Deprecated, use ``__is_nothrow_constructible`` instead.
1367* ``__has_trivial_assign`` (GNU, Microsoft, Embarcadero):
1368  Deprecated, use ``__is_trivially_assignable`` instead.
1369* ``__has_trivial_move_assign`` (GNU, Microsoft):
1370  Deprecated, use ``__is_trivially_assignable`` instead.
1371* ``__has_trivial_copy`` (GNU, Microsoft):
1372  Deprecated, use ``__is_trivially_constructible`` instead.
1373* ``__has_trivial_constructor`` (GNU, Microsoft):
1374  Deprecated, use ``__is_trivially_constructible`` instead.
1375* ``__has_trivial_move_constructor`` (GNU, Microsoft):
1376  Deprecated, use ``__is_trivially_constructible`` instead.
1377* ``__has_trivial_destructor`` (GNU, Microsoft, Embarcadero):
1378  Deprecated, use ``__is_trivially_destructible`` instead.
1379* ``__has_unique_object_representations`` (C++, GNU)
1380* ``__has_virtual_destructor`` (C++, GNU, Microsoft, Embarcadero)
1381* ``__is_abstract`` (C++, GNU, Microsoft, Embarcadero)
1382* ``__is_aggregate`` (C++, GNU, Microsoft)
1383* ``__is_arithmetic`` (C++, Embarcadero)
1384* ``__is_array`` (C++, Embarcadero)
1385* ``__is_assignable`` (C++, MSVC 2015)
1386* ``__is_base_of`` (C++, GNU, Microsoft, Embarcadero)
1387* ``__is_class`` (C++, GNU, Microsoft, Embarcadero)
1388* ``__is_complete_type(type)`` (Embarcadero):
1389  Return ``true`` if ``type`` is a complete type.
1390  Warning: this trait is dangerous because it can return different values at
1391  different points in the same program.
1392* ``__is_compound`` (C++, Embarcadero)
1393* ``__is_const`` (C++, Embarcadero)
1394* ``__is_constructible`` (C++, MSVC 2013)
1395* ``__is_convertible`` (C++, Embarcadero)
1396* ``__is_convertible_to`` (Microsoft):
1397  Synonym for ``__is_convertible``.
1398* ``__is_destructible`` (C++, MSVC 2013):
1399  Only available in ``-fms-extensions`` mode.
1400* ``__is_empty`` (C++, GNU, Microsoft, Embarcadero)
1401* ``__is_enum`` (C++, GNU, Microsoft, Embarcadero)
1402* ``__is_final`` (C++, GNU, Microsoft)
1403* ``__is_floating_point`` (C++, Embarcadero)
1404* ``__is_function`` (C++, Embarcadero)
1405* ``__is_fundamental`` (C++, Embarcadero)
1406* ``__is_integral`` (C++, Embarcadero)
1407* ``__is_interface_class`` (Microsoft):
1408  Returns ``false``, even for types defined with ``__interface``.
1409* ``__is_literal`` (Clang):
1410  Synonym for ``__is_literal_type``.
1411* ``__is_literal_type`` (C++, GNU, Microsoft):
1412  Note, the corresponding standard trait was deprecated in C++17
1413  and removed in C++20.
1414* ``__is_lvalue_reference`` (C++, Embarcadero)
1415* ``__is_member_object_pointer`` (C++, Embarcadero)
1416* ``__is_member_function_pointer`` (C++, Embarcadero)
1417* ``__is_member_pointer`` (C++, Embarcadero)
1418* ``__is_nothrow_assignable`` (C++, MSVC 2013)
1419* ``__is_nothrow_constructible`` (C++, MSVC 2013)
1420* ``__is_nothrow_destructible`` (C++, MSVC 2013)
1421  Only available in ``-fms-extensions`` mode.
1422* ``__is_object`` (C++, Embarcadero)
1423* ``__is_pod`` (C++, GNU, Microsoft, Embarcadero):
1424  Note, the corresponding standard trait was deprecated in C++20.
1425* ``__is_pointer`` (C++, Embarcadero)
1426* ``__is_polymorphic`` (C++, GNU, Microsoft, Embarcadero)
1427* ``__is_reference`` (C++, Embarcadero)
1428* ``__is_rvalue_reference`` (C++, Embarcadero)
1429* ``__is_same`` (C++, Embarcadero)
1430* ``__is_same_as`` (GCC): Synonym for ``__is_same``.
1431* ``__is_scalar`` (C++, Embarcadero)
1432* ``__is_sealed`` (Microsoft):
1433  Synonym for ``__is_final``.
1434* ``__is_signed`` (C++, Embarcadero):
1435  Returns false for enumeration types, and returns true for floating-point
1436  types. Note, before Clang 10, returned true for enumeration types if the
1437  underlying type was signed, and returned false for floating-point types.
1438* ``__is_standard_layout`` (C++, GNU, Microsoft, Embarcadero)
1439* ``__is_trivial`` (C++, GNU, Microsoft, Embarcadero)
1440* ``__is_trivially_assignable`` (C++, GNU, Microsoft)
1441* ``__is_trivially_constructible`` (C++, GNU, Microsoft)
1442* ``__is_trivially_copyable`` (C++, GNU, Microsoft)
1443* ``__is_trivially_destructible`` (C++, MSVC 2013)
1444* ``__is_trivially_relocatable`` (Clang): Returns true if moving an object
1445  of the given type, and then destroying the source object, is known to be
1446  functionally equivalent to copying the underlying bytes and then dropping the
1447  source object on the floor. This is true of trivial types and types which
1448  were made trivially relocatable via the ``clang::trivial_abi`` attribute.
1449* ``__is_union`` (C++, GNU, Microsoft, Embarcadero)
1450* ``__is_unsigned`` (C++, Embarcadero):
1451  Returns false for enumeration types. Note, before Clang 13, returned true for
1452  enumeration types if the underlying type was unsigned.
1453* ``__is_void`` (C++, Embarcadero)
1454* ``__is_volatile`` (C++, Embarcadero)
1455* ``__reference_binds_to_temporary(T, U)`` (Clang):  Determines whether a
1456  reference of type ``T`` bound to an expression of type ``U`` would bind to a
1457  materialized temporary object. If ``T`` is not a reference type the result
1458  is false. Note this trait will also return false when the initialization of
1459  ``T`` from ``U`` is ill-formed.
1460* ``__underlying_type`` (C++, GNU, Microsoft)
1461
1462In addition, the following expression traits are supported:
1463
1464* ``__is_lvalue_expr(e)`` (Embarcadero):
1465  Returns true if ``e`` is an lvalue expression.
1466  Deprecated, use ``__is_lvalue_reference(decltype((e)))`` instead.
1467* ``__is_rvalue_expr(e)`` (Embarcadero):
1468  Returns true if ``e`` is a prvalue expression.
1469  Deprecated, use ``!__is_reference(decltype((e)))`` instead.
1470
1471There are multiple ways to detect support for a type trait ``__X`` in the
1472compiler, depending on the oldest version of Clang you wish to support.
1473
1474* From Clang 10 onwards, ``__has_builtin(__X)`` can be used.
1475* From Clang 6 onwards, ``!__is_identifier(__X)`` can be used.
1476* From Clang 3 onwards, ``__has_feature(X)`` can be used, but only supports
1477  the following traits:
1478
1479  * ``__has_nothrow_assign``
1480  * ``__has_nothrow_copy``
1481  * ``__has_nothrow_constructor``
1482  * ``__has_trivial_assign``
1483  * ``__has_trivial_copy``
1484  * ``__has_trivial_constructor``
1485  * ``__has_trivial_destructor``
1486  * ``__has_virtual_destructor``
1487  * ``__is_abstract``
1488  * ``__is_base_of``
1489  * ``__is_class``
1490  * ``__is_constructible``
1491  * ``__is_convertible_to``
1492  * ``__is_empty``
1493  * ``__is_enum``
1494  * ``__is_final``
1495  * ``__is_literal``
1496  * ``__is_standard_layout``
1497  * ``__is_pod``
1498  * ``__is_polymorphic``
1499  * ``__is_sealed``
1500  * ``__is_trivial``
1501  * ``__is_trivially_assignable``
1502  * ``__is_trivially_constructible``
1503  * ``__is_trivially_copyable``
1504  * ``__is_union``
1505  * ``__underlying_type``
1506
1507A simplistic usage example as might be seen in standard C++ headers follows:
1508
1509.. code-block:: c++
1510
1511  #if __has_builtin(__is_convertible_to)
1512  template<typename From, typename To>
1513  struct is_convertible_to {
1514    static const bool value = __is_convertible_to(From, To);
1515  };
1516  #else
1517  // Emulate type trait for compatibility with other compilers.
1518  #endif
1519
1520Blocks
1521======
1522
1523The syntax and high level language feature description is in
1524:doc:`BlockLanguageSpec<BlockLanguageSpec>`. Implementation and ABI details for
1525the clang implementation are in :doc:`Block-ABI-Apple<Block-ABI-Apple>`.
1526
1527Query for this feature with ``__has_extension(blocks)``.
1528
1529ASM Goto with Output Constraints
1530================================
1531
1532In addition to the functionality provided by `GCC's extended
1533assembly <https://gcc.gnu.org/onlinedocs/gcc/Extended-Asm.html>`_, clang
1534supports output constraints with the `goto` form.
1535
1536The goto form of GCC's extended assembly allows the programmer to branch to a C
1537label from within an inline assembly block. Clang extends this behavior by
1538allowing the programmer to use output constraints:
1539
1540.. code-block:: c++
1541
1542  int foo(int x) {
1543      int y;
1544      asm goto("# %0 %1 %l2" : "=r"(y) : "r"(x) : : err);
1545      return y;
1546    err:
1547      return -1;
1548  }
1549
1550It's important to note that outputs are valid only on the "fallthrough" branch.
1551Using outputs on an indirect branch may result in undefined behavior. For
1552example, in the function above, use of the value assigned to `y` in the `err`
1553block is undefined behavior.
1554
1555When using tied-outputs (i.e. outputs that are inputs and outputs, not just
1556outputs) with the `+r` constraint, there is a hidden input that's created
1557before the label, so numeric references to operands must account for that.
1558
1559.. code-block:: c++
1560
1561  int foo(int x) {
1562      // %0 and %1 both refer to x
1563      // %l2 refers to err
1564      asm goto("# %0 %1 %l2" : "+r"(x) : : : err);
1565      return x;
1566    err:
1567      return -1;
1568  }
1569
1570This was changed to match GCC in clang-13; for better portability, symbolic
1571references can be used instead of numeric references.
1572
1573.. code-block:: c++
1574
1575  int foo(int x) {
1576      asm goto("# %[x] %l[err]" : [x]"+r"(x) : : : err);
1577      return x;
1578    err:
1579      return -1;
1580  }
1581
1582Query for this feature with ``__has_extension(gnu_asm_goto_with_outputs)``.
1583
1584Objective-C Features
1585====================
1586
1587Related result types
1588--------------------
1589
1590According to Cocoa conventions, Objective-C methods with certain names
1591("``init``", "``alloc``", etc.) always return objects that are an instance of
1592the receiving class's type.  Such methods are said to have a "related result
1593type", meaning that a message send to one of these methods will have the same
1594static type as an instance of the receiver class.  For example, given the
1595following classes:
1596
1597.. code-block:: objc
1598
1599  @interface NSObject
1600  + (id)alloc;
1601  - (id)init;
1602  @end
1603
1604  @interface NSArray : NSObject
1605  @end
1606
1607and this common initialization pattern
1608
1609.. code-block:: objc
1610
1611  NSArray *array = [[NSArray alloc] init];
1612
1613the type of the expression ``[NSArray alloc]`` is ``NSArray*`` because
1614``alloc`` implicitly has a related result type.  Similarly, the type of the
1615expression ``[[NSArray alloc] init]`` is ``NSArray*``, since ``init`` has a
1616related result type and its receiver is known to have the type ``NSArray *``.
1617If neither ``alloc`` nor ``init`` had a related result type, the expressions
1618would have had type ``id``, as declared in the method signature.
1619
1620A method with a related result type can be declared by using the type
1621``instancetype`` as its result type.  ``instancetype`` is a contextual keyword
1622that is only permitted in the result type of an Objective-C method, e.g.
1623
1624.. code-block:: objc
1625
1626  @interface A
1627  + (instancetype)constructAnA;
1628  @end
1629
1630The related result type can also be inferred for some methods.  To determine
1631whether a method has an inferred related result type, the first word in the
1632camel-case selector (e.g., "``init``" in "``initWithObjects``") is considered,
1633and the method will have a related result type if its return type is compatible
1634with the type of its class and if:
1635
1636* the first word is "``alloc``" or "``new``", and the method is a class method,
1637  or
1638
1639* the first word is "``autorelease``", "``init``", "``retain``", or "``self``",
1640  and the method is an instance method.
1641
1642If a method with a related result type is overridden by a subclass method, the
1643subclass method must also return a type that is compatible with the subclass
1644type.  For example:
1645
1646.. code-block:: objc
1647
1648  @interface NSString : NSObject
1649  - (NSUnrelated *)init; // incorrect usage: NSUnrelated is not NSString or a superclass of NSString
1650  @end
1651
1652Related result types only affect the type of a message send or property access
1653via the given method.  In all other respects, a method with a related result
1654type is treated the same way as method that returns ``id``.
1655
1656Use ``__has_feature(objc_instancetype)`` to determine whether the
1657``instancetype`` contextual keyword is available.
1658
1659Automatic reference counting
1660----------------------------
1661
1662Clang provides support for :doc:`automated reference counting
1663<AutomaticReferenceCounting>` in Objective-C, which eliminates the need
1664for manual ``retain``/``release``/``autorelease`` message sends.  There are three
1665feature macros associated with automatic reference counting:
1666``__has_feature(objc_arc)`` indicates the availability of automated reference
1667counting in general, while ``__has_feature(objc_arc_weak)`` indicates that
1668automated reference counting also includes support for ``__weak`` pointers to
1669Objective-C objects. ``__has_feature(objc_arc_fields)`` indicates that C structs
1670are allowed to have fields that are pointers to Objective-C objects managed by
1671automatic reference counting.
1672
1673.. _objc-weak:
1674
1675Weak references
1676---------------
1677
1678Clang supports ARC-style weak and unsafe references in Objective-C even
1679outside of ARC mode.  Weak references must be explicitly enabled with
1680the ``-fobjc-weak`` option; use ``__has_feature((objc_arc_weak))``
1681to test whether they are enabled.  Unsafe references are enabled
1682unconditionally.  ARC-style weak and unsafe references cannot be used
1683when Objective-C garbage collection is enabled.
1684
1685Except as noted below, the language rules for the ``__weak`` and
1686``__unsafe_unretained`` qualifiers (and the ``weak`` and
1687``unsafe_unretained`` property attributes) are just as laid out
1688in the :doc:`ARC specification <AutomaticReferenceCounting>`.
1689In particular, note that some classes do not support forming weak
1690references to their instances, and note that special care must be
1691taken when storing weak references in memory where initialization
1692and deinitialization are outside the responsibility of the compiler
1693(such as in ``malloc``-ed memory).
1694
1695Loading from a ``__weak`` variable always implicitly retains the
1696loaded value.  In non-ARC modes, this retain is normally balanced
1697by an implicit autorelease.  This autorelease can be suppressed
1698by performing the load in the receiver position of a ``-retain``
1699message send (e.g. ``[weakReference retain]``); note that this performs
1700only a single retain (the retain done when primitively loading from
1701the weak reference).
1702
1703For the most part, ``__unsafe_unretained`` in non-ARC modes is just the
1704default behavior of variables and therefore is not needed.  However,
1705it does have an effect on the semantics of block captures: normally,
1706copying a block which captures an Objective-C object or block pointer
1707causes the captured pointer to be retained or copied, respectively,
1708but that behavior is suppressed when the captured variable is qualified
1709with ``__unsafe_unretained``.
1710
1711Note that the ``__weak`` qualifier formerly meant the GC qualifier in
1712all non-ARC modes and was silently ignored outside of GC modes.  It now
1713means the ARC-style qualifier in all non-GC modes and is no longer
1714allowed if not enabled by either ``-fobjc-arc`` or ``-fobjc-weak``.
1715It is expected that ``-fobjc-weak`` will eventually be enabled by default
1716in all non-GC Objective-C modes.
1717
1718.. _objc-fixed-enum:
1719
1720Enumerations with a fixed underlying type
1721-----------------------------------------
1722
1723Clang provides support for C++11 enumerations with a fixed underlying type
1724within Objective-C.  For example, one can write an enumeration type as:
1725
1726.. code-block:: c++
1727
1728  typedef enum : unsigned char { Red, Green, Blue } Color;
1729
1730This specifies that the underlying type, which is used to store the enumeration
1731value, is ``unsigned char``.
1732
1733Use ``__has_feature(objc_fixed_enum)`` to determine whether support for fixed
1734underlying types is available in Objective-C.
1735
1736Interoperability with C++11 lambdas
1737-----------------------------------
1738
1739Clang provides interoperability between C++11 lambdas and blocks-based APIs, by
1740permitting a lambda to be implicitly converted to a block pointer with the
1741corresponding signature.  For example, consider an API such as ``NSArray``'s
1742array-sorting method:
1743
1744.. code-block:: objc
1745
1746  - (NSArray *)sortedArrayUsingComparator:(NSComparator)cmptr;
1747
1748``NSComparator`` is simply a typedef for the block pointer ``NSComparisonResult
1749(^)(id, id)``, and parameters of this type are generally provided with block
1750literals as arguments.  However, one can also use a C++11 lambda so long as it
1751provides the same signature (in this case, accepting two parameters of type
1752``id`` and returning an ``NSComparisonResult``):
1753
1754.. code-block:: objc
1755
1756  NSArray *array = @[@"string 1", @"string 21", @"string 12", @"String 11",
1757                     @"String 02"];
1758  const NSStringCompareOptions comparisonOptions
1759    = NSCaseInsensitiveSearch | NSNumericSearch |
1760      NSWidthInsensitiveSearch | NSForcedOrderingSearch;
1761  NSLocale *currentLocale = [NSLocale currentLocale];
1762  NSArray *sorted
1763    = [array sortedArrayUsingComparator:[=](id s1, id s2) -> NSComparisonResult {
1764               NSRange string1Range = NSMakeRange(0, [s1 length]);
1765               return [s1 compare:s2 options:comparisonOptions
1766               range:string1Range locale:currentLocale];
1767       }];
1768  NSLog(@"sorted: %@", sorted);
1769
1770This code relies on an implicit conversion from the type of the lambda
1771expression (an unnamed, local class type called the *closure type*) to the
1772corresponding block pointer type.  The conversion itself is expressed by a
1773conversion operator in that closure type that produces a block pointer with the
1774same signature as the lambda itself, e.g.,
1775
1776.. code-block:: objc
1777
1778  operator NSComparisonResult (^)(id, id)() const;
1779
1780This conversion function returns a new block that simply forwards the two
1781parameters to the lambda object (which it captures by copy), then returns the
1782result.  The returned block is first copied (with ``Block_copy``) and then
1783autoreleased.  As an optimization, if a lambda expression is immediately
1784converted to a block pointer (as in the first example, above), then the block
1785is not copied and autoreleased: rather, it is given the same lifetime as a
1786block literal written at that point in the program, which avoids the overhead
1787of copying a block to the heap in the common case.
1788
1789The conversion from a lambda to a block pointer is only available in
1790Objective-C++, and not in C++ with blocks, due to its use of Objective-C memory
1791management (autorelease).
1792
1793Object Literals and Subscripting
1794--------------------------------
1795
1796Clang provides support for :doc:`Object Literals and Subscripting
1797<ObjectiveCLiterals>` in Objective-C, which simplifies common Objective-C
1798programming patterns, makes programs more concise, and improves the safety of
1799container creation.  There are several feature macros associated with object
1800literals and subscripting: ``__has_feature(objc_array_literals)`` tests the
1801availability of array literals; ``__has_feature(objc_dictionary_literals)``
1802tests the availability of dictionary literals;
1803``__has_feature(objc_subscripting)`` tests the availability of object
1804subscripting.
1805
1806Objective-C Autosynthesis of Properties
1807---------------------------------------
1808
1809Clang provides support for autosynthesis of declared properties.  Using this
1810feature, clang provides default synthesis of those properties not declared
1811@dynamic and not having user provided backing getter and setter methods.
1812``__has_feature(objc_default_synthesize_properties)`` checks for availability
1813of this feature in version of clang being used.
1814
1815.. _langext-objc-retain-release:
1816
1817Objective-C retaining behavior attributes
1818-----------------------------------------
1819
1820In Objective-C, functions and methods are generally assumed to follow the
1821`Cocoa Memory Management
1822<https://developer.apple.com/library/mac/#documentation/Cocoa/Conceptual/MemoryMgmt/Articles/mmRules.html>`_
1823conventions for ownership of object arguments and
1824return values. However, there are exceptions, and so Clang provides attributes
1825to allow these exceptions to be documented. This are used by ARC and the
1826`static analyzer <https://clang-analyzer.llvm.org>`_ Some exceptions may be
1827better described using the ``objc_method_family`` attribute instead.
1828
1829**Usage**: The ``ns_returns_retained``, ``ns_returns_not_retained``,
1830``ns_returns_autoreleased``, ``cf_returns_retained``, and
1831``cf_returns_not_retained`` attributes can be placed on methods and functions
1832that return Objective-C or CoreFoundation objects. They are commonly placed at
1833the end of a function prototype or method declaration:
1834
1835.. code-block:: objc
1836
1837  id foo() __attribute__((ns_returns_retained));
1838
1839  - (NSString *)bar:(int)x __attribute__((ns_returns_retained));
1840
1841The ``*_returns_retained`` attributes specify that the returned object has a +1
1842retain count.  The ``*_returns_not_retained`` attributes specify that the return
1843object has a +0 retain count, even if the normal convention for its selector
1844would be +1.  ``ns_returns_autoreleased`` specifies that the returned object is
1845+0, but is guaranteed to live at least as long as the next flush of an
1846autorelease pool.
1847
1848**Usage**: The ``ns_consumed`` and ``cf_consumed`` attributes can be placed on
1849an parameter declaration; they specify that the argument is expected to have a
1850+1 retain count, which will be balanced in some way by the function or method.
1851The ``ns_consumes_self`` attribute can only be placed on an Objective-C
1852method; it specifies that the method expects its ``self`` parameter to have a
1853+1 retain count, which it will balance in some way.
1854
1855.. code-block:: objc
1856
1857  void foo(__attribute__((ns_consumed)) NSString *string);
1858
1859  - (void) bar __attribute__((ns_consumes_self));
1860  - (void) baz:(id) __attribute__((ns_consumed)) x;
1861
1862Further examples of these attributes are available in the static analyzer's `list of annotations for analysis
1863<https://clang-analyzer.llvm.org/annotations.html#cocoa_mem>`_.
1864
1865Query for these features with ``__has_attribute(ns_consumed)``,
1866``__has_attribute(ns_returns_retained)``, etc.
1867
1868Objective-C @available
1869----------------------
1870
1871It is possible to use the newest SDK but still build a program that can run on
1872older versions of macOS and iOS by passing ``-mmacosx-version-min=`` /
1873``-miphoneos-version-min=``.
1874
1875Before LLVM 5.0, when calling a function that exists only in the OS that's
1876newer than the target OS (as determined by the minimum deployment version),
1877programmers had to carefully check if the function exists at runtime, using
1878null checks for weakly-linked C functions, ``+class`` for Objective-C classes,
1879and ``-respondsToSelector:`` or ``+instancesRespondToSelector:`` for
1880Objective-C methods.  If such a check was missed, the program would compile
1881fine, run fine on newer systems, but crash on older systems.
1882
1883As of LLVM 5.0, ``-Wunguarded-availability`` uses the `availability attributes
1884<https://clang.llvm.org/docs/AttributeReference.html#availability>`_ together
1885with the new ``@available()`` keyword to assist with this issue.
1886When a method that's introduced in the OS newer than the target OS is called, a
1887-Wunguarded-availability warning is emitted if that call is not guarded:
1888
1889.. code-block:: objc
1890
1891  void my_fun(NSSomeClass* var) {
1892    // If fancyNewMethod was added in e.g. macOS 10.12, but the code is
1893    // built with -mmacosx-version-min=10.11, then this unconditional call
1894    // will emit a -Wunguarded-availability warning:
1895    [var fancyNewMethod];
1896  }
1897
1898To fix the warning and to avoid the crash on macOS 10.11, wrap it in
1899``if(@available())``:
1900
1901.. code-block:: objc
1902
1903  void my_fun(NSSomeClass* var) {
1904    if (@available(macOS 10.12, *)) {
1905      [var fancyNewMethod];
1906    } else {
1907      // Put fallback behavior for old macOS versions (and for non-mac
1908      // platforms) here.
1909    }
1910  }
1911
1912The ``*`` is required and means that platforms not explicitly listed will take
1913the true branch, and the compiler will emit ``-Wunguarded-availability``
1914warnings for unlisted platforms based on those platform's deployment target.
1915More than one platform can be listed in ``@available()``:
1916
1917.. code-block:: objc
1918
1919  void my_fun(NSSomeClass* var) {
1920    if (@available(macOS 10.12, iOS 10, *)) {
1921      [var fancyNewMethod];
1922    }
1923  }
1924
1925If the caller of ``my_fun()`` already checks that ``my_fun()`` is only called
1926on 10.12, then add an `availability attribute
1927<https://clang.llvm.org/docs/AttributeReference.html#availability>`_ to it,
1928which will also suppress the warning and require that calls to my_fun() are
1929checked:
1930
1931.. code-block:: objc
1932
1933  API_AVAILABLE(macos(10.12)) void my_fun(NSSomeClass* var) {
1934    [var fancyNewMethod];  // Now ok.
1935  }
1936
1937``@available()`` is only available in Objective-C code.  To use the feature
1938in C and C++ code, use the ``__builtin_available()`` spelling instead.
1939
1940If existing code uses null checks or ``-respondsToSelector:``, it should
1941be changed to use ``@available()`` (or ``__builtin_available``) instead.
1942
1943``-Wunguarded-availability`` is disabled by default, but
1944``-Wunguarded-availability-new``, which only emits this warning for APIs
1945that have been introduced in macOS >= 10.13, iOS >= 11, watchOS >= 4 and
1946tvOS >= 11, is enabled by default.
1947
1948.. _langext-overloading:
1949
1950Objective-C++ ABI: protocol-qualifier mangling of parameters
1951------------------------------------------------------------
1952
1953Starting with LLVM 3.4, Clang produces a new mangling for parameters whose
1954type is a qualified-``id`` (e.g., ``id<Foo>``).  This mangling allows such
1955parameters to be differentiated from those with the regular unqualified ``id``
1956type.
1957
1958This was a non-backward compatible mangling change to the ABI.  This change
1959allows proper overloading, and also prevents mangling conflicts with template
1960parameters of protocol-qualified type.
1961
1962Query the presence of this new mangling with
1963``__has_feature(objc_protocol_qualifier_mangling)``.
1964
1965Initializer lists for complex numbers in C
1966==========================================
1967
1968clang supports an extension which allows the following in C:
1969
1970.. code-block:: c++
1971
1972  #include <math.h>
1973  #include <complex.h>
1974  complex float x = { 1.0f, INFINITY }; // Init to (1, Inf)
1975
1976This construct is useful because there is no way to separately initialize the
1977real and imaginary parts of a complex variable in standard C, given that clang
1978does not support ``_Imaginary``.  (Clang also supports the ``__real__`` and
1979``__imag__`` extensions from gcc, which help in some cases, but are not usable
1980in static initializers.)
1981
1982Note that this extension does not allow eliding the braces; the meaning of the
1983following two lines is different:
1984
1985.. code-block:: c++
1986
1987  complex float x[] = { { 1.0f, 1.0f } }; // [0] = (1, 1)
1988  complex float x[] = { 1.0f, 1.0f }; // [0] = (1, 0), [1] = (1, 0)
1989
1990This extension also works in C++ mode, as far as that goes, but does not apply
1991to the C++ ``std::complex``.  (In C++11, list initialization allows the same
1992syntax to be used with ``std::complex`` with the same meaning.)
1993
1994For GCC compatibility, ``__builtin_complex(re, im)`` can also be used to
1995construct a complex number from the given real and imaginary components.
1996
1997OpenCL Features
1998===============
1999
2000Clang supports internal OpenCL extensions documented below.
2001
2002``__cl_clang_bitfields``
2003--------------------------------
2004
2005With this extension it is possible to enable bitfields in structs
2006or unions using the OpenCL extension pragma mechanism detailed in
2007`the OpenCL Extension Specification, section 1.2
2008<https://www.khronos.org/registry/OpenCL/specs/3.0-unified/html/OpenCL_Ext.html#extensions-overview>`_.
2009
2010Use of bitfields in OpenCL kernels can result in reduced portability as struct
2011layout is not guaranteed to be consistent when compiled by different compilers.
2012If structs with bitfields are used as kernel function parameters, it can result
2013in incorrect functionality when the layout is different between the host and
2014device code.
2015
2016**Example of Use**:
2017
2018.. code-block:: c++
2019
2020  #pragma OPENCL EXTENSION __cl_clang_bitfields : enable
2021  struct with_bitfield {
2022    unsigned int i : 5; // compiled - no diagnostic generated
2023  };
2024
2025  #pragma OPENCL EXTENSION __cl_clang_bitfields : disable
2026  struct without_bitfield {
2027    unsigned int i : 5; // error - bitfields are not supported
2028  };
2029
2030``__cl_clang_function_pointers``
2031--------------------------------
2032
2033With this extension it is possible to enable various language features that
2034are relying on function pointers using regular OpenCL extension pragma
2035mechanism detailed in `the OpenCL Extension Specification,
2036section 1.2
2037<https://www.khronos.org/registry/OpenCL/specs/3.0-unified/html/OpenCL_Ext.html#extensions-overview>`_.
2038
2039In C++ for OpenCL this also enables:
2040
2041- Use of member function pointers;
2042
2043- Unrestricted use of references to functions;
2044
2045- Virtual member functions.
2046
2047Such functionality is not conformant and does not guarantee to compile
2048correctly in any circumstances. It can be used if:
2049
2050- the kernel source does not contain call expressions to (member-) function
2051  pointers, or virtual functions. For example this extension can be used in
2052  metaprogramming algorithms to be able to specify/detect types generically.
2053
2054- the generated kernel binary does not contain indirect calls because they
2055  are eliminated using compiler optimizations e.g. devirtualization.
2056
2057- the selected target supports the function pointer like functionality e.g.
2058  most CPU targets.
2059
2060**Example of Use**:
2061
2062.. code-block:: c++
2063
2064  #pragma OPENCL EXTENSION __cl_clang_function_pointers : enable
2065  void foo()
2066  {
2067    void (*fp)(); // compiled - no diagnostic generated
2068  }
2069
2070  #pragma OPENCL EXTENSION __cl_clang_function_pointers : disable
2071  void bar()
2072  {
2073    void (*fp)(); // error - pointers to function are not allowed
2074  }
2075
2076``__cl_clang_variadic_functions``
2077---------------------------------
2078
2079With this extension it is possible to enable variadic arguments in functions
2080using regular OpenCL extension pragma mechanism detailed in `the OpenCL
2081Extension Specification, section 1.2
2082<https://www.khronos.org/registry/OpenCL/specs/3.0-unified/html/OpenCL_Ext.html#extensions-overview>`_.
2083
2084This is not conformant behavior and it can only be used portably when the
2085functions with variadic prototypes do not get generated in binary e.g. the
2086variadic prototype is used to specify a function type with any number of
2087arguments in metaprogramming algorithms in C++ for OpenCL.
2088
2089This extensions can also be used when the kernel code is intended for targets
2090supporting the variadic arguments e.g. majority of CPU targets.
2091
2092**Example of Use**:
2093
2094.. code-block:: c++
2095
2096  #pragma OPENCL EXTENSION __cl_clang_variadic_functions : enable
2097  void foo(int a, ...); // compiled - no diagnostic generated
2098
2099  #pragma OPENCL EXTENSION __cl_clang_variadic_functions : disable
2100  void bar(int a, ...); // error - variadic prototype is not allowed
2101
2102``__cl_clang_non_portable_kernel_param_types``
2103----------------------------------------------
2104
2105With this extension it is possible to enable the use of some restricted types
2106in kernel parameters specified in `C++ for OpenCL v1.0 s2.4
2107<https://www.khronos.org/opencl/assets/CXX_for_OpenCL.html#kernel_function>`_.
2108The restrictions can be relaxed using regular OpenCL extension pragma mechanism
2109detailed in `the OpenCL Extension Specification, section 1.2
2110<https://www.khronos.org/registry/OpenCL/specs/3.0-unified/html/OpenCL_Ext.html#extensions-overview>`_.
2111
2112This is not a conformant behavior and it can only be used when the
2113kernel arguments are not accessed on the host side or the data layout/size
2114between the host and device is known to be compatible.
2115
2116**Example of Use**:
2117
2118.. code-block:: c++
2119
2120  // Plain Old Data type.
2121  struct Pod {
2122    int a;
2123    int b;
2124  };
2125
2126  // Not POD type because of the constructor.
2127  // Standard layout type because there is only one access control.
2128  struct OnlySL {
2129    int a;
2130    int b;
2131    NotPod() : a(0), b(0) {}
2132  };
2133
2134  // Not standard layout type because of two different access controls.
2135  struct NotSL {
2136    int a;
2137  private:
2138    int b;
2139  }
2140
2141  kernel void kernel_main(
2142    Pod a,
2143  #pragma OPENCL EXTENSION __cl_clang_non_portable_kernel_param_types : enable
2144    OnlySL b,
2145    global NotSL *c,
2146  #pragma OPENCL EXTENSION __cl_clang_non_portable_kernel_param_types : disable
2147    global OnlySL *d,
2148  );
2149
2150Remove address space builtin function
2151-------------------------------------
2152
2153``__remove_address_space`` allows to derive types in C++ for OpenCL
2154that have address space qualifiers removed. This utility only affects
2155address space qualifiers, therefore, other type qualifiers such as
2156``const`` or ``volatile`` remain unchanged.
2157
2158**Example of Use**:
2159
2160.. code-block:: c++
2161
2162  template<typename T>
2163  void foo(T *par){
2164    T var1; // error - local function variable with global address space
2165    __private T var2; // error - conflicting address space qualifiers
2166    __private __remove_address_space<T>::type var3; // var3 is __private int
2167  }
2168
2169  void bar(){
2170    __global int* ptr;
2171    foo(ptr);
2172  }
2173
2174Legacy 1.x atomics with generic address space
2175---------------------------------------------
2176
2177Clang allows use of atomic functions from the OpenCL 1.x standards
2178with the generic address space pointer in C++ for OpenCL mode.
2179
2180This is a non-portable feature and might not be supported by all
2181targets.
2182
2183**Example of Use**:
2184
2185.. code-block:: c++
2186
2187  void foo(__generic volatile unsigned int* a) {
2188    atomic_add(a, 1);
2189  }
2190
2191Builtin Functions
2192=================
2193
2194Clang supports a number of builtin library functions with the same syntax as
2195GCC, including things like ``__builtin_nan``, ``__builtin_constant_p``,
2196``__builtin_choose_expr``, ``__builtin_types_compatible_p``,
2197``__builtin_assume_aligned``, ``__sync_fetch_and_add``, etc.  In addition to
2198the GCC builtins, Clang supports a number of builtins that GCC does not, which
2199are listed here.
2200
2201Please note that Clang does not and will not support all of the GCC builtins
2202for vector operations.  Instead of using builtins, you should use the functions
2203defined in target-specific header files like ``<xmmintrin.h>``, which define
2204portable wrappers for these.  Many of the Clang versions of these functions are
2205implemented directly in terms of :ref:`extended vector support
2206<langext-vectors>` instead of builtins, in order to reduce the number of
2207builtins that we need to implement.
2208
2209``__builtin_alloca``
2210--------------------
2211
2212``__builtin_alloca`` is used to dynamically allocate memory on the stack. Memory
2213is automatically freed upon function termination.
2214
2215**Syntax**:
2216
2217.. code-block:: c++
2218
2219  __builtin_alloca(size_t n)
2220
2221**Example of Use**:
2222
2223.. code-block:: c++
2224
2225  void init(float* data, size_t nbelems);
2226  void process(float* data, size_t nbelems);
2227  int foo(size_t n) {
2228    auto mem = (float*)__builtin_alloca(n * sizeof(float));
2229    init(mem, n);
2230    process(mem, n);
2231    /* mem is automatically freed at this point */
2232  }
2233
2234**Description**:
2235
2236``__builtin_alloca`` is meant to be used to allocate a dynamic amount of memory
2237on the stack. This amount is subject to stack allocation limits.
2238
2239Query for this feature with ``__has_builtin(__builtin_alloca)``.
2240
2241``__builtin_alloca_with_align``
2242-------------------------------
2243
2244``__builtin_alloca_with_align`` is used to dynamically allocate memory on the
2245stack while controlling its alignment. Memory is automatically freed upon
2246function termination.
2247
2248
2249**Syntax**:
2250
2251.. code-block:: c++
2252
2253  __builtin_alloca_with_align(size_t n, size_t align)
2254
2255**Example of Use**:
2256
2257.. code-block:: c++
2258
2259  void init(float* data, size_t nbelems);
2260  void process(float* data, size_t nbelems);
2261  int foo(size_t n) {
2262    auto mem = (float*)__builtin_alloca_with_align(
2263                        n * sizeof(float),
2264                        CHAR_BIT * alignof(float));
2265    init(mem, n);
2266    process(mem, n);
2267    /* mem is automatically freed at this point */
2268  }
2269
2270**Description**:
2271
2272``__builtin_alloca_with_align`` is meant to be used to allocate a dynamic amount of memory
2273on the stack. It is similar to ``__builtin_alloca`` but accepts a second
2274argument whose value is the alignment constraint, as a power of 2 in *bits*.
2275
2276Query for this feature with ``__has_builtin(__builtin_alloca_with_align)``.
2277
2278.. _langext-__builtin_assume:
2279
2280``__builtin_assume``
2281--------------------
2282
2283``__builtin_assume`` is used to provide the optimizer with a boolean
2284invariant that is defined to be true.
2285
2286**Syntax**:
2287
2288.. code-block:: c++
2289
2290    __builtin_assume(bool)
2291
2292**Example of Use**:
2293
2294.. code-block:: c++
2295
2296  int foo(int x) {
2297      __builtin_assume(x != 0);
2298      // The optimizer may short-circuit this check using the invariant.
2299      if (x == 0)
2300            return do_something();
2301      return do_something_else();
2302  }
2303
2304**Description**:
2305
2306The boolean argument to this function is defined to be true. The optimizer may
2307analyze the form of the expression provided as the argument and deduce from
2308that information used to optimize the program. If the condition is violated
2309during execution, the behavior is undefined. The argument itself is never
2310evaluated, so any side effects of the expression will be discarded.
2311
2312Query for this feature with ``__has_builtin(__builtin_assume)``.
2313
2314``__builtin_call_with_static_chain``
2315------------------------------------
2316
2317``__builtin_call_with_static_chain`` is used to perform a static call while
2318setting updating the static chain register.
2319
2320**Syntax**:
2321
2322.. code-block:: c++
2323
2324  T __builtin_call_with_static_chain(T expr, void* ptr)
2325
2326**Example of Use**:
2327
2328.. code-block:: c++
2329
2330  auto v = __builtin_call_with_static_chain(foo(3), foo);
2331
2332**Description**:
2333
2334This builtin returns ``expr`` after checking that ``expr`` is a non-member
2335static call expression. The call to that expression is made while using ``ptr``
2336as a function pointer stored in a dedicated register to implement *static chain*
2337calling convention, as used by some language to implement closures or nested
2338functions.
2339
2340Query for this feature with ``__has_builtin(__builtin_call_with_static_chain)``.
2341
2342``__builtin_readcyclecounter``
2343------------------------------
2344
2345``__builtin_readcyclecounter`` is used to access the cycle counter register (or
2346a similar low-latency, high-accuracy clock) on those targets that support it.
2347
2348**Syntax**:
2349
2350.. code-block:: c++
2351
2352  __builtin_readcyclecounter()
2353
2354**Example of Use**:
2355
2356.. code-block:: c++
2357
2358  unsigned long long t0 = __builtin_readcyclecounter();
2359  do_something();
2360  unsigned long long t1 = __builtin_readcyclecounter();
2361  unsigned long long cycles_to_do_something = t1 - t0; // assuming no overflow
2362
2363**Description**:
2364
2365The ``__builtin_readcyclecounter()`` builtin returns the cycle counter value,
2366which may be either global or process/thread-specific depending on the target.
2367As the backing counters often overflow quickly (on the order of seconds) this
2368should only be used for timing small intervals.  When not supported by the
2369target, the return value is always zero.  This builtin takes no arguments and
2370produces an unsigned long long result.
2371
2372Query for this feature with ``__has_builtin(__builtin_readcyclecounter)``. Note
2373that even if present, its use may depend on run-time privilege or other OS
2374controlled state.
2375
2376``__builtin_dump_struct``
2377-------------------------
2378
2379**Syntax**:
2380
2381.. code-block:: c++
2382
2383    __builtin_dump_struct(&some_struct, some_printf_func, args...);
2384
2385**Examples**:
2386
2387.. code-block:: c++
2388
2389    struct S {
2390      int x, y;
2391      float f;
2392      struct T {
2393        int i;
2394      } t;
2395    };
2396
2397    void func(struct S *s) {
2398      __builtin_dump_struct(s, printf);
2399    }
2400
2401Example output:
2402
2403.. code-block:: none
2404
2405    struct S {
2406      int x = 100
2407      int y = 42
2408      float f = 3.141593
2409      struct T t = {
2410        int i = 1997
2411      }
2412    }
2413
2414.. code-block:: c++
2415
2416    #include <string>
2417    struct T { int a, b; };
2418    constexpr void constexpr_sprintf(std::string &out, const char *format,
2419                                     auto ...args) {
2420      // ...
2421    }
2422    constexpr std::string dump_struct(auto &x) {
2423      std::string s;
2424      __builtin_dump_struct(&x, constexpr_sprintf, s);
2425      return s;
2426    }
2427    static_assert(dump_struct(T{1, 2}) == R"(struct T {
2428      int a = 1
2429      int b = 2
2430    }
2431    )");
2432
2433**Description**:
2434
2435The ``__builtin_dump_struct`` function is used to print the fields of a simple
2436structure and their values for debugging purposes. The first argument of the
2437builtin should be a pointer to the struct to dump. The second argument ``f``
2438should be some callable expression, and can be a function object or an overload
2439set. The builtin calls ``f``, passing any further arguments ``args...``
2440followed by a ``printf``-compatible format string and the corresponding
2441arguments. ``f`` may be called more than once, and ``f`` and ``args`` will be
2442evaluated once per call. In C++, ``f`` may be a template or overload set and
2443resolve to different functions for each call.
2444
2445In the format string, a suitable format specifier will be used for builtin
2446types that Clang knows how to format. This includes standard builtin types, as
2447well as aggregate structures, ``void*`` (printed with ``%p``), and ``const
2448char*`` (printed with ``%s``). A ``*%p`` specifier will be used for a field
2449that Clang doesn't know how to format, and the corresopnding argument will be a
2450pointer to the field. This allows a C++ templated formatting function to detect
2451this case and implement custom formatting. A ``*`` will otherwise not precede a
2452format specifier.
2453
2454This builtin does not return a value.
2455
2456This builtin can be used in constant expressions.
2457
2458Query for this feature with ``__has_builtin(__builtin_dump_struct)``
2459
2460.. _langext-__builtin_shufflevector:
2461
2462``__builtin_shufflevector``
2463---------------------------
2464
2465``__builtin_shufflevector`` is used to express generic vector
2466permutation/shuffle/swizzle operations.  This builtin is also very important
2467for the implementation of various target-specific header files like
2468``<xmmintrin.h>``.
2469
2470**Syntax**:
2471
2472.. code-block:: c++
2473
2474  __builtin_shufflevector(vec1, vec2, index1, index2, ...)
2475
2476**Examples**:
2477
2478.. code-block:: c++
2479
2480  // identity operation - return 4-element vector v1.
2481  __builtin_shufflevector(v1, v1, 0, 1, 2, 3)
2482
2483  // "Splat" element 0 of V1 into a 4-element result.
2484  __builtin_shufflevector(V1, V1, 0, 0, 0, 0)
2485
2486  // Reverse 4-element vector V1.
2487  __builtin_shufflevector(V1, V1, 3, 2, 1, 0)
2488
2489  // Concatenate every other element of 4-element vectors V1 and V2.
2490  __builtin_shufflevector(V1, V2, 0, 2, 4, 6)
2491
2492  // Concatenate every other element of 8-element vectors V1 and V2.
2493  __builtin_shufflevector(V1, V2, 0, 2, 4, 6, 8, 10, 12, 14)
2494
2495  // Shuffle v1 with some elements being undefined
2496  __builtin_shufflevector(v1, v1, 3, -1, 1, -1)
2497
2498**Description**:
2499
2500The first two arguments to ``__builtin_shufflevector`` are vectors that have
2501the same element type.  The remaining arguments are a list of integers that
2502specify the elements indices of the first two vectors that should be extracted
2503and returned in a new vector.  These element indices are numbered sequentially
2504starting with the first vector, continuing into the second vector.  Thus, if
2505``vec1`` is a 4-element vector, index 5 would refer to the second element of
2506``vec2``. An index of -1 can be used to indicate that the corresponding element
2507in the returned vector is a don't care and can be optimized by the backend.
2508
2509The result of ``__builtin_shufflevector`` is a vector with the same element
2510type as ``vec1``/``vec2`` but that has an element count equal to the number of
2511indices specified.
2512
2513Query for this feature with ``__has_builtin(__builtin_shufflevector)``.
2514
2515.. _langext-__builtin_convertvector:
2516
2517``__builtin_convertvector``
2518---------------------------
2519
2520``__builtin_convertvector`` is used to express generic vector
2521type-conversion operations. The input vector and the output vector
2522type must have the same number of elements.
2523
2524**Syntax**:
2525
2526.. code-block:: c++
2527
2528  __builtin_convertvector(src_vec, dst_vec_type)
2529
2530**Examples**:
2531
2532.. code-block:: c++
2533
2534  typedef double vector4double __attribute__((__vector_size__(32)));
2535  typedef float  vector4float  __attribute__((__vector_size__(16)));
2536  typedef short  vector4short  __attribute__((__vector_size__(8)));
2537  vector4float vf; vector4short vs;
2538
2539  // convert from a vector of 4 floats to a vector of 4 doubles.
2540  __builtin_convertvector(vf, vector4double)
2541  // equivalent to:
2542  (vector4double) { (double) vf[0], (double) vf[1], (double) vf[2], (double) vf[3] }
2543
2544  // convert from a vector of 4 shorts to a vector of 4 floats.
2545  __builtin_convertvector(vs, vector4float)
2546  // equivalent to:
2547  (vector4float) { (float) vs[0], (float) vs[1], (float) vs[2], (float) vs[3] }
2548
2549**Description**:
2550
2551The first argument to ``__builtin_convertvector`` is a vector, and the second
2552argument is a vector type with the same number of elements as the first
2553argument.
2554
2555The result of ``__builtin_convertvector`` is a vector with the same element
2556type as the second argument, with a value defined in terms of the action of a
2557C-style cast applied to each element of the first argument.
2558
2559Query for this feature with ``__has_builtin(__builtin_convertvector)``.
2560
2561``__builtin_bitreverse``
2562------------------------
2563
2564* ``__builtin_bitreverse8``
2565* ``__builtin_bitreverse16``
2566* ``__builtin_bitreverse32``
2567* ``__builtin_bitreverse64``
2568
2569**Syntax**:
2570
2571.. code-block:: c++
2572
2573     __builtin_bitreverse32(x)
2574
2575**Examples**:
2576
2577.. code-block:: c++
2578
2579      uint8_t rev_x = __builtin_bitreverse8(x);
2580      uint16_t rev_x = __builtin_bitreverse16(x);
2581      uint32_t rev_y = __builtin_bitreverse32(y);
2582      uint64_t rev_z = __builtin_bitreverse64(z);
2583
2584**Description**:
2585
2586The '``__builtin_bitreverse``' family of builtins is used to reverse
2587the bitpattern of an integer value; for example ``0b10110110`` becomes
2588``0b01101101``. These builtins can be used within constant expressions.
2589
2590``__builtin_rotateleft``
2591------------------------
2592
2593* ``__builtin_rotateleft8``
2594* ``__builtin_rotateleft16``
2595* ``__builtin_rotateleft32``
2596* ``__builtin_rotateleft64``
2597
2598**Syntax**:
2599
2600.. code-block:: c++
2601
2602     __builtin_rotateleft32(x, y)
2603
2604**Examples**:
2605
2606.. code-block:: c++
2607
2608      uint8_t rot_x = __builtin_rotateleft8(x, y);
2609      uint16_t rot_x = __builtin_rotateleft16(x, y);
2610      uint32_t rot_x = __builtin_rotateleft32(x, y);
2611      uint64_t rot_x = __builtin_rotateleft64(x, y);
2612
2613**Description**:
2614
2615The '``__builtin_rotateleft``' family of builtins is used to rotate
2616the bits in the first argument by the amount in the second argument.
2617For example, ``0b10000110`` rotated left by 11 becomes ``0b00110100``.
2618The shift value is treated as an unsigned amount modulo the size of
2619the arguments. Both arguments and the result have the bitwidth specified
2620by the name of the builtin. These builtins can be used within constant
2621expressions.
2622
2623``__builtin_rotateright``
2624-------------------------
2625
2626* ``__builtin_rotateright8``
2627* ``__builtin_rotateright16``
2628* ``__builtin_rotateright32``
2629* ``__builtin_rotateright64``
2630
2631**Syntax**:
2632
2633.. code-block:: c++
2634
2635     __builtin_rotateright32(x, y)
2636
2637**Examples**:
2638
2639.. code-block:: c++
2640
2641      uint8_t rot_x = __builtin_rotateright8(x, y);
2642      uint16_t rot_x = __builtin_rotateright16(x, y);
2643      uint32_t rot_x = __builtin_rotateright32(x, y);
2644      uint64_t rot_x = __builtin_rotateright64(x, y);
2645
2646**Description**:
2647
2648The '``__builtin_rotateright``' family of builtins is used to rotate
2649the bits in the first argument by the amount in the second argument.
2650For example, ``0b10000110`` rotated right by 3 becomes ``0b11010000``.
2651The shift value is treated as an unsigned amount modulo the size of
2652the arguments. Both arguments and the result have the bitwidth specified
2653by the name of the builtin. These builtins can be used within constant
2654expressions.
2655
2656``__builtin_unreachable``
2657-------------------------
2658
2659``__builtin_unreachable`` is used to indicate that a specific point in the
2660program cannot be reached, even if the compiler might otherwise think it can.
2661This is useful to improve optimization and eliminates certain warnings.  For
2662example, without the ``__builtin_unreachable`` in the example below, the
2663compiler assumes that the inline asm can fall through and prints a "function
2664declared '``noreturn``' should not return" warning.
2665
2666**Syntax**:
2667
2668.. code-block:: c++
2669
2670    __builtin_unreachable()
2671
2672**Example of use**:
2673
2674.. code-block:: c++
2675
2676  void myabort(void) __attribute__((noreturn));
2677  void myabort(void) {
2678    asm("int3");
2679    __builtin_unreachable();
2680  }
2681
2682**Description**:
2683
2684The ``__builtin_unreachable()`` builtin has completely undefined behavior.
2685Since it has undefined behavior, it is a statement that it is never reached and
2686the optimizer can take advantage of this to produce better code.  This builtin
2687takes no arguments and produces a void result.
2688
2689Query for this feature with ``__has_builtin(__builtin_unreachable)``.
2690
2691``__builtin_unpredictable``
2692---------------------------
2693
2694``__builtin_unpredictable`` is used to indicate that a branch condition is
2695unpredictable by hardware mechanisms such as branch prediction logic.
2696
2697**Syntax**:
2698
2699.. code-block:: c++
2700
2701    __builtin_unpredictable(long long)
2702
2703**Example of use**:
2704
2705.. code-block:: c++
2706
2707  if (__builtin_unpredictable(x > 0)) {
2708     foo();
2709  }
2710
2711**Description**:
2712
2713The ``__builtin_unpredictable()`` builtin is expected to be used with control
2714flow conditions such as in ``if`` and ``switch`` statements.
2715
2716Query for this feature with ``__has_builtin(__builtin_unpredictable)``.
2717
2718
2719``__builtin_expect``
2720--------------------
2721
2722``__builtin_expect`` is used to indicate that the value of an expression is
2723anticipated to be the same as a statically known result.
2724
2725**Syntax**:
2726
2727.. code-block:: c++
2728
2729    long __builtin_expect(long expr, long val)
2730
2731**Example of use**:
2732
2733.. code-block:: c++
2734
2735  if (__builtin_expect(x, 0)) {
2736     bar();
2737  }
2738
2739**Description**:
2740
2741The ``__builtin_expect()`` builtin is typically used with control flow
2742conditions such as in ``if`` and ``switch`` statements to help branch
2743prediction. It means that its first argument ``expr`` is expected to take the
2744value of its second argument ``val``. It always returns ``expr``.
2745
2746Query for this feature with ``__has_builtin(__builtin_expect)``.
2747
2748``__builtin_expect_with_probability``
2749-------------------------------------
2750
2751``__builtin_expect_with_probability`` is similar to ``__builtin_expect`` but it
2752takes a probability as third argument.
2753
2754**Syntax**:
2755
2756.. code-block:: c++
2757
2758    long __builtin_expect_with_probability(long expr, long val, double p)
2759
2760**Example of use**:
2761
2762.. code-block:: c++
2763
2764  if (__builtin_expect_with_probability(x, 0, .3)) {
2765     bar();
2766  }
2767
2768**Description**:
2769
2770The ``__builtin_expect_with_probability()`` builtin is typically used with
2771control flow conditions such as in ``if`` and ``switch`` statements to help
2772branch prediction. It means that its first argument ``expr`` is expected to take
2773the value of its second argument ``val`` with probability ``p``. ``p`` must be
2774within ``[0.0 ; 1.0]`` bounds. This builtin always returns the value of ``expr``.
2775
2776Query for this feature with ``__has_builtin(__builtin_expect_with_probability)``.
2777
2778``__builtin_prefetch``
2779----------------------
2780
2781``__builtin_prefetch`` is used to communicate with the cache handler to bring
2782data into the cache before it gets used.
2783
2784**Syntax**:
2785
2786.. code-block:: c++
2787
2788    void __builtin_prefetch(const void *addr, int rw=0, int locality=3)
2789
2790**Example of use**:
2791
2792.. code-block:: c++
2793
2794    __builtin_prefetch(a + i);
2795
2796**Description**:
2797
2798The ``__builtin_prefetch(addr, rw, locality)`` builtin is expected to be used to
2799avoid cache misses when the developper has a good understanding of which data
2800are going to be used next. ``addr`` is the address that needs to be brought into
2801the cache. ``rw`` indicates the expected access mode: ``0`` for *read* and ``1``
2802for *write*. In case of *read write* access, ``1`` is to be used. ``locality``
2803indicates the expected persistance of data in cache, from ``0`` which means that
2804data can be discarded from cache after its next use to ``3`` which means that
2805data is going to be reused a lot once in cache. ``1`` and ``2`` provide
2806intermediate behavior between these two extremes.
2807
2808Query for this feature with ``__has_builtin(__builtin_prefetch)``.
2809
2810``__sync_swap``
2811---------------
2812
2813``__sync_swap`` is used to atomically swap integers or pointers in memory.
2814
2815**Syntax**:
2816
2817.. code-block:: c++
2818
2819  type __sync_swap(type *ptr, type value, ...)
2820
2821**Example of Use**:
2822
2823.. code-block:: c++
2824
2825  int old_value = __sync_swap(&value, new_value);
2826
2827**Description**:
2828
2829The ``__sync_swap()`` builtin extends the existing ``__sync_*()`` family of
2830atomic intrinsics to allow code to atomically swap the current value with the
2831new value.  More importantly, it helps developers write more efficient and
2832correct code by avoiding expensive loops around
2833``__sync_bool_compare_and_swap()`` or relying on the platform specific
2834implementation details of ``__sync_lock_test_and_set()``.  The
2835``__sync_swap()`` builtin is a full barrier.
2836
2837``__builtin_addressof``
2838-----------------------
2839
2840``__builtin_addressof`` performs the functionality of the built-in ``&``
2841operator, ignoring any ``operator&`` overload.  This is useful in constant
2842expressions in C++11, where there is no other way to take the address of an
2843object that overloads ``operator&``.
2844
2845**Example of use**:
2846
2847.. code-block:: c++
2848
2849  template<typename T> constexpr T *addressof(T &value) {
2850    return __builtin_addressof(value);
2851  }
2852
2853``__builtin_function_start``
2854-----------------------------
2855
2856``__builtin_function_start`` returns the address of a function body.
2857
2858**Syntax**:
2859
2860.. code-block:: c++
2861
2862  void *__builtin_function_start(function)
2863
2864**Example of use**:
2865
2866.. code-block:: c++
2867
2868  void a() {}
2869  void *p = __builtin_function_start(a);
2870
2871  class A {
2872  public:
2873    void a(int n);
2874    void a();
2875  };
2876
2877  void A::a(int n) {}
2878  void A::a() {}
2879
2880  void *pa1 = __builtin_function_start((void(A::*)(int)) &A::a);
2881  void *pa2 = __builtin_function_start((void(A::*)()) &A::a);
2882
2883**Description**:
2884
2885The ``__builtin_function_start`` builtin accepts an argument that can be
2886constant-evaluated to a function, and returns the address of the function
2887body.  This builtin is not supported on all targets.
2888
2889The returned pointer may differ from the normally taken function address
2890and is not safe to call.  For example, with ``-fsanitize=cfi``, taking a
2891function address produces a callable pointer to a CFI jump table, while
2892``__builtin_function_start`` returns an address that fails
2893:doc:`cfi-icall<ControlFlowIntegrity>` checks.
2894
2895``__builtin_operator_new`` and ``__builtin_operator_delete``
2896------------------------------------------------------------
2897
2898A call to ``__builtin_operator_new(args)`` is exactly the same as a call to
2899``::operator new(args)``, except that it allows certain optimizations
2900that the C++ standard does not permit for a direct function call to
2901``::operator new`` (in particular, removing ``new`` / ``delete`` pairs and
2902merging allocations), and that the call is required to resolve to a
2903`replaceable global allocation function
2904<https://en.cppreference.com/w/cpp/memory/new/operator_new>`_.
2905
2906Likewise, ``__builtin_operator_delete`` is exactly the same as a call to
2907``::operator delete(args)``, except that it permits optimizations
2908and that the call is required to resolve to a
2909`replaceable global deallocation function
2910<https://en.cppreference.com/w/cpp/memory/new/operator_delete>`_.
2911
2912These builtins are intended for use in the implementation of ``std::allocator``
2913and other similar allocation libraries, and are only available in C++.
2914
2915Query for this feature with ``__has_builtin(__builtin_operator_new)`` or
2916``__has_builtin(__builtin_operator_delete)``:
2917
2918  * If the value is at least ``201802L``, the builtins behave as described above.
2919
2920  * If the value is non-zero, the builtins may not support calling arbitrary
2921    replaceable global (de)allocation functions, but do support calling at least
2922    ``::operator new(size_t)`` and ``::operator delete(void*)``.
2923
2924``__builtin_preserve_access_index``
2925-----------------------------------
2926
2927``__builtin_preserve_access_index`` specifies a code section where
2928array subscript access and structure/union member access are relocatable
2929under bpf compile-once run-everywhere framework. Debuginfo (typically
2930with ``-g``) is needed, otherwise, the compiler will exit with an error.
2931The return type for the intrinsic is the same as the type of the
2932argument.
2933
2934**Syntax**:
2935
2936.. code-block:: c
2937
2938  type __builtin_preserve_access_index(type arg)
2939
2940**Example of Use**:
2941
2942.. code-block:: c
2943
2944  struct t {
2945    int i;
2946    int j;
2947    union {
2948      int a;
2949      int b;
2950    } c[4];
2951  };
2952  struct t *v = ...;
2953  int *pb =__builtin_preserve_access_index(&v->c[3].b);
2954  __builtin_preserve_access_index(v->j);
2955
2956``__builtin_debugtrap``
2957-----------------------
2958
2959``__builtin_debugtrap`` causes the program to stop its execution in such a way that a debugger can catch it.
2960
2961**Syntax**:
2962
2963.. code-block:: c++
2964
2965    __builtin_debugtrap()
2966
2967**Description**
2968
2969``__builtin_debugtrap`` is lowered to the ` ``llvm.debugtrap`` <https://llvm.org/docs/LangRef.html#llvm-debugtrap-intrinsic>`_ builtin. It should have the same effect as setting a breakpoint on the line where the builtin is called.
2970
2971Query for this feature with ``__has_builtin(__builtin_debugtrap)``.
2972
2973
2974``__builtin_trap``
2975------------------
2976
2977``__builtin_trap`` causes the program to stop its execution abnormally.
2978
2979**Syntax**:
2980
2981.. code-block:: c++
2982
2983    __builtin_trap()
2984
2985**Description**
2986
2987``__builtin_trap`` is lowered to the ` ``llvm.trap`` <https://llvm.org/docs/LangRef.html#llvm-trap-intrinsic>`_ builtin.
2988
2989Query for this feature with ``__has_builtin(__builtin_trap)``.
2990
2991
2992``__builtin_sycl_unique_stable_name``
2993-------------------------------------
2994
2995``__builtin_sycl_unique_stable_name()`` is a builtin that takes a type and
2996produces a string literal containing a unique name for the type that is stable
2997across split compilations, mainly to support SYCL/Data Parallel C++ language.
2998
2999In cases where the split compilation needs to share a unique token for a type
3000across the boundary (such as in an offloading situation), this name can be used
3001for lookup purposes, such as in the SYCL Integration Header.
3002
3003The value of this builtin is computed entirely at compile time, so it can be
3004used in constant expressions. This value encodes lambda functions based on a
3005stable numbering order in which they appear in their local declaration contexts.
3006Once this builtin is evaluated in a constexpr context, it is erroneous to use
3007it in an instantiation which changes its value.
3008
3009In order to produce the unique name, the current implementation of the bultin
3010uses Itanium mangling even if the host compilation uses a different name
3011mangling scheme at runtime. The mangler marks all the lambdas required to name
3012the SYCL kernel and emits a stable local ordering of the respective lambdas.
3013The resulting pattern is demanglable.  When non-lambda types are passed to the
3014builtin, the mangler emits their usual pattern without any special treatment.
3015
3016**Syntax**:
3017
3018.. code-block:: c
3019
3020  // Computes a unique stable name for the given type.
3021  constexpr const char * __builtin_sycl_unique_stable_name( type-id );
3022
3023Multiprecision Arithmetic Builtins
3024----------------------------------
3025
3026Clang provides a set of builtins which expose multiprecision arithmetic in a
3027manner amenable to C. They all have the following form:
3028
3029.. code-block:: c
3030
3031  unsigned x = ..., y = ..., carryin = ..., carryout;
3032  unsigned sum = __builtin_addc(x, y, carryin, &carryout);
3033
3034Thus one can form a multiprecision addition chain in the following manner:
3035
3036.. code-block:: c
3037
3038  unsigned *x, *y, *z, carryin=0, carryout;
3039  z[0] = __builtin_addc(x[0], y[0], carryin, &carryout);
3040  carryin = carryout;
3041  z[1] = __builtin_addc(x[1], y[1], carryin, &carryout);
3042  carryin = carryout;
3043  z[2] = __builtin_addc(x[2], y[2], carryin, &carryout);
3044  carryin = carryout;
3045  z[3] = __builtin_addc(x[3], y[3], carryin, &carryout);
3046
3047The complete list of builtins are:
3048
3049.. code-block:: c
3050
3051  unsigned char      __builtin_addcb (unsigned char x, unsigned char y, unsigned char carryin, unsigned char *carryout);
3052  unsigned short     __builtin_addcs (unsigned short x, unsigned short y, unsigned short carryin, unsigned short *carryout);
3053  unsigned           __builtin_addc  (unsigned x, unsigned y, unsigned carryin, unsigned *carryout);
3054  unsigned long      __builtin_addcl (unsigned long x, unsigned long y, unsigned long carryin, unsigned long *carryout);
3055  unsigned long long __builtin_addcll(unsigned long long x, unsigned long long y, unsigned long long carryin, unsigned long long *carryout);
3056  unsigned char      __builtin_subcb (unsigned char x, unsigned char y, unsigned char carryin, unsigned char *carryout);
3057  unsigned short     __builtin_subcs (unsigned short x, unsigned short y, unsigned short carryin, unsigned short *carryout);
3058  unsigned           __builtin_subc  (unsigned x, unsigned y, unsigned carryin, unsigned *carryout);
3059  unsigned long      __builtin_subcl (unsigned long x, unsigned long y, unsigned long carryin, unsigned long *carryout);
3060  unsigned long long __builtin_subcll(unsigned long long x, unsigned long long y, unsigned long long carryin, unsigned long long *carryout);
3061
3062Checked Arithmetic Builtins
3063---------------------------
3064
3065Clang provides a set of builtins that implement checked arithmetic for security
3066critical applications in a manner that is fast and easily expressible in C. As
3067an example of their usage:
3068
3069.. code-block:: c
3070
3071  errorcode_t security_critical_application(...) {
3072    unsigned x, y, result;
3073    ...
3074    if (__builtin_mul_overflow(x, y, &result))
3075      return kErrorCodeHackers;
3076    ...
3077    use_multiply(result);
3078    ...
3079  }
3080
3081Clang provides the following checked arithmetic builtins:
3082
3083.. code-block:: c
3084
3085  bool __builtin_add_overflow   (type1 x, type2 y, type3 *sum);
3086  bool __builtin_sub_overflow   (type1 x, type2 y, type3 *diff);
3087  bool __builtin_mul_overflow   (type1 x, type2 y, type3 *prod);
3088  bool __builtin_uadd_overflow  (unsigned x, unsigned y, unsigned *sum);
3089  bool __builtin_uaddl_overflow (unsigned long x, unsigned long y, unsigned long *sum);
3090  bool __builtin_uaddll_overflow(unsigned long long x, unsigned long long y, unsigned long long *sum);
3091  bool __builtin_usub_overflow  (unsigned x, unsigned y, unsigned *diff);
3092  bool __builtin_usubl_overflow (unsigned long x, unsigned long y, unsigned long *diff);
3093  bool __builtin_usubll_overflow(unsigned long long x, unsigned long long y, unsigned long long *diff);
3094  bool __builtin_umul_overflow  (unsigned x, unsigned y, unsigned *prod);
3095  bool __builtin_umull_overflow (unsigned long x, unsigned long y, unsigned long *prod);
3096  bool __builtin_umulll_overflow(unsigned long long x, unsigned long long y, unsigned long long *prod);
3097  bool __builtin_sadd_overflow  (int x, int y, int *sum);
3098  bool __builtin_saddl_overflow (long x, long y, long *sum);
3099  bool __builtin_saddll_overflow(long long x, long long y, long long *sum);
3100  bool __builtin_ssub_overflow  (int x, int y, int *diff);
3101  bool __builtin_ssubl_overflow (long x, long y, long *diff);
3102  bool __builtin_ssubll_overflow(long long x, long long y, long long *diff);
3103  bool __builtin_smul_overflow  (int x, int y, int *prod);
3104  bool __builtin_smull_overflow (long x, long y, long *prod);
3105  bool __builtin_smulll_overflow(long long x, long long y, long long *prod);
3106
3107Each builtin performs the specified mathematical operation on the
3108first two arguments and stores the result in the third argument.  If
3109possible, the result will be equal to mathematically-correct result
3110and the builtin will return 0.  Otherwise, the builtin will return
31111 and the result will be equal to the unique value that is equivalent
3112to the mathematically-correct result modulo two raised to the *k*
3113power, where *k* is the number of bits in the result type.  The
3114behavior of these builtins is well-defined for all argument values.
3115
3116The first three builtins work generically for operands of any integer type,
3117including boolean types.  The operands need not have the same type as each
3118other, or as the result.  The other builtins may implicitly promote or
3119convert their operands before performing the operation.
3120
3121Query for this feature with ``__has_builtin(__builtin_add_overflow)``, etc.
3122
3123Floating point builtins
3124---------------------------------------
3125
3126``__builtin_canonicalize``
3127--------------------------
3128
3129.. code-block:: c
3130
3131   double __builtin_canonicalize(double);
3132   float __builtin_canonicalizef(float);
3133   long double__builtin_canonicalizel(long double);
3134
3135Returns the platform specific canonical encoding of a floating point
3136number. This canonicalization is useful for implementing certain
3137numeric primitives such as frexp. See `LLVM canonicalize intrinsic
3138<https://llvm.org/docs/LangRef.html#llvm-canonicalize-intrinsic>`_ for
3139more information on the semantics.
3140
3141String builtins
3142---------------
3143
3144Clang provides constant expression evaluation support for builtins forms of
3145the following functions from the C standard library headers
3146``<string.h>`` and ``<wchar.h>``:
3147
3148* ``memchr``
3149* ``memcmp`` (and its deprecated BSD / POSIX alias ``bcmp``)
3150* ``strchr``
3151* ``strcmp``
3152* ``strlen``
3153* ``strncmp``
3154* ``wcschr``
3155* ``wcscmp``
3156* ``wcslen``
3157* ``wcsncmp``
3158* ``wmemchr``
3159* ``wmemcmp``
3160
3161In each case, the builtin form has the name of the C library function prefixed
3162by ``__builtin_``. Example:
3163
3164.. code-block:: c
3165
3166  void *p = __builtin_memchr("foobar", 'b', 5);
3167
3168In addition to the above, one further builtin is provided:
3169
3170.. code-block:: c
3171
3172  char *__builtin_char_memchr(const char *haystack, int needle, size_t size);
3173
3174``__builtin_char_memchr(a, b, c)`` is identical to
3175``(char*)__builtin_memchr(a, b, c)`` except that its use is permitted within
3176constant expressions in C++11 onwards (where a cast from ``void*`` to ``char*``
3177is disallowed in general).
3178
3179Constant evaluation support for the ``__builtin_mem*`` functions is provided
3180only for arrays of ``char``, ``signed char``, ``unsigned char``, or ``char8_t``,
3181despite these functions accepting an argument of type ``const void*``.
3182
3183Support for constant expression evaluation for the above builtins can be detected
3184with ``__has_feature(cxx_constexpr_string_builtins)``.
3185
3186Memory builtins
3187---------------
3188
3189Clang provides constant expression evaluation support for builtin forms of the
3190following functions from the C standard library headers
3191``<string.h>`` and ``<wchar.h>``:
3192
3193* ``memcpy``
3194* ``memmove``
3195* ``wmemcpy``
3196* ``wmemmove``
3197
3198In each case, the builtin form has the name of the C library function prefixed
3199by ``__builtin_``.
3200
3201Constant evaluation support is only provided when the source and destination
3202are pointers to arrays with the same trivially copyable element type, and the
3203given size is an exact multiple of the element size that is no greater than
3204the number of elements accessible through the source and destination operands.
3205
3206Guaranteed inlined copy
3207^^^^^^^^^^^^^^^^^^^^^^^
3208
3209.. code-block:: c
3210
3211  void __builtin_memcpy_inline(void *dst, const void *src, size_t size);
3212
3213
3214``__builtin_memcpy_inline`` has been designed as a building block for efficient
3215``memcpy`` implementations. It is identical to ``__builtin_memcpy`` but also
3216guarantees not to call any external functions. See LLVM IR `llvm.memcpy.inline
3217<https://llvm.org/docs/LangRef.html#llvm-memcpy-inline-intrinsic>`_ intrinsic
3218for more information.
3219
3220This is useful to implement a custom version of ``memcpy``, implement a
3221``libc`` memcpy or work around the absence of a ``libc``.
3222
3223Note that the `size` argument must be a compile time constant.
3224
3225Note that this intrinsic cannot yet be called in a ``constexpr`` context.
3226
3227Guaranteed inlined memset
3228^^^^^^^^^^^^^^^^^^^^^^^^^
3229
3230.. code-block:: c
3231
3232  void __builtin_memset_inline(void *dst, int value, size_t size);
3233
3234
3235``__builtin_memset_inline`` has been designed as a building block for efficient
3236``memset`` implementations. It is identical to ``__builtin_memset`` but also
3237guarantees not to call any external functions. See LLVM IR `llvm.memset.inline
3238<https://llvm.org/docs/LangRef.html#llvm-memset-inline-intrinsic>`_ intrinsic
3239for more information.
3240
3241This is useful to implement a custom version of ``memset``, implement a
3242``libc`` memset or work around the absence of a ``libc``.
3243
3244Note that the `size` argument must be a compile time constant.
3245
3246Note that this intrinsic cannot yet be called in a ``constexpr`` context.
3247
3248Atomic Min/Max builtins with memory ordering
3249--------------------------------------------
3250
3251There are two atomic builtins with min/max in-memory comparison and swap.
3252The syntax and semantics are similar to GCC-compatible __atomic_* builtins.
3253
3254* ``__atomic_fetch_min``
3255* ``__atomic_fetch_max``
3256
3257The builtins work with signed and unsigned integers and require to specify memory ordering.
3258The return value is the original value that was stored in memory before comparison.
3259
3260Example:
3261
3262.. code-block:: c
3263
3264  unsigned int val = __atomic_fetch_min(unsigned int *pi, unsigned int ui, __ATOMIC_RELAXED);
3265
3266The third argument is one of the memory ordering specifiers ``__ATOMIC_RELAXED``,
3267``__ATOMIC_CONSUME``, ``__ATOMIC_ACQUIRE``, ``__ATOMIC_RELEASE``,
3268``__ATOMIC_ACQ_REL``, or ``__ATOMIC_SEQ_CST`` following C++11 memory model semantics.
3269
3270In terms or aquire-release ordering barriers these two operations are always
3271considered as operations with *load-store* semantics, even when the original value
3272is not actually modified after comparison.
3273
3274.. _langext-__c11_atomic:
3275
3276__c11_atomic builtins
3277---------------------
3278
3279Clang provides a set of builtins which are intended to be used to implement
3280C11's ``<stdatomic.h>`` header.  These builtins provide the semantics of the
3281``_explicit`` form of the corresponding C11 operation, and are named with a
3282``__c11_`` prefix.  The supported operations, and the differences from
3283the corresponding C11 operations, are:
3284
3285* ``__c11_atomic_init``
3286* ``__c11_atomic_thread_fence``
3287* ``__c11_atomic_signal_fence``
3288* ``__c11_atomic_is_lock_free`` (The argument is the size of the
3289  ``_Atomic(...)`` object, instead of its address)
3290* ``__c11_atomic_store``
3291* ``__c11_atomic_load``
3292* ``__c11_atomic_exchange``
3293* ``__c11_atomic_compare_exchange_strong``
3294* ``__c11_atomic_compare_exchange_weak``
3295* ``__c11_atomic_fetch_add``
3296* ``__c11_atomic_fetch_sub``
3297* ``__c11_atomic_fetch_and``
3298* ``__c11_atomic_fetch_or``
3299* ``__c11_atomic_fetch_xor``
3300* ``__c11_atomic_fetch_nand`` (Nand is not presented in ``<stdatomic.h>``)
3301* ``__c11_atomic_fetch_max``
3302* ``__c11_atomic_fetch_min``
3303
3304The macros ``__ATOMIC_RELAXED``, ``__ATOMIC_CONSUME``, ``__ATOMIC_ACQUIRE``,
3305``__ATOMIC_RELEASE``, ``__ATOMIC_ACQ_REL``, and ``__ATOMIC_SEQ_CST`` are
3306provided, with values corresponding to the enumerators of C11's
3307``memory_order`` enumeration.
3308
3309(Note that Clang additionally provides GCC-compatible ``__atomic_*``
3310builtins and OpenCL 2.0 ``__opencl_atomic_*`` builtins. The OpenCL 2.0
3311atomic builtins are an explicit form of the corresponding OpenCL 2.0
3312builtin function, and are named with a ``__opencl_`` prefix. The macros
3313``__OPENCL_MEMORY_SCOPE_WORK_ITEM``, ``__OPENCL_MEMORY_SCOPE_WORK_GROUP``,
3314``__OPENCL_MEMORY_SCOPE_DEVICE``, ``__OPENCL_MEMORY_SCOPE_ALL_SVM_DEVICES``,
3315and ``__OPENCL_MEMORY_SCOPE_SUB_GROUP`` are provided, with values
3316corresponding to the enumerators of OpenCL's ``memory_scope`` enumeration.)
3317
3318Low-level ARM exclusive memory builtins
3319---------------------------------------
3320
3321Clang provides overloaded builtins giving direct access to the three key ARM
3322instructions for implementing atomic operations.
3323
3324.. code-block:: c
3325
3326  T __builtin_arm_ldrex(const volatile T *addr);
3327  T __builtin_arm_ldaex(const volatile T *addr);
3328  int __builtin_arm_strex(T val, volatile T *addr);
3329  int __builtin_arm_stlex(T val, volatile T *addr);
3330  void __builtin_arm_clrex(void);
3331
3332The types ``T`` currently supported are:
3333
3334* Integer types with width at most 64 bits (or 128 bits on AArch64).
3335* Floating-point types
3336* Pointer types.
3337
3338Note that the compiler does not guarantee it will not insert stores which clear
3339the exclusive monitor in between an ``ldrex`` type operation and its paired
3340``strex``. In practice this is only usually a risk when the extra store is on
3341the same cache line as the variable being modified and Clang will only insert
3342stack stores on its own, so it is best not to use these operations on variables
3343with automatic storage duration.
3344
3345Also, loads and stores may be implicit in code written between the ``ldrex`` and
3346``strex``. Clang will not necessarily mitigate the effects of these either, so
3347care should be exercised.
3348
3349For these reasons the higher level atomic primitives should be preferred where
3350possible.
3351
3352Non-temporal load/store builtins
3353--------------------------------
3354
3355Clang provides overloaded builtins allowing generation of non-temporal memory
3356accesses.
3357
3358.. code-block:: c
3359
3360  T __builtin_nontemporal_load(T *addr);
3361  void __builtin_nontemporal_store(T value, T *addr);
3362
3363The types ``T`` currently supported are:
3364
3365* Integer types.
3366* Floating-point types.
3367* Vector types.
3368
3369Note that the compiler does not guarantee that non-temporal loads or stores
3370will be used.
3371
3372C++ Coroutines support builtins
3373--------------------------------
3374
3375.. warning::
3376  This is a work in progress. Compatibility across Clang/LLVM releases is not
3377  guaranteed.
3378
3379Clang provides experimental builtins to support C++ Coroutines as defined by
3380https://wg21.link/P0057. The following four are intended to be used by the
3381standard library to implement the ``std::coroutine_handle`` type.
3382
3383**Syntax**:
3384
3385.. code-block:: c
3386
3387  void  __builtin_coro_resume(void *addr);
3388  void  __builtin_coro_destroy(void *addr);
3389  bool  __builtin_coro_done(void *addr);
3390  void *__builtin_coro_promise(void *addr, int alignment, bool from_promise)
3391
3392**Example of use**:
3393
3394.. code-block:: c++
3395
3396  template <> struct coroutine_handle<void> {
3397    void resume() const { __builtin_coro_resume(ptr); }
3398    void destroy() const { __builtin_coro_destroy(ptr); }
3399    bool done() const { return __builtin_coro_done(ptr); }
3400    // ...
3401  protected:
3402    void *ptr;
3403  };
3404
3405  template <typename Promise> struct coroutine_handle : coroutine_handle<> {
3406    // ...
3407    Promise &promise() const {
3408      return *reinterpret_cast<Promise *>(
3409        __builtin_coro_promise(ptr, alignof(Promise), /*from-promise=*/false));
3410    }
3411    static coroutine_handle from_promise(Promise &promise) {
3412      coroutine_handle p;
3413      p.ptr = __builtin_coro_promise(&promise, alignof(Promise),
3414                                                      /*from-promise=*/true);
3415      return p;
3416    }
3417  };
3418
3419
3420Other coroutine builtins are either for internal clang use or for use during
3421development of the coroutine feature. See `Coroutines in LLVM
3422<https://llvm.org/docs/Coroutines.html#intrinsics>`_ for
3423more information on their semantics. Note that builtins matching the intrinsics
3424that take token as the first parameter (llvm.coro.begin, llvm.coro.alloc,
3425llvm.coro.free and llvm.coro.suspend) omit the token parameter and fill it to
3426an appropriate value during the emission.
3427
3428**Syntax**:
3429
3430.. code-block:: c
3431
3432  size_t __builtin_coro_size()
3433  void  *__builtin_coro_frame()
3434  void  *__builtin_coro_free(void *coro_frame)
3435
3436  void  *__builtin_coro_id(int align, void *promise, void *fnaddr, void *parts)
3437  bool   __builtin_coro_alloc()
3438  void  *__builtin_coro_begin(void *memory)
3439  void   __builtin_coro_end(void *coro_frame, bool unwind)
3440  char   __builtin_coro_suspend(bool final)
3441
3442Note that there is no builtin matching the `llvm.coro.save` intrinsic. LLVM
3443automatically will insert one if the first argument to `llvm.coro.suspend` is
3444token `none`. If a user calls `__builin_suspend`, clang will insert `token none`
3445as the first argument to the intrinsic.
3446
3447Source location builtins
3448------------------------
3449
3450Clang provides builtins to support C++ standard library implementation
3451of ``std::source_location`` as specified in C++20.  With the exception
3452of ``__builtin_COLUMN``, these builtins are also implemented by GCC.
3453
3454**Syntax**:
3455
3456.. code-block:: c
3457
3458  const char *__builtin_FILE();
3459  const char *__builtin_FUNCTION();
3460  unsigned    __builtin_LINE();
3461  unsigned    __builtin_COLUMN(); // Clang only
3462  const std::source_location::__impl *__builtin_source_location();
3463
3464**Example of use**:
3465
3466.. code-block:: c++
3467
3468  void my_assert(bool pred, int line = __builtin_LINE(), // Captures line of caller
3469                 const char* file = __builtin_FILE(),
3470                 const char* function = __builtin_FUNCTION()) {
3471    if (pred) return;
3472    printf("%s:%d assertion failed in function %s\n", file, line, function);
3473    std::abort();
3474  }
3475
3476  struct MyAggregateType {
3477    int x;
3478    int line = __builtin_LINE(); // captures line where aggregate initialization occurs
3479  };
3480  static_assert(MyAggregateType{42}.line == __LINE__);
3481
3482  struct MyClassType {
3483    int line = __builtin_LINE(); // captures line of the constructor used during initialization
3484    constexpr MyClassType(int) { assert(line == __LINE__); }
3485  };
3486
3487**Description**:
3488
3489The builtins ``__builtin_LINE``, ``__builtin_FUNCTION``, and ``__builtin_FILE``
3490return the values, at the "invocation point", for ``__LINE__``,
3491``__FUNCTION__``, and ``__FILE__`` respectively. ``__builtin_COLUMN`` similarly
3492returns the column, though there is no corresponding macro. These builtins are
3493constant expressions.
3494
3495When the builtins appear as part of a default function argument the invocation
3496point is the location of the caller. When the builtins appear as part of a
3497default member initializer, the invocation point is the location of the
3498constructor or aggregate initialization used to create the object. Otherwise
3499the invocation point is the same as the location of the builtin.
3500
3501When the invocation point of ``__builtin_FUNCTION`` is not a function scope the
3502empty string is returned.
3503
3504The builtin ``__builtin_source_location`` returns a pointer to constant static
3505data of type ``std::source_location::__impl``. This type must have already been
3506defined, and must contain exactly four fields: ``const char *_M_file_name``,
3507``const char *_M_function_name``, ``<any-integral-type> _M_line``, and
3508``<any-integral-type> _M_column``. The fields will be populated in the same
3509manner as the above four builtins, except that ``_M_function_name`` is populated
3510with ``__PRETTY_FUNCTION__`` rather than ``__FUNCTION__``.
3511
3512
3513Alignment builtins
3514------------------
3515Clang provides builtins to support checking and adjusting alignment of
3516pointers and integers.
3517These builtins can be used to avoid relying on implementation-defined behavior
3518of arithmetic on integers derived from pointers.
3519Additionally, these builtins retain type information and, unlike bitwise
3520arithmetic, they can perform semantic checking on the alignment value.
3521
3522**Syntax**:
3523
3524.. code-block:: c
3525
3526  Type __builtin_align_up(Type value, size_t alignment);
3527  Type __builtin_align_down(Type value, size_t alignment);
3528  bool __builtin_is_aligned(Type value, size_t alignment);
3529
3530
3531**Example of use**:
3532
3533.. code-block:: c++
3534
3535  char* global_alloc_buffer;
3536  void* my_aligned_allocator(size_t alloc_size, size_t alignment) {
3537    char* result = __builtin_align_up(global_alloc_buffer, alignment);
3538    // result now contains the value of global_alloc_buffer rounded up to the
3539    // next multiple of alignment.
3540    global_alloc_buffer = result + alloc_size;
3541    return result;
3542  }
3543
3544  void* get_start_of_page(void* ptr) {
3545    return __builtin_align_down(ptr, PAGE_SIZE);
3546  }
3547
3548  void example(char* buffer) {
3549     if (__builtin_is_aligned(buffer, 64)) {
3550       do_fast_aligned_copy(buffer);
3551     } else {
3552       do_unaligned_copy(buffer);
3553     }
3554  }
3555
3556  // In addition to pointers, the builtins can also be used on integer types
3557  // and are evaluatable inside constant expressions.
3558  static_assert(__builtin_align_up(123, 64) == 128, "");
3559  static_assert(__builtin_align_down(123u, 64) == 64u, "");
3560  static_assert(!__builtin_is_aligned(123, 64), "");
3561
3562
3563**Description**:
3564
3565The builtins ``__builtin_align_up``, ``__builtin_align_down``, return their
3566first argument aligned up/down to the next multiple of the second argument.
3567If the value is already sufficiently aligned, it is returned unchanged.
3568The builtin ``__builtin_is_aligned`` returns whether the first argument is
3569aligned to a multiple of the second argument.
3570All of these builtins expect the alignment to be expressed as a number of bytes.
3571
3572These builtins can be used for all integer types as well as (non-function)
3573pointer types. For pointer types, these builtins operate in terms of the integer
3574address of the pointer and return a new pointer of the same type (including
3575qualifiers such as ``const``) with an adjusted address.
3576When aligning pointers up or down, the resulting value must be within the same
3577underlying allocation or one past the end (see C17 6.5.6p8, C++ [expr.add]).
3578This means that arbitrary integer values stored in pointer-type variables must
3579not be passed to these builtins. For those use cases, the builtins can still be
3580used, but the operation must be performed on the pointer cast to ``uintptr_t``.
3581
3582If Clang can determine that the alignment is not a power of two at compile time,
3583it will result in a compilation failure. If the alignment argument is not a
3584power of two at run time, the behavior of these builtins is undefined.
3585
3586Non-standard C++11 Attributes
3587=============================
3588
3589Clang's non-standard C++11 attributes live in the ``clang`` attribute
3590namespace.
3591
3592Clang supports GCC's ``gnu`` attribute namespace. All GCC attributes which
3593are accepted with the ``__attribute__((foo))`` syntax are also accepted as
3594``[[gnu::foo]]``. This only extends to attributes which are specified by GCC
3595(see the list of `GCC function attributes
3596<https://gcc.gnu.org/onlinedocs/gcc/Function-Attributes.html>`_, `GCC variable
3597attributes <https://gcc.gnu.org/onlinedocs/gcc/Variable-Attributes.html>`_, and
3598`GCC type attributes
3599<https://gcc.gnu.org/onlinedocs/gcc/Type-Attributes.html>`_). As with the GCC
3600implementation, these attributes must appertain to the *declarator-id* in a
3601declaration, which means they must go either at the start of the declaration or
3602immediately after the name being declared.
3603
3604For example, this applies the GNU ``unused`` attribute to ``a`` and ``f``, and
3605also applies the GNU ``noreturn`` attribute to ``f``.
3606
3607.. code-block:: c++
3608
3609  [[gnu::unused]] int a, f [[gnu::noreturn]] ();
3610
3611Target-Specific Extensions
3612==========================
3613
3614Clang supports some language features conditionally on some targets.
3615
3616ARM/AArch64 Language Extensions
3617-------------------------------
3618
3619Memory Barrier Intrinsics
3620^^^^^^^^^^^^^^^^^^^^^^^^^
3621Clang implements the ``__dmb``, ``__dsb`` and ``__isb`` intrinsics as defined
3622in the `ARM C Language Extensions Release 2.0
3623<http://infocenter.arm.com/help/topic/com.arm.doc.ihi0053c/IHI0053C_acle_2_0.pdf>`_.
3624Note that these intrinsics are implemented as motion barriers that block
3625reordering of memory accesses and side effect instructions. Other instructions
3626like simple arithmetic may be reordered around the intrinsic. If you expect to
3627have no reordering at all, use inline assembly instead.
3628
3629X86/X86-64 Language Extensions
3630------------------------------
3631
3632The X86 backend has these language extensions:
3633
3634Memory references to specified segments
3635^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
3636
3637Annotating a pointer with address space #256 causes it to be code generated
3638relative to the X86 GS segment register, address space #257 causes it to be
3639relative to the X86 FS segment, and address space #258 causes it to be
3640relative to the X86 SS segment.  Note that this is a very very low-level
3641feature that should only be used if you know what you're doing (for example in
3642an OS kernel).
3643
3644Here is an example:
3645
3646.. code-block:: c++
3647
3648  #define GS_RELATIVE __attribute__((address_space(256)))
3649  int foo(int GS_RELATIVE *P) {
3650    return *P;
3651  }
3652
3653Which compiles to (on X86-32):
3654
3655.. code-block:: gas
3656
3657  _foo:
3658          movl    4(%esp), %eax
3659          movl    %gs:(%eax), %eax
3660          ret
3661
3662You can also use the GCC compatibility macros ``__seg_fs`` and ``__seg_gs`` for
3663the same purpose. The preprocessor symbols ``__SEG_FS`` and ``__SEG_GS``
3664indicate their support.
3665
3666PowerPC Language Extensions
3667---------------------------
3668
3669Set the Floating Point Rounding Mode
3670^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
3671PowerPC64/PowerPC64le supports the builtin function ``__builtin_setrnd`` to set
3672the floating point rounding mode. This function will use the least significant
3673two bits of integer argument to set the floating point rounding mode.
3674
3675.. code-block:: c++
3676
3677  double __builtin_setrnd(int mode);
3678
3679The effective values for mode are:
3680
3681    - 0 - round to nearest
3682    - 1 - round to zero
3683    - 2 - round to +infinity
3684    - 3 - round to -infinity
3685
3686Note that the mode argument will modulo 4, so if the integer argument is greater
3687than 3, it will only use the least significant two bits of the mode.
3688Namely, ``__builtin_setrnd(102))`` is equal to ``__builtin_setrnd(2)``.
3689
3690PowerPC cache builtins
3691^^^^^^^^^^^^^^^^^^^^^^
3692
3693The PowerPC architecture specifies instructions implementing cache operations.
3694Clang provides builtins that give direct programmer access to these cache
3695instructions.
3696
3697Currently the following builtins are implemented in clang:
3698
3699``__builtin_dcbf`` copies the contents of a modified block from the data cache
3700to main memory and flushes the copy from the data cache.
3701
3702**Syntax**:
3703
3704.. code-block:: c
3705
3706  void __dcbf(const void* addr); /* Data Cache Block Flush */
3707
3708**Example of Use**:
3709
3710.. code-block:: c
3711
3712  int a = 1;
3713  __builtin_dcbf (&a);
3714
3715Extensions for Static Analysis
3716==============================
3717
3718Clang supports additional attributes that are useful for documenting program
3719invariants and rules for static analysis tools, such as the `Clang Static
3720Analyzer <https://clang-analyzer.llvm.org/>`_. These attributes are documented
3721in the analyzer's `list of source-level annotations
3722<https://clang-analyzer.llvm.org/annotations.html>`_.
3723
3724
3725Extensions for Dynamic Analysis
3726===============================
3727
3728Use ``__has_feature(address_sanitizer)`` to check if the code is being built
3729with :doc:`AddressSanitizer`.
3730
3731Use ``__has_feature(thread_sanitizer)`` to check if the code is being built
3732with :doc:`ThreadSanitizer`.
3733
3734Use ``__has_feature(memory_sanitizer)`` to check if the code is being built
3735with :doc:`MemorySanitizer`.
3736
3737Use ``__has_feature(dataflow_sanitizer)`` to check if the code is being built
3738with :doc:`DataFlowSanitizer`.
3739
3740Use ``__has_feature(safe_stack)`` to check if the code is being built
3741with :doc:`SafeStack`.
3742
3743
3744Extensions for selectively disabling optimization
3745=================================================
3746
3747Clang provides a mechanism for selectively disabling optimizations in functions
3748and methods.
3749
3750To disable optimizations in a single function definition, the GNU-style or C++11
3751non-standard attribute ``optnone`` can be used.
3752
3753.. code-block:: c++
3754
3755  // The following functions will not be optimized.
3756  // GNU-style attribute
3757  __attribute__((optnone)) int foo() {
3758    // ... code
3759  }
3760  // C++11 attribute
3761  [[clang::optnone]] int bar() {
3762    // ... code
3763  }
3764
3765To facilitate disabling optimization for a range of function definitions, a
3766range-based pragma is provided. Its syntax is ``#pragma clang optimize``
3767followed by ``off`` or ``on``.
3768
3769All function definitions in the region between an ``off`` and the following
3770``on`` will be decorated with the ``optnone`` attribute unless doing so would
3771conflict with explicit attributes already present on the function (e.g. the
3772ones that control inlining).
3773
3774.. code-block:: c++
3775
3776  #pragma clang optimize off
3777  // This function will be decorated with optnone.
3778  int foo() {
3779    // ... code
3780  }
3781
3782  // optnone conflicts with always_inline, so bar() will not be decorated.
3783  __attribute__((always_inline)) int bar() {
3784    // ... code
3785  }
3786  #pragma clang optimize on
3787
3788If no ``on`` is found to close an ``off`` region, the end of the region is the
3789end of the compilation unit.
3790
3791Note that a stray ``#pragma clang optimize on`` does not selectively enable
3792additional optimizations when compiling at low optimization levels. This feature
3793can only be used to selectively disable optimizations.
3794
3795The pragma has an effect on functions only at the point of their definition; for
3796function templates, this means that the state of the pragma at the point of an
3797instantiation is not necessarily relevant. Consider the following example:
3798
3799.. code-block:: c++
3800
3801  template<typename T> T twice(T t) {
3802    return 2 * t;
3803  }
3804
3805  #pragma clang optimize off
3806  template<typename T> T thrice(T t) {
3807    return 3 * t;
3808  }
3809
3810  int container(int a, int b) {
3811    return twice(a) + thrice(b);
3812  }
3813  #pragma clang optimize on
3814
3815In this example, the definition of the template function ``twice`` is outside
3816the pragma region, whereas the definition of ``thrice`` is inside the region.
3817The ``container`` function is also in the region and will not be optimized, but
3818it causes the instantiation of ``twice`` and ``thrice`` with an ``int`` type; of
3819these two instantiations, ``twice`` will be optimized (because its definition
3820was outside the region) and ``thrice`` will not be optimized.
3821
3822Clang also implements MSVC's range-based pragma,
3823``#pragma optimize("[optimization-list]", on | off)``. At the moment, Clang only
3824supports an empty optimization list, whereas MSVC supports the arguments, ``s``,
3825``g``, ``t``, and ``y``. Currently, the implementation of ``pragma optimize`` behaves
3826the same as ``#pragma clang optimize``. All functions
3827between ``off`` and ``on`` will be decorated with the ``optnone`` attribute.
3828
3829.. code-block:: c++
3830
3831  #pragma optimize("", off)
3832  // This function will be decorated with optnone.
3833  void f1() {}
3834
3835  #pragma optimize("", on)
3836  // This function will be optimized with whatever was specified on
3837  // the commandline.
3838  void f2() {}
3839
3840  // This will warn with Clang's current implementation.
3841  #pragma optimize("g", on)
3842  void f3() {}
3843
3844For MSVC, an empty optimization list and ``off`` parameter will turn off
3845all optimizations, ``s``, ``g``, ``t``, and ``y``. An empty optimization and
3846``on`` parameter will reset the optimizations to the ones specified on the
3847commandline.
3848
3849.. list-table:: Parameters (unsupported by Clang)
3850
3851   * - Parameter
3852     - Type of optimization
3853   * - g
3854     - Deprecated
3855   * - s or t
3856     - Short or fast sequences of machine code
3857   * - y
3858     - Enable frame pointers
3859
3860Extensions for loop hint optimizations
3861======================================
3862
3863The ``#pragma clang loop`` directive is used to specify hints for optimizing the
3864subsequent for, while, do-while, or c++11 range-based for loop. The directive
3865provides options for vectorization, interleaving, predication, unrolling and
3866distribution. Loop hints can be specified before any loop and will be ignored if
3867the optimization is not safe to apply.
3868
3869There are loop hints that control transformations (e.g. vectorization, loop
3870unrolling) and there are loop hints that set transformation options (e.g.
3871``vectorize_width``, ``unroll_count``).  Pragmas setting transformation options
3872imply the transformation is enabled, as if it was enabled via the corresponding
3873transformation pragma (e.g. ``vectorize(enable)``). If the transformation is
3874disabled  (e.g. ``vectorize(disable)``), that takes precedence over
3875transformations option pragmas implying that transformation.
3876
3877Vectorization, Interleaving, and Predication
3878--------------------------------------------
3879
3880A vectorized loop performs multiple iterations of the original loop
3881in parallel using vector instructions. The instruction set of the target
3882processor determines which vector instructions are available and their vector
3883widths. This restricts the types of loops that can be vectorized. The vectorizer
3884automatically determines if the loop is safe and profitable to vectorize. A
3885vector instruction cost model is used to select the vector width.
3886
3887Interleaving multiple loop iterations allows modern processors to further
3888improve instruction-level parallelism (ILP) using advanced hardware features,
3889such as multiple execution units and out-of-order execution. The vectorizer uses
3890a cost model that depends on the register pressure and generated code size to
3891select the interleaving count.
3892
3893Vectorization is enabled by ``vectorize(enable)`` and interleaving is enabled
3894by ``interleave(enable)``. This is useful when compiling with ``-Os`` to
3895manually enable vectorization or interleaving.
3896
3897.. code-block:: c++
3898
3899  #pragma clang loop vectorize(enable)
3900  #pragma clang loop interleave(enable)
3901  for(...) {
3902    ...
3903  }
3904
3905The vector width is specified by
3906``vectorize_width(_value_[, fixed|scalable])``, where _value_ is a positive
3907integer and the type of vectorization can be specified with an optional
3908second parameter. The default for the second parameter is 'fixed' and
3909refers to fixed width vectorization, whereas 'scalable' indicates the
3910compiler should use scalable vectors instead. Another use of vectorize_width
3911is ``vectorize_width(fixed|scalable)`` where the user can hint at the type
3912of vectorization to use without specifying the exact width. In both variants
3913of the pragma the vectorizer may decide to fall back on fixed width
3914vectorization if the target does not support scalable vectors.
3915
3916The interleave count is specified by ``interleave_count(_value_)``, where
3917_value_ is a positive integer. This is useful for specifying the optimal
3918width/count of the set of target architectures supported by your application.
3919
3920.. code-block:: c++
3921
3922  #pragma clang loop vectorize_width(2)
3923  #pragma clang loop interleave_count(2)
3924  for(...) {
3925    ...
3926  }
3927
3928Specifying a width/count of 1 disables the optimization, and is equivalent to
3929``vectorize(disable)`` or ``interleave(disable)``.
3930
3931Vector predication is enabled by ``vectorize_predicate(enable)``, for example:
3932
3933.. code-block:: c++
3934
3935  #pragma clang loop vectorize(enable)
3936  #pragma clang loop vectorize_predicate(enable)
3937  for(...) {
3938    ...
3939  }
3940
3941This predicates (masks) all instructions in the loop, which allows the scalar
3942remainder loop (the tail) to be folded into the main vectorized loop. This
3943might be more efficient when vector predication is efficiently supported by the
3944target platform.
3945
3946Loop Unrolling
3947--------------
3948
3949Unrolling a loop reduces the loop control overhead and exposes more
3950opportunities for ILP. Loops can be fully or partially unrolled. Full unrolling
3951eliminates the loop and replaces it with an enumerated sequence of loop
3952iterations. Full unrolling is only possible if the loop trip count is known at
3953compile time. Partial unrolling replicates the loop body within the loop and
3954reduces the trip count.
3955
3956If ``unroll(enable)`` is specified the unroller will attempt to fully unroll the
3957loop if the trip count is known at compile time. If the fully unrolled code size
3958is greater than an internal limit the loop will be partially unrolled up to this
3959limit. If the trip count is not known at compile time the loop will be partially
3960unrolled with a heuristically chosen unroll factor.
3961
3962.. code-block:: c++
3963
3964  #pragma clang loop unroll(enable)
3965  for(...) {
3966    ...
3967  }
3968
3969If ``unroll(full)`` is specified the unroller will attempt to fully unroll the
3970loop if the trip count is known at compile time identically to
3971``unroll(enable)``. However, with ``unroll(full)`` the loop will not be unrolled
3972if the loop count is not known at compile time.
3973
3974.. code-block:: c++
3975
3976  #pragma clang loop unroll(full)
3977  for(...) {
3978    ...
3979  }
3980
3981The unroll count can be specified explicitly with ``unroll_count(_value_)`` where
3982_value_ is a positive integer. If this value is greater than the trip count the
3983loop will be fully unrolled. Otherwise the loop is partially unrolled subject
3984to the same code size limit as with ``unroll(enable)``.
3985
3986.. code-block:: c++
3987
3988  #pragma clang loop unroll_count(8)
3989  for(...) {
3990    ...
3991  }
3992
3993Unrolling of a loop can be prevented by specifying ``unroll(disable)``.
3994
3995Loop unroll parameters can be controlled by options
3996`-mllvm -unroll-count=n` and `-mllvm -pragma-unroll-threshold=n`.
3997
3998Loop Distribution
3999-----------------
4000
4001Loop Distribution allows splitting a loop into multiple loops.  This is
4002beneficial for example when the entire loop cannot be vectorized but some of the
4003resulting loops can.
4004
4005If ``distribute(enable))`` is specified and the loop has memory dependencies
4006that inhibit vectorization, the compiler will attempt to isolate the offending
4007operations into a new loop.  This optimization is not enabled by default, only
4008loops marked with the pragma are considered.
4009
4010.. code-block:: c++
4011
4012  #pragma clang loop distribute(enable)
4013  for (i = 0; i < N; ++i) {
4014    S1: A[i + 1] = A[i] + B[i];
4015    S2: C[i] = D[i] * E[i];
4016  }
4017
4018This loop will be split into two loops between statements S1 and S2.  The
4019second loop containing S2 will be vectorized.
4020
4021Loop Distribution is currently not enabled by default in the optimizer because
4022it can hurt performance in some cases.  For example, instruction-level
4023parallelism could be reduced by sequentializing the execution of the
4024statements S1 and S2 above.
4025
4026If Loop Distribution is turned on globally with
4027``-mllvm -enable-loop-distribution``, specifying ``distribute(disable)`` can
4028be used the disable it on a per-loop basis.
4029
4030Additional Information
4031----------------------
4032
4033For convenience multiple loop hints can be specified on a single line.
4034
4035.. code-block:: c++
4036
4037  #pragma clang loop vectorize_width(4) interleave_count(8)
4038  for(...) {
4039    ...
4040  }
4041
4042If an optimization cannot be applied any hints that apply to it will be ignored.
4043For example, the hint ``vectorize_width(4)`` is ignored if the loop is not
4044proven safe to vectorize. To identify and diagnose optimization issues use
4045`-Rpass`, `-Rpass-missed`, and `-Rpass-analysis` command line options. See the
4046user guide for details.
4047
4048Extensions to specify floating-point flags
4049====================================================
4050
4051The ``#pragma clang fp`` pragma allows floating-point options to be specified
4052for a section of the source code. This pragma can only appear at file scope or
4053at the start of a compound statement (excluding comments). When using within a
4054compound statement, the pragma is active within the scope of the compound
4055statement.
4056
4057Currently, the following settings can be controlled with this pragma:
4058
4059``#pragma clang fp reassociate`` allows control over the reassociation
4060of floating point expressions. When enabled, this pragma allows the expression
4061``x + (y + z)`` to be reassociated as ``(x + y) + z``.
4062Reassociation can also occur across multiple statements.
4063This pragma can be used to disable reassociation when it is otherwise
4064enabled for the translation unit with the ``-fassociative-math`` flag.
4065The pragma can take two values: ``on`` and ``off``.
4066
4067.. code-block:: c++
4068
4069  float f(float x, float y, float z)
4070  {
4071    // Enable floating point reassociation across statements
4072    #pragma clang fp reassociate(on)
4073    float t = x + y;
4074    float v = t + z;
4075  }
4076
4077
4078``#pragma clang fp contract`` specifies whether the compiler should
4079contract a multiply and an addition (or subtraction) into a fused FMA
4080operation when supported by the target.
4081
4082The pragma can take three values: ``on``, ``fast`` and ``off``.  The ``on``
4083option is identical to using ``#pragma STDC FP_CONTRACT(ON)`` and it allows
4084fusion as specified the language standard.  The ``fast`` option allows fusion
4085in cases when the language standard does not make this possible (e.g. across
4086statements in C).
4087
4088.. code-block:: c++
4089
4090  for(...) {
4091    #pragma clang fp contract(fast)
4092    a = b[i] * c[i];
4093    d[i] += a;
4094  }
4095
4096
4097The pragma can also be used with ``off`` which turns FP contraction off for a
4098section of the code. This can be useful when fast contraction is otherwise
4099enabled for the translation unit with the ``-ffp-contract=fast-honor-pragmas`` flag.
4100Note that ``-ffp-contract=fast`` will override pragmas to fuse multiply and
4101addition across statements regardless of any controlling pragmas.
4102
4103``#pragma clang fp exceptions`` specifies floating point exception behavior. It
4104may take one of the values: ``ignore``, ``maytrap`` or ``strict``. Meaning of
4105these values is same as for `constrained floating point intrinsics <http://llvm.org/docs/LangRef.html#constrained-floating-point-intrinsics>`_.
4106
4107.. code-block:: c++
4108
4109  {
4110    // Preserve floating point exceptions
4111    #pragma clang fp exceptions(strict)
4112    z = x + y;
4113    if (fetestexcept(FE_OVERFLOW))
4114	  ...
4115  }
4116
4117A ``#pragma clang fp`` pragma may contain any number of options:
4118
4119.. code-block:: c++
4120
4121  void func(float *dest, float a, float b) {
4122    #pragma clang fp exceptions(maytrap) contract(fast) reassociate(on)
4123    ...
4124  }
4125
4126``#pragma clang fp eval_method`` allows floating-point behavior to be specified
4127for a section of the source code. This pragma can appear at file or namespace
4128scope, or at the start of a compound statement (excluding comments).
4129The pragma is active within the scope of the compound statement.
4130
4131When ``pragma clang fp eval_method(source)`` is enabled, the section of code
4132governed by the pragma behaves as though the command-line option
4133``-ffp-eval-method=source`` is enabled. Rounds intermediate results to
4134source-defined precision.
4135
4136When ``pragma clang fp eval_method(double)`` is enabled, the section of code
4137governed by the pragma behaves as though the command-line option
4138``-ffp-eval-method=double`` is enabled. Rounds intermediate results to
4139``double`` precision.
4140
4141When ``pragma clang fp eval_method(extended)`` is enabled, the section of code
4142governed by the pragma behaves as though the command-line option
4143``-ffp-eval-method=extended`` is enabled. Rounds intermediate results to
4144target-dependent ``long double`` precision. In Win32 programming, for instance,
4145the long double data type maps to the double, 64-bit precision data type.
4146
4147The full syntax this pragma supports is
4148``#pragma clang fp eval_method(source|double|extended)``.
4149
4150.. code-block:: c++
4151
4152  for(...) {
4153    // The compiler will use long double as the floating-point evaluation
4154    // method.
4155    #pragma clang fp eval_method(extended)
4156    a = b[i] * c[i] + e;
4157  }
4158
4159The ``#pragma float_control`` pragma allows precise floating-point
4160semantics and floating-point exception behavior to be specified
4161for a section of the source code. This pragma can only appear at file or
4162namespace scope, within a language linkage specification or at the start of a
4163compound statement (excluding comments). When used within a compound statement,
4164the pragma is active within the scope of the compound statement.  This pragma
4165is modeled after a Microsoft pragma with the same spelling and syntax.  For
4166pragmas specified at file or namespace scope, or within a language linkage
4167specification, a stack is supported so that the ``pragma float_control``
4168settings can be pushed or popped.
4169
4170When ``pragma float_control(precise, on)`` is enabled, the section of code
4171governed by the pragma uses precise floating point semantics, effectively
4172``-ffast-math`` is disabled and ``-ffp-contract=on``
4173(fused multiply add) is enabled.
4174
4175When ``pragma float_control(except, on)`` is enabled, the section of code
4176governed by the pragma behaves as though the command-line option
4177``-ffp-exception-behavior=strict`` is enabled,
4178when ``pragma float_control(except, off)`` is enabled, the section of code
4179governed by the pragma behaves as though the command-line option
4180``-ffp-exception-behavior=ignore`` is enabled.
4181
4182The full syntax this pragma supports is
4183``float_control(except|precise, on|off [, push])`` and
4184``float_control(push|pop)``.
4185The ``push`` and ``pop`` forms, including using ``push`` as the optional
4186third argument, can only occur at file scope.
4187
4188.. code-block:: c++
4189
4190  for(...) {
4191    // This block will be compiled with -fno-fast-math and -ffp-contract=on
4192    #pragma float_control(precise, on)
4193    a = b[i] * c[i] + e;
4194  }
4195
4196Specifying an attribute for multiple declarations (#pragma clang attribute)
4197===========================================================================
4198
4199The ``#pragma clang attribute`` directive can be used to apply an attribute to
4200multiple declarations. The ``#pragma clang attribute push`` variation of the
4201directive pushes a new "scope" of ``#pragma clang attribute`` that attributes
4202can be added to. The ``#pragma clang attribute (...)`` variation adds an
4203attribute to that scope, and the ``#pragma clang attribute pop`` variation pops
4204the scope. You can also use ``#pragma clang attribute push (...)``, which is a
4205shorthand for when you want to add one attribute to a new scope. Multiple push
4206directives can be nested inside each other.
4207
4208The attributes that are used in the ``#pragma clang attribute`` directives
4209can be written using the GNU-style syntax:
4210
4211.. code-block:: c++
4212
4213  #pragma clang attribute push (__attribute__((annotate("custom"))), apply_to = function)
4214
4215  void function(); // The function now has the annotate("custom") attribute
4216
4217  #pragma clang attribute pop
4218
4219The attributes can also be written using the C++11 style syntax:
4220
4221.. code-block:: c++
4222
4223  #pragma clang attribute push ([[noreturn]], apply_to = function)
4224
4225  void function(); // The function now has the [[noreturn]] attribute
4226
4227  #pragma clang attribute pop
4228
4229The ``__declspec`` style syntax is also supported:
4230
4231.. code-block:: c++
4232
4233  #pragma clang attribute push (__declspec(dllexport), apply_to = function)
4234
4235  void function(); // The function now has the __declspec(dllexport) attribute
4236
4237  #pragma clang attribute pop
4238
4239A single push directive can contain multiple attributes, however,
4240only one syntax style can be used within a single directive:
4241
4242.. code-block:: c++
4243
4244  #pragma clang attribute push ([[noreturn, noinline]], apply_to = function)
4245
4246  void function1(); // The function now has the [[noreturn]] and [[noinline]] attributes
4247
4248  #pragma clang attribute pop
4249
4250  #pragma clang attribute push (__attribute((noreturn, noinline)), apply_to = function)
4251
4252  void function2(); // The function now has the __attribute((noreturn)) and __attribute((noinline)) attributes
4253
4254  #pragma clang attribute pop
4255
4256Because multiple push directives can be nested, if you're writing a macro that
4257expands to ``_Pragma("clang attribute")`` it's good hygiene (though not
4258required) to add a namespace to your push/pop directives. A pop directive with a
4259namespace will pop the innermost push that has that same namespace. This will
4260ensure that another macro's ``pop`` won't inadvertently pop your attribute. Note
4261that an ``pop`` without a namespace will pop the innermost ``push`` without a
4262namespace. ``push``es with a namespace can only be popped by ``pop`` with the
4263same namespace. For instance:
4264
4265.. code-block:: c++
4266
4267   #define ASSUME_NORETURN_BEGIN _Pragma("clang attribute AssumeNoreturn.push ([[noreturn]], apply_to = function)")
4268   #define ASSUME_NORETURN_END   _Pragma("clang attribute AssumeNoreturn.pop")
4269
4270   #define ASSUME_UNAVAILABLE_BEGIN _Pragma("clang attribute Unavailable.push (__attribute__((unavailable)), apply_to=function)")
4271   #define ASSUME_UNAVAILABLE_END   _Pragma("clang attribute Unavailable.pop")
4272
4273
4274   ASSUME_NORETURN_BEGIN
4275   ASSUME_UNAVAILABLE_BEGIN
4276   void function(); // function has [[noreturn]] and __attribute__((unavailable))
4277   ASSUME_NORETURN_END
4278   void other_function(); // function has __attribute__((unavailable))
4279   ASSUME_UNAVAILABLE_END
4280
4281Without the namespaces on the macros, ``other_function`` will be annotated with
4282``[[noreturn]]`` instead of ``__attribute__((unavailable))``. This may seem like
4283a contrived example, but its very possible for this kind of situation to appear
4284in real code if the pragmas are spread out across a large file. You can test if
4285your version of clang supports namespaces on ``#pragma clang attribute`` with
4286``__has_extension(pragma_clang_attribute_namespaces)``.
4287
4288Subject Match Rules
4289-------------------
4290
4291The set of declarations that receive a single attribute from the attribute stack
4292depends on the subject match rules that were specified in the pragma. Subject
4293match rules are specified after the attribute. The compiler expects an
4294identifier that corresponds to the subject set specifier. The ``apply_to``
4295specifier is currently the only supported subject set specifier. It allows you
4296to specify match rules that form a subset of the attribute's allowed subject
4297set, i.e. the compiler doesn't require all of the attribute's subjects. For
4298example, an attribute like ``[[nodiscard]]`` whose subject set includes
4299``enum``, ``record`` and ``hasType(functionType)``, requires the presence of at
4300least one of these rules after ``apply_to``:
4301
4302.. code-block:: c++
4303
4304  #pragma clang attribute push([[nodiscard]], apply_to = enum)
4305
4306  enum Enum1 { A1, B1 }; // The enum will receive [[nodiscard]]
4307
4308  struct Record1 { }; // The struct will *not* receive [[nodiscard]]
4309
4310  #pragma clang attribute pop
4311
4312  #pragma clang attribute push([[nodiscard]], apply_to = any(record, enum))
4313
4314  enum Enum2 { A2, B2 }; // The enum will receive [[nodiscard]]
4315
4316  struct Record2 { }; // The struct *will* receive [[nodiscard]]
4317
4318  #pragma clang attribute pop
4319
4320  // This is an error, since [[nodiscard]] can't be applied to namespaces:
4321  #pragma clang attribute push([[nodiscard]], apply_to = any(record, namespace))
4322
4323  #pragma clang attribute pop
4324
4325Multiple match rules can be specified using the ``any`` match rule, as shown
4326in the example above. The ``any`` rule applies attributes to all declarations
4327that are matched by at least one of the rules in the ``any``. It doesn't nest
4328and can't be used inside the other match rules. Redundant match rules or rules
4329that conflict with one another should not be used inside of ``any``. Failing to
4330specify a rule within the ``any`` rule results in an error.
4331
4332Clang supports the following match rules:
4333
4334- ``function``: Can be used to apply attributes to functions. This includes C++
4335  member functions, static functions, operators, and constructors/destructors.
4336
4337- ``function(is_member)``: Can be used to apply attributes to C++ member
4338  functions. This includes members like static functions, operators, and
4339  constructors/destructors.
4340
4341- ``hasType(functionType)``: Can be used to apply attributes to functions, C++
4342  member functions, and variables/fields whose type is a function pointer. It
4343  does not apply attributes to Objective-C methods or blocks.
4344
4345- ``type_alias``: Can be used to apply attributes to ``typedef`` declarations
4346  and C++11 type aliases.
4347
4348- ``record``: Can be used to apply attributes to ``struct``, ``class``, and
4349  ``union`` declarations.
4350
4351- ``record(unless(is_union))``: Can be used to apply attributes only to
4352  ``struct`` and ``class`` declarations.
4353
4354- ``enum``: Can be be used to apply attributes to enumeration declarations.
4355
4356- ``enum_constant``: Can be used to apply attributes to enumerators.
4357
4358- ``variable``: Can be used to apply attributes to variables, including
4359  local variables, parameters, global variables, and static member variables.
4360  It does not apply attributes to instance member variables or Objective-C
4361  ivars.
4362
4363- ``variable(is_thread_local)``: Can be used to apply attributes to thread-local
4364  variables only.
4365
4366- ``variable(is_global)``: Can be used to apply attributes to global variables
4367  only.
4368
4369- ``variable(is_local)``: Can be used to apply attributes to local variables
4370  only.
4371
4372- ``variable(is_parameter)``: Can be used to apply attributes to parameters
4373  only.
4374
4375- ``variable(unless(is_parameter))``: Can be used to apply attributes to all
4376  the variables that are not parameters.
4377
4378- ``field``: Can be used to apply attributes to non-static member variables
4379  in a record. This includes Objective-C ivars.
4380
4381- ``namespace``: Can be used to apply attributes to ``namespace`` declarations.
4382
4383- ``objc_interface``: Can be used to apply attributes to ``@interface``
4384  declarations.
4385
4386- ``objc_protocol``: Can be used to apply attributes to ``@protocol``
4387  declarations.
4388
4389- ``objc_category``: Can be used to apply attributes to category declarations,
4390  including class extensions.
4391
4392- ``objc_method``: Can be used to apply attributes to Objective-C methods,
4393  including instance and class methods. Implicit methods like implicit property
4394  getters and setters do not receive the attribute.
4395
4396- ``objc_method(is_instance)``: Can be used to apply attributes to Objective-C
4397  instance methods.
4398
4399- ``objc_property``: Can be used to apply attributes to ``@property``
4400  declarations.
4401
4402- ``block``: Can be used to apply attributes to block declarations. This does
4403  not include variables/fields of block pointer type.
4404
4405The use of ``unless`` in match rules is currently restricted to a strict set of
4406sub-rules that are used by the supported attributes. That means that even though
4407``variable(unless(is_parameter))`` is a valid match rule,
4408``variable(unless(is_thread_local))`` is not.
4409
4410Supported Attributes
4411--------------------
4412
4413Not all attributes can be used with the ``#pragma clang attribute`` directive.
4414Notably, statement attributes like ``[[fallthrough]]`` or type attributes
4415like ``address_space`` aren't supported by this directive. You can determine
4416whether or not an attribute is supported by the pragma by referring to the
4417:doc:`individual documentation for that attribute <AttributeReference>`.
4418
4419The attributes are applied to all matching declarations individually, even when
4420the attribute is semantically incorrect. The attributes that aren't applied to
4421any declaration are not verified semantically.
4422
4423Specifying section names for global objects (#pragma clang section)
4424===================================================================
4425
4426The ``#pragma clang section`` directive provides a means to assign section-names
4427to global variables, functions and static variables.
4428
4429The section names can be specified as:
4430
4431.. code-block:: c++
4432
4433  #pragma clang section bss="myBSS" data="myData" rodata="myRodata" relro="myRelro" text="myText"
4434
4435The section names can be reverted back to default name by supplying an empty
4436string to the section kind, for example:
4437
4438.. code-block:: c++
4439
4440  #pragma clang section bss="" data="" text="" rodata="" relro=""
4441
4442The ``#pragma clang section`` directive obeys the following rules:
4443
4444* The pragma applies to all global variable, statics and function declarations
4445  from the pragma to the end of the translation unit.
4446
4447* The pragma clang section is enabled automatically, without need of any flags.
4448
4449* This feature is only defined to work sensibly for ELF targets.
4450
4451* If section name is specified through _attribute_((section("myname"))), then
4452  the attribute name gains precedence.
4453
4454* Global variables that are initialized to zero will be placed in the named
4455  bss section, if one is present.
4456
4457* The ``#pragma clang section`` directive does not does try to infer section-kind
4458  from the name. For example, naming a section "``.bss.mySec``" does NOT mean
4459  it will be a bss section name.
4460
4461* The decision about which section-kind applies to each global is taken in the back-end.
4462  Once the section-kind is known, appropriate section name, as specified by the user using
4463  ``#pragma clang section`` directive, is applied to that global.
4464
4465Specifying Linker Options on ELF Targets
4466========================================
4467
4468The ``#pragma comment(lib, ...)`` directive is supported on all ELF targets.
4469The second parameter is the library name (without the traditional Unix prefix of
4470``lib``).  This allows you to provide an implicit link of dependent libraries.
4471
4472Evaluating Object Size Dynamically
4473==================================
4474
4475Clang supports the builtin ``__builtin_dynamic_object_size``, the semantics are
4476the same as GCC's ``__builtin_object_size`` (which Clang also supports), but
4477``__builtin_dynamic_object_size`` can evaluate the object's size at runtime.
4478``__builtin_dynamic_object_size`` is meant to be used as a drop-in replacement
4479for ``__builtin_object_size`` in libraries that support it.
4480
4481For instance, here is a program that ``__builtin_dynamic_object_size`` will make
4482safer:
4483
4484.. code-block:: c
4485
4486  void copy_into_buffer(size_t size) {
4487    char* buffer = malloc(size);
4488    strlcpy(buffer, "some string", strlen("some string"));
4489    // Previous line preprocesses to:
4490    // __builtin___strlcpy_chk(buffer, "some string", strlen("some string"), __builtin_object_size(buffer, 0))
4491  }
4492
4493Since the size of ``buffer`` can't be known at compile time, Clang will fold
4494``__builtin_object_size(buffer, 0)`` into ``-1``. However, if this was written
4495as ``__builtin_dynamic_object_size(buffer, 0)``, Clang will fold it into
4496``size``, providing some extra runtime safety.
4497
4498Deprecating Macros
4499==================
4500
4501Clang supports the pragma ``#pragma clang deprecated``, which can be used to
4502provide deprecation warnings for macro uses. For example:
4503
4504.. code-block:: c
4505
4506   #define MIN(x, y) x < y ? x : y
4507   #pragma clang deprecated(MIN, "use std::min instead")
4508
4509   void min(int a, int b) {
4510     return MIN(a, b); // warning: MIN is deprecated: use std::min instead
4511   }
4512
4513``#pragma clang deprecated`` should be preferred for this purpose over
4514``#pragma GCC warning`` because the warning can be controlled with
4515``-Wdeprecated``.
4516
4517Restricted Expansion Macros
4518===========================
4519
4520Clang supports the pragma ``#pragma clang restrict_expansion``, which can be
4521used restrict macro expansion in headers. This can be valuable when providing
4522headers with ABI stability requirements. Any expansion of the annotated macro
4523processed by the preprocessor after the ``#pragma`` annotation will log a
4524warning. Redefining the macro or undefining the macro will not be diagnosed, nor
4525will expansion of the macro within the main source file. For example:
4526
4527.. code-block:: c
4528
4529   #define TARGET_ARM 1
4530   #pragma clang restrict_expansion(TARGET_ARM, "<reason>")
4531
4532   /// Foo.h
4533   struct Foo {
4534   #if TARGET_ARM // warning: TARGET_ARM is marked unsafe in headers: <reason>
4535     uint32_t X;
4536   #else
4537     uint64_t X;
4538   #endif
4539   };
4540
4541   /// main.c
4542   #include "foo.h"
4543   #if TARGET_ARM // No warning in main source file
4544   X_TYPE uint32_t
4545   #else
4546   X_TYPE uint64_t
4547   #endif
4548
4549This warning is controlled by ``-Wpedantic-macros``.
4550
4551Final Macros
4552============
4553
4554Clang supports the pragma ``#pragma clang final``, which can be used to
4555mark macros as final, meaning they cannot be undef'd or re-defined. For example:
4556
4557.. code-block:: c
4558
4559   #define FINAL_MACRO 1
4560   #pragma clang final(FINAL_MACRO)
4561
4562   #define FINAL_MACRO // warning: FINAL_MACRO is marked final and should not be redefined
4563   #undef FINAL_MACRO  // warning: FINAL_MACRO is marked final and should not be undefined
4564
4565This is useful for enforcing system-provided macros that should not be altered
4566in user headers or code. This is controlled by ``-Wpedantic-macros``. Final
4567macros will always warn on redefinition, including situations with identical
4568bodies and in system headers.
4569
4570Line Control
4571============
4572
4573Clang supports an extension for source line control, which takes the
4574form of a preprocessor directive starting with an unsigned integral
4575constant. In addition to the standard ``#line`` directive, this form
4576allows control of an include stack and header file type, which is used
4577in issuing diagnostics. These lines are emitted in preprocessed
4578output.
4579
4580.. code-block:: c
4581
4582   # <line:number> <filename:string> <header-type:numbers>
4583
4584The filename is optional, and if unspecified indicates no change in
4585source filename. The header-type is an optional, whitespace-delimited,
4586sequence of magic numbers as follows.
4587
4588* ``1:`` Push the current source file name onto the include stack and
4589  enter a new file.
4590
4591* ``2``: Pop the include stack and return to the specified file. If
4592  the filename is ``""``, the name popped from the include stack is
4593  used. Otherwise there is no requirement that the specified filename
4594  matches the current source when originally pushed.
4595
4596* ``3``: Enter a system-header region. System headers often contain
4597  implementation-specific source that would normally emit a diagnostic.
4598
4599* ``4``: Enter an implicit ``extern "C"`` region. This is not required on
4600  modern systems where system headers are C++-aware.
4601
4602At most a single ``1`` or ``2`` can be present, and values must be in
4603ascending order.
4604
4605Examples are:
4606
4607.. code-block:: c
4608
4609   # 57 // Advance (or return) to line 57 of the current source file
4610   # 57 "frob" // Set to line 57 of "frob"
4611   # 1 "foo.h" 1 // Enter "foo.h" at line 1
4612   # 59 "main.c" 2 // Leave current include and return to "main.c"
4613   # 1 "/usr/include/stdio.h" 1 3 // Enter a system header
4614   # 60 "" 2 // return to "main.c"
4615   # 1 "/usr/ancient/header.h" 1 4 // Enter an implicit extern "C" header
4616
4617Extended Integer Types
4618======================
4619
4620Clang supports the C23 ``_BitInt(N)`` feature as an extension in older C modes
4621and in C++. This type was previously implemented in Clang with the same
4622semantics, but spelled ``_ExtInt(N)``. This spelling has been deprecated in
4623favor of the standard type.
4624
4625Note: the ABI for ``_BitInt(N)`` is still in the process of being stabilized,
4626so this type should not yet be used in interfaces that require ABI stability.
4627
4628Intrinsics Support within Constant Expressions
4629==============================================
4630
4631The following builtin intrinsics can be used in constant expressions:
4632
4633* ``__builtin_bitreverse8``
4634* ``__builtin_bitreverse16``
4635* ``__builtin_bitreverse32``
4636* ``__builtin_bitreverse64``
4637* ``__builtin_bswap16``
4638* ``__builtin_bswap32``
4639* ``__builtin_bswap64``
4640* ``__builtin_clrsb``
4641* ``__builtin_clrsbl``
4642* ``__builtin_clrsbll``
4643* ``__builtin_clz``
4644* ``__builtin_clzl``
4645* ``__builtin_clzll``
4646* ``__builtin_clzs``
4647* ``__builtin_ctz``
4648* ``__builtin_ctzl``
4649* ``__builtin_ctzll``
4650* ``__builtin_ctzs``
4651* ``__builtin_ffs``
4652* ``__builtin_ffsl``
4653* ``__builtin_ffsll``
4654* ``__builtin_fpclassify``
4655* ``__builtin_inf``
4656* ``__builtin_isinf``
4657* ``__builtin_isinf_sign``
4658* ``__builtin_isfinite``
4659* ``__builtin_isnan``
4660* ``__builtin_isnormal``
4661* ``__builtin_nan``
4662* ``__builtin_nans``
4663* ``__builtin_parity``
4664* ``__builtin_parityl``
4665* ``__builtin_parityll``
4666* ``__builtin_popcount``
4667* ``__builtin_popcountl``
4668* ``__builtin_popcountll``
4669* ``__builtin_rotateleft8``
4670* ``__builtin_rotateleft16``
4671* ``__builtin_rotateleft32``
4672* ``__builtin_rotateleft64``
4673* ``__builtin_rotateright8``
4674* ``__builtin_rotateright16``
4675* ``__builtin_rotateright32``
4676* ``__builtin_rotateright64``
4677
4678The following x86-specific intrinsics can be used in constant expressions:
4679
4680* ``_bit_scan_forward``
4681* ``_bit_scan_reverse``
4682* ``__bsfd``
4683* ``__bsfq``
4684* ``__bsrd``
4685* ``__bsrq``
4686* ``__bswap``
4687* ``__bswapd``
4688* ``__bswap64``
4689* ``__bswapq``
4690* ``_castf32_u32``
4691* ``_castf64_u64``
4692* ``_castu32_f32``
4693* ``_castu64_f64``
4694* ``_mm_popcnt_u32``
4695* ``_mm_popcnt_u64``
4696* ``_popcnt32``
4697* ``_popcnt64``
4698* ``__popcntd``
4699* ``__popcntq``
4700* ``__rolb``
4701* ``__rolw``
4702* ``__rold``
4703* ``__rolq``
4704* ``__rorb``
4705* ``__rorw``
4706* ``__rord``
4707* ``__rorq``
4708* ``_rotl``
4709* ``_rotr``
4710* ``_rotwl``
4711* ``_rotwr``
4712* ``_lrotl``
4713* ``_lrotr``
4714