[AMDGPU][AsmParser][NFC] Get rid of custom default operand handlers.
[llvm-project.git] / clang / docs / ReleaseNotes.rst
blob6bfd77cc91028250c9485e797056704e7c4f6ba4
1 ===========================================
2 Clang |release| |ReleaseNotesTitle|
3 ===========================================
5 .. contents::
6    :local:
7    :depth: 2
9 Written by the `LLVM Team <https://llvm.org/>`_
11 .. only:: PreRelease
13   .. warning::
14      These are in-progress notes for the upcoming Clang |version| release.
15      Release notes for previous releases can be found on
16      `the Releases Page <https://llvm.org/releases/>`_.
18 Introduction
19 ============
21 This document contains the release notes for the Clang C/C++/Objective-C
22 frontend, part of the LLVM Compiler Infrastructure, release |release|. Here we
23 describe the status of Clang in some detail, including major
24 improvements from the previous release and new feature work. For the
25 general LLVM release notes, see `the LLVM
26 documentation <https://llvm.org/docs/ReleaseNotes.html>`_. For the libc++ release notes,
27 see `this page <https://libcxx.llvm.org/ReleaseNotes.html>`_. All LLVM releases
28 may be downloaded from the `LLVM releases web site <https://llvm.org/releases/>`_.
30 For more information about Clang or LLVM, including information about the
31 latest release, please see the `Clang Web Site <https://clang.llvm.org>`_ or the
32 `LLVM Web Site <https://llvm.org>`_.
34 Potentially Breaking Changes
35 ============================
36 These changes are ones which we think may surprise users when upgrading to
37 Clang |release| because of the opportunity they pose for disruption to existing
38 code bases.
41 C/C++ Language Potentially Breaking Changes
42 -------------------------------------------
43 - Indirect edges of asm goto statements under certain circumstances may now be
44   split. In previous releases of clang, that means for the following code the
45   two inputs may have compared equal in the inline assembly.  This is no longer
46   guaranteed (and necessary to support outputs along indirect edges, which is
47   now supported as of this release). This change is more consistent with the
48   behavior of GCC.
50   .. code-block:: c
52     foo: asm goto ("# %0 %1"::"i"(&&foo)::foo);
54 - ``__builtin_object_size`` and ``__builtin_dynamic_object_size`` now add the
55   ``sizeof`` the elements specified in designated initializers of flexible
56   array members for structs that contain them. This change is more consistent
57   with the behavior of GCC.
59 C++ Specific Potentially Breaking Changes
60 -----------------------------------------
61 - Clang won't search for coroutine_traits in std::experimental namespace any more.
62   Clang will only search for std::coroutine_traits for coroutines then.
63 - Clang no longer allows dereferencing of a ``void *`` as an extension. Clang 16
64   converted this to a default-error as ``-Wvoid-ptr-dereference``, as well as a
65   SFINAE error. This flag is still valid however, as it disables the equivalent
66   warning in C.
68 ABI Changes in This Version
69 ---------------------------
70 - A bug in evaluating the ineligibility of some special member functions has been fixed. This can
71   make some classes trivially copyable that were not trivially copyable before. (`#62555 <https://github.com/llvm/llvm-project/issues/62555>`_)
73 What's New in Clang |release|?
74 ==============================
75 Some of the major new features and improvements to Clang are listed
76 here. Generic improvements to Clang as a whole or to its underlying
77 infrastructure are described first, followed by language-specific
78 sections with improvements to Clang's support for those languages.
80 C++ Language Changes
81 --------------------
82 - Improved ``-O0`` code generation for calls to ``std::forward_like``. Similarly to
83   ``std::move, std::forward`` et al. it is now treated as a compiler builtin and implemented
84   directly rather than instantiating the definition from the standard library.
85 - Implemented `CWG2518 <https://wg21.link/CWG2518>`_ which allows ``static_assert(false)``
86   to not be ill-formed when its condition is evaluated in the context of a template definition.
88 C++20 Feature Support
89 ^^^^^^^^^^^^^^^^^^^^^
90 - Implemented the rule introduced by `CA104 <https://wg21.link/P2103R0>`_  for comparison of
91   constraint-expressions. Improved support for out-of-line definitions of constrained templates.
92   This fixes:
93   `#49620 <https://github.com/llvm/llvm-project/issues/49620>`_,
94   `#60231 <https://github.com/llvm/llvm-project/issues/60231>`_,
95   `#61414 <https://github.com/llvm/llvm-project/issues/61414>`_,
96   `#61809 <https://github.com/llvm/llvm-project/issues/61809>`_.
97 - Lambda templates with a requires clause directly after the template parameters now parse
98   correctly if the requires clause consists of a variable with a dependent type.
99   (`#61278 <https://github.com/llvm/llvm-project/issues/61278>`_)
100 - Announced C++20 Coroutines is fully supported on all targets except Windows, which
101   still has some stability and ABI issues.
102 - Downgraded use of a reserved identifier in a module export declaration from
103   an error to a warning under the ``-Wreserved-module-identifier`` warning
104   group. This warning is enabled by default. This addresses `#61446
105   <https://github.com/llvm/llvm-project/issues/61446>`_ and allows easier
106   building of standard modules. This diagnostic may be strengthened into an
107   error again in the future once there is a less fragile way to mark a module
108   as being part of the implementation rather than a user module.
109 - Clang now implements `[temp.deduct]p9`. Substitution failures inside lambdas from
110   unevaluated contexts will be surfaced as errors. They were previously handled as
111   SFINAE.
112 - Clang now supports `requires cplusplus20` for module maps.
113 - Implemented missing parts of `P2002R1: Consistent comparison operators <https://wg21.link/P2002R1>`_
114 - Clang now defines `__cpp_consteval` macro.
116 C++23 Feature Support
117 ^^^^^^^^^^^^^^^^^^^^^
119 - Implemented `P2036R3: Change scope of lambda trailing-return-type <https://wg21.link/P2036R3>`_
120   and `P2579R0 Mitigation strategies for P2036 <https://wg21.link/P2579R0>`_.
121   These proposals modify how variables captured in lambdas can appear in trailing return type
122   expressions and how their types are deduced therein, in all C++ language versions.
123 - Implemented partial support for `P2448R2: Relaxing some constexpr restrictions <https://wg21.link/p2448r2>`_
124   Explicitly defaulted functions no longer have to be constexpr-compatible but merely constexpr suitable.
125   We do not support outside of defaulted special memeber functions the change that constexpr functions no
126   longer have to be constexpr compatible but rather support a less restricted requirements for constexpr
127   functions. Which include allowing non-literal types as return values and parameters, allow calling of
128   non-constexpr functions and constructors.
129 - Clang now supports `requires cplusplus23` for module maps.
130 - Implemented `P2564R3: consteval needs to propagate up <https://wg21.link/P2564R3>`_.
132 C++2c Feature Support
133 ^^^^^^^^^^^^^^^^^^^^^
134 - Compiler flags ``-std=c++2c`` and ``-std=gnu++2c`` have been added for experimental C++2c implementation work.
136 Resolutions to C++ Defect Reports
137 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
138 - Implemented `DR2397 <https://wg21.link/CWG2397>`_ which allows ``auto`` specifier for pointers
139   and reference to arrays.
141 C Language Changes
142 ------------------
143 - Support for outputs from asm goto statements along indirect edges has been
144   added. (`#53562 <https://github.com/llvm/llvm-project/issues/53562>`_)
145 - Fixed a bug that prevented initialization of an ``_Atomic``-qualified pointer
146   from a null pointer constant.
147 - Fixed a bug that prevented casting to an ``_Atomic``-qualified type.
148   (`#39596 <https://github.com/llvm/llvm-project/issues/39596>`_)
149 - Added an extension to ``_Generic`` which allows the first operand to be a
150   type rather than an expression. The type does not undergo any conversions,
151   which makes this feature suitable for matching qualified types, incomplete
152   types, and function or array types.
154   .. code-block:: c
156     const int i = 12;
157     _Generic(i, int : 0, const int : 1); // Warns about unreachable code, the
158                                          // result is 0, not 1.
159     _Generic(typeof(i), int : 0, const int : 1); // Result is 1, not 0.
161 C2x Feature Support
162 ^^^^^^^^^^^^^^^^^^^
163 - Implemented the ``unreachable`` macro in freestanding ``<stddef.h>`` for
164   `WG14 N2826 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2826.pdf>`_
166 - Removed the ``ATOMIC_VAR_INIT`` macro in C2x and later standards modes, which
167   implements `WG14 N2886 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2886.htm>`_
169 - Implemented `WG14 N2934 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2934.pdf>`_
170   which introduces the ``bool``, ``static_assert``, ``alignas``, ``alignof``,
171   and ``thread_local`` keywords in C2x.
173 - Implemented `WG14 N2900 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2900.htm>`_
174   and `WG14 N3011 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3011.htm>`_
175   which allows for empty braced initialization in C.
177   .. code-block:: c
179     struct S { int x, y } s = {}; // Initializes s.x and s.y to 0
181   As part of this change, the ``-Wgnu-empty-initializer`` warning group was
182   removed, as this is no longer a GNU extension but a C2x extension. You can
183   use ``-Wno-c2x-extensions`` to silence the extension warning instead.
185 - Updated the implementation of
186   `WG14 N3042 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3042.htm>`_
187   based on decisions reached during the WG14 CD Ballot Resolution meetings held
188   in Jan and Feb 2023. This should complete the implementation of ``nullptr``
189   and ``nullptr_t`` in C. The specific changes are:
191   .. code-block:: c
193     void func(nullptr_t);
194     func(0); // Previously required to be rejected, is now accepted.
195     func((void *)0); // Previously required to be rejected, is now accepted.
197     nullptr_t val;
198     val = 0; // Previously required to be rejected, is now accepted.
199     val = (void *)0; // Previously required to be rejected, is now accepted.
201     bool b = nullptr; // Was incorrectly rejected by Clang, is now accepted.
204 Non-comprehensive list of changes in this release
205 -------------------------------------------------
206 - Clang now saves the address of ABI-indirect function parameters on the stack,
207   improving the debug information available in programs compiled without
208   optimizations.
209 - Clang now supports ``__builtin_nondeterministic_value`` that returns a
210   nondeterministic value of the same type as the provided argument.
211 - Clang now supports ``__builtin_FILE_NAME()`` which returns the same
212   information as the ``__FILE_NAME__`` macro (the presumed file name
213   from the invocation point, with no path components included).
214 - Clang now supports ``__builtin_assume_separate_storage`` that indicates that
215   its arguments point to objects in separate storage allocations.
216 - Clang now supports expressions in ``#pragma clang __debug dump``.
217 - Clang now supports declaration of multi-dimensional arrays with
218   ``__declspec(property)``.
219 - A new builtin type trait ``__is_trivially_equality_comparable`` has been added,
220   which checks whether comparing two instances of a type is equivalent to
221   ``memcmp(&lhs, &rhs, sizeof(T)) == 0``.
222 - Clang now ignores null directives outside of the include guard when deciding
223   whether a file can be enabled for the multiple-include optimization.
224 - Clang now support ``__builtin_FUNCSIG()`` which returns the same information
225   as the ``__FUNCSIG__`` macro (available only with ``-fms-extensions`` flag).
226   This fixes (`#58951 <https://github.com/llvm/llvm-project/issues/58951>`_).
227 - Clang now supports the `NO_COLOR <https://no-color.org/>`_ environment
228   variable as a way to disable color diagnostics.
230 New Compiler Flags
231 ------------------
232 - The flag ``-std=c++23`` has been added. This behaves the same as the existing
233   flag ``-std=c++2b``.
234 - ``-dumpdir`` has been implemented to specify auxiliary and dump output
235   filenames for features like ``-gsplit-dwarf``.
236 - ``-fcaret-diagnostics-max-lines=`` has been added as a driver options, which
237   lets users control the maximum number of source lines printed for a
238   caret diagnostic.
240 Deprecated Compiler Flags
241 -------------------------
243 Modified Compiler Flags
244 -----------------------
246 - ``clang -g -gsplit-dwarf a.c -o obj/x`` (compile and link) now generates the
247   ``.dwo`` file at ``obj/x-a.dwo``, instead of a file in the temporary
248   directory (``/tmp`` on \*NIX systems, if none of the environment variables
249   TMPDIR, TMP, and TEMP are specified).
251 Removed Compiler Flags
252 -------------------------
253 - The deprecated flag `-fmodules-ts` is removed. Please use ``-std=c++20``
254   or higher to use standard C++ modules instead.
255 - The deprecated flag `-fcoroutines-ts` is removed. Please use ``-std=c++20``
256   or higher to use standard C++ coroutines instead.
257 - The CodeGen flag `-lower-global-dtors-via-cxa-atexit` which affects how global
258   destructors are lowered for MachO is removed without replacement. The default
259   of `-lower-global-dtors-via-cxa-atexit=true` is now the only supported way.
260 - The cc1 flag ``-no-opaque-pointers`` has been removed.
262 Attribute Changes in Clang
263 --------------------------
264 - Introduced a new function attribute ``__attribute__((unsafe_buffer_usage))``
265   to be worn by functions containing buffer operations that could cause out of
266   bounds memory accesses. It emits warnings at call sites to such functions when
267   the flag ``-Wunsafe-buffer-usage`` is enabled.
268 - ``__declspec`` attributes can now be used together with the using keyword. Before
269   the attributes on ``__declspec`` was ignored, while now it will be forwarded to the
270   point where the alias is used.
271 - Introduced a new ``USR`` (unified symbol resolution) clause inside of the
272   existing ``__attribute__((external_source_symbol))`` attribute. Clang's indexer
273   uses the optional USR value when indexing Clang's AST. This value is expected
274   to be generated by an external compiler when generating C++ bindings during
275   the compilation of the foreign language sources (e.g. Swift).
276 - The ``__has_attribute``, ``__has_c_attribute`` and ``__has_cpp_attribute``
277   preprocessor operators now return 1 also for attributes defined by plugins.
278 - Improve the AST fidelity of ``alignas`` and ``_Alignas`` attribute. Before, we
279   model ``alignas(type-id)`` as though the user wrote ``alignas(alignof(type-id))``,
280   now we directly use ``alignas(type-id)``.
282 Improvements to Clang's diagnostics
283 -----------------------------------
284 - We now generate a diagnostic for signed integer overflow due to unary minus
285   in a non-constant expression context.
286   (`#31643 <https://github.com/llvm/llvm-project/issues/31643>`_)
287 - Clang now warns by default for C++20 and later about deprecated capture of
288   ``this`` with a capture default of ``=``. This warning can be disabled with
289   ``-Wno-deprecated-this-capture``.
290 - Clang had failed to emit some ``-Wundefined-internal`` for members of a local
291   class if that class was first introduced with a forward declaration.
292 - Diagnostic notes and fix-its are now generated for ``ifunc``/``alias`` attributes
293   which point to functions whose names are mangled.
294 - Diagnostics relating to macros on the command line of a preprocessed assembly
295   file or precompiled header are now reported as coming from the file
296   ``<command line>`` instead of ``<built-in>``.
297 - Clang constexpr evaluator now provides a more concise diagnostic when calling
298   function pointer that is known to be null.
299 - Clang now avoids duplicate warnings on unreachable ``[[fallthrough]];`` statements
300   previously issued from ``-Wunreachable-code`` and ``-Wunreachable-code-fallthrough``
301   by prioritizing ``-Wunreachable-code-fallthrough``.
302 - Clang now correctly diagnoses statement attributes ``[[clang::always_inline]]`` and
303   ``[[clang::noinline]]`` when used on a statement with dependent call expressions.
304 - Clang now checks for completeness of the second and third arguments in the
305   conditional operator.
306   (`#59718 <https://github.com/llvm/llvm-project/issues/59718>`_)
307 - There were some cases in which the diagnostic for the unavailable attribute
308   might not be issued, this fixes those cases.
309   (`61815 <https://github.com/llvm/llvm-project/issues/61815>`_)
310 - Clang now avoids unnecessary diagnostic warnings for obvious expressions in
311   the case of binary operators with logical OR operations.
312   (`#57906 <https://github.com/llvm/llvm-project/issues/57906>`_)
313 - Clang's "static assertion failed" diagnostic now points to the static assertion
314   expression instead of pointing to the ``static_assert`` token.
315   (`#61951 <https://github.com/llvm/llvm-project/issues/61951>`_)
316 - ``-Wformat`` now recognizes ``%lb`` for the ``printf``/``scanf`` family of
317   functions.
318   (`#62247: <https://github.com/llvm/llvm-project/issues/62247>`_).
319 - Clang now diagnoses shadowing of lambda's template parameter by a capture.
320   (`#61105: <https://github.com/llvm/llvm-project/issues/61105>`_).
321 - Address a false positive in ``-Wpacked`` when applied to a non-pod type using
322   Clang ABI >= 15.
323   (`#62353: <https://github.com/llvm/llvm-project/issues/62353>`_,
324   fallout from the non-POD packing ABI fix in LLVM 15).
325 - Clang constexpr evaluator now prints subobject's name instead of its type in notes
326   when a constexpr variable has uninitialized subobjects after its constructor call.
327   (`#58601 <https://github.com/llvm/llvm-project/issues/58601>`_)
328 - Clang's `-Wshadow` warning now warns about shadowings by static local variables
329   (`#62850: <https://github.com/llvm/llvm-project/issues/62850>`_).
330 - Clang now warns when any predefined macro is undefined or redefined, instead
331   of only some of them.
332 - Clang now correctly diagnoses when the argument to ``alignas`` or ``_Alignas``
333   is an incomplete type.
334   (`#55175: <https://github.com/llvm/llvm-project/issues/55175>`_, and fixes an
335   incorrect mention of ``alignof`` in a diagnostic about ``alignas``).
336 - Clang will now show a margin with line numbers to the left of each line
337   of code it prints for diagnostics. This can be disabled using
338   ``-fno-diagnostics-show-line-numbers``. At the same time, the maximum
339   number of code lines it prints has been increased from 1 to 16. This
340   can be controlled using ``-fcaret-diagnostics-max-lines=``.
341 - Clang no longer emits ``-Wunused-variable`` warnings for variables declared
342   with ``__attribute__((cleanup(...)))`` to match GCC's behavior.
344 Bug Fixes in This Version
345 -------------------------
347 - Fix segfault while running clang-rename on a non existing file.
348   (`#36471 <https://github.com/llvm/llvm-project/issues/36471>`_)
349 - Fix crash when diagnosing incorrect usage of ``_Nullable`` involving alias
350   templates.
351   (`#60344 <https://github.com/llvm/llvm-project/issues/60344>`_)
352 - Fix confusing warning message when ``/clang:-x`` is passed in ``clang-cl``
353   driver mode and emit an error which suggests using ``/TC`` or ``/TP``
354   ``clang-cl`` options instead.
355   (`#59307 <https://github.com/llvm/llvm-project/issues/59307>`_)
356 - Fix assert that fails when the expression causing the this pointer to be
357   captured by a block is part of a constexpr if statement's branch and
358   instantiation of the enclosing method causes the branch to be discarded.
359 - Fix __VA_OPT__ implementation so that it treats the concatenation of a
360   non-placemaker token and placemaker token as a non-placemaker token.
361   (`#60268 <https://github.com/llvm/llvm-project/issues/60268>`_)
362 - Fix crash when taking the address of a consteval lambda call operator.
363   (`#57682 <https://github.com/llvm/llvm-project/issues/57682>`_)
364 - Clang now support export declarations in the language linkage.
365   (`#60405 <https://github.com/llvm/llvm-project/issues/60405>`_)
366 - Fix aggregate initialization inside lambda constexpr.
367   (`#60936 <https://github.com/llvm/llvm-project/issues/60936>`_)
368 - No longer issue a false positive diagnostic about a catch handler that cannot
369   be reached despite being reachable. This fixes
370   `#61177 <https://github.com/llvm/llvm-project/issues/61177>`_ in anticipation
371   of `CWG2699 <https://wg21.link/CWG2699>_` being accepted by WG21.
372 - Fix crash when parsing fold expression containing a delayed typo correction.
373   (`#61326 <https://github.com/llvm/llvm-project/issues/61326>`_)
374 - Fix crash when dealing with some member accesses outside of class or member
375   function context.
376   (`#37792 <https://github.com/llvm/llvm-project/issues/37792>`_) and
377   (`#48405 <https://github.com/llvm/llvm-project/issues/48405>`_)
378 - Fix crash when using ``[[clang::always_inline]]`` or ``[[clang::noinline]]``
379   statement attributes on a call to a template function in the body of a
380   template function.
381 - Fix coroutines issue where ``get_return_object()`` result was always eagerly
382   converted to the return type. Eager initialization (allowing RVO) is now only
383   performed when these types match, otherwise deferred initialization is used,
384   enabling short-circuiting coroutines use cases. This fixes
385   (`#56532 <https://github.com/llvm/llvm-project/issues/56532>`_) in
386   anticipation of `CWG2563 <https://cplusplus.github.io/CWG/issues/2563.html>_`.
387 - Fix highlighting issue with ``_Complex`` and initialization list with more than
388   2 items. (`#61518 <https://github.com/llvm/llvm-project/issues/61518>`_)
389 - Fix  ``getSourceRange`` on  ``VarTemplateSpecializationDecl`` and
390   ``VarTemplatePartialSpecializationDecl``, which represents variable with
391   the initializer, so it behaves consistently with other ``VarDecls`` and ends
392   on the last token of initializer, instead of right angle bracket of
393   the template argument list.
394 - Fix false-positive diagnostic issued for consteval initializers of temporary
395   objects.
396   (`#60286 <https://github.com/llvm/llvm-project/issues/60286>`_)
397 - Correct restriction of trailing requirements clauses on a templated function.
398   Previously we only rejected non-'templated' things, but the restrictions ALSO need
399   to limit non-defined/non-member functions as well. Additionally, we now diagnose
400   requires on lambdas when not allowed, which we previously missed.
401   (`#61748 <https://github.com/llvm/llvm-project/issues/61748>`_)
402 - Fix confusing diagnostic for incorrect use of qualified concepts names.
403 - Fix handling of comments in function like macros so they are ignored in -CC
404   mode.
405   (`#60887 <https://github.com/llvm/llvm-project/issues/60887>`_)
406 - Fix incorrect merging of lambdas across modules.
407   (`#60985 <https://github.com/llvm/llvm-project/issues/60985>`_)
408 - Fix crash when handling nested immediate invocations in initializers of global
409   variables.
410   (`#58207 <https://github.com/llvm/llvm-project/issues/58207>`_)
411 - Fix crash when generating code coverage information for `PseudoObjectExpr` in
412   Clang AST.
413   (`#45481 <https://github.com/llvm/llvm-project/issues/45481>`_)
414 - Fix the assertion hit when a template consteval function appears in a nested
415   consteval/constexpr call chain.
416   (`#61142 <https://github.com/llvm/llvm-project/issues/61142>`_)
417 - Clang now better diagnose placeholder types constrained with a concept that is
418   not a type concept.
419 - Fix crash when a doc comment contains a line splicing.
420   (`#62054 <https://github.com/llvm/llvm-project/issues/62054>`_)
421 - Work around with a clang coverage crash which happens when visiting
422   expressions/statements with invalid source locations in non-assert builds.
423   Assert builds may still see assertions triggered from this.
424 - Fix a failed assertion due to an invalid source location when trying to form
425   a coverage report for an unresolved constructor expression.
426   (`#62105 <https://github.com/llvm/llvm-project/issues/62105>`_)
427 - Fix defaulted equality operator so that it does not attempt to compare unnamed
428   bit-fields. This fixes:
429   (`#61355 <https://github.com/llvm/llvm-project/issues/61335>`_) and
430   (`#61417 <https://github.com/llvm/llvm-project/issues/61417>`_)
431 - Fix crash after suggesting typo correction to constexpr if condition.
432   (`#61885 <https://github.com/llvm/llvm-project/issues/61885>`_)
433 - Clang constexpr evaluator now treats comparison of [[gnu::weak]]-attributed
434   member pointer as an invalid expression.
435 - Fix crash when member function contains invalid default argument.
436   (`#62122 <https://github.com/llvm/llvm-project/issues/62122>`_)
437 - Fix crash when handling undefined template partial specialization
438   (`#61356 <https://github.com/llvm/llvm-project/issues/61356>`_)
439 - Fix premature substitution into the constraints of an inherited constructor.
440 - Fix crash when attempting to perform parenthesized initialization of an
441   aggregate with a base class with only non-public constructors.
442   (`#62296 <https://github.com/llvm/llvm-project/issues/62296>`_)
443 - Fix crash when handling initialization candidates for invalid deduction guide.
444   (`#62408 <https://github.com/llvm/llvm-project/issues/62408>`_)
445 - Fix crash when redefining a variable with an invalid type again with an
446   invalid type. (`#62447 <https://github.com/llvm/llvm-project/issues/62447>`_)
447 - Fix a stack overflow issue when evaluating ``consteval`` default arguments.
448   (`#60082` <https://github.com/llvm/llvm-project/issues/60082>`_)
449 - Fix the assertion hit when generating code for global variable initializer of
450   _BitInt(1) type.
451   (`#62207 <https://github.com/llvm/llvm-project/issues/62207>`_)
452 - Fix lambdas and other anonymous function names not respecting ``-fdebug-prefix-map``
453   (`#62192 <https://github.com/llvm/llvm-project/issues/62192>`_)
454 - Fix crash when attempting to pass a non-pointer type as first argument of
455   ``__builtin_assume_aligned``.
456   (`#62305 <https://github.com/llvm/llvm-project/issues/62305>`_)
457 - A default argument for a non-type template parameter is evaluated and checked
458   at the point where it is required. This fixes:
459   (`#62224 <https://github.com/llvm/llvm-project/issues/62224>`_) and
460   (`#62596 <https://github.com/llvm/llvm-project/issues/62596>`_)
461 - Fix an assertion when instantiating the body of a Class Template Specialization
462   when it had been instantiated from a partial template specialization with different
463   template arguments on the containing class. This fixes:
464   (`#60778 <https://github.com/llvm/llvm-project/issues/60778>`_).
465 - Fix a crash when an enum constant has a dependent-type recovery expression for
466   C.
467   (`#62446 <https://github.com/llvm/llvm-project/issues/62446>`_).
468 - Propagate the value-dependent bit for VAArgExpr. Fixes a crash where a
469   __builtin_va_arg call has invalid arguments.
470   (`#62711 <https://github.com/llvm/llvm-project/issues/62711>`_).
471 - Fix crash on attempt to initialize union with flexible array member.
472   (`#61746 <https://github.com/llvm/llvm-project/issues/61746>`_).
473 - Clang `TextNodeDumper` enabled through `-ast-dump` flag no longer evaluates the
474   initializer of constexpr `VarDecl` if the declaration has a dependent type.
475 - Match GCC's behavior for ``__builtin_object_size`` and
476   ``__builtin_dynamic_object_size`` on structs containing flexible array
477   members.
478   (`#62789 <https://github.com/llvm/llvm-project/issues/62789>`_).
479 - Fix a crash when instantiating a non-type template argument in a dependent scope.
480   (`#62533 <https://github.com/llvm/llvm-project/issues/62533>`_).
481 - Fix crash when diagnosing default comparison method.
482   (`#62791 <https://github.com/llvm/llvm-project/issues/62791>`_) and
483   (`#62102 <https://github.com/llvm/llvm-project/issues/62102>`_).
484 - Fix crash when passing a braced initializer list to a parentehsized aggregate
485   initialization expression.
486   (`#63008 <https://github.com/llvm/llvm-project/issues/63008>`_).
487 - Reject increment of bool value in unevaluated contexts after C++17.
488   (`#47517 <https://github.com/llvm/llvm-project/issues/47517>`_).
489 - Fix assertion and quality of diagnostic messages in a for loop
490   containing multiple declarations and a range specifier
491   (`#63010 <https://github.com/llvm/llvm-project/issues/63010>`_).
492 - Fix rejects-valid when consteval operator appears inside of a template.
493   (`#62886 <https://github.com/llvm/llvm-project/issues/62886>`_).
494 - Fix crash for code using ``_Atomic`` types in C++
495   (`See patch <https://reviews.llvm.org/D152303>`_).
496 - Fix crash when passing a value larger then 64 bits to the aligned attribute.
497   (`#50534 <https://github.com/llvm/llvm-project/issues/50534>`_).
498 - CallExpr built for C error-recovery now is always type-dependent. Fixes a
499   crash when we encounter a unresolved TypoExpr during diagnostic emission.
500   (`#50244 <https://github.com/llvm/llvm-project/issues/50244>_`).
502 Bug Fixes to Compiler Builtins
503 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
505 Bug Fixes to Attribute Support
506 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
507 - Fixed a bug where attribute annotations on type specifiers (enums, classes,
508   structs, unions, and scoped enums) were not properly ignored, resulting in
509   misleading warning messages. Now, such attribute annotations are correctly
510   ignored. (`#61660 <https://github.com/llvm/llvm-project/issues/61660>`_)
511 - GNU attributes preceding C++ style attributes on templates were not properly
512   handled, resulting in compilation error. This has been corrected to match the
513   behavior exhibited by GCC, which permits mixed ordering of GNU and C++
514   attributes.
516 Bug Fixes to C++ Support
517 ^^^^^^^^^^^^^^^^^^^^^^^^
519 - Fix crash on invalid code when looking up a destructor in a templated class
520   inside a namespace.
521   (`#59446 <https://github.com/llvm/llvm-project/issues/59446>`_)
522 - Fix crash when evaluating consteval constructor of derived class whose base
523   has more than one field.
524   (`#60166 <https://github.com/llvm/llvm-project/issues/60166>`_)
525 - Fix an issue about ``decltype`` in the members of class templates derived from
526   templates with related parameters.
527   (`#58674 <https://github.com/llvm/llvm-project/issues/58674>`_)
528 - Fix incorrect deletion of the default constructor of unions in some
529   cases. (`#48416 <https://github.com/llvm/llvm-project/issues/48416>`_)
530 - No longer issue a pre-C++23 compatibility warning in ``-pedantic`` mode
531   regarding overloaded `operator[]` with more than one parameter or for static
532   lambdas. (`#61582 <https://github.com/llvm/llvm-project/issues/61582>`_)
533 - Stop stripping CV qualifiers from the type of ``this`` when capturing it by value in
534   a lambda.
535   (`#50866 <https://github.com/llvm/llvm-project/issues/50866>`_)
536 - Fix ordering of function templates by constraints when they have template
537   template parameters with different nested constraints.
538 - Fix type equivalence comparison between auto types to take constraints into
539   account.
540 - Fix bug in the computation of the ``__has_unique_object_representations``
541   builtin for types with unnamed bitfields.
542   (`#61336 <https://github.com/llvm/llvm-project/issues/61336>`_)
543 - Fix default member initializers sometimes being ignored when performing
544   parenthesized aggregate initialization of templated types.
545   (`#62266 <https://github.com/llvm/llvm-project/issues/62266>`_)
546 - Fix overly aggressive lifetime checks for parenthesized aggregate
547   initialization.
548   (`#61567 <https://github.com/llvm/llvm-project/issues/61567>`_)
549 - Fix a crash when expanding a pack as the index of a subscript expression.
550 - Fix handling of constexpr dynamic memory allocations in template
551   arguments. (`#62462 <https://github.com/llvm/llvm-project/issues/62462>`_)
552 - Some predefined expressions are now treated as string literals in MSVC
553   compatibility mode.
554   (`#114 <https://github.com/llvm/llvm-project/issues/114>`_)
555 - Fix parsing of `auto(x)`, when it is surrounded by parentheses.
556   (`#62494 <https://github.com/llvm/llvm-project/issues/62494>`_)
557 - Fix handling of generic lambda used as template arguments.
558   (`#62611 <https://github.com/llvm/llvm-project/issues/62611>`_)
559 - Allow omitting ``typename`` in the parameter declaration of a friend
560   constructor declaration.
561   (`#63119 <https://github.com/llvm/llvm-project/issues/63119>`_)
562 - Fix access of a friend class declared in a local class. Clang previously
563   emitted an error when a friend of a local class tried to access it's
564   private data members.
565 - Allow abstract parameter and return types in functions that are
566   either deleted or not defined.
567   (`#63012 <https://github.com/llvm/llvm-project/issues/63012>`_)
569 Bug Fixes to AST Handling
570 ^^^^^^^^^^^^^^^^^^^^^^^^^
572 - Preserve ``namespace`` definitions that follow malformed declarations.
574 Miscellaneous Bug Fixes
575 ^^^^^^^^^^^^^^^^^^^^^^^
577 Miscellaneous Clang Crashes Fixed
578 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
580 - Dumping the AST to JSON no longer causes a failed assertion when targetting
581   the Microsoft ABI and the AST to be dumped contains dependent names that
582   would not typically be mangled.
583   (`#61440 <https://github.com/llvm/llvm-project/issues/61440>`_)
585 Target Specific Changes
586 -----------------------
588 AMDGPU Support
589 ^^^^^^^^^^^^^^
591 - Linking for AMDGPU now uses ``--no-undefined`` by default. This causes
592   undefined symbols in the created module to be a linker error. To prevent this,
593   pass ``-Wl,--undefined`` if compiling directly, or ``-Xoffload-linker
594   --undefined`` if using an offloading language.
595 - The deprecated ``-mcode-object-v3`` and ``-mno-code-object-v3`` command-line
596   options have been removed.
597 - A new option ``-mprintf-kind`` has been introduced that controls printf lowering
598   scheme. It is currently supported only for HIP and takes following values,
599   ``hostcall`` - printing happens during kernel execution via series of hostcalls,
600   The scheme requires the system to support pcie atomics.(default)
601   ``buffered`` - Scheme uses a debug buffer to populate printf varargs, does not
602   rely on pcie atomics support.
604 X86 Support
605 ^^^^^^^^^^^
607 - Add ISA of ``AMX-COMPLEX`` which supports ``tcmmimfp16ps`` and
608   ``tcmmrlfp16ps``.
610 Arm and AArch64 Support
611 ^^^^^^^^^^^^^^^^^^^^^^^
613 - The hard-float ABI is now available in Armv8.1-M configurations that
614   have integer MVE instructions (and therefore have FP registers) but
615   no scalar or vector floating point computation. Previously, trying
616   to select the hard-float ABI on such a target (via
617   ``-mfloat-abi=hard`` or a triple ending in ``hf``) would silently
618   use the soft-float ABI instead.
620 - Clang builtin ``__arithmetic_fence`` and the command line option ``-fprotect-parens``
621   are now enabled for AArch64.
623 - Clang supports flag output operands by which conditions in the NZCV could be outputs
624   of inline assembly for AArch64. This change is more consistent with the behavior of
625   GCC.
627    .. code-block:: c
629      // int a = foo(); int* b = bar();
630      asm("ands %w[a], %w[a], #3" : [a] "+r"(a), "=@cceq"(*b));
632 - Fix a crash when ``preserve_all`` calling convention is used on AArch64.
633   `Issue 58145 <https://github.com/llvm/llvm-project/issues/58145>`_
635 Windows Support
636 ^^^^^^^^^^^^^^^
638 LoongArch Support
639 ^^^^^^^^^^^^^^^^^
641 - Patchable function entry (``-fpatchable-function-entry``) is now supported
642   on LoongArch.
644 RISC-V Support
645 ^^^^^^^^^^^^^^
646 - Added ``-mrvv-vector-bits=`` option to give an upper and lower bound on vector
647   length. Valid values are powers of 2 between 64 and 65536. A value of 32
648   should eventually be supported. We also accept "zvl" to use the Zvl*b
649   extension from ``-march`` or ``-mcpu`` to the be the upper and lower bound.
650 - Fixed incorrect ABI lowering of ``_Float16`` in the case of structs
651   containing ``_Float16`` that are eligible for passing via GPR+FPR or
652   FPR+FPR.
653 - Removed support for ``__attribute__((interrupt("user")))``. User-level
654   interrupts are not in version 1.12 of the privileged specification.
655 - Added ``attribute(riscv_rvv_vector_bits(__riscv_v_fixed_vlen))`` to allow
656   the size of a RVV (RISC-V Vector) scalable type to be specified. This allows
657   RVV scalable vector types to be used in structs or in global variables.
659 CUDA/HIP Language Changes
660 ^^^^^^^^^^^^^^^^^^^^^^^^^
662 CUDA Support
663 ^^^^^^^^^^^^
664 - Clang now supports CUDA SDK up to 12.1
666 AIX Support
667 ^^^^^^^^^^^
668 - Add an AIX-only link-time option, `-mxcoff-build-id=0xHEXSTRING`, to allow users
669   to embed a hex id in their binary such that it's readable by the program itself.
670   This option is an alternative to the `--build-id=0xHEXSTRING` GNU linker option
671   which is currently not supported by the AIX linker.
673 - Introduced the ``-mxcoff-roptr`` option to place constant objects with
674   relocatable address values in the read-only data section. This option should
675   be used with the ``-fdata-sections`` option, and is not supported with
676   ``-fno-data-sections``. When ``-mxcoff-roptr`` is in effect at link time,
677   read-only data sections with relocatable address values that resolve to
678   imported symbols are made writable.
680 WebAssembly Support
681 ^^^^^^^^^^^^^^^^^^^
683 AVR Support
684 ^^^^^^^^^^^
685 - The definition of ``USHRT_MAX`` in the freestanding ``<limits.h>`` no longer
686   overflows on AVR (where ``sizeof(int) == sizeof(unsigned short)``).  The type
687   of ``USHRT_MAX`` is now ``unsigned int`` instead of ``int``, as required by
688   the C standard.
690 DWARF Support in Clang
691 ----------------------
693 Floating Point Support in Clang
694 -------------------------------
695 - Add ``__builtin_elementwise_log`` builtin for floating point types only.
696 - Add ``__builtin_elementwise_log10`` builtin for floating point types only.
697 - Add ``__builtin_elementwise_log2`` builtin for floating point types only.
698 - Add ``__builtin_elementwise_exp`` builtin for floating point types only.
699 - Add ``__builtin_elementwise_exp2`` builtin for floating point types only.
700 - Add ``__builtin_set_flt_rounds`` builtin for X86, x86_64, Arm and AArch64 only.
702 AST Matchers
703 ------------
705 - Add ``coroutineBodyStmt`` matcher.
707 - The ``hasBody`` matcher now matches coroutine body nodes in
708   ``CoroutineBodyStmts``.
710 clang-format
711 ------------
713 - Add ``NextLineOnly`` style to option ``PackConstructorInitializers``.
714   Compared to ``NextLine`` style, ``NextLineOnly`` style will not try to
715   put the initializers on the current line first, instead, it will try to
716   put the initializers on the next line only.
717 - Add additional Qualifier Ordering support for special cases such
718   as templates, requires clauses, long qualified names.
719 - Fix all known issues associated with ``LambdaBodyIndentation: OuterScope``.
720 - Add ``BracedInitializerIndentWidth`` which can be used to configure
721   the indentation level of the contents of braced init lists.
722 - Add ``KeepEmptyLinesAtEOF`` to keep empty lines at end of file.
724 libclang
725 --------
727 - Introduced the new function ``clang_CXXMethod_isExplicit``,
728   which identifies whether a constructor or conversion function cursor
729   was marked with the explicit identifier.
731 - Introduced the new ``CXIndex`` constructor function
732   ``clang_createIndexWithOptions``, which allows storing precompiled preambles
733   in memory or overriding the precompiled preamble storage path.
735 - Deprecated two functions ``clang_CXIndex_setGlobalOptions`` and
736   ``clang_CXIndex_setInvocationEmissionPathOption`` in favor of the new
737   function ``clang_createIndexWithOptions`` in order to improve thread safety.
739 - Added check in ``clang_getFieldDeclBitWidth`` for whether a bit-field
740   has an evaluable bit width. Fixes undefined behavior when called on a
741   bit-field whose width depends on a template parameter.
743 - Added ``CXBinaryOperatorKind`` and ``CXUnaryOperatorKind``.
744   (`#29138 <https://github.com/llvm/llvm-project/issues/29138>`_)
746 Static Analyzer
747 ---------------
748 - Fix incorrect alignment attribute on the this parameter of certain
749   non-complete destructors when using the Microsoft ABI.
750   (`#60465 <https://github.com/llvm/llvm-project/issues/60465>`_)
752 .. _release-notes-sanitizers:
754 Sanitizers
755 ----------
757 Python Binding Changes
758 ----------------------
759 The following methods have been added:
761 - ``clang_Location_isInSystemHeader`` exposed via the ``is_in_system_header``
762   property of the `Location` class.
764 Additional Information
765 ======================
767 A wide variety of additional information is available on the `Clang web
768 page <https://clang.llvm.org/>`_. The web page contains versions of the
769 API documentation which are up-to-date with the Git version of
770 the source code. You can access versions of these documents specific to
771 this release by going into the "``clang/docs/``" directory in the Clang
772 tree.
774 If you have any questions or comments about Clang, please feel free to
775 contact us on the `Discourse forums (Clang Frontend category)
776 <https://discourse.llvm.org/c/clang/6>`_.